4#include <ruckig/ruckig.hpp>
14 using std::runtime_error::runtime_error;
37template <
typename TargetType>
59template <
typename ControlSignalType,
typename Waypo
intType,
typename TargetType>
62 std::is_base_of_v<Waypoint<TargetType>,
WaypointType>,
"WaypointType must inherit from Waypoint<TargetType>");
71 : waypoints_(std::move(
waypoints)), return_when_finished_(return_when_finished), prev_result_() {}
75 target_reached_time_ = std::nullopt;
76 waypoint_started_time_ = franka::Duration(0);
80 waypoint_iterator_ = waypoints_.begin();
81 if (waypoint_iterator_ != waypoints_.end()) {
82 checkWaypointPrivate(*waypoint_iterator_);
85 prev_result_ = ruckig::Result::Working;
87 prev_result_ = ruckig::Result::Finished;
100 output_parameter_.pass_to_input(input_parameter_);
103 if (waypoint_iterator_ != waypoints_.end() && waypoint_iterator_->max_total_duration.has_value()) {
107 if (!target_reached_time_.has_value()) {
110 auto hold_target_duration = waypoint_iterator_->hold_target_duration;
111 if (waypoint_iterator_ + 1 == waypoints_.end()) {
113 hold_target_duration = std::max(hold_target_duration, franka::Duration(5));
116 target_reached_time_ = std::nullopt;
117 if (waypoint_iterator_ != waypoints_.end()) {
118 ++waypoint_iterator_;
121 if (waypoint_iterator_ == waypoints_.end()) {
123 if (!return_when_finished_)
return command;
124 return franka::MotionFinished(
command);
126 checkWaypointPrivate(*waypoint_iterator_);
132 if (waypoint_iterator_ != waypoints_.end()) {
133 auto blend = waypoint_iterator_->state_estimate_weight;
137 auto pos_t =
toEigen(input_parameter_.current_position);
138 auto vel_t =
toEigen(input_parameter_.current_velocity);
139 auto acc_t =
toEigen(input_parameter_.current_acceleration);
150 prev_result_ = trajectory_generator_.update(input_parameter_, output_parameter_);
151 if (prev_result_ == ruckig::Result::Working || prev_result_ == ruckig::Result::Finished) {
152 output_parameter_.pass_to_input(input_parameter_);
187 std::vector<WaypointType> waypoints_;
188 bool return_when_finished_{
true};
191 ruckig::Result prev_result_;
192 ruckig::InputParameter<7> input_parameter_;
193 ruckig::OutputParameter<7> output_parameter_;
195 typename std::vector<WaypointType>::iterator waypoint_iterator_;
197 std::optional<franka::Duration> target_reached_time_;
198 franka::Duration waypoint_started_time_;
201 if (
waypoint.state_estimate_weight < 0 ||
waypoint.state_estimate_weight > 1)
202 throw std::runtime_error(
203 "state_estimate_weight must be between 0 and 1. Got " + std::to_string(
waypoint.state_estimate_weight));
Base class for motions.
Definition motion.hpp:23
Relative dynamics factors.
Definition relative_dynamics_factor.hpp:13
static constexpr double control_rate
Definition robot.hpp:98
A motion following multiple waypoints in a time-optimal way. Works with arbitrary initial conditions.
Definition waypoint_motion.hpp:60
virtual std::tuple< Vector7d, Vector7d, Vector7d > getStateEstimate(const RobotState &robot_state) const =0
virtual void initWaypointMotion(const RobotState &robot_state, const std::optional< ControlSignalType > &previous_command, ruckig::InputParameter< 7 > &input_parameter)=0
virtual void setInputLimits(const WaypointType &waypoint, ruckig::InputParameter< 7 > &input_parameter) const =0
WaypointMotion(std::vector< WaypointType > waypoints, bool return_when_finished=true)
Definition waypoint_motion.hpp:70
virtual void checkWaypoint(const WaypointType &waypoint) const
Definition waypoint_motion.hpp:173
virtual ControlSignalType getControlSignal(const RobotState &robot_state, const franka::Duration &time_step, const std::optional< ControlSignalType > &previous_command, const ruckig::InputParameter< 7 > &input_parameter)=0
virtual void setNewWaypoint(const RobotState &robot_state, const std::optional< ControlSignalType > &previous_command, const WaypointType &new_waypoint, ruckig::InputParameter< 7 > &input_parameter)=0
void initImpl(const RobotState &robot_state, const std::optional< ControlSignalType > &previous_command) override
Definition waypoint_motion.hpp:74
ControlSignalType nextCommandImpl(const RobotState &robot_state, franka::Duration time_step, franka::Duration rel_time, franka::Duration abs_time, const std::optional< ControlSignalType > &previous_command) override
Definition waypoint_motion.hpp:91
virtual std::tuple< Vector7d, Vector7d, Vector7d > getAbsoluteInputLimits() const =0
virtual void extrapolateMotion(const franka::Duration &time_step, const ruckig::InputParameter< 7 > &input_parameter, ruckig::OutputParameter< 7 > &output_parameter) const =0
Definition dynamics_limit.cpp:8
std::array< double, dims > toStdD(const Eigen::Matrix< double, dims, 1 > &vector)
Definition util.hpp:18
Eigen::Matrix< T, dims, 1 > toEigen(const std::array< T, dims > &vector)
Definition util.hpp:23
ControlSignalType
Type of control signal.
Definition control_signal_type.hpp:8
Exception thrown if the motion planner fails.
Definition waypoint_motion.hpp:13
Full state of the robot.
Definition robot_state.hpp:20
A waypoint with a target and optional parameters.
Definition waypoint_motion.hpp:38
std::optional< franka::Duration > max_total_duration
Definition waypoint_motion.hpp:47
franka::Duration hold_target_duration
Definition waypoint_motion.hpp:45
double state_estimate_weight
Definition waypoint_motion.hpp:49
TargetType target
Definition waypoint_motion.hpp:39
RelativeDynamicsFactor relative_dynamics_factor
Definition waypoint_motion.hpp:41
std::optional< franka::Duration > minimum_time
Definition waypoint_motion.hpp:43