How to use rosserial with two Arduinos and Raspberry Pi

Arduino is a good development board for reading data from various sensors and for controlling the robot’s DC motors. Raspberry Pi is a very good Linux computer running ROS. To benefit from both systems, the easiest way is to connect and make them communicate through ROS nodes.

In this tutorial, I’ll show you how to use two Arduino boards as an extension of the Raspberry Pi computer. For this tutorial, you need Raspberry Pi to be able to identify each Arduino board. Such a system becomes necessary when the robot’s architecture is complex.

At one time, only one ROS node can run on an Arduino board. So in this tutorial, I will use one of the two Arduino boards to generate a random number, and a second Arduino board to control the LED connected to pin 13. On both boards, I will run one ROS node that will send or receive data according to the chart below.

How To use rosserial with Two Arduinos and Raspberry Pi

How To use rosserial with Two Arduinos and Raspberry Pi

The description of the structure

  • The user will start all ROS nodes by running a .launch file.
  • The first Arduino board will run a random number script and send data to Raspberry Pi.
  • A ROS node will receive a random number from the first Arduino board. The node will run on Raspberry Pi and will command the LED on the second Arduino board.
  • The second Arduino board will turn ON and OFF the LED (pin 13) depending on the commands received from the ROS node running on the Pi board.

The ROS node for random number generation

#include <ros.h>
#include <ros/time.h>
#include <std_msgs/Int32.h>

int min=1;
int max=5000;
int rand_no;

ros::NodeHandle nh;
std_msgs::Int32 rand_msg;
ros::Publisher pub_random("/random_number", &rand_msg);

char frameid[] = "/randomData";

#this function returns the random number
int random_number(){
rand_no= random(min, max);
return rand_no;

void setup() {

void loop() {;

Testing the node
Step 1: Open a Linux Terminal and type the command:


Step 2: Open a second Linux Terminal and type the following command:

rosrun rosserial_python /dev/ttyACM*

Step 3: To see the random numbers generated by the Arduino node, open a third Terminal and type the following command:

rostopic echo /random_number

The ROS node that displays and calculates the LED’s stage

This node will run on Raspberry Pi and will be a ROS node in Python. Before you start writing the Python code, you must create the workspace and the package that contains the node. The necessary steps can be found in this article.

#!/usr/bin/env python

import rospy

from std_msgs.msg import Int32
from std_msgs.msg import String


#define the display text
def callback(msg):
    global var

if __name__=='__main__':
 rospy.Subscriber('random_number',Int32, callback)
 pub=rospy.Publisher('LED', String, queue_size=1)

while not rospy.is_shutdown():
     if var<=2500:
        #send message to turn OFF the LED
          rospy.loginfo("The output is OFF and the var is: %s", var)
        #send message to turn ON the LED
         rospy.loginfo("The output is ON and the var is: %s", var)


The ROS node that controls the LED

#include <ros.h>
#include <std_msgs/String.h>

ros::NodeHandle nh;

void messageCb(const std_msgs::String& msg)
  if( =="ON")
    digitalWrite(13, HIGH-digitalRead(13));   //blink the led
   digitalWrite(13, LOW-digitalRead(13));   //turn off the led

ros::Subscriber sub("OFF", &messageCb);

void setup()
  pinMode(13, OUTPUT);

void loop()

Write the launch file

<node pkg=”rosserial_python” type=”” name=”twoArduino_LED” output=”screen”>
<param name=”port” value=”/dev/ttyACM0″/>
<param name=”baud” value=”57600″/>
<node pkg=”rosserial_python” type=”” name=”twoArduinos_RandNo” output=”screen”>
<param name=”port” value=”/dev/ttyACM1″/>
<param name=”baud” value=”57600″/>
<node name=”random_number” pkg=”pi_and_arduino” type=”” output=”screen” />



Commerce Content is independent of articles and advertising, and if you buy something through our posts, I may get a small share of the sale.

1 comment » Write a comment

Leave a Reply

Required fields are marked *.