diff --git a/README.md b/README.md index f3ca0ed..b5be39d 100644 --- a/README.md +++ b/README.md @@ -33,73 +33,68 @@ Metapackage for the MRS UAV Gazebo simulation pipeline. Use one of the prepared Tmuxinator sessions: -- [tmux/one_drone_gps](tmux/one_drone_gps) +- [tmux/one_drone](tmux/one_drone) -## Customizing drone using the "spawner parameters" +## Using the MRS drone spawner in your simulations -**TODO** the wiki page [https://ctu-mrs.github.io/docs/simulation/drone_spawner.html](https://ctu-mrs.github.io/docs/simulation/drone_spawner.html) contains potentially duplicit or contradicting information. -These two pages should be merged and the information should be presented at only one of the locations. +The drone models are dynamically created in runtime using the [MRS drone spawner](https://ctu-mrs.github.io/docs/simulation/gazebo/gazebo/drone_spawner.html). The UAV platforms can be additionally equipped by adding [components](ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja) (rangefinders, LiDARs, cameras, plugins etc.). -The UAV platforms can be additionaly equipped with sensors (rangefinders, 2d lidars, stereo cameras etc.). +### Start the Gazebo simulator -### Start of the Gazebo simulator - -To start the prepared example of Gazebo world call: +To start the example Gazebo world call: ```bash -roslaunch mrs_simulation simulation.launch world_file:='$(find mrs_gazebo_common)/worlds/grass_plane.world' gui:=true +roslaunch mrs_uav_gazebo_simulation simulation.launch world_name:=grass_plane.world gui:=true ``` At this point the Gazebo world will only contain the environment with grass plane but with no vehicles yet. -### Spawning of UAVs +### Spawning the UAVs -The `simulation.launch` will automatically start the `mrs_drone_spawner` python node. If you use a custom launch file to start the simulation, you can start it separately: +The `simulation.launch` will automatically start the `mrs_drone_spawner` as a ROS node. If you use a custom launch file to start Gazbo, you can launch the spawner separately: ```bash -roslaunch mrs_simulation mrs_drone_spawner.launch +roslaunch mrs_uav_gazebo_simulation mrs_drone_spawner.launch ``` The `mrs_drone_spawner` will perform the following tasks: -* Spawn vehicle models in the Gazebo simulation (ids from 0 to 250). This is done internally by calling the command `rosrun gazebo_ros spawn_model`. +* Generate SDF models from the UAV templates + +* Add optional components (sensors, plugins...) based on the user input + +* Run PX4 SITL and Mavros, and ensure that all ports are correctly linked with the Gazebo simulator -* For each vehicle, PX4 firmware and mavros is started at specific port numbers depending on the vehicle ID. +* Remove all subprocesses on exit Vehicles are added to the simulation by calling the `spawn` service of the `mrs_drone_spawner`. The service takes one string argument, which specifies the vehicle ID, type and sensor configuration. -Example: spawn a single vehicle with a down-facing laser rangefinder: - -```bash -rosservice call /mrs_drone_spawner/spawn "1 --enable-rangefinder" -``` +Example: spawn a single vehicle with ID 1, type X500, with a down-facing laser rangefinder: -To display the manual containing a list of all available arguments, perform a dry-run of the script: ```bash -rosrun mrs_simulation mrs_drone_spawner +rosservice call /mrs_drone_spawner/spawn "1 --x500 --enable-rangefinder" ``` -The arguments are also listed in the `mrs_simulation/config/spawner_params.yaml` file. -Note that not all sensors are available for all the vehicle types. -The config file stores the available configurations in the following format: `parameter: [default_value, help_description, [compatible_vehicles]]` +To display the basic use manual for the spawner, call the service with the argument ` --help`. **NOTE**: String argument cannot start with a dash. Add a space before the dashes to avoid errors. The service call returns the full help text, but the formatting may be broken. Please refer to the terminal running `simulation` or `mrs_drone_spawner` where the help text is also printed with proper formatting. -Multiple vehicles may be spawned with one service call: ```bash -rosservice call /mrs_drone_spawner/spawn "1 2 3 4 5 --t650 --enable-bluefox-camera --enable-rangefinder" +rosservice call /mrs_drone_spawner/spawn " --help" ``` -Spawn position may be specified by a command line argument `--pos x y z heading`: [m, m, m, rad] +You can also display a manual for a specific platform. This will list all the components that can be equipped to the selected platform, and their brief description. ```bash -rosservice call /mrs_drone_spawner/spawn "1 --f550 --enable-rangefinder --pos 10 -15 0.3 0.7" +rosservice call /mrs_drone_spawner/spawn " --x500 --help" ``` -For multiple vehicles, `--pos` defines the spawn point of the first vehicle. Following vehicles will be spawned in a line, with an x-offset of 2 meters from the previous vehicle. -Spawn position may be specified by a `.csv` or a `.yaml` file using `--file absolute_path_to_file`: +Multiple vehicles may be spawned with one service call: ```bash -rosservice call /mrs_drone_spawner/spawn "1 --f450 --enable-rangefinder --enable-ouster --use-gpu-ray --ouster-model OS1-64 --file `pwd`/spawn_poses.yaml" +rosservice call /mrs_drone_spawner/spawn "1 2 3 4 5 --t650 --enable-bluefox-camera --enable-rangefinder" ``` -Use a whitespace instead of an ID to get an available ID automatically assigned by the spawner. +The default parameters of some components may be reconfigured by adding `param:=value` after the component keyword. Multiple params may be used at the same time: ```bash -rosservice call /mrs_drone_spawner/spawn " --f450 --enable-rangefinder" +rosservice call /mrs_drone_spawner/spawn "1 --x500 --enable-rangefinder --enable-ouster model:=OS0-32 use_gpu:=True horizontal_samples:=128 update_rate:=10" ``` +The list of components and their reconfigurable parameters can be displayed using the platform-specific help. + +For more details, please refer to the [MRS drone spawner](https://ctu-mrs.github.io/docs/simulation/gazebo/gazebo/drone_spawner.html) page. diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja index 053e09f..b5f591b 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja @@ -70,7 +70,7 @@ limitations under the License. {# #} {# propellers_macro {--> #} -{%- macro propellers_macro(prop_list, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, rotor_drag_coefficient, rolling_moment_coefficient, meshes_z_offset, prop_ixx, prop_ixy, prop_ixz, prop_iyy, prop_iyz, prop_izz, spawner_args) -%} +{%- macro propellers_macro(prop_list, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, rotor_drag_coefficient, rolling_moment_coefficient, meshes_z_offset, use_mrs_plugin, prop_ixx, prop_ixy, prop_ixz, prop_iyy, prop_iyz, prop_izz, spawner_args) -%} {%- set spawner_keyword = 'disable-motor-crash' -%} {%- set spawner_description = 'Disables motor failure after a crash with the environment.' -%} @@ -80,6 +80,12 @@ limitations under the License. {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} + {%- if use_mrs_plugin -%} + {%- set motor_plugin_filename = "libMrsGazeboCommonResources_MotorPropModelPlugin.so" -%} + {%- else -%} + {%- set motor_plugin_filename = "libgazebo_motor_model.so" -%} + {%- endif -%} + {%- for prop_params in prop_list -%} @@ -103,6 +109,7 @@ limitations under the License. color = prop_params['color'], mesh_file = prop_params['mesh_files'][0], mesh_scale = prop_params['mesh_scale'], + motor_plugin_filename = motor_plugin_filename, x = prop_params['x'], y = prop_params['y'], z = prop_params['z'], @@ -139,6 +146,7 @@ limitations under the License. mesh_file_2 = prop_params['mesh_files'][1], meshes_z_offset = meshes_z_offset, mesh_scale = prop_params['mesh_scale'], + motor_plugin_filename = motor_plugin_filename, x = prop_params['x'], y = prop_params['y'], z = prop_params['z'], @@ -228,7 +236,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -302,7 +310,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -376,7 +384,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -432,7 +440,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -606,7 +614,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -708,7 +716,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -989,7 +997,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1155,7 +1163,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1196,7 +1204,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1236,7 +1244,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1276,7 +1284,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1316,7 +1324,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1356,7 +1364,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1412,7 +1420,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1467,7 +1475,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1522,7 +1530,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1577,7 +1585,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1632,7 +1640,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1687,7 +1695,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1742,7 +1750,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -1806,7 +1814,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -2026,7 +2034,7 @@ limitations under the License. {%- endfor -%} - {{ mount }} + {{ mount if mount }} @@ -2082,7 +2090,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -2136,7 +2144,7 @@ limitations under the License. }} - {{ mount }} + {{ mount if mount }} @@ -2173,7 +2181,7 @@ limitations under the License. }} - {{ mount }} + {{ mount if mount }} @@ -2209,7 +2217,7 @@ limitations under the License. }} - {{ mount }} + {{ mount if mount }} @@ -2402,7 +2410,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -2483,7 +2491,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} @@ -2821,7 +2829,7 @@ limitations under the License. - {{ mount }} + {{ mount if mount }} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja.orig b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja.orig deleted file mode 100644 index fb47f16..0000000 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/component_snippets.sdf.jinja.orig +++ /dev/null @@ -1,3046 +0,0 @@ - - - -{%- import 'mrs_robots_description/sdf/generic_components.sdf.jinja' as generic -%} - -{# !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! #} -{# !! THIS DOCUMENT CONTAINS ONLY COMPLEX COMPONENT MACROS DESIGNED !! #} -{# !! FOR USE WITH THE MRS DRONE SPAWNER AND USE THE SPAWNER API !! #} -{# !! GENERIC SENSORS, VISUAL BLOCKS, PLUGINS ETC BELONG TO GENERIC !! #} -{# !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! #} - - - - - -{# ================================================================== #} -{# || Components using spawner API || #} -{# ================================================================== #} - -{# ground_truth_macro {--> #} -{%- macro ground_truth_macro(parent_link, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-ground-truth' -%} - {%- set spawner_description = 'Enable ROS topic with ground truth odometry published under model namespace' -%} - {%- set spawner_default_args = {'topic_name': 'ground_truth', 'frame_name': 'world', 'update_rate': 150} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - {{ generic.odometry_sensor_macro( - odometry_sensor_name = 'ground_truth', - parent_link = parent_link, - topic_name = spawner_args[spawner_keyword]['topic_name'], - noise = 0, - frame_name = spawner_args[spawner_keyword]['frame_name'], - update_rate = spawner_args[spawner_keyword]['update_rate'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - {%- endif -%} - -{%- endmacro -%} -{# #} - -{# propellers_macro {--> #} -{%- macro propellers_macro(prop_list, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, rotor_drag_coefficient, rolling_moment_coefficient, meshes_z_offset, prop_ixx, prop_ixy, prop_ixz, prop_iyy, prop_iyz, prop_izz, spawner_args) -%} - - {%- set spawner_keyword = 'disable-motor-crash' -%} - {%- set spawner_description = 'Disables motor failure after a crash with the environment.' -%} - {%- set spawner_default_args = none -%} - - {%- set enable_motor_crash = spawner_args[spawner_keyword] is undefined -%} - - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - {%- for prop_params in prop_list -%} - - {%- if prop_params['mesh_files'] | length == 1 -%} - - {{ generic.prop_macro( - direction = prop_params['direction'], - rotor_velocity_slowdown_sim = rotor_velocity_slowdown_sim, - motor_constant = motor_constant, - moment_constant = moment_constant, - parent = parent, - mass = mass, - radius = radius, - time_constant_up = time_constant_up, - time_constant_down = time_constant_down, - max_rot_velocity = max_rot_velocity, - motor_number = prop_params['motor_number'], - rotor_drag_coefficient = rotor_drag_coefficient, - rolling_moment_coefficient = rolling_moment_coefficient, - enable_motor_crash = enable_motor_crash, - color = prop_params['color'], - mesh_file = prop_params['mesh_files'][0], - mesh_scale = prop_params['mesh_scale'], - x = prop_params['x'], - y = prop_params['y'], - z = prop_params['z'], - roll = 0, - pitch = 0, - yaw = 0, - ixx = prop_ixx, - ixy = prop_ixy, - ixz = prop_ixz, - iyy = prop_iyy, - iyz = prop_iyz, - izz = prop_izz) - }} - - {%- elif prop_params['mesh_files'] | length == 2 -%} - - {{ generic.prop_macro_2_meshes( - direction = prop_params['direction'], - rotor_velocity_slowdown_sim = rotor_velocity_slowdown_sim, - motor_constant = motor_constant, - moment_constant = moment_constant, - parent = parent, - mass = mass, - radius = radius, - time_constant_up = time_constant_up, - time_constant_down = time_constant_down, - max_rot_velocity = max_rot_velocity, - motor_number = prop_params['motor_number'], - rotor_drag_coefficient = rotor_drag_coefficient, - rolling_moment_coefficient = rolling_moment_coefficient, - enable_motor_crash = enable_motor_crash, - color = prop_params['color'], - mesh_file_1 = prop_params['mesh_files'][0], - mesh_file_2 = prop_params['mesh_files'][1], - meshes_z_offset = meshes_z_offset, - mesh_scale = prop_params['mesh_scale'], - x = prop_params['x'], - y = prop_params['y'], - z = prop_params['z'], - roll = 0, - pitch = 0, - yaw = 0, - ixx = prop_ixx, - ixy = prop_ixy, - ixz = prop_ixz, - iyy = prop_iyy, - iyz = prop_iyz, - izz = prop_izz) - }} - - {%- endif -%} - - {%- endfor -%} - - -{%- endmacro -%} -{# #} - -{# ======================= rangefinder sensors ====================== #} - -{# garmin_down_macro (connected through pixhawk) {--> #} -{%- macro garmin_down_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-rangefinder' -%} - {%- set spawner_description = 'Add a laser rangefinder (Garmin LIDAR-Lite v3) pointing down. Creates a Gazebo publisher for gazebo_mavlink_interface. ROS topic must be created by mavros. Do not set range outside <0.06 - 40.0> (unrealistic)' -%} - {%- set spawner_default_args = {'update_rate': 100, 'min_range': 0.1, 'max_range': 36.0, 'noise': 0.01} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- set sensor_name = 'lidar0' -%} - - - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - - {{ generic.zero_inertial_macro() }} - - {{ generic.visual_mesh_macro( - name = sensor_name, - mesh_file = 'model://mrs_robots_description/meshes/sensors/garmin_lidar_v3.stl', - mesh_scale = '0.001 0.001 0.001', - color = 'DarkGrey', - x = 0.015, - y = 0, - z = 0, - roll = 0, - pitch = 0, - yaw = 0) - }} - - {{ generic.gazebo_rangefinder_sensor_macro( - name = sensor_name, - parent_frame_name = spawner_args['name'] + '/fcu', - sensor_frame_name = spawner_args['name'] + '/garmin', - topic = sensor_name, - update_rate = spawner_args[spawner_keyword]['update_rate'], - samples = 1, - fov = 0.03, - min_distance = spawner_args[spawner_keyword]['min_range'], - max_distance = spawner_args[spawner_keyword]['max_range'], - resolution = 0.005, - noise = spawner_args[spawner_keyword]['noise'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - - - {{ sensor_name }}_link - {{ parent_link }} - - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# garmin_down_external_macro (external -> connected to computer) {--> #} -{%- macro garmin_down_external_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-rangefinder-external' -%} - {%- set spawner_description = 'Add a laser rangefinder (Garmin LIDAR-Lite v3) pointing down. Creates a ROS topic /robot_name/garmin/range. Do not set range outside <0.06 - 40.0> (unrealistic)' -%} - {%- set spawner_default_args = {'update_rate': 100, 'min_range': 0.1, 'max_range': 36.0, 'noise': 0.01} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- set sensor_name = 'garmin' -%} - - - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - - {{ generic.zero_inertial_macro() }} - - {{ generic.visual_mesh_macro( - name = sensor_name, - mesh_file = 'model://mrs_robots_description/meshes/sensors/garmin_lidar_v3.stl', - mesh_scale = '0.001 0.001 0.001', - color = 'DarkGrey', - x = 0.015, - y = 0, - z = 0, - roll = 0, - pitch = 0, - yaw = 0) - }} - - {{ generic.rangefinder_sensor_macro( - name = sensor_name, - parent_frame_name = spawner_args['name'] + '/fcu', - sensor_frame_name = spawner_args['name'] + '/' + sensor_name, - topic = sensor_name + '/range', - update_rate = spawner_args[spawner_keyword]['update_rate'], - samples = 1, - fov = 0.03, - min_distance = spawner_args[spawner_keyword]['min_range'], - max_distance = spawner_args[spawner_keyword]['max_range'], - resolution = 0.005, - noise = spawner_args[spawner_keyword]['noise'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - - - {{ sensor_name }}_link - {{ parent_link }} - - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# garmin_up_external_macro (external -> connected to computer) {--> #} -{%- macro garmin_up_external_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-rangefinder-up' -%} - {%- set spawner_description = 'Add a laser rangefinder (Garmin LIDAR-Lite v3) pointing up. Creates a ROS topic /robot_name/garmin/range. Do not set range outside <0.06 - 40.0> (unrealistic)' -%} - {%- set spawner_default_args = {'update_rate': 100, 'min_range': 0.1, 'max_range': 36.0, 'noise': 0.01} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- set sensor_name = 'garmin_up' -%} - - - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - - {{ generic.zero_inertial_macro() }} - - {{ generic.visual_mesh_macro( - name = sensor_name, - mesh_file = 'model://mrs_robots_description/meshes/sensors/garmin_lidar_v3.stl', - mesh_scale = '0.001 0.001 0.001', - color = 'DarkGrey', - x = 0.015, - y = 0, - z = 0, - roll = 0, - pitch = 0, - yaw = 0) - }} - - {{ generic.rangefinder_sensor_macro( - name = sensor_name, - parent_frame_name = spawner_args['name'] + '/fcu', - sensor_frame_name = spawner_args['name'] + '/' + sensor_name, - topic = sensor_name + '/range', - update_rate = spawner_args[spawner_keyword]['update_rate'], - samples = 1, - fov = 0.03, - min_distance = spawner_args[spawner_keyword]['min_range'], - max_distance = spawner_args[spawner_keyword]['max_range'], - resolution = 0.005, - noise = spawner_args[spawner_keyword]['noise'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - - - {{ sensor_name }}_link - {{ parent_link }} - - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# teraranger_macro {--> #} -{%- macro teraranger_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-teraranger' -%} - {%- set spawner_description = 'Add a laser rangefinder (Teraranger One) pointing down' -%} - {%- set spawner_default_args = {'update_rate': 100, 'min_range': 0.1, 'max_range': 14.0, 'noise': 0.04} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- set sensor_name = 'teraranger' -%} - - - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_colored_box_macro(sensor_name, 0.015, 0.027, 0.033, 'Yellow', 0, 0, 0, 0, 0, 0) }} - {{ generic.rangefinder_sensor_macro( - name = sensor_name, - parent_frame_name = spawner_args['name'] + '/fcu', - sensor_frame_name = spawner_args['name'] + '/' + sensor_name, - topic = sensor_name + '/range', - update_rate = spawner_args[spawner_keyword]['update_rate'], - samples = 1, - fov = 0.03, - min_distance = spawner_args[spawner_keyword]['min_range'], - max_distance = spawner_args[spawner_keyword]['max_range'], - resolution = 0.005, - noise = spawner_args[spawner_keyword]['noise'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ parent_link }} - {{ sensor_name}}_link - - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# teraranger_evo_tower_macro {--> #} -{%- macro teraranger_evo_tower_macro(parent_link, visualize, frame_name, parent_frame_name, gaussian_noise, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-teraranger-evo-tower' -%} - {%- set spawner_description = 'Add the Teraranger Evo Tower laser scanner to the vehicle' -%} - {%- set spawner_default_args = none -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {# -- parameters of sensors -- (id, x, y, z, roll, pitch, yaw) #} - {%- set sensor_parameters = [(0, 0.046, 0.0, 0.001, 0.0, 0.0, 0.0), - (1, 0.032, 0.032, 0.001, 0.0, 0.0, math.radians(45)), - (2, 0.000, 0.046, 0.001, 0.0, 0.0, math.radians(90)), - (3, -0.032, 0.032, 0.001, 0.0, 0.0, math.radians(135)), - (4, -0.046, 0.000, 0.001, 0.0, 0.0, math.radians(180)), - (5, -0.032, -0.032, 0.001, 0.0, 0.0, -math.radians(135)), - (6, 0.000, -0.046, 0.001, 0.0, 0.0, -math.radians(90)), - (7, 0.032, -0.032, 0.001, 0.0, 0.0, -math.radians(45))] -%} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - 0 0 -0.014 0 0 0 - - - 0.001 - 0.06 - - - - - - - - {%- for id_, x_, y_, z_, roll_, pitch_, yaw_ in sensor_parameters -%} - - {{ generic.teraranger_evo_macro( - parent_link = parent_link, - id = id_, - visualize = visualize, - frame_name = frame_name, - parent_frame_name = parent_frame_name, - gaussian_noise = gaussian_noise, - x = x_, - y = y_, - z = z_, - roll = roll_, - pitch = pitch_, - yaw = yaw_) - }} - - {%- endfor -%} - - - - {{ parent_link }} - teraranger_evo_tower_link - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# ========================== LIDAR sensors ========================= #} - -{# rplidar_macro {--> #} -{%- macro rplidar_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-rplidar' -%} - {%- set spawner_description = 'Add the RPlidar A3 laser scanner. Do not set range outside <0.10 - 15.0> (unrealistic)' -%} - {%- set spawner_default_args = {'horizontal_samples': 1600, 'update_rate': 20.0, 'min_range': 0.15, 'max_range': 14.0, 'noise': 0.01} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- set sensor_name = 'rplidar' -%} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - - {{ generic.visual_mesh_macro( - name = 'base_visual', - mesh_file = 'model://mrs_robots_description/meshes/sensors/rplidar.stl', - mesh_scale = '0.001 0.001 0.001', - color = 'FlatBlack', - x = 0, - y = 0, - z = -0.029, - roll = 0, - pitch = 0, - yaw = math.radians(180)) - }} - - 0 0 -0.011 0 0 0 - - - 0.001 - 0.038 - - - - - - - - - - - false - {{ spawner_args[spawner_keyword]['update_rate'] }} - - - - {{ spawner_args[spawner_keyword]['horizontal_samples'] | int }} - 1 - -3.1241390751 - 3.1241390751 - - - - {{ spawner_args[spawner_keyword]['min_range'] }} - {{ spawner_args[spawner_keyword]['max_range'] }} - 0.01 - - - gaussian - 0.0 - {{ spawner_args[spawner_keyword]['noise'] }} - - - - {{ sensor_name }}/scan - {{ spawner_args['name'] }}/{{ sensor_name }} - {{ spawner_args['name'] }}/fcu - {{ x }} - {{ y }} - {{ z }} - {{ roll }} - {{ pitch }} - {{ yaw }} - - - - - - - - {{ parent_link }} - {{ sensor_name }}_link - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# scanse_sweep_macro {--> #} -{%- macro scanse_sweep_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-scanse-sweep' -%} - {%- set spawner_description = 'Add the Scanse Sweep laser scanner' -%} - {%- set spawner_default_args = {'horizontal_samples': 500, 'update_rate': 10.0, 'min_range': 0.45, 'max_range': 10.0, 'noise': 0.01} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - - - 0 0 -0.031 0 0 0 - - - 0.0255 - 0.0234 - - - - - - - - - - 0.0385 - 0.0325 - - - - - - - - - - - false - {{ spawner_args[spawner_keyword]['update_rate'] }} - - - - {{ spawner_args[spawner_keyword]['horizontal_samples'] | int }} - 1 - 0 - 6.283185 - - - - {{ spawner_args[spawner_keyword]['min_range'] }} - {{ spawner_args[spawner_keyword]['max_range'] }} - 0.01 - - - gaussian - 0.0 - {{ spawner_args[spawner_keyword]['noise'] }} - - - - scanse_sweep/range - {{ spawner_args['name'] }}/scanse_sweep - {{ spawner_args['name'] }}/fcu - {{ x }} - {{ y }} - {{ z }} - {{ roll }} - {{ pitch }} - {{ yaw }} - - - - - - - - {{ parent_link }} - sweeper_link - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# ouster_macro {--> #} -{%- macro ouster_macro(parent_link, sensor_name, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-ouster' -%} - {%- set spawner_description = 'Add Ouster laser scanner to the vehicle. Select a model to automatically set number of lines, vertical FOV and range. Available models: OS0-32, OS0-64, OS0-128, OS1-16, OS1-32G1, OS1-32, OS1-64, OS1-128, OS2-32, OS2-64, OS2-128' -%} - {%- set spawner_default_args = {'model': 'OS1-16', 'horizontal_samples': 2048, 'update_rate': 10, 'noise': 0.03, 'use_gpu': false} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {# model selection {--> #} - {%- set ouster_model = spawner_args[spawner_keyword]['model'] -%} - - {# OS0 {--> #} - - {# OS0-32 #} - {%- if ouster_model == 'OS0-32' -%} - {%- set lasers = 32 -%} - {%- set vfov_angle = 90 -%} - {%- set range = 55 -%} - {%- endif -%} - - {# OS0-64 #} - {%- if ouster_model == 'OS0-64' -%} - {%- set lasers = 64 -%} - {%- set vfov_angle = 90 -%} - {%- set range = 55 -%} - {%- endif -%} - - {# OS0-128 #} - {%- if ouster_model == 'OS0-128' -%} - {%- set lasers = 128 -%} - {%- set vfov_angle = 90 -%} - {%- set range = 55 -%} - {%- endif -%} - - {# #} - - {# OS1 Generation 1 {--> #} - {# #} - {%- if ouster_model == 'OS1-16' -%} - {%- set lasers = 16 -%} - {%- set vfov_angle = 33.2 -%} - {%- set range = 120 -%} - {%- endif -%} - {# #} - - {# OS1 Generation 2 {--> #} - - {# OS1-32 Generation 2 #} - {%- if ouster_model == 'OS1-32' -%} - {%- set lasers = 32 -%} - {%- set vfov_angle = 45 -%} - {%- set range = 120 -%} - {%- endif -%} - - {# OS1-64 Generation 2 #} - {%- if ouster_model == 'OS1-64' -%} - {%- set lasers = 64 -%} - {%- set vfov_angle = 45 -%} - {%- set range = 120 -%} - {%- endif -%} - - {# OS1-128 Generation 2 #} - {%- if ouster_model == 'OS1-128' -%} - {%- set lasers = 128 -%} - {%- set vfov_angle = 45 -%} - {%- set range = 120 -%} - {%- endif -%} - - {# #} - - {# OS2 {--> #} - - {# OS2-32 #} - {%- if ouster_model == 'OS2-32' -%} - {%- set lasers = 32 -%} - {%- set vfov_angle = 22.5 -%} - {%- set range = 240 -%} - {%- endif -%} - - {# OS2-64 #} - {%- if ouster_model == 'OS2-64' -%} - {%- set lasers = 64 -%} - {%- set vfov_angle = 22.5 -%} - {%- set range = 240 -%} - {%- endif -%} - - {# OS2-128 #} - {%- if ouster_model == 'OS2-128' -%} - {%- set lasers = 128 -%} - {%- set vfov_angle = 22.5 -%} - {%- set range = 240 -%} - {%- endif -%} - - {# #} - - {# #} - - {# The real ouster is transforming lidar data from lidar_frame to sensor_frame directly for user. #} - {# For simplicity, we are placing sensor_frame to the same place as the lidar_frame is. #} - - {# setup local variables {--> #} - - {# -- gazebo links -- #} - {%- set sensor_link = sensor_name + '_sensor_link' -%} - - {# -- frame names -- #} - {%- set frame_fcu = spawner_args['name'] + '/fcu' -%} - {%- set frame_sensor = spawner_args['name'] + '/' + sensor_name + '_sensor' -%} - {%- set frame_lidar = spawner_args['name'] + '/' + sensor_name + '_lidar' -%} - {%- set frame_imu = spawner_args['name'] + '/' + sensor_name + '_imu' -%} - - {# -- topics -- #} - {%- set topic_lidar = '/' + spawner_args['name'] + '/' + sensor_name + '_cloud_nodelet/points' -%} - {%- set topic_imu = '/' + spawner_args['name'] + '/' + sensor_name + '_cloud_nodelet/imu' -%} - {%- set topic_diag = '/' + spawner_args['name'] + '/' + sensor_name + '_cloud_nodelet/is_alive' -%} - - {# -- tf from sensor to lidar -- #} - {%- set lidar_x = 0 -%} - {%- set lidar_y = 0 -%} - {%- set lidar_z = 0.0344 -%} - {%- set lidar_roll = 0 -%} - {%- set lidar_pitch = 0 -%} - {%- set lidar_yaw = 0 -%} - - {# -- tf from sensor to imu -- #} - {%- set imu_x = 0.006253 -%} - {%- set imu_y = -0.011775 -%} - {%- set imu_z = 0.007645 -%} - {%- set imu_roll = 0 -%} - {%- set imu_pitch = 0 -%} - {%- set imu_yaw = 0 -%} - - {%- if spawner_args[spawner_keyword]['use_gpu'] -%} - {%- set ouster_plugin_filename ='libMrsGazeboCommonResources_3DLidarGpuPlugin.so' -%} - {%- set sensor_type = 'gpu_ray' -%} - {%- else -%} - {%- set ouster_plugin_filename ='libMrsGazeboCommonResources_3DLidarPlugin.so' -%} - {%- set sensor_type = 'ray' -%} - {%- endif -%} - - {# #} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - - {{ generic.visual_mesh_macro( - name = 'base_visual', - mesh_file = 'model://mrs_robots_description/meshes/sensors/os1_64.dae', - mesh_scale = '1 1 1', - color = 'White', - x = 0, - y = 0, - z = 0, - roll = 0, - pitch = 0, - yaw = math.radians(90)) - }} - - 0 0 {{ lidar_z }} 0 0 - - - 0.035 - 0.038 - - - - - - - - - - - {{ imu_x }} {{ imu_y }} {{ imu_z }} {{ imu_roll }} {{ imu_pitch }} {{ imu_yaw }} - true - true - 100 - false - __default_topic__ - - - {{ topic_imu }} - {{ sensor_link }} - 100 - 0.005 - 0 0 0 - 0 0 0 - {{ frame_imu }} - - - - - - - {{ lidar_x }} {{ lidar_y }} {{ lidar_z }} {{ lidar_roll }} {{ lidar_pitch }} {{ lidar_yaw }} - false - {{ spawner_args[spawner_keyword]['update_rate'] }} - - - - {{ spawner_args[spawner_keyword]['horizontal_samples'] }} - 1 - 0 - {{ 2*math.pi }} - - - {{ lasers }} - 1 - {{ -vfov_angle/2*math.radians(180)/180.0 }} - {{ vfov_angle/2*math.radians(180)/180.0 }} - - - - 0.1 - {{ range }} - 0.03 - - - - {{ frame_fcu }} - {{ frame_sensor }} - {{ x + lidar_x }} - {{ y + lidar_y }} - {{ z + lidar_z }} - {{ roll + lidar_roll }} - {{ pitch + lidar_pitch }} - {{ yaw + lidar_yaw }} - - - {{ frame_lidar }} - 0 - 0 - 0 - 0 - 0 - {{ math.radians(180) }} - {{ topic_lidar }} - {{ topic_diag }} - 0.1 - {{ range }} - true - {{ spawner_args[spawner_keyword]['noise'] }} - - - true - {{ frame_imu }} - {{ imu_x - lidar_x }} - {{ imu_y - lidar_y }} - {{ imu_z - lidar_z }} - {{ imu_roll - lidar_roll }} - {{ imu_pitch - lidar_pitch }} - {{ imu_yaw - lidar_yaw }} - - - - - - - - {{ parent_link }} - {{ sensor_link }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# velodyne_macro {--> #} -{%- macro velodyne_macro(parent_link, sensor_name, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-velodyne' -%} - {%- set spawner_description = 'Add Velodyne PUCK laser scanner to the vehicle' -%} - {%- set spawner_default_args = {'horizontal_samples': 3600, 'lasers': 16, 'noise': 0.01, 'range': 100, 'vfov': 30, 'update_rate': 20, 'use_gpu': false} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {# setup local variables {--> #} - - {# The real ouster is transforming lidar data from lidar_frame to sensor_frame directly for user. #} - {# For simplicity, we are placing sensor_frame to the same place as the lidar_frame is. #} - {# Velodyne macro is using the same plugin as ouster macro. Therefore we need to render data in the same way. #} - - {# -- frame names -- #} - {%- set frame_fcu = spawner_args['name'] + '/fcu' -%} - {%- set frame_sensor = spawner_args['name'] + '/' + sensor_name + '_sensor' -%} - {%- set frame_lidar = spawner_args['name'] + '/' + sensor_name -%} - - {# -- topics -- #} - {%- set topic_lidar = '/' + spawner_args['name'] + '/' + sensor_name + '/scan' -%} - {%- set topic_diag = '/' + spawner_args['name'] + '/' + sensor_name + '/is_alive' -%} - - {# -- tf from sensor to lidar -- #} - {# The laser rays should be coming approximately from the half of sensor height #} - {%- set lidar_x = 0 -%} - {%- set lidar_y = 0 -%} - {%- set lidar_z = 0.037725 -%} - {%- set lidar_roll = 0 -%} - {%- set lidar_pitch = 0 -%} - {%- set lidar_yaw = 0 -%} - - {%- if spawner_args[spawner_keyword]['use_gpu'] -%} - {%- set velodyne_plugin_filename ='libMrsGazeboCommonResources_3DLidarGpuPlugin.so' -%} - {%- set sensor_type = 'gpu_ray' -%} - {%- else -%} - {%- set velodyne_plugin_filename ='libMrsGazeboCommonResources_3DLidarPlugin.so' -%} - {%- set sensor_type = 'ray' -%} - {%- endif -%} - {# #} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - - - 0 0 0.0094 0 0 0 - - - 0.0188 - 0.062 - - - - - - - - 0 0 0.0643 0 0 0 - - - 0.0148 - 0.062 - - - - - - - - 0 0 0.03785 0 0 0 - - - 0.0381 - 0.058 - - - - - - - - - - - {{ lidar_x }} {{ lidar_y }} {{ lidar_z }} {{ lidar_roll }} {{ lidar_pitch }} {{ lidar_yaw }} - {# 0 0 0 0 0 0 #} - false - {{ spawner_args[spawner_keyword]['update_rate'] }} - - - - {{ spawner_args[spawner_keyword]['horizontal_samples'] }} - 1 - {{ -math.radians(180) }} - {{ math.radians(180) }} - - - {{ spawner_args[spawner_keyword]['lasers'] }} - 1 - {{ -spawner_args[spawner_keyword]['vfov']/2*math.radians(180)/180.0 }} - {{ spawner_args[spawner_keyword]['vfov']/2*math.radians(180)/180.0 }} - - - - 0.1 - {{ spawner_args[spawner_keyword]['range'] }} - 0.03 - - - - {{ frame_fcu }} - {{ frame_sensor }} - {{ x + lidar_x }} - {{ y + lidar_y }} - {{ z + lidar_z }} - {{ roll }} - {{ pitch }} - {{ yaw }} - 0 - 0 - 0 - {{ lidar_roll }} - {{ lidar_pitch }} - {{ lidar_yaw }} - {{ topic_lidar }} - {{ topic_diag }} - {{ frame_lidar }} - 0.1 - {{ spawner_args[spawner_keyword]['range'] }} - {{ spawner_args[spawner_keyword]['noise'] }} - false - - - - - - - - {{ parent_link }} - velodyne_link - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# ============================= cameras ============================ #} - -{# realsense_top_macro {--> #} -{%- macro realsense_top_macro(camera_name, camera_suffix, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-realsense-top' -%} - {%- set spawner_description = 'Add Intel Realsense D435 depth camera to the vehicle [1280x720 @ 30hz], pointed forward, placed on an aluminum frame above the body' -%} - {%- set spawner_default_args = {'realistic': False, 'update_rate': 30} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.realsense_d435_macro( - namespace = spawner_args['name'], - camera_name = camera_name, - camera_suffix = camera_suffix, - parent_link = parent_link, - realistic = spawner_args[spawner_keyword]['realistic'], - update_rate = spawner_args[spawner_keyword]['update_rate'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} - -{%- endmacro -%} -{# #} - -{# realsense_front_macro {--> #} -{%- macro realsense_front_macro(camera_name, camera_suffix, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-realsense-front' -%} - {%- set spawner_description = 'Add Intel Realsense D435 depth camera to the vehicle [1280x720 @ 30hz], pointed forward placed on the front holder between the legs' -%} - {%- set spawner_default_args = {'realistic': False, 'update_rate': 30} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.realsense_d435_macro( - namespace = spawner_args['name'], - camera_name = camera_name, - camera_suffix = camera_suffix, - parent_link = parent_link, - realistic = spawner_args[spawner_keyword]['realistic'], - update_rate = spawner_args[spawner_keyword]['update_rate'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} - -{%- endmacro -%} -{# #} - -{# realsense_front_pitched_macro {--> #} -{%- macro realsense_front_pitched_macro(camera_name, camera_suffix, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-realsense-front-pitched' -%} - {%- set spawner_description = 'Add Intel Realsense D435 depth camera to the vehicle [1280x720 @ 30hz], pointed forward pitched down by 10-45 deg (angle depends on vehicle model)' -%} - {%- set spawner_default_args = {'realistic': False, 'update_rate': 30} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.realsense_d435_macro( - namespace = spawner_args['name'], - camera_name = camera_name, - camera_suffix = camera_suffix, - parent_link = parent_link, - realistic = spawner_args[spawner_keyword]['realistic'], - update_rate = spawner_args[spawner_keyword]['update_rate'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} - -{%- endmacro -%} -{# #} - -{# realsense_up_macro {--> #} -{%- macro realsense_up_macro(camera_name, camera_suffix, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-realsense-up' -%} - {%- set spawner_description = 'Add Intel Realsense D435 depth camera to the vehicle [1280x720 @ 30hz], pointed upwards' -%} - {%- set spawner_default_args = {'realistic': False, 'update_rate': 30} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.realsense_d435_macro( - namespace = spawner_args['name'], - camera_name = camera_name, - camera_suffix = camera_suffix, - parent_link = parent_link, - realistic = spawner_args[spawner_keyword]['realistic'], - update_rate = spawner_args[spawner_keyword]['update_rate'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} - -{%- endmacro -%} -{# #} - -{# realsense_down_macro {--> #} -{%- macro realsense_down_macro(camera_name, camera_suffix, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-realsense-down' -%} - {%- set spawner_description = 'Add Intel Realsense D435 depth camera to the vehicle [1280x720 @ 30hz], pointed down' -%} - {%- set spawner_default_args = {'realistic': False, 'update_rate': 30} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.realsense_d435_macro( - namespace = spawner_args['name'], - camera_name = camera_name, - camera_suffix = camera_suffix, - parent_link = parent_link, - realistic = spawner_args[spawner_keyword]['realistic'], - update_rate = spawner_args[spawner_keyword]['update_rate'], - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} - -{%- endmacro -%} -{# #} - -{# bluefox_camera_macro {--> #} -{%- macro bluefox_camera_macro(camera_name, parent_link, x, y, z, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-bluefox-camera' -%} - {%- set spawner_description = 'Add bluefox camera to the vehicle [752x480 @ 50hz], pointing down' -%} - {%- set spawner_default_args = {'update_rate': 100, 'noise': 0.0} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - frame_rate = spawner_args[spawner_keyword]['update_rate'], - horizontal_fov = 2.1, - image_width = 752, - image_height = 480, - min_distance = 0.02, - max_distance = 80, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/bluefox.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = math.radians(90), - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = 0, - pitch = math.radians(90), - yaw = 0) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# bluefox_camera_reverse_macro {--> #} -{%- macro bluefox_camera_reverse_macro(camera_name, parent_link, x, y, z, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-bluefox-camera-reverse' -%} - {%- set spawner_description = 'Add bluefox camera to the vehicle [752x480 @ 50hz], pointing down but image is rotated by 180 deg' -%} - {%- set spawner_default_args = {'update_rate': 100, 'noise': 0.0} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - frame_rate = spawner_args[spawner_keyword]['update_rate'], - horizontal_fov = 2.1, - image_width = 752, - image_height = 480, - min_distance = 0.02, - max_distance = 80, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/bluefox.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = math.radians(90), - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = 0, - pitch = math.radians(90), - yaw = math.radians(180)) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# bluefox_camera_front_macro {--> #} -{%- macro bluefox_camera_front_macro(camera_name, parent_link, x, y, z, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-bluefox-camera-front' -%} - {%- set spawner_description = 'Add bluefox camera to the vehicle [752x480 @ 50hz], pointing forward' -%} - {%- set spawner_default_args = {'update_rate': 100, 'noise': 0.0} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - frame_rate = spawner_args[spawner_keyword]['update_rate'], - horizontal_fov = 2.1, - image_width = 752, - image_height = 480, - min_distance = 0.02, - max_distance = 80, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/bluefox.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = math.radians(90), - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = 0, - pitch = 0, - yaw = 0) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# mobius_down_macro {-->#} -{%- macro mobius_down_macro(camera_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-mobius-camera-down' -%} - {%- set spawner_description = 'Add mobius camera to the vehicle [1280x720 @ 30hz], pointing down' -%} - {%- set spawner_default_args = {'update_rate': 30, 'noise': 0.007} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - frame_rate = spawner_args[spawner_keyword]['update_rate'], - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - horizontal_fov = 2.28638, - image_width = 1280, - image_height = 720, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/mobius.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = -0.004, - visual_y = 0.0045, - visual_z = 0, - visual_roll = 0, - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# mobius_front_macro {-->#} -{%- macro mobius_front_macro(camera_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-mobius-camera-front' -%} - {%- set spawner_description = 'Add mobius camera to the vehicle [1280x720 @ 30hz], pointing forward' -%} - {%- set spawner_default_args = {'update_rate': 30, 'noise': 0.007} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - frame_rate = spawner_args[spawner_keyword]['update_rate'], - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - horizontal_fov = 2.28638, - image_width = 1280, - image_height = 720, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/mobius.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = -0.004, - visual_y = 0.0045, - visual_z = 0, - visual_roll = 0, - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# mobius_back_left_macro {-->#} -{%- macro mobius_back_left_macro(camera_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-mobius-camera-back-left' -%} - {%- set spawner_description = 'Add mobius camera to the vehicle [1280x720 @ 30hz], pointing to the back left' -%} - {%- set spawner_default_args = {'update_rate': 30, 'noise': 0.007} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - frame_rate = spawner_args[spawner_keyword]['update_rate'], - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - horizontal_fov = 2.28638, - image_width = 1280, - image_height = 720, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/mobius.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = -0.004, - visual_y = 0.0045, - visual_z = 0, - visual_roll = 0, - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# mobius_back_right_macro {-->#} -{%- macro mobius_back_right_macro(camera_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-mobius-camera-back-right' -%} - {%- set spawner_description = 'Add mobius camera to the vehicle [1280x720 @ 30hz], pointing to the back right' -%} - {%- set spawner_default_args = {'update_rate': 30, 'noise': 0.007} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - frame_rate = spawner_args[spawner_keyword]['update_rate'], - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - horizontal_fov = 2.28638, - image_width = 1280, - image_height = 720, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/mobius.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = -0.004, - visual_y = 0.0045, - visual_z = 0, - visual_roll = 0, - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# fisheye_bluefox_macro {--> #} -{%- macro fisheye_bluefox_macro(camera_name, topic_ns_prefix, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-fisheye-camera' -%} - {%- set spawner_description = 'Add a fisheye bluefox camera [752x480 @ 45hz, 180 deg] to the vehicle' -%} - {%- set spawner_default_args = {'update_rate': 45, 'noise': 0.0} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.fisheye_camera_macro( - camera_name = camera_name, - topic_ns_prefix = topic_ns_prefix, - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - parent_link = parent_link, - frame_rate = spawner_args[spawner_keyword]['update_rate'], - horizontal_fov = math.radians(180), - image_width = 752, - image_height = 480, - lens_type = 'custom', - lens_c1 = 1.05, - lens_c2 = 4, - lens_f = 1.0, - lens_fun = 'tan', - lens_scale = True, - lens_cutoff_angle = math.radians(90), - lens_texture_size = 512, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/bluefox.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = math.radians(90), - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# servo_camera_macro {--> #} -{%- macro servo_camera_macro(parent, offset_pitch_link_x, offset_pitch_link_y, offset_pitch_link_z, offset_pitch_link_yaw, offset_pitch_link_roll, offset_pitch_link_pitch, offset_roll_link_x, offset_roll_link_y, offset_roll_link_z, offset_roll_link_yaw, offset_roll_link_roll, offset_roll_link_pitch, tilt_update_rate, max_pitch, min_pitch, max_pitch_rate, max_roll, min_roll, max_roll_rate, compensate_tilt_roll, compensate_tilt_pitch, parent_frame_name, sensor_base_frame_name, camera_frame_name, camera_update_rate, horizontal_fov, img_width, img_height, roll_link_mesh_file, pitch_link_mesh_file, mesh_scale, spawner_args) -%} - - {%- set spawner_keyword = 'enable-servo-camera' -%} - {%- set spawner_description = 'Add a camera on virtual servo to the vehicle' -%} - {%- set spawner_default_args = none -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - - 0 0 0 0 0 0 - {{ generic.zero_inertial_macro() }} - - 0 0 0 0 0 0 - - {%- if roll_link_mesh_file == '' -%} - - 0.01 0.01 0.01 - - {%- else -%} - - {{ roll_link_mesh_file }} - {{ mesh_scale }} - - {%- endif -%} - - - - - - - - - - - 0 0 0 0 0 0 - {{ generic.zero_inertial_macro() }} - - 0 0 0 0 0 0 - - {%- if pitch_link_mesh_file == '' -%} - - 0.01 0.01 0.01 - - {%- else -%} - - {{ pitch_link_mesh_file }} - {{ mesh_scale }} - - {%- endif -%} - - - - - - - {{ camera_update_rate }} - - {{ horizontal_fov }} - - {{ img_width }} - {{ img_height }} - - - 0.25 - 100 - - - gaussian - - 0.0 - 0.01 - - - - true - {{ camera_update_rate }} - servo_camera - image_raw - camera_info - {{ camera_frame_name }} - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - 0.0 - {{ parent_frame_name }} - {{ sensor_base_frame_name }} - - - - - - {{ tilt_update_rate }} - {{ max_pitch_rate }} - {{ max_pitch }} - {{ min_pitch }} - {{ max_roll_rate }} - {{ max_roll }} - {{ min_roll }} - servo_camera_pitch_joint - servo_camera_roll_joint - servo_camera_gimbal_link - {{ parent }} - {{ compensate_tilt_roll }} - {{ compensate_tilt_pitch }} - - - - - - {{ parent }} - servo_camera_gimbal_link - {{ offset_roll_link_x }} {{ offset_roll_link_y }} {{ offset_roll_link_z }} {{ offset_roll_link_roll }} {{ offset_roll_link_pitch }} {{ offset_roll_link_yaw }} - - 1 0 0 - - -0.5 - 0.5 - 1 - 10 - - - 0.0 - 0.0 - - - - - - servo_camera_gimbal_link - servo_camera_link - {{ offset_pitch_link_x }} {{ offset_pitch_link_y }} {{ offset_pitch_link_z }} {{ offset_pitch_link_roll }} {{ offset_pitch_link_pitch }} {{ offset_pitch_link_yaw }} - - 0 1 0 - - -1.57 - 1.57 - 1 - 10 - - - 0.0 - 0.0 - - - - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# TODO: Thermal camera plugin is not core #} -{# thermal_cameras_macro {--> #} -{%- macro thermal_cameras_macro(cameras_list, parent_link, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-thermal-cameras' -%} - {%- set spawner_description = 'Add several thermal cameras to the vehicle' -%} - {%- set spawner_default_args = {'image_width': 32, 'image_height': 32, 'update_rate': 14} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- if cameras_list | length > 0 -%} - - {%- for camera in cameras_list -%} - - {{ generic.thermal_camera_macro( - camera_name = camera['name'], - camera_topic_name = '/' + spawner_args['name'] + '/thermal/' + camera['name'], - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = 'thermal/' + camera['name'] + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/thermal/' + camera['name'], - parent_link = parent_link, - frame_rate = spawner_args[spawner_keyword]['update_rate'], - hfov = 0.575959, - image_width = spawner_args[spawner_keyword]['image_width'] | int, - image_height = spawner_args[spawner_keyword]['image_height'] | int, - x = camera['x'], - y = camera['y'], - z = camera['z'], - roll = camera['roll'], - pitch = camera['pitch'], - yaw = camera['yaw']) - }} - - {%- endfor -%} - - - {{ mount }} - - - - {%- endif -%} - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# basler_camera_down_macro {--> #} -{%- macro basler_camera_down_macro(camera_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-basler-camera-down' -%} - {%- set spawner_description = 'Add a Basler Dart camera pointing down' -%} - {%- set spawner_default_args = {'image_width': 1920, 'image_height': 1080, 'update_rate': 30, 'hfov': 1.990252, 'noise': 0.007} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.camera_macro( - parent_link = parent_link, - camera_name = camera_name, - camera_frame_name = spawner_args['name'] + '/' + camera_name + '_optical', - frame_rate = spawner_args[spawner_keyword]['update_rate'], - sensor_base_frame_name = spawner_args['name'] + '/' + camera_name, - parent_frame_name = spawner_args['name'] + '/fcu', - horizontal_fov = spawner_args[spawner_keyword]['hfov'], - image_width = spawner_args[spawner_keyword]['image_width'], - image_height = spawner_args[spawner_keyword]['image_height'], - min_distance = 0.02, - max_distance = 80, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/basler_dart.stl', - mesh_scale = '0.001 0.001 0.001', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = 0, - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# ========================= UVDAR components ======================= #} - -{# dual_uv_cameras_macro {--> #} -{%- macro dual_uv_cameras_macro(parent_link, x1, y1, z1, roll1, pitch1, yaw1, x2, y2, z2, roll2, pitch2, yaw2, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-dual-uv-cameras' -%} - {%- set spawner_description = 'Add right and left UV cameras to the vehicle. Requires param "calib_file" to be set. Setting param "occlusions" to True requires a BEEFY computer.' -%} - {%- set spawner_default_args = {'occlusions': False, 'calib_file': none, 'update_rate': 60} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- if spawner_args[spawner_keyword]['calib_file'] is not none -%} - - {{ generic.uvcam_macro( - parent_link = parent_link, - camera_publish_topic = '/' + spawner_args['name'] + '/uvdar_bluefox_left/image_raw', - calibration_file = spawner_args[spawner_keyword]['calib_file'], - occlusions = spawner_args[spawner_keyword]['occlusions'], - frame_rate = spawner_args[spawner_keyword]['update_rate'], - device_id = spawner_args['name'] + '_1', - x = x1, - y = y1, - z = z1, - roll = roll1, - pitch = pitch1, - yaw = yaw1) - }} - - {{ generic.uvcam_macro( - parent_link = parent_link, - camera_publish_topic = '/' + spawner_args['name'] + '/uvdar_bluefox_right/image_raw', - calibration_file = spawner_args[spawner_keyword]['calib_file'], - occlusions = spawner_args[spawner_keyword]['occlusions'], - frame_rate = spawner_args[spawner_keyword]['update_rate'], - device_id = spawner_args['name'] + '_2', - x = x2, - y = y2, - z = z2, - roll = roll2, - pitch = pitch2, - yaw = yaw2) - }} - - - {{ mount }} - - - - {%- endif -%} - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# back_uv_camera_macro {--> #} -{%- macro back_uv_camera_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-back-uv-camera' -%} - {%- set spawner_description = 'Add a back UV camera to the vehicle. Requires param "calib_file" to be set' -%} - {%- set spawner_default_args = {'occlusions': False, 'calib_file': none, 'update_rate': 60} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - {{ generic.uvcam_macro( - parent_link = parent_link, - camera_publish_topic = '/' + spawner_args['name'] + '/uvdar_bluefox_back/image_raw', - calibration_file = spawner_args[spawner_keyword]['calib_file'], - occlusions = spawner_args[spawner_keyword]['occlusions'], - frame_rate = spawner_args[spawner_keyword]['update_rate'], - device_id = spawner_args['name'] + '_3', - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# downward_uv_camera_macro {--> #} -{%- macro downward_uv_camera_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-downward-uv-camera' -%} - {%- set spawner_description = 'Add a UV camera to the vehicle pointed down. Requires param "calib_file" to be set' -%} - {%- set spawner_default_args = {'occlusions': False, 'calib_file': none, 'update_rate': 60} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - {{ generic.uvcam_macro( - parent_link = parent_link, - camera_publish_topic = '/' + spawner_args['name'] + '/uvdar_bluefox_bottom/image_raw', - calibration_file = spawner_args[spawner_keyword]['calib_file'], - occlusions = spawner_args[spawner_keyword]['occlusions'], - frame_rate = spawner_args[spawner_keyword]['update_rate'], - device_id = spawner_args['name'] + '_3', - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# uv_leds_macro {--> #} -{%- macro uv_leds_macro(parent_link, x1, x2, y1, y2, z, spawner_args) -%} - - {%- set spawner_keyword = 'enable-uv-leds' -%} - {%- set spawner_description = 'Add UV LEDs to the vehicle. Requires param "signal_id" to be set. Legacy params "left_id" and "right_id" may replace "signal_id" (for backwards compatibility)' -%} - {%- set spawner_default_args = {'signal_id': none, 'left_id': none, 'right_id': none} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {# setup led signals {--> #} - {%- if spawner_args[spawner_keyword]['signal_id'] is not none and spawner_args[spawner_keyword]['signal_id'] | length > 3 -%} - - {%- set led1 = spawner_args[spawner_keyword]['signal_id'][0] -%} - {%- set led2 = spawner_args[spawner_keyword]['signal_id'][1] -%} - {%- set led4 = spawner_args[spawner_keyword]['signal_id'][3] -%} - {%- set led3 = spawner_args[spawner_keyword]['signal_id'][2] -%} - - {%- elif spawner_args[spawner_keyword]['left_id'] is not none and spawner_args[spawner_keyword]['right_id'] is not none -%} - - {%- set led1 = spawner_args[spawner_keyword]['left_id'] -%} - {%- set led2 = spawner_args[spawner_keyword]['right_id'] -%} - {%- set led3 = spawner_args[spawner_keyword]['left_id'] -%} - {%- set led4 = spawner_args[spawner_keyword]['right_id'] -%} - - {%- endif -%} - {# #} - - {%- if led1 is not none and led2 is not none and led3 is not none and led4 is not none -%} - - {# -- leds configuration -- (id, signal_id, x, y, z, roll, pitch, yaw) #} - {%- set uv_leds_macro_parameters = [(1, led1, x1, y1, z, 0.0, math.radians(90), 0.0), - (2, led1, x2, y2, z, 0.0, math.radians(90), math.radians(90)), - (3, led2, x2, -y2, z, 0.0, math.radians(90), -math.radians(90)), - (4, led2, x1, -y1, z, 0.0, math.radians(90), 0.0), - (5, led3, -x2, y2, z, 0.0, math.radians(90), math.radians(90)), - (6, led3, -x1, y1, z, 0.0, math.radians(90), math.radians(180)), - (7, led4, -x1, -y1, z, 0.0, math.radians(90), -math.radians(180)), - (8, led4, -x2, -y2, z, 0.0, math.radians(90), -math.radians(90))] -%} - - - {%- for id_, signal_id_, x_, y_, z_, roll_, pitch_, yaw_ in uv_leds_macro_parameters -%} - - {{ generic.uvled_macro( - parent_link = parent_link, - device_id = spawner_args['name'] + '_' + id_ | string(), - signal_id = signal_id_, - x = x_, - y = y_, - z = z_, - roll = roll_, - pitch = pitch_, - yaw = yaw_) - }} - - {%- endfor -%} - - - {%- endif -%} - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# uv_leds_beacon_macro {--> #} -{%- macro uv_leds_beacon_macro(parent_link, x1, x2, y1, y2, z, spawner_args) -%} - - {%- set spawner_keyword = 'enable-uv-leds-beacon' -%} - {%- set spawner_description = 'Add UV LED beacon to the top of the vehicle. Requires param "signal_id" to be set.' -%} - {%- set spawner_default_args = {'signal_id': none} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- if spawner_args[spawner_keyword]['signal_id'] is not none -%} - - {# setup led signals {--> #} - {# -- leds configuration -- (id, signal_id, x, y, z, roll, pitch, yaw) #} - {%- set uv_leds_macro_parameters = [('b1', spawner_args[spawner_keyword]['signal_id'], x1, y1, z, 0.0, math.radians(90), 0.0), - ('b2', spawner_args[spawner_keyword]['signal_id'], x2, y2, z, 0.0, math.radians(90), math.radians(90)), - ('b3', spawner_args[spawner_keyword]['signal_id'], -x1, -y1, z, 0.0, math.radians(90), math.radians(180)), - ('b4', spawner_args[spawner_keyword]['signal_id'], -x2, -y2, z, 0.0, math.radians(90), math.radians(270))] -%} - - {# #} - - {%- for id_, signal_id_, x_, y_, z_, roll_, pitch_, yaw_ in uv_leds_macro_parameters -%} - - {{ generic.uvled_macro( - parent_link = parent_link, - device_id = spawner_args['name'] + '_' + id_ | string(), - signal_id = signal_id_, - x = x_, - y = y_, - z = z_, - roll = roll_, - pitch = pitch_, - yaw = yaw_) - }} - - {%- endfor -%} - - {%- endif -%} - - {%- endif -%} -{%- endmacro -%} -{# #} - - -{# ========================== VIO components ======================== #} - -{# vio_macro {--> #} -{%- macro vio_macro(sensor_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-vio' -%} - {%- set spawner_description = 'Add a forward-looking fisheye camera and a high-frequency IMU' -%} - {%- set spawner_default_args = {'camera_rate': 45, 'camera_noise': 0.0, 'imu_rate': 100, 'imu_noise': 0.0} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.fisheye_camera_macro( - camera_name = sensor_name, - topic_ns_prefix = 'camera/', - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = spawner_args['name'] + '/' + sensor_name + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/' + sensor_name, - parent_link = parent_link, - frame_rate = spawner_args[spawner_keyword]['camera_rate'], - horizontal_fov = math.radians(180), - image_width = 752, - image_height = 480, - lens_type = 'custom', - lens_c1 = 1.05, - lens_c2 = 4, - lens_f = 1.0, - lens_fun = 'tan', - lens_scale = True, - lens_cutoff_angle = math.radians(90), - lens_texture_size = 512, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['camera_noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/bluefox.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = math.radians(90), - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ generic.imu_sensor_macro( - sensor_name = sensor_name + '_imu', - parent_link = parent_link, - update_rate = spawner_args[spawner_keyword]['imu_rate'], - topic_name = '/' + spawner_args['name'] + '/' + sensor_name + '/imu', - frame_name = spawner_args['name'] + '/' + sensor_name, - noise_mean = spawner_args[spawner_keyword]['imu_noise'], - x = 0, - y = 0, - z = 0, - roll = -math.radians(90), - pitch = 0, - yaw = -math.radians(90)) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# vio_down_macro {--> #} -{%- macro vio_down_macro(sensor_name, parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-vio-down' -%} - {%- set spawner_description = 'Add a downward-looking fisheye camera and a high-frequency IMU' -%} - {%- set spawner_default_args = {'camera_rate': 45, 'camera_noise': 0.0, 'imu_rate': 100, 'imu_noise': 0.0} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - - {{ generic.fisheye_camera_macro( - camera_name = sensor_name, - topic_ns_prefix = 'camera/', - parent_frame_name = spawner_args['name'] + '/fcu', - camera_frame_name = spawner_args['name'] + '/' + sensor_name + '_optical', - sensor_base_frame_name = spawner_args['name'] + '/' + sensor_name, - parent_link = parent_link, - frame_rate = spawner_args[spawner_keyword]['camera_rate'], - horizontal_fov = math.radians(180), - image_width = 752, - image_height = 480, - lens_type = 'custom', - lens_c1 = 1.05, - lens_c2 = 4, - lens_f = 1.0, - lens_fun = 'tan', - lens_scale = True, - lens_cutoff_angle = math.radians(90), - lens_texture_size = 512, - min_distance = 0.02, - max_distance = 40, - noise_mean = 0.0, - noise_stddev = spawner_args[spawner_keyword]['camera_noise'], - mesh_file = 'model://mrs_robots_description/meshes/sensors/bluefox.dae', - mesh_scale = '1 1 1', - color = 'DarkGrey', - visual_x = 0, - visual_y = 0, - visual_z = 0, - visual_roll = math.radians(90), - visual_pitch = 0, - visual_yaw = 0, - x = x, - y = y, - z = z, - roll = roll, - pitch = pitch, - yaw = yaw) - }} - - - - {{ generic.imu_sensor_macro( - sensor_name = sensor_name + '_imu', - parent_link = parent_link, - update_rate = spawner_args[spawner_keyword]['imu_rate'], - topic_name = '/' + spawner_args['name'] + '/' + sensor_name + '/imu', - frame_name = spawner_args['name'] + '/' + sensor_name, - noise_mean = spawner_args[spawner_keyword]['imu_noise'], - x = 0, - y = 0, - z = 0, - roll = -math.radians(90), - pitch = 0, - yaw = -math.radians(90)) - }} - - - - {{ mount }} - - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# ==================== miscellaneous components ==================== #} - -{# light_macro {--> #} -{%- macro light_macro(parent_link, max_pitch_rate, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-light' -%} - {%- set spawner_description = 'Add a light on a gimbal to the vehicle. Requires a Gazebo world with enabled shadows' -%} - {%- set spawner_default_args = {'update_rate': 30, 'compensate_tilt': True, 'initial_on': True} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_colored_box_macro('light', 0.01, 0.01, 0.01, 'Yellow', 0, 0, 0, 0, 0, 0) }} - - - - {{ x }} - {{ y }} - {{ z }} - {{ roll }} - {{ pitch }} - {{ yaw }} - {{ parent_link }} - {{ spawner_args[spawner_keyword]['update_rate'] }} - {{ max_pitch_rate }} - {{ spawner_args[spawner_keyword]['initial_on'] }} - {{ spawner_args[spawner_keyword]['compensate_tilt'] }} - - - - {{ parent_link }} - light_macro_link - - 0 1 0 - - -1.57 - 1.57 - 1 - 10 - - - 0.0 - 0.0 - - - - - - {%- endif -%} -{%- endmacro -%} - - -{# magnet_gripper_visualization_macro {--> #} -{%- macro magnet_gripper_visualization_macro(parent_link, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-magnetic-gripper' -%} - {%- set spawner_description = 'Add a magnetic gripper visualization' -%} - {%- set spawner_default_args = none %} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_colored_box_macro('front', 0.005, 0.05, 0.06, 'Black', -0.09, 0, 0.03, 0, 0, 0) }} - {{ generic.visual_colored_box_macro('back', 0.005, 0.05, 0.06, 'Black', 0.09, 0, 0.03, 0, 0, 0) }} - {{ generic.visual_colored_box_macro('down', 0.18, 0.05, 0.005, 'Black', 0, 0, 0, 0, 0, 0) }} - {{ generic.visual_colored_box_macro('up', 0.18, 0.05, 0.005, 'Black', 0, 0, 0.06, 0, 0, 0) }} - - 0 0 0 0 0 0 - - - 0.18 0.05 0.005 - - - - - - - {{ parent_link }} - magnet_gripper_visualization_link - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# omni_ultrasounds_macro {--> #} -{%- macro omni_ultrasounds_macro(sensors_list, parent_link, spawner_args) -%} - - {%- set spawner_keyword = 'enable-omni-ultrasounds' -%} - {%- set spawner_description = 'Add omnidirectional ultrasonic sensors (up, down, 4 in horizontal plane)' -%} - {%- set spawner_default_args = none -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {%- for sensor in sensors_list -%} - - - {{ generic.ultrasonic_sensor_macro( - namespace = spawner_args['name'], - parent_link = parent_link, - suffix = sensor['suffix'], - x = sensor['x'], - y = sensor['y'], - z = sensor['z'], - roll = sensor['roll'], - pitch = sensor['pitch'], - yaw = sensor['yaw']) - }} - - - {%- endfor -%} - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# pendulum_macro {--> #} -{%- macro pendulum_macro(parent_link, x, y, z, spawner_args) -%} - - {%- set spawner_keyword = 'enable-pendulum' -%} - {%- set spawner_description = 'Add a pendulum to the vehicle. Specify the length and mass of the whole chain. Length and mass is uniformly distributed between the links' -%} - {%- set spawner_default_args = {'chain_length': 3.0, 'chain_mass': 0.5, 'num_links': 30, 'radius': 0.01} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ generic.single_chain_pendulum_macro( - parent_link = parent_link, - id = 0, - link_mass = spawner_args[spawner_keyword]['chain_mass'] / spawner_args[spawner_keyword]['num_links'], - link_radius = spawner_args[spawner_keyword]['radius'], - link_length = spawner_args[spawner_keyword]['chain_length'] / spawner_args[spawner_keyword]['num_links'], - joint_offset_x = x, - joint_offset_y = y, - joint_offset_z = z) - }} - - - {%- for id_ in range(1, spawner_args[spawner_keyword]['num_links'] | int) -%} - - - {{ generic.single_chain_pendulum_macro( - parent_link = 'pendulum_chain_' + (id_ - 1)| string() + '_link', - id = id_, - link_mass = spawner_args[spawner_keyword]['chain_mass'] / spawner_args[spawner_keyword]['num_links'], - link_radius = spawner_args[spawner_keyword]['radius'], - link_length = spawner_args[spawner_keyword]['chain_length'] / spawner_args[spawner_keyword]['num_links'], - joint_offset_x = 0, - joint_offset_y = 0, - joint_offset_z = -0.5 * (spawner_args[spawner_keyword]['chain_length'] / spawner_args[spawner_keyword]['num_links'])) - }} - - - {%- endfor -%} - - - {%- endif -%} -{%- endmacro -%} - - -{# safety_led_macro {--> #} -{%- macro safety_led_macro(parent_link, failure_duration_threshold, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-safety-led' -%} - {%- set spawner_description = 'Add a safety LED' -%} - {%- set spawner_default_args = none -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - - - safety_led - {{ failure_duration_threshold }} - 5.0 - {{ x }} - {{ y }} - {{ z }}} - {{ roll }} - {{ pitch }} - {{ yaw }} - - - - {{ parent_link }} - safety_led_link - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# TODO: Timepix is not core #} -{# Timepix detector {--> #} -{%- macro timepix_macro(parent_link, sensor_name, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-timepix' -%} - {%- set spawner_description = 'Add a Timepix radiation detector to the vehicle' -%} - {%- set spawner_default_args = {'material': 'si', 'exposition_time': 0.1, 'thickness': 0.0003} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_colored_box_macro(sensor_name, 0.02, 0.09, 0.02, 'Green', 0, 0.05, 0, 0, 0, 0) }} - - - - {{ spawner_args[spawner_keyword]['exposition_time'] }} - {{ spawner_args[spawner_keyword]['material'] }} - {{ spawner_args[spawner_keyword]['thickness'] }} 0.01408 0.01408 - - - - {{ parent_link }} - {{ sensor_name }}_link - - - - {%- endif -%} - -{%- endmacro -%} - - -{# TODO: Timepix3 is not core #} -{# Timepix3 detector {--> #} -{%- macro timepix3_macro(parent_link, sensor_name, sensor_suffix, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-timepix3' -%} - {%- set spawner_description = 'Add a Timepix3 gamma event camera to the vehicle' -%} - {%- set spawner_default_args = {'material': 'cdte', 'max_message_window': 1.0, 'thickness': 0.002} %} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_colored_box_macro(sensor_name, 0.02, 0.09, 0.02, 'Green', 0.05, 0, 0, 0, 0, 0) }} - - - - {{ material }} - {{ spawner_args[spawner_keyword]['thickness'] }} 0.01408 0.01408 - {{ spawner_args[spawner_keyword]['max_message_window'] }} - {{ sensor_suffix }} - - -<<<<<<< HEAD - - {{ parent_link }} - {{ sensor_name }}_link - - - - {%- endif -%} - -{%- endmacro -%} - - -{# TODO: UWB plugin is not core #} -{# uwb_range_macro {--> #} -{%- macro uwb_range_macro(parent_link, x, y, z, roll, pitch, yaw, mount, spawner_args) -%} - - {%- set spawner_keyword = 'enable-uwb-range' -%} - {%- set spawner_description = 'Add Qorvo DW1000 UWB transceiver. Requires param "signal_id" to be set.' -%} - {%- set spawner_default_args = {'signal_id': none, 'update_rate': 10} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- if spawner_args[spawner_keyword]['signal_id'] is not none -%} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - {{ spawner_args[spawner_keyword]['update_rate'] }} - 1 - - {{ spawner_args[spawner_keyword]['signal_id'] }} - /{{ spawner_args['name'] }}/uwb_range/range - {{ spawner_args['name'] }}/uwb - -150 - 0.1 - - - 6489.6 - 6240.0 - 6739.2 - 14.5 - 2.5 - - - - - {{ parent_link }} - uwb_range_link - true - true - - - - {{ mount }} - -======= - - {{ tilt_update_rate }} - {{ max_pitch_rate }} - {{ max_pitch }} - {{ min_pitch }} - {{ max_roll_rate }} - {{ max_roll }} - {{ min_roll }} - servo_camera_pitch_joint - servo_camera_roll_joint - servo_camera_gimbal_link - {{ parent }} - {{ compensate_tilt_roll }} - {{ compensate_tilt_pitch }} - - - - {{ parent }} - servo_camera_gimbal_link - {{ offset_roll_link_x }} {{ offset_roll_link_y }} {{ offset_roll_link_z }} {{ offset_roll_link_roll }} {{ offset_roll_link_pitch }} {{ offset_roll_link_yaw }} - - 1 0 0 - - -0.5 - 0.5 - 1 - 10 - - - 0.0 - 0.0 - - - ->>>>>>> master - - - - {%- endif -%} - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# water_gun_macro {--> #} -{%- macro water_gun_macro(parent_link, nozzle_offset_x, nozzle_offset_y, nozzle_offset_z, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-water-gun' -%} - {%- set spawner_description = 'Add a water gun for firefighting. Requires a dummy object (spawning_reservoir) to be present in the simulation' -%} - {%- set spawner_default_args = {'muzzle_velocity': 15.0, 'num_particles': 30, 'spread': 1.0, 'spawning_reservoir': 'the_void'} -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_colored_box_macro('water_bag', 0.02, 0.08, 0.03, 'Blue', 0, 0, 0, 0, 0, 0) }} - - {{ nozzle_offset_x - 0.08/2 }} {{ nozzle_offset_y }} {{ nozzle_offset_z - 0.006/2 }} 0 {{ math.radians(90) }} 0 - - - 0.08 - 0.006 - - - - - - - - - - {{ spawner_args[spawner_keyword]['muzzle_velocity'] }} - {{ nozzle_offset_x }} - {{ nozzle_offset_y }} - {{ nozzle_offset_z }} - {{ spawner_args[spawner_keyword]['spread'] }} - {{ spawner_args[spawner_keyword]['num_particles'] }} - {{ spawner_args[spawner_keyword]['spawning_reservoir'] }} - - - - {{ parent_link }} - water_gun_link - - - - {%- endif -%} -{%- endmacro -%} -{# #} - -{# whycon_box_macro {--> #} -{%- macro whycon_box_macro(parent_link, x, y, z, roll, pitch, yaw, spawner_args) -%} - - {%- set spawner_keyword = 'enable-whycon-box' -%} - {%- set spawner_description = 'Add a Whycon box for relative localization using visual markers' -%} - {%- set spawner_default_args = none -%} - - {%- if spawner_keyword in spawner_args.keys() -%} - {{ generic.handle_spawner_args(spawner_keyword, spawner_default_args, spawner_args) }} - - {%- set mesh_file = 'model://mrs_robots_description/meshes/sensors/whycon_box.dae' -%} - {%- set mesh_scale = '1 1 1' -%} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - {{ generic.visual_mesh_textured_macro("whycon_box", mesh_file, mesh_scale, x, y, z, roll, pitch, yaw) }} - - - - {{ parent_link }} - whycon_box_link - - - - {%- endif -%} - -{%- endmacro -%} - - -{# ==================== Unsupported components ==================== #} - -{# TODO: not supported in the current version #} -{# TODO: not used #} -{# gps_satelites_blocking_macro {--> #} -{%- macro gps_satelites_blocking_macro(parent_link) -%} - - 0 0 0 0 {{ -math.radians(90) }} 0 - {{ generic.zero_inertial_macro() }} - - false - 2 - - - - 4 - 1 - -1.1 - 1.1 - - - 4 - 1 - -0.9 - 0.9 - - - - 0.5 - 50 - 0.5 - - - - gps_sat_blocking - gps_blocking - - - - - - {{ parent_link }} - gps_blocking_link - -{%- endmacro -%} - - -{# TODO: not supported in the current version #} -{# TODO: not used #} -{# parachute_macro {--> #} -{%- macro parachute_macro(parent_link, x, y, z, roll, pitch, yaw) -%} - - - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - {{ generic.zero_inertial_macro() }} - - 0 0 0 0 0 0 - - - 0.1 - 0.048 - - - - - - - - - - 1.225 - 500 - 0.25 - 0 - 0 - -1.56 - - - - {{ parent_link }} - parachute_link - - - -{%- endmacro -%} -{# #} - - diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f330.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f330.sdf.jinja index cc32c6c..3af9b1b 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f330.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f330.sdf.jinja @@ -90,7 +90,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f450.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f450.sdf.jinja index e723599..8586b0e 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f450.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f450.sdf.jinja @@ -94,7 +94,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f550.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f550.sdf.jinja index a71510d..decc36d 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f550.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/f550.sdf.jinja @@ -93,7 +93,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/generic_components.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/generic_components.sdf.jinja index 458e465..0b4c2e7 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/generic_components.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/generic_components.sdf.jinja @@ -327,21 +327,6 @@ limitations under the License. {%- endmacro -%} {# #} -{# visual_mesh_textured_with_collision_macro {--> #} -{%- macro visual_mesh_textured_with_collision_macro(name, mesh_file, mesh_scale, x, y, z, roll, pitch, yaw) -%} - {{ visual_mesh_textured_macro(name, mesh_file, mesh_scale, x, y, z, roll, pitch, yaw) }} - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - - - {{ mesh_file }} - {{ mesh_scale }} - - - -{%- endmacro -%} -{# #} - {# visual_colored_box_macro {--> #} {%- macro visual_colored_box_macro(name, size_x, size_y, size_z, color, x, y, z, roll, pitch, yaw) -%} @@ -436,8 +421,8 @@ limitations under the License. {# ========================= drone propellers ======================== #} {# motor_plugins_macro {--> #} -{%- macro motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash) -%} - +{%- macro motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash, motor_plugin_filename) -%} + prop_{{ motor_number }}_joint prop_{{ motor_number }}_link @@ -464,7 +449,7 @@ limitations under the License. {# #} {# prop_macro {--> #} -{%- macro prop_macro(direction, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, motor_number, rotor_drag_coefficient, rolling_moment_coefficient, enable_motor_crash, color, mesh_file, mesh_scale, x, y, z, roll, pitch, yaw, ixx, ixy, ixz, iyy, iyz, izz) -%} +{%- macro prop_macro(direction, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, motor_number, rotor_drag_coefficient, rolling_moment_coefficient, enable_motor_crash, color, mesh_file, mesh_scale, motor_plugin_filename, x, y, z, roll, pitch, yaw, ixx, ixy, ixz, iyy, iyz, izz) -%} {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} @@ -491,7 +476,7 @@ limitations under the License. yaw = 0) }} - {{ motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash) }} + {{ motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash, motor_plugin_filename) }} {{ parent }} prop_{{ motor_number }}_link @@ -512,7 +497,7 @@ limitations under the License. {# #} {# prop_macro_2_meshes {--> #} -{%- macro prop_macro_2_meshes(direction, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, motor_number, rotor_drag_coefficient, rolling_moment_coefficient, enable_motor_crash, color, mesh_file_1, mesh_file_2, meshes_z_offset, mesh_scale, x, y, z, roll, pitch, yaw, ixx, ixy, ixz, iyy, iyz, izz) -%} +{%- macro prop_macro_2_meshes(direction, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, motor_number, rotor_drag_coefficient, rolling_moment_coefficient, enable_motor_crash, color, mesh_file_1, mesh_file_2, meshes_z_offset, mesh_scale, motor_plugin_filename, x, y, z, roll, pitch, yaw, ixx, ixy, ixz, iyy, iyz, izz) -%} {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} @@ -540,7 +525,7 @@ limitations under the License. yaw = 0) }} - {{ motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash) }} + {{ motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash, motor_plugin_filename) }} {{ parent }} prop_{{ motor_number }}_link @@ -560,114 +545,6 @@ limitations under the License. {%- endmacro -%} -{# TODO: UNUSED #} -{# mrs_motor_plugins_macro {--> #} -{%- macro motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash) -%} - - - prop_{{ motor_number }}_joint - prop_{{ motor_number }}_link - {{ direction }} - {{ time_constant_up }} - {{ time_constant_down }} - {{ max_rot_velocity }} - {{ motor_constant }} - {{ moment_constant }} - /gazebo/command/motor_speed - {{ motor_number }} - {{ rotor_drag_coefficient }} - {{ rolling_moment_coefficient }} - /motor_speed/{{ motor_number }} - {{ rotor_velocity_slowdown_sim }} - {{ enable_motor_crash }} - - - - - /motor_speed/{{ motor_number }} - -{%- endmacro -%} -{# #} - -{# TODO: UNUSED #} -{# prop_macro_2_meshes_mrs_motor_model {--> #} -{%- macro prop_macro_2_meshes_mrs_motor_model(direction, rotor_velocity_slowdown_sim, motor_constant, moment_constant, parent, mass, radius, time_constant_up, time_constant_down, max_rot_velocity, motor_number, rotor_drag_coefficient, rolling_moment_coefficient, enable_motor_crash, color, mesh_file_1, mesh_file_2, meshes_z_offset, mesh_scale, x, y, z, roll, pitch, yaw, ixx, ixy, ixz, iyy, iyz, izz) -%} - - {{ x }} {{ y }} {{ z }} {{ roll }} {{ pitch }} {{ yaw }} - - {{ mass }} - - {{ ixx }} - {{ ixy }} - {{ ixz }} - {{ iyy }} - {{ iyz }} - {{ izz }} - - - - - - {{ mesh_file_1 }} - {{ mesh_scale }} - - - - - {{ 0 }} {{ 0 }} {{ meshes_z_offset }} {{ 0 }} {{ 0 }} {{ 0 }} - - - {{ mesh_file_2 }} - {{ mesh_scale }} - - - - - - - - 0 0 0 0 {{ math.radians(90) }} 0 - - - {{ 2*radius }} - 0.01 - - - - - - - - - - - - - -{{ mrs_motor_plugins_macro(motor_number, direction, time_constant_up, time_constant_down, max_rot_velocity, motor_constant, moment_constant, rotor_drag_coefficient, rolling_moment_coefficient, rotor_velocity_slowdown_sim, enable_motor_crash) }} - - - {{ parent }} - prop_{{ motor_number }}_link - - 0 0 1 - - -1e+16 - 1e+16 - - - 0 - 0 - - 1 - - -{%- endmacro -%} -{# #} - {# =========================== base sensors ========================== #} {# odometry_sensor_macro {--> #} @@ -1112,7 +989,6 @@ limitations under the License. {%- endmacro -%} {# #} -{# TODO: UNUSED #} {# gazebo_fluid_resistance_plugin_macro {--> #} {%- macro gazebo_fluid_resistance_plugin_macro(verbose, model_mass, parent_link, update_rate, uav_body_resistance_x, uav_body_resistance_y, uav_body_resistance_z) -%} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/m690.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/m690.sdf.jinja index 069dfa9..934d0e9 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/m690.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/m690.sdf.jinja @@ -82,7 +82,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/naki.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/naki.sdf.jinja index f91b6d9..095372a 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/naki.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/naki.sdf.jinja @@ -85,7 +85,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} @@ -140,7 +140,7 @@ - {{ generic.visual_mesh_textured_with_collision_macro( + {{ generic.visual_mesh_textured_macro( name = 'legs', mesh_file = legs_mesh_file, mesh_scale = mesh_scale, @@ -151,6 +151,28 @@ pitch = 0, yaw = 0) }} + {{ generic.collision_cylinder_macro( + name = 'left_leg', + collision_length = 0.17, + collision_radius = 0.07, + x = 0, + y = -0.2, + z = -0.17, + roll = 0, + pitch = 0, + yaw = 0) + }} + {{ generic.collision_cylinder_macro( + name = 'right_leg', + collision_length = 0.17, + collision_radius = 0.07, + x = 0, + y = 0.2, + z = -0.17, + roll = 0, + pitch = 0, + yaw = 0) + }} diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/t650.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/t650.sdf.jinja index 0bdb1fa..64468b1 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/t650.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/t650.sdf.jinja @@ -87,7 +87,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} @@ -633,7 +633,7 @@ parent_link = root, x = 0.0, y = -0.221, - z = -0.035, + z = -0.0249, roll = 0, pitch = math.radians(90), yaw = math.radians(90), diff --git a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/x500.sdf.jinja b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/x500.sdf.jinja index d48ff62..6756dd4 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/x500.sdf.jinja +++ b/ros_packages/mrs_uav_gazebo_simulation/models/mrs_robots_description/sdf/x500.sdf.jinja @@ -103,7 +103,7 @@ {%- set prop_izz = 0.0001 -%} {# #} - + {# ================================================================== #} {# || bare body definitions || #} diff --git a/ros_packages/mrs_uav_gazebo_simulation/test/CMakeLists.txt b/ros_packages/mrs_uav_gazebo_simulation/test/CMakeLists.txt index 5084ddf..51372ef 100644 --- a/ros_packages/mrs_uav_gazebo_simulation/test/CMakeLists.txt +++ b/ros_packages/mrs_uav_gazebo_simulation/test/CMakeLists.txt @@ -1,3 +1,5 @@ find_package(rostest REQUIRED) add_subdirectory(takeoff) + +add_subdirectory(uav_models) diff --git a/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/CMakeLists.txt b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/CMakeLists.txt new file mode 100644 index 0000000..d3144cd --- /dev/null +++ b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/CMakeLists.txt @@ -0,0 +1,33 @@ +get_filename_component(TEST_NAME "${CMAKE_CURRENT_SOURCE_DIR}" NAME) + +set(MODELS + x500 + f330 + f450 + f550 + t650 + m690 + naki + ) + +catkin_add_executable_with_gtest(test_${TEST_NAME} + test.cpp + ) + +target_link_libraries(test_${TEST_NAME} + ${catkin_LIBRARIES} + ) + +add_dependencies(test_${TEST_NAME} + ${${PROJECT_NAME}_EXPORTED_TARGETS} + ${catkin_EXPORTED_TARGETS} + ) + +foreach(MODEL ${MODELS}) + + add_rostest(${TEST_NAME}.test + ARGS + UAV_TYPE:=${MODEL} + ) + +endforeach() diff --git a/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/config/custom_config.yaml b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/config/custom_config.yaml new file mode 100644 index 0000000..4b0275a --- /dev/null +++ b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/config/custom_config.yaml @@ -0,0 +1,16 @@ +# GET ALL PARAMETERS USABLE FOR CUSTOM CONFIG BY RUNNING: +## -------------------------------------------------------------- +## | rosrun mrs_uav_core get_public_params.py # +## -------------------------------------------------------------- + +mrs_uav_managers: + + estimation_manager: + + # loaded state estimator plugins + state_estimators: [ + "gps_garmin", + ] + + initial_state_estimator: "gps_garmin" # will be used as the first state estimator + agl_height_estimator: "garmin_agl" # only slightly filtered height for checking min height (not used in control feedback) diff --git a/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/test.cpp b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/test.cpp new file mode 100644 index 0000000..6eb2ab8 --- /dev/null +++ b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/test.cpp @@ -0,0 +1,62 @@ +#include + +#include + +class Tester : public mrs_uav_testing::TestGeneric { + +public: + bool test(); +}; + +bool Tester::test() { + + { + auto [success, message] = spawnGazeboUav(); + + if (!success) { + ROS_ERROR("[%s]: gazebo UAV spawning failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + { + auto [success, message] = takeoff(); + + if (!success) { + ROS_ERROR("[%s]: takeoff failed with message: '%s'", ros::this_node::getName().c_str(), message.c_str()); + return false; + } + } + + this->sleep(5.0); + + if (this->isFlyingNormally()) { + return true; + } else { + ROS_ERROR("[%s]: not flying normally", ros::this_node::getName().c_str()); + return false; + } +} + + +TEST(TESTSuite, test) { + + Tester tester; + + bool result = tester.test(); + + if (result) { + GTEST_SUCCEED(); + } else { + GTEST_FAIL(); + } +} + +int main([[maybe_unused]] int argc, [[maybe_unused]] char** argv) { + + ros::init(argc, argv, "test"); + + testing::InitGoogleTest(&argc, argv); + + return RUN_ALL_TESTS(); +} diff --git a/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/uav_models.test b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/uav_models.test new file mode 100644 index 0000000..ba16e3a --- /dev/null +++ b/ros_packages/mrs_uav_gazebo_simulation/test/uav_models/uav_models.test @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +