This repo extends the ROS interfaces for the Ultra-Wideband (UWB) Real Time Locatin System (RTLS) demo of Decawave's MDEK1001 Dev-boards provided by TIERS and Mub @20chix for the purpose of tracking and visualizing multiple tags in ROS environment. Additionally, we added the Kalman filter on top of the previous works to smoothen the positioning data from the UWB device before sending them as ROS topics. Moreover, we provide the ROS interface for the UWB tracking demo based on TREK1000/EVK1000 Dev-boards, which we wrote it from scratch, in this repo. The code has been tested under Ubuntu 20.04 LTS with ROS Noetic Ninjemys distribution. It should be noted that this is a work-in-progress research repo and some parts are still in developing states.
This project has been originated as a supplementary sub-project for CITrack in Cognitronics and Sensor Systems Research Group, CITEC, Bielefeld University.
For the ROS2 use case of this repository, please refer to this link, provided and tested by Lauritz. Alternatively, you can also directly check out to the ros2 branch within this repo.
- Clone this repo into your catkin workspace (see installation section)
- Plug the USB cable of the tag acting as either a listener node or gateway node into your machine
- Check the name of the USB in your machine (typically it is /dev/ttyACM0 in Ubuntu if no other USB is connected into it)
- Give read-write permission to your USB (i.e., sudo chmod 777 /dev/<your_USB_port> or add it into the user group dialout)
- Make sure that RTLS is working on the app from the grid view according to the instruction in 'Getting Started' section
- Install the stlink-tools to connect the Dev-board via USB
sudo apt install stlink-tools
- If you are using virtual machine via Windows as a host, STM32 Virtual COM Port Driver is necessary to install on the host in some cases.
- Plug the USB cable of the coordinator node (Achor 0) into your machine
- Give read-write permission to your USB (typically it is /dev/ttyACM0 in Ubuntu if no other USBs are connected)
Clone this repo into your catkin workspace and install the dependencies if required
rosdep install --from-paths src --ignore-src -r -y
pip install pyserial
pip install numpy
Build the workspace:
cd ~/<your_catkin_workspace>
catkin_make
Then, run the respetive launch file.
roslaunch <your_ros_package>/ <your_launch_file>
For instance, run the following launch file for the DWM1001 multiple tags tracking scenario:
roslaunch uwb_tracking_ros uwb_tracking_dwm1001.launch
Follow the steps in Decawave's DRTLS Guide to setup a Real Time Location System (RTLS) system with at least 3 anchors and 1 active node using DWM1001-dev board ( in our case, we use MDEK1001 hardware setup). An android phone or a tablet is required to set-up the RTLS using DRTLS andriod app.
The UWB node can be set-up as an anchor, a tag, and listener modes. This repo requires the listener node (or) gateway node to be attached into the PC or remote machine where ROS is running. The task of the listener node is echoing the positioning data of tags that it has heard. Only position data (x, y, z) of the tags in 3D are able to process via listener node (i.e., the ranging data are not available). To set-up the node as a listener, simply switch the dedicated UWB node to a 'passive' mode in the Decawave's RTLS app.
The update rate of the tag's position can be adjusted within the Decawave's app. However, we recommend setting the update rate to 10 Hz (100 ms).
The following is a sample visualization screenshot of two tags on rviz in 3D
Follow the set-up instructions given for TREK1000 by Decawave. Then, connect the coordinator node (i.e., Anchor 0 in TREK1000) into your machine where ROS is availalbe via USB port. Run the launch file related to TREK1000 from this repo and process further as your requirments. It should be noted that the tag node can also be connected into the your machine. In this case, the scenario will be for navigation or self-navigation purpose where the positioning data is available to the moving tag.