Skip to main content

NS2 Installation in Ubuntu 22.04

How to write Publisher Subscriber in ROS Noetic | Step by Step instructions

ROS1 Noetic -Publisher and Subscriber Example

This post tells about the implementation of a publisher and a subscriber in ROS Noetic.  


In this example, we have considered the following:
Example 1: 
One publisher (pub.py) and one Subscriber (Sub.py)
Topic: first_lecture
Message: String Message 

Example 2:
Two publishers (pub.py and pub1.py) and
Two subscribers (sub.py and sub1.py)
Topic: first_lecture 

See the following video for step by step instructions for running this example:



The following picture shows the nodes (The picture is taken by running the rqt_graph command)
ROS Noetic
Publisher Subscriber in ROS Noetic


How to run in ROS Noetic

Prerequsities 
1. Ubuntu Basic commands
2. PATH Setting in Ubuntu
3. Basic knowledge of Linux 
4. Programming fundamentals

To Install ROS1 Noetic in Ubuntu 20.04, you can refer the following video in my channel.


ROS is enabled with a catkin make system which perform the easier build operation and cross compilation enablement.

Create a workspace to store all our files.

/home/pradeepkumar/pradeep_ws 

To create a workspace:
Open a terminal 

$ mkdir -p pradeep_ws/src
$ cd pradeep_ws/
$ catkin_make 

Then set the path 
Copy the following line in the /home/pradeepkumar/.bashrc file 

source /home/pradeepkumar/pradeep_ws/devel/setup.bash

]alternative way to set the environment, but for every terminal to be opened, we need to do the following step.
$ source $HOME/pradeep_ws/devel/setup.bash

To create a Catkin package, here is the command
$ cd pradeep_ws/src

$ catkin_create_pkg ros_tutorial1 rospy std_msgs

$ cd pradeep_ws/src/ros_tutorial1

$ mkdir script

create the pub.py, pub1.py, sub.py and sub1.py (You can download the source code from https://github.com/tspradeepkumar/ROSNoteic 

$ chmod 777 *.py

ROS Noetic runs always with a master that means it should run roscore to run all the ros applications.

You need to open 5 Terminals and give the commands in each of the terminals
  • $ roscore
  • $ rosrun ros_tutorial1 pub.py
  • $ rosrun ros_tutorial1 pub1.py
  • $ rosrun ros_tutorial1 sub.py
  • $ rosrun ros_tutorial1 sub1.py

Open a terminal and run the command roscore
$ roscore

Open another terminal for publisher  and run the following command 

$ rosrun ros_tutorial1 pub.py
You will get the output as ROS Noetic World

If ros_tutorial1 is not found, then set the following command and try again 

$ source $HOME/pradeep_ws/devel/setup.bash

Open one more ternminal for the subscriber and run the following command 

$ rosrun ros_tutorial1 sub.py
You will get the output as I learn about ROS Noetic World. 

Run the following command to know about the graph 
$ rqt_graph 

You can see the following graph (You need to untick the Debug checkbox, to see the complete nodes running in ROS Noetic) 

ROS Noetic
ROS Noetic Pub Sub


Comments

Popular posts from this blog

Installation of NS2 (ns-2.35) in Ubuntu 20.04

Installation of NS2 (ns-2.35) in Ubuntu 20.04 LTS Step 1: Install the basic libraries like      $] sudo apt install build-essential autoconf automake libxmu-dev Step 2: install gcc-4.8 and g++-4.8 open the file using sudo mode $] sudo nano /etc/apt/sources.list Include the following line deb http://in.archive.ubuntu.com/ubuntu bionic main universe $] sudo apt update $] sudo apt install gcc-4.8 g++-4.8 Step 3:  Unzip the ns2 packages to home folder $] tar zxvf ns-allinone-2.35.tar.gz $] cd ns-allinone-2.35/ns-2.35 Modify the following make files. ~ns-2.35/Makefile.in Change @CC@ to gcc-4.8 change @CXX@ to g++-4.8 ~nam-1.15/Makefile.in ~xgraph-12.2/Makefile.in ~otcl-1.14/Makefile.in Change in all places  @CC@ to gcc-4.8 @CPP@ or @CXX@ to g++-4.8 open the file: ~ns-2.35/linkstate/ls.h Change at the Line no 137  void eraseAll() { erase(baseMap::begin(), baseMap::end()); } to This void eraseAll() { this->erase(baseMap::begin(), baseMap::end()); } All changes made Step 4: Open a new termi

Installing ns3 in Ubuntu 22.04 | Complete Instructions

In this post, we are going to see how to install ns-3.36.1 in Ubuntu 22.04. You can follow the video for complete details Tools used in this simulation: NS3 version ns-3.36.1  OS Used: Ubuntu 22.04 LTS Installation of NS3 (ns-3.36.1) There are some changes in the ns3 installation procedure and the dependencies. So open a terminal and issue the following commands Step 1:  Prerequisites $ sudo apt update In the following packages, all the required dependencies are taken care and you can install all these packages for the complete use of ns3. $ sudo apt install g++ python3 python3-dev pkg-config sqlite3 cmake python3-setuptools git qtbase5-dev qtchooser qt5-qmake qtbase5-dev-tools gir1.2-goocanvas-2.0 python3-gi python3-gi-cairo python3-pygraphviz gir1.2-gtk-3.0 ipython3 openmpi-bin openmpi-common openmpi-doc libopenmpi-dev autoconf cvs bzr unrar gsl-bin libgsl-dev libgslcblas0 wireshark tcpdump sqlite sqlite3 libsqlite3-dev  libxml2 libxml2-dev libc6-dev libc6-dev-i386 libclang-dev llvm-

VPL Jail Server Installation | Virtual Programming Laboratory with Moodle

Virtual Programming Laboratory (VPL)  This post tells you how to install VPL Jail Server Installation in Ubuntu 20.04 and how to configure it using Moodle Learning Management System. VPL - Virtual Programming Laboratory  For full installation with complete description, follow the video What is VPL? VPL is Virtual Programming Laboratory which is a tool for programming assignments, evaluation and running of programs. The programming languages supported by VPL is C, C++, Java, Python, Perl, PHP, NodeJS, Verilog, etc. Step 1 - Install  VPN Jail Server Installation  My Server configuration  16GB RAM and 16 Core PRocessor (Intel Xeon)  Virtual Machine  Ubuntu 20.04 (64 bit OS). To download the softwares  https://vpl.dis.ulpgc.es/index.php/home/download  Unzip or untar the above file in the home folder (in my case it is /home/tspradeepkumar/ ) $ cd vpl-jail-system-2.7.2/ $ sudo ./install-vpl-sh VPL Jail Server Installation This will take some time based on your internet connection: To Star