hpp-constraints  6.0.0
Definition of basic geometric constraints for motion planning
locked-joint.hh
Go to the documentation of this file.
1 // Copyright (c) 2015 - 2018, LAAS-CNRS
2 // Authors: Florent Lamiraux, Joseph Mirabel
3 //
4 
5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are
7 // met:
8 //
9 // 1. Redistributions of source code must retain the above copyright
10 // notice, this list of conditions and the following disclaimer.
11 //
12 // 2. Redistributions in binary form must reproduce the above copyright
13 // notice, this list of conditions and the following disclaimer in the
14 // documentation and/or other materials provided with the distribution.
15 //
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20 // HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
27 // DAMAGE.
28 
29 #ifndef HPP_CONSTRAINTS_LOCKED_JOINT_HH
30 #define HPP_CONSTRAINTS_LOCKED_JOINT_HH
31 
33 #include <hpp/pinocchio/joint.hh>
34 
35 namespace hpp {
36 namespace constraints {
37 
40 
67  public:
69  virtual ImplicitPtr_t copy() const;
70 
74  static LockedJointPtr_t create(const JointPtr_t& joint,
75  const LiegroupElement& value);
76 
83  static LockedJointPtr_t create(const JointPtr_t& joint, const size_type index,
84  vectorIn_t value);
85 
91  static LockedJointPtr_t create(const DevicePtr_t& dev, const size_type index,
92  vectorIn_t value);
93 
97 
100 
103 
106 
109 
112 
114  vectorIn_t value() const;
115 
117  void value(vectorIn_t value);
118 
120  const JointPtr_t& joint() { return joint_; }
122  const std::string& jointName() const { return jointName_; }
124  std::ostream& print(std::ostream& os) const;
125 
134  virtual std::pair<JointConstPtr_t, JointConstPtr_t>
136 
137  protected:
141  LockedJoint(const JointPtr_t& joint, const LiegroupElement& value);
148  LockedJoint(const JointPtr_t& joint, const size_type index, vectorIn_t value);
154  LockedJoint(const DevicePtr_t& robot, const size_type index,
155  vectorIn_t value);
157  LockedJoint(const LockedJoint& other);
161  virtual bool isEqual(const Implicit& other, bool swapAndTest) const;
162 
163  void init(const LockedJointPtr_t& self);
164 
165  private:
166  std::string jointName_;
167  JointPtr_t joint_;
168  LiegroupSpacePtr_t configSpace_;
170  LockedJointWkPtr_t weak_;
171 
172  LockedJoint() {}
173  HPP_SERIALIZABLE();
174 }; // class LockedJoint
175 
177 inline std::ostream& operator<<(std::ostream& os, const LockedJoint& lj) {
178  return lj.print(os);
179 }
180 } // namespace constraints
181 } // namespace hpp
182 
183 BOOST_CLASS_EXPORT_KEY(hpp::constraints::LockedJoint)
184 #endif // HPP_CONSTRAINTS_LOCKED_JOINT_HH
Definition: explicit.hh:143
Definition: implicit.hh:119
Definition: locked-joint.hh:66
virtual std::pair< JointConstPtr_t, JointConstPtr_t > doesConstrainRelPoseBetween(DeviceConstPtr_t robot) const
LockedJoint(const JointPtr_t &joint, const size_type index, vectorIn_t value)
const JointPtr_t & joint()
Return shared pointer to joint.
Definition: locked-joint.hh:120
size_type rankInConfiguration() const
Get index of locked degree of freedom in robot configuration vector.
static LockedJointPtr_t createCopy(LockedJointConstPtr_t other)
void value(vectorIn_t value)
Set the value of the locked joint.
LockedJoint(const DevicePtr_t &robot, const size_type index, vectorIn_t value)
static LockedJointPtr_t create(const JointPtr_t &joint, const LiegroupElement &value)
virtual ImplicitPtr_t copy() const
Copy object and return shared pointer to copy.
void init(const LockedJointPtr_t &self)
std::ostream & print(std::ostream &os) const
Print object in a stream.
LockedJoint(const JointPtr_t &joint, const LiegroupElement &value)
size_type numberDof() const
Get number of degrees of freedom of the joint.
virtual bool isEqual(const Implicit &other, bool swapAndTest) const
size_type rankInVelocity() const
Get index of locked degree of freedom in robot velocity vector.
static LockedJointPtr_t create(const JointPtr_t &joint, const size_type index, vectorIn_t value)
LockedJoint(const LockedJoint &other)
Copy constructor.
vectorIn_t value() const
Get the value of the locked joint.
const std::string & jointName() const
Return the joint name.
Definition: locked-joint.hh:122
size_type configSize() const
Get the configuration size of the joint.
static LockedJointPtr_t create(const DevicePtr_t &dev, const size_type index, vectorIn_t value)
const LiegroupSpacePtr_t & configSpace() const
Get configuration space of locked joint.
#define HPP_CONSTRAINTS_DLLAPI
Definition: config.hh:88
pinocchio::LiegroupElement LiegroupElement
Definition: fwd.hh:65
shared_ptr< const LockedJoint > LockedJointConstPtr_t
Definition: fwd.hh:206
pinocchio::DevicePtr_t DevicePtr_t
Definition: fwd.hh:109
pinocchio::DeviceConstPtr_t DeviceConstPtr_t
Definition: fwd.hh:110
pinocchio::LiegroupSpacePtr_t LiegroupSpacePtr_t
Definition: fwd.hh:69
ComparisonTypes_t operator<<(const ComparisonType &a, const ComparisonType &b)
Definition: comparison-types.hh:61
shared_ptr< Implicit > ImplicitPtr_t
Definition: fwd.hh:173
pinocchio::size_type size_type
Definition: fwd.hh:47
pinocchio::vectorIn_t vectorIn_t
Definition: fwd.hh:60
shared_ptr< LockedJoint > LockedJointPtr_t
Definition: fwd.hh:205
pinocchio::JointPtr_t JointPtr_t
Definition: fwd.hh:49
Definition: active-set-differentiable-function.hh:36