SimTK | This is the top-level SimTK namespace into which all SimTK names are placed to avoid collision with other symbols |
Exception | |
APIMethodFailed | |
RepLevelException | |
MobilizerCantExactlyRepresentRequestedQuantity | |
NewtonRaphsonFailure | |
LoopConstraintConstructionFailure | |
Base | |
Assert | This is for reporting internally-detected bugs only, not problems induced by confused users (that is, it is for confused developers instead) |
ErrorCheck | This is for reporting errors occurring during execution of SimTK core methods, beyond those caused by mere improper API arguments, which should be reported with APIArgcheck instead |
APIArgcheckFailed | This is for reporting problems detected by checking the caller's supplied arguments to a SimTK API method |
IndexOutOfRange | |
SizeOutOfRange | |
SizeWasNegative | |
ValueOutOfRange | |
ValueWasNegative | |
UnimplementedMethod | |
UnimplementedVirtualMethod | |
IncompatibleValues | |
OperationNotAllowedOnView | |
OperationNotAllowedOnOwner | |
OperationNotAllowedOnNonconstReadOnlyView | |
Cant | |
RealizeTopologyMustBeCalledFirst | |
StateAndSystemTopologyVersionsMustMatch | |
StageTooLow | |
StageIsWrong | |
StageTooHigh | |
StageOutOfRange | |
CacheEntryOutOfDate | |
RealizeCheckFailed | |
OptimizerFailed | |
UnrecognizedParameter | |
IllegalLapackArg | |
IncorrectArrayLength | |
SingularMatrix | |
ConvergedFailed | |
NotPositiveDefinite | |
Impl | |
Assembler | This Study attempts to find a configuration (set of joint coordinates q) of a Simbody MultibodySystem that satisfies the System's position Constraints plus optional additional assembly conditions |
AssemblyCondition | Define an assembly condition consisting of a scalar goal and/or a related set of assembly error equations (that is, an objective and/or some constraints) |
QValue | This AssemblyCondition requests that a particular generalized coordinate end up with a specified value |
Markers | This AssemblyCondition specifies a correspondence between stations on mobilized bodies ("markers") and fixed ground-frame locations ("observations") |
Body | Reference frame that can be used to describe mass properties and geometry |
Ground | This is a Body representing something immobile, of effectively infinite mass and inertia, that cannot be modified to be anything else |
Linear | This is a rigid body in the shape of a line, which is inherently inertialess about its axis |
Massless | This is a Body that is constitutively massless (and inertialess); meaning that no amount of fiddling with it will ever give it any mass or inertia |
Particle | This kind of body can only represent an inertialess point mass, with mass center at (0,0,0) in the local frame |
Rigid | A general rigid body |
CablePath | This class represents the path of a frictionless cable from an origin point fixed to a body, through via points and over geometric obstacles fixed to other bodies, to a final termination point |
CableObstacle | An obstacle is any significant object along the cable path – one of the end points, a via point, or a surface |
Surface | This obstacle is a solid object represented by a ContactGeometry surface |
ViaPoint | This is a point through which the cable must pass |
CableSpring | This force element implements a passive elastic element (like a rubber band) that follows a frictionless CablePath across a set of "obstacles" |
CableTrackerSubsystem | This subsystem tracks the paths of massless, frictionless cables that take the shortest route between two distant points of a multibody system, passing smoothly over geometric obstacles that are attached to intermediate bodies |
CompliantContactSubsystem | This is a force subsystem that implements a compliant contact model to respond to Contact objects as detected by a ContactTrackerSubsystem |
ContactForce | This is a simple class containing the basic force information for a single contact between deformable surfaces S1 and S2 mounted on rigid bodies B1 and B2 |
ContactDetail | This provides deformed geometry and force details for one element of a contact patch that may be composed of many elements |
ContactPatch | A ContactPatch is the description of the forces and the deformed shape of the contact surfaces that result from compliant contact interactions |
ContactForceGenerator | A ContactForceGenerator implements an algorithm for responding to overlaps or potential overlaps between pairs of ContactSurface objects, as detected by a ContactTrackerSubsystem |
DoNothing | This ContactForceGenerator silently does nothing |
ElasticFoundation | This ContactForceGenerator handles contact between a TriangleMesh and a variety of other geometric objects, all of which produce a TriangleMeshContact tracking object |
HertzCircular | This ContactForceGenerator handles contact between non-conforming objects that meet at a point and generate a circular contact patch; those generate a CircularPointContact tracking object |
HertzElliptical | 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 |
ThrowError | This ContactForceGenerator throws an error if it is every invoked |
Constraint | This is the base class for all Constraint classes, which is just a handle for the underlying hidden implementation |
Ball | Enforce that a fixed station on one body remains coincident with a fixed station on a second body, as though there were a ball joint connecting them at those points |
BallRollingOnPlane | This constraint enforces continuous contact and non-slip rolling between a spherical surface fixed on one body and a half space (flat surface) fixed on another |
ConstantAcceleration | Constrain a single mobility to have a particular acceleration |
ConstantAngle | This constraint consists of a single constraint equation that enforces that a unit vector v1 fixed to one body (the "base body") must maintain a fixed angle theta with respect to a unit vector v2 fixed on the other body (the "follower body") |
ConstantOrientation | Three constraint equations |
ConstantSpeed | Constrain a single mobility to have a particular speed |
CoordinateCoupler | This is a Constraint that uses a Function object to define a single holonomic (position) constraint equation acting to relate a set of generalized coordinates q |
Custom | The handle class Constraint::Custom (dataless) and its companion class Constraint::Custom::Implementation can be used together to define new Constraint types with arbitrary properties |
Implementation | This is the abstract base class for the implementation of custom constraints. See Constraint::Custom for more information |
NoSlip1D | One non-holonomic constraint equation |
PointInPlane | One constraint equation |
PointOnLine | Two constraint equations |
PrescribedMotion | This is a Constraint that uses a Function to prescribe the behavior of a single generalized coordinate as a function of time |
Rod | This constraint consists of one constraint equation that enforces a constant distance between a point on one body and a point on another body |
SpeedCoupler | This is a Constraint that uses a Function object to define a nonholonomic (velocity) constraint |
Weld | Six constraint equations |
ContactMaterial | Define the physical properties of the material from which a contact surface is made, including properties needed by a variety of contact response techniques that might be applied during contact |
ContactSurface | This class combines a piece of ContactGeometry with a ContactMaterial to make an object suitable for attaching to a body which can then engage in contact behavior with other contact surfaces |
ContactTrackerSubsystem | This subsystem identifies and tracks potential contacts between bodies of a multibody system, but does not generate any physical responses to those contacts |
ContactSnapshot | Objects of this class represent collections of surface-pair interactions that are being tracked at a particular instant during a simulation |
DecorationSubsystem | This is the client-side handle class encapsulating the hidden implementation of the DecorationSubsystem |
ElasticFoundationForce | This class implements an elastic foundation or "bed of springs" contact model |
Force | This is the base class from which all Force element handle classes derive |
ConstantForce | A constant force applied to a body station |
ConstantTorque | A constant torque to a body |
Custom | This class is used to define new force elements |
Implementation | Every custom force requires implementation of a class that is derived from this abstract class. See Force::Custom for details |
DiscreteForces | Arbitrary discrete body forces and mobility (generalized) forces. Useful for applying external forces or forces that are updated at discrete times due to the occurrence of events |
GlobalDamper | A general energy "drain" on the system |
Gravity | This force element represents a uniform gravitational field applied to a set of bodies |
LinearBushing | This force element represents a bushing acting to connect a frame F fixed on one body (B1) to a frame M fixed on a second body (B2), by a massless, compliant element with linear stiffness and damping properties |
MobilityConstantForce | A constant generalized force f (a scalar) applied to a mobility |
MobilityDiscreteForce | A discrete mobility (generalized) force f applied to a particular mobility that is specified at construction. Useful for applying external forces or forces that are updated at discrete times due to the occurrence of events |
MobilityLinearDamper | A linear damper that acts along or around a mobility coordinate to apply a generalized force there |
MobilityLinearSpring | A linear spring that acts along or around a mobility coordinate to apply a generalized force there |
MobilityLinearStop | Model a compliant stop element that acts to keep a mobilizer coordinate q within specified bounds |
Thermostat | This is a feedback-controlled force that uses Nose'-Hoover chains to maintain a particular temperature Tb, as though the system were immersed in an infinite heat bath at that temperature |
TwoPointConstantForce | A constant force f (a signed scalar) which acts along the line between two points, specified as a station on each of two bodies |
TwoPointLinearDamper | A force which resists changes in the distance between two points, acting along the line between those points |
TwoPointLinearSpring | A linear spring between two points, specified as a station on each of two bodies |
UniformGravity | A uniform gravitational force applied to every body in the system. See Force::Gravity for a more flexible option |
ForceSubsystem | This is logically an abstract class, more specialized than "Subsystem" but not yet concrete |
Guts | Public declaration of internals for ForceSubsystem extension |
GeneralContactSubsystem | This class performs collision detection for use in contact modeling |
GeneralForceSubsystem | This is a concrete subsystem which can apply arbitrary forces to a MultibodySystem |
HuntCrossleyContact | This is a concrete subsystem that handles simple, frictionless contact situations with a model due to Hunt & Crossley: K |
HuntCrossleyForce | This class models the forces generated by simple point contacts, such as between two spheres, or a sphere and a half space |
LocalEnergyMinimizer | This class performs local potential energy minimization of a MultibodySystem |
MobilizedBody | A MobilizedBody is Simbody's fundamental body-and-joint object used to parameterize a system's motion by constructing a multibody tree containing each body and its unique "mobilizer" (internal coordinate joint) |
Ball | Three mobilities – unrestricted orientation modeled with a quaternion which is never singular |
BendStretch | Two mobilities: The z axis of the parent's F frame is used for rotation (and that is always aligned with the M frame z axis) |
Bushing | Six mobilities – arbitrary relative motion modeled as x-y-z translation followed by an x-y-z body-fixed Euler angle sequence, though with a singularity when the middle angle is +/- 90 degrees |
Custom | The handle class MobilizedBody::Custom (dataless) and its companion class MobilizedBody::Custom::Implementation can be used together to define new MobilizedBody types with arbitrary properties |
Implementation | This is the implementation class for Custom mobilizers |
Cylinder | Two mobilities – rotation and translation along the common z axis of the inboard and outboard mobilizer frames |
Ellipsoid | Three mobilities – coordinated rotation and translation along the surface of an ellipsoid fixed to the parent (inboard) body |
Free | Unrestricted motion for a rigid body (six mobilities) |
FreeLine | Five mobilities, representing unrestricted motion for a body which is inertialess along its own z axis |
FunctionBased | This is a subclass of MobilizedBody::Custom which uses a set of Function objects to define the behavior of the MobilizedBody |
Gimbal | Three mobilities – unrestricted orientation modeled as a 1-2-3 body-fixed Euler angle sequence, though with a singularity when the middle angle is +/- 90 degrees |
Ground | This is a special type of "mobilized" body generated automatically by Simbody as a placeholder for Ground in the 0th slot for a SimbodyMatterSubsystem's mobilized bodies; don't create this yourself |
LineOrientation | Two mobilities, representing unrestricted orientation for a body which is inertialess along its own z axis |
Pin | Provides one rotational mobility about the common z axis of the F and M frames of the mobilizer |
Planar | Three mobilities – z rotation and x,y translation |
Screw | One mobility – coordinated rotation and translation along the common z axis of the inboard and outboard mobilizer frames |
Slider | One mobility – translation along the common x axis of the F (inboard) and M (outboard) mobilizer frames |
SphericalCoords | Three mobilities – body fixed 3-2 (z-y) rotation followed by translation along body z or body x |
Translation | Three translational mobilities describing the Cartesian motion of a point |
Universal | Two mobilities – rotation about the x axis, followed by a rotation about the new y axis |
Weld | Zero mobilities |
Motion | A Motion object belongs to a particular MobilizedBody and prescribes how the associated motion is to be calculated |
Custom | This class can be used to define new motions |
Implementation | This is the abstract base class for Custom Motion implementations |
Sinusoid | Prescribe position, velocity, or acceleration motion as a sinusoidal function of time, m(t) = a * sin( w*t + p ) |
Steady | This non-holonomic Motion object imposes a constant rate on all mobilities |
MultibodySystem | The job of the MultibodySystem class is to coordinate the activities of various subsystems which can be part of a multibody system |
ObservedPointFitter | This class attempts to find the configuration of an internal coordinate model which best fits a set of observed data |
SimbodyMatterSubsystem | This subsystem contains the bodies ("matter") in the multibody system, the mobilizers (joints) that define the generalized coordinates used to represent the motion of those bodies, and constraints that must be satisfied by the values of those coordinates |
SimbodyMatterSubtree | A SimbodyMatterSubtree is a view of a connected subgraph of the tree of mobilized bodies in a SimbodyMatterSubsystem |
SimbodyMatterSubtreeResults | |
TextDataEventReporter | This is an EventReporter which prints out numeric data at regular intervals in tabular form |
UserFunction | This template class defines a standard interface for objects that calculate a function based on a System and State for use in a TextDataEventReporter |
Visualizer | Provide simple visualization of and interaction with a Simbody simulation, with real time control of the frame rate. There are several operating modes available, including real time operation permitting responsive user interaction with the simulation |
FrameController | This abstract class represents an object that will be invoked by the Visualizer just prior to rendering each frame |
InputListener | This abstract class defines methods to be called when the Visualizer reports user activity back to the simulation process. Derive a concrete event listener whose methods take appropriate actions when event of interest occur |
InputSilo | This pre-built InputListener is extremely useful for processing user input that is intended to affect a running simulation |
Reporter | This is an EventReporter that makes it easy to generate on-screen movies of any simulation |
MatrixBase | Variable-size 2d matrix of Composite Numerical Type (ELT) elements |
EltResult | |
VectorBase | This is a dataless rehash of the MatrixBase class to specialize it for Vectors |
EltResult | |
RowVectorBase | This is a dataless rehash of the MatrixBase class to specialize it for RowVectors |
EltResult | |
MatrixView_ | This class is identical to a Matrix_; it is used only to manage the C++ rules for when copy constructors are called by introducing a separate type to prevent certain allowed optimizations from occuring when we don't want them |
DeadMatrixView_ | This is a MatrixView_ with the additional property that we are about to delete it |
Matrix_ | This is the Matrix class intended to appear in user code |
DeadMatrix_ | |
VectorView_ | This class is identical to a Vector_; it is used only to manage the C++ rules for when copy constructors are called by introducing a separate type to prevent certain allowed optimizations from occuring when we don't want them |
DeadVectorView_ | |
Vector_ | This is the Vector class intended to appear in user code |
DeadVector_ | |
RowVectorView_ | This class is identical to a RowVector_; it is used only to manage the C++ rules for when copy constructors are called by introducing a separate type to prevent certain allowed optimizations from occuring when we don't want them |
DeadRowVectorView_ | |
RowVector_ | RowVectors are much less common than Vectors |
DeadRowVector_ | |
VectorIterator | This is an iterator for iterating over the elements of a Vector |
MatrixStructure | Matrix "structure" refers to an inherent mathematical (or at least algorithmic) characteristic of the matrix rather than a storage strategy |
Mask | |
MatrixStorage | Matrix "storage" refers to the physical layout of data in the computer’s memory |
Mask | Use this class to represent sets of acceptable values for each of the storage attributes (packing, position, order, diagonal) |
MatrixOutline | Matrix "outline" refers to the characteristic relationship between the number of rows and columns of a matrix, without necessarily specifying the absolute dimensions |
Mask | |
MatrixCondition | Matrix "condition" is a statement about the numerical characteristics of a Matrix |
Mask | Use this class to represent a set of acceptable Condition values |
MatrixCharacter | A MatrixCharacter is a set containing a value for each of the matrix characteristics except element type, which is part of the templatized declaration of a Matrix, Vector, or RowVector handle |
LapackFull | Predefined MatrixCharacter for an ordinary Lapack-style full matrix of a particular dimension m x n (nrows X ncols) |
Mask | This class collects masks of each characteristic type for representing sets of accceptable characteristics |
RowVector | Predefined MatrixCharacter for an ordinary row vector of a particular size |
Vector | Predefined MatrixCharacter for an ordinary column vector of a particular size |
MatrixCommitment | A MatrixCommitment provides a set of acceptable matrix characteristics |
Hermitian | This is the default commitment for a Hermitian (*not* symmetric) matrix |
RowVector | This is the default commitment for a row vector |
SkewHermitian | This is the default commitment for a skew Hermitian (*not* skew symmetric) matrix |
SkewSymmetric | This is the default commitment for skew symmetric (*not* skew Hermitian) matrix |
Symmetric | This is the default commitment for a symmetric (*not* Hermitian) matrix |
Triangular | This is the default commitment for a triangular matrix |
Vector | This is the default commitment for a column vector |
MatrixHelperRep | |
MatrixHelper | Here we define class MatrixHelper<S>, the scalar-type templatized helper class for the more general, composite numerical type-templatized class MatrixBase<ELT> |
DeepCopy | |
DiagonalView | |
ShallowCopy | |
TransposeView | |
DecorationGenerator | A DecorationGenerator is used to define geometry that may change over the course of a simulation |
DecorativeGeometry | This is the client-side interface to an implementation-independent representation of "Decorations" suitable for visualization, annotation, logging, or debugging but which cannot have any effect on the behavior of a System or the evolution of a Study |
DecorativePoint | A point of interest |
DecorativeLine | A line between two points |
DecorativeCircle | This defines a circle in the x-y plane, centered at the origin |
DecorativeSphere | This defines a sphere centered at the origin |
DecorativeEllipsoid | This defines an ellipsoidal solid centered at the origin and aligned with the local frame axes |
DecorativeBrick | This defines a rectangular solid centered at the origin and aligned with the local frame axes |
DecorativeCylinder | This defines a cylinder centered on the origin and aligned in the y direction |
DecorativeFrame | This defines geometry to represent a coordinate frame |
DecorativeText | This defines a text label with its base at the origin |
DecorativeMesh | This defines a displayable mesh by referencing an already-existing PolygonalMesh object |
Decorations | This defines a single DecorativeGeometry object that is composed of a collection of other DecorativeGeometry objects |
DecorativeGeometryImplementation | Use this abstract class to connect your implementation of decorative geometry to the implementation-independent classes above |
PolygonalMesh | This class provides a description of a mesh made of polygonal faces (not limited to triangles) |
ArrayIndexTraits | This templatized type is used by the Array_<T,X> classes to obtain the information they need to use the class X as an index class for the array |
ArrayViewConst_ | This Array_ helper class is the base class for ArrayView_ which is the base class for Array_; here we provide only the minimal read-only "const" functionality required by any Array_ object, and shallow copy semantics |
ArrayView_ | This Array_ helper class is the base class for Array_, extending ArrayViewConst_ to add the ability to modify elements, but not the ability to change size or reallocate |
Array_ | The SimTK::Array_<T> container class is a plug-compatible replacement for the C++ standard template library (STL) std::vector<T> class, but with some important advantages in performance, and functionality, and binary compatibility |
ArrayIndexTraits< unsigned > | Specialization of ArrayIndexTraits for unsigned (that is, unsigned int ) used as an index |
ArrayIndexTraits< int > | Specialization of ArrayIndexTraits for (signed) int used as an index |
ArrayIndexTraits< unsigned long > | Specialization of ArrayIndexTraits for unsigned long used as an index |
ArrayIndexTraits< long > | Specialization of ArrayIndexTraits for (signed) long used as an index |
ArrayIndexTraits< unsigned short > | Specialization of ArrayIndexTraits for unsigned short used as an index |
ArrayIndexTraits< short > | Specialization of ArrayIndexTraits for (signed) short used as an index |
ArrayIndexTraits< unsigned char > | Specialization of ArrayIndexTraits for unsigned char used as an index |
ArrayIndexTraits< signed char > | Specialization of ArrayIndexTraits for signed char used as an index |
ArrayIndexTraits< char > | Specialization of ArrayIndexTraits for char used as an index |
ArrayIndexTraits< bool > | Specialization of ArrayIndexTraits for bool used as an index |
ArrayIndexTraits< unsigned long long > | Specialization of ArrayIndexTraits for unsigned long long used as an index |
ArrayIndexTraits< long long > | Specialization of ArrayIndexTraits for long long used as an index |
AtomicInteger | This class functions exactly like an int, except that the following operators are atomic: ++, –, +=, -=, *=, /=, %=, &=, |=, ^=, <<=, and >>= |
ClonePtr | Wrap a pointer to an abstract base class in a way that makes it behave like a concrete class |
Function_ | This abstract class represents a mathematical function that calculates a value of arbitrary type based on M real arguments |
Constant | This is a Function_ subclass which simply returns a fixed value, independent of its arguments |
Linear | This is a Function_ subclass whose output value is a linear function of its arguments: f(x, y, ...) = ax+by+...+c |
Polynomial | This is a Function_ subclass whose output value is a polynomial of its argument: f(x) = ax^n+bx^(n-1)+...+c |
Sinusoid | This is a Function_ subclass whose output value is a sinusoid of its argument: f(x) = a*sin(w*x + p) where a is amplitude, w is frequency in radians per unit of x, p is phase in radians |
Step | This is a Function_ subclass whose output value y=f(x) is smoothly stepped from y=y0 to y1 as its input argument goes from x=x0 to x1 |
Parallel2DExecutor | This class is used for performing multithreaded computations over two dimensional ranges |
Task | Concrete subclasses of this abstract class represent tasks that can be executed by a Parallel2DExecutor |
ParallelExecutor | This class is used for performing multithreaded computations |
Task | Concrete subclasses of this abstract class represent tasks that can be executed by a ParallelExecutor |
ParallelWorkQueue | This class is used for performing multithreaded computations. It maintains a queue of tasks to be executed, and a pool of threads for executing them |
Task | Concrete subclasses of this abstract class represent tasks that can be executed by a ParallelWorkQueue |
Pathname | This class encapsulates the handling of file and directory pathnames in a platform-independent manner |
Plugin | This is the base class for representing a runtime-linked dynamic library, also known as a "plugin", in a platform-independent manner |
PIMPLHandle | This class provides some infrastructure useful in making SimTK Private Implementation (PIMPL) classes |
PIMPLImplementation | This class provides some infrastructure useful in creating PIMPL Implementation classes (the ones referred to by Handles) |
ReferencePtr | This is a smart pointer that implements "cross reference" semantics where a pointer data member of some object is intended to refer to some target object in a larger data structure |
StableArray | StableArray<T> is like std::vector<T> (or SimTK::Array_<T>) but more stable in two ways: |
negator | Negator<N>, where N is a number type (real, complex, conjugate), is represented in memory identically to N, but behaves as though multiplied by -1, though at zero cost |
Result | |
Substitute | |
conjugate | SimTK::conjugate<R> should be instantiated only for float, double, long double |
String | SimTK::String is a plug-compatible std::string replacement (plus some additional functionality) intended to be suitable for passing through the SimTK API without introducing binary compatibility problems the way std::string does, especially on Windows |
ThreadLocal | This class represents a "thread local" variable: one which has a different value on each thread |
AbstractValue | Abstract base class representing an arbitrary value of self-describing type |
Value | Templatized version of the abstract class, providing generic type-specific functionality that does not require specialization, with automatic conversion to the underlying type |
Xml | This class provides a minimalist capability for reading and writing XML documents, as files or strings |
Attribute | Elements can have attributes, which are name="value" pairs that appear within the element start tag in an XML document; this class represents the in-memory representation of one of those attributes and can be used to examine or modify the name or value |
attribute_iterator | This is a bidirectional iterator suitable for moving forward or backward within a list of Attributes within an Element, for writable access |
Comment | A comment contains only uninterpreted text |
Element | An element has (1) a tagword, (2) a map of (name,value) pairs called attributes, and (3) a list of child nodes |
element_iterator | This is a bidirectional iterator suitable for moving forward or backward within a list of Element nodes, for writable access |
Node | Abstract handle for holding any kind of node in an XML tree |
node_iterator | This is a bidirectional iterator suitable for moving forward or backward within a list of Nodes, for writable access |
Text | This is the "leaf" content of an element |
Unknown | This is something we don't understand but can carry around |
Lapack | |
Test | This is the main class to support testing |
Subtest | Internal utility class for generating test messages for subtests |
CoordinateAxis | This class, along with its sister class CoordinateDirection, provides convenient manipulation of the three coordinate axes via the definition of three constants XAxis, YAxis, and ZAxis each with a unique subtype and implicit conversion to the integers 0, 1, and 2 whenever necessary. Methods are provided to allow code to be written once that can be used to work with the axes in any order |
XCoordinateAxis | |
YCoordinateAxis | |
ZCoordinateAxis | |
CoordinateDirection | A CoordinateDirection is a CoordinateAxis plus a direction indicating the positive or negative direction along that axis |
Negative | Use for compile-time construction of a negative CoordinateDirection along one of the coordinate axes |
NegXDirection | |
NegYDirection | |
NegZDirection | |
UnitInertia_ | A UnitInertia matrix is a unit-mass inertia matrix; you can convert it to an Inertia by multiplying it by the actual body mass |
Inertia_ | The physical meaning of an inertia is the distribution of a rigid body's mass about a particular point |
SpatialInertia_ | A spatial inertia contains the mass, center of mass point, and inertia matrix for a rigid body |
ArticulatedInertia_ | An articulated body inertia (ABI) matrix P(q) contains the spatial inertia properties that a body appears to have when it is the free base body of an articulated multibody tree in a given configuration q |
MassProperties_ | This class contains the mass, center of mass, and unit inertia matrix of a rigid body B |
Rotation_ | The Rotation class is a Mat33 that guarantees that the matrix is a legitimate 3x3 array associated with the relative orientation of two right-handed, orthogonal, unit vector bases |
Quaternion_ | A Quaternion is a Vec4 with the following behavior: |
InverseRotation_ | ----------------------------------------------------------------------------- This InverseRotation class is the inverse of a Rotation See the Rotation class for information |
PhiMatrix | |
PhiMatrixTranspose | |
Transform_ | This class represents the rotate-and-shift transform which gives the location and orientation of a new frame F in a base (reference) frame B |
InverseTransform_ | Transform from frame B to frame F, but with the internal representation inverted |
UnitVec | This class is a Vec3 plus an ironclad guarantee either that: |
UnitRow | This type is used for the transpose of UnitVec, and as the returned row type of a Rotation |
PolynomialRootFinder | This class provides static methods for finding the roots of polynomials |
ZeroLeadingCoefficient | This is an exception which is thrown by all of the PolynomialRootFinder::findRoots() methods |
Random | This class defines the interface for pseudo-random number generators |
Gaussian | This is a subclass of Random that generates numbers according to a Gaussian distribution with a specified mean and standard deviation |
Uniform | This is a subclass of Random that generates numbers uniformly distributed within a specified range |
CNT | Specialized information about Composite Numerical Types which allows us to define appropriate templatized classes using them |
Result | |
Substitute | |
Wider | |
Wider< float, float > | |
Wider< float, double > | |
Wider< double, float > | |
Wider< double, double > | |
Wider< float, long double > | |
Wider< double, long double > | |
Wider< long double, float > | |
Wider< long double, double > | |
Wider< long double, long double > | |
conjugate< float > | |
conjugate< double > | |
conjugate< long double > | |
NTraits | |
Widest | This class is specialized for all 36 combinations of standard types (that is, real and complex types in each of three precisions) and has typedefs "Type" which is the appropriate "widened" type for use when R1 & R2 appear in an operation together, and "Precision" which is the wider precision (float,double,long double) |
Widest< float, float > | |
Widest< float, double > | |
Widest< float, long double > | |
Widest< double, float > | |
Widest< double, double > | |
Widest< double, long double > | |
Widest< long double, float > | |
Widest< long double, double > | |
Widest< long double, long double > | |
Widest< complex< R1 >, complex< R2 > > | |
Widest< complex< R1 >, R2 > | |
Widest< R1, complex< R2 > > | |
Narrowest | This class is specialized for all 36 combinations of standard types (that is, real and complex types in each of three precisions) and has typedefs "Type" which is the appropriate "narrowed" type for use when R1 & R2 appear in an operation together where the result must be of the narrower precision, and "Precision" which is the expected precision of the result (float, double, long double) |
Narrowest< float, float > | |
Narrowest< float, double > | |
Narrowest< float, long double > | |
Narrowest< double, float > | |
Narrowest< double, double > | |
Narrowest< double, long double > | |
Narrowest< long double, float > | |
Narrowest< long double, double > | |
Narrowest< long double, long double > | |
Narrowest< complex< R1 >, complex< R2 > > | |
Narrowest< complex< R1 >, R2 > | |
Narrowest< R1, complex< R2 > > | |
RTraits | RTraits is a helper class for NTraits |
RTraits< float > | |
RTraits< double > | |
RTraits< long double > | |
NTraits< complex< R > > | Partial specialization for complex numbers – underlying real R is still a template parameter |
Result | |
Substitute | |
NTraits< conjugate< R > > | |
Result | |
Substitute | |
CNT< complex< R > > | Specializations of CNT for numeric types |
CNT< conjugate< R > > | |
CNT< float > | |
CNT< double > | |
CNT< long double > | |
Event | An Event is "something that happens" during a Study that is advancing through time |
Cause | These are all the possible causes for events |
EventTriggerInfo | This class is used to communicate between the System and an Integrator regarding the properties of a particular event trigger function |
HandleEventsOptions | Options for the handleEvent() method |
HandleEventsResults | Results returned by the handleEvent() method |
EventHandler | An EventHandler is an object that defines an event that can occur within a system |
ScheduledEventHandler | ScheduledEventHandler is a subclass of EventHandler for events that occur at a particular time that is known in advance |
TriggeredEventHandler | TriggeredEventHandler is a subclass of EventHandler for events that occur when some condition is satisfied within the system |
PeriodicEventHandler | PeriodicEventHandler is a subclass of ScheduledEventHandler which generates a series of uniformly spaced events at regular intervals |
EventReporter | An EventReporter is an object that defines an event that can occur within a system |
ScheduledEventReporter | ScheduledEventReporter is a subclass of EventReporter for events that occur at a particular time that is known in advance |
TriggeredEventReporter | TriggeredEventReporter is a subclass of EventReporter for events that occur when some condition is satisfied within the system |
PeriodicEventReporter | PeriodicEventReporter is a subclass of ScheduledEventReporter which generates a series of uniformly spaced events at regular intervals |
AbstractMeasure | This is the base class for all Measure handle classes |
Implementation | The abstract parent of all Measure Implementation classes |
SetHandle | An object of this type is used as a dummy argument to make sure the automatically-generated handle constructor's signature doesn't conflict with an explicitly-defined one |
Measure_ | This is the base handle class for all Measures whose value type is known, including all the Simbody built-in Measure types |
Constant | This creates a Measure whose value is a Topology-stage constant of any type T |
Implementation | |
Delay | (CAUTION: still under development) This is a Measure whose value at time t is the value that its source operand had at time t-delay for a specified delay |
Implementation | |
Differentiate | This Measure operator returns the time derivative of its operand measure, or a numerical approximation of the time derivative if an analytic one is not available |
Implementation | |
Extreme | This Measure tracks extreme values attained by the elements of its source operand since the last initialize() call or explicit call to setValue() |
Implementation | |
Implementation | This is the base Implementation class for all Measures whose value type is known |
Integrate | This measure yields the time integral of a given derivative measure, initializing with an initial condition measure of the same type T |
Implementation | The implementation for Integrate measures allocates a continuous state variable or variables from the State's z pool and generates zdot values to be integrated into those z variables |
MaxAbs | Track the value of the operand that is of maximum absolute value |
Maximum | Track the maximum value of the operand (signed) |
MinAbs | Track the value of the operand that is of minimum absolute value (not very useful) |
Minimum | Track the minimum value of the operand (signed) |
Minus | This Measure is the difference of two Measures of the same type T |
Implementation | |
One | This creates a Measure::Constant whose value is always T(1) and can't be changed |
Plus | This Measure is the sum of two Measures of the same type T |
Implementation | |
Result | This Measure holds the result of some externally-determined computation, and helps to coordinate the validity of that computation with respect to the state variables |
Implementation | |
SampleAndHold | NOT IMPLEMENTED YET – This is a Measure operator which, upon occurrence of a designated event, samples its source Measure and then holds its value in a discrete state variable until the next occurrence of the event |
Scale | This Measure multiplies some other Measure by a Real scale factor |
Implementation | |
Sinusoid | This measure produces a sinusoidal function of time: |
Implementation | |
Time | This creates a Measure::Time whose value is always T(time) |
Implementation | |
Variable | This creates a Measure whose value is a discrete State variable of any type T |
Implementation | |
Zero | This creates a Measure::Constant whose value is always T(0) and can't be changed |
Stage | This class is basically a glorified enumerated type, type-safe and range checked but permitting convenient (if limited) arithmetic |
State | This is the handle class for the hidden State implementation |
Study | |
Guts | This is the declaration for the Study::Guts class, the abstract object to which a Study handle points |
Subsystem | The abstract parent of all Subsystems |
Guts | The abstract parent of all Subsystem "Guts" implementation classes |
System | This is the base class that serves as the parent of all SimTK System objects; most commonly Simbody's MultibodySystem class |
Guts | This is the declaration for the System::Guts class, the abstract object to which a System handle points |
DefaultSystemSubsystem | This is a concrete Subsystem that is part of every System. It provides a variety of services for the System, such as maintaining lists of event handlers and reporters, and acting as a source of globally unique event IDs |
ProjectOptions | Options for the advanced project() methods |
ProjectResults | Results for advanced users of project() methods |
RealizeOptions | (NOT USED YET) Options for the advanced realize() methods |
RealizeResults | (NOT USED YET) Results for advanced users of realize() methods |
Mat | This class represents a small matrix whose size is known at compile time, containing elements of any Composite Numerical Type (CNT) and engineered to have no runtime overhead whatsoever |
EltResult | |
Result | |
SubMat | |
Substitute | |
Row | Generic Row |
EltResult | |
Result | |
Substitute | |
SymMat | RS is total spacing between rows in memory (default 1) |
EltResult | |
Result | |
Substitute | |
Vec | This is a fixed length column vector designed for no-overhead inline computation |
EltResult | |
Result | |
Substitute | Shape-preserving element substitution (always packed) |
BicubicSurface | This class will create a smooth surface that approximates a two-argument function F(X,Y) from a given set of samples of that function on a rectangular grid with regular or irregular spacing |
PatchHint | This object is used to hold precalculated data about the most recently accessed patch to accelerate the common case of repeated access to the same patch or to nearby patches |
BicubicFunction | This is a two-argument Function built using a shared BicubicSurface and managing current state to optimize for localized access |
CollisionDetectionAlgorithm | A CollisionDetectionAlgorithm implements an algorithm for detecting overlaps between pairs of ContactGeometry objects, and creating Contact objects based on them |
ConvexConvex | This algorithm detects contacts between two ContactGeometry::Convex objects |
HalfSpaceEllipsoid | This algorithm detects contacts between a ContactGeometry::HalfSpace and a ContactGeometry::Ellipsoid |
HalfSpaceSphere | This algorithm detects contacts between a ContactGeometry::HalfSpace and a ContactGeometry::Sphere |
HalfSpaceTriangleMesh | This algorithm detects contacts between a ContactGeometry::HalfSpace and a ContactGeometry::TriangleMesh |
SphereSphere | This algorithm detects contacts between two ContactGeometry::Sphere objects |
SphereTriangleMesh | This algorithm detects contacts between a ContactGeometry::Sphere and a ContactGeometry::TriangleMesh |
TriangleMeshTriangleMesh | This algorithm detects contacts between two ContactGeometry::TriangleMesh objects |
Contact | A Contact contains information about the spatial relationship between two surfaces that are near, or in contact with, each other |
UntrackedContact | This subclass of Contact represents a pair of contact surfaces that are not yet being tracked; there is no ContactId for them |
BrokenContact | This subclass of Contact represents a pair of contact surfaces that were in contact (meaning within cutoff range) but have now gone out of range |
CircularPointContact | This subclass of Contact represents a contact between two non-conforming surfaces 1 and 2 that initially meet at a point where each surface has a uniform radius of curvature in all directions (R1 and R2), like a sphere (inside or outside) or a halfspace, resulting in a contact region with circular symmetry |
EllipticalPointContact | This subclass of Contact represents a contact between two non-conforming surfaces 1 and 2 that initially meet at a point and where each surface has two principal curvatures (maximum and minimum) in perpendicular directions |
TriangleMeshContact | This subclass of Contact is used when one or both of the ContactGeometry objects is a TriangleMesh |
PointContact | OBSOLETE – use CircularPointContact or EllipticalPointContact |
ContactGeometry | A ContactGeometry object describes the shape of all or part of the boundary of a solid object, for the purpose of modeling with Simbody physical effects that occur at the surface of that object, such as contact and wrapping forces |
Cylinder | This ContactGeometry subclass represents a cylinder centered at the origin, with radius r in the x-y plane, and infinite length along z |
Ellipsoid | This ContactGeometry subclass represents an ellipsoid centered at the origin, with its principal axes pointing along the x, y, and z axes and half dimensions a,b, and c (all > 0) along those axes, respectively |
HalfSpace | This ContactGeometry subclass represents an object that occupies the entire half-space x>0 |
SmoothHeightMap | This ContactGeometry subclass represents a smooth surface fit through a set of sampled points using bicubic patches to provide C2 continuity |
Sphere | This ContactGeometry subclass represents a sphere centered at the origin |
Torus | This ContactGeometry subclass represents a torus centered at the origin with the axial direction aligned to the z-axis |
TriangleMesh | This ContactGeometry subclass represents an arbitrary shape described by a mesh of triangular faces |
OBBTreeNode | This class represents a node in the Oriented Bounding Box Tree for a TriangleMesh |
Plane | A simple plane class |
GeodHitPlaneEvent | A event handler to terminate integration when geodesic hits the plane |
PathDecorator | This class generates decoration for contact points and straight line path segments |
PlaneDecorator | This class generates decoration for a plane |
ContactTracker | A ContactTracker implements an algorithm for detecting overlaps or potential overlaps between pairs of ContactGeometry objects, and managing Contact objects that track individual contacts as they evolve through time |
ConvexImplicitPair | This ContactTracker handles contacts between two smooth, convex objects by using their implicit functions |
GeneralImplicitPair | (TODO: not implemented yet) This ContactTracker handles contacts between two arbitrary smooth surfaces by using their implicit functions, with no shape restrictions |
HalfSpaceEllipsoid | This ContactTracker handles contacts between a ContactGeometry::HalfSpace and a ContactGeometry::Ellipsoid, in that order |
HalfSpaceSphere | This ContactTracker handles contacts between a ContactGeometry::HalfSpace and a ContactGeometry::Sphere, in that order |
HalfSpaceTriangleMesh | This ContactTracker handles contacts between a ContactGeometry::HalfSpace and a ContactGeometry::TriangleMesh, in that order |
SphereSphere | This ContactTracker handles contacts between two ContactGeometry::Sphere objects |
SphereTriangleMesh | This ContactTracker handles contacts between a ContactGeometry::Sphere and a ContactGeometry::TriangleMesh, in that order |
TriangleMeshTriangleMesh | This ContactTracker handles contacts between two ContactGeometry::TriangleMesh surfaces |
GCVSPLUtil | This class provides entry points for using the GCVSPL algorithm in terms of SimTK data types |
Geo | Collects geometric primitives intended to deal with raw, fixed-size geometric shapes occupying minimal memory and providing maximum performance through small inline methods and larger high performance algorithms |
AlignedBox_ | A 3d box aligned with an unspecified frame F and centered at a given point measured from that frame's origin |
BicubicBezierPatch_ | A primitive useful for computations involving a single bicubic Bezier patch |
BicubicHermitePatch_ | A primitive useful for computations involving a single bicubic Hermite patch |
Box_ | A 3d rectangular box aligned with an unspecified frame F and centered at that frame's origin |
Circle_ | |
CubicBezierCurve_ | This is a primitive useful for computations involving a single cubic Bezier curve segment |
CubicHermiteCurve_ | A primitive useful for computations involving a single cubic Hermite curve segment in algebraic or geometric (Hermite) form |
Line_ | |
LineSeg_ | A 3d line segment primitive represented by its end points in an unspecified frame, and a collection of line segment-related utility methods |
OrientedBox_ | TODO: A 3d box oriented and positioned with respect to an unspecified frame F |
Plane_ | |
Point_ | A 3d point primitive represented by a Vec3 from the origin of an unspecified frame, and a collection of point-related utility methods |
Sphere_ | A geometric primitive representing a sphere by its radius and center point, and a collection of sphere-related utility methods |
Triangle_ | A geometric primitive representing a triangle by its vertices as points in some unspecified frame, and a collection of triangle-related utility methods |
Geodesic | This class stores a geodesic curve after it has been determined |
GeodesicDecorator | This class generates decoration (line segments) for a geodesic curve |
GeodesicOptions | This class stores options for calculating geodesics |
GeodesicIntegrator | This is a stripped-down numerical integrator for small ODE or DAE problems whose size is known at compile time, with no provision for discrete variables, event detection, or interpolation |
OBBLeaf | TODO |
OBBNode | TODO |
OBBTree | TODO |
OrientedBoundingBox | This class represents a rectangular box with arbitrary position and orientation |
ParticleConSurfaceSystemGuts | |
ParticleConSurfaceSystem | |
Spline_ | This class implements a non-uniform Bezier curve |
SplineImpl | This is the implementation class that supports the Spline_ interface |
SplineFitter | Given a set of data points, this class creates a Spline_ which interpolates or approximates them |
SplineFitterImpl | |
Differentiator | Given a function f(y), where f, y or both can be vectors, calculate the derivative (gradient, Jacobian) df/dy |
Function | This abstract class defines a function to be differentiated (repeatedly) by a Differentiator object |
GradientFunction | Derive a concrete class from this one if you have a scalar function of multiple variables that you want to differentiate |
JacobianFunction | Derive a concrete class from this one if you have a set of functions (i.e., a vector-valued function) of multiple variables that you want to differentiate |
ScalarFunction | Derive a concrete class from this one if you have a scalar function of a single scalar variable that you want to differentiate |
SysObjectiveFunc | |
SysConstraintFunc | |
DefaultOptimizer | |
Factor | Base class for the various matrix factorizations |
FactorLU | Class for performing LU matrix factorizations |
FactorQTZ | Class to perform a QTZ (linear least squares) factorization |
Eigen | Class to compute Eigen values and Eigen vectors of a matrix |
FactorSVD | Class to compute a singular value decomposition of a matrix |
MultibodyGraphMaker | Construct a reasonably good spanning-tree-plus-constraints structure for modeling a given set of bodies and joints with a generalized coordinate multibody system like Simbody |
Body | Local class that collects information about bodies |
Joint | Local class that collects information about joints |
JointType | Local class that defines the properties of a known joint type |
LoopConstraint | Local class that represents one of the constraints that were added to close topological loops that were cut to form the spanning tree |
Mobilizer | Local class that represents one of the mobilizers (tree joints) in the generated spanning tree |
OptimizerSystem | Abstract class which defines an objective/cost function which is optimized by and Optimizer object |
Optimizer | API for SimTK Simmath's optimizers |
OptimizerRep | |
CPodesIntegrator | This is an Integrator based on the CPODES library |
ExplicitEulerIntegrator | This is an Integrator based on the explicit Euler algorithm |
Integrator | An Integrator is an object that can advance the State of a System through time |
CPodesSystem | This abstract class defines the system to be integrated with SimTK CPodes |
CPodes | This is a straightforward translation of the Sundials CPODES C interface into C++ |
RungeKutta2Integrator | This is a 2nd order Runge-Kutta Integrator using coefficients that are also known as the explicit trapezoid rule |
RungeKutta3Integrator | This is a 3rd order Runge-Kutta Integrator using coefficents from J.C |
RungeKuttaFeldbergIntegrator | |
RungeKuttaMersonIntegrator | |
SemiExplicitEuler2Integrator | This is an implementation of a variable-step, first-order semi-explicit Euler method, also known as semi-implicit Euler or symplectic Euler |
SemiExplicitEulerIntegrator | This is an implementation of the fixed-step Semi-Explicit Euler method, also known as Semi-Implicit Euler or Symplectic Euler |
TimeStepper | This class uses an Integrator to advance a System through time |
VerletIntegrator | This is an Integrator based on the velocity Verlet algorithm |
CableObstacleIndex | This is a unique integer type for identifying obstacles comprising a particular cable path |
CablePathIndex | This is a unique integer type for quickly identifying specific cables for fast lookup purposes |
MobilizedBodyIndex | This is for arrays indexed by mobilized body number within a subsystem (typically the SimbodyMatterSubsystem). It is assigned when a MobilizedBody is added to a subsystem. You can abbreviate this as MobodIndex if you prefer |
ConstraintIndex | This is for arrays indexed by constraint number within a subsystem (typically the SimbodyMatterSubsystem). It is assigned when a Constraint is added to the subsystem |
MobilizerQIndex | The Mobilizer associated with each MobilizedBody, once modeled, has a specific number of generalized coordinates q (0-7) and generalized speeds (mobilities) u (0-6). This is the index type for the small array of Mobilizer-local q's |
MobilizerUIndex | The Mobilizer associated with each MobilizedBody, once modeled, has a specific number of generalized coordinates q (0-7) and generalized speeds (mobilities) u (0-6). This is the index type for the small array of Mobilizer-local u's |
ForceIndex | This type represents the index of a Force element within its subsystem |
EventId | This is a class to represent unique IDs for events in a type-safe way |
SystemEventTriggerIndex | This unique integer type is for identifying a triggered event in the full System-level view of the State |
SystemEventTriggerByStageIndex | This unique integer type is for identifying a triggered event within a particular Stage of the full System-level view of the State |
EventTriggerByStageIndex | Unique integer type for Subsystem-local, per-stage event indexing |
SubsystemIndex | Provide a unique integer type for identifying Subsystems |
SystemYIndex | This unique integer type is for indexing the global, System-level "y-like" arrays, that is, the arrays in which all of the various Subsystems' continuous state variables q, u, and z have been collected into contiguous memory |
SystemQIndex | This unique integer type is for indexing global "q-like" arrays, that is, arrays that inherently have the same dimension as the total number of second order state variables (generalized coordinates) in the full System-level view of the State |
QIndex | Unique integer type for Subsystem-local q indexing |
SystemUIndex | This unique integer type is for indexing global "u-like" arrays, that is, arrays that inherently have the same dimension as the total number of mobilities (generalized speeds) in the full System-level view of the State |
UIndex | Unique integer type for Subsystem-local u indexing |
SystemZIndex | This unique integer type is for indexing global "z-like" arrays, that is, arrays that inherently have the same dimension as the total number of auxiliary state variables in the full System-level view of the State |
ZIndex | Unique integer type for Subsystem-local z indexing |
DiscreteVariableIndex | This unique integer type is for selecting discrete variables |
CacheEntryIndex | This unique integer type is for selecting non-shared cache entries |
SystemYErrIndex | This unique integer type is for indexing the global, System-level "yErr-like" arrays, that is, the arrays in which all of the various Subsystems' qErr and uErr constraint equation slots have been collected together |
SystemQErrIndex | This unique integer type is for indexing global "qErr-like" arrays, that is, arrays that inherently have the same dimension as the total number of position-level constraint equations in the full System-level view of the State |
QErrIndex | Unique integer type for Subsystem-local qErr indexing |
SystemUErrIndex | This unique integer type is for indexing global "uErr-like" arrays, that is, arrays that inherently have the same dimension as the total number of velocity-level constraint equations in the full System-level view of the State |
UErrIndex | Unique integer type for Subsystem-local uErr indexing |
SystemUDotErrIndex | This unique integer type is for indexing global "uDotErr-like" arrays, that is, arrays that inherently have the same dimension as the total number of acceleration-level constraint equations in the full System-level view of the State |
UDotErrIndex | Unique integer type for Subsystem-local uDotErr indexing |
SystemMultiplierIndex | This unique integer type is for indexing global "multiplier-like" arrays, that is, arrays that inherently have the same dimension as the total number of Lagrange multipliers in the full System-level view of the State |
MultiplierIndex | Unique integer type for Subsystem-local multiplier indexing |
ContactSurfaceIndex | This defines a unique index for all the contact surfaces being handled either by a ContactTrackerSubsystem or within a single ContactSet of a GeneralContactSubsystem |
ContactId | This is a unique integer Id assigned to each contact pair when we first begin to track it |
ContactTypeId | This is a small integer that serves as the unique typeid for each type of concrete Contact class |
ContactGeometryTypeId | This is a unique integer type for quickly identifying specific types of contact geometry for fast lookup purposes |