Simbody  3.4
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
SimTK::Measure_< T >::Integrate::Implementation Class Reference

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. More...

#include <MeasureImplementation.h>

+ Inheritance diagram for SimTK::Measure_< T >::Integrate::Implementation:

Public Member Functions

 Implementation ()
 The derivative and initialConditions Measures will be empty handles if this is default constructed.
 Implementation (const Measure_< T > &deriv, const Measure_< T > &ic, const T &defaultValue)
 Here we're shallow-copying the Measure handles so we'll be referring to the original Measures.
 Implementation (const Implementation &source)
 Copy constructor shallow-copies the referenced measures, but we don't want to share our state variables.
void setValue (State &s, const T &value) const
 Set the value of the state variables(s) that hold the integral.
const Measure_< T > & getDerivativeMeasure () const
const Measure_< T > & getInitialConditionMeasure () const
void setDerivativeMeasure (const Measure_< T > &d)
void setInitialConditionMeasure (const Measure_< T > &ic)
ImplementationcloneVirtual () const override
int getNumTimeDerivativesVirtual () const override
 This measure has one more time derivative than the integrand.
void calcCachedValueVirtual (const State &s, int derivOrder, T &value) const override
 Concrete measures must override this if the state cache is used for precalculated values or derivatives.
const T & getUncachedValueVirtual (const State &s, int derivOrder) const override
 This is only called when derivOrder >= the number of cache entries we have, but still <= the number of derivatives the Measure says it can deliver.
Stage getDependsOnStageVirtual (int derivOrder) const override
void initializeVirtual (State &s) const override
 Initialize the state to the current value of the initial condition measure, if there is one, otherwise to the default value.
void realizeMeasureTopologyVirtual (State &s) const override
 Allocate one Real continuous state variable z per element of this Measure's data type T, using the default value to determine how many are needed (if that's not part of the type T), and initialize them to the corresponding element from the default value.
void realizeMeasureAccelerationVirtual (const State &s) const override
 Set the zdots to the integrand (derivative measure) value.
- Public Member Functions inherited from SimTK::Measure_< T >::Implementation
const T & getValue (const State &s, int derivOrder) const
void setDefaultValue (const T &defaultValue)
 Set a new default value for this Measure.
const T & getDefaultValue () const
 Return a reference to the value that this Measure will use to initialize its value-level state resource (state variable or cache entry) during the next call to realizeTopology().
void setIsPresumedValidAtDependsOnStage (bool presume)
bool getIsPresumedValidAtDependsOnStage () const

Additional Inherited Members

- Protected Member Functions inherited from SimTK::Measure_< T >::Implementation
 Implementation (const T &defaultValue, int numCacheEntries=1)
 Implementation (int numCacheEntries=1)
 Argument numCacheEntries should be one greater than the number of derivatives; that is, there is room for the value ("0th" derivative) also.
int size () const
 Return the number of elements in the data type of this Measure; for Vector measures this is determined by the size of the default value.
int getNumCacheEntries () const
 Return the number of cache entries allocated for the value and derivatives of this Measure.
const T & getCacheEntry (const State &s, int derivOrder) const
 Get a const reference to the value stored in one of this Measure's cache entries, indexed by the derivative order (with the value treated as the 0th derivative).
T & updCacheEntry (const State &s, int derivOrder) const
 Get a writable reference to the value stored in one of this Measure's cache entries, indexed by the derivative order (with the value treated as the 0th derivative).
bool isCacheValueRealized (const State &s, int derivOrder) const
 Determine whether a particular one of this Measure's cache entries has already been realized since the given state was modified.
void markCacheValueRealized (const State &s, int derivOrder) const
 Mark one of this Measure's cache entries up to date; call this after you have calculated a value or derivative and stored it in the corresponding cache entry.
void markCacheValueNotRealized (const State &s, int derivOrder) const
 Invalidate one of this Measure's cache entries.
const T & getValueZero () const
 Return a reference to a zero of the same type and size as this Measure's value.

Detailed Description

template<class T>
class SimTK::Measure_< T >::Integrate::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.

The z's are then copied into a type T, Time-stage cache entry so that we can return the value as a type T reference. Derivative requests are passed through to the integrand so only one cache entry is required here.

Constructor & Destructor Documentation

template<class T>
SimTK::Measure_< T >::Integrate::Implementation::Implementation ( )
inline

The derivative and initialConditions Measures will be empty handles if this is default constructed.

Reimplemented from SimTK::AbstractMeasure::Implementation.

template<class T>
SimTK::Measure_< T >::Integrate::Implementation::Implementation ( const Measure_< T > &  deriv,
const Measure_< T > &  ic,
const T &  defaultValue 
)
inline

Here we're shallow-copying the Measure handles so we'll be referring to the original Measures.

template<class T>
SimTK::Measure_< T >::Integrate::Implementation::Implementation ( const Implementation source)
inline

Copy constructor shallow-copies the referenced measures, but we don't want to share our state variables.

Reimplemented from SimTK::Measure_< T >::Implementation.

Member Function Documentation

template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::setValue ( State s,
const T &  value 
) const
inline

Set the value of the state variables(s) that hold the integral.

This cannot be used to change the size if the type T is a Vector; the supplied value must be the same length as the default value of this Measure.

template<class T>
const Measure_<T>& SimTK::Measure_< T >::Integrate::Implementation::getDerivativeMeasure ( ) const
inline
template<class T>
const Measure_<T>& SimTK::Measure_< T >::Integrate::Implementation::getInitialConditionMeasure ( ) const
inline
template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::setDerivativeMeasure ( const Measure_< T > &  d)
inline
template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::setInitialConditionMeasure ( const Measure_< T > &  ic)
inline
template<class T>
Implementation* SimTK::Measure_< T >::Integrate::Implementation::cloneVirtual ( ) const
inlineoverridevirtual
template<class T>
int SimTK::Measure_< T >::Integrate::Implementation::getNumTimeDerivativesVirtual ( ) const
inlineoverridevirtual

This measure has one more time derivative than the integrand.

Reimplemented from SimTK::AbstractMeasure::Implementation.

template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::calcCachedValueVirtual ( const State ,
int  derivOrder,
T &  value 
) const
inlineoverridevirtual

Concrete measures must override this if the state cache is used for precalculated values or derivatives.

Reimplemented from SimTK::Measure_< T >::Implementation.

template<class T>
const T& SimTK::Measure_< T >::Integrate::Implementation::getUncachedValueVirtual ( const State ,
int  derivOrder 
) const
inlineoverridevirtual

This is only called when derivOrder >= the number of cache entries we have, but still <= the number of derivatives the Measure says it can deliver.

You don't need to override this if that condition can't occur. This is commonly used for functions whose derivatives above a certain order are zero.

Reimplemented from SimTK::Measure_< T >::Implementation.

template<class T>
Stage SimTK::Measure_< T >::Integrate::Implementation::getDependsOnStageVirtual ( int  derivOrder) const
inlineoverridevirtual
template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::initializeVirtual ( State s) const
inlineoverridevirtual

Initialize the state to the current value of the initial condition measure, if there is one, otherwise to the default value.

Reimplemented from SimTK::AbstractMeasure::Implementation.

template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::realizeMeasureTopologyVirtual ( State s) const
inlineoverridevirtual

Allocate one Real continuous state variable z per element of this Measure's data type T, using the default value to determine how many are needed (if that's not part of the type T), and initialize them to the corresponding element from the default value.

Reimplemented from SimTK::Measure_< T >::Implementation.

template<class T>
void SimTK::Measure_< T >::Integrate::Implementation::realizeMeasureAccelerationVirtual ( const State s) const
inlineoverridevirtual

Set the zdots to the integrand (derivative measure) value.

If no integrand was provided it is treated as though it were zero.

Reimplemented from SimTK::AbstractMeasure::Implementation.


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