DART 6.10.1
|
#include <World.hpp>
Public Types | |
using | NameChangedSignal = common::Signal< void(const std::string &_oldName, const std::string &_newName)> |
Public Member Functions | |
World (const std::string &_name="world") | |
Constructor. | |
virtual | ~World () |
Destructor. | |
std::shared_ptr< World > | clone () const |
Create a clone of this World. | |
const std::string & | setName (const std::string &_newName) |
Set the name of this World. | |
const std::string & | getName () const |
Get the name of this World. | |
void | setGravity (const Eigen::Vector3d &_gravity) |
Set gravity. | |
const Eigen::Vector3d & | getGravity () const |
Get gravity. | |
void | setTimeStep (double _timeStep) |
Set time step. | |
double | getTimeStep () const |
Get time step. | |
dynamics::SkeletonPtr | getSkeleton (std::size_t _index) const |
Get the indexed skeleton. | |
dynamics::SkeletonPtr | getSkeleton (const std::string &_name) const |
Find a Skeleton by name. | |
std::size_t | getNumSkeletons () const |
Get the number of skeletons. | |
std::string | addSkeleton (const dynamics::SkeletonPtr &_skeleton) |
Add a skeleton to this world. | |
void | removeSkeleton (const dynamics::SkeletonPtr &_skeleton) |
Remove a skeleton from this world. | |
std::set< dynamics::SkeletonPtr > | removeAllSkeletons () |
Remove all the skeletons in this world, and return a set of shared pointers to them, in case you want to recycle them. | |
bool | hasSkeleton (const dynamics::ConstSkeletonPtr &skeleton) const |
Returns whether this World contains a Skeleton. | |
bool | hasSkeleton (const std::string &skeletonName) const |
Returns whether this World contains a Skeleton named skeletonName . | |
int | getIndex (int _index) const |
Get the dof index for the indexed skeleton. | |
dynamics::SimpleFramePtr | getSimpleFrame (std::size_t _index) const |
Get the indexed Entity. | |
dynamics::SimpleFramePtr | getSimpleFrame (const std::string &_name) const |
Find an Entity by name. | |
std::size_t | getNumSimpleFrames () const |
Get the number of Entities. | |
std::string | addSimpleFrame (const dynamics::SimpleFramePtr &_frame) |
Add an Entity to this world. | |
void | removeSimpleFrame (const dynamics::SimpleFramePtr &_frame) |
Remove a SimpleFrame from this world. | |
std::set< dynamics::SimpleFramePtr > | removeAllSimpleFrames () |
Remove all SimpleFrames in this world, and return a set of shared pointers to them, in case you want to recycle them. | |
bool | checkCollision (bool checkAllCollisions) |
Deprecated. Please use checkCollision(~) instead. | |
bool | checkCollision (const collision::CollisionOption &option=collision::CollisionOption(false, 1u, nullptr), collision::CollisionResult *result=nullptr) |
Perform collision checking with 'option' over all the feasible collision pairs in this World, and the result will be stored 'result'. | |
const collision::CollisionResult & | getLastCollisionResult () const |
Return the collision checking result of the last simulation step. | |
void | reset () |
Reset the time, frame counter and recorded histories. | |
void | step (bool _resetCommand=true) |
Calculate the dynamics and integrate the world for one step. | |
void | setTime (double _time) |
Set current time. | |
double | getTime () const |
Get current time. | |
int | getSimFrames () const |
Get the number of simulated frames. | |
void | setConstraintSolver (constraint::UniqueConstraintSolverPtr solver) |
Sets the constraint solver. | |
constraint::ConstraintSolver * | getConstraintSolver () |
Get the constraint solver. | |
const constraint::ConstraintSolver * | getConstraintSolver () const |
Get the constraint solver. | |
void | bake () |
Bake simulated current state and store it into mRecording. | |
Recording * | getRecording () |
Get recording. | |
Static Public Member Functions | |
template<typename... Args> | |
static WorldPtr | create (Args &&... args) |
Creates World as shared_ptr. | |
static std::shared_ptr< World > | create (const std::string &name="world") |
Creates a World. | |
Public Attributes | |
common::SlotRegister< NameChangedSignal > | onNameChanged |
Protected Member Functions | |
void | handleSkeletonNameChange (const dynamics::ConstMetaSkeletonPtr &_skeleton) |
Register when a Skeleton's name is changed. | |
void | handleSimpleFrameNameChange (const dynamics::Entity *_entity) |
Register when a SimpleFrame's name is changed. | |
void | sendDestructionNotification () const |
Send a destruction notification to all Observers. | |
void | addObserver (Observer *_observer) const |
Add an Observer to the list of Observers. | |
void | removeObserver (Observer *_observer) const |
Remove an Observer from the list of Observers. | |
Protected Attributes | |
std::string | mName |
Name of this World. | |
std::vector< dynamics::SkeletonPtr > | mSkeletons |
Skeletons in this world. | |
std::map< dynamics::ConstMetaSkeletonPtr, dynamics::SkeletonPtr > | mMapForSkeletons |
std::vector< common::Connection > | mNameConnectionsForSkeletons |
Connections for noticing changes in Skeleton names TODO(MXG): Consider putting this functionality into NameManager. | |
dart::common::NameManager< dynamics::SkeletonPtr > | mNameMgrForSkeletons |
NameManager for keeping track of Skeletons. | |
std::vector< dynamics::SimpleFramePtr > | mSimpleFrames |
Entities in this world. | |
std::vector< common::Connection > | mNameConnectionsForSimpleFrames |
Connections for noticing changes in Frame names TODO(MXG): Consider putting this functionality into NameManager. | |
std::map< const dynamics::SimpleFrame *, dynamics::SimpleFramePtr > | mSimpleFrameToShared |
Map from raw SimpleFrame pointers to their shared_ptrs. | |
dart::common::NameManager< dynamics::SimpleFramePtr > | mNameMgrForSimpleFrames |
NameManager for keeping track of Entities. | |
std::vector< int > | mIndices |
The first indeices of each skeleton's dof in mDofs. | |
Eigen::Vector3d | mGravity |
Gravity. | |
double | mTimeStep |
Simulation time step. | |
double | mTime |
Current simulation time. | |
int | mFrame |
Current simulation frame number. | |
std::unique_ptr< constraint::ConstraintSolver > | mConstraintSolver |
Constraint solver. | |
Recording * | mRecording |
NameChangedSignal | mNameChangedSignal |
std::set< Observer * > | mObservers |
List of current Observers. | |
class World
using dart::simulation::World::NameChangedSignal = common::Signal<void( const std::string& _oldName, const std::string& _newName)> |
dart::simulation::World::World | ( | const std::string & | _name = "world" | ) |
Constructor.
|
virtual |
Destructor.
|
protectedinherited |
Add an Observer to the list of Observers.
std::string dart::simulation::World::addSimpleFrame | ( | const dynamics::SimpleFramePtr & | _frame | ) |
Add an Entity to this world.
std::string dart::simulation::World::addSkeleton | ( | const dynamics::SkeletonPtr & | _skeleton | ) |
Add a skeleton to this world.
void dart::simulation::World::bake | ( | ) |
Bake simulated current state and store it into mRecording.
bool dart::simulation::World::checkCollision | ( | bool | checkAllCollisions | ) |
Deprecated. Please use checkCollision(~) instead.
bool dart::simulation::World::checkCollision | ( | const collision::CollisionOption & | option = collision::CollisionOption(false, 1u, nullptr) , |
collision::CollisionResult * | result = nullptr |
||
) |
Perform collision checking with 'option' over all the feasible collision pairs in this World, and the result will be stored 'result'.
If no argument is passed in then it will return just whether there is collision or not without the contact information such as contact point, normal, and penetration depth.
WorldPtr dart::simulation::World::clone | ( | ) | const |
|
static |
Creates World as shared_ptr.
|
static |
Creates a World.
constraint::ConstraintSolver * dart::simulation::World::getConstraintSolver | ( | ) |
Get the constraint solver.
const constraint::ConstraintSolver * dart::simulation::World::getConstraintSolver | ( | ) | const |
Get the constraint solver.
const Eigen::Vector3d & dart::simulation::World::getGravity | ( | ) | const |
Get gravity.
int dart::simulation::World::getIndex | ( | int | _index | ) | const |
Get the dof index for the indexed skeleton.
const collision::CollisionResult & dart::simulation::World::getLastCollisionResult | ( | ) | const |
Return the collision checking result of the last simulation step.
If this world hasn't stepped forward yet, then the result would be empty. Note that this function does not return the collision checking result of World::checkCollision().
const std::string & dart::simulation::World::getName | ( | ) | const |
Get the name of this World.
std::size_t dart::simulation::World::getNumSimpleFrames | ( | ) | const |
Get the number of Entities.
std::size_t dart::simulation::World::getNumSkeletons | ( | ) | const |
Get the number of skeletons.
Recording * dart::simulation::World::getRecording | ( | ) |
Get recording.
int dart::simulation::World::getSimFrames | ( | ) | const |
Get the number of simulated frames.
TODO(MXG): I think the name of this function is much too similar to getSimpleFrame()
dynamics::SimpleFramePtr dart::simulation::World::getSimpleFrame | ( | const std::string & | _name | ) | const |
Find an Entity by name.
dynamics::SimpleFramePtr dart::simulation::World::getSimpleFrame | ( | std::size_t | _index | ) | const |
Get the indexed Entity.
dynamics::SkeletonPtr dart::simulation::World::getSkeleton | ( | const std::string & | _name | ) | const |
Find a Skeleton by name.
[in] | _name | The name of the Skeleton you are looking for. |
dynamics::SkeletonPtr dart::simulation::World::getSkeleton | ( | std::size_t | _index | ) | const |
Get the indexed skeleton.
double dart::simulation::World::getTime | ( | ) | const |
Get current time.
double dart::simulation::World::getTimeStep | ( | ) | const |
Get time step.
|
protected |
Register when a SimpleFrame's name is changed.
|
protected |
Register when a Skeleton's name is changed.
bool dart::simulation::World::hasSkeleton | ( | const dynamics::ConstSkeletonPtr & | skeleton | ) | const |
Returns whether this World contains a Skeleton.
bool dart::simulation::World::hasSkeleton | ( | const std::string & | skeletonName | ) | const |
Returns whether this World contains a Skeleton named skeletonName
.
std::set< dynamics::SimpleFramePtr > dart::simulation::World::removeAllSimpleFrames | ( | ) |
Remove all SimpleFrames in this world, and return a set of shared pointers to them, in case you want to recycle them.
std::set< dynamics::SkeletonPtr > dart::simulation::World::removeAllSkeletons | ( | ) |
Remove all the skeletons in this world, and return a set of shared pointers to them, in case you want to recycle them.
|
protectedinherited |
Remove an Observer from the list of Observers.
void dart::simulation::World::removeSimpleFrame | ( | const dynamics::SimpleFramePtr & | _frame | ) |
Remove a SimpleFrame from this world.
void dart::simulation::World::removeSkeleton | ( | const dynamics::SkeletonPtr & | _skeleton | ) |
Remove a skeleton from this world.
void dart::simulation::World::reset | ( | ) |
Reset the time, frame counter and recorded histories.
|
protectedinherited |
Send a destruction notification to all Observers.
This will cause all Observers to behave as if this Subject has been permanently deleted, so it should only be called when that behavior is desired.
void dart::simulation::World::setConstraintSolver | ( | constraint::UniqueConstraintSolverPtr | solver | ) |
Sets the constraint solver.
Note that the internal properties of solver
will be overwritten by this World.
void dart::simulation::World::setGravity | ( | const Eigen::Vector3d & | _gravity | ) |
Set gravity.
const std::string & dart::simulation::World::setName | ( | const std::string & | _newName | ) |
Set the name of this World.
void dart::simulation::World::setTime | ( | double | _time | ) |
Set current time.
void dart::simulation::World::setTimeStep | ( | double | _timeStep | ) |
Set time step.
void dart::simulation::World::step | ( | bool | _resetCommand = true | ) |
Calculate the dynamics and integrate the world for one step.
[in] | _resetCommand | True if you want to reset to zero the joint command after simulation step. |
|
protected |
Constraint solver.
|
protected |
Current simulation frame number.
|
protected |
Gravity.
|
protected |
The first indeices of each skeleton's dof in mDofs.
For example, if this world has three skeletons and their dof are 6, 1 and 2 then the mIndices goes like this: [0 6 7].
|
protected |
|
protected |
Name of this World.
|
protected |
|
protected |
Connections for noticing changes in Frame names TODO(MXG): Consider putting this functionality into NameManager.
|
protected |
Connections for noticing changes in Skeleton names TODO(MXG): Consider putting this functionality into NameManager.
|
protected |
NameManager for keeping track of Entities.
|
protected |
NameManager for keeping track of Skeletons.
|
mutableprotectedinherited |
List of current Observers.
|
protected |
|
protected |
Entities in this world.
|
protected |
Map from raw SimpleFrame pointers to their shared_ptrs.
|
protected |
Skeletons in this world.
|
protected |
Current simulation time.
|
protected |
Simulation time step.
common::SlotRegister<NameChangedSignal> dart::simulation::World::onNameChanged |