33#ifndef DART_DYNAMICS_DEGREEOFFREEDOM_HPP_
34#define DART_DYNAMICS_DEGREEOFFREEDOM_HPP_
72 const std::string& _name,
bool _preserveName =
true);
89 const std::string&
getName()
const;
#define DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_END
Definition ClassWithVirtualBase.hpp:44
#define DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN
Definition ClassWithVirtualBase.hpp:43
bool * preserveName
Definition SkelParser.cpp:1696
The Subject class is a base class for any object that wants to report when it gets destroyed.
Definition Subject.hpp:58
BodyNode class represents a single node of the skeleton.
Definition BodyNode.hpp:79
DegreeOfFreedom class is a proxy class for accessing single degrees of freedom (aka generalized coord...
Definition DegreeOfFreedom.hpp:56
double getDampingCoefficient() const
Get coefficient of damping (viscous friction) force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:463
void resetForce()
Set the generalized force of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:348
void setAccelerationLimits(double _lowerLimit, double _upperLimit)
Set the acceleration limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:290
void setVelocity(double _velocity)
Set the velocity of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:197
void setAccelerationUpperLimit(double _limit)
Set the upper acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:324
bool isCyclic() const
Get whether this DOF is cyclic.
Definition DegreeOfFreedom.cpp:173
void resetPosition()
Set the position of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:179
double getForceUpperLimit() const
Get the upper generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:391
double getPosition() const
Get the position of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:115
void resetConstraintImpulse()
Set the constraint impulse of this generalized coordinate to zero.
Definition DegreeOfFreedom.cpp:427
void setAcceleration(double _acceleration)
Set the acceleration of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:272
BodyNode * getChildBodyNode()
Get the BodyNode downstream of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:505
void setForce(double _force)
Set the generalized force of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:336
double getCoulombFriction() const
Get Coulomb friction force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:475
DegreeOfFreedom(const DegreeOfFreedom &)=delete
void setCoulombFriction(double _friction)
Set Coulomb friction force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:469
std::size_t getIndexInTree() const
Get this DegreeOfFreedom's index within its tree.
Definition DegreeOfFreedom.cpp:73
std::size_t getIndexInSkeleton() const
Get this DegreeOfFreedom's index within its Skeleton.
Definition DegreeOfFreedom.cpp:67
double getForce() const
Get the generalized force of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:342
Joint * getJoint()
Get the Joint that this DegreeOfFreedom belongs to.
Definition DegreeOfFreedom.cpp:481
std::size_t getTreeIndex() const
Get the index of the tree that this DegreeOfFreedom belongs to.
Definition DegreeOfFreedom.cpp:85
std::pair< double, double > getVelocityLimits() const
Get the velocity limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:229
const std::string & getName() const
Get the name of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:49
void resetCommand()
Set the command of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:103
bool hasPositionLimit() const
Get whether the position of this DegreeOfFreedom has limits.
Definition DegreeOfFreedom.cpp:167
std::pair< double, double > getForceLimits() const
Get the generalized force limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:367
std::size_t mIndexInTree
Index of this DegreeOfFreedom within its tree.
Definition DegreeOfFreedom.hpp:399
void setDampingCoefficient(double _coeff)
Set coefficient of damping (viscous friction) force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:457
double getAcceleration() const
Get the acceleration of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:278
void setRestPosition(double _q0)
Set rest position for the spring force of this generalized coordinate.
Definition DegreeOfFreedom.cpp:445
double getRestPosition() const
Get rest position for the spring force of this generalized coordinate.
Definition DegreeOfFreedom.cpp:451
std::size_t getIndexInJoint() const
Get this DegreeOfFreedom's index within its Joint.
Definition DegreeOfFreedom.cpp:79
void setVelocityLowerLimit(double _limit)
Set the lower velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:236
void setAccelerationLowerLimit(double _limit)
Set the lower acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:312
void setSpringStiffness(double _k)
Set stiffness of the spring force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:433
void setCommand(double _command)
Set the command of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:91
double getAccelerationLowerLimit() const
Get the lower acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:318
double getVelocityUpperLimit() const
Get the upper Velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:254
std::pair< double, double > getAccelerationLimits() const
Get the acceleration limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:305
double getVelocityChange() const
Get the velocity change of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:403
double getSpringStiffness() const
Get stiffness of the spring force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:439
void setPositionLimits(double _lowerLimit, double _upperLimit)
Set the position limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:121
void setVelocityUpperLimit(double _limit)
Set the upper velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:248
void setInitialPosition(double _initial)
Change the position that resetPosition() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:185
BodyNode * getParentBodyNode()
Get the BodyNode upstream of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:517
double getInitialVelocity() const
Get the velocity that resetVelocity() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:266
void setForceLimits(double _lowerLimit, double _upperLimit)
Set the generalized force limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:354
double getCommand() const
Get the command of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:97
double getVelocityLowerLimit() const
Get the lower velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:242
double getPositionLowerLimit() const
Get the lower position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:149
std::pair< double, double > getPositionLimits() const
Get the position limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:135
double getAccelerationUpperLimit() const
Get the upper acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:330
double getConstraintImpulse() const
Get the constraint impulse of this generalized coordinate.
Definition DegreeOfFreedom.cpp:421
void setVelocityChange(double _velocityChange)
Set the velocity change of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:397
double getVelocity() const
Get the velocity of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:203
SkeletonPtr getSkeleton()
Get the Skeleton that this DegreeOfFreedom is inside of.
Definition DegreeOfFreedom.cpp:493
double getInitialPosition() const
Get the position that resetPosition() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:191
Joint * mJoint
The joint that this DegreeOfFreedom belongs to.
Definition DegreeOfFreedom.hpp:402
void setPositionUpperLimit(double _limit)
Set the upper position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:155
std::size_t mIndexInJoint
Index of this DegreeOfFreedom within its Joint.
Definition DegreeOfFreedom.hpp:393
void setConstraintImpulse(double _impulse)
Set the constraint impulse of this generalized coordinate.
Definition DegreeOfFreedom.cpp:415
double getForceLowerLimit() const
Get the lower generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:379
bool isNamePreserved() const
Check whether DegreeOfFreedom::lockName(bool) is activate.
Definition DegreeOfFreedom.cpp:61
void setForceLowerLimit(double _limit)
Set the lower generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:373
void setVelocityLimits(double _lowerLimit, double _upperLimit)
Set the velocity limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:215
double getPositionUpperLimit() const
Get the upper position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:161
void setInitialVelocity(double _initial)
Change the velocity that resetVelocity() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:260
void resetAcceleration()
Set the acceleration of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:284
std::size_t mIndexInSkeleton
Index of this DegreeOfFreedom within its Skeleton.
Definition DegreeOfFreedom.hpp:396
const std::string & setName(const std::string &_name, bool _preserveName=true)
Change the name of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:42
void setPosition(double _position)
Set the position of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:109
void resetVelocityChange()
Set the velocity change of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:409
void setForceUpperLimit(double _limit)
Set the upper generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:385
void setPositionLowerLimit(double _limit)
Set the lower position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:143
void resetVelocity()
Set the velocity of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:209
Definition GenericJoint.hpp:49
class Joint
Definition Joint.hpp:61
class Skeleton
Definition Skeleton.hpp:60
std::shared_ptr< const Skeleton > ConstSkeletonPtr
Definition SmartPointer.hpp:60
std::shared_ptr< Skeleton > SkeletonPtr
Definition SmartPointer.hpp:60
Definition BulletCollisionDetector.cpp:60