Simbody  3.3
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
SimTK::CompliantContactSubsystem Class Reference

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>

+ Inheritance diagram for SimTK::CompliantContactSubsystem:

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 ContactForcegetContactForce (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 ContactForcegetContactForceById (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 ContactForceGeneratorgetContactForceGenerator (ContactTypeId contact) const
 Return the force generator to be used for a Contact of the indicated type. More...
 
const ContactForceGeneratorgetDefaultForceGenerator () const
 Return the force generator to be used for a Contact type for which no suitable force generator has been registered. More...
 
const ContactTrackerSubsystemgetContactTrackerSubsystem () const
 Get a read-only reference to the ContactTrackerSubsystem associated with this CompliantContactSubsystem. More...
 
const MultibodySystemgetMultibodySystem () 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)
 
GutsupdRep ()
 
const GutsgetRep () const
 
- Public Member Functions inherited from SimTK::Subsystem
 Subsystem ()
 
 Subsystem (const Subsystem &)
 
Subsystemoperator= (const Subsystem &)
 
 ~Subsystem ()
 
const StringgetName () const
 
const StringgetVersion () 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 VectorgetQ (const State &) const
 
const VectorgetU (const State &) const
 
const VectorgetZ (const State &) const
 
const VectorgetQDot (const State &) const
 
const VectorgetUDot (const State &) const
 
const VectorgetZDot (const State &) const
 
const VectorgetQDotDot (const State &) const
 
const VectorgetQErr (const State &) const
 
const VectorgetUErr (const State &) const
 
const VectorgetUDotErr (const State &) const
 
const VectorgetMultipliers (const State &) const
 
const VectorgetEventTriggersByStage (const State &, Stage) const
 
VectorupdQ (State &) const
 
VectorupdU (State &) const
 
VectorupdZ (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
 
VectorupdQDot (const State &) const
 
VectorupdUDot (const State &) const
 
VectorupdZDot (const State &) const
 
VectorupdQDotDot (const State &) const
 
VectorupdQErr (const State &) const
 
VectorupdUErr (const State &) const
 
VectorupdUDotErr (const State &) const
 
VectorupdMultipliers (const State &) const
 
VectorupdEventTriggersByStage (const State &, Stage) const
 
Stage getStage (const State &) const
 
const AbstractValuegetDiscreteVariable (const State &s, DiscreteVariableIndex dx) const
 
Real getDiscreteVarLastUpdateTime (const State &s, DiscreteVariableIndex dx) const
 
CacheEntryIndex getDiscreteVarUpdateIndex (const State &s, DiscreteVariableIndex dx) const
 
const AbstractValuegetDiscreteVarUpdateValue (const State &s, DiscreteVariableIndex dx) const
 
AbstractValueupdDiscreteVarUpdateValue (const State &s, DiscreteVariableIndex dx) const
 
bool isDiscreteVarUpdateValueRealized (const State &s, DiscreteVariableIndex dx) const
 
void markDiscreteVarUpdateValueRealized (const State &s, DiscreteVariableIndex dx) const
 
AbstractValueupdDiscreteVariable (State &, DiscreteVariableIndex) const
 
const AbstractValuegetCacheEntry (const State &, CacheEntryIndex) const
 
AbstractValueupdCacheEntry (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 SystemgetSystem () const
 
SystemupdSystem ()
 
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::GutsgetSubsystemGuts () const
 
Subsystem::GutsupdSubsystemGuts ()
 
void adoptSubsystemGuts (Subsystem::Guts *g)
 
void setSystem (System &, SubsystemIndex)
 
 Subsystem (Subsystem::Guts *g)
 
bool hasGuts () const
 

Detailed Description

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.

Constructor & Destructor Documentation

SimTK::CompliantContactSubsystem::CompliantContactSubsystem ( )
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.

Member Function Documentation

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.

See Also
getDissipatedEnergy(),setDissipatedEnergy(),getTrackDissipatedEnergy()
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.

See Also
getDissipatedEnergy(),setDissipatedEnergy(),setTrackDissipatedEnergy()
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.

See Also
getContactForceById()
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.

See Also
getContactForce(), calcContactPatchDetailsById()
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.

Precondition
state realized to Stage::Velocity
Parameters
[in]stateThe state from whose active contacts we are selecting.
[in]idThe ContactId of the Contact whose patch details are to be returned. This refers to a Contact within the ContactTrackerSubsystem associated with this ContactForceSubsystem.
[out]patchThe 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.
Returns
True if the indicated Contact is currently generating contact forces; false otherwise (in which case patch is also marked invalid).
See Also
getContactForceById()
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.

Precondition
state realized to Stage::Model
Parameters
[in]stateThe State from which to obtain the current value of the dissipated energy.
Returns
The total dissipated energy (a nonnegative scalar).

An error message will be thrown if you call this method without having turned on energy tracking via setTrackDissipatedEnergy().

Note
The Hunt and Crossley dissipation model used by many contact force generators can occasionally detect that a body is being "yanked" out of a contact (this is more likely with very large dissipation coefficients). To track all the energy in that case we would have to allow the surfaces to stick together, which is unreasonable. Instead, some of the energy will be lost to unmodeled effects because the surface is unable to transfer energy back to the bodies and will instead vibrate or ring until the energy is dissipated.
See Also
setTrackDissipatedEnergy(), setDissipatedEnergy()
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.

Precondition
state realized to Stage::Model
Parameters
[in,out]stateThe State whose dissipated energy variable for this subsystem is to be modified.
[in]energyThe 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().

See Also
getDissipatedEnergy(), setTrackDissipatedEnergy()
void SimTK::CompliantContactSubsystem::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.

The subsystem takes over ownership of the generator; don't delete it yourself.

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.


The documentation for this class was generated from the following file: