This repository is the software stack for F1/5th off-road robot, Cinnamon! Please check src folder to see all the modules I have. We are using Ubuntu 22.04, ROS2 Humble, and Jetpack 6.0. We tested on NVIDIA Jetson Orin Nano and Orin AGX. We recommend flasing Jetson on SSD. Choose NVMe on SDK manager when flashing. (I forgot which step it was but it was on the bottom right on the screen.)
xLAB has other scales of robots :)
This is the diagram of the robot.
6S battery gives power to Jetson, FixPosition, and Traxxas Receiver. We used three identical PDBs.
6S battery and two 4S batteries can be placed in a stable matter like below.
The BoM is here .
The CAD files: the top plate and the wheel encoders We used ¼ inch acrylic to make the base board for all the electronics. All the screws are M3 except Jetson (M2.5).
The video on how to decompose the x-maxx to see the servo is here.
The video recorded by us on how to assemble the 1/5th robot is here.
The video recorded by us on how to connect all the cables is here.
For Jetson Orin nano and Jetson Orin AGX, you need to use M2.5 screws. To use Jetson Orin nano, use M2.5 of length 6mm from the top and M2.5 of length 8mm from the bottom to fix Jetson together with the stand offs. The longer screws needs to be used as the base plate is thick (5 or 6mm).
We are using OUSTER OS1 LiDAR with 128 rays. Connect the LiDAR and its medium converter. Give 24V to the converter. Go to http://os-122411000631.local/ (http://os-[serial number of your OUSTER].local/) to open the sensor's configuration page. Use the official ROS2 package as we have it in src as well. When you run the launch file, you need to put the ip address of the sensor, which can be obtained from os-122411000631.local
We recommend to have ethernet connection between Jetson and Fixposition instead of Wi-Fi. You should also mount modem (we used NRadio as in BoM spreadsheet) and connect it to Jetson so that Jetson and Fixposition has a stable Internet.
- access point - keep it on
- connect fixposition and NRadio via ethernet
- From the laptop, connect to fixposition's wifi using access point fp-(numbers)
- On laptop, open the fixposition page 10.0.2.1. Then from the configuration of network, choose DHCP-client. When turning this on, make this to the default.
- connect the ethernet between the lap and dress was assigned to the fixposition.
- Check 192.168.66.105 (fp's address assigned by NRadio) is accessible
- If accessible, disconnect from the fixposition's Access Point fp-(numbers)
- we can turn off wifi on laptop to make sure ethernet is used
- If you want to have remote access to Jetson using NoMachine, the password to connect to NRadio WiFi is “12345678”.
Once you did the above setup, you don’t have to repeat the same thing next time you power on the fixposition. You can connect the ethernet between the laptop and the modem (NRadio) and between fixposition and the modem. Fixposition should automatically become DHCP-client by default by doing the step 3 of the first-time setup. Sometimes the ip address of the fixposition assigned by the modem can change. If so, you can check the new ip address by going to the modem’s ip address (192.168.66.1).
Although we recommend using modem and ethernet cable connection to have stable Internet as mentioned above, we explain how to have Wi-Fi on Fixposition just in case.
With Ethernet cable, connect to 10.0.2.1 With Wifi, connect to 10.0.1.1 On Fixposition's configration page, connect to the same Wi-Fi that Jetson is connected to.
If you can’t connect, you should try unplugging the ethernet cable on fix position and plugging it again. You can also try removing the ethernet connection setting and make a new default one.
Clone to these repos. Make sure to update the ip address of fixposition in tcp.yaml. Then, colcon build the package. https://github.com/fixposition/fixposition_driver https://github.com/fixposition/fixposition_gnss_tf
We used this service on our robot. On Fixposition, fill out the RTK subscription account's information.
- sudo apt install git cmake build-essential libssl-dev libusb-1.0-0-dev pkg-config libgtk-3-dev
- sudo apt install libglfw3-dev libgl1-mesa-dev libglu1-mesa-dev
- git clone https://github.com/IntelRealSense/librealsense.git
- cd librealsense
- git checkout development
- ./scripts/patch-realsense-ubuntu-L4T.sh
- sudo apt-get install git libssl-dev libusb-1.0-0-dev pkg-config libgtk-3-dev -y v4l-utils
- ./scripts/setup_udev_rules.sh
- mkdir build && cd build
- cmake .. -DBUILD_PYTHON_BINDINGS:bool=true -DBUILD_EXAMPLES=true -DCMAKE_BUILD_TYPE=release -DFORCE_RSUSB_BACKEND=false -DBUILD_WITH_CUDA=true
- sudo make uninstall && sudo make clean && sudo make -j4 && sudo make install
- cd .. && sudo cp config/99-realsense-libusb.rules /etc/udev/rules.d/
- sudo udevadm control --reload-rules && sudo udevadm trigger
- realsense-viewer
sudo apt install ros-humble-realsense2-*
We recommend the voltage indicator on 6S battery. Black cables come to the left and red cable come to the right. If it does not say 6 cs, try it again. You should try to insert all the pins at the same time.
On VESC, Choose ADC2 Low. Connect the sensor onto the VESC as indicated by the labels.
- Press ON on the remote controllers to let the car run. The emergency sensor should have red lights on.
- When you want to immediately stop the car, press OFF on the controllers.
There are two remote controllers, so two people at the experiments can hold them. You can turn on/off by pressing a small button on the emergency sensor too.
- Connect the ethernet between the modem and jetson
- Connect the joystick to Jetson via bluetooth
- In the workspace directory, run
ros2 launch f1tenth_stack bringup_launch_hokuyo.py
. You should be able to control the robot with the joystick. Although our robot does not have hokuyo lidar, you can still run this python script.
- Make sure to change the ip address of fixposition in tcp.yaml file.
- In the workspace directory (ros2_ws for example), run
colcon build --packages-up-to fixposition_driver_ros2
- Run
ros2 launch fixposition_driver_ros2 tcp.launch
Of course, if the ip address has not changed and you did colcon build of fixposition previously, you only have to do the step 3.
- Connect to 10.0.2.1 in the browser to see the fixposition.
- Make sure the GNSS is connected to active NTRIP subscription - you should see two light green circles on top right for GNSS 1 and GNSS 2.
- Make sure the wifi for the fixposition is connected to the same wifi of Jetson. Don’t use Chinese or Japanese characters for the name of the wifi. Fixposition can’t connect to the wifi with those names.
ros2 laKeyboardunch fixposition_driver_ros2 tcp.launch
If you want to have remote control of Jetson, install NoMachine on the machine you want to control from.
- On Jetson, type “ifconfig” to find its own IP address. You can also find it on NRadio's config page (192.168.66.1).
- Open NoMachine on the remote computer. Make sure the remote computer is also connected to the same network (NRadio) via WiFi.
- Display Port Dongle
- Keyboard
- Mouse
- Converter from HDMI to DP
- Two blue Sony controllers in case one of them becomes laggy
- Tape so that you can keep some cables inside
- Color cones
- Insect repellent
- (Tool to turn the screw of the wheel)