25#include <VirtualRobot/VirtualRobot.h>
31#include <armarx/control/common/common.aron.generated.h>
36#include <armarx/control/njoint_controller/task_space/ControllerInterface.h>
40 namespace law = armarx::control::common::control_law;
59 using ConfigPtrT = ConfigurableNJointControllerConfigPtr;
60 using Config = law::TaskspaceMixedImpedanceVelocityController::Config;
61 using ConfigDict = law::TaskspaceMixedImpedanceVelocityController::ConfigDict;
73 std::vector<ControlTarget1DoFActuatorVelocity*>
targetsVel;
83 law::TaskspaceMixedImpedanceVelocityController
controller;
114 const NJointControllerConfigPtr& config,
117 std::string
getClassName(
const Ice::Current& = Ice::emptyCurrent)
const override;
119 void rtRun(
const IceUtil::Time& sensorValuesTimestamp,
120 const IceUtil::Time& timeSinceLastIteration)
override;
123 void updateConfig(const ::armarx::aron::data::dto::DictPtr& dto,
124 const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
127 const Ice::Current& = Ice::emptyCurrent)
override;
129 getConfig(
const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
131 getRTStatus(
const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
133 Ice::FloatSeq
getTCPVel(
const std::string& rns,
134 const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
138 const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
144 const bool forceGuard,
145 const bool torqueGuard,
146 const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
148 const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
150 const ::armarx::aron::data::dto::DictPtr& dto,
151 const Ice::Current& iceCurrent = Ice::emptyCurrent)
override;
157 const std::map<std::string, ConstControlDevicePtr>&,
158 const std::map<std::string, ConstSensorDevicePtr>&);
172 void limbInit(
const std::string nodeSetName,
180 const size_t nDoFTorque,
181 const size_t nDoFVelocity,
182 const Eigen::VectorXf& targetTorque,
183 const Eigen::VectorXf& targetVelocity);
191 const Eigen::Matrix4f& targetPose,
193 const Eigen::Matrix4f& pose,
199 std::map<std::string, ArmPtr>
limb;
208 std::shared_ptr<common::coordination::SyncCoordination>
coordinator =
nullptr;
Provides a ready-to-use ArViz client arviz as member variable.
A simple triple buffer for lockfree comunication between a single writer and a single reader.
std::string getClassName(const Ice::Current &=Ice::emptyCurrent) const override
std::map< std::string, VirtualRobot::RobotNodeSetPtr > controllableNodeSets
void onPublish(const SensorAndControl &, const DebugDrawerInterfacePrx &, const DebugObserverInterfacePrx &) override
static WidgetDescription::WidgetPtr GenerateConfigDescription(const VirtualRobot::RobotPtr &, const std::map< std::string, ConstControlDevicePtr > &, const std::map< std::string, ConstSensorDevicePtr > &)
--------------------------------— GUI Widget ------------------------------------------—
void onInitNJointController() override
NJointControllerBase interface.
ConfigurableNJointControllerConfigPtr ConfigPtrT
void limbRT(ArmPtr &arm, const double deltaT)
Ice::DoubleSeq getCurrentTCPPose(const std::string &nodeSetName, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
std::shared_ptr< common::coordination::SyncCoordination > coordinator
void limbNonRT(ArmPtr &arm)
law::TaskspaceMixedImpedanceVelocityController::ConfigDict ConfigDict
void onPublishCoordinator(const DebugObserverInterfacePrx &debugObs)
::armarx::aron::data::dto::DictPtr getConfig(const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Ice::FloatSeq getTCPVel(const std::string &rns, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
void limbReInit(ArmPtr &arm)
void useCoordinator(const std::string &type, const ::armarx::aron::data::dto::DictPtr &dto, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
std::map< std::string, ArmPtr > limb
bool isSafeForceTorque(const std::string &nodeSetName, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
-----------------------------— Other interaces ----------------------------------------—
law::TaskspaceMixedImpedanceVelocityController::Config Config
std::atomic_bool coordinatorEnabled
coordinator
void validateConfigData(Config &config, ArmPtr &arm)
static ConfigPtrT GenerateConfigFromVariants(const StringVariantBaseMap &values)
void limbRTSetTarget(ArmPtr &arm, const size_t nDoFTorque, const size_t nDoFVelocity, const Eigen::VectorXf &targetTorque, const Eigen::VectorXf &targetVelocity)
core::HandControlPtr hands
void enableSafeGuardForceTorque(const std::string &nodeSetName, const bool forceGuard, const bool torqueGuard, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
std::tuple< bool, bool > additionalTaskUpdateStatus()
armarx::control::common::control_law::TSCtrlRtStatus RtStatus
void rtPostDeactivateController() override
This function is called after the controller is deactivated.
void updateInputData(const std::string &key, const Eigen::Matrix4f &targetPose, const PoseFrameMode &targetPoseMode, const Eigen::Matrix4f &pose, const Eigen::Vector6f &vel, const Eigen::Vector6f &ft, const Eigen::Vector6f &stiffness)
some method for coordinator
void rtRunCoordinator(double deltaT)
coordinator
virtual void additionalTask()
void rtRun(const IceUtil::Time &sensorValuesTimestamp, const IceUtil::Time &timeSinceLastIteration) override
TODO make protected and use attorneys.
void limbInit(const std::string nodeSetName, ArmPtr &arm, Config &cfg, VirtualRobot::RobotPtr &nonRtRobotPtr)
std::unique_ptr< ArmData > ArmPtr
void additionalTaskSetTarget()
std::map< std::string, common::coordination::InputData > coordinatorInputData
void updateConfig(const ::armarx::aron::data::dto::DictPtr &dto, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
NJointController interface.
bool updateTargetPose(const TargetPoseMap &targetPoseMap, const TargetNullspaceMap &targetNullspaceMap, const Ice::Current &=Ice::emptyCurrent) override
void limbPublish(ArmPtr &arm, const DebugObserverInterfacePrx &debugObs)
void handleRTNotSafeInNonRT()
armarx::control::common::arondto::PoseFrameMode PoseFrameMode
VirtualRobot::RobotPtr nonRtRobot
NJointTaskspaceMixedImpedanceVelocityController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &)
void rtPreActivateController() override
This function is called before the controller is activated.
void limbRTUpdateStatus(ArmPtr &arm, const double deltaT)
-----------------------------— Real time cotnrol --------------------------------------—
armarx::aron::data::dto::Dict getRTStatus()
void disableCoordinator()
void calibrateFTSensor()
ft sensor
Matrix< float, 6, 1 > Vector6f
std::shared_ptr< class Robot > RobotPtr
::IceInternal::Handle< Dict > DictPtr
This file is part of ArmarX.
std::shared_ptr< HandControlBase > HandControlPtr
dictionary< string, Ice::FloatSeq > TargetNullspaceMap
dictionary< string, FloatSeqSeq > TargetPoseMap
::IceInternal::ProxyHandle<::IceProxy::armarx::DebugObserverInterface > DebugObserverInterfacePrx
std::map< std::string, VariantBasePtr > StringVariantBaseMap
SynchronousNJointController NJointController
IceUtil::Handle< class RobotUnit > RobotUnitPtr
::IceInternal::ProxyHandle<::IceProxy::armarx::DebugDrawerInterface > DebugDrawerInterfacePrx
detail::ControlThreadOutputBufferEntry SensorAndControl
std::atomic_bool rtFirstRun
flags
std::string kinematicChainName
names
std::vector< std::string > jointNames
std::vector< ControlTarget1DoFActuatorVelocity * > targetsVel
std::vector< size_t > velocityControlledIndex
std::vector< ControlTarget1DoFActuatorTorque * > targetsTorque
TripleBuffer< RtStatus > bufferRtStatusToNonRt
TripleBuffer< RtStatus > bufferRtStatusToOnPublish
TripleBuffer< Config > bufferConfigUserToNonRt
TripleBuffer< RtStatus > bufferRtStatusToUser
common::SensorDevicesForNJointTorqueController sensorDevices
devices
std::vector< size_t > torqueControlledIndex
TripleBuffer< Config > bufferConfigNonRtToRt
std::atomic_bool reInitPreActivate
TripleBuffer< Config > bufferConfigRtToUser
TripleBuffer< Config > bufferConfigRtToOnPublish
double nonRTAccumulateTime
set data containers and buffers
VirtualRobot::RobotPtr nonRtRobot
robot