This repository contains the necessary files to launch a gazebo simulation of the Franka Panda set in the Pearl lab with the ZED2 camera attached to the end effector.
To launch the simulation, you will need a few packages including libfranka
, franka_ros
, MoveIt! and panda_moveit_config
. For convenience, you can install a docker and pull images with the necessary packages.
For installing the docker, you can follow the instructions here.
Then you can pull the images.
- If your PC has an NVIDIA GPU, you can run:
docker pull 3liyounes/pearl_robots:franka
- If your PC does not have an NVIDIA GPU, you can run:
docker pull 3liyounes/pearl_robots:franka_wo_nvidia
- If you want to test in the real robot with ZED2 camera, you can run:
docker pull 3liyounes/pearl_robots:franka_real
Remember to allow any external program X11 to access the GUI:
xhost +
Create a container with a name to contain the pulled image (only once!)
source ~/.bashrc
docker_run_nvidia --name=container_name 3liyounes/pearl_robots:image_name bash
Now you are within the docker workspace. If you want to access the workspace in a new terminal, just run:
docker exec -it container_name bash
Get up-to-date repo by
cd src/franka_zed_gazebo/ && git pull && cd ../..
With all packages installed, you can launch the Gazebo simulator together with RviZ and the Motion Planning interface from MoveIt! and then spawn the cubes on the table. Manipulate the robot using the arrows and click on Plan & Execute
to manually move the robot as you wish. You can add the image panels by clicking Add
>By topic
on the left panel and selecting the topic you want to visualize.
roslaunch franka_zed_gazebo moveit_gazebo_panda.launch
Note
You can control the number of cubes and how they are spawned by editing the end of the file scripts/spawn_cubes.py
Note
There are two mount files possible for the ZED2 camera, including the gripper on the field view, on the left image below, and not including it, on the right image below. You can select the one you desire to work in simulation by editing the file urdf/panda_camera.urdf.xacro
.
If you want to use the real ZED2 camera on the real robot, make sure you have to have the right 3D printed mount file (with gripper on the field of view and without it), available inside the 3d_prints
folder.
Turn on the robot (controller box under the table). Access the work desk by typing the ip address of the robot in the browser. Unlock the robot before using.
- If you are sending commands through ROS, activate the FCI and put in Execution mode.
- If you want to manually move the robot, activate Programming mode and, on the robot, press lightly at the same time the two buttons located on the left of the end-effector (check manual for exact location)
If you are using the camera holder with the gripper in the field of view, edit the transformation in file launch/real_robot_zed2.launch
. While in Execution mode, you can launch the camera together with the robot:
roslaunch franka_zed_gazebo real_robot_zed2.launch robot_ip:=10.10.10.10
Warning
Remember to keep the emergency button close at all times and push it immediately if it doesn't behave as expected or when there is a risk to damage the robot or anything/anyone around it. Unpush it and unlock it on the desk panel to continue working.
If you want to test your code on real camera data without accessing the lab, you can use the rosbags samples coollected by using the rosbags
branch of this repository, where there are 4 samples of data available of the camera mounted on the real robot facing different configuration of cubes.
git clone -b rosbags https://github.com/pearl-robot-lab/franka_zed_gazebo.git
You can play the bag in a loop and access the topics for the rgb image, depth and pointcloud (sample 2). Remember to have the ROS master running in another terminal.
rosbag play -l sample_2.bag
The necessary data for the integration of the ZED2 camera in the Gazebo simulation was taken from the package created by LeoRover for the European Rover Challenge