-
Notifications
You must be signed in to change notification settings - Fork 27
/
mars.orogen
executable file
·569 lines (416 loc) · 21.5 KB
/
mars.orogen
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
name 'mars'
using_library "mars_interfaces", :typekit => false
using_library "mars_gui", :typekit => false
using_library "mars_app", :typekit => false
using_library "mars_sim", :typekit => false
using_library "mars_smurf_loader", :typekit => false
using_library "lib_manager", :typekit => false
using_library "configmaps", :typekit => false
import_types_from "tasks/MarsControl.hpp"
import_types_from "jointTypes.hpp"
import_types_from "poseType.hpp"
import_types_from "objectDetectionTypes.hpp"
import_types_from "wrenchTypes.hpp"
import_types_from "base"
#Disable default deployments, most of the time stand_alone deployments are useless
#since the simulation needs plugins within the same deployment to work
#self.define_default_deployments = false
# Core orogen module that brings up the mars simulation and
# makes it accessible as a orogen module
# use subclassing to derive robot specific modules, e.g.
#
# task_context 'RobotSimulation' do
# subclasses 'mars::Task'
# end
#
# Pay attention that all these tasks have to be started within
# one deployment to be able to share their static resources.
task_context "Task" do
needs_configuration
operation("loadScene").
argument("path","/std/string")
operation("setPosition").
argument("positions", "mars/Positions")
property('add_floor',"/bool",false)
property('gravity',"/base/Vector3d").dynamic
property("show_coordinate_system","bool",false).
dynamic
property("use_now_instead_of_sim_time","/bool",false)
property("reaction_to_physics_error","/std/string","shutdown").
doc("Possible Values: abort (killing sim), reset (ressing scene and simulation), warn (keep simulation running an print warnings), shutdown (stop physics but keep mars-running and set this task to the error state)").
dynamic
property('initial_scene', '/std/string').
doc('the full path to the initial scene, this is needed because operations are not accessible during configuration within syskit (deadlock)')
property('initial_scenes', '/std/vector</std/string>').
doc('the full path to the initial scene, this is needed because operations are not accessible during configuration within syskit (deadlock)')
property('positions', 'std/vector<mars/Positions>' ).
doc('override positions in the scene (scn) file, e.g. move the terrain to create different experiment setups without changing the scene file itself')
property('initial_pose', 'mars/Pose' ).
doc('override initial joint positions in the scene (scn) file, i.e. set an initial pose')
property('config_dir', '/std/string', "#{ENV['AUTOPROJ_CURRENT_ROOT']}/install/configuration/mars_default").
doc('the full path to the main configuration folder')
property('plugin_dir', '/std/string', "#{ENV['AUTOPROJ_CURRENT_ROOT']}/install/lib").
doc('the full path where the plugins can be found')
property('plugins', '/std/vector</std/string>').
doc('additional mars plugins to load. This can be a relative path to the plugin_dir, or absolute.')
property('simulation_property_list', '/std/vector</mars/SimulationProperty>').
doc('list of attributes containing plugin and property name as well as the desired value')
property('distributed_simulation', 'bool').
doc('switch to active the distributed simulation if needed')
property('enable_gui', 'bool').
doc('start the simulation graphical interface with this module')
property('controller_port', 'int').
doc('set the controller port, e.g. 1600 for communication with monster')
property('sim_step_size', 'double',0.01).
dynamic.
doc('The Step-size that each mars-step calculates')
property('raw_options', '/std/vector<mars::Option>').
doc('forward the original mars arguments, such as -c 1600 for setting the ode port - option consists of name, here: -c and parameter: here 1600')
property('realtime_calc', 'bool', false).
doc('if true, simulation runs in real time or slower, but not faster')
property('start_sim', 'bool', false).
doc('starts the simulation after loading the initial scene(s)')
# Add a task context
# operation('addPlugin').
# returns('int').
# argument('taskcontext', '/
# method addPlugin(input: TaskContext ) return bool
# method removePlugin(input: TaskContext) return bool
input_port('control_action', '/mars/Control')
#This operation moves a node to a specific position, simpliar to the positions property but can be used during runtime
operation("move_node").
argument("arg","/mars/Positions")
operation('connect_links').
doc('Defines a fixed joint between the two specified links').
returns("bool").
argument('link1', 'std::string', "Name of link1").
argument('link2', 'std::string', "Name of link2")
operation('disconnect_links').
doc('Resolves a fixed joint between the two specified links').
returns("bool").
argument('link1', 'std::string', "Name of link1").
argument('link2', 'std::string', "Name of link2")
output_port('time', 'double')
output_port('simulated_time', '/base/Time')
port_driven 'control_action'
exception_states :PHYSICS_ERROR
end
task_context "Plugin" do
needs_configuration
abstract
error_states "LOST_MARS_CONNECTION"
end
#Do not use this prugin direct use Camera or DepthCamera instead
task_context "CameraPlugin", subclasses: "Plugin" do
abstract
property('name', '/std/string').
doc('name of the camera in the scene file')
property('robot_name', '/std/string', '').
doc('Name of the robot')
end
task_context "Camera", subclasses: "CameraPlugin" do
needs_configuration
output_port 'frame', ro_ptr('base::samples::frame::Frame')
end
task_context "DepthCamera", subclasses: "CameraPlugin" do
needs_configuration
output_port 'distance_image', ro_ptr('base::samples::DistanceImage')
end
task_context "TOFCamera", subclasses: "CameraPlugin" do
needs_configuration
output_port 'pointcloud', 'base::samples::Pointcloud'
end
task_context "HighResRangeFinder", subclasses: "CameraPlugin" do
needs_configuration
property('left_limit', 'double', -Math::PI/4.0).
doc('Left limit of the vertical opening angle in radians')
property('right_limit', 'double', Math::PI/4.0).
doc('Right limit of the vertical opening angle in radians')
property('resolution_vertical', 'double', Math::PI/180.0).
doc('Vertical angular resolution in radians')
property('upper_limit', 'double', Math::PI/4.0).
doc('Upper limit of the horizontal opening angle in radians')
property('lower_limit', 'double', -Math::PI/4.0).
doc('Lower limit of the horizontal opening angle in radians')
property('resolution_horizontal', 'double', Math::PI/180.0).
doc('Vertical angular resolution in radians')
property('minimum_distance', 'double', 1.0).
doc('Smaller distances (meter) are discarded')
property('maximum_distance', 'double', 80.0).
doc('Larger distances (meter) are discarded')
operation('addCamera').
doc('Adds another camera which will be used for pointcloud creation').
returns("bool").
argument('name', 'std::string', "Name of the camera within the scene file").
argument('orientation', 'double', "To get a full 360 degree view you have to add four 90-cameras with 0, 90, 180 and 270")
output_port('pointcloud', '/base/samples/Pointcloud').
doc 'Created by using the distance image of the DepthCamera'
end
task_context "Joints", subclasses: "Plugin" do
property('names', 'std/vector</std/string>').
doc('Array of names of the motor in the scene file. The names get mapped to motor ids starting from zero')
property('robot_name', '/std/string', '').
doc('Name of the robot')
property('name_remap', 'std/vector</std/string>').
doc('If this array is set the joints will be renamed for the external interface')
property('parallel_kinematics', 'std/vector<mars/ParallelKinematic>').
doc('maps a single joint command to two joints to control parallel kinematics simulated by two joints')
property('scaling', 'std/vector<double>').
doc('Optional array of scale values that are applied to the mars joint values. Needs to be empty or the same size as names.')
property('offset', 'std/vector<double>').
doc('Optional array of offset values that added to the scaled mars joint values. Needs to be empty or the same size as names.')
# optional configuration for the rigid_body_states
# this module will generate on the
property "joint_transform", "base/JointTransformVector"
property("controlMode", "/mars/JointPositionAndSpeedControlMode", :IGNORE).doc('sets the how speed is interpreted in case speed and position is set :MAX_SPEED :IGNORE. unsupported: :SPEED_AT_POS')
output_port( "status_samples", "base/samples/Joints" ).
doc "status values for the joints"
input_port( "command", "base/commands/Joints" ).
doc "command values for the joints"
output_port( "current_values", "mars/JointCurrents")
# if the joint_transform configuration is set, this port
# will output the joints in form of RigidBodyStates
#
# note: you will need a buffered connection if multiple joints
# are served by this module in order to not miss any transforms
output_port "transforms", "base/samples/RigidBodyState"
end
task_context "ForceTorque6DOF", subclasses: "Plugin" do
output_port("wrenches_deprecated", "std/vector< /base/samples/Wrench >")
output_port("wrenches", "/base/samples/Wrenches")
property('names', 'std/vector</std/string>').
doc('Array of names of the ft sensors in the scene file.')
property('name_remap', 'std/vector</std/string>').
doc('If this array is set the sensors will be renamed for the external interface')
end
task_context "ContactForceSensor", subclasses: "Plugin" do
property('wrench_mappings', 'std::vector<mars/WrenchMapping>').
doc('Mapping from raw sensor data to base/samples/Wrenches type')
output_port("wrenches", "/base/samples/Wrenches")
end
# This plugin can be used to "trigger" a simlation cycle,
# it can be useful for operating mars with more-than-realtime
# mode and use the task_scheduler for a fixed execution sequence
task_context "Trigger", subclasses: "Plugin" do
property "do_step","bool",false
doc("This components triggeres the mars simulation cycle if the update-hook is called,
this is useful if an sequence between componentes is needed, like it is possible with the
trigger_component")
end
task_context "LaserRangeFinder", subclasses: "Plugin" do
needs_configuration
property('remission_values', 'bool', 0).
doc 'include remission values in output if set to true and available in the device'
property('start_step', 'int', -1).
doc 'the step at which to start acquisition'
property('end_step', 'int', -1).
doc 'the step at which to end acquisition'
property('scan_skip', 'int', 0).
doc 'how much acquisitions to ignore between two acquisitions to report'
property('merge_count', 'int', 1).
doc 'how much ranges measurement to merge into one single reported measurement'
property('min_range', 'double', 0.0).
doc("Minimum valid range of the laser range finder")
output_port('scans', 'base/samples/LaserScan').
max_sizes('remission' => 2000, 'ranges' => 2000).
doc "the laser scans themselves"
property('name', '/std/string', 'laser_scanner').
doc('name of the sensor in the scene file')
property('robot_name', '/std/string', '').
doc('Name of the robot')
end
# Can be used to simulate laser scanners with more than one vertical scan line
# (e.g. Velodyne).
task_context "RotatingLaserRangeFinder", subclasses: "Plugin" do
needs_configuration
property('name', '/std/string', 'unknown_ray_sensor').
doc('Name of the RotatingRaySensor in the scene file')
property('min_range', 'double', 0.0).
doc("Minimum valid range of the laser range finder")
property('max_range', 'double', 20.0).
doc("Maximum valid range of the laser range finder")
output_port('pointcloud', '/base/samples/Pointcloud').
doc 'Received distances converted to a pointcloud'
end
task_context "IMU", subclasses: "Plugin" do
property("provide_position", "/bool",false).
doc("Set to true is this Sensor should output position readings")
property("provide_orientation", "/bool",true).
doc("Set to true is this Sensor should output orientation readings")
property("provide_velocity", "/bool",true).
doc("Set to true is this Sensor should output angular/translational velocities")
property("imu_frame", "std/string", "imu").
doc "The name of the imu frame."
property("world_frame", "std/string", "world").
doc "The name of the world frame."
property('rotate_node_relative', '/std/vector<double>' ).
doc('if the robot is moved my mars (yaml), rotation of the IMU may be wrong and can be set here (in degrees)')
property("position_sigma", "double", 0.0).
doc "Standard deviation of the position, that will be applied to the measurement."
property("orientation_sigma", "double", 0.0).
doc "Standard deviation of the orientation, that will be applied to the measurement."
property("velocity_sigma", "double", 0.0).
doc "Standard deviation of the velocity, that will be applied to the measurement."
property("angular_velocity_sigma", "double", 0.0).
doc "Standard deviation of the angular velocity, that will be applied to the measurement."
output_port('orientation_samples', '/base/samples/RigidBodyState').
doc 'provides timestamped IMUReading samples containing the orientation estimate as reported by the IMU.'
output_port('calibrated_sensors', '/base/samples/IMUSensors').
doc 'provides timestamped IMUReading samples containing the calibrated sensor readings.'
needs_configuration
property('name', '/std/string', 'imu').
doc('name of the node in the scene file from which to get the imu data')
property('robot_name', '/std/string', '').
doc('Name of the robot')
operation('estimate_bias').
argument('duration', '/uint16_t').
returns('/bool').
doc("Normally triggers bias estimation on the xsens imu, in simulation thios does nothing")
end
task_context "EntityFakeDetection", subclasses: "CameraPlugin" do
property("frame_id", "/uint16_t", 1).
doc("0 for coordinates in world frame. 1 for coordinates in camera frame.")
property("minVisibleVertices", "/uint16_t", 5).
doc("Number of vertices that have to be in the viewing frustum to be counted as seen. Center is counted as vertex.")
property("use_camera", "/bool", false).
doc("Whether the camera should be used.")
output_port('detectionArray', '/mars/Detection3DArray').
doc 'Puts out the entities in a ROS similar detection format.'
needs_configuration
end
task_context "RobotTeleportation", subclasses: "Plugin" do
property("robot_name", "/std/string").
doc("Name of the robot.")
property("scene_path", "/std/string").
doc("Path to smurfs")
property("reset_node_name", "/std/string").
doc("Name of the node that has to be resetted additionally.")
property("position_mode", "/uint16_t", 1).
doc("0 for manual: needs coordinates in world frame. 1 for configured: needs id of preconfigured coordinates.")
input_port('position', '/base/Vector3d').
doc 'Puts the robot to the given position.'
input_port('rotation', '/base/Quaterniond').
doc 'Puts the robot to the given rotation.'
input_port('position_id', '/uint16_t').
doc 'Puts the robot to the given preconfigured position.'
input_port('anchor', '/bool').
doc 'Fixes the robot at the given position.'
input_port('reset_node', '/bool').
doc 'Resets root and the given node (config).'
port_driven
needs_configuration
end
task_context "RepositionTask", subclasses: "Plugin" do
# Repositions the named entities of the given scene in the current mars scene
property("entity_names", "/std/vector<std/string>").
doc("Name of parts to move.")
property("scene_path", "/std/string").
doc("Path to smurf(a/s)")
property("ignore_position", "bool", false).
doc("Whether the position input shall be ignored")
input_port('poses', '/std/vector<base/Pose>').
doc 'Poses relative to the parent link'
port_driven
needs_configuration
end
task_context "ObjectHighlighter", subclasses: "Plugin" do
input_port('obj_id', '/uint16_t').
doc 'Highlights entity with given id'
port_driven
needs_configuration
end
task_context "Sonar", subclasses: "Plugin" do
needs_configuration
property('node_name', 'std/string').
doc 'the name of the vehicle in the scene file'
property("left_limit","double").dynamic.
doc 'maximum left angle'
property("right_limit","double").dynamic.
doc 'maximum right angle'
property("resolution","double").dynamic.
doc 'resolution of the sonar beam'
property("maximum_distance","double").dynamic.
doc 'maximum distance of the sonar beam'
property("ping_pong_mode","bool").dynamic.
doc('if true ping pong mode is activated')
output_port("sonar_beam","base::samples::SonarBeam").
doc('top sonar beam')
end
task_context "Altimeter", subclasses: "Plugin" do
property('node_name', 'std/string')
doc 'the name of the vehicle in the scene file'
needs_configuration
output_port("ground_distance", "/base/samples/RigidBodyState").
doc('current ground distance simulating echo sounder')
end
task_context "ForceTorqueApplier", subclasses: "Plugin" do
needs_configuration
property('entity', 'std/string')
doc 'the name of the robot in the scene file'
property('visualize_wrenches', 'bool', true)
doc 'Positions of the thrusters on the vehicle. The size of the vector must equal to amount_of_actuators'
property('thickness', 'float', 5.0)
doc 'the point size of the marker'
property('force_display_factor', 'float', 0.01)
property('torque_display_factor', 'float', 0.01)
property('norm_length', 'float', 1)
input_port('wrenches', '/base/samples/Wrenches')
doc 'the wrenches to apply at the com at the given nodes'
output_port('input_wrenches', '/base/samples/Wrenches')
doc 'copy of the input_port: the wrench to apply at the com at the given nodes'
port_driven 'wrenches'
end
###Here are comming AUV specific plugins for motion building
task_context "ForceApplier", subclasses: "Plugin" do
needs_configuration
property('node_name', 'std/string')
doc 'the name of the vehicle in the scene file'
property('amount_of_actuators', 'int')
doc 'the amount of actuators the vehicle has'
property('maximum_thruster_force', 'std/vector<double>')
doc 'The maximum thruster foce for each actuator. Is also used as a factor. The size of the vector must equal to amount_of_actuators'
property('thruster_position', 'std/vector</base/Vector3d>')
doc 'Positions of the thrusters on the vehicle. The size of the vector must equal to amount_of_actuators'
property('joint_names','std/vector</string>').
doc 'The names of the joints, array indexes must equal to the positions'
property('thruster_direction', 'std/vector</base/Vector3d>')
doc 'Directions of the thruster force on the vehicle. The size of the vector must equal to amount_of_actuators'
input_port("command", "base/commands/Joints").
doc("actuator command as joint type").
needs_buffered_connection
output_port("status", "base/samples/Joints")
port_driven :command
end
# This plugin models a artificial buoancy for AUVs,
# the auv will stop to "float" at Z-Value 0 (water surface)
task_context "AuvController", subclasses: "Plugin" do
property('node_name', 'std/string')
doc 'the name of the vehicle in the scene file'
needs_configuration
property('position','/base/Vector3d').
dynamic
property('orientation','/base/Quaterniond').
dynamic
property('cob','/base/Vector3d').
doc('Point where the Buoyancy should be applied')
property('buoyancy_force','double')
end
task_context "AuvMotion", subclasses: "ForceApplier" do
doc("This task models the dynamics of underwater vehicles, according to the fossen model.
A full 6d dynamic model without couple-effects is used.
Thruster-dynamics are modeld by a voltage-based model.
For basic functions, all properties need to be set.
For more information about the model, see: Fossen, T.I.: Guidance and control of ocean vehicles")
property("linear_damp", "/base/Vector6d").
doc("Linear damping coefficients, in 6 degrees of freedom")
property("square_damp", "/base/Vector6d").
doc("Square damping coefficients, in 6 degrees of freedom")
property("thruster_coefficients" , "/std/vector<double>").
doc("The square coefficients of the thrusters, the size of the list must be the amount of actuators")
property("voltage", "double", 0).
doc("Maximum volatage of the thrusters, used for pwm to force calculation")
property("cob", "/base/Vector3d").
doc("Center of Bouyancy, with respect to the origin of the vehicle")
property("buoyancy_force", "double", 0).
doc("Buoyancy force applied to the vehicle")
end