33#ifndef DART_DYNAMICS_SIMPLEFRAME_HPP_
34#define DART_DYNAMICS_SIMPLEFRAME_HPP_
59 const std::string& _name =
"simple_frame",
60 const Eigen::Isometry3d& _relativeTransform
61 = Eigen::Isometry3d::Identity());
72 const std::string&
setName(
const std::string& _name)
override;
75 const std::string&
getName()
const override;
87 const Frame& _otherFrame,
89 bool _copyProperties =
true);
93 const Frame* _otherFrame,
95 bool _copyProperties =
true);
106 const std::string&
name =
"SimpleFrame",
107 const Eigen::Isometry3d& relativeTransform
108 = Eigen::Isometry3d::Identity());
127 const Eigen::Isometry3d& _newTransform,
134 const Eigen::Vector3d& _newTranslation,
141 const Eigen::Matrix3d& _newRotation,
168 const Frame* _inCoordinatesOf);
189 const Frame* _inCoordinatesOf);
218 const Eigen::Vector3d& _linearVelocity = Eigen::Vector3d::Zero(),
219 const Eigen::Vector3d& _angularVelocity = Eigen::Vector3d::Zero(),
220 const Eigen::Vector3d& _linearAcceleration = Eigen::Vector3d::Zero(),
221 const Eigen::Vector3d& _angularAcceleration = Eigen::Vector3d::Zero());
241 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
#define DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(class_name)
Definition Memory.hpp:155
std::string * name
Definition SkelParser.cpp:1697
The Detachable class is a special case of the Entity base class.
Definition Entity.hpp:238
The Frame class serves as the backbone of DART's kinematic tree structure.
Definition Frame.hpp:58
static Frame * World()
Definition Frame.cpp:73
Definition ShapeFrame.hpp:192
The SimpleFrame class offers a user-friendly way of creating arbitrary Frames within the kinematic tr...
Definition SimpleFrame.hpp:52
std::shared_ptr< SimpleFrame > clone(Frame *_refFrame=Frame::World()) const
Create a new SimpleFrame with the same world transform, velocity, and acceleration as this one.
Definition SimpleFrame.cpp:101
void setRelativeRotation(const Eigen::Matrix3d &_newRotation)
Set the relative rotation of this SimpleFrame.
Definition SimpleFrame.cpp:176
std::string mName
Name of this SimpleFrame.
Definition SimpleFrame.hpp:225
void copy(const Frame &_otherFrame, Frame *_refFrame=Frame::World(), bool _copyProperties=true)
Make the world transform, world velocity, and world acceleration of this SimpleFrame match another Fr...
Definition SimpleFrame.cpp:107
const Eigen::Vector6d & getRelativeSpatialAcceleration() const override
Get the spatial acceleration of this Frame relative to its parent Frame, in the coordinates of this F...
Definition SimpleFrame.cpp:258
Eigen::Isometry3d mRelativeTf
Relative transform of the SimpleFrame.
Definition SimpleFrame.hpp:228
void setRelativeSpatialVelocity(const Eigen::Vector6d &_newSpatialVelocity)
Set the spatial velocity of this SimpleFrame relative to its parent Frame.
Definition SimpleFrame.cpp:213
void setClassicDerivatives(const Eigen::Vector3d &_linearVelocity=Eigen::Vector3d::Zero(), const Eigen::Vector3d &_angularVelocity=Eigen::Vector3d::Zero(), const Eigen::Vector3d &_linearAcceleration=Eigen::Vector3d::Zero(), const Eigen::Vector3d &_angularAcceleration=Eigen::Vector3d::Zero())
Set the relative velocity and acceleration of this Frame according to classical (non-spatial) relativ...
Definition SimpleFrame.cpp:278
Eigen::Vector6d mRelativeAcceleration
Relative spatial acceleration of the SimpleFrame.
Definition SimpleFrame.hpp:234
void setRelativeTransform(const Eigen::Isometry3d &_newRelTransform)
Set the relative transform of this SimpleFrame.
Definition SimpleFrame.cpp:161
const Eigen::Vector6d & getPrimaryRelativeAcceleration() const override
The Featherstone ABI algorithm exploits a component of the spatial acceleration which we refer to as ...
Definition SimpleFrame.cpp:264
Eigen::Vector6d mPartialAcceleration
Partial Acceleration of this Frame.
Definition SimpleFrame.hpp:237
const std::string & getName() const override
Return the name of this Entity.
Definition SimpleFrame.cpp:95
~SimpleFrame() override
Destructor.
Definition SimpleFrame.cpp:74
void setTransform(const Eigen::Isometry3d &_newTransform, const Frame *_withRespectTo=Frame::World())
Set the transform of this SimpleFrame so that its transform with respect to Frame _withRespectTo is e...
Definition SimpleFrame.cpp:183
std::shared_ptr< SimpleFrame > spawnChildSimpleFrame(const std::string &name="SimpleFrame", const Eigen::Isometry3d &relativeTransform=Eigen::Isometry3d::Identity())
Spawn a child SimpleFrame to this SimpleFrame.
Definition SimpleFrame.cpp:154
const Eigen::Vector6d & getRelativeSpatialVelocity() const override
Get the spatial velocity of this Frame relative to its parent Frame, in its own coordinates.
Definition SimpleFrame.cpp:232
const Eigen::Isometry3d & getRelativeTransform() const override
Get the transform of this Frame with respect to its parent Frame.
Definition SimpleFrame.cpp:207
void setRelativeSpatialAcceleration(const Eigen::Vector6d &_newSpatialAcceleration)
Set the spatial acceleration of this SimpleFrame relative to its parent Frame.
Definition SimpleFrame.cpp:238
void setRotation(const Eigen::Matrix3d &_newRotation, const Frame *_withRespectTo=Frame::World())
Set the rotation of this SimpleFrame so that its rotation with respect to Frame _withRespectTo is equ...
Definition SimpleFrame.cpp:199
const std::string & setName(const std::string &_name) override
Set name.
Definition SimpleFrame.cpp:80
void setTranslation(const Eigen::Vector3d &_newTranslation, const Frame *_withRespectTo=Frame::World())
Set the translation of this SimpleFrame so that its translation with respect to Frame _withRespectTo ...
Definition SimpleFrame.cpp:191
const Eigen::Vector6d & getPartialAcceleration() const override
The Featherstone ABI algorithm exploits a component of the spatial acceleration which we refer to as ...
Definition SimpleFrame.cpp:270
SimpleFrame & operator=(const SimpleFrame &_otherFrame)
Same as copy(const Frame&) except the parent frame of this SimpleFrame is left the same,...
Definition SimpleFrame.cpp:147
void setRelativeTranslation(const Eigen::Vector3d &_newTranslation)
Set the relative translation of this SimpleFrame.
Definition SimpleFrame.cpp:169
Eigen::Vector6d mRelativeVelocity
Relative spatial velocity of the SimpleFrame.
Definition SimpleFrame.hpp:231
Matrix< double, 6, 1 > Vector6d
Definition MathTypes.hpp:49
Definition BulletCollisionDetector.cpp:65