37 : min_position(std::numeric_limits<double>::quiet_NaN()),
38 max_position(std::numeric_limits<double>::quiet_NaN()),
39 max_velocity(std::numeric_limits<double>::quiet_NaN()),
40 max_acceleration(std::numeric_limits<double>::quiet_NaN()),
41 max_deceleration(std::numeric_limits<double>::quiet_NaN()),
42 max_jerk(std::numeric_limits<double>::quiet_NaN()),
43 max_effort(std::numeric_limits<double>::quiet_NaN()),
44 has_position_limits(
false),
45 has_velocity_limits(
false),
46 has_acceleration_limits(
false),
47 has_deceleration_limits(
false),
48 has_jerk_limits(
false),
49 has_effort_limits(
false),
50 angle_wraparound(
false)
57 double max_acceleration;
58 double max_deceleration;
62 bool has_position_limits;
63 bool has_velocity_limits;
64 bool has_acceleration_limits;
65 bool has_deceleration_limits;
67 bool has_effort_limits;
68 bool angle_wraparound;
70 void disable_all_limits()
72 has_position_limits =
false;
73 has_velocity_limits =
false;
74 has_acceleration_limits =
false;
75 has_deceleration_limits =
false;
76 has_jerk_limits =
false;
77 has_effort_limits =
false;
78 min_position = -std::numeric_limits<double>::max();
79 max_position = std::numeric_limits<double>::max();
80 max_velocity = std::numeric_limits<double>::max();
81 max_acceleration = std::numeric_limits<double>::max();
82 max_deceleration = std::numeric_limits<double>::max();
83 max_jerk = std::numeric_limits<double>::max();
84 max_effort = std::numeric_limits<double>::max();
87 std::string to_string()
const
89 std::stringstream ss_output;
91 ss_output <<
" has position limits: " << (has_position_limits ?
"true" :
"false") <<
" ["
92 << min_position <<
", " << max_position <<
"]\n";
93 ss_output <<
" has velocity limits: " << (has_velocity_limits ?
"true" :
"false") <<
" ["
94 << max_velocity <<
"]\n";
95 ss_output <<
" has acceleration limits: " << (has_acceleration_limits ?
"true" :
"false")
96 <<
" [" << max_acceleration <<
"]\n";
97 ss_output <<
" has deceleration limits: " << (has_deceleration_limits ?
"true" :
"false")
98 <<
" [" << max_deceleration <<
"]\n";
99 ss_output <<
" has jerk limits: " << (has_jerk_limits ?
"true" :
"false") <<
" [" << max_jerk
101 ss_output <<
" has effort limits: " << (has_effort_limits ?
"true" :
"false") <<
" ["
102 << max_effort <<
"]\n";
103 ss_output <<
" angle wraparound: " << (angle_wraparound ?
"true" :
"false");
105 return ss_output.str();
132 : min_position(std::numeric_limits<double>::quiet_NaN()),
133 max_position(std::numeric_limits<double>::quiet_NaN()),
134 k_position(std::numeric_limits<double>::quiet_NaN()),
135 k_velocity(std::numeric_limits<double>::quiet_NaN())
144 std::string to_string()
const
146 std::stringstream ss_output;
148 ss_output <<
" soft position limits: "
149 <<
"[" << min_position <<
", " << max_position <<
"]\n";
151 ss_output <<
" k-position: "
152 <<
"[" << k_position <<
"]\n";
154 ss_output <<
" k-velocity: "
155 <<
"[" << k_velocity <<
"]\n";
157 return ss_output.str();