Base.h
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * ArmarX is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 * ArmarX is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 *
16 * @package ...
17 * @author Jianfeng Gao ( jianfeng dot gao at kit dot edu )
18 * @date 2025
19 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
20 * GNU General Public License
21 */
22
23#pragma once
24
25#include <VirtualRobot/VirtualRobot.h>
26
31
32#include <armarx/control/common/common.aron.generated.h>
37#include <armarx/control/njoint_controller/task_space/ControllerInterface.h>
38
40{
41 namespace law = armarx::control::common::control_law;
42
43 /**
44 * @defgroup Library-NJointTaskspaceController NJointTaskspaceController
45 * @ingroup Library-RobotUnit-NJointControllers
46 * A description of the library NJointTaskspaceController.
47 *
48 * @class NJointTaskspaceController
49 * @ingroup Library-NJointTaskspaceController
50 * @brief Brief description of class NJointTaskspaceController.
51 *
52 * Detailed description of class NJointTaskspaceController.
53 */
54 template <typename NJointTaskspaceControllerType>
56 virtual public NJointController,
57 virtual public TSCtrlInterface,
59 {
60 public:
61 using ControlType = NJointTaskspaceControllerType;
62 using ConfigPtrT = ConfigurableNJointControllerConfigPtr;
63 using Config = typename NJointTaskspaceControllerType::Config;
64 using ConfigDict = typename NJointTaskspaceControllerType::ConfigDict;
65
67 using PoseFrameMode = armarx::control::common::arondto::PoseFrameMode;
68
69 struct ArmData
70 {
71 /// devices
73 std::vector<ControlTarget1DoFActuatorTorque*> targetsTorque;
74 std::vector<ControlTarget1DoFActuatorVelocity*> targetsVel;
75
76 /// names
77 std::string kinematicChainName;
78 std::vector<std::string> jointNames;
79
80 /// controller (maths)
81 NJointTaskspaceControllerType controller;
82
83 /// set data containers and buffers
84 double nonRTAccumulateTime = 0.0;
85 double nonRTDeltaT = 0.0;
86
94
100
101 /// flags
102 std::atomic_bool rtFirstRun{true};
103 std::atomic_bool rtReady{false};
104 std::atomic_bool reInitPreActivate{false};
105
106 std::atomic_bool desiredPoseSafeOnActivation{false};
107
108 /// robot
110
111 void rtPostDeactivate();
112 };
113
114 using ArmPtr = std::unique_ptr<ArmData>;
115
117 const NJointControllerConfigPtr& config,
119
120 void createLimbs();
121
122 // virtual std::string getClassName(const Ice::Current& = Ice::emptyCurrent) const override = 0;
123 // std::string getClassName(const Ice::Current& = Ice::emptyCurrent) const override = 0;
124
125 void rtRun(const IceUtil::Time& sensorValuesTimestamp,
126 const IceUtil::Time& timeSinceLastIteration) override;
127
128 /// NJointController interface
129 void updateConfig(const ::armarx::aron::data::dto::DictPtr& dto,
130 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
131 bool updateTargetPose(const TargetPoseMap& targetPoseMap,
132 const TargetNullspaceMap& targetNullspaceMap,
133 const Ice::Current& = Ice::emptyCurrent) override;
135 getConfig(const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
137 getRTStatus(const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
138
139 Ice::FloatSeq getTCPVel(const std::string& rns,
140 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
141
142 Ice::DoubleSeq
143 getCurrentTCPPose(const std::string& nodeSetName,
144 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
145
146 /// ft sensor
147 void calibrateFTSensor(const Ice::Current&) override;
148 void
149 enableSafeGuardForceTorque(const std::string& nodeSetName,
150 const bool forceGuard,
151 const bool torqueGuard,
152 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
153 bool isSafeForceTorque(const std::string& nodeSetName,
154 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
155 bool wasNotSafeForceTorque(const std::string& nodeSetName,
156 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
157
158 void useCoordinator(const std::string& type,
159 const ::armarx::aron::data::dto::DictPtr& dto,
160 const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
161 void disableCoordinator(const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
162
163 public:
166 const std::map<std::string, ConstControlDevicePtr>&,
167 const std::map<std::string, ConstSensorDevicePtr>&);
168
170
171 protected:
172 virtual void additionalTask();
173 std::tuple<bool, bool> additionalTaskUpdateStatus();
177 void validateConfigData(Config& config, ArmPtr& arm);
178 virtual void validateConfigDataCheckSize(Config& configData, ArmPtr& arm) = 0;
179 void onPublish(const SensorAndControl&,
181 const DebugObserverInterfacePrx&) override;
183
184 void commitArviz();
185 virtual void collectArviz(viz::StagedCommit& stage) const;
186
187 void limbInit(const std::string& nodeSetName,
188 ArmPtr& arm,
189 Config& cfg,
190 VirtualRobot::RobotPtr& nonRtRobotPtr);
191 void limbNonRT(ArmPtr& arm);
192 void limbRT(ArmPtr& arm, const double deltaT);
193 void limbRTUpdateStatus(ArmPtr& arm, const double deltaT);
194 void limbRTSetTarget(ArmPtr& arm,
195 const size_t nDoFTorque,
196 const size_t nDoFVelocity,
197 const Eigen::VectorXf& targetTorque,
198 const Eigen::VectorXf& targetVelocity);
199 void limbPublish(ArmPtr& arm, const DebugObserverInterfacePrx& debugObs);
200 virtual void limbPublishConfig(StringVariantBaseMap& datafields, ArmPtr& arm) = 0;
201 void limbReInit(ArmPtr& arm);
203
204 /// coordinator
205 void rtRunCoordinator(double deltaT);
206 void updateInputData(const std::string& key,
207 const Eigen::Matrix4f& targetPose,
208 const PoseFrameMode& targetPoseMode,
209 const Eigen::Matrix4f& pose,
210 const Eigen::Vector6f& vel,
211 const Eigen::Vector6f& ft,
212 const Eigen::Vector6f& stiffness);
213
214 protected:
215 std::map<std::string, ArmPtr> limb;
220 std::map<std::string, VirtualRobot::RobotNodeSetPtr> controllableNodeSets;
221
222 /// coordinator
223 std::atomic_bool coordinatorEnabled = false;
224 std::shared_ptr<common::coordination::SyncCoordination> coordinator = nullptr;
225 std::map<std::string, common::coordination::InputData> coordinatorInputData;
226
227 std::optional<viz::ScopedClient> scopedArviz = std::nullopt;
228
229 protected:
230 /// NJointControllerBase interface
231 void activateController(const Ice::Current& current = Ice::emptyCurrent) final;
232 void deactivateController(const Ice::Current& current = Ice::emptyCurrent) final;
233 void onInitNJointController() override;
234 void rtPreActivateController() override;
235 void rtPostDeactivateController() override;
236
237 private:
238 void createHands();
239
240 unsigned int skipStepCountArviz_ = 0;
241 unsigned int skipStepsArviz_ = 10;
242 bool resetArviz = false;
243 mutable std::unordered_map<std::string, viz::Layer> storedArvizLayers;
244 };
245
246 class NJointTSMixImpVelController : public NJointTaskspaceController<law::TSMixImpVelController>
247 {
248 public:
250 const NJointControllerConfigPtr& config,
251 const VirtualRobot::RobotPtr& robot);
252
253 std::string getClassName(const Ice::Current& = Ice::emptyCurrent) const override;
254 void validateConfigDataCheckSize(Config& configData, ArmPtr& arm) override;
255 void limbPublishConfig(StringVariantBaseMap& datafields, ArmPtr& arm) override;
256 };
257
258 class NJointTSImpController : public NJointTaskspaceController<law::TSImpController>
259 {
260 public:
262 const NJointControllerConfigPtr& config,
263 const VirtualRobot::RobotPtr& robot);
264
265 std::string getClassName(const Ice::Current& = Ice::emptyCurrent) const override;
266 void validateConfigDataCheckSize(Config& configData, ArmPtr& arm) override;
267 void limbPublishConfig(StringVariantBaseMap& datafields, ArmPtr& arm) override;
268 };
269
270 class NJointTSAdmController : public NJointTaskspaceController<law::TSAdmController>
271 {
272 public:
274 const NJointControllerConfigPtr& config,
275 const VirtualRobot::RobotPtr& robot);
276
277 std::string getClassName(const Ice::Current& = Ice::emptyCurrent) const override;
278 void validateConfigDataCheckSize(Config& configData, ArmPtr& arm) override;
279 void limbPublishConfig(StringVariantBaseMap& datafields, ArmPtr& arm) override;
280 };
281
282 class NJointTSVelController : public NJointTaskspaceController<law::TSVelController>
283 {
284 public:
286 const NJointControllerConfigPtr& config,
287 const VirtualRobot::RobotPtr& robot);
288
289 std::string getClassName(const Ice::Current& = Ice::emptyCurrent) const override;
290 void validateConfigDataCheckSize(Config& configData, ArmPtr& arm) override;
291 void limbPublishConfig(StringVariantBaseMap& datafields, ArmPtr& arm) override;
292 };
293
294} // namespace armarx::control::njoint_controller::task_space
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
Definition Base.cpp:1554
void limbPublishConfig(StringVariantBaseMap &datafields, ArmPtr &arm) override
Definition Base.cpp:1578
void validateConfigDataCheckSize(Config &configData, ArmPtr &arm) override
Definition Base.cpp:1560
NJointTSAdmController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &robot)
Definition Base.cpp:1545
std::string getClassName(const Ice::Current &=Ice::emptyCurrent) const override
================================== TSImp ==================================
Definition Base.cpp:1498
NJointTSImpController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &robot)
Definition Base.cpp:1489
void limbPublishConfig(StringVariantBaseMap &datafields, ArmPtr &arm) override
Definition Base.cpp:1522
void validateConfigDataCheckSize(Config &configData, ArmPtr &arm) override
Definition Base.cpp:1504
std::string getClassName(const Ice::Current &=Ice::emptyCurrent) const override
================================== TSMixImpVel ==================================
Definition Base.cpp:1437
NJointTSMixImpVelController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &robot)
Definition Base.cpp:1427
void limbPublishConfig(StringVariantBaseMap &datafields, ArmPtr &arm) override
Definition Base.cpp:1464
void validateConfigDataCheckSize(Config &configData, ArmPtr &arm) override
Definition Base.cpp:1443
std::string getClassName(const Ice::Current &=Ice::emptyCurrent) const override
Definition Base.cpp:1610
NJointTSVelController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &robot)
Definition Base.cpp:1601
void limbPublishConfig(StringVariantBaseMap &datafields, ArmPtr &arm) override
Definition Base.cpp:1631
void validateConfigDataCheckSize(Config &configData, ArmPtr &arm) override
Definition Base.cpp:1616
std::map< std::string, VirtualRobot::RobotNodeSetPtr > controllableNodeSets
Definition Base.h:220
void onPublish(const SensorAndControl &, const DebugDrawerInterfacePrx &, const DebugObserverInterfacePrx &) override
Definition Base.cpp:901
static WidgetDescription::WidgetPtr GenerateConfigDescription(const VirtualRobot::RobotPtr &, const std::map< std::string, ConstControlDevicePtr > &, const std::map< std::string, ConstSensorDevicePtr > &)
--------------------------------— GUI Widget ------------------------------------------—
Definition Base.cpp:1361
Ice::DoubleSeq getCurrentTCPPose(const std::string &nodeSetName, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Definition Base.cpp:729
std::shared_ptr< common::coordination::SyncCoordination > coordinator
Definition Base.h:224
void onPublishCoordinator(const DebugObserverInterfacePrx &debugObs)
Definition Base.cpp:929
::armarx::aron::data::dto::DictPtr getConfig(const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Definition Base.cpp:616
virtual void collectArviz(viz::StagedCommit &stage) const
Definition Base.cpp:983
NJointTaskspaceController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &)
Definition Base.cpp:138
Ice::FloatSeq getTCPVel(const std::string &rns, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Definition Base.cpp:712
void useCoordinator(const std::string &type, const ::armarx::aron::data::dto::DictPtr &dto, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Definition Base.cpp:1128
bool isSafeForceTorque(const std::string &nodeSetName, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
-----------------------------— Other interaces ----------------------------------------—
Definition Base.cpp:678
typename NJointTaskspaceControllerType::Config Config
Definition Base.h:63
bool wasNotSafeForceTorque(const std::string &nodeSetName, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Definition Base.cpp:695
void limbRTSetTarget(ArmPtr &arm, const size_t nDoFTorque, const size_t nDoFVelocity, const Eigen::VectorXf &targetTorque, const Eigen::VectorXf &targetVelocity)
Definition Base.cpp:380
void enableSafeGuardForceTorque(const std::string &nodeSetName, const bool forceGuard, const bool torqueGuard, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
Definition Base.cpp:650
typename NJointTaskspaceControllerType::ConfigDict ConfigDict
Definition Base.h:64
armarx::control::common::control_law::TSCtrlRtStatus RtStatus
Definition Base.h:66
void rtPostDeactivateController() override
This function is called after the controller is deactivated.
Definition Base.cpp:1329
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
Definition Base.cpp:460
void rtRun(const IceUtil::Time &sensorValuesTimestamp, const IceUtil::Time &timeSinceLastIteration) override
TODO make protected and use attorneys.
Definition Base.cpp:534
void activateController(const Ice::Current &current=Ice::emptyCurrent) final
NJointControllerBase interface.
Definition Base.cpp:1275
std::map< std::string, common::coordination::InputData > coordinatorInputData
Definition Base.h:225
void updateConfig(const ::armarx::aron::data::dto::DictPtr &dto, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
NJointController interface.
Definition Base.cpp:560
virtual void validateConfigDataCheckSize(Config &configData, ArmPtr &arm)=0
bool updateTargetPose(const TargetPoseMap &targetPoseMap, const TargetNullspaceMap &targetNullspaceMap, const Ice::Current &=Ice::emptyCurrent) override
Definition Base.cpp:749
static ConfigPtrT GenerateConfigFromVariants(const StringVariantBaseMap &values)
Definition Base.cpp:1404
virtual void limbPublishConfig(StringVariantBaseMap &datafields, ArmPtr &arm)=0
void limbPublish(ArmPtr &arm, const DebugObserverInterfacePrx &debugObs)
Definition Base.cpp:819
armarx::control::common::arondto::PoseFrameMode PoseFrameMode
Definition Base.h:67
void deactivateController(const Ice::Current &current=Ice::emptyCurrent) final
Definition Base.cpp:1298
void rtPreActivateController() override
This function is called before the controller is activated.
Definition Base.cpp:1311
void limbRTUpdateStatus(ArmPtr &arm, const double deltaT)
-----------------------------— Real time cotnrol --------------------------------------—
Definition Base.cpp:351
void limbInit(const std::string &nodeSetName, ArmPtr &arm, Config &cfg, VirtualRobot::RobotPtr &nonRtRobotPtr)
Definition Base.cpp:57
armarx::aron::data::dto::Dict getRTStatus()
Matrix< float, 6, 1 > Vector6f
std::shared_ptr< class Robot > RobotPtr
Definition Bus.h:19
::IceInternal::Handle<::armarx::WidgetDescription::Widget > WidgetPtr
::IceInternal::Handle< Dict > DictPtr
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
Definition FTSensor.h:34
::IceInternal::ProxyHandle<::IceProxy::armarx::DebugDrawerInterface > DebugDrawerInterfacePrx
detail::ControlThreadOutputBufferEntry SensorAndControl
std::vector< ControlTarget1DoFActuatorVelocity * > targetsVel
Definition Base.h:74
std::vector< ControlTarget1DoFActuatorTorque * > targetsTorque
Definition Base.h:73
common::SensorDevicesForNJointTorqueController sensorDevices
devices
Definition Base.h:72
A staged commit prepares multiple layers to be committed.
Definition Client.h:30