30#include <VirtualRobot/VirtualRobot.h>
32#include <RobotAPI/interface/core/CartesianWaypointControllerConfig.h>
52 const Eigen::VectorXf& currentJointVelocity,
53 float maxPositionAcceleration,
54 float maxOrientationAcceleration,
55 float maxNullspaceAcceleration,
56 const VirtualRobot::RobotNodePtr& tcp =
nullptr,
57 const VirtualRobot::RobotNodePtr& referenceFrame =
nullptr);
60 [[deprecated(
"compued null space velocity does not match pseudo inverse svd method in "
61 "simox. never use this function.")]]
void
69 void setTarget(
const Eigen::Matrix4f& target);
72 const Eigen::Vector3f& feedForwardVelocityOri);
95 void setConfig(
const CartesianWaypointControllerConfig& cfg);
118 Eigen::VectorXf _out;
119 Eigen::VectorXf _jnv;
float getPositionError() const
size_t currentWaypointIndex
bool autoClearFeedForward
const Eigen::VectorXf & calculate(float dt)
void setNullSpaceControl(bool enabled)
void swapWaypoints(std::vector< Eigen::Matrix4f > &waypoints)
Eigen::Vector6f cartesianVelocity
void setWaypoints(const std::vector< Eigen::Matrix4f > &waypoints)
bool isLastWaypoint() const
std::vector< Eigen::Matrix4f > waypoints
const Eigen::Matrix4f & getCurrentTarget() const
float thresholdPositionNear
size_t skipToClosestWaypoint(float rad2mmFactor)
void setCurrentJointVelocity(const Eigen::Ref< const Eigen::VectorXf > ¤tJointVelocity)
CartesianWaypointController(const VirtualRobot::RobotNodeSetPtr &rns, const Eigen::VectorXf ¤tJointVelocity, float maxPositionAcceleration, float maxOrientationAcceleration, float maxNullspaceAcceleration, const VirtualRobot::RobotNodePtr &tcp=nullptr, const VirtualRobot::RobotNodePtr &referenceFrame=nullptr)
float thresholdPositionReached
Eigen::Vector6f feedForwardVelocity
void clearFeedForwardVelocity()
CartesianPositionController ctrlCartesianPos2Vel
CartesianVelocityControllerWithRamp ctrlCartesianVelWithRamps
void setTarget(const Eigen::Matrix4f &target)
const Eigen::Vector3f getCurrentTargetPosition() const
bool isCurrentTargetNear() const
float getOrientationError() const
bool isFinalTargetNear() const
bool isCurrentTargetReached() const
float KpJointLimitAvoidance
std::string getStatusText()
void setConfig(const CartesianWaypointControllerConfig &cfg)
void setFeedForwardVelocity(const Eigen::Vector6f &feedForwardVelocity)
bool nullSpaceControlEnabled
float jointLimitAvoidanceScale
void addWaypoint(const Eigen::Matrix4f &waypoint)
bool isFinalTargetReached() const
float thresholdOrientationReached
float thresholdOrientationNear
Matrix< float, 6, 1 > Vector6f
This file offers overloads of toIce() and fromIce() functions for STL container types.
std::shared_ptr< CartesianWaypointController > CartesianWaypointControllerPtr