NJointHolonomicPlatformVelocityControllerWithRamp.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 RobotAPI::NJointHolonomicPlatformVelocityControllerInterface
17  * @author Tobias Gröger ( tobias dot groeger at student dot kit dot edu )
18  * @date 2024
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 
28 
29 // #include "NJointControllerWithTripleBuffer.h"
30 
31 namespace armarx
32 {
33  class ControlTargetHolonomicPlatformVelocity;
34  class SensorValueHolonomicPlatformVelocity;
35 
37  {
38  public:
39  Cartesian2DimVelocityRamp(float maxPositionAcceleration, float maxOrientationAcceleration);
40  void init(const Eigen::Vector3f& state);
41 
42  Eigen::Vector3f update(const Eigen::Vector3f& target, float dt);
43 
44  void setMaxPositionAcceleration(float maxPositionAcceleration);
45  void setMaxOrientationAcceleration(float maxOrientationAcceleration);
46 
47  private:
48  float maxPositionAcceleration = 0;
49  float maxOrientationAcceleration = 0;
50 
51  Eigen::Vector3f state; // [velX,velY,velRotation]
52  };
53 
55 
57  virtual public NJointControllerConfig
58  {
59  public:
60  std::string platformName;
61 
64  };
65 
67 
70  {
71  public:
72  using ConfigPtrT = NJointHolonomicPlatformVelocityControllerWithRampConfigPtr;
73 
75  ConfigPtrT config,
76  const VirtualRobot::RobotPtr&);
77 
78  void rtRun(const IceUtil::Time& sensorValuesTimestamp,
79  const IceUtil::Time& timeSinceLastIteration) override;
80 
81 
82  void setMaxAccelerations(float maxPositionAcceleration, float maxOrientationAcceleration);
83 
84  //ice interface
85  std::string
86  getClassName(const Ice::Current& = Ice::emptyCurrent) const override
87  {
88  return "NJointHolonomicPlatformVelocityControllerWithRamp";
89  }
90 
91  protected:
92  void rtPreActivateController() override;
93 
94  protected:
96 
97  Eigen::Vector3f activationVelocity;
99 
102  };
103 } // namespace armarx
armarx::ControlTargetHolonomicPlatformVelocity
Brief description of class ControlTargetHolonomicPlatformVelocity.
Definition: ControlTargetHolonomicPlatformVelocity.h:38
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::NJointHolonomicPlatformVelocityControllerInterface
Definition: NJointHolonomicPlatformVelocityControllerInterface.h:43
NJointHolonomicPlatformVelocityControllerInterface.h
armarx::TYPEDEF_PTRS_HANDLE
TYPEDEF_PTRS_HANDLE(NJointCartesianNaturalPositionController)
armarx::Cartesian2DimVelocityRamp
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:36
armarx::Cartesian2DimVelocityRamp::update
Eigen::Vector3f update(const Eigen::Vector3f &target, float dt)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:135
armarx::NJointHolonomicPlatformVelocityControllerWithRamp
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:68
armarx::NJointHolonomicPlatformVelocityControllerWithRampConfig::maxPositionAcceleration
float maxPositionAcceleration
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:62
boost::target
Vertex target(const detail::edge_base< Directed, Vertex > &e, const PCG &)
Definition: point_cloud_graph.h:668
armarx::NJointHolonomicPlatformVelocityControllerWithRampConfig::platformName
std::string platformName
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:60
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::NJointHolonomicPlatformVelocityControllerWithRamp::velocitySensor
const SensorValueHolonomicPlatformVelocity * velocitySensor
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:101
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
armarx::armem::Time
armarx::core::time::DateTime Time
Definition: forward_declarations.h:13
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::activationTime
IceUtil::Time activationTime
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:98
armarx::RobotUnit
The RobotUnit class manages a robot and its controllers.
Definition: RobotUnit.h:180
armarx::NJointHolonomicPlatformVelocityControllerWithRampConfig::maxOrientationAcceleration
float maxOrientationAcceleration
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:63
armarx::Cartesian2DimVelocityRamp::setMaxOrientationAcceleration
void setMaxOrientationAcceleration(float maxOrientationAcceleration)
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.cpp:162
armarx::NJointHolonomicPlatformVelocityControllerWithRampConfig
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:56
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
armarx::NJointHolonomicPlatformVelocityControllerWithRamp::getClassName
std::string getClassName(const Ice::Current &=Ice::emptyCurrent) const override
Definition: NJointHolonomicPlatformVelocityControllerWithRamp.h:86
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
VirtualRobot::RobotPtr
std::shared_ptr< class Robot > RobotPtr
Definition: Bus.h:19