CartesianPositionController.cpp
Go to the documentation of this file.
1 /*
2  * This file is part of ArmarX.
3  *
4  * Copyright (C) 2012-2016, High Performance Humanoid Technologies (H2T),
5  * Karlsruhe Institute of Technology (KIT), all rights reserved.
6  *
7  * ArmarX is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License version 2 as
9  * published by the Free Software Foundation.
10  *
11  * ArmarX is distributed in the hope that it will be useful, but
12  * WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program. If not, see <http://www.gnu.org/licenses/>.
18  *
19  * @author Simon Ottenhaus (simon dot ottenhaus at kit dot edu)
20  * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
21  * GNU General Public License
22  */
23 
25 
26 #include <VirtualRobot/IK/DifferentialIK.h>
27 #include <VirtualRobot/Nodes/RobotNode.h>
28 #include <VirtualRobot/Robot.h>
29 #include <VirtualRobot/RobotNodeSet.h>
30 
32 
34 
35 namespace armarx
36 {
38  const VirtualRobot::RobotNodePtr& tcp,
39  const VirtualRobot::RobotNodePtr& referenceFrame) :
40  tcp(tcp), referenceFrame(referenceFrame ? referenceFrame : tcp->getRobot()->getRootNode())
41  {
42  }
43 
44  Eigen::VectorXf
47  {
49  int posLen = mode & VirtualRobot::IKSolver::Position ? 3 : 0;
50  int oriLen = mode & VirtualRobot::IKSolver::Orientation ? 3 : 0;
51  Eigen::VectorXf cartesianVel(posLen + oriLen);
52 
53  if (posLen)
54  {
56  Eigen::Vector3f targetPos = targetPose.block<3, 1>(0, 3);
57  Eigen::Vector3f currentPos = tcp->getPositionInFrame(referenceFrame);
58  Eigen::Vector3f errPos = targetPos - currentPos;
59  Eigen::Vector3f posVel = errPos * KpPos;
60  if (maxPosVel > 0)
61  {
62  posVel = math::MathUtils::LimitTo(posVel, maxPosVel);
63  }
64  cartesianVel.block<3, 1>(0, 0) = posVel;
65  }
66 
67  if (oriLen)
68  {
70  Eigen::Matrix3f targetOri = targetPose.block<3, 3>(0, 0);
71  Eigen::Matrix3f tcpOri = tcp->getPoseInFrame(referenceFrame).block<3, 3>(0, 0);
72  Eigen::Matrix3f oriDir = targetOri * tcpOri.inverse();
73  Eigen::AngleAxisf aa(oriDir);
74  Eigen::Vector3f errOri = aa.axis() * aa.angle();
75  Eigen::Vector3f oriVel = errOri * KpOri;
76 
77  if (maxOriVel > 0)
78  {
79  oriVel = math::MathUtils::LimitTo(oriVel, maxOriVel);
80  }
81  cartesianVel.block<3, 1>(posLen, 0) = oriVel;
82  }
83  return cartesianVel;
84  }
85 
86  Eigen::VectorXf
87  CartesianPositionController::calculatePos(const Eigen::Vector3f& targetPos) const
88  {
90  Eigen::VectorXf cartesianVel(3);
91  Eigen::Vector3f currentPos = tcp->getPositionInFrame(referenceFrame);
92  Eigen::Vector3f errPos = targetPos - currentPos;
93  Eigen::Vector3f posVel = errPos * KpPos;
94  if (maxPosVel > 0)
95  {
97  posVel = math::MathUtils::LimitTo(posVel, maxPosVel);
98  }
99  cartesianVel.block<3, 1>(0, 0) = posVel;
100  return cartesianVel;
101  }
102 
103  float
105  {
106  return GetPositionError(targetPose, tcp, referenceFrame);
107  }
108 
109  float
111  {
112  return GetOrientationError(targetPose, tcp, referenceFrame);
113  }
114 
115  float
117  const VirtualRobot::RobotNodePtr& tcp,
118  const VirtualRobot::RobotNodePtr& referenceFrame)
119  {
120  ARMARX_TRACE;
121  Eigen::Vector3f targetPos = targetPose.block<3, 1>(0, 3);
122  Eigen::Vector3f tcpPos = referenceFrame ? tcp->getPositionInFrame(referenceFrame)
123  : tcp->getPositionInRootFrame();
124  Eigen::Vector3f errPos = targetPos - tcpPos;
125  return errPos.norm();
126  }
127 
128  float
130  const Eigen::Matrix4f& targetPose,
131  const VirtualRobot::RobotNodePtr& tcp,
132  const VirtualRobot::RobotNodePtr& referenceFrame)
133  {
134  ARMARX_TRACE;
135  Eigen::Matrix3f targetOri = targetPose.block<3, 3>(0, 0);
136  Eigen::Matrix4f tcpPose =
137  referenceFrame ? tcp->getPoseInFrame(referenceFrame) : tcp->getPoseInRootFrame();
138  Eigen::Matrix3f tcpOri = tcpPose.block<3, 3>(0, 0);
139  Eigen::Matrix3f oriDir = targetOri * tcpOri.inverse();
140  Eigen::AngleAxisf aa(oriDir);
141  return aa.angle();
142  }
143 
144  bool
146  const VirtualRobot::RobotNodePtr& tcp,
147  bool checkOri,
148  float thresholdPosReached,
149  float thresholdOriReached,
150  const VirtualRobot::RobotNodePtr& referenceFrame)
151  {
152  return GetPositionError(targetPose, tcp, referenceFrame) < thresholdPosReached &&
153  (!checkOri ||
154  GetOrientationError(targetPose, tcp, referenceFrame) < thresholdOriReached);
155  }
156 
157  bool
160  float thresholdPosReached,
161  float thresholdOriReached)
162  {
163  ARMARX_TRACE;
165  {
166  if (GetPositionError(targetPose, tcp, referenceFrame) > thresholdPosReached)
167  {
168  return false;
169  }
170  }
172  {
173  if (GetOrientationError(targetPose, tcp, referenceFrame) > thresholdOriReached)
174  {
175  return false;
176  }
177  }
178  return true;
179  }
180 
181  Eigen::Vector3f
183  {
184  ARMARX_TRACE;
185  Eigen::Vector3f targetPos = targetPose.block<3, 1>(0, 3);
186  return targetPos - tcp->getPositionInFrame(referenceFrame);
187  }
188 
189  Eigen::Vector3f
190  CartesianPositionController::getPositionDiffVec3(const Eigen::Vector3f& targetPosition) const
191  {
192  return targetPosition - tcp->getPositionInFrame(referenceFrame);
193  }
194 
195  Eigen::Vector3f
197  {
198  ARMARX_TRACE;
199  Eigen::Matrix3f targetOri = targetPose.block<3, 3>(0, 0);
200  Eigen::Matrix3f tcpOri = tcp->getPoseInFrame(referenceFrame).block<3, 3>(0, 0);
201  Eigen::Matrix3f oriDir = targetOri * tcpOri.inverse();
202  Eigen::AngleAxisf aa(oriDir);
203  return aa.axis() * aa.angle();
204  }
205 
206  VirtualRobot::RobotNodePtr
208  {
209  return tcp;
210  }
211 
212 #define SS_OUT(x) ss << #x << " = " << x << "\n"
213 #define SET_FLT(x) obj->setFloat(#x, x)
214 #define GET_FLT(x) x = obj->getFloat(#x);
215 
217  {
218  }
219 
220  std::string
221  CartesianPositionControllerConfig::output(const Ice::Current&) const
222  {
223  std::stringstream ss;
224 
225  SS_OUT(KpPos);
226  SS_OUT(KpOri);
227  SS_OUT(maxPosVel);
228  SS_OUT(maxOriVel);
229  SS_OUT(thresholdOrientationNear);
230  SS_OUT(thresholdOrientationReached);
231  SS_OUT(thresholdPositionNear);
232  SS_OUT(thresholdPositionReached);
233 
234  return ss.str();
235  }
236 
237  void
238  CartesianPositionControllerConfig::serialize(const ObjectSerializerBasePtr& serializer,
239  const Ice::Current&) const
240  {
241  AbstractObjectSerializerPtr obj = AbstractObjectSerializerPtr::dynamicCast(serializer);
242 
243  SET_FLT(KpPos);
244  SET_FLT(KpOri);
245  SET_FLT(maxPosVel);
246  SET_FLT(maxOriVel);
247  SET_FLT(thresholdOrientationNear);
248  SET_FLT(thresholdOrientationReached);
249  SET_FLT(thresholdPositionNear);
250  SET_FLT(thresholdPositionReached);
251  }
252 
253  void
254  CartesianPositionControllerConfig::deserialize(const ObjectSerializerBasePtr& serializer,
255  const Ice::Current&)
256  {
257  AbstractObjectSerializerPtr obj = AbstractObjectSerializerPtr::dynamicCast(serializer);
258 
259  GET_FLT(KpPos);
260  GET_FLT(KpOri);
261  GET_FLT(maxPosVel);
262  GET_FLT(maxOriVel);
263  GET_FLT(thresholdOrientationNear);
264  GET_FLT(thresholdOrientationReached);
265  GET_FLT(thresholdPositionNear);
266  GET_FLT(thresholdPositionReached);
267  }
268 } // namespace armarx
armarx::CartesianPositionController::CartesianPositionController
CartesianPositionController(const VirtualRobot::RobotNodePtr &tcp, const VirtualRobot::RobotNodePtr &referenceFrame=nullptr)
Definition: CartesianPositionController.cpp:37
MathUtils.h
GfxTL::Orientation
ScalarT Orientation(const VectorXD< 2, ScalarT > &p1, const VectorXD< 2, ScalarT > &p2, const VectorXD< 2, ScalarT > &c)
Definition: Orientation.h:10
GfxTL::Matrix4f
MatrixXX< 4, 4, float > Matrix4f
Definition: MatrixXX.h:650
armarx::CartesianPositionController::maxPosVel
float maxPosVel
Definition: CartesianPositionController.h:82
armarx::CartesianPositionController::calculatePos
Eigen::VectorXf calculatePos(const Eigen::Vector3f &targetPos) const
Definition: CartesianPositionController.cpp:87
trace.h
armarx::CartesianPositionController::GetOrientationError
static float GetOrientationError(const Eigen::Matrix4f &targetPose, const VirtualRobot::RobotNodePtr &tcp, const VirtualRobot::RobotNodePtr &referenceFrame=nullptr)
Definition: CartesianPositionController.cpp:129
armarx::CartesianPositionController::getPositionDiff
Eigen::Vector3f getPositionDiff(const Eigen::Matrix4f &targetPose) const
Definition: CartesianPositionController.cpp:182
SET_FLT
#define SET_FLT(x)
Definition: CartesianPositionController.cpp:213
armarx::CartesianPositionController::reached
bool reached(const Eigen::Matrix4f &targetPose, VirtualRobot::IKSolver::CartesianSelection mode, float thresholdPosReached, float thresholdOriReached)
Definition: CartesianPositionController.cpp:158
IceInternal::Handle
Definition: forward_declarations.h:8
armarx::CartesianPositionController::getPositionError
float getPositionError(const Eigen::Matrix4f &targetPose) const
Definition: CartesianPositionController.cpp:104
armarx::CartesianPositionController::getPositionDiffVec3
Eigen::Vector3f getPositionDiffVec3(const Eigen::Vector3f &targetPosition) const
Definition: CartesianPositionController.cpp:190
ARMARX_TRACE
#define ARMARX_TRACE
Definition: trace.h:77
armarx::CartesianPositionControllerConfig::serialize
void serialize(const armarx::ObjectSerializerBasePtr &serializer, const ::Ice::Current &=::Ice::Current()) const override
Definition: CartesianPositionController.cpp:238
armarx::CartesianPositionController::KpOri
float KpOri
Definition: CartesianPositionController.h:81
armarx::CartesianPositionController::GetPositionError
static float GetPositionError(const Eigen::Matrix4f &targetPose, const VirtualRobot::RobotNodePtr &tcp, const VirtualRobot::RobotNodePtr &referenceFrame=nullptr)
Definition: CartesianPositionController.cpp:116
GET_FLT
#define GET_FLT(x)
Definition: CartesianPositionController.cpp:214
armarx::NJointTaskSpaceDMPControllerMode::CartesianSelection
CartesianSelection
Definition: ControllerInterface.ice:34
armarx::CartesianPositionControllerConfig::CartesianPositionControllerConfig
CartesianPositionControllerConfig()
Definition: CartesianPositionController.cpp:216
armarx::CartesianPositionController::getTcp
VirtualRobot::RobotNodePtr getTcp() const
Definition: CartesianPositionController.cpp:207
CartesianPositionController.h
armarx::CartesianPositionControllerConfig::output
std::string output(const Ice::Current &c=::Ice::Current()) const override
Definition: CartesianPositionController.cpp:221
armarx::math::MathUtils::LimitTo
static double LimitTo(double value, double absThreshold)
Definition: MathUtils.h:71
armarx::CartesianPositionController::getOrientationDiff
Eigen::Vector3f getOrientationDiff(const Eigen::Matrix4f &targetPose) const
Definition: CartesianPositionController.cpp:196
armarx::CartesianPositionController::maxOriVel
float maxOriVel
Definition: CartesianPositionController.h:83
armarx::CartesianPositionController::Reached
static bool Reached(const Eigen::Matrix4f &targetPose, const VirtualRobot::RobotNodePtr &tcp, bool checkOri, float thresholdPosReached, float thresholdOriReached, const VirtualRobot::RobotNodePtr &referenceFrame=nullptr)
Definition: CartesianPositionController.cpp:145
armarx::CartesianPositionControllerConfig::deserialize
void deserialize(const armarx::ObjectSerializerBasePtr &serializer, const ::Ice::Current &=::Ice::Current()) override
Definition: CartesianPositionController.cpp:254
armarx::CartesianPositionController::KpPos
float KpPos
Definition: CartesianPositionController.h:80
armarx::navigation::core::Position
Eigen::Vector3f Position
Definition: basic_types.h:36
GfxTL::Matrix3f
MatrixXX< 3, 3, float > Matrix3f
Definition: MatrixXX.h:649
armarx::CartesianPositionController::getOrientationError
float getOrientationError(const Eigen::Matrix4f &targetPose) const
Definition: CartesianPositionController.cpp:110
armarx
This file offers overloads of toIce() and fromIce() functions for STL container types.
Definition: ArmarXTimeserver.cpp:27
SS_OUT
#define SS_OUT(x)
Definition: CartesianPositionController.cpp:212
armarx::CartesianPositionController::calculate
Eigen::VectorXf calculate(const Eigen::Matrix4f &targetPose, VirtualRobot::IKSolver::CartesianSelection mode) const
Definition: CartesianPositionController.cpp:45