33#ifndef DART_DYNAMICS_DEGREEOFFREEDOM_HPP_
34#define DART_DYNAMICS_DEGREEOFFREEDOM_HPP_
71 const std::string& _name,
bool _preserveName =
true);
88 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:55
double getDampingCoefficient() const
Get coefficient of damping (viscous friction) force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:462
void resetForce()
Set the generalized force of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:347
void setAccelerationLimits(double _lowerLimit, double _upperLimit)
Set the acceleration limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:289
void setVelocity(double _velocity)
Set the velocity of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:196
void setAccelerationUpperLimit(double _limit)
Set the upper acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:323
bool isCyclic() const
Get whether this DOF is cyclic.
Definition DegreeOfFreedom.cpp:172
void resetPosition()
Set the position of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:178
double getForceUpperLimit() const
Get the upper generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:390
double getPosition() const
Get the position of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:114
void resetConstraintImpulse()
Set the constraint impulse of this generalized coordinate to zero.
Definition DegreeOfFreedom.cpp:426
void setAcceleration(double _acceleration)
Set the acceleration of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:271
BodyNode * getChildBodyNode()
Get the BodyNode downstream of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:504
void setForce(double _force)
Set the generalized force of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:335
double getCoulombFriction() const
Get Coulomb friction force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:474
DegreeOfFreedom(const DegreeOfFreedom &)=delete
void setCoulombFriction(double _friction)
Set Coulomb friction force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:468
std::size_t getIndexInTree() const
Get this DegreeOfFreedom's index within its tree.
Definition DegreeOfFreedom.cpp:72
std::size_t getIndexInSkeleton() const
Get this DegreeOfFreedom's index within its Skeleton.
Definition DegreeOfFreedom.cpp:66
double getForce() const
Get the generalized force of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:341
Joint * getJoint()
Get the Joint that this DegreeOfFreedom belongs to.
Definition DegreeOfFreedom.cpp:480
std::size_t getTreeIndex() const
Get the index of the tree that this DegreeOfFreedom belongs to.
Definition DegreeOfFreedom.cpp:84
std::pair< double, double > getVelocityLimits() const
Get the velocity limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:228
const std::string & getName() const
Get the name of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:48
void resetCommand()
Set the command of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:102
bool hasPositionLimit() const
Get whether the position of this DegreeOfFreedom has limits.
Definition DegreeOfFreedom.cpp:166
std::pair< double, double > getForceLimits() const
Get the generalized force limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:366
std::size_t mIndexInTree
Index of this DegreeOfFreedom within its tree.
Definition DegreeOfFreedom.hpp:398
void setDampingCoefficient(double _coeff)
Set coefficient of damping (viscous friction) force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:456
double getAcceleration() const
Get the acceleration of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:277
void setRestPosition(double _q0)
Set rest position for the spring force of this generalized coordinate.
Definition DegreeOfFreedom.cpp:444
double getRestPosition() const
Get rest position for the spring force of this generalized coordinate.
Definition DegreeOfFreedom.cpp:450
std::size_t getIndexInJoint() const
Get this DegreeOfFreedom's index within its Joint.
Definition DegreeOfFreedom.cpp:78
void setVelocityLowerLimit(double _limit)
Set the lower velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:235
void setAccelerationLowerLimit(double _limit)
Set the lower acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:311
void setSpringStiffness(double _k)
Set stiffness of the spring force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:432
void setCommand(double _command)
Set the command of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:90
double getAccelerationLowerLimit() const
Get the lower acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:317
double getVelocityUpperLimit() const
Get the upper Velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:253
std::pair< double, double > getAccelerationLimits() const
Get the acceleration limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:304
double getVelocityChange() const
Get the velocity change of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:402
double getSpringStiffness() const
Get stiffness of the spring force for this generalized coordinate.
Definition DegreeOfFreedom.cpp:438
void setPositionLimits(double _lowerLimit, double _upperLimit)
Set the position limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:120
void setVelocityUpperLimit(double _limit)
Set the upper velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:247
void setInitialPosition(double _initial)
Change the position that resetPosition() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:184
BodyNode * getParentBodyNode()
Get the BodyNode upstream of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:516
double getInitialVelocity() const
Get the velocity that resetVelocity() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:265
void setForceLimits(double _lowerLimit, double _upperLimit)
Set the generalized force limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:353
double getCommand() const
Get the command of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:96
double getVelocityLowerLimit() const
Get the lower velocity limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:241
double getPositionLowerLimit() const
Get the lower position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:148
std::pair< double, double > getPositionLimits() const
Get the position limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:134
double getAccelerationUpperLimit() const
Get the upper acceleration limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:329
double getConstraintImpulse() const
Get the constraint impulse of this generalized coordinate.
Definition DegreeOfFreedom.cpp:420
void setVelocityChange(double _velocityChange)
Set the velocity change of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:396
double getVelocity() const
Get the velocity of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:202
SkeletonPtr getSkeleton()
Get the Skeleton that this DegreeOfFreedom is inside of.
Definition DegreeOfFreedom.cpp:492
double getInitialPosition() const
Get the position that resetPosition() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:190
Joint * mJoint
The joint that this DegreeOfFreedom belongs to.
Definition DegreeOfFreedom.hpp:401
void setPositionUpperLimit(double _limit)
Set the upper position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:154
std::size_t mIndexInJoint
Index of this DegreeOfFreedom within its Joint.
Definition DegreeOfFreedom.hpp:392
void setConstraintImpulse(double _impulse)
Set the constraint impulse of this generalized coordinate.
Definition DegreeOfFreedom.cpp:414
double getForceLowerLimit() const
Get the lower generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:378
bool isNamePreserved() const
Check whether DegreeOfFreedom::lockName(bool) is activate.
Definition DegreeOfFreedom.cpp:60
void setForceLowerLimit(double _limit)
Set the lower generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:372
void setVelocityLimits(double _lowerLimit, double _upperLimit)
Set the velocity limits of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:214
double getPositionUpperLimit() const
Get the upper position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:160
void setInitialVelocity(double _initial)
Change the velocity that resetVelocity() will give to this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:259
void resetAcceleration()
Set the acceleration of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:283
std::size_t mIndexInSkeleton
Index of this DegreeOfFreedom within its Skeleton.
Definition DegreeOfFreedom.hpp:395
const std::string & setName(const std::string &_name, bool _preserveName=true)
Change the name of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:41
void setPosition(double _position)
Set the position of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:108
void resetVelocityChange()
Set the velocity change of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:408
void setForceUpperLimit(double _limit)
Set the upper generalized force limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:384
void setPositionLowerLimit(double _limit)
Set the lower position limit of this DegreeOfFreedom.
Definition DegreeOfFreedom.cpp:142
void resetVelocity()
Set the velocity of this DegreeOfFreedom to zero.
Definition DegreeOfFreedom.cpp:208
Definition GenericJoint.hpp:48
class Joint
Definition Joint.hpp:60
class Skeleton
Definition Skeleton.hpp:59
std::shared_ptr< const Skeleton > ConstSkeletonPtr
Definition SmartPointer.hpp:60
std::shared_ptr< Skeleton > SkeletonPtr
Definition SmartPointer.hpp:60
Definition BulletCollisionDetector.cpp:65