If you're on a Mac, follow the steps under "Step-by-Step Guide" on this page first.
Run
bash speedystart.sh
to instantly start the project. You might have to stop any cpss-ros2
containers running on your machine via docker stop cpss-ros2
if you've
run the script before. You'll be dropped into a tmux
session.
It might take a hot second to run; it's building a whole Docker image.
Your current directory is mounted in /home/pwd
in the container. Edits made in
the container will be reflected in real time on your host machine and vice versa--so the ideal workflow is to develop on your host machine using your favorite IDE, then run the changes in the ROS2 container that the script launches. You don't have to open/close any windows or refresh anything; the mounted directory just updates.
Look up how to use tmux
; it's how you'll open different terminal windows at
the same time (as ROS2 frequently requires). In particular, learn how to create
panes, which split one terminal window into two. Windows might also be useful for creating "browser tab"-like setups.
Enter the container using the steps above. From inside the container, run:
bash setup/ros2/ros2_rust_setup.sh
This will install the necessary dependencies for the Rust code to run, including Cargo. You can now create ROS2 Rust projects as described in the ROS2 Rust tutorial
You'll need Docker for this. Here's a setup tutorial.
- Run
sudo apt install python3-venv
- Give yourself permisison to write to the teensy
- in
/etc/udev/rules.d
, runsudo wget https://www.pjrc.com/teensy/00-teensy.rules
- in
- Open VSCode, and install PlatformIO extension for VSCode
- Clone the repo and Open the micro-ros-demo-project
- MAKE SURE TO CLONE WITH
--recurse-submodules
FLAG (necessary for micro-ros)
- MAKE SURE TO CLONE WITH
- Plug in the teensy
- Open the Platformio-Projects folder, click on the .ini file, then build and upload the project using the small right arrow in the bottom of your IDE
- If you get any errors during this process, try restarting VSCode
For this task, We need to run the micro-ros-agent, THEN plug in the teensy. there are 2 methods:
- Building the micro-ros-agent
- make sure the microros submodule is initialized correctly (cloned with --recurse-submodules, or initialized submodules after cloning)
- build the agent:
- cd into
microros_ws
sudo usermod -a -G dialout $USER
sudo apt update && sudo apt install python3-rosdep2 && sudo rosdep init && rosdep update
rosdep install --from-paths src --ignore-src -y
sudo apt-get install python3-pip
colcon build
source install/local_setup.bash
ros2 run micro_ros_setup create_agent_ws.sh
ros2 run micro_ros_setup build_agent.sh
- cd into
- From this point on, you never need to build again on your machine. Anytime you want to use te agent, cd into
microros_ws
and use the following commandssource install/local_setup.bash
ros2 run micro_ros_agent micro_ros_agent serial --dev /dev/ttyACM0
- if ttyACM0 doesn't work, try ttyACM1
- After this, you should see your agent start, and if the teensy is created you should see all the subscribers and timers start up
- To see your nodes and topic data running, you can use the following commands in any terminal:
ros2 node list
ros2 topic list
ros2 topic echo /put/topic/name/here
Adding new code should be a fairly easy process if you already understand the processes behind ROS. Inside this repo is the MICRO-ROS-DEMO project, where you can add your sensors and effectors. Here's how:
- Note that this project represents a single node. Each file in "handlers" corresponds to one or more related publishers+timers and/or subscribers (referred to as handlers). To add your code, you'll write a new .hpp file in the handlers directory, then add it to config.hpp
- In the MICRO-ROS-DEMO projects, you should see a number of c++ files. Here's a breakdown of the directories:
- config -> Contains the config.hpp file you'll use to add your code to this node. Once you create your own c++ file, you can copy the structure of how the other c++ files added their handlers in the 2 functions and to the constant at the top. If you do it right it should just work when the node starts up.
- handlers -> the actual code for communicating with hardware. Go ahead and create a file here for your new software. This is the only file you need to create. In this directory should be a bunch of scripts for individual sensors, along with
daylight_sensor.hpp
as an example publisher or sensor, andlight_switch.hpp
as an example of 2 subscribers or effectors. Yo can copy either light switch or daylight sensor to use as a template based on if you're writing an effector or sensor, and refer to the other sensor files if you are a little stuck on where to go. - support -> included by every file. Contains helper functions and macros. You never need to edit this file
- main.cpp -> Runs the node and connects everything together. You never need to edit this file
- TLDR: follow these steps
- in handlers/, create a new file and use either daylight_sensor.hpp or light_switch.hpp as a template
- in config/config.hpp, add the information for your code just like the other sensors/effectors
- build the code, flash the teensy, start the agent, and it should just work.
If you have any questions on Micro-ROS or this demo project, DM Cameron Wolff on teams