ARCS SDK API  0.25.0
载入中...
搜索中...
未找到
force_control.h
浏览该文件的文档.
1/** @file force_control.h
2 * @brief 力控接口
3 *
4 * 力控的限制
5 * When the robot is force controlled, the following functionality is not
6 * accessible:
7 *
8 * • Collision Detection (option 613-1) \n
9 * • SoftMove (option 885-1) \n
10 * • Tracking functionality like Conveyor Tracking (option 606-1), Optical
11 * Tracking (6601) and Weld Guide (815-2) \n
12 * • Sensor Synchronization or Analog Synchronization \n
13 * • World Zones (option 608-1) \n
14 * • Independent Axes (option 610-1) \n
15 * • Path Offset (option 612-1) \n
16 * • Arc options \n
17 * • PickMaster options \n
18 * • Joint soft servo (instruction SoftAct) \n
19 * • Force Control cannot be activated when the robot is running in MultiMove
20 * Coordinated mode (option 604-1). \n
21 * • If Force Control is used together with SafeMove (option 810-2) or
22 * Electronic Position Switches (option 810-1), the function Operational
23 * Safety Range must be used. See the respective manual for these options. \n
24 * • RAPID instructions such as FCAct, FCDeact, FCConditionWaitWhile and
25 * FCRefStop can only be called from normal level in a motion task.
26 *
27 * 应用:抛光、打磨、清洁 \n
28 * FC Pressure \n
29 * 设置轨迹坐标系的z方向为力控轴,spring设置为0 \n
30 * 在还没接触前设置输出力为0,spring设置为固定值(根据vel确定) \n
31 * 离开接触面:设置输出力为0,spring设置为固定值 \n
32 *
33 * 活塞(Piston)装配 \n
34 * Forward clutch hub \n
35 * 设置力控终止模式
36 *
37 * 基于末端力传感器的拖动示教 \n
38 * spring = 0; force_ref = 0; 参考轨迹点任意
39 */
40#ifndef AUBO_SDK_FORCE_CONTROL_INTERFACE_H
41#define AUBO_SDK_FORCE_CONTROL_INTERFACE_H
42
43#include <vector>
44#include <thread>
45
46#include <aubo/global_config.h>
47#include <aubo/type_def.h>
48
49namespace arcs {
50namespace common_interface {
51
52/**
53 * 力控接口抽象类
54 */
55class ARCS_ABI_EXPORT ForceControl
56{
57public:
59 virtual ~ForceControl();
60
61 /**
62 * Start force control
63 *
64 * fcEnable is used to enable Force Control. At the same time as Force
65 * Control is enabled, fcEnable is used to define the coordinate system
66 * for Force Control, and tune the force and torque damping. If a coordinate
67 * system is not specified in fcEnable a default force control coordinate
68 * system is created with the same orientation as the work object coordinate
69 * system. All Force Control supervisions are activated by fcEnable.
70 *
71 * 使能力控。
72 * fcEnable 被用于使能力控。 在力控被使能的同时,
73 * fcEnable 用于定义力控的坐标系,并调整力和力矩的阻尼。
74 * 如果在 fcEnable 中未指定坐标系,
75 * 则会创建一个默认的力控制坐标系,其方向与工作对象坐标系相同。
76 * 所有力控制监管功能都被 fcEnable 激活。
77 *
78 * @return 成功返回0;失败返回错误码
79 * AUBO_BUSY
80 * AUBO_BAD_STATE
81 * -AUBO_BAD_STATE
82 *
83 * @throws arcs::common_interface::AuboException
84 *
85 * @par Python函数原型
86 * fcEnable(self: pyaubo_sdk.ForceControl) -> int
87 *
88 * @par Lua函数原型
89 * fcEnable() -> nil
90 *
91 * @par JSON-RPC请求示例
92 * {"jsonrpc":"2.0","method":"rob1.ForceControl.fcEnable","params":[],"id":1}
93 *
94 * @par JSON-RPC响应示例
95 * {"id":1,"jsonrpc":"2.0","result":0}
96 *
97 */
98 int fcEnable();
99
100 /**
101 * End force control
102 *
103 * fcDisable is used to disable Force Control. After a successful
104 * deactivation the robot is back in position control.
105 *
106 * 失能力控。
107 * fcDisable 被用于失能力控。 在成功失能力控之后,机器人将回到位置控制模式。
108 *
109 * @return 成功返回0;失败返回错误码
110 * AUBO_BUSY
111 * AUBO_BAD_STATE
112 * -AUBO_BAD_STATE
113 *
114 * @throws arcs::common_interface::AuboException
115 *
116 * @par Python函数原型
117 * fcDisable(self: pyaubo_sdk.ForceControl) -> int
118 *
119 * @par Lua函数原型
120 * fcDisable() -> nil
121 *
122 * @par JSON-RPC请求示例
123 * {"jsonrpc":"2.0","method":"rob1.ForceControl.fcDisable","params":[],"id":1}
124 *
125 * @par JSON-RPC响应示例
126 * {"id":1,"jsonrpc":"2.0","result":0}
127 *
128 */
130
131 /**
132 * 判断力控是否被使能
133 *
134 * @return 使能返回true,失能返回false
135 *
136 * @throws arcs::common_interface::AuboException
137 *
138 * @par Python函数原型
139 * isFcEnabled(self: pyaubo_sdk.ForceControl) -> bool
140 *
141 * @par Lua函数原型
142 * isFcEnabled() -> boolean
143 *
144 * @par JSON-RPC请求示例
145 * {"jsonrpc":"2.0","method":"rob1.ForceControl.isFcEnabled","params":[],"id":1}
146 *
147 * @par JSON-RPC响应示例
148 * {"id":1,"jsonrpc":"2.0","result":false}
149 *
150 */
152
153 /**
154 * 设置力控参考(目标)值
155 *
156 * @param feature: 参考几何特征,用于生成力控参考坐标系
157 * @param compliance: 柔性轴(方向)选择
158 * @param wrench: 目标力/力矩
159 * @param limits: 速度限制
160 * @param type: 力控参考坐标系类型
161 *
162 * @return 成功返回0;失败返回错误码
163 * AUBO_BUSY
164 * AUBO_BAD_STATE
165 * -AUBO_INVL_ARGUMENT
166 * -AUBO_BAD_STATE
167 *
168 * @throws arcs::common_interface::AuboException
169 *
170 * @par Python函数原型
171 * setTargetForce(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
172 * List[bool], arg2: List[float], arg3: List[float], arg4:
173 * arcs::common_interface::TaskFrameType) -> int
174 *
175 * @par Lua函数原型
176 * setTargetForce(feature: table, compliance: table, wrench: table, limits:
177 * table, type: number) -> nil
178 *
179 */
180 int setTargetForce(const std::vector<double> &feature,
181 const std::vector<bool> &compliance,
182 const std::vector<double> &wrench,
183 const std::vector<double> &limits,
184 TaskFrameType type = TaskFrameType::FRAME_FORCE);
185
186 /**
187 * 设置力控动力学模型
188 *
189 * @param env_stiff: 环境刚度,表示为接触轴方向上的工件刚度,取值范围[0,
190 * 1],默认为0
191 * @param damp_scale: 表征阻尼水平的参数,取值范围[0, 1],默认为0.5
192 * @param stiff_scale: 表征软硬程度的参数,取值范围[0, 1],默认为0.5
193 *
194 * @return 成功返回0;失败返回错误码
195 * AUBO_BUSY
196 * AUBO_BAD_STATE
197 * -AUBO_INVL_ARGUMENT
198 * -AUBO_BAD_STATE
199 *
200 * @throws arcs::common_interface::AuboException
201 *
202 * @par Python函数原型
203 * setDynamicModel1(self: pyaubo_sdk.ForceControl, arg0: List[float],
204 * arg1: List[float], arg2: List[float]) -> int
205 *
206 * @par Lua函数原型
207 * setDynamicModel1(env_stiff: table, damp_scale: table, stiff_scale:
208 * table) -> nil
209 *
210 */
211 int setDynamicModel1(const std::vector<double> &env_stiff,
212 const std::vector<double> &damp_scale,
213 const std::vector<double> &stiff_scale);
214
215 /**
216 * 计算力控动力学模型
217 *
218 * @param env_stiff: 环境刚度,表示为接触轴方向上的工件刚度,取值范围[0,
219 * 1],默认为0
220 * @param damp_scale: 表征阻尼水平的参数,取值范围[0, 1],默认为0.5
221 * @param stiff_scale: 表征软硬程度的参数,取值范围[0, 1],默认为0.5
222 *
223 * @return 力控动力学模型MDK
224 * AUBO_BUSY
225 * AUBO_BAD_STATE
226 * -AUBO_INVL_ARGUMENT
227 * -AUBO_BAD_STATE
228 *
229 * @throws arcs::common_interface::AuboException
230 *
231 * @par Python函数原型
232 * fcCalDynamicModel(self: pyaubo_sdk.ForceControl, arg0: List[float],
233 * arg1: List[float], arg2: List[float]) -> > Tuple[List[float],
234 * List[float], List[float]]
235 *
236 * @par Lua函数原型
237 * fcCalDynamicModel(env_stiff: table, damp_scale: table, stiff_scale:
238 * table) -> table
239 *
240 */
241 DynamicsModel fcCalDynamicModel(const std::vector<double> &env_stiff,
242 const std::vector<double> &damp_scale,
243 const std::vector<double> &stiff_scale);
244
245 /**
246 * 设置力控搜孔场景下的动力学模型
247 *
248 * @param damp_scale: 表征阻尼水平的参数,取值范围[0, 1],默认为0.5
249 * @param stiff_scale: 表征软硬程度的参数,取值范围[0, 1],默认为0.5
250 *
251 * @return 成功返回0;失败返回错误码
252 * AUBO_BUSY
253 * AUBO_BAD_STATE
254 * -AUBO_INVL_ARGUMENT
255 * -AUBO_BAD_STATE
256 *
257 * @throws arcs::common_interface::AuboException
258 *
259 * @par Python函数原型
260 * setDynamicModelSearch(self: pyaubo_sdk.ForceControl, arg0: List[float],
261 * arg1: List[float]) -> int
262 *
263 * @par Lua函数原型
264 * setDynamicModelSearch(damp_scale: table, stiff_scale: table) -> nil
265 *
266 */
267 int setDynamicModelSearch(const std::vector<double> &damp_scale,
268 const std::vector<double> &stiff_scale);
269
270 /**
271 * 设置力控插/拔孔场景下的动力学模型
272 *
273 * @param damp_scale: 表征阻尼水平的参数,取值范围[0, 1],默认为0.5
274 * @param stiff_scale: 表征软硬程度的参数,取值范围[0, 1],默认为0.5
275 *
276 * @return 成功返回0;失败返回错误码
277 * AUBO_BUSY
278 * AUBO_BAD_STATE
279 * -AUBO_INVL_ARGUMENT
280 * -AUBO_BAD_STATE
281 *
282 * @throws arcs::common_interface::AuboException
283 *
284 * @par Python函数原型
285 * setDynamicModelInsert(self: pyaubo_sdk.ForceControl, arg0: List[float],
286 * arg1: List[float]) -> int
287 *
288 * @par Lua函数原型
289 * setDynamicModelInsert(damp_scale: table, stiff_scale: table) -> nil
290 *
291 */
292 int setDynamicModelInsert(const std::vector<double> &damp_scale,
293 const std::vector<double> &stiff_scale);
294
295 /**
296 * 设置力控动力学模型
297 *
298 * @param m
299 * @param d
300 * @param k
301 *
302 * @return 成功返回0;失败返回错误码
303 * AUBO_BUSY
304 * AUBO_BAD_STATE
305 * -AUBO_INVL_ARGUMENT
306 * -AUBO_BAD_STATE
307 *
308 * @throws arcs::common_interface::AuboException
309 *
310 * @par Python函数原型
311 * setDynamicModel(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
312 * List[float], arg2: List[float]) -> int
313 *
314 * @par Lua函数原型
315 * setDynamicModel(m: table, d: table, k: table) -> nil
316 *
317 */
318 int setDynamicModel(const std::vector<double> &m,
319 const std::vector<double> &d,
320 const std::vector<double> &k);
321
322 /**
323 * 设置力控阈值
324 *
325 * @param thresholds: 力控阈值
326 *
327 * @return 成功返回0;失败返回错误码
328 * AUBO_BUSY
329 * AUBO_BAD_STATE
330 * -AUBO_INVL_ARGUMENT
331 * -AUBO_BAD_STATE
332 *
333 * @throws arcs::common_interface::AuboException
334 *
335 * @par Python函数原型
336 * fcSetSensorThresholds(self: pyaubo_sdk.ForceControl, arg0:
337 * List[float]) -> int
338 *
339 * @par Lua函数原型
340 * fcSetSensorThresholds(feature: table, compliance: table, wrench:
341 * table, limits: table, type: number) -> nil
342 *
343 */
344 int fcSetSensorThresholds(const std::vector<double> &thresholds);
345
346 /**
347 * 设置力控最大受力限制
348 *
349 * @param limits: 力限制
350 *
351 * @return 成功返回0;失败返回错误码
352 * AUBO_BUSY
353 * AUBO_BAD_STATE
354 * -AUBO_INVL_ARGUMENT
355 * -AUBO_BAD_STATE
356 *
357 * @throws arcs::common_interface::AuboException
358 *
359 * @par Python函数原型
360 * fcSetSensorLimits(self: pyaubo_sdk.ForceControl, arg0:
361 * List[float]) -> int
362 *
363 * @par Lua函数原型
364 * fcSetSensorLimits(feature: table, compliance: table, wrench:
365 * table, limits: table, type: number) -> nil
366 *
367 */
368 int fcSetSensorLimits(const std::vector<double> &limits);
369
370 /**
371 * 获取力控阈值
372 *
373 * @return 力控最小力阈值
374 *
375 * @throws arcs::common_interface::AuboException
376 *
377 * @par Python函数原型
378 * getFcSensorThresholds(self: pyaubo_sdk.ForceControl) -> list
379 *
380 * @par Lua函数原型
381 * getFcSensorThresholds() -> table
382 *
383 */
384 std::vector<double> getFcSensorThresholds();
385
386 /**
387 * 获取最大力限制
388 *
389 * @return 力控最大力限制
390 *
391 * @throws arcs::common_interface::AuboException
392 *
393 * @par Python函数原型
394 * getFcSensorLimits(self: pyaubo_sdk.ForceControl) -> list
395 *
396 * @par Lua函数原型
397 * getFcSensorLimits() -> table
398 *
399 */
400 std::vector<double> getFcSensorLimits();
401
402 /**
403 * 获取力控动力学模型
404 *
405 * @return 力控动力学模型
406 *
407 * @throws arcs::common_interface::AuboException
408 *
409 * @par Python函数原型
410 * getDynamicModel(self: pyaubo_sdk.ForceControl) -> Tuple[List[float],
411 * List[float], List[float]]
412 *
413 * @par Lua函数原型
414 * getDynamicModel() -> table
415 *
416 * @par JSON-RPC请求示例
417 * {"jsonrpc":"2.0","method":"rob1.ForceControl.getDynamicModel","params":[],"id":1}
418 *
419 * @par JSON-RPC响应示例
420 * {"id":1,"jsonrpc":"2.0","result":[[],[20.0,20.0,20.0,5.0,5.0,5.0],[]]}
421 *
422 */
424
425 /**
426 * 设置力控终止条件:力,当测量的力在设置的范围之内,力控算法将保持运行,直到设置的条件不满足,力控将退出
427 *
428 * FCCondForce is used to set up an end condition based on measured force.
429 * The condition is lateractivated by calling the instruction
430 * FCCondWaitWhile, which will wait and hold the program execution while the
431 * specified condition is true. This allows the reference force, torque and
432 * movement to continue until the force is outside the specified limits.
433 *
434 * A force condition is set up by defining minimum and maximum limits for
435 * the force in the directions of the force control coordinate system. Once
436 * activated with FCCondWaitWhile, the program execution will continue to
437 * wait while the measured force is within its specified limits.
438 *
439 * It is possible to specify that the condition is fulfilled when the force
440 * is outside the specified limits instead. This is done by using the switch
441 * argument Outside. The condition on force is specified in the force
442 * control coordinate system. This coordinate system is setup by the user in
443 * the instruction FCAct.
444 *
445 * @param min 各方向最小的力/力矩
446 * @param max 各方向最大的力/力矩
447 * @param outside false 在设置条件的范围之内有效
448 * true 在设置条件的范围之外有效
449 * @param timeout
450 * 时间限制,单位s(秒),从开始力控到达该时间时,不管是否满足力控终止条件,都会终止力控
451 *
452 * @return 成功返回0;失败返回错误码
453 * AUBO_BUSY
454 * AUBO_BAD_STATE
455 * -AUBO_INVL_ARGUMENT
456 * -AUBO_BAD_STATE
457 *
458 * @throws arcs::common_interface::AuboException
459 *
460 * @par Python函数原型
461 * setCondForce(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
462 * List[float], arg2: bool, arg3: float) -> int
463 *
464 * @par Lua函数原型
465 * setCondForce(min: table, max: table, outside: boolean, timeout: number)
466 * -> nil
467 *
468 */
469 int setCondForce(const std::vector<double> &min,
470 const std::vector<double> &max, bool outside,
471 double timeout);
472
473 /**
474 * FCCondOrient is used to set up an end condition for the tool orientation.
475 * The condition is lateractivated by calling the instruction
476 * FCCondWaitWhile, which will wait and hold the program execution while the
477 * specified condition is true. This allows the reference force, torque and
478 * movement to continue until the orientation is outside the specified
479 * limits.
480 *
481 * An orientation condition is set up by defining a maximum angle and a
482 * maximum rotation from a reference orientation. The reference orientation
483 * is either defined by the current z direction of the tool, or by
484 * specifying an orientation in relation to the z direction of the work
485 * object.
486 *
487 * Once activated, the tool orientation must be within the limits (or
488 * outside, if the argument Outside is used).
489 *
490 * @param frame
491 * @param max_angle
492 * @param max_rot
493 * @param outside
494 * @param timeout
495 *
496 * @return 成功返回0;失败返回错误码
497 * AUBO_BUSY
498 * AUBO_BAD_STATE
499 * -AUBO_INVL_ARGUMENT
500 * -AUBO_BAD_STATE
501 *
502 * @throws arcs::common_interface::AuboException
503 *
504 * @par Python函数原型
505 * setCondOrient(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
506 * float, arg2: float, arg3: bool, arg4: float) -> int
507 *
508 * @par Lua函数原型
509 * setCondOrient(frame: table, max_angle: number, max_rot: number, outside:
510 * boolean, timeout: number) -> nil
511 *
512 */
513 int setCondOrient(const std::vector<double> &frame, double max_angle,
514 double max_rot, bool outside, double timeout);
515
516 /**
517 * 指定力控有效平面,x-y平面,z方向有效
518 *
519 * FCCondPos is used to set up an end condition for the TCP position. The
520 * condition is later activated by calling the instruction FCCondWaitWhile,
521 * which will wait and hold the program execution while the specified
522 * condition is true. This allows the reference force, torque and movement
523 * to continue until the specified position is outside the specified limits.
524 *
525 * A position condition is set up by defining a volume in space for the TCP
526 * position. Once activated the measured TCP position has to be within the
527 * specified volume (or outside, if the argument Outside is used).
528 *
529 * @param plane={A,B,C,D}
530 * 平面表示方法 Ax +By +Cz + D = 0
531 * 其中,n = (A, B, C)是平面的法向量,
532 * D 是将平面平移到坐标原点所需距离(所以D=0时,平面过原点)
533 * @param timeout
534 *
535 * @return 成功返回0;失败返回错误码
536 * AUBO_BUSY
537 * AUBO_BAD_STATE
538 * -AUBO_INVL_ARGUMENT
539 * -AUBO_BAD_STATE
540 *
541 * @throws arcs::common_interface::AuboException
542 *
543 * @par Python函数原型
544 * setCondPlane(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
545 * float) -> int
546 *
547 * @par Lua函数原型
548 * setCondPlane(plane: table, timeout: number) -> nil
549 *
550 */
551 int setCondPlane(const std::vector<double> &plane, double timeout);
552
553 /**
554 * 指定力控有效圆柱体,提供中心轴和圆柱半径,可以指定圆柱内部还是外部
555 *
556 * @param axis
557 * @param radius
558 * @param outside
559 * @param timeout
560 *
561 * @return 成功返回0;失败返回错误码
562 * AUBO_BUSY
563 * AUBO_BAD_STATE
564 * -AUBO_INVL_ARGUMENT
565 * -AUBO_BAD_STATE
566 *
567 * @throws arcs::common_interface::AuboException
568 *
569 * @par Python函数原型
570 * setCondCylinder(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
571 * float, arg2: bool, arg3: float) -> int
572 *
573 * @par Lua函数原型
574 * setCondCylinder(axis: table, radius: number, outside: boolean, timeout:
575 * number) -> nil
576 *
577 */
578 int setCondCylinder(const std::vector<double> &axis, double radius,
579 bool outside, double timeout);
580
581 /**
582 * 指定力控有效球体,提供球心和半径,可以指定球体内部还是外部
583 *
584 * @param center
585 * @param radius
586 * @param outside
587 * @param timeout
588 *
589 * @return 成功返回0;失败返回错误码
590 * AUBO_BUSY
591 * AUBO_BAD_STATE
592 * -AUBO_INVL_ARGUMENT
593 * -AUBO_BAD_STATE
594 *
595 * @throws arcs::common_interface::AuboException
596 *
597 * @par Python函数原型
598 * setCondSphere(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
599 * float, arg2: bool, arg3: float) -> int
600 *
601 * @par Lua函数原型
602 * setCondSphere(center: table, radius: number, outside: boolean, timeout:
603 * number) -> nil
604 *
605 */
606 int setCondSphere(const std::vector<double> &center, double radius,
607 bool outside, double timeout);
608
609 /**
610 * FCCondTCPSpeed is used to setup an end condition for the TCP speed. The
611 * condition is lateractivated by calling the instruction FCCondWaitWhile,
612 * which will wait and hold the program execution while the specified
613 * condition is true. This allows the reference force, torque and movement
614 * to continue until the speed is outside the specified limits.
615 *
616 * A TCP speed condition is setup up by defining minimum and maximum limits
617 * for the TCP speed in all directions of the work object. Once activated
618 * with FCCondWaitWhile, the program execution will continue to wait while
619 * the measured speed is within its specified limits.
620 *
621 * It is possible to specify that the condition is fulfilled when the speed
622 * is outside the specified limits instead. This is the done by using the
623 * switch argument Outside. The condition on TCP speed is specified in the
624 * work object coordinate system.
625 *
626 * @param min
627 * @param max
628 * @param outside
629 * @param timeout
630 *
631 * @return 成功返回0;失败返回错误码
632 * AUBO_BUSY
633 * AUBO_BAD_STATE
634 * -AUBO_INVL_ARGUMENT
635 * -AUBO_BAD_STATE
636 *
637 * @throws arcs::common_interface::AuboException
638 *
639 * @par Python函数原型
640 * setCondTcpSpeed(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
641 * List[float], arg2: bool, arg3: float) -> int
642 *
643 * @par Lua函数原型
644 * setCondTcpSpeed(min: table, max: table, outside: boolean, timeout:
645 * number) -> nil
646 *
647 */
648 int setCondTcpSpeed(const std::vector<double> &min,
649 const std::vector<double> &max, bool outside,
650 double timeout);
651
652 /**
653 * 力控终止条件-距离
654 *
655 * @param distance
656 * @param timeout
657 *
658 * @return 成功返回0;失败返回错误码
659 * AUBO_BUSY
660 * AUBO_BAD_STATE
661 * -AUBO_INVL_ARGUMENT
662 * -AUBO_BAD_STATE
663 *
664 * @throws arcs::common_interface::AuboException
665 *
666 */
667 int setCondDistance(double distance, double timeout);
668
669 /**
670 * 高级力控终止条件
671 *
672 * @param type
673 * @param args
674 * @param timeout
675 *
676 * @return 成功返回0;失败返回错误码
677 * AUBO_BUSY
678 * AUBO_BAD_STATE
679 * -AUBO_INVL_ARGUMENT
680 * -AUBO_BAD_STATE
681 *
682 * @throws arcs::common_interface::AuboException
683 *
684 */
685 int setCondAdvanced(const std::string &type,
686 const std::vector<double> &args, double timeout);
687
688 /**
689 * 激活力控终止条件
690 *
691 * @return 成功返回0;失败返回错误码
692 * AUBO_BUSY
693 * AUBO_BAD_STATE
694 * -AUBO_BAD_STATE
695 *
696 * @throws arcs::common_interface::AuboException
697 *
698 * @par Python函数原型
699 * setCondActive(self: pyaubo_sdk.ForceControl) -> int
700 *
701 * @par Lua函数原型
702 * setCondActive() -> nil
703 *
704 * @par JSON-RPC请求示例
705 * {"jsonrpc":"2.0","method":"rob1.ForceControl.setCondActive","params":[],"id":1}
706 *
707 * @par JSON-RPC响应示例
708 * {"id":1,"jsonrpc":"2.0","result":0}
709 *
710 */
712
713 /**
714 * 力控终止条件是否已经满足
715 *
716 * @return
717 *
718 * @throws arcs::common_interface::AuboException
719 *
720 * @par Python函数原型
721 * isCondFullfiled(self: pyaubo_sdk.ForceControl) -> bool
722 *
723 * @par Lua函数原型
724 * isCondFullfiled() -> boolean
725 *
726 * @par JSON-RPC请求示例
727 * {"jsonrpc":"2.0","method":"rob1.ForceControl.isCondFullfiled","params":[],"id":1}
728 *
729 * @par JSON-RPC响应示例
730 * {"id":1,"jsonrpc":"2.0","result":false}
731 *
732 */
734
735 /**
736 * FCSupvForce is used to set up force supervision in Force Control. The
737 * supervision is activated when Force Control is activated with the
738 * instruction FCAct.
739 *
740 * The force supervision is set up by defining minimum and maximum limits
741 * for the force in the directions of the force control coordinate system.
742 * Once activated, the supervision will stop the execution if the force is
743 * outside the allowed values. The force supervision is specified in the
744 * force control coordinate system. This coordinate system is setup by the
745 * user with the instruction FCAct.
746 *
747 * @param min
748 * @param max
749 *
750 * @return 成功返回0;失败返回错误码
751 * AUBO_BUSY
752 * AUBO_BAD_STATE
753 * -AUBO_INVL_ARGUMENT
754 * -AUBO_BAD_STATE
755 *
756 * @throws arcs::common_interface::AuboException
757 *
758 * @par Python函数原型
759 * setSupvForce(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
760 * List[float]) -> int
761 *
762 * @par Lua函数原型
763 * setSupvForce(min: table, max: table) -> nil
764 *
765 */
766 int setSupvForce(const std::vector<double> &min,
767 const std::vector<double> &max);
768
769 /**
770 * FCSupvOrient is used to set up an supervision for the tool orientation.
771 * The supervision is activated when Force Control is activated with the
772 * instruction FCAct.
773 *
774 * An orientation supervision is set up by defining a maximum angle and a
775 * maximum rotation from a reference orientation. The reference orientation
776 * is either defined by the current z direction of the tool, or by
777 * specifying an orientation in relation to the z direction of the work
778 * object.
779 *
780 * Once activated, the tool orientation must be within the limits otherwise
781 * the supervision will stop the execution.
782 *
783 * @param frame
784 * @param max_angle
785 * @param max_rot
786 * @param outside
787 *
788 * @return 成功返回0;失败返回错误码
789 * AUBO_BUSY
790 * AUBO_BAD_STATE
791 * -AUBO_INVL_ARGUMENT
792 * -AUBO_BAD_STATE
793 *
794 * @throws arcs::common_interface::AuboException
795 *
796 * @par Python函数原型
797 * setSupvOrient(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
798 * float, arg2: float, arg3: bool) -> int
799 *
800 * @par Lua函数原型
801 * setSupvOrient(frame: table, max_angle: number, max_rot: number,
802 * outside: boolean) -> nil
803 *
804 */
805 int setSupvOrient(const std::vector<double> &frame, double max_angle,
806 double max_rot, bool outside);
807
808 /**
809 * FCSupvPos is used to set up position supervision in Force Control.
810 * Supervision is activated when Force Control is activated with the
811 * instruction FCAct. Position supervision is set up by defining a volume in
812 * space for the TCP. Once activated, the supervision will stop the
813 * execution if the TCP is outside this volume.
814 *
815 * @param frame
816 * @param box
817 *
818 * @return 成功返回0;失败返回错误码
819 * AUBO_BUSY
820 * AUBO_BAD_STATE
821 * -AUBO_INVL_ARGUMENT
822 * -AUBO_BAD_STATE
823 *
824 * @throws arcs::common_interface::AuboException
825 *
826 * @par Python函数原型
827 * setSupvPosBox(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
828 * List[float[6]]) -> int
829 *
830 * @par Lua函数原型
831 * setSupvPosBox(frame: table, box: table) -> nil
832 *
833 */
834 int setSupvPosBox(const std::vector<double> &frame, const Box &box);
835
836 /**
837 *
838 * @param frame
839 * @param cylinder
840 *
841 * @return 成功返回0;失败返回错误码
842 * AUBO_BUSY
843 * AUBO_BAD_STATE
844 * -AUBO_INVL_ARGUMENT
845 * -AUBO_BAD_STATE
846 *
847 * @throws arcs::common_interface::AuboException
848 *
849 * @par Python函数原型
850 * setSupvPosCylinder(self: pyaubo_sdk.ForceControl, arg0: List[float],
851 * arg1: List[float[5]]) -> int
852 *
853 * @par Lua函数原型
854 * setSupvPosCylinder(frame: table, cylinder: table) -> nil
855 *
856 */
857 int setSupvPosCylinder(const std::vector<double> &frame,
858 const Cylinder &cylinder);
859
860 /**
861 *
862 * @param frame
863 * @param sphere
864 *
865 * @return 成功返回0;失败返回错误码
866 * AUBO_BUSY
867 * AUBO_BAD_STATE
868 * -AUBO_INVL_ARGUMENT
869 * -AUBO_BAD_STATE
870 *
871 * @throws arcs::common_interface::AuboException
872 *
873 * @par Python函数原型
874 * setSupvPosSphere(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
875 * List[float[3]]) -> int
876 *
877 * @par Lua函数原型
878 * setSupvPosSphere(frame: table, sphere: table) -> nil
879 *
880 */
881 int setSupvPosSphere(const std::vector<double> &frame,
882 const Sphere &sphere);
883
884 /**
885 * FCSupvReoriSpeed is used to set up reorientation speed supervision in
886 * Force Control. The supervision is activated when Force Control is
887 * activated with the instruction FCAct.
888 *
889 * The reorientation speed supervision is set up by defining minimum and
890 * maximum limits for the reorientation speed around the axis of the work
891 * object coordinate system. Once activated, the supervision will stop the
892 * execution if the values of the reorientation speed are to high.
893 *
894 * There are two speed supervisions: FCSupvReoriSpeed and FCSupvTCPSpeed,
895 * which is described in section FCSupvTCPSpeed on page 199.
896 * Both supervisions may be required because:
897 * - A robot axis can rotate with high speed while the TCP is stationary.
898 * - The TCP can be far from the rotating axisand asmallaxis rotation may
899 * result in a high speed movement of the TCP
900 *
901 * @param speed_limit
902 * @param outside
903 * @param timeout
904 *
905 * @return 成功返回0;失败返回错误码
906 * AUBO_BUSY
907 * AUBO_BAD_STATE
908 * -AUBO_INVL_ARGUMENT
909 * -AUBO_BAD_STATE
910 *
911 * @throws arcs::common_interface::AuboException
912 *
913 * @par Python函数原型
914 * setSupvReoriSpeed(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
915 * bool, arg2: float) -> int
916 *
917 * @par Lua函数原型
918 * setSupvReoriSpeed(speed_limit: table, outside: boolean, timeout: number)
919 * -> nil
920 *
921 */
922 int setSupvReoriSpeed(const std::vector<double> &speed_limit, bool outside,
923 double timeout);
924
925 /**
926 * FCSupvTCPSpeed is used to set up TCP speed supervision in Force Control.
927 * The supervision is activated when Force Control is activated with the
928 * instruction FCAct. The TCP speed supervision is set up by defining
929 * minimum and maximum limits for the TCP speed in the directions of the
930 * work object coordinate system. Once activated, the supervision will stop
931 * the execution if too high TCP speed values are detected.
932 *
933 * There are two speed supervisions: FCSupvTCPSpeed and FCSupvReorispeed,
934 * which is described in section FCSupvReoriSpeed on page 197.
935 *
936 * Both supervisions may be required because:
937 * - A robot axis can rotate with high speed while the TCP is stationary.
938 * - The TCP can be far from the rotating axisand asmallaxis rotation may
939 * result in a high speed movement of the TCP.
940 *
941 * @param speed_limit
942 * @param outside
943 * @param timeout
944 *
945 * @return 成功返回0;失败返回错误码
946 * AUBO_BUSY
947 * AUBO_BAD_STATE
948 * -AUBO_INVL_ARGUMENT
949 * -AUBO_BAD_STATE
950 *
951 * @throws arcs::common_interface::AuboException
952 *
953 * @par Python函数原型
954 * setSupvTcpSpeed(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1:
955 * bool, arg2: float) -> int
956 *
957 * @par Lua函数原型
958 * setSupvTcpSpeed(speed_limit: table, outside: boolean, timeout: number) ->
959 * nil
960 *
961 */
962 int setSupvTcpSpeed(const std::vector<double> &speed_limit, bool outside,
963 double timeout);
964
965 // 设置低通滤波器
966 // --- force frame filter: 过滤测量到的力/力矩
967 // +++ force loop filter: 力控输出参考速度的滤波器
968
969 /**
970 * 设置低通滤波器
971 *
972 * --- force frame filter: 过滤测量到的力/力矩
973 * +++ force loop filter: 力控输出参考速度的滤波器
974 *
975 * FCSetLPFilterTune is used change the response of force loop according to
976 * description in Damping and LP-filter on page 103.
977 *
978 * @param cutoff_freq
979 *
980 * @return 成功返回0;失败返回错误码
981 * AUBO_BUSY
982 * AUBO_BAD_STATE
983 * -AUBO_INVL_ARGUMENT
984 * -AUBO_BAD_STATE
985 *
986 * @throws arcs::common_interface::AuboException
987 *
988 * @par Python函数原型
989 * setLpFilter(self: pyaubo_sdk.ForceControl, arg0: List[float]) -> int
990 *
991 * @par Lua函数原型
992 * setLpFilter(cutoff_freq: table) -> nil
993 *
994 */
995 int setLpFilter(const std::vector<double> &cutoff_freq);
996
997 /**
998 * 重置低通滤波器
999 *
1000 * @return 成功返回0;失败返回错误码
1001 * AUBO_BUSY
1002 * AUBO_BAD_STATE
1003 * -AUBO_BAD_STATE
1004 *
1005 * @throws arcs::common_interface::AuboException
1006 *
1007 * @par Python函数原型
1008 * resetLpFilter(self: pyaubo_sdk.ForceControl) -> int
1009 *
1010 * @par Lua函数原型
1011 * resetLpFilter() -> nil
1012 *
1013 * @par JSON-RPC请求示例
1014 * {"jsonrpc":"2.0","method":"rob1.ForceControl.resetLpFilter","params":[],"id":1}
1015 *
1016 * @par JSON-RPC响应示例
1017 * {"id":1,"jsonrpc":"2.0","result":0}
1018 *
1019 */
1021
1022 /**
1023 * The FCSpdChgAct is used to activate FC SpeedChange function with desired
1024 * reference and recover behavior. When FC SpeedChange function is active,
1025 * the robot speed will be reduced/increased in order to keep the measured
1026 * signal close to the reference.
1027 *
1028 * @param ref_force
1029 *
1030 * @return 成功返回0;失败返回错误码
1031 * AUBO_BUSY
1032 * AUBO_BAD_STATE
1033 * -AUBO_INVL_ARGUMENT
1034 * -AUBO_BAD_STATE
1035 *
1036 * @throws arcs::common_interface::AuboException
1037 *
1038 * @par Python函数原型
1039 * speedChangeEnable(self: pyaubo_sdk.ForceControl, arg0: float) -> int
1040 *
1041 * @par Lua函数原型
1042 * speedChangeEnable(ref_force: number) -> nil
1043 *
1044 */
1045 int speedChangeEnable(double ref_force);
1046
1047 /**
1048 * Deactivate FC SpeedChange function.
1049 *
1050 * @return 成功返回0;失败返回错误码
1051 * AUBO_BUSY
1052 * AUBO_BAD_STATE
1053 * -AUBO_BAD_STATE
1054 *
1055 * @throws arcs::common_interface::AuboException
1056 *
1057 * @par Python函数原型
1058 * speedChangeDisable(self: pyaubo_sdk.ForceControl) -> int
1059 *
1060 * @par Lua函数原型
1061 * speedChangeDisable() -> nil
1062 *
1063 * @par JSON-RPC请求示例
1064 * {"jsonrpc":"2.0","method":"rob1.ForceControl.speedChangeDisable","params":[],"id":1}
1065 *
1066 * @par JSON-RPC响应示例
1067 * {"id":1,"jsonrpc":"2.0","result":0}
1068 *
1069 */
1071
1072 /**
1073 * FCSpdChgTunSet is used to set FC SpeedChange system parameters to a new
1074 * value.
1075 *
1076 * @param speed_levels
1077 * @param speed_ratio_min
1078 *
1079 * @return 成功返回0;失败返回错误码
1080 * AUBO_BUSY
1081 * AUBO_BAD_STATE
1082 * -AUBO_INVL_ARGUMENT
1083 * -AUBO_BAD_STATE
1084 *
1085 * @throws arcs::common_interface::AuboException
1086 *
1087 * @par Python函数原型
1088 * speedChangeTune(self: pyaubo_sdk.ForceControl, arg0: int, arg1: float) ->
1089 * int
1090 *
1091 * @par Lua函数原型
1092 * speedChangeTune(speed_levels: number, speed_ratio_min: number) -> nil
1093 *
1094 */
1095 int speedChangeTune(int speed_levels, double speed_ratio_min);
1096
1097 /* Defines how many Newtons are required to make the robot move 1 m/s. The
1098 higher the value, the less responsive the robot gets.
1099 The damping can be tuned (as a percentage of the system parameter values)
1100 by the RAPID instruction FCAct. */
1101 // 设置阻尼系数,阻尼的系统参数需要通过配置文件设置
1102 // [damping_fx, damping_fy, damping_fz, damping_tx, damping_ty, damping_tz]
1103 // A value between min and 10,000,000 Ns/m.
1104 // A value between minimum and 10,000,000 Nms/rad.
1105
1106 /**
1107 * FCSetDampingTune is used to tune the damping in the force control
1108 * coordinate systems. The parameters tuned are those described in Damping
1109 * in Torque x Direction - Damping in Torque z Direction on page 255 and
1110 * Damping in Force x Direction - Damping in Force z Direction on page 254.
1111 *
1112 * Damping can be set in the configuration file or by the instruction FCAct.
1113 * The difference is that this instruction can be used when force control is
1114 * active. FCSetDampingTune tunes the actual values set by the instruction
1115 * FCAct, not the value in the configuration file.
1116 *
1117 * @param damping
1118 * @param ramp_time
1119 *
1120 * @return 成功返回0;失败返回错误码
1121 * AUBO_BUSY
1122 * AUBO_BAD_STATE
1123 * -AUBO_INVL_ARGUMENT
1124 * -AUBO_BAD_STATE
1125 *
1126 * @throws arcs::common_interface::AuboException
1127 *
1128 * @par Python函数原型
1129 * setDamping(self: pyaubo_sdk.ForceControl, arg0: List[float], arg1: float)
1130 * -> int
1131 *
1132 * @par Lua函数原型
1133 * setDamping(damping: table, ramp_time: number) -> nil
1134 *
1135 */
1136 int setDamping(const std::vector<double> &damping, double ramp_time);
1137
1138 /**
1139 *
1140 *
1141 * @return 成功返回0;失败返回错误码
1142 * AUBO_BUSY
1143 * AUBO_BAD_STATE
1144 * -AUBO_BAD_STATE
1145 *
1146 * @throws arcs::common_interface::AuboException
1147 *
1148 * @par Python函数原型
1149 * resetDamping(self: pyaubo_sdk.ForceControl) -> int
1150 *
1151 * @par Lua函数原型
1152 * resetDamping() -> nil
1153 *
1154 * @par JSON-RPC请求示例
1155 * {"jsonrpc":"2.0","method":"rob1.ForceControl.resetDamping","params":[],"id":1}
1156 *
1157 * @par JSON-RPC响应示例
1158 * {"id":1,"jsonrpc":"2.0","result":0}
1159 *
1160 */
1162
1163 /**
1164 *
1165 * @return 成功返回0;失败返回错误码
1166 * AUBO_BUSY
1167 * AUBO_BAD_STATE
1168 * -AUBO_BAD_STATE
1169 *
1170 * @throws arcs::common_interface::AuboException
1171 *
1172 * @par JSON-RPC请求示例
1173 * {"jsonrpc":"2.0","method":"rob1.ForceControl.softFloatEnable","params":[],"id":1}
1174 *
1175 * @par JSON-RPC响应示例
1176 * {"id":1,"jsonrpc":"2.0","result":0}
1177 *
1178 */
1180
1181 /**
1182 *
1183 * @return 成功返回0;失败返回错误码
1184 * AUBO_BUSY
1185 * AUBO_BAD_STATE
1186 * -AUBO_BAD_STATE
1187 *
1188 * @throws arcs::common_interface::AuboException
1189 *
1190 * @par JSON-RPC请求示例
1191 * {"jsonrpc":"2.0","method":"rob1.ForceControl.softFloatDisable","params":[],"id":1}
1192 *
1193 * @par JSON-RPC响应示例
1194 * {"id":1,"jsonrpc":"2.0","result":-1}
1195 *
1196 */
1198
1199 /**
1200 * 返回是否开启了软浮动
1201 *
1202 * @return
1203 *
1204 * @throws arcs::common_interface::AuboException
1205 *
1206 * @par JSON-RPC请求示例
1207 * {"jsonrpc":"2.0","method":"rob1.ForceControl.isSoftFloatEnabled","params":[],"id":1}
1208 *
1209 * @par JSON-RPC响应示例
1210 * {"id":1,"jsonrpc":"2.0","result":false}
1211 *
1212 */
1214
1215 /**
1216 * 设置软浮动参数
1217 *
1218 * @param joint_softfloat
1219 * @param select
1220 * @param stiff_percent
1221 * @param stiff_damp_ratio
1222 * @param force_threshold
1223 * @param force_limit
1224 * @return
1225 */
1226 int setSoftFloatParams(bool joint_space, const std::vector<bool> &select,
1227 const std::vector<double> &stiff_percent,
1228 const std::vector<double> &stiff_damp_ratio,
1229 const std::vector<double> &force_threshold,
1230 const std::vector<double> &force_limit);
1231
1232 /**
1233 * 检测工具和外部物体的接触
1234 *
1235 * @param direction
1236 * 预期的接触方向,如果所有的元素为0,表示检测所有方向的接触
1237 * @return
1238 * 返回从当前点回退到碰撞开始点的周期步数,如果返回值为0,表示没有接触
1239 */
1240 int toolContact(const std::vector<bool> &direction);
1241
1242protected:
1243 void *d_{ nullptr };
1244};
1245using ForceControlPtr = std::shared_ptr<ForceControl>;
1246} // namespace common_interface
1247} // namespace arcs
1248
1249#endif // AUBO_SDK_FORCE_CONTROL_INTERFACE_H
int setSoftFloatParams(bool joint_space, const std::vector< bool > &select, const std::vector< double > &stiff_percent, const std::vector< double > &stiff_damp_ratio, const std::vector< double > &force_threshold, const std::vector< double > &force_limit)
设置软浮动参数
int speedChangeEnable(double ref_force)
The FCSpdChgAct is used to activate FC SpeedChange function with desired reference and recover behavi...
int setDynamicModel1(const std::vector< double > &env_stiff, const std::vector< double > &damp_scale, const std::vector< double > &stiff_scale)
设置力控动力学模型
int setSupvReoriSpeed(const std::vector< double > &speed_limit, bool outside, double timeout)
FCSupvReoriSpeed is used to set up reorientation speed supervision in Force Control.
int setDynamicModelSearch(const std::vector< double > &damp_scale, const std::vector< double > &stiff_scale)
设置力控搜孔场景下的动力学模型
int fcDisable()
End force control
int setCondDistance(double distance, double timeout)
力控终止条件-距离
bool isSoftFloatEnabled()
返回是否开启了软浮动
int setSupvTcpSpeed(const std::vector< double > &speed_limit, bool outside, double timeout)
FCSupvTCPSpeed is used to set up TCP speed supervision in Force Control.
int setCondActive()
激活力控终止条件
bool isCondFullfiled()
力控终止条件是否已经满足
int setDynamicModelInsert(const std::vector< double > &damp_scale, const std::vector< double > &stiff_scale)
设置力控插/拔孔场景下的动力学模型
int setCondCylinder(const std::vector< double > &axis, double radius, bool outside, double timeout)
指定力控有效圆柱体,提供中心轴和圆柱半径,可以指定圆柱内部还是外部
int setDamping(const std::vector< double > &damping, double ramp_time)
FCSetDampingTune is used to tune the damping in the force control coordinate systems.
int resetLpFilter()
重置低通滤波器
int setCondAdvanced(const std::string &type, const std::vector< double > &args, double timeout)
高级力控终止条件
int setLpFilter(const std::vector< double > &cutoff_freq)
设置低通滤波器
int setCondTcpSpeed(const std::vector< double > &min, const std::vector< double > &max, bool outside, double timeout)
FCCondTCPSpeed is used to setup an end condition for the TCP speed.
int setCondForce(const std::vector< double > &min, const std::vector< double > &max, bool outside, double timeout)
设置力控终止条件:力,当测量的力在设置的范围之内,力控算法将保持运行,直到设置的条件不满足,力控将退出
int setCondSphere(const std::vector< double > &center, double radius, bool outside, double timeout)
指定力控有效球体,提供球心和半径,可以指定球体内部还是外部
int setCondPlane(const std::vector< double > &plane, double timeout)
指定力控有效平面,x-y平面,z方向有效
bool isFcEnabled()
判断力控是否被使能
int setSupvPosBox(const std::vector< double > &frame, const Box &box)
FCSupvPos is used to set up position supervision in Force Control.
int setSupvPosSphere(const std::vector< double > &frame, const Sphere &sphere)
int setSupvForce(const std::vector< double > &min, const std::vector< double > &max)
FCSupvForce is used to set up force supervision in Force Control.
std::vector< double > getFcSensorLimits()
获取最大力限制
int speedChangeDisable()
Deactivate FC SpeedChange function.
int fcSetSensorThresholds(const std::vector< double > &thresholds)
设置力控阈值
int setSupvPosCylinder(const std::vector< double > &frame, const Cylinder &cylinder)
int setDynamicModel(const std::vector< double > &m, const std::vector< double > &d, const std::vector< double > &k)
设置力控动力学模型
int fcSetSensorLimits(const std::vector< double > &limits)
设置力控最大受力限制
DynamicsModel getDynamicModel()
获取力控动力学模型
int setTargetForce(const std::vector< double > &feature, const std::vector< bool > &compliance, const std::vector< double > &wrench, const std::vector< double > &limits, TaskFrameType type=TaskFrameType::FRAME_FORCE)
设置力控参考(目标)值
DynamicsModel fcCalDynamicModel(const std::vector< double > &env_stiff, const std::vector< double > &damp_scale, const std::vector< double > &stiff_scale)
计算力控动力学模型
int fcEnable()
Start force control
int setSupvOrient(const std::vector< double > &frame, double max_angle, double max_rot, bool outside)
FCSupvOrient is used to set up an supervision for the tool orientation.
std::vector< double > getFcSensorThresholds()
获取力控阈值
int speedChangeTune(int speed_levels, double speed_ratio_min)
FCSpdChgTunSet is used to set FC SpeedChange system parameters to a new value.
int toolContact(const std::vector< bool > &direction)
检测工具和外部物体的接触
int setCondOrient(const std::vector< double > &frame, double max_angle, double max_rot, bool outside, double timeout)
FCCondOrient is used to set up an end condition for the tool orientation.
std::tuple< std::vector< double >, std::vector< double >, std::vector< double > > DynamicsModel
Definition type_def.h:715
std::vector< double > Box
Definition type_def.h:723
std::vector< double > Sphere
Definition type_def.h:735
std::shared_ptr< ForceControl > ForceControlPtr
std::vector< double > Cylinder
Definition type_def.h:730
数据类型的定义