No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

Package Summary

Tags No category tags.
Version 0.0.0
License BSD-3-Clause
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/superdiodo/ur_ros_rtde.git
VCS Type git
VCS Version main
Last Updated 2025-03-27
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

ur_ros_rtde tutorials

Additional Links

No additional links.

Maintainers

  • Alessio Saccuti

Authors

No additional authors.

Tutorials for ur_ros_rtde

The proposed software is composed of three ROS2 nodes:

You can easily interact with ROS2 services and actions using header files provided in ur_ros_rtde_simple_clients. For further details and documentation, please visit ur_ros_rtde.

Run examples

Ensure that the ur_ros_rtde_tutorials package is compiled.

Retrieve robot state

To retrieve the robot state RobotStateReceiver must be used.

  1. Configure robot_state_receiver.launch.py:
    • set ip address with robot_ip
  2. Launch robot_state_receiver:
    # type in a new terminal
    ros2 launch ur_ros_rtde robot_state_receiver.launch.py
    

At this point, the robot state can be accessed using topics and services.

  1. Print joint states:
    # type in a new terminal
    ros2 topic echo /joint_states
    

Visualize the robot in RViz

RobotStateReceiver does not require any URDF of the robot, but URDF files are required to visualize the robot in tools like RViz. If a ROS2 description package of a UR robot is already available, skip to step 2 and use that package instead of simple_ur10e_description.

  1. In simple_ur10e_description generate UR10e URDF file from xacro files.
    # generate ur10e urdf
    cd ~/your_path/simple_ur10e_description/urdf
    sh generate_urdf.sh ur10e.xacro ur10e.urdf

    # build again the package to make the urdf visible
    cd <ros_workspace_path>
    colcon build --symlink-install --cmake-args -DCMAKE_BUILD_TYPE=Release --packages-up-to simple_ur10e_description
    
  1. Configure robot_state_receiver.launch.py:
    • set ip address with robot_ip
    • set robot_description_package = "simple_ur10e_description"
    • set urdf_file_name = "urdf/ur10e.urdf"
    • set launch_rviz = True

When setting launch_rviz to True a robot state publisher node is started which will publish TF for each robot link based on the joint states.

  1. Launch RobotStateReceiver:
    # type in a new terminal
    ros2 launch ur_ros_rtde robot_state_receiver.launch.py
    
The first time RViz will be empty. To show the robot: 
1. Add a robot model: `Displays\Add\RobotModel`
2. Set `world` in `Fixed Frame`
3. Set `/robot_description` in `RobotModel\Description Topic`
4. Click on `File\Save config` to save the actual configuration of RViz

Activate robot commands

In ur_ros_rtde commands are defined as plugins and exposed as action servers. To make available these action servers the CommandServer must be started:

  1. Configure command_server.launch.py setting ip address with robot_ip

  2. Launch CommandServer:

    # type in a new terminal
    ros2 launch ur_ros_rtde command_server.launch.py
    
  1. List the available commands (more info at ur_ros_rtde):
    # type in a new terminal
    ros2 action list
    

The file command_server.launch.py can also be used to define a blacklist of plugins which must not be loaded. By default, the plugins implemented in ur_ros_rtde_gripper_commands are disabled, since they rely on the presence of specific hardware.

Move the robot

In this tutorial package are provided 3 examples which can be used to move the robot:

  • Execute linear movements: The robot performs small linear movements along the X-axis printing the robot pose after each movement. The robot state is retrieved with services exposed by RobotStateReceiver. Commands are sent to the robot with the CommandServer.

    1. Configure and launch RobotStateReceiver, set launch_rviz = True if you want to see the robot moving in RViz:
        # type in a new terminal
        ros2 launch ur_ros_rtde robot_state_receiver.launch.py
        
  1. Configure command_server.launch.py setting ip address with robot_ip.

  2. Launch CommandServer:

      # type in a new terminal
      ros2 launch ur_ros_rtde command_server.launch.py
      
  1. Run executables:

    WARNING! If everything was successfully configured the robot will start moving! Check for possible collisions with the environment!

    With linear_movements executable MoveL commands are sent to the robot. Starting from the actual pose it will move +10 cm on X axis, then -20 cm on X axis and finally +10 on X axis again.

      # type in a new terminal
      ros2 run ur_ros_rtde_tutorials linear_movements
      
  • Execute a waypoint-based trajectory: In trajectory_execution there is an example in which a trajectory is sent to the robot. The robot (oriented towards Y-axis) will move as shown in the animated image.

    This example only requires an instance of the CommandServer and can be executed as shown below:

    # type in a new terminal
    ros2 run ur_ros_rtde_tutorials trajectory_execution
    

Adding new commands to ur_ros_rtde

In ur_ros_rtde/src/base_commands and ur_ros_rtde/src/base_dashboard_commands there is the implementation of several commands which are exposed as ROS2 plugins. When launching CommandServer and DashboardServer these plugins are automatically loaded.

In this package and ur_ros_rtde_gripper_commands and are provided examples of how new commands can be implemented as ROS2 plugins. For instance, in this package there is an example of implementation of the MoveDownUntilForce plugin, which allow to move the robot towards the ground until a force is detected.

If ur_ros_rtde_tutorials is compiled, the plugin will be loaded automatically by the CommandServer. The command can be sent to the robot sending an empty goal to the corresponding action server:

  1. Launch CommandServer:
    # type in a new terminal
    ros2 launch ur_ros_rtde command_server.launch.py
    
  1. Send the goal:
    # type in a new terminal
    ros2 action send_goal /ur_ros_rtde/move_down_until_force_command ur_ros_rtde_tutorials/action/MoveDownUntilForce {}
    


Integration of ur_ros_rtde and MoveIt!

Setting launch_moveit = True in ur_ros_rtde/launch/robot_state_receiver.launch.py, several files from the associated MoveIt! configuration package are automatically launched.

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged ur_ros_rtde_tutorials at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.