MBDyn-1.7.3
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups
UniformGravity Class Reference

#include <gravity.h>

Inheritance diagram for UniformGravity:
Collaboration diagram for UniformGravity:

Public Member Functions

 UniformGravity (const TplDriveCaller< Vec3 > *pDC, flag fOut)
 
virtual ~UniformGravity (void)
 
virtual std::ostream & Restart (std::ostream &out) const
 
virtual SubVectorHandlerAssRes (SubVectorHandler &WorkVec, doublereal dCoef, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr)
 
virtual void Output (OutputHandler &OH) const
 
virtual Vec3 GetAcceleration (const Vec3 &) const
 
- Public Member Functions inherited from Elem
 Elem (unsigned int uL, flag fOut)
 
virtual ~Elem (void)
 
virtual unsigned int iGetNumDof (void) const
 
virtual std::ostream & DescribeDof (std::ostream &out, const char *prefix="", bool bInitial=false) const
 
virtual void DescribeDof (std::vector< std::string > &desc, bool bInitial=false, int i=-1) const
 
virtual std::ostream & DescribeEq (std::ostream &out, const char *prefix="", bool bInitial=false) const
 
virtual void DescribeEq (std::vector< std::string > &desc, bool bInitial=false, int i=-1) const
 
virtual DofOrder::Order GetDofType (unsigned int) const
 
virtual void AssMats (VariableSubMatrixHandler &WorkMatA, VariableSubMatrixHandler &WorkMatB, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr)
 
virtual bool bInverseDynamics (void) const
 
void SetInverseDynamicsFlags (unsigned uIDF)
 
unsigned GetInverseDynamicsFlags (void) const
 
bool bIsErgonomy (void) const
 
bool bIsRightHandSide (void) const
 
virtual VariableSubMatrixHandlerAssJac (VariableSubMatrixHandler &WorkMat, const VectorHandler &XCurr)
 
virtual SubVectorHandlerAssRes (SubVectorHandler &WorkVec, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr, const VectorHandler &XPrimePrimeCurr, InverseDynamics::Order iOrder=InverseDynamics::INVERSE_DYNAMICS)
 
virtual void GetConnectedNodes (std::vector< const Node * > &connectedNodes) const
 
- Public Member Functions inherited from WithLabel
 WithLabel (unsigned int uL=0, const std::string &sN="")
 
virtual ~WithLabel (void)
 
void PutLabel (unsigned int uL)
 
void PutName (const std::string &sN)
 
unsigned int GetLabel (void) const
 
const std::string & GetName (void) const
 
- Public Member Functions inherited from SimulationEntity
 SimulationEntity (void)
 
virtual ~SimulationEntity (void)
 
virtual bool bIsValidIndex (unsigned int i) const
 
virtual DofOrder::Order GetEqType (unsigned int i) const
 
virtual void SetValue (DataManager *pDM, VectorHandler &X, VectorHandler &XP, SimulationEntity::Hints *h=0)
 
virtual HintParseHint (DataManager *pDM, const char *s) const
 
virtual void BeforePredict (VectorHandler &, VectorHandler &, VectorHandler &, VectorHandler &) const
 
virtual void AfterPredict (VectorHandler &X, VectorHandler &XP)
 
virtual void Update (const VectorHandler &XCurr, const VectorHandler &XPrimeCurr)
 
virtual void DerivativesUpdate (const VectorHandler &XCurr, const VectorHandler &XPrimeCurr)
 
virtual void Update (const VectorHandler &XCurr, InverseDynamics::Order iOrder)
 
virtual void AfterConvergence (const VectorHandler &X, const VectorHandler &XP)
 
virtual void AfterConvergence (const VectorHandler &X, const VectorHandler &XP, const VectorHandler &XPP)
 
virtual unsigned int iGetNumPrivData (void) const
 
virtual unsigned int iGetPrivDataIdx (const char *s) const
 
virtual doublereal dGetPrivData (unsigned int i) const
 
virtual std::ostream & OutputAppend (std::ostream &out) const
 
virtual void ReadInitialState (MBDynParser &HP)
 
- Public Member Functions inherited from ToBeOutput
 ToBeOutput (flag fOut=fDefaultOut)
 
virtual ~ToBeOutput (void)
 
virtual void OutputPrepare (OutputHandler &OH)
 
virtual void Output (OutputHandler &OH, const VectorHandler &X, const VectorHandler &XP) const
 
virtual flag fToBeOutput (void) const
 
virtual bool bToBeOutput (void) const
 
virtual void SetOutputFlag (flag f=flag(1))
 
- Public Member Functions inherited from Gravity
 Gravity (flag fOut)
 
virtual ~Gravity (void)
 
virtual Elem::Type GetElemType (void) const
 
virtual void WorkSpaceDim (integer *piNumRows, integer *piNumCols) const
 
virtual VariableSubMatrixHandlerAssJac (VariableSubMatrixHandler &WorkMat, doublereal dCoef, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr)
 
virtual int GetNumConnectedNodes (void) const
 
- Public Member Functions inherited from TplDriveOwner< Vec3 >
 TplDriveOwner (const TplDriveCaller< Vec3 > *pDC=0)
 
virtual ~TplDriveOwner (void)
 
void Set (const TplDriveCaller< Vec3 > *pDC)
 
TplDriveCaller< Vec3 > * pGetDriveCaller (void) const
 
Vec3 Get (const doublereal &dVar) const
 
Vec3 Get (void) const
 
virtual bool bIsDifferentiable (void) const
 
virtual Vec3 GetP (void) const
 

Protected Attributes

Vec3 Acc
 
- Protected Attributes inherited from WithLabel
unsigned int uLabel
 
std::string sName
 
- Protected Attributes inherited from ToBeOutput
flag fOutput
 
- Protected Attributes inherited from TplDriveOwner< Vec3 >
TplDriveCaller< Vec3 > * pTplDriveCaller
 

Additional Inherited Members

- Public Types inherited from Elem
enum  Type {
  UNKNOWN = -1, AIRPROPERTIES = 0, INDUCEDVELOCITY, AUTOMATICSTRUCTURAL,
  GRAVITY, BODY, JOINT, JOINT_REGULARIZATION,
  BEAM, PLATE, FORCE, INERTIA,
  ELECTRICBULK, ELECTRIC, THERMAL, HYDRAULIC,
  BULK, LOADABLE, DRIVEN, EXTERNAL,
  AEROMODAL, AERODYNAMIC, GENEL, SOCKETSTREAM_OUTPUT,
  RTAI_OUTPUT = SOCKETSTREAM_OUTPUT, LASTELEMTYPE
}
 
- Public Types inherited from SimulationEntity
typedef std::vector< Hint * > Hints
 
- Public Types inherited from ToBeOutput
enum  { OUTPUT = 0x1U, OUTPUT_MASK = 0xFU, OUTPUT_PRIVATE = 0x10U, OUTPUT_PRIVATE_MASK = ~OUTPUT_MASK }
 

Detailed Description

Definition at line 127 of file gravity.h.

Constructor & Destructor Documentation

UniformGravity::UniformGravity ( const TplDriveCaller< Vec3 > *  pDC,
flag  fOut 
)

Definition at line 81 of file gravity.cc.

References Acc, and TplDriveOwner< Vec3 >::Get().

82 : Elem(1, fOut), Gravity(fOut), TplDriveOwner<Vec3>(pDC)
83 {
84  Acc = Get();
85 }
Gravity(flag fOut)
Definition: gravity.cc:41
Elem(unsigned int uL, flag fOut)
Definition: elem.cc:41
Vec3 Get(void) const
Definition: tpldrive.h:113

Here is the call graph for this function:

UniformGravity::~UniformGravity ( void  )
virtual

Definition at line 87 of file gravity.cc.

References NO_OP.

88 {
89  NO_OP;
90 }
#define NO_OP
Definition: myassert.h:74

Member Function Documentation

SubVectorHandler & UniformGravity::AssRes ( SubVectorHandler WorkVec,
doublereal  dCoef,
const VectorHandler XCurr,
const VectorHandler XPrimeCurr 
)
virtual

Implements Elem.

Definition at line 102 of file gravity.cc.

References Acc, Gravity::AssRes(), DEBUGCOUT, and TplDriveOwner< Vec3 >::Get().

106 {
107  DEBUGCOUT("Entering UniformGravity::AssRes()" << std::endl);
108 
109  /* Approfitto del fatto che Gravity viene aggiornato prima
110  * degli altri elementi (vedi l'enum Elem::Type e la sequenza di
111  * assemblaggio) per fargli calcolare Acc una volta per tutte.
112  * Quindi, quando viene chiamata GetAcceleration(void),
113  * questa restituisce un reference all'accelerazione con il
114  * minimo overhead
115  */
116  Acc = Get();
117  return Gravity::AssRes(WorkVec, dCoef, XCurr, XPrimeCurr);
118 }
#define DEBUGCOUT(msg)
Definition: myassert.h:232
virtual SubVectorHandler & AssRes(SubVectorHandler &WorkVec, doublereal dCoef, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr)
Definition: gravity.cc:66
Vec3 Get(void) const
Definition: tpldrive.h:113

Here is the call graph for this function:

virtual Vec3 UniformGravity::GetAcceleration ( const Vec3 ) const
inlinevirtual

Implements Gravity.

Definition at line 166 of file gravity.h.

References Acc.

166  {
167  return Acc;
168  };
void UniformGravity::Output ( OutputHandler OH) const
virtual

Reimplemented from ToBeOutput.

Definition at line 121 of file gravity.cc.

References Acc, ToBeOutput::bToBeOutput(), WithLabel::GetLabel(), OutputHandler::GRAVITY, OutputHandler::Gravity(), and OutputHandler::UseText().

122 {
123  if (bToBeOutput()) {
125  OH.Gravity() << std::setw(8) << GetLabel()
126  << " " << Acc << std::endl;
127  }
128  }
129 }
virtual bool bToBeOutput(void) const
Definition: output.cc:890
std::ostream & Gravity(void) const
Definition: output.h:587
unsigned int GetLabel(void) const
Definition: withlab.cc:62
bool UseText(int out) const
Definition: output.cc:446

Here is the call graph for this function:

std::ostream & UniformGravity::Restart ( std::ostream &  out) const
virtual

Implements Elem.

Definition at line 94 of file gravity.cc.

References TplDriveOwner< Vec3 >::pGetDriveCaller(), and TplDriveCaller< T >::Restart().

95 {
96  return out << " gravity: uniform, /* reference, global, */ ",
97  pGetDriveCaller()->Restart(out) << ";" << std::endl;
98 }
TplDriveCaller< Vec3 > * pGetDriveCaller(void) const
Definition: tpldrive.h:105
virtual std::ostream & Restart(std::ostream &out) const =0

Here is the call graph for this function:

Member Data Documentation

Vec3 UniformGravity::Acc
protected

Definition at line 129 of file gravity.h.

Referenced by AssRes(), GetAcceleration(), Output(), and UniformGravity().


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