Skip to content

Commit a26d149

Browse files
urfeexmergify[bot]
authored andcommitted
Add support for UR18 (#1524)
(cherry picked from commit 233d524) # Conflicts: # ur_moveit_config/launch/ur_moveit.launch.py # ur_robot_driver/launch/ur_rsp.launch.py # ur_robot_driver/urdf/ur.urdf.xacro
1 parent 278cb95 commit a26d149

File tree

9 files changed

+713
-3
lines changed

9 files changed

+713
-3
lines changed

README.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -124,7 +124,7 @@ For getting started, you'll basically need three steps:
124124
details.
125125

126126
```bash
127-
# Replace ur5e with one of ur3, ur5, ur10, ur3e, ur5e, ur7e, ur10e, ur12e, ur16e, ur8long, ur15, ur20, ur30
127+
# Replace ur5e with one of ur3, ur3e, ur5, ur5e, ur7e, ur10, ur10e, ur12e, ur16e, ur8long, ur15, ur18, ur20, ur30
128128
# Replace the IP address with the IP address of your actual robot / URSim
129129
ros2 launch ur_robot_driver ur_control.launch.py ur_type:=ur5e robot_ip:=192.168.56.101
130130
```

ur_moveit_config/launch/ur_moveit.launch.py

Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -82,6 +82,7 @@ def launch_setup(context, *args, **kwargs):
8282

8383
robot_description_content = Command(
8484
[
85+
<<<<<<< HEAD
8586
PathJoinSubstitution([FindExecutable(name="xacro")]),
8687
" ",
8788
PathJoinSubstitution([FindPackageShare(description_package), "urdf", description_file]),
@@ -124,6 +125,47 @@ def launch_setup(context, *args, **kwargs):
124125
"prefix:=",
125126
prefix,
126127
" ",
128+
=======
129+
DeclareLaunchArgument("launch_rviz", default_value="true", description="Launch RViz?"),
130+
DeclareLaunchArgument(
131+
"ur_type",
132+
description="Typo/series of used UR robot.",
133+
choices=[
134+
"ur3",
135+
"ur5",
136+
"ur10",
137+
"ur3e",
138+
"ur5e",
139+
"ur7e",
140+
"ur10e",
141+
"ur12e",
142+
"ur16e",
143+
"ur8long",
144+
"ur15",
145+
"ur18",
146+
"ur20",
147+
"ur30",
148+
],
149+
),
150+
DeclareLaunchArgument(
151+
"warehouse_sqlite_path",
152+
default_value=os.path.expanduser("~/.ros/warehouse_ros.sqlite"),
153+
description="Path where the warehouse database should be stored",
154+
),
155+
DeclareLaunchArgument(
156+
"launch_servo", default_value="false", description="Launch Servo?"
157+
),
158+
DeclareLaunchArgument(
159+
"use_sim_time",
160+
default_value="false",
161+
description="Using or not time from simulation",
162+
),
163+
DeclareLaunchArgument(
164+
"publish_robot_description_semantic",
165+
default_value="true",
166+
description="MoveGroup publishes robot description semantic",
167+
),
168+
>>>>>>> 233d524 (Add support for UR18 (#1524))
127169
]
128170
)
129171
robot_description = {
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
controller_manager:
2+
ros__parameters:
3+
update_rate: 500 # Hz

ur_robot_driver/doc/usage/startup.rst

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -22,8 +22,8 @@ nodes for UR robots. The only required arguments are the ``ur_type`` and ``robot
2222
2323
$ ros2 launch ur_robot_driver ur_control.launch.py ur_type:=ur5e robot_ip:=192.168.56.101
2424
25-
Allowed ``ur_type`` strings: ``ur3``, ``ur5``, ``ur10``, ``ur3e``, ``ur5e``, ``ur7e``, ``ur10e``,
26-
``ur12e``, ``ur16e``, ``ur8long``, ``ur15``, ``ur20``, ``ur30``.
25+
Allowed ``ur_type`` strings: ``ur3``, ``ur3e``, ``ur5``, ``ur5e``, ``ur7e``, ``ur10``, ``ur10e``,
26+
``ur12e``, ``ur16e``, ``ur8long``, ``ur15``, ``ur18``, ``ur20``, ``ur30``.
2727

2828
Other important arguments are:
2929

Lines changed: 101 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,101 @@
1+
# Copyright (c) 2025 Universal Robots A/S
2+
#
3+
# Redistribution and use in source and binary forms, with or without
4+
# modification, are permitted provided that the following conditions are met:
5+
#
6+
# * Redistributions of source code must retain the above copyright
7+
# notice, this list of conditions and the following disclaimer.
8+
#
9+
# * Redistributions in binary form must reproduce the above copyright
10+
# notice, this list of conditions and the following disclaimer in the
11+
# documentation and/or other materials provided with the distribution.
12+
#
13+
# * Neither the name of the {copyright_holder} nor the names of its
14+
# contributors may be used to endorse or promote products derived from
15+
# this software without specific prior written permission.
16+
#
17+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20+
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21+
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22+
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23+
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24+
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25+
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26+
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27+
# POSSIBILITY OF SUCH DAMAGE.
28+
29+
from launch import LaunchDescription
30+
from launch.actions import DeclareLaunchArgument, IncludeLaunchDescription
31+
from launch.launch_description_sources import PythonLaunchDescriptionSource
32+
from launch.substitutions import LaunchConfiguration, ThisLaunchFileDir
33+
34+
35+
def generate_launch_description():
36+
# Declare arguments
37+
declared_arguments = []
38+
declared_arguments.append(
39+
DeclareLaunchArgument(
40+
"robot_ip",
41+
description="IP address by which the robot can be reached.",
42+
)
43+
)
44+
declared_arguments.append(
45+
DeclareLaunchArgument(
46+
"use_mock_hardware",
47+
default_value="false",
48+
description="Start robot with mock hardware mirroring command to its states.",
49+
)
50+
)
51+
declared_arguments.append(
52+
DeclareLaunchArgument(
53+
"mock_sensor_commands",
54+
default_value="false",
55+
description="Enable mock command interfaces for sensors used for simple simulations. "
56+
"Used only if 'use_mock_hardware' parameter is true.",
57+
)
58+
)
59+
declared_arguments.append(
60+
DeclareLaunchArgument(
61+
"initial_joint_controller",
62+
default_value="scaled_joint_trajectory_controller",
63+
description="Initially loaded robot controller.",
64+
choices=[
65+
"scaled_joint_trajectory_controller",
66+
"joint_trajectory_controller",
67+
"forward_velocity_controller",
68+
"forward_position_controller",
69+
"freedrive_mode_controller",
70+
"passthrough_trajectory_controller",
71+
],
72+
)
73+
)
74+
declared_arguments.append(
75+
DeclareLaunchArgument(
76+
"activate_joint_controller",
77+
default_value="true",
78+
description="Activate loaded joint controller.",
79+
)
80+
)
81+
82+
# Initialize Arguments
83+
robot_ip = LaunchConfiguration("robot_ip")
84+
use_mock_hardware = LaunchConfiguration("use_mock_hardware")
85+
mock_sensor_commands = LaunchConfiguration("mock_sensor_commands")
86+
initial_joint_controller = LaunchConfiguration("initial_joint_controller")
87+
activate_joint_controller = LaunchConfiguration("activate_joint_controller")
88+
89+
base_launch = IncludeLaunchDescription(
90+
PythonLaunchDescriptionSource([ThisLaunchFileDir(), "/ur_control.launch.py"]),
91+
launch_arguments={
92+
"ur_type": "ur18",
93+
"robot_ip": robot_ip,
94+
"use_mock_hardware": use_mock_hardware,
95+
"mock_sensor_commands": mock_sensor_commands,
96+
"initial_joint_controller": initial_joint_controller,
97+
"activate_joint_controller": activate_joint_controller,
98+
}.items(),
99+
)
100+
101+
return LaunchDescription(declared_arguments + [base_launch])

ur_robot_driver/launch/ur_control.launch.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -410,6 +410,7 @@ def generate_launch_description():
410410
"ur16e",
411411
"ur8long",
412412
"ur15",
413+
"ur18",
413414
"ur20",
414415
"ur30",
415416
],

0 commit comments

Comments
 (0)