80#ifndef CLINEARSPRING_H
81#define CLINEARSPRING_H
86#include "sfh/timers/Timer.h"
91#ifdef FH_VISUALIZATION
93# include "sfh/ogre/C3DLine.h"
106#ifdef FH_VISUALIZATION
108 virtual void RenderInit(Ogre::Root*
const pOgreRoot, ISimObjectCreator*
const pCreator);
111 virtual void RenderUpdate(
const double dT,
const double*
const adX);
116 void OdeFcn(
const double dT,
const double*
const adX,
double*
const adXDot,
const bool bIsMajorTimeStep) { }
119 const double*
ForceA(
const double dT,
const double*
const adX);
122 const double*
ForceB(
const double dT,
const double*
const adX);
139#ifdef FH_VISUALIZATION
140 Ogre::Entity* m_pRenderEntity;
141 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
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:116
const double * ForceB(const double dT, const double *const adX)
Calculates the end force A.
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