NJointHolonomicPlatformVelocityControllerWithRamp.cpp
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 RobotAPI::ArmarXObjects::NJointHolonomicPlatformUnitVelocityPassThroughController
17  * @author Raphael Grimm ( raphael dot grimm at kit dot edu )
18  * @date 2017
19  * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
20  * GNU General Public License
21  */
22 
24 
25 #include <VirtualRobot/Robot.h>
26 
28 
32 
33 #include "../ControlTargets/ControlTargetHolonomicPlatformVelocity.h"
34 
35 namespace armarx
36 {
39  ConfigPtrT cfg,
40  const VirtualRobot::RobotPtr&) :
41  ramp(cfg->maxPositionAcceleration, cfg->maxOrientationAcceleration)
42  {
43  target = useControlTarget(cfg->platformName, ControlModes::HolonomicPlatformVelocity)
46  << "The actuator " << cfg->platformName << " has no control mode "
47  << ControlModes::HolonomicPlatformVelocity;
48 
49  const auto sensor = useSensorValue(cfg->platformName);
50  ARMARX_CHECK_EXPRESSION(sensor) << "No sensor value for " << cfg->platformName;
53  << "Sensor value for " << cfg->platformName << " has invalid type";
54  }
55 
56  void
58  {
62  activationTime = IceUtil::Time::now();
63 
64  // init velocity ramp
66  }
67 
68  void
70  const IceUtil::Time& sensorValuesTimestamp,
71  const IceUtil::Time& timeSinceLastIteration)
72  {
73  auto commandAge = sensorValuesTimestamp - rtGetControlStruct().commandTimestamp;
74 
75  if (commandAge > maxCommandDelay && // command must be recent
76  (rtGetControlStruct().velocityX != 0.0f || rtGetControlStruct().velocityY != 0.0f ||
77  rtGetControlStruct().velocityRotation !=
78  0.0f)) // only throw error if any command is not zero
79  {
80  throw LocalException(
81  "Platform target velocity was not set for a too long time: delay: ")
82  << commandAge.toSecondsDouble()
83  << " s, max allowed delay: " << maxCommandDelay.toSecondsDouble() << " s";
84  }
85  else
86  {
87  Eigen::Vector3f result;
88  if (activationTime > rtGetControlStruct().commandTimestamp)
89  {
90  // No valid command has been specified. Sane default: come to rest.
91  const Eigen::Vector3f targetVelocity = Eigen::Vector3f::Zero();
92  result = ramp.update(targetVelocity, timeSinceLastIteration.toSecondsDouble());
93  }
94  else
95  {
96  Eigen::Vector3f x(rtGetControlStruct().velocityX,
97  rtGetControlStruct().velocityY,
98  rtGetControlStruct().velocityRotation);
99  result = ramp.update(x, timeSinceLastIteration.toSecondsDouble());
100  }
101 
102  target->velocityX = result(0);
103  target->velocityY = result(1);
104  target->velocityRotation = result(2);
105  }
106  }
107 
108  void
110  float maxPositionAcceleration,
111  float maxOrientationAcceleration)
112  {
113  ramp.setMaxPositionAcceleration(maxPositionAcceleration);
114  ramp.setMaxOrientationAcceleration(maxOrientationAcceleration);
115  }
116 
119  "NJointHolonomicPlatformVelocityControllerWithRamp");
120 
122  float maxOrientationAcceleration) :
123  maxPositionAcceleration(maxPositionAcceleration),
124  maxOrientationAcceleration(maxOrientationAcceleration)
125  {
126  }
127 
128  void
129  Cartesian2DimVelocityRamp::init(const Eigen::Vector3f& state)
130  {
131  this->state = state;
132  }
133 
134  Eigen::Vector3f
135  Cartesian2DimVelocityRamp::update(const Eigen::Vector3f& target, float dt)
136  {
137  if (dt <= 0)
138  {
139  return state;
140  }
141  Eigen::Vector3f delta = target - state;
142  float factor = 1;
143 
144  Eigen::Vector2f posDelta = delta.block<2, 1>(0, 0);
145  float posFactor = posDelta.norm() / maxPositionAcceleration / dt;
146  factor = std::max(factor, posFactor);
147 
148  float oriFactor = std::abs(delta(2)) / maxOrientationAcceleration / dt;
149  factor = std::max(factor, oriFactor);
150 
151  state += delta / factor;
152  return state;
153  }
154 
155  void
157  {
158  this->maxPositionAcceleration = maxPositionAcceleration;
159  }
160 
161  void
163  {
164  this->maxOrientationAcceleration = maxOrientationAcceleration;
165  }
166 
167 } // namespace armarx
armarx::ControlTargetHolonomicPlatformVelocity
Brief description of class ControlTargetHolonomicPlatformVelocity.
Definition: ControlTargetHolonomicPlatformVelocity.h:38
armarx::ControlTargetBase::asA
const T * asA() const
Definition: ControlTargetBase.h:76
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::rtRun
void rtRun(const IceUtil::Time &sensorValuesTimestamp, const IceUtil::Time &timeSinceLastIteration) override
TODO make protected and use attorneys.
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:69
armarx::SensorValueHolonomicPlatformVelocity::velocityX
DETAIL_SensorValueBase_DEFAULT_METHOD_IMPLEMENTATION float velocityX
Definition: SensorValueHolonomicPlatform.h:33
armarx::NJointControllerRegistration
Definition: NJointControllerRegistry.h:74
armarx::NJointControllerWithTripleBuffer< NJointHolonomicPlatformVelocityControllerControlData >::rtGetControlStruct
const NJointHolonomicPlatformVelocityControllerControlData & rtGetControlStruct() const
Definition: NJointControllerWithTripleBuffer.h:32
armarx::SensorValueBase::asA
const T * asA() const
Definition: SensorValueBase.h:82
SensorValueHolonomicPlatform.h
armarx::Cartesian2DimVelocityRamp::update
Eigen::Vector3f update(const Eigen::Vector3f &target, float dt)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:135
armarx::NJointControllerBase::useControlTarget
ControlTargetBase * useControlTarget(const std::string &deviceName, const std::string &controlMode)
Declares to calculate the ControlTarget for the given ControlDevice in the given ControlMode when rtR...
Definition: NJointController.cpp:410
armarx::registrationNJointHolonomicPlatformVelocityControllerWithRamp
NJointControllerRegistration< NJointHolonomicPlatformVelocityControllerWithRamp > registrationNJointHolonomicPlatformVelocityControllerWithRamp("NJointHolonomicPlatformVelocityControllerWithRamp")
boost::target
Vertex target(const detail::edge_base< Directed, Vertex > &e, const PCG &)
Definition: point_cloud_graph.h:668
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::NJointHolonomicPlatformVelocityControllerWithRamp
NJointHolonomicPlatformVelocityControllerWithRamp(RobotUnit *prov, ConfigPtrT config, const VirtualRobot::RobotPtr &)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:38
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::ramp
Cartesian2DimVelocityRamp ramp
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:95
armarx::NJointControllerBase::ConfigPtrT
NJointControllerConfigPtr ConfigPtrT
Definition: NJointControllerBase.h:587
armarx::ControlTargetHolonomicPlatformVelocity::velocityRotation
float velocityRotation
Definition: ControlTargetHolonomicPlatformVelocity.h:43
armarx::SensorValueHolonomicPlatformVelocity::velocityRotation
float velocityRotation
Definition: SensorValueHolonomicPlatform.h:35
armarx::NJointHolonomicPlatformVelocityControllerInterface::maxCommandDelay
IceUtil::Time maxCommandDelay
Definition: NJointHolonomicPlatformVelocityControllerInterface.h:57
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::velocitySensor
const SensorValueHolonomicPlatformVelocity * velocitySensor
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:101
SensorValueBase.h
armarx::SensorValueHolonomicPlatformVelocity::velocityY
float velocityY
Definition: SensorValueHolonomicPlatform.h:34
armarx::abs
std::vector< T > abs(const std::vector< T > &v)
Definition: VectorHelpers.h:281
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::setMaxAccelerations
void setMaxAccelerations(float maxPositionAcceleration, float maxOrientationAcceleration)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:109
armarx::SensorValueHolonomicPlatformVelocity
Definition: SensorValueHolonomicPlatform.h:30
armarx::Cartesian2DimVelocityRamp::init
void init(const Eigen::Vector3f &state)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:129
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::target
ControlTargetHolonomicPlatformVelocity * target
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:100
max
T max(T t1, T t2)
Definition: gdiam.h:51
armarx::ControlTargetHolonomicPlatformVelocity::velocityX
float velocityX
Definition: ControlTargetHolonomicPlatformVelocity.h:41
armarx::armem::Time
armarx::core::time::DateTime Time
Definition: forward_declarations.h:13
armarx::ControlTargetHolonomicPlatformVelocity::velocityY
float velocityY
Definition: ControlTargetHolonomicPlatformVelocity.h:42
ExpressionException.h
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::activationTime
IceUtil::Time activationTime
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:98
ARMARX_CHECK_EXPRESSION
#define ARMARX_CHECK_EXPRESSION(expression)
This macro evaluates the expression and if it turns out to be false it will throw an ExpressionExcept...
Definition: ExpressionException.h:73
NJointHolonomicPlatformVelocityControllerWithRamp.h
armarx::NJointHolonomicPlatformVelocityControllerControlData::commandTimestamp
IceUtil::Time commandTimestamp
Definition: NJointHolonomicPlatformVelocityControllerInterface.h:38
armarx::RobotUnit
The RobotUnit class manages a robot and its controllers.
Definition: RobotUnit.h:180
armarx::Cartesian2DimVelocityRamp::setMaxOrientationAcceleration
void setMaxOrientationAcceleration(float maxOrientationAcceleration)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:162
armarx::Cartesian2DimVelocityRamp::setMaxPositionAcceleration
void setMaxPositionAcceleration(float maxPositionAcceleration)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:156
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::rtPreActivateController
void rtPreActivateController() override
This function is called before the controller is activated.
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:57
NJointControllerRegistry.h
armarx
This file offers overloads of toIce() and fromIce() functions for STL container types.
Definition: ArmarXTimeserver.cpp:27
armarx::Cartesian2DimVelocityRamp::Cartesian2DimVelocityRamp
Cartesian2DimVelocityRamp(float maxPositionAcceleration, float maxOrientationAcceleration)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:121
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::activationVelocity
Eigen::Vector3f activationVelocity
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:97
dt
constexpr T dt
Definition: UnscentedKalmanFilterTest.cpp:45
armarx::NJointControllerBase::useSensorValue
const SensorValueBase * useSensorValue(const std::string &sensorDeviceName) const
Get a const ptr to the given SensorDevice's SensorValue.
Definition: NJointController.cpp:383
VirtualRobot::RobotPtr
std::shared_ptr< class Robot > RobotPtr
Definition: Bus.h:19