Module: sphericalPendulum¶
This class in an instantiation of the state effector class and implements an effector representing spherical pendulum.
The module
PDF Description
contains further information on this module’s function,
how to run it, as well as testing.
-
class
SphericalPendulum
: public StateEffector, public SysModel, public FuelSlosh¶ Public Functions
-
SphericalPendulum
()¶ Contructor
This is the constructor, setting variables to default values
-
~SphericalPendulum
()¶ Destructor
This is the destructor, nothing to report here
-
void
registerStates
(DynParamManager &states)¶ Method for FSP to register its states
This is the method for the spherical pendulum to register its states: l and lDot
-
void
linkInStates
(DynParamManager &states)¶ Method for FSP to get access of other states
Method for spherical pendulum to access the states that it needs. It needs gravity and the hub states
-
void
updateEffectorMassProps
(double integTime)¶ Method for FSP to add its contributions to mass props
This is the method for the FSP to add its contributions to the mass props and mass prop rates of the vehicle
-
void
modifyStates
(double integTime)¶ Method to force states modification during integration
-
void
retrieveMassValue
(double integTime)¶ This is method is used to pass mass properties information to the fuelTank
-
void
updateContributions
(double integTime, BackSubMatrices &backSubContr, Eigen::Vector3d sigma_BN, Eigen::Vector3d omega_BN_B, Eigen::Vector3d g_N)¶ Back-sub contributions
This method is for the FSP to add its contributions to the back-sub method
-
void
updateEnergyMomContributions
(double integTime, Eigen::Vector3d &rotAngMomPntCContr_B, double &rotEnergyContr, Eigen::Vector3d omega_BN_B)¶ Energy and momentum calculations
This method is for the FSP to add its contributions to energy and momentum
-
void
computeDerivatives
(double integTime, Eigen::Vector3d rDDot_BN_N, Eigen::Vector3d omegaDot_BN_B, Eigen::Vector3d sigma_BN)¶ Method for each stateEffector to calculate derivatives
This method is used to define the derivatives of the FSP. One is the trivial kinematic derivative and the other is derived using the back-sub method
Public Members
-
double
pendulumRadius
¶ [m] distance between the center of the tank and the spherical pendulum mass
-
double
phiDotInit
¶ [rad/s] Initial value for spherical pendulum pendulum offset derivative
-
double
thetaDotInit
¶ [rad/s] Initial value for spherical pendulum pendulum offset derivative
-
double
massInit
¶ [m] Initial value for spherical pendulum pendulum mass
-
std::string
nameOfPhiState
¶ [-] Identifier for the phi state data container
-
std::string
nameOfThetaState
¶ [-] Identifier for the theta state data container
-
std::string
nameOfPhiDotState
¶ [-] Identifier for the phiDot state data container
-
std::string
nameOfThetaDotState
¶ [-] Identifier for the thetaDot state data container
-
std::string
nameOfMassState
¶ [-] Identifier for the mass state data container
Private Members
-
double
phiInit
¶ [rad] Initial value for spherical pendulum pendulum offset
-
double
thetaInit
¶ [rad] Initial value for spherical pendulum pendulum offset
-
double
phi
¶ [rad] spherical pendulum displacement in P0 frame
-
double
theta
¶ [rad] spherical pendulum displacement in P0 frame
-
double
phiDot
¶ [rad/s] time derivative of displacement in P0 frame
-
double
thetaDot
¶ [rad/s] time derivative of displacement in P0 frame
-
double
massFSP
¶ [kg] mass of spherical pendulum pendulum
-
double
cPhi
¶ Term needed for back-sub method
-
double
cTheta
¶ Term needed for back-sub method
-