Unofficial MBARI's ROV Simulation and Control Project
Underwater World Simulation | ROV | ROS2 Jazzy | Gazebo Harmonic |
I started this project because of my interest in underwater robotics and fascination with the MBARI Oceanographic Institute.
During this project, I want to learn how to set up an underwater world simulation with ROS2 and Gazebo.
Gazebo Classic has reached its end of life, and it is time to learn how to use Gazebo sim.
Due to some limitations of Gazebo, soon, I want to explore other robotics simulators, like NVIDIA Omniverse IsaacSim.
Thanks to the huge amount of available models of ROV, Environments, and Creatures gifted by MBARI on sketchfab, I want to:
- Create a URDF Model of MBARI's ROV Doc Ricketts
- Model each thruster as an independent joint
- Model and Integrate the actuated ROV's Manipulator (with all joints)
(Even If currently Ricketts has 2 arms for advanced manipulation tasks, I will consider this only in the future)
- Define an approximated fluid dynamic model of the ROV, for simulation
- Learn to correctly set up Gazebo sim plugins to simulate thrusters, buoyancy, and fluid dynamics force
- Create a custom sdf world file, with deep-sea environments from MBARI's 3D sea floor reconstruction
- Add deep sea creatures as Gazebo Actors, to make this world even more alive.
This is possible thanks to Photogrammetry Techniques used by MBARI. - Implement high and low-level ROS nodes to control and teleoperate the ROV motion (exploiting the 7 thrusters)
- Implement high and low-level ROS nodes to control and teleoperate the ROV Arm (including Gripper operations)
- Add light sources, cameras, and other exteroceptive/proprioceptive sensors to the Robot Model.
- Implement control on Pan-Tilt Camera motion
- Set up needed TFs, sensors, topics, and odometry to Enable Mapping with SLAM
- Set up Autonomous Navigation Features
- Implement high-level algorithms for Visual Tracking of deep water animals
(Due to Gazebo's Limitations in rendering camera images, this may require moving to IsaacSim) - Implement high-level algorithms for Visual Servo Control of the ROV Robotic Arm.
- ...
Tip
The following steps can be useful for anyone who wants to create a Robotic Simulation from the robot mesh!
Here world and robot plugins will be underwater specific, but the high-level concepts remain the same even for a ground vehicle.
This is why I'll try to describe the implementation step as clearly as possible.
Later on I will provide a concise command sheet to run the simulation and use its functionalities.
... This is a lot just for a single person, 🖐️ a big high five to anyone opening an issue for suggestions, ideas, or reviews.
Feel free to Pull Requests to contribute to this project.
This emoji " 👉 "Indicates the current step in development.
- Linux Ubuntu 24.04
- ROS2 Jazzy
Note
Alternatively, you can build a Docker
container to work with ROS2 Jazzy in your OS.
If you are using Docker, refer to this section just to know the required dependencies.
Install and Set Up ROS2 Jazzy
- Install ROS Jazzy and source
Refer to ros documentation for the step-by-step installation tutorial.
Anytime you open a new terminal, you should source your underlay ros environment with:
# Terminal
# Replace ".bash" with your shell if you're not using bash
# Possible values are: setup.bash, setup.sh, setup.zsh
source /opt/ros/jazzy/setup.bash
To avoid doing it every time, add that command to your bashrc
, opening it with a text editor of your choice:
# Terminal (use your preferred text editor tool)
gedit ~/.bashrc
And add the line source /opt/ros/jazzy/setup.bash
at the end.
- If not automatically installed, install
colcon
, the build tool for ROS2:
# Terminal
sudo apt install python3-colcon-common-extensions
- Create and build a ros2 workspace to position this project packages:
In your preferred directory
# Terminal
mkdir ros2_ws
cd ros2_ws
mkdir src
colcon build
- Source your ros2 workspace and the colcon argmícomplete environment:
As done for the ros underlay, you need to source the overlay setup.bash when you build it, again you can add that to the bashrc
# Terminal
gedit ~/.bashrc
Add the line source ~/ros2_ws/install/setup.bash
and source /usr/share/colcon_argcomplete/hook/colcon-argcomplete.bash
to complete colocn commands by pressing Tab.
To launch this project packages, you may need ROS2 packages not installed with ros-jazzy-desktop.
I will update this list during implementation:
xacro
joint_state_publisher_gui
- ...
# Terminal
sudo apt install ros-jazzy-xacro ros-jazzy-joint-state-publisher-gui
Move to your ros workspace, inside /src folder (where all your packages are located)
# Terminal
git clone https://github.com/AlePuglisi/ROV-Ricketts-ros2.git
then, move back to the workspace folder (before /src), and build your workspace.
Now you are ready to test this project!
(Remember that after building the workspace, you need to source your bashrc, so your overlay and underlay will be sourced, just run source ~/.bashrc
)
- First I download Doc Ricketts ROV model from Sketchfab, in
fbx
format. - Import it in Blender to create separate meshes (with texture) for each piece
- Export each model as
dae
(COLLADA format)
Tip
I discovered that stl
format does not support texture by default, setting it up may be possible but hard.
Here you can find stl models, but for an astonishing visualization, rely on dae
.
With the COLLADA format, textures are easy to load (just be sure the texture png file is in the correct referenced path inside dae XML file).
- Create the
URDF
connecting and positioning each thruster, as a revolute joint (probably continuous joint will be used later on).
I used thexacro
format, to make it cleaner and allow a simple customization at launch time. - Inertia property tuning will be done later on when setting up Gazebo simulation
- Creta a simple launcher
display.launch.py
to run Rviz, robot_state_publisher, joint_state_publisher (and its GUI). - Add relevant visualization objects in Rviz and save as
rov_monitor.rviz
.
Finally, it is possible to visualize the robot in Rviz and move the thrusters with joint_state_publisher_gui:
# Terminal
ros2 launch rov_ricketts_description display.launch.py
The next step is to model and attach the robotic arm to Doc Ricketts.
The arm is defined as a single piece in the 3D model, three options are possible to derive the URDF model:
- 1. Remodel it with simple cylinders and parallelepiped shapes, connected by revolute joints, directly in URDF.
- 2. Create a new 3D model from scratch, with separate links, using the original arm as a reference
- 3. Use the original model and modify it to cut the links, then use this as URDF links
Unfortunately, I didn't find much information about the arm structure, I'm not sure if arm_link4
needs to be further divided, with a roll joint.
Suggestions and any sharing of information may help in improving the model!
I also include the arm_tool frame, this will help when performing manipulation tasks.
Tip
A useful tag to define gripper joints is "mimic":
<joint name="${name}_link4_claw_left" type="revolute">
<mimic joint="${name}_link4_claw_right" multiplier="1" offset="0"/>
....
This forces this joint to move around its rotation axis as the mimic joint times the multiplier.
(joint_state = mimic_joint_state * multiplier)
Changing the multiplier value we can set an inverse rotation or a transformation ratio.
Once Doc Ricketts Arm URDF has been derived, to make the robot reconfigurable at launch time, we can decide at launch time if we want to load it or not.
To achieve this flexibility feature, we can use a launch argument, and the xacro conditional statement.
- To configure Ricketts with the Robotic Arm:
# Terminal
ros2 launch rov_ricketts_description display.launch.py load_arm:=true
- To configure Ricketts without the Robotic Arm:
# Terminal
ros2 launch rov_ricketts_description display.launch.py load_arm:=false
(Notice that the default value of load_arm is false, so argument initialization can be neglected in that case)
As can be seen, all joints have been articulated properly!
Joint Limits and dynamical joints/body properties will be defined in the next steps...