Simbody
Public Member Functions

SimTK::ContactForceGenerator::HertzElliptical Class Reference

This ContactForceGenerator handles contact between non-conforming objects that meet at a point and generate an elliptical contact patch; those generate an EllipticalPointContact tracking object. More...

#include <CompliantContactSubsystem.h>

Inheritance diagram for SimTK::ContactForceGenerator::HertzElliptical:

List of all members.

Public Member Functions

 HertzElliptical ()
virtual ~HertzElliptical ()
virtual void calcContactForce (const State &state, const Contact &overlapping, const SpatialVec &V_S1S2, ContactForce &contactForce) const
 The CompliantContactSubsystem will invoke this method on any active contact pair of the right Contact type for which there is overlapping undeformed geometry.
virtual void calcContactPatch (const State &state, const Contact &overlapping, const SpatialVec &V_S1S2, ContactPatch &patch) const
 The CompliantContactSubsystem will invoke this method in response to a user request for contact patch information; this returns force, potential energy, and power as above but may also require expensive computations that can be avoided in calcContactForce().

Detailed Description

This ContactForceGenerator handles contact between non-conforming objects that meet at a point and generate an elliptical contact patch; those generate an EllipticalPointContact tracking object.

For objects that are known to produce circular contact, use the specialized HertzCircular generator instead.


Constructor & Destructor Documentation

virtual SimTK::ContactForceGenerator::HertzElliptical::~HertzElliptical ( ) [inline, virtual]

Member Function Documentation

virtual void SimTK::ContactForceGenerator::HertzElliptical::calcContactForce ( const State state,
const Contact overlapping,
const SpatialVec V_S1S2,
ContactForce contactForce 
) const [virtual]

The CompliantContactSubsystem will invoke this method on any active contact pair of the right Contact type for which there is overlapping undeformed geometry.

The force generator is expected to calculate a point in space where equal and opposite contact forces should be applied to the two contacting rigid bodies, the potential energy currently stored in this contact, and the power (energy dissipation rate). State should be used for instance info only; use position information from overlapping and velocity information from the supplied arguments. That allows this method to be used as an operator, for example to calculate potential energy when velocities are not yet available.

Implements SimTK::ContactForceGenerator.

virtual void SimTK::ContactForceGenerator::HertzElliptical::calcContactPatch ( const State state,
const Contact overlapping,
const SpatialVec V_S1S2,
ContactPatch patch 
) const [virtual]

The CompliantContactSubsystem will invoke this method in response to a user request for contact patch information; this returns force, potential energy, and power as above but may also require expensive computations that can be avoided in calcContactForce().

Don't use the state for position or velocity information; the only allowed positions are in the Contact object and the velocities are supplied explicitly.

Implements SimTK::ContactForceGenerator.


The documentation for this class was generated from the following file:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines