10#ifndef CLINEARSPRING_H
11#define CLINEARSPRING_H
15#include "sfh/timers/Timer.h"
20#ifdef FH_VISUALIZATION
21# include "sfh/ogre/C3DLine.h"
34#ifdef FH_VISUALIZATION
36 virtual void RenderInit(Ogre::Root*
const pOgreRoot, ISimObjectCreator*
const pCreator);
39 virtual void RenderUpdate(
const double dT,
const double*
const adX);
44 void OdeFcn(
const double dT,
const double*
const adX,
double*
const adXDot,
const bool bIsMajorTimeStep) { }
47 const double*
ForceA(
const double dT,
const double*
const adX);
50 const double*
ForceB(
const double dT,
const double*
const adX);
54 void CalcOutput(
const double dT,
const double*
const adX);
65#ifdef FH_VISUALIZATION
66 Ogre::Entity* m_pRenderEntity;
67 Ogre::SceneNode* m_pRenderNode;
A linear spring in 3 degrees of freedom.
Definition: CLinearSpring.h:26
CLinearSpring(std::string sSimObjectName, ISimObjectCreator *pCreator)
The constructor sets the pointer to the output object and the parser object.
const double * ForceA(const double dT, const double *const adX)
Calculates the end force A.
double m_adOutForceB[3]
Force vector on point B.
Definition: CLinearSpring.h:62
ICommonComputation * m_CalcOutputs
Common computation for outputs.
Definition: CLinearSpring.h:64
ISignalPort * m_pInPosB
Input for position B.
Definition: CLinearSpring.h:60
void OdeFcn(const double dT, const double *const adX, double *const adXDot, const bool bIsMajorTimeStep)
Does nothing, as the object contains no states.
Definition: CLinearSpring.h:44
const double * ForceB(const double dT, const double *const adX)
Calculates the end force B.
void CalcOutput(const double dT, const double *const adX)
< Sets the parameters of the spring.
~CLinearSpring()
The destructor cleans up dynamically allocated memory.
double m_adOutForceA[3]
Force vector on point A.
Definition: CLinearSpring.h:61
ISignalPort * m_pInPosA
Input for position A.
Definition: CLinearSpring.h:59
double m_dStiffness
The linear stiffness of the spring.
Definition: CLinearSpring.h:57
sfh::timers::Timer m_OutputTimer
Output timer.
Definition: CLinearSpring.h:63
double m_dRelaxedLength
the relaxed length of the spring.
Definition: CLinearSpring.h:58