Module: stateEffector
Abstract class that is used to implement an effector attached to the dynamicObject that has a state that needs to be integrated. For example: reaction wheels, flexing solar panels, fuel slosh etc
-
struct BackSubMatrices
- #include <stateEffector.h>
back substitution matrix structure
Public Members
-
struct EffectorMassProps
- #include <stateEffector.h>
Abstract class that is used to implement an effector attached to the dynamicObject that has a state that needs to be integrated. For example: reaction wheels, flexing solar panels, fuel slosh etc.
-
class StateEffector
- #include <stateEffector.h>
state effector class
Subclassed by HubEffector
Public Functions
-
void setStateNameOfPosition(std::string value)
setter for
stateNameOfPositionproperty
-
inline const std::string getStateNameOfPosition() const
getter for
stateNameOfPositionproperty
-
void setStateNameOfVelocity(std::string value)
setter for
stateNameOfVelocityproperty
-
inline const std::string getStateNameOfVelocity() const
getter for
stateNameOfVelocityproperty
-
void setStateNameOfSigma(std::string value)
setter for
stateNameOfSigmaproperty
-
inline const std::string getStateNameOfSigma() const
getter for
stateNameOfSigmaproperty
-
void setStateNameOfOmega(std::string value)
setter for
stateNameOfOmegaproperty
-
inline const std::string getStateNameOfOmega() const
getter for
stateNameOfOmegaproperty
-
void setPropName_m_SC(std::string value)
setter for
propName_m_SCproperty
-
inline const std::string getPropName_m_SC() const
getter for
propName_m_SCproperty
-
void setPropName_mDot_SC(std::string value)
setter for
propName_mDot_SCproperty
-
inline const std::string getPropName_mDot_SC() const
getter for
propName_mDot_SCproperty
-
void setPropName_centerOfMassSC(std::string value)
setter for
propName_centerOfMassSCproperty
-
inline const std::string getPropName_centerOfMassSC() const
getter for
propName_centerOfMassSCproperty
-
void setPropName_inertiaSC(std::string value)
setter for
propName_inertiaSCproperty
-
inline const std::string getPropName_inertiaSC() const
getter for
propName_inertiaSCproperty
-
void setPropName_inertiaPrimeSC(std::string value)
setter for
propName_inertiaPrimeSCproperty
-
inline const std::string getPropName_inertiaPrimeSC() const
getter for
propName_inertiaPrimeSCproperty
-
void setPropName_centerOfMassPrimeSC(std::string value)
setter for
propName_centerOfMassPrimeSCproperty
-
inline const std::string getPropName_centerOfMassPrimeSC() const
getter for
propName_centerOfMassPrimeSCproperty
-
void setPropName_centerOfMassDotSC(std::string value)
setter for
propName_centerOfMassDotSCproperty
-
inline const std::string getPropName_centerOfMassDotSC() const
getter for
propName_centerOfMassDotSCproperty
-
void setPropName_inertialPosition(std::string value)
setter for
propName_inertialPositionproperty
-
inline const std::string getPropName_inertialPosition() const
getter for
propName_inertialPositionproperty
-
void setPropName_inertialVelocity(std::string value)
setter for
propName_inertialVelocityproperty
-
inline const std::string getPropName_inertialVelocity() const
getter for
propName_inertialVelocityproperty
-
void setPropName_vehicleGravity(std::string value)
setter for
propName_vehicleGravityproperty
-
inline const std::string getPropName_vehicleGravity() const
getter for
propName_vehicleGravityproperty
-
void setPropName_prescribedPosition(std::string value)
setter for
propName_prescribedPositionproperty
-
inline const std::string getPropName_prescribedPosition() const
getter for
propName_prescribedPositionproperty
-
void setPropName_prescribedVelocity(std::string value)
setter for
propName_prescribedVelocityproperty
-
inline const std::string getPropName_prescribedVelocity() const
getter for
propName_prescribedVelocityproperty
-
void setPropName_prescribedAcceleration(std::string value)
setter for
propName_prescribedAccelerationproperty
-
inline const std::string getPropName_prescribedAcceleration() const
getter for
propName_prescribedAccelerationproperty
-
void setPropName_prescribedAttitude(std::string value)
setter for
propName_prescribedAttitudeproperty
-
inline const std::string getPropName_prescribedAttitude() const
getter for
propName_prescribedAttitudeproperty
-
void setPropName_prescribedAngVelocity(std::string value)
setter for
propName_prescribedAngVelocityproperty
-
inline const std::string getPropName_prescribedAngVelocity() const
getter for
propName_prescribedAngVelocityproperty
-
void setPropName_prescribedAngAcceleration(std::string value)
setter for
propName_prescribedAngAccelerationproperty
-
inline const std::string getPropName_prescribedAngAcceleration() const
getter for
propName_prescribedAngAccelerationproperty
-
StateEffector()
Contructor.
This is the constructor, just setting the variables to zero
-
virtual ~StateEffector()
Destructor.
This is the destructor, nothing to report here
-
virtual void updateEffectorMassProps(double integTime)
Method for stateEffector to give mass contributions.
This method is for the state effector to provide its contributions of mass and mass rates to the dynamicObject. This allows for the dynamicObject to have access to the total mass, and inerita, mass and inertia rates
-
virtual 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 strictly for the back-substituion method for computing the dynamics of the spacecraft. The back-sub method first computes rDDot_BN_N and omegaDot_BN_B for the spacecraft using these contributions from the state effectors. Then computeDerivatives is called to compute the stateEffectors derivatives using rDDot_BN_N omegaDot_BN_B
-
virtual void addPrescribedMotionCouplingContributions(BackSubMatrices &backSubContr)
Method for adding coupling contributions for state effector branching on prescribed motion.
This method must be implemented to attach a state effector to a prescribed motion state effector. The additional coupling terms required to attach the state effector to the prescribed component are computed in this method. Similar to how the spacecraft module calls updateContributions for all its attached effectors, the prescribed motion module calls this method for all its attached state effectors.
-
virtual void updateEnergyMomContributions(double integTime, Eigen::Vector3d &rotAngMomPntCContr_B, double &rotEnergyContr, Eigen::Vector3d omega_BN_B)
Energy and momentum calculations.
This method allows for an individual stateEffector to add its energy and momentum calculations to the dynamicObject. The analytical devlopement of these contributions can be seen in Basilisk/simulation/dynamics/_Documentation/Basilisk-EnergyAndMomentum-20161219.pdf
-
virtual void modifyStates(double integTime)
Modify state values after integration.
This method allows for an individual stateEffector to modify their states after integration
-
virtual void calcForceTorqueOnBody(double integTime, Eigen::Vector3d omega_BN_B)
Force and torque on s/c due to stateEffector.
This method allows for an individual stateEffector to find the force and torque that the stateEffector is placing on to the body
-
virtual void writeOutputStateMessages(uint64_t integTimeNanos)
Write State Messages after integration.
This method ensures that all dynamics states have their messages written after integation
-
virtual void registerStates(DynParamManager &states) = 0
Method for stateEffectors to register states.
-
virtual void registerProperties(DynParamManager &states)
Method for stateEffectors to register properties.
This method allows the effector to register its properties
-
virtual void addDynamicEffector(DynamicEffector *newDynamicEffector, int segment)
Method to attach a dynamic effector.
This method can only be called for a state effector with override definition set up to support attached dynamic effectors
-
virtual void linkInStates(DynParamManager &states) = 0
Method for stateEffectors to get other states.
-
virtual void linkInPrescribedMotionProperties(DynParamManager &properties)
Method for stateEffectors to access prescribed motion properties.
This method allows the state effector to link in prescribed motion properties
-
virtual void computeDerivatives(double integTime, Eigen::Vector3d rDDot_BN_N, Eigen::Vector3d omegaDot_BN_B, Eigen::Vector3d sigma_BN) = 0
Method for each stateEffector to calculate derivatives.
-
virtual void prependSpacecraftNameToStates()
This method ensures that stateEffectors can be implemented using the multi-spacecraft archticture
Public Members
-
std::string nameOfSpacecraftAttachedTo = ""
class variable
-
std::string parentSpacecraftName = ""
name of the spacecraft the state effector is attached to
-
EffectorMassProps effProps
stateEffectors instantiation of effector mass props
-
Eigen::VectorXd stateDerivContribution
stateEffector contribution to another stateEffector to prevent double-counting
-
Eigen::Vector3d torqueOnBodyPntB_B
[N] Torque that the state effector applies to the body about point B
-
Eigen::Vector3d torqueOnBodyPntC_B
[N] Torque that the state effector applies to the body about point B
-
Eigen::Vector3d r_BP_P
position vector of the spacecraft mody frame origin B relative to the primary spacecraft body frame P. This is used in the SpacecraftSystem module where multiple spacecraft hubs can be a single spacecraft
-
Eigen::Matrix3d dcm_BP
DCM of the spacecraft body frame B relative to primary spacecraft body frame P.
-
BSKLogger bskLogger
BSK Logging.
Protected Attributes
-
std::string stateNameOfPosition = ""
state engine name of the parent rigid body inertial position vector
-
std::string stateNameOfVelocity = ""
state engine name of the parent rigid body inertial velocity vector
-
std::string stateNameOfSigma = ""
state engine name of the parent rigid body inertial attitude
-
std::string stateNameOfOmega = ""
state engine name of the parent rigid body inertial angular velocity vector
-
std::string propName_m_SC = ""
property name of m_SC
-
std::string propName_mDot_SC = ""
property name of mDot_SC
-
std::string propName_centerOfMassSC = ""
property name of centerOfMassSC
-
std::string propName_inertiaSC = ""
property name of inertiaSC
-
std::string propName_inertiaPrimeSC = ""
property name of inertiaPrimeSC
-
std::string propName_centerOfMassPrimeSC = ""
property name of centerOfMassPrimeSC
-
std::string propName_centerOfMassDotSC = ""
property name of centerOfMassDotSC
-
std::string propName_inertialPosition = ""
property name of inertialPosition
-
std::string propName_inertialVelocity = ""
property name of inertialVelocity
-
std::string propName_vehicleGravity = ""
property name of vehicleGravity
-
std::string propName_prescribedPosition = ""
property name of prescribedPosition
-
std::string propName_prescribedVelocity = ""
property name of prescribedVelocity
-
std::string propName_prescribedAcceleration = ""
property name of prescribedAcceleration
-
std::string propName_prescribedAttitude = ""
property name of prescribedAttitude
-
std::string propName_prescribedAngVelocity = ""
property name of prescribedAngVelocity
-
std::string propName_prescribedAngAcceleration = ""
property name of prescribedAngAcceleration
-
Eigen::MatrixXd *prescribedPositionProperty = nullptr
[m] r_PB_B prescribed position relative to hub
-
Eigen::MatrixXd *prescribedVelocityProperty = nullptr
[m/s] rPrime_PB_B prescribed velocity relative to hub
-
Eigen::MatrixXd *prescribedAccelerationProperty = nullptr
[m/s^2] rPrimePrime_PB_B prescribed acceleration relative to hub
-
Eigen::MatrixXd *prescribedAttitudeProperty = nullptr
sigma_PB prescribed MRP attitude relative to hub
-
void setStateNameOfPosition(std::string value)