Skip to content

dusty-nv/jetbot_ros

master
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Code

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
July 14, 2021 14:45
October 20, 2021 11:26
October 18, 2021 16:36
April 26, 2022 23:08
June 30, 2021 17:26
August 4, 2021 22:25
June 30, 2021 17:26
July 1, 2021 15:20
June 24, 2021 16:55
July 1, 2021 15:19
June 30, 2021 17:25
June 30, 2021 17:26

jetbot_ros

ROS2 nodes and Gazebo model for NVIDIA JetBot with Jetson Nano

note: if you want to use ROS Melodic, see the melodic branch

Start the JetBot ROS2 Foxy container

git clone https://github.com/dusty-nv/jetbot_ros
cd jetbot_ros
docker/run.sh

Run JetBot

If you have a real JetBot, you can start the camera / motors like so:

ros2 launch jetbot_ros jetbot_nvidia.launch.py

or (for a Sparkfun Jetbot)

ros2 launch jetbot_ros jetbot_sparkfun.launch.py

Otherwise, see the Launch Gazebo section below to run the simulator.

Launch Gazebo

ros2 launch jetbot_ros gazebo_world.launch.py

Then to run the following commands, launch a new terminal session into the container:

sudo docker exec -it jetbot_ros /bin/bash

Test Teleop

ros2 launch jetbot_ros teleop_keyboard.launch.py

The keyboard controls are as follows:

w/x:  increase/decrease linear velocity
a/d:  increase/decrease angular velocity

space key, s:  force stop

Press Ctrl+C to quit.

Data Collection

ros2 launch jetbot_ros data_collection.launch.py

It's recommended to view the camera feed in Gazebo by going to Window -> Topic Visualization -> gazebo.msgs.ImageStamped and selecting the /gazebo/default/jetbot/camera_link/camera/image topic.

Then drive the robot and press the C key to capture an image. Then annotate that image in the pop-up window by clicking the center point of the path. Repeat this all the way around the track. It's important to also collect data of when the robot gets off-course (i.e. near the edges of the track, or completely off the track). This way, the JetBot will know how to get back on track.

Press Ctrl+C when you're done collecting data to quit.

Train Navigation Model

Run this from inside the container, substituting the path of the dataset that you collected (by default, it will be in a timestamped folder under /workspace/src/jetbot_ros/data/datasets/)

cd /workspace/src/jetbot_ros/jetbot_ros/dnn
python3 train.py --data /workspace/src/jetbot_ros/data/datasets/20211018-160950/

Run Navigation Model

After the model has finished training, run the command below to have the JetBot navigate autonomously around the track. Substitute the path to your model below:

ros2 launch jetbot_ros nav_model.launch.py model:=/workspace/src/jetbot_ros/data/models/202106282129/model_best.pth

note: to reset the position of the robot in the Gazebo environment, press Ctrl+R