feature-pose.hh
Go to the documentation of this file.
1 /*
2  * Copyright 2019,
3  * Joseph Mirabel
4  *
5  * LAAS-CNRS
6  *
7  */
8 
9 #ifndef __SOT_FEATURE_POSE_HH__
10 #define __SOT_FEATURE_POSE_HH__
11 
12 /* --------------------------------------------------------------------- */
13 /* --- INCLUDE --------------------------------------------------------- */
14 /* --------------------------------------------------------------------- */
15 
16 /* SOT */
17 #include <sot/core/config.hh>
20 
21 /* --------------------------------------------------------------------- */
22 /* --- CLASS ----------------------------------------------------------- */
23 /* --------------------------------------------------------------------- */
24 
25 namespace dynamicgraph {
26 namespace sot {
27 
30 
61 template <Representation_t representation = R3xSO3Representation>
62 class SOT_CORE_DLLAPI FeaturePose : public FeatureAbstract {
63  public:
64  static const std::string CLASS_NAME;
65  virtual const std::string &getClassName(void) const { return CLASS_NAME; }
66 
67  public:
83 
96 
100 
109 
115  public:
116  FeaturePose(const std::string &name);
117  virtual ~FeaturePose(void);
118 
119  virtual unsigned int &getDimension(unsigned int &dim, int time);
120 
122  virtual dynamicgraph::Vector &computeError(dynamicgraph::Vector &res,
123  int time);
130  virtual dynamicgraph::Vector &computeErrorDot(dynamicgraph::Vector &res,
131  int time);
138  virtual dynamicgraph::Matrix &computeJacobian(dynamicgraph::Matrix &res,
139  int time);
140 
141  virtual void display(std::ostream &os) const;
142 
143  public:
144  void servoCurrentPosition(const int &time);
145 
146  private:
147  MatrixHomogeneous &computefaMfb(MatrixHomogeneous &res, int time);
148  Vector7 &computeQfaMfb(Vector7 &res, int time);
149  Vector7 &computeQfaMfbDes(Vector7 &res, int time);
150 
152 };
153 
154 template <typename T>
155 Vector6d convertVelocity(const MatrixHomogeneous &M,
156  const MatrixHomogeneous &Mdes,
157  const Vector &faNufafbDes);
158 
159 template <>
161 template <>
163 
164 #if __cplusplus >= 201103L
165 extern template class FeaturePose<SE3Representation>;
166 extern template class FeaturePose<R3xSO3Representation>;
167 #endif
168 
171 
172 } /* namespace sot */
173 } /* namespace dynamicgraph */
174 
175 #endif // #ifndef __SOT_FEATURE_POSE_HH__
176 
177 /*
178  * Local variables:
179  * c-basic-offset: 2
180  * End:
181  */
dynamicgraph::SignalPtr< MatrixHomogeneous, int > jaMfa
Input pose of Frame A wrt to Joint A.
Definition: feature-pose.hh:74
Eigen::Transform< double, 3, Eigen::Affine > SOT_CORE_EXPORT MatrixHomogeneous
Eigen::VectorXd Vector
SignalPtr< Flags, int > selectionSIN
This vector specifies which dimension are used to perform the computation. For instance let us assume...
#define DECLARE_NO_REFERENCE
virtual const std::string & getClassName(void) const
Returns the name class.
Definition: feature-pose.hh:65
SignalTimeDependent< Vector7, int > q_faMfb
Definition: feature-pose.hh:99
SignalTimeDependent< dynamicgraph::Matrix, int > jacobianSOUT
Jacobian of the error wrt the robot state: .
dynamicgraph::SignalPtr< MatrixHomogeneous, int > jbMfb
Input pose of Frame B wrt to Joint B.
Definition: feature-pose.hh:78
static const std::string CLASS_NAME
Definition: feature-pose.hh:64
SignalTimeDependent< Vector7, int > q_faMfbDes
FeaturePose< R3xSO3Representation > FeaturePose_t
Vector6d convertVelocity(const MatrixHomogeneous &M, const MatrixHomogeneous &Mdes, const Vector &faNufafbDes)
FeaturePose< SE3Representation > FeaturePoseSE3_t
Representation_t
Enum used to specify what difference operation is used in FeaturePose.
Definition: feature-pose.hh:29
dynamicgraph::SignalPtr< Matrix, int > jaJja
Jacobian of the input Joint A, expressed in Joint A
Definition: feature-pose.hh:80
This class gives the abstract definition of a feature.
Eigen::MatrixXd Matrix
Eigen::Matrix< double, 7, 1 > SOT_CORE_EXPORT Vector7
Feature that controls the relative (or absolute) pose between two frames A (or world) and B...
Definition: feature-pose.hh:62
dynamicgraph::SignalPtr< Matrix, int > jbJjb
Jacobian of the input Joint B, expressed in Joint B
Definition: feature-pose.hh:82
dynamicgraph::SignalPtr< MatrixHomogeneous, int > faMfbDes
The desired pose of Frame B wrt to Frame A.
Definition: feature-pose.hh:85
dynamicgraph::SignalPtr< MatrixHomogeneous, int > oMjb
Input pose of Joint B wrt to world frame.
Definition: feature-pose.hh:76
dynamicgraph::SignalPtr< Vector, int > faNufafbDes
Definition: feature-pose.hh:88
SignalTimeDependent< dynamicgraph::Vector, int > errorSOUT
This signal returns the error between the desired value and the current value : . ...


sot-core
Author(s): Olivier Stasse, ostasse@laas.fr
autogenerated on Wed Jun 21 2023 02:51:26