Simbody
3.3
|
This is a force subsystem that implements a compliant contact model to respond to Contact objects as detected by a ContactTrackerSubsystem. More...
#include <CompliantContactSubsystem.h>
Public Member Functions | |
CompliantContactSubsystem () | |
Default constructor creates an empty handle. More... | |
CompliantContactSubsystem (MultibodySystem &, const ContactTrackerSubsystem &) | |
Add a new CompliantContactSubsystem to the indicated MultibodySystem, specifying the ContactTrackerSubsystem that we will use to obtain the list of ActiveContacts from which we will generate compliant forces. More... | |
Real | getTransitionVelocity () const |
Get the transition velocity (vt) of the friction model. More... | |
void | setTransitionVelocity (Real vt) |
Set the transition velocity (vt) of the friction model. More... | |
Real | getOOTransitionVelocity () const |
Get a precalculated 1/vt to avoid expensive runtime divisions. More... | |
void | setTrackDissipatedEnergy (bool shouldTrack) |
Specify whether to track energy dissipated by contacts. More... | |
bool | getTrackDissipatedEnergy () const |
Obtain the current setting of the "track dissipated energy" flag. More... | |
int | getNumContactForces (const State &state) const |
Determine how many of the active Contacts are currently generating contact forces. More... | |
const ContactForce & | getContactForce (const State &state, int n) const |
For each active Contact, get a reference to the most recently calculated force there; the ContactId that produced this force is available from the referenced ContactForce object. More... | |
const ContactForce & | getContactForceById (const State &state, ContactId id) const |
Get a reference to the ContactForce currently being produced by a particular ContactId; if that Contact is not currently producing forces then a reference to an invalid ContactForce is returned (you can check with isValid()). More... | |
bool | calcContactPatchDetailsById (const State &state, ContactId id, ContactPatch &patch) const |
Calculate detailed information about a particular active contact patch, including deformed geometric information, pressure and friction force distribution, and resultant forces and moments. More... | |
Real | getDissipatedEnergy (const State &state) const |
Obtain the total amount of energy dissipated by all the contact responses that were generated by this subsystem since some arbitrary starting point. More... | |
void | setDissipatedEnergy (State &state, Real energy) const |
Set the accumulated dissipated energy to an arbitrary value. More... | |
void | adoptForceGenerator (ContactForceGenerator *generator) |
Attach a new generator to this subsystem as the responder to be used when we see the kind of Contact type for which this generator is defined, replacing the previous generator for this Contact type if there was one. More... | |
void | adoptDefaultForceGenerator (ContactForceGenerator *generator) |
Attach a new generator to this subsystem as the responder to be used when we see a Contact type for which no suitable generator has been defined, replacing the previous default generator type if there was one. More... | |
bool | hasForceGenerator (ContactTypeId contact) const |
Return true if this subsystem has a force generator registered that can respond to this kind of Contact. More... | |
bool | hasDefaultForceGenerator () const |
Return true if this subsystem has a force generator registered that can be used for response to an unrecognized type of Contact (typically this will be a "do nothing" or "throw an error" generator. More... | |
const ContactForceGenerator & | getContactForceGenerator (ContactTypeId contact) const |
Return the force generator to be used for a Contact of the indicated type. More... | |
const ContactForceGenerator & | getDefaultForceGenerator () const |
Return the force generator to be used for a Contact type for which no suitable force generator has been registered. More... | |
const ContactTrackerSubsystem & | getContactTrackerSubsystem () const |
Get a read-only reference to the ContactTrackerSubsystem associated with this CompliantContactSubsystem. More... | |
const MultibodySystem & | getMultibodySystem () const |
Every Subsystem is owned by a System; a CompliantContactSubsystem expects to be owned by a MultibodySystem. More... | |
Public Member Functions inherited from SimTK::ForceSubsystem | |
ForceSubsystem () | |
SimTK_PIMPL_DOWNCAST (ForceSubsystem, Subsystem) | |
Guts & | updRep () |
const Guts & | getRep () const |
Public Member Functions inherited from SimTK::Subsystem | |
Subsystem () | |
Subsystem (const Subsystem &) | |
Subsystem & | operator= (const Subsystem &) |
~Subsystem () | |
const String & | getName () const |
const String & | getVersion () const |
QIndex | allocateQ (State &, const Vector &qInit) const |
UIndex | allocateU (State &, const Vector &uInit) const |
ZIndex | allocateZ (State &, const Vector &zInit) const |
DiscreteVariableIndex | allocateDiscreteVariable (State &, Stage invalidates, AbstractValue *v) const |
DiscreteVariableIndex | allocateAutoUpdateDiscreteVariable (State &, Stage invalidates, AbstractValue *v, Stage updateDependsOn) const |
CacheEntryIndex | allocateCacheEntry (const State &, Stage dependsOn, Stage computedBy, AbstractValue *v) const |
CacheEntryIndex | allocateCacheEntry (const State &state, Stage g, AbstractValue *v) const |
CacheEntryIndex | allocateLazyCacheEntry (const State &state, Stage earliest, AbstractValue *v) const |
QErrIndex | allocateQErr (const State &, int nqerr) const |
UErrIndex | allocateUErr (const State &, int nuerr) const |
UDotErrIndex | allocateUDotErr (const State &, int nudoterr) const |
EventTriggerByStageIndex | allocateEventTriggersByStage (const State &, Stage, int ntriggers) const |
const Vector & | getQ (const State &) const |
const Vector & | getU (const State &) const |
const Vector & | getZ (const State &) const |
const Vector & | getQDot (const State &) const |
const Vector & | getUDot (const State &) const |
const Vector & | getZDot (const State &) const |
const Vector & | getQDotDot (const State &) const |
const Vector & | getQErr (const State &) const |
const Vector & | getUErr (const State &) const |
const Vector & | getUDotErr (const State &) const |
const Vector & | getMultipliers (const State &) const |
const Vector & | getEventTriggersByStage (const State &, Stage) const |
Vector & | updQ (State &) const |
Vector & | updU (State &) const |
Vector & | updZ (State &) const |
void | setQ (State &s, const Vector &q) const |
void | setU (State &s, const Vector &u) const |
void | setZ (State &s, const Vector &z) const |
Vector & | updQDot (const State &) const |
Vector & | updUDot (const State &) const |
Vector & | updZDot (const State &) const |
Vector & | updQDotDot (const State &) const |
Vector & | updQErr (const State &) const |
Vector & | updUErr (const State &) const |
Vector & | updUDotErr (const State &) const |
Vector & | updMultipliers (const State &) const |
Vector & | updEventTriggersByStage (const State &, Stage) const |
Stage | getStage (const State &) const |
const AbstractValue & | getDiscreteVariable (const State &s, DiscreteVariableIndex dx) const |
Real | getDiscreteVarLastUpdateTime (const State &s, DiscreteVariableIndex dx) const |
CacheEntryIndex | getDiscreteVarUpdateIndex (const State &s, DiscreteVariableIndex dx) const |
const AbstractValue & | getDiscreteVarUpdateValue (const State &s, DiscreteVariableIndex dx) const |
AbstractValue & | updDiscreteVarUpdateValue (const State &s, DiscreteVariableIndex dx) const |
bool | isDiscreteVarUpdateValueRealized (const State &s, DiscreteVariableIndex dx) const |
void | markDiscreteVarUpdateValueRealized (const State &s, DiscreteVariableIndex dx) const |
AbstractValue & | updDiscreteVariable (State &, DiscreteVariableIndex) const |
const AbstractValue & | getCacheEntry (const State &, CacheEntryIndex) const |
AbstractValue & | updCacheEntry (const State &, CacheEntryIndex) const |
bool | isCacheValueRealized (const State &, CacheEntryIndex) const |
void | markCacheValueRealized (const State &, CacheEntryIndex) const |
void | markCacheValueNotRealized (const State &, CacheEntryIndex) const |
SystemQIndex | getQStart (const State &) const |
int | getNQ (const State &) const |
SystemUIndex | getUStart (const State &) const |
int | getNU (const State &) const |
SystemZIndex | getZStart (const State &) const |
int | getNZ (const State &) const |
SystemQErrIndex | getQErrStart (const State &) const |
int | getNQErr (const State &) const |
SystemUErrIndex | getUErrStart (const State &) const |
int | getNUErr (const State &) const |
SystemUDotErrIndex | getUDotErrStart (const State &) const |
int | getNUDotErr (const State &) const |
SystemMultiplierIndex | getMultipliersStart (const State &) const |
int | getNMultipliers (const State &) const |
SystemEventTriggerByStageIndex | getEventTriggerStartByStage (const State &, Stage) const |
int | getNEventTriggersByStage (const State &, Stage) const |
bool | isInSystem () const |
bool | isInSameSystem (const Subsystem &otherSubsystem) const |
const System & | getSystem () const |
System & | updSystem () |
SubsystemIndex | getMySubsystemIndex () const |
bool | isOwnerHandle () const |
bool | isEmptyHandle () const |
bool | isSameSubsystem (const Subsystem &otherSubsystem) const |
bool | subsystemTopologyHasBeenRealized () const |
void | invalidateSubsystemTopologyCache () const |
MeasureIndex | adoptMeasure (AbstractMeasure &) |
AbstractMeasure | getMeasure (MeasureIndex) const |
template<class T > | |
Measure_< T > | getMeasure_ (MeasureIndex mx) const |
const Subsystem::Guts & | getSubsystemGuts () const |
Subsystem::Guts & | updSubsystemGuts () |
void | adoptSubsystemGuts (Subsystem::Guts *g) |
void | setSystem (System &, SubsystemIndex) |
Subsystem (Subsystem::Guts *g) | |
bool | hasGuts () const |
This is a force subsystem that implements a compliant contact model to respond to Contact objects as detected by a ContactTrackerSubsystem.
The subsystem contains an extendable collection of ContactForceGenerator objects, one per type of Contact. For example, a point contact would be handled by a different force generator than would a mesh contact.
|
inline |
Default constructor creates an empty handle.
SimTK::CompliantContactSubsystem::CompliantContactSubsystem | ( | MultibodySystem & | , |
const ContactTrackerSubsystem & | |||
) |
Add a new CompliantContactSubsystem to the indicated MultibodySystem, specifying the ContactTrackerSubsystem that we will use to obtain the list of ActiveContacts from which we will generate compliant forces.
The MultibodySystem takes over ownership of the new subsystem object, but the handle we construct here retains a reference to it.
Real SimTK::CompliantContactSubsystem::getTransitionVelocity | ( | ) | const |
Get the transition velocity (vt) of the friction model.
void SimTK::CompliantContactSubsystem::setTransitionVelocity | ( | Real | vt | ) |
Set the transition velocity (vt) of the friction model.
Real SimTK::CompliantContactSubsystem::getOOTransitionVelocity | ( | ) | const |
Get a precalculated 1/vt to avoid expensive runtime divisions.
void SimTK::CompliantContactSubsystem::setTrackDissipatedEnergy | ( | bool | shouldTrack | ) |
Specify whether to track energy dissipated by contacts.
This permits conservation of energy tests to be performed in the presence of dissipative contact elements. If you enable this, a state variable (z) will be allocated to integrate instantaneous dissipated power. By default energy dissipation is not tracked and an exception is thrown if it is requested. This is a topological change, meaning you'll have to call realizeTopology() and get a new State if you change the setting.
bool SimTK::CompliantContactSubsystem::getTrackDissipatedEnergy | ( | ) | const |
Obtain the current setting of the "track dissipated energy" flag.
You must not call getDissipatedEnergy() or setDissipatedEnergy() if this flag has not been set.
int SimTK::CompliantContactSubsystem::getNumContactForces | ( | const State & | state | ) | const |
Determine how many of the active Contacts are currently generating contact forces.
You can call this at Velocity stage or later; the contact forces will be realized first if necessary before we report how many there are.
const ContactForce& SimTK::CompliantContactSubsystem::getContactForce | ( | const State & | state, |
int | n | ||
) | const |
For each active Contact, get a reference to the most recently calculated force there; the ContactId that produced this force is available from the referenced ContactForce object.
The ContactForce object is measured and expressed in the Ground frame. You can request this response at Velocity stage or later; the contact forces will be realized first if necessary.
const ContactForce& SimTK::CompliantContactSubsystem::getContactForceById | ( | const State & | state, |
ContactId | id | ||
) | const |
Get a reference to the ContactForce currently being produced by a particular ContactId; if that Contact is not currently producing forces then a reference to an invalid ContactForce is returned (you can check with isValid()).
The ContactForce object is measured and expressed in the Ground frame. You can call this at Velocity stage or later; the contact forces (not just this one) will be realized first if necessary.
bool SimTK::CompliantContactSubsystem::calcContactPatchDetailsById | ( | const State & | state, |
ContactId | id, | ||
ContactPatch & | patch | ||
) | const |
Calculate detailed information about a particular active contact patch, including deformed geometric information, pressure and friction force distribution, and resultant forces and moments.
This detailed information is only calculated when requested because it may be expensive for some ContactForceGenerators; for simulation purposes only the resultants are needed. Resultant forces may be obtained cheaply by calling getContactForceById(); don't call this method unless you really need these details. The returned information will overwrite anything that is already in the supplied ContactPatch object; the contact point and vectors are expressed in Ground. You can call this operator at Velocity stage or higher. The result is calculated here and not saved internally.
[in] | state | The state from whose active contacts we are selecting. |
[in] | id | The ContactId of the Contact whose patch details are to be returned. This refers to a Contact within the ContactTrackerSubsystem associated with this ContactForceSubsystem. |
[out] | patch | The object that will be overwritten with the result or set invalid if the given ContactId is not currently producing a patch. Results are returned in the Ground frame. |
Real SimTK::CompliantContactSubsystem::getDissipatedEnergy | ( | const State & | state | ) | const |
Obtain the total amount of energy dissipated by all the contact responses that were generated by this subsystem since some arbitrary starting point.
This information is available only if you have requested tracking by calling setTrackDissipatedEnergy().
This is the time integral of all the power dissipated during any of the contacts by material dissipative and friction forces. For a system whose only non-conservative forces are contacts, the sum of potential, kinetic, and dissipated energies should be conserved with an exception noted below. This is particularly useful for debugging new ContactForceGenerators. This is a State variable so you can obtain its value any time after it is allocated.
[in] | state | The State from which to obtain the current value of the dissipated energy. |
An error message will be thrown if you call this method without having turned on energy tracking via setTrackDissipatedEnergy().
void SimTK::CompliantContactSubsystem::setDissipatedEnergy | ( | State & | state, |
Real | energy | ||
) | const |
Set the accumulated dissipated energy to an arbitrary value.
This is only permitted if you have requested tracking of dissipated energy by calling setTrackDissipatedEnergy().
Typically this method is used only to reset the dissipated energy to zero, but non-zero values can be useful if you are trying to match some existing data or continuing a simulation. This is a State variable so you can set its value any time after it is allocated.
[in,out] | state | The State whose dissipated energy variable for this subsystem is to be modified. |
[in] | energy | The new value for the accumulated dissipated energy (must be a nonnegative scalar). |
An error message will be thrown if you call this method without having turned on energy tracking via setTrackDissipatedEnergy().
void SimTK::CompliantContactSubsystem::adoptForceGenerator | ( | ContactForceGenerator * | generator | ) |
void SimTK::CompliantContactSubsystem::adoptDefaultForceGenerator | ( | ContactForceGenerator * | generator | ) |
Attach a new generator to this subsystem as the responder to be used when we see a Contact type for which no suitable generator has been defined, replacing the previous default generator type if there was one.
The subsystem takes over ownership of the generator; don't delete it yourself.
bool SimTK::CompliantContactSubsystem::hasForceGenerator | ( | ContactTypeId | contact | ) | const |
Return true if this subsystem has a force generator registered that can respond to this kind of Contact.
bool SimTK::CompliantContactSubsystem::hasDefaultForceGenerator | ( | ) | const |
Return true if this subsystem has a force generator registered that can be used for response to an unrecognized type of Contact (typically this will be a "do nothing" or "throw an error" generator.
const ContactForceGenerator& SimTK::CompliantContactSubsystem::getContactForceGenerator | ( | ContactTypeId | contact | ) | const |
Return the force generator to be used for a Contact of the indicated type.
If no generator was registered for this type of contact, this will be the default generator.
const ContactForceGenerator& SimTK::CompliantContactSubsystem::getDefaultForceGenerator | ( | ) | const |
Return the force generator to be used for a Contact type for which no suitable force generator has been registered.
const ContactTrackerSubsystem& SimTK::CompliantContactSubsystem::getContactTrackerSubsystem | ( | ) | const |
Get a read-only reference to the ContactTrackerSubsystem associated with this CompliantContactSubsystem.
This is the contact tracker that is maintaining the list of contacts for which this subsystem will be providing the response forces.
const MultibodySystem& SimTK::CompliantContactSubsystem::getMultibodySystem | ( | ) | const |
Every Subsystem is owned by a System; a CompliantContactSubsystem expects to be owned by a MultibodySystem.
This method returns a const reference to the containing MultibodySystem and will throw an exception if there is no containing System or it is not a MultibodySystem.