BimanualImpedanceController.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 2023
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/Robot.h>
26 
31 
33 #include <armarx/control/interface/ConfigurableNJointControllerInterface.h>
34 #include <armarx/control/njoint_controller/task_space/ControllerInterface.h>
36 #include <armarx/control/njoint_controller/task_space/aron/NJointBimanualControllerConfig.aron.generated.h>
37 
38 
40 {
42 
44  {
45  control_law::TaskspaceImpedanceController::Config configLeft;
46  control_law::TaskspaceImpedanceController::Config configRight;
47  };
48 
49  /**
50  * @defgroup Library-NJointTaskspaceImpedanceController NJointTaskspaceImpedanceController
51  * @ingroup Library-RobotUnit-NJointControllers
52  * A description of the library NJointTaskspaceImpedanceController.
53  *
54  * @class NJointTaskspaceImpedanceController
55  * @ingroup Library-NJointTaskspaceImpedanceController
56  * @brief Brief description of class NJointTaskspaceImpedanceController.
57  *
58  * Detailed description of class NJointTaskspaceImpedanceController.
59  */
61  virtual public NJointController,
62  virtual public NJointTaskspaceBimanualImpedanceControllerInterface
63  {
64  public:
65  using ConfigPtrT = ConfigurableNJointControllerConfigPtr;
66  using AronDTO = law::arondto::TaskspaceImpedanceControllerConfig;
67  using BO = law::TaskspaceImpedanceController::Config;
68 
70  const NJointControllerConfigPtr& config,
71  const VirtualRobot::RobotPtr&);
72 
73  std::string getClassName(const Ice::Current&) const override;
74 
75  void rtRun(const IceUtil::Time& sensorValuesTimestamp,
76  const IceUtil::Time& timeSinceLastIteration) override;
77 
78  /// NJointController interface
79  // std::string getKinematicChainName(const Ice::Current&) override;
80 
82  const Ice::Current& iceCurrent = Ice::emptyCurrent) override;
83 
84  void validateConfigData(BO& config);
85 
86  protected:
87  virtual void additionalTask();
88  void onPublish(const SensorAndControl&,
90  const DebugObserverInterfacePrx&) override;
91 
92  protected:
93  /// devices
95  {
96  std::vector<const SensorValue1DoFActuatorTorque*> torqueSensors;
97  std::vector<const SensorValue1DoFActuatorVelocity*> velocitySensors;
98  std::vector<const SensorValue1DoFActuatorPosition*> positionSensors;
99  };
102 
103  std::vector<ControlTarget1DoFActuatorTorque*> targetsLeft;
104  std::vector<ControlTarget1DoFActuatorTorque*> targetsRight;
105 
106  protected:
107  /// variables
110  std::vector<std::string> jointNamesLeft;
111  std::vector<std::string> jointNamesRight;
114 
115  /// set buffers
119 
120  std::atomic_bool rtFirstRun = true;
121  std::atomic_bool rtReady = false;
122  std::atomic_bool reInitPreActivateLeft = false;
123  std::atomic_bool reInitPreActivateRight = false;
124 
126 
129 
130  RobotUnitPtr robotUnit;
131 
132  protected:
133  /// NJointControllerBase interface
134  void onInitNJointController() override;
135  void rtPreActivateController() override;
136  void rtPostDeactivateController() override;
137  };
138 } /// namespace armarx::control::njoint_controller::task_space
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::rtPreActivateController
void rtPreActivateController() override
This function is called before the controller is activated.
Definition: BimanualImpedanceController.cpp:265
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::updateConfig
void updateConfig(const ::armarx::aron::data::dto::DictPtr &dto, const Ice::Current &iceCurrent=Ice::emptyCurrent) override
NJointController interface.
Definition: BimanualImpedanceController.cpp:203
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::targetsLeft
std::vector< ControlTarget1DoFActuatorTorque * > targetsLeft
Definition: BimanualImpedanceController.h:103
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::SensorDevices::positionSensors
std::vector< const SensorValue1DoFActuatorPosition * > positionSensors
Definition: BimanualImpedanceController.h:98
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::kinematicChainNameLeft
std::string kinematicChainNameLeft
variables
Definition: BimanualImpedanceController.h:108
RobotUnit.h
TaskspaceImpedanceController.h
armarx::SynchronousNJointController
Definition: NJointControllerBase.h:1145
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::SensorDevices::velocitySensors
std::vector< const SensorValue1DoFActuatorVelocity * > velocitySensors
Definition: BimanualImpedanceController.h:97
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::rtFirstRun
std::atomic_bool rtFirstRun
Definition: BimanualImpedanceController.h:120
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::reInitPreActivateLeft
std::atomic_bool reInitPreActivateLeft
Definition: BimanualImpedanceController.h:122
armarx::control::njoint_controller::task_space
Definition: AdmittanceController.cpp:35
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::jointNamesLeft
std::vector< std::string > jointNamesLeft
Definition: BimanualImpedanceController.h:110
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::BO
law::TaskspaceImpedanceController::Config BO
Definition: BimanualImpedanceController.h:67
armarx::NJointControllerBase::ConfigPtrT
NJointControllerConfigPtr ConfigPtrT
Definition: NJointControllerBase.h:586
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::onInitNJointController
void onInitNJointController() override
NJointControllerBase interface.
Definition: BimanualImpedanceController.cpp:135
armarx::detail::ControlThreadOutputBufferEntry
Definition: ControlThreadOutputBuffer.h:177
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::AronDTO
law::arondto::TaskspaceImpedanceControllerConfig AronDTO
Definition: BimanualImpedanceController.h:66
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::bufferRtToAdditionalTask
TripleBuffer< law::RobotStatus > bufferRtToAdditionalTask
Definition: BimanualImpedanceController.h:118
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::nonRtRobot
VirtualRobot::RobotPtr nonRtRobot
Definition: BimanualImpedanceController.h:125
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::reInitPreActivateRight
std::atomic_bool reInitPreActivateRight
Definition: BimanualImpedanceController.h:123
armarx::control::njoint_controller::task_space::TSBimanualImpedanceConfig::configLeft
control_law::TaskspaceImpedanceController::Config configLeft
Definition: BimanualImpedanceController.h:45
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::kinematicChainNameRight
std::string kinematicChainNameRight
Definition: BimanualImpedanceController.h:109
armarx::control::common::control_law
namespace armarx::control::common::ft
Definition: aron_conversions.cpp:62
ControlTarget1DoFActuator.h
armarx::control::njoint_controller::task_space::TSBimanualImpedanceConfig
Definition: BimanualImpedanceController.h:43
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::targetsRight
std::vector< ControlTarget1DoFActuatorTorque * > targetsRight
Definition: BimanualImpedanceController.h:104
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::NJointTaskspaceImpedanceController
NJointTaskspaceImpedanceController(const RobotUnitPtr &robotUnit, const NJointControllerConfigPtr &config, const VirtualRobot::RobotPtr &)
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::controllerRight
law::TaskspaceImpedanceController controllerRight
Definition: BimanualImpedanceController.h:113
armarx::armem::Time
armarx::core::time::DateTime Time
Definition: forward_declarations.h:13
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::sensorDevicesLeft
SensorDevices sensorDevicesLeft
Definition: BimanualImpedanceController.h:100
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::sensorDevicesRight
SensorDevices sensorDevicesRight
Definition: BimanualImpedanceController.h:101
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::controlTargetsRight
common::control_law::ControlTarget controlTargetsRight
Definition: BimanualImpedanceController.h:128
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::onPublish
void onPublish(const SensorAndControl &, const DebugDrawerInterfacePrx &, const DebugObserverInterfacePrx &) override
Definition: BimanualImpedanceController.cpp:242
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::SensorDevices::torqueSensors
std::vector< const SensorValue1DoFActuatorTorque * > torqueSensors
Definition: BimanualImpedanceController.h:96
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::controlTargetsLeft
common::control_law::ControlTarget controlTargetsLeft
Definition: BimanualImpedanceController.h:127
NJointController.h
armarx::aron::data::DictPtr
std::shared_ptr< Dict > DictPtr
Definition: Dict.h:41
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::validateConfigData
void validateConfigData(BO &config)
Definition: BimanualImpedanceController.cpp:218
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::rtReady
std::atomic_bool rtReady
Definition: BimanualImpedanceController.h:121
armarx::control::common::control_law::TaskspaceImpedanceController
Definition: TaskspaceImpedanceController.h:38
armarx::control::njoint_controller::task_space::TSBimanualImpedanceConfig::configRight
control_law::TaskspaceImpedanceController::Config configRight
Definition: BimanualImpedanceController.h:46
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::jointNamesRight
std::vector< std::string > jointNamesRight
Definition: BimanualImpedanceController.h:111
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::controllerLeft
law::TaskspaceImpedanceController controllerLeft
Definition: BimanualImpedanceController.h:112
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::bufferUserToAdditionalTask
TripleBuffer< BO > bufferUserToAdditionalTask
set buffers
Definition: BimanualImpedanceController.h:116
IceInternal::ProxyHandle<::IceProxy::armarx::DebugDrawerInterface >
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::rtPostDeactivateController
void rtPostDeactivateController() override
This function is called after the controller is deactivated.
Definition: BimanualImpedanceController.cpp:301
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::robotUnit
RobotUnitPtr robotUnit
Definition: BimanualImpedanceController.h:130
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::additionalTask
virtual void additionalTask()
Definition: BimanualImpedanceController.cpp:156
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController
Definition: BimanualImpedanceController.h:60
armarx::control::common::control_law::ControlTarget
Definition: common.h:44
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::bufferUserToRt
TripleBuffer< BO > bufferUserToRt
Definition: BimanualImpedanceController.h:117
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::getClassName
std::string getClassName(const Ice::Current &) const override
Definition: BimanualImpedanceController.cpp:124
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::rtRun
void rtRun(const IceUtil::Time &sensorValuesTimestamp, const IceUtil::Time &timeSinceLastIteration) override
TODO make protected and use attorneys.
Definition: BimanualImpedanceController.cpp:166
SensorValue1DoFActuator.h
VirtualRobot::RobotPtr
std::shared_ptr< class Robot > RobotPtr
Definition: Bus.h:18
armarx::control::njoint_controller::task_space::NJointTaskspaceBimanualImpedanceController::SensorDevices
devices
Definition: BimanualImpedanceController.h:94
armarx::TripleBuffer< BO >
controller_descriptions.h