🚀 Check out the ROS2 version: Nicla Vision ROS2 repository 🚀
This ROS package enables the Arduino Nicla Vision board to be ready-to-use in the ROS world! 💥
The implemented architecture is described in the above image: the Arduino Nicla Vision board streams the sensors data to a ROS-running machine through TCP/UDP socket. This package will be running on the ROS-running machine, allowing to deserialize the received info, and stream it in the corresponding ROS topics
Here a list of the available sensors with their respective ROS topics:
- 2MP color camera streams on
/nicla/camera/camera_info
/nicla/camera/image_raw
/nicla/camera/image_raw/compressed
- Time-of-Flight (distance) sensor streams on:
/nicla/tof
- Microphone streams on:
/nicla/audio
/nicla/audio_info
/nicla/audio_stamped
/nicla/audio_recognized
- Imu streams on:
/nicla/imu
The user can easily configure this package, by launch parameters, to receive sensors data via either UDP or TCP socket connections, specifying also the socket IP address. Moreover, the user can decide which sensor to be streamed within the ROS environment. In this repository you can find the Python code optimised for receiving the data by the board, and subsequently publishing it through ROS topics.
Step-by-step instructions on how to get the ROS package running
Binaries available for noetic
:
sudo apt install ros-$ROS_DISTRO-nicla-vision-ros
For ROS2, check https://github.com/ADVRHumanoids/nicla_vision_ros2.git
Usual catkin
build :
$ cd <your_workpace>/src
$ git clone https://github.com/ADVRHumanoids/nicla_vision_ros.git
$ cd <your_workpace>
$ catkin build
$ source <your_workpace>/devel/setup.bash
After having completed the setup steps in the Nicla Vision Drivers repository, just turn on your Arduino Nicla Vision. When you power on your Arduino Nicla Vision, it will automatically connect to the network and it will start streaming to your ROS-running machine.
It is possible to run a speech recognition feature directly on this module, that will then publish the recognized words on the /nicla/audio_recognized
topic. At the moment, VOSK is utilized. Only Arduino version is supported.
pip install vosk
- Download a VOSK model https://alphacephei.com/vosk/models
- Check the
recognition
arguments in thenicla_receiver.launch
file
Follow the below steps for enjoying your Arduino Nicla Vision board with ROS!
-
Launch the package:
$ roslaunch nicla_vision_ros nicla_receiver.launch receiver_ip:="x.x.x.x" connection_type:="tcp/udp" <optional arguments>
- Set the
receiver_ip
with the IP address of your ROS-running machine. You can get this IP address by executing the following command:and taking the "inet" address under the "enp" voice.$ ifconfig
- Set the socket type to be used, either TCP or UDP (
connection_type:="tcp"
or"udp"
).
Furthermore, using the
<optional arguments>
, you can decide:-
which sensor to be streamed in ROS
(e.g.
enable_imu:=true enable_range:=true enable_audio:=true enable_audio_stamped:=false enable_camera_compressed:=true enable_camera_raw:=true
), and -
on which socket port (default
receiver_port:=8002
).
Once you run it, you will be ready for receiving the sensors data
- Set the
- For simulating the Arduino Nicla Vision in Gazebo and Rviz:
Using the
$ roslaunch nicla_vision_ros nicla_sim.launch <optional arguments>
<optional arguments>
, you can decide if to run the simulation in Gazebo or in Rviz, and which sensor to simulate (everything set to true as default).
Note this version is not supported and maintained anymore, we defitively moved to the Arduino version.
If you want to use the micropython driver of the nicla (after setup it accordingly), simply run the nicla_receiver.launch
with driver_version:=micropython
as argument.
CentauroDaganaNicla.mp4
Here some useful links:
Distributed under the Apache-2.0 License. See LICENSE for more information.
🙌 If you use this work or take inspiration from it, please cite (publication in progress):
@inproceedings{delbianco2024dagana,
title={},
author={},
booktitle={},
year={}
}