|
| UniversalPinJoint (unsigned int uL, const DofOwner *pDO, const StructNode *pN, const Vec3 &X0Tmp, const Mat3x3 &R0Tmp, const Vec3 &dTmp, const Mat3x3 &RhTmp, flag fOut) |
|
| ~UniversalPinJoint (void) |
|
virtual Joint::Type | GetJointType (void) const |
|
virtual std::ostream & | Restart (std::ostream &out) const |
|
virtual unsigned int | iGetNumDof (void) const |
|
virtual DofOrder::Order | GetDofType (unsigned int i) const |
|
virtual void | WorkSpaceDim (integer *piNumRows, integer *piNumCols) const |
|
VariableSubMatrixHandler & | AssJac (VariableSubMatrixHandler &WorkMat, doublereal dCoef, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr) |
|
SubVectorHandler & | AssRes (SubVectorHandler &WorkVec, doublereal dCoef, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr) |
|
virtual void | Output (OutputHandler &OH) const |
|
virtual unsigned int | iGetInitialNumDof (void) const |
|
virtual void | InitialWorkSpaceDim (integer *piNumRows, integer *piNumCols) const |
|
VariableSubMatrixHandler & | InitialAssJac (VariableSubMatrixHandler &WorkMat, const VectorHandler &XCurr) |
|
SubVectorHandler & | InitialAssRes (SubVectorHandler &WorkVec, const VectorHandler &XCurr) |
|
virtual void | GetConnectedNodes (std::vector< const Node * > &connectedNodes) const |
|
| Elem (unsigned int uL, flag fOut) |
|
virtual | ~Elem (void) |
|
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 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 VariableSubMatrixHandler & | AssJac (VariableSubMatrixHandler &WorkMat, const VectorHandler &XCurr) |
|
virtual SubVectorHandler & | AssRes (SubVectorHandler &WorkVec, const VectorHandler &XCurr, const VectorHandler &XPrimeCurr, const VectorHandler &XPrimePrimeCurr, InverseDynamics::Order iOrder=InverseDynamics::INVERSE_DYNAMICS) |
|
virtual int | GetNumConnectedNodes (void) const |
|
| 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 |
|
| SimulationEntity (void) |
|
virtual | ~SimulationEntity (void) |
|
virtual bool | bIsValidIndex (unsigned int i) const |
|
virtual DofOrder::Order | GetEqType (unsigned int i) const |
|
virtual Hint * | ParseHint (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 | 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) |
|
| 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)) |
|
| Joint (unsigned int uL, const DofOwner *pD, flag fOut) |
|
virtual | ~Joint (void) |
|
virtual Elem::Type | GetElemType (void) const |
|
std::ostream & | Output (std::ostream &out, const char *sJointName, unsigned int uLabel, const Vec3 &FLocal, const Vec3 &MLocal, const Vec3 &FGlobal, const Vec3 &MGlobal) const |
|
virtual void | SetInitialValue (VectorHandler &) |
|
virtual void | SetValue (DataManager *pDM, VectorHandler &, VectorHandler &, SimulationEntity::Hints *ph=0) |
|
virtual void | Update (const VectorHandler &XCurr, InverseDynamics::Order iOrder=InverseDynamics::INVERSE_DYNAMICS) |
|
bool | bIsPrescribedMotion (void) const |
|
bool | bIsTorque (void) const |
|
| ElemGravityOwner (unsigned int uL, flag fOut) |
|
virtual | ~ElemGravityOwner (void) |
|
virtual doublereal | dGetM (void) const |
|
Vec3 | GetS (void) const |
|
Mat3x3 | GetJ (void) const |
|
Vec3 | GetB (void) const |
|
Vec3 | GetG (void) const |
|
| GravityOwner (void) |
|
virtual | ~GravityOwner (void) |
|
void | PutGravity (const Gravity *pG) |
|
virtual bool | bGetGravity (const Vec3 &X, Vec3 &Acc) const |
|
| ElemWithDofs (unsigned int uL, const DofOwner *pDO, flag fOut) |
|
virtual | ~ElemWithDofs (void) |
|
| DofOwnerOwner (const DofOwner *pDO) |
|
virtual | ~DofOwnerOwner () |
|
virtual const DofOwner * | pGetDofOwner (void) const |
|
virtual integer | iGetFirstIndex (void) const |
|
| InitialAssemblyElem (unsigned int uL, flag fOut) |
|
virtual | ~InitialAssemblyElem (void) |
|
| SubjectToInitialAssembly (void) |
|
virtual | ~SubjectToInitialAssembly (void) |
|
|
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
} |
|
typedef std::vector< Hint * > | Hints |
|
enum | { OUTPUT = 0x1U,
OUTPUT_MASK = 0xFU,
OUTPUT_PRIVATE = 0x10U,
OUTPUT_PRIVATE_MASK = ~OUTPUT_MASK
} |
|
enum | Type {
UNKNOWN = -1,
DISTANCE = 0,
DISTANCEWITHOFFSET,
CLAMP,
SPHERICALHINGE,
PIN,
UNIVERSALHINGE,
UNIVERSALROTATION,
UNIVERSALPIN,
PLANEHINGE,
PLANEROTATION,
PLANEPIN,
AXIALROTATION,
PLANEDISP,
PLANEDISPPIN,
INPLANE,
INPLANECONTACT,
J_INLINE,
ROD,
RODBEZIER,
DEFORMABLEHINGE,
DEFORMABLEDISPJOINT,
DEFORMABLEJOINT,
DEFORMABLEAXIALJOINT,
VISCOUSBODY,
LINEARVELOCITY,
ANGULARVELOCITY,
LINEARACCELERATION,
ANGULARACCELERATION,
PRISMATIC,
DRIVEHINGE,
DRIVEDISP,
DRIVEDISPPIN,
IMPOSEDORIENTATION,
IMPOSEDDISP,
IMPOSEDDISPPIN,
IMPOSEDKINEMATICS,
BEAMSLIDER,
BRAKE,
GIMBAL,
POINT_SURFACE_CONTACT,
TOTALJOINT,
TOTALPINJOINT,
TOTALEQUATION,
TOTALREACTION,
MODAL,
SCREWJOINT,
LASTJOINTTYPE
} |
|
virtual void | OutputPrepare_int (const std::string &type, OutputHandler &OH, std::string &name) |
|
virtual Vec3 | GetS_int (void) const |
|
virtual Mat3x3 | GetJ_int (void) const |
|
virtual Vec3 | GetB_int (void) const |
|
virtual Vec3 | GetG_int (void) const |
|
unsigned int | uLabel |
|
std::string | sName |
|
flag | fOutput |
|
Gravity * | pGravity |
|
Definition at line 242 of file univj.h.
Implements SubjectToInitialAssembly.
Definition at line 1302 of file univj.cc.
References FullSubMatrixHandler::Add(), Vec3::Cross(), d, DEBUGCOUT, dM, F, WithLabel::GetLabel(), StructNode::GetRRef(), Mat3x3::GetVec(), StructNode::GetWRef(), DofOwnerOwner::iGetFirstIndex(), StructDispNode::iGetFirstPositionIndex(), InitialWorkSpaceDim(), MatCross, MatCrossCross, MBDYN_EXCEPT_ARGS, pNode, FullSubMatrixHandler::PutCoef(), FullSubMatrixHandler::PutColIndex(), FullSubMatrixHandler::PutRowIndex(), R, R0, FullSubMatrixHandler::ResizeReset(), Rh, and VariableSubMatrixHandler::SetFull().
1305 DEBUGCOUT(
"Entering UniversalPinJoint::InitialAssJac()" << std::endl);
1319 integer iFirstVelocityIndex = iFirstPositionIndex + 6;
1321 integer iReactionPrimeIndex = iFirstReactionIndex + 4;
1324 for (
int iCnt = 1; iCnt <= 6; iCnt++) {
1327 WM.
PutRowIndex(6 + iCnt, iFirstVelocityIndex + iCnt);
1328 WM.
PutColIndex(6 + iCnt, iFirstVelocityIndex + iCnt);
1331 for (
int iCnt = 1; iCnt <= 8; iCnt++) {
1332 WM.
PutRowIndex(12 + iCnt, iFirstReactionIndex + iCnt);
1333 WM.
PutColIndex(12 + iCnt, iFirstReactionIndex + iCnt);
1340 Vec3 FPrime(XCurr, iReactionPrimeIndex + 1);
1341 doublereal dMPrime(XCurr(iReactionPrimeIndex + 4));
1344 for (
int iCnt = 1; iCnt <= 3; iCnt++) {
1346 WM.
PutCoef(iCnt, 12 + iCnt, 1.);
1349 WM.
PutCoef(6 + iCnt, 16 + iCnt, 1.);
1352 WM.
PutCoef(12 + iCnt, iCnt, -1.);
1355 WM.
PutCoef(16 + iCnt, 6 + iCnt, -1.);
1365 Vec3 Tmp(e2.Cross(e3));
1373 if (Tmp.Dot() < std::numeric_limits<doublereal>::epsilon()) {
1374 silent_cerr(
"CardanoPinJoint(" <<
GetLabel() <<
"): "
1375 "node and fixed point hinge axes are (nearly) orthogonal"
1380 Vec3 TmpPrime(e3.Cross(e2.Cross(Omega)));
1385 Vec3 MPrimeTmp(e2*dMPrime);
1402 WM.
Add(10, 13, OWedgedWedge);
1405 for (
int iCnt = 1; iCnt <= 3; iCnt++) {
1410 WM.
PutCoef(9 + iCnt, 16, TmpPrime(iCnt));
1417 WM.
Add(17, 4, OWedgedWedge);
1421 for (
int iCnt = 1; iCnt <= 3; iCnt++) {
1431 TmpPrime = e2.Cross(Omega.Cross(e3));
1432 for (
int iCnt = 1; iCnt <= 3; iCnt++) {
1433 WM.
PutCoef(20, 3 + iCnt, TmpPrime(iCnt));
void PutColIndex(integer iSubCol, integer iCol)
virtual const Mat3x3 & GetRRef(void) const
#define MBDYN_EXCEPT_ARGS
const MatCross_Manip MatCross
FullSubMatrixHandler & SetFull(void)
void Add(integer iRow, integer iCol, const Vec3 &v)
void PutCoef(integer iRow, integer iCol, const doublereal &dCoef)
virtual const Vec3 & GetWRef(void) const
Vec3 GetVec(unsigned short int i) const
virtual integer iGetFirstPositionIndex(void) const
virtual void InitialWorkSpaceDim(integer *piNumRows, integer *piNumCols) const
virtual void ResizeReset(integer, integer)
const MatCrossCross_Manip MatCrossCross
void PutRowIndex(integer iSubRow, integer iRow)
virtual integer iGetFirstIndex(void) const
unsigned int GetLabel(void) const
Implements SubjectToInitialAssembly.
Definition at line 1442 of file univj.cc.
References VectorHandler::Add(), Vec3::Cross(), d, DEBUGCOUT, dM, F, StructNode::GetRCurr(), StructDispNode::GetVCurr(), Mat3x3::GetVec(), StructNode::GetWCurr(), StructDispNode::GetXCurr(), DofOwnerOwner::iGetFirstIndex(), StructDispNode::iGetFirstPositionIndex(), InitialWorkSpaceDim(), pNode, VectorHandler::PutCoef(), SubVectorHandler::PutRowIndex(), R, R0, VectorHandler::ResizeReset(), Rh, VectorHandler::Sub(), and X0.
1445 DEBUGCOUT(
"Entering UniversalPinJoint::InitialAssRes()" << std::endl);
1455 integer iFirstVelocityIndex = iFirstPositionIndex + 6;
1457 integer iReactionPrimeIndex = iFirstReactionIndex + 4;
1460 for (
int iCnt = 1; iCnt <= 6; iCnt++) {
1461 WorkVec.
PutRowIndex(iCnt, iFirstPositionIndex + iCnt);
1462 WorkVec.
PutRowIndex(6 + iCnt, iFirstVelocityIndex + iCnt);
1465 for (
int iCnt = 1; iCnt <= 8; iCnt++) {
1466 WorkVec.
PutRowIndex(12 + iCnt, iFirstReactionIndex + iCnt);
1475 F =
Vec3(XCurr, iFirstReactionIndex + 1);
1476 dM = XCurr(iFirstReactionIndex + 4);
1477 Vec3 FPrime(XCurr, iReactionPrimeIndex + 1);
1478 doublereal dMPrime(XCurr(iReactionPrimeIndex + 4));
1485 Vec3 Tmp(e2.Cross(e3));
1487 Vec3 TmpPrime(e3.Cross(e2.Cross(Omega)));
1493 Vec3 OWedged(Omega.Cross(dTmp));
1498 Vec3 MPrimeTmp(e3.Cross(MTmp.Cross(Omega)) + e2.Cross(e3)*dMPrime);
1502 WorkVec.
Sub(4, dTmp.Cross(F) - MTmp.Cross(e3));
1505 WorkVec.
Sub(7, FPrime);
1506 WorkVec.
Sub(10, dTmp.Cross(FPrime) + OWedged.Cross(F) + MPrimeTmp);
1509 WorkVec.
Add(13, x + dTmp -
X0);
1515 WorkVec.
Add(17, v + OWedged);
1518 Tmp = e3.Cross(Omega);
virtual void ResizeReset(integer)
virtual const Mat3x3 & GetRCurr(void) const
virtual void Sub(integer iRow, const Vec3 &v)
Vec3 GetVec(unsigned short int i) const
virtual void PutRowIndex(integer iSubRow, integer iRow)=0
virtual integer iGetFirstPositionIndex(void) const
virtual const Vec3 & GetWCurr(void) const
virtual void InitialWorkSpaceDim(integer *piNumRows, integer *piNumCols) const
virtual void PutCoef(integer iRow, const doublereal &dCoef)=0
virtual const Vec3 & GetXCurr(void) const
virtual void Add(integer iRow, const Vec3 &v)
virtual const Vec3 & GetVCurr(void) const
virtual integer iGetFirstIndex(void) const