sot-core  4.11.8
Hierarchical task solver plug-in for dynamic-graph.
feature-generic.hh
Go to the documentation of this file.
1 /*
2  * Copyright 2010,
3  * François Bleibel,
4  * Olivier Stasse,
5  *
6  * CNRS/AIST
7  *
8  */
9 
10 #ifndef __SOT_FEATURE_GENERIC_HH__
11 #define __SOT_FEATURE_GENERIC_HH__
12 
13 /* --------------------------------------------------------------------- */
14 /* --- INCLUDE --------------------------------------------------------- */
15 /* --------------------------------------------------------------------- */
16 
17 /* SOT */
20 
21 /* --------------------------------------------------------------------- */
22 /* --- API ------------------------------------------------------------- */
23 /* --------------------------------------------------------------------- */
24 
25 #if defined(WIN32)
26 #if defined(feature_generic_EXPORTS)
27 #define SOTFEATUREGENERIC_EXPORT __declspec(dllexport)
28 #else
29 #define SOTFEATUREGENERIC_EXPORT __declspec(dllimport)
30 #endif
31 #else
32 #define SOTFEATUREGENERIC_EXPORT
33 #endif
34 
35 /* --------------------------------------------------------------------- */
36 /* --- CLASS ----------------------------------------------------------- */
37 /* --------------------------------------------------------------------- */
38 
39 namespace dynamicgraph {
40 namespace sot {
41 
57  : public FeatureAbstract,
58  FeatureReferenceHelper<FeatureGeneric> {
59  public:
61  static const std::string CLASS_NAME;
63  virtual const std::string &getClassName(void) const { return CLASS_NAME; }
64 
65  protected:
67 
68  /* --- SIGNALS ------------------------------------------------------------ */
69  public:
77  dynamicgraph::SignalPtr<dynamicgraph::Vector, int> errorSIN;
78 
80  dynamicgraph::SignalPtr<dynamicgraph::Matrix, int> jacobianSIN;
81 
90 
94 
95  public:
97  FeatureGeneric(const std::string &name);
98 
100  virtual ~FeatureGeneric(void) {}
101 
103  virtual unsigned int &getDimension(unsigned int &dim, int time);
104 
111  virtual dynamicgraph::Vector &computeError(dynamicgraph::Vector &res,
112  int time);
113 
115  virtual dynamicgraph::Matrix &computeJacobian(dynamicgraph::Matrix &res,
116  int time);
117 
121  virtual void display(std::ostream &os) const;
122 
128 };
129 
130 } /* namespace sot */
131 } /* namespace dynamicgraph */
132 
133 #endif // #ifndef __SOT_FEATURE_GENERIC_HH__
134 
135 /*
136  * Local variables:
137  * c-basic-offset: 2
138  * End:
139  */
This class gives the abstract definition of a feature.
Definition: feature-abstract.hh:76
SignalTimeDependent< dynamicgraph::Matrix, int > jacobianSOUT
Jacobian of the error wrt the robot state: .
Definition: feature-abstract.hh:193
SignalTimeDependent< dynamicgraph::Vector, int > errorSOUT
This signal returns the error between the desired value and the current value : .
Definition: feature-abstract.hh:185
Class that defines a generic implementation of the abstract interface for features.
Definition: feature-generic.hh:58
dynamicgraph::Vector::Index dimensionDefault
Definition: feature-generic.hh:66
static const std::string CLASS_NAME
Definition: feature-generic.hh:61
dynamicgraph::SignalPtr< dynamicgraph::Vector, int > errorSIN
Input for the error.
Definition: feature-generic.hh:77
DECLARE_REFERENCE_FUNCTIONS(FeatureGeneric)
FeatureGeneric(const std::string &name)
Default constructor.
virtual const std::string & getClassName(void) const
Definition: feature-generic.hh:63
dynamicgraph::SignalPtr< dynamicgraph::Matrix, int > jacobianSIN
Input for the Jacobian.
Definition: feature-generic.hh:80
virtual ~FeatureGeneric(void)
Default destructor.
Definition: feature-generic.hh:100
virtual dynamicgraph::Vector & computeError(dynamicgraph::Vector &res, int time)
Compute the error between the desired value and the value itself.
virtual dynamicgraph::Matrix & computeJacobian(dynamicgraph::Matrix &res, int time)
Compute the Jacobian of the value according to the robot state..
virtual void display(std::ostream &os) const
Display the information related to this generic implementation.
virtual unsigned int & getDimension(unsigned int &dim, int time)
Get the dimension of the feature.
Definition: feature-abstract.hh:229
#define SOTFEATUREGENERIC_EXPORT
Definition: feature-generic.hh:32
Eigen::VectorXd::Index Index
Definition: robot-utils.hh:39
Definition: abstract-sot-external-interface.hh:17