2022-05-20 15:20:45 -05:00
|
|
|
/************************************************************************
|
|
|
|
PURPOSE: (Simulate a ... .)
|
|
|
|
LIBRARY DEPENDENCIES:
|
|
|
|
((CrewModule/src/CrewModuleDynamics.o)((CrewModule/src/CrewModuleShape.o)))
|
|
|
|
**************************************************************************/
|
|
|
|
#ifndef CREW_MODULE_DYNAMICS_HH
|
|
|
|
#define CREW_MODULE_DYNAMICS_HH
|
|
|
|
|
|
|
|
#include "../include/CrewModuleShape.hh"
|
|
|
|
|
|
|
|
class CrewModuleDynamics {
|
|
|
|
public:
|
|
|
|
|
|
|
|
double R[3][3]; /* (--) Vehicle body to World rotation matrix. */
|
|
|
|
double Rdot[3][3];
|
|
|
|
double angular_velocity[3];
|
|
|
|
double I_body[3][3]; /* (kg*m2) Inertia Tensor in Body frame. */
|
|
|
|
double I_body_inverse[3][3];
|
|
|
|
|
2022-06-16 18:44:49 -05:00
|
|
|
double momentum[3]; /* (N*s) Linear Momentum */
|
|
|
|
double force_total[3]; /* (N) */
|
|
|
|
double force_gravity[3]; /* (N) */
|
|
|
|
double force_buoyancy[3]; /* (N) */
|
|
|
|
double force_drag[3]; /* (N) */
|
2022-05-20 15:20:45 -05:00
|
|
|
|
|
|
|
double position[3]; // (m) Position (world coordinates).
|
|
|
|
double velocity[3]; // (m/s) Velocity (world coordinates).
|
|
|
|
double mass_vehicle; // (kg) Vehicle mass
|
|
|
|
|
|
|
|
double angular_momentum[3]; /* (kg*m2/s) Angular Momentum */
|
|
|
|
|
2022-06-16 18:44:49 -05:00
|
|
|
double torque_buoyancy[3]; /* (N*m) */
|
|
|
|
double torque_drag[3]; /* (N*m) */
|
|
|
|
double torque_total[3]; /* (N*m) */
|
2022-05-20 15:20:45 -05:00
|
|
|
|
|
|
|
double center_of_buoyancy[3];
|
|
|
|
|
2022-06-16 18:44:49 -05:00
|
|
|
double volume_displaced; // (m^3)
|
|
|
|
double mass_displaced; // (kg) mass of displaced water.
|
2022-05-20 15:20:45 -05:00
|
|
|
|
|
|
|
CrewModuleShape crewModuleShape;
|
|
|
|
|
2022-06-16 18:44:49 -05:00
|
|
|
double density_of_water; // (kg/m^3) density of water.
|
|
|
|
|
2022-05-20 15:20:45 -05:00
|
|
|
CrewModuleDynamics();
|
|
|
|
|
|
|
|
void init_defaults();
|
2022-06-16 18:44:49 -05:00
|
|
|
void init_inertia_tensor(double A, double B, double C);
|
2022-05-20 15:20:45 -05:00
|
|
|
void calcVolumeAndCenterOfBuoyancy();
|
|
|
|
void calcVelocity();
|
|
|
|
void calcRDot();
|
|
|
|
void calcAngularVelocity();
|
|
|
|
|
|
|
|
void calcTotalTorque();
|
|
|
|
void calcBuoyancyTorque();
|
|
|
|
void calcDragTorque();
|
|
|
|
|
|
|
|
void calcMassDisplaced();
|
2022-06-16 18:44:49 -05:00
|
|
|
|
2022-05-20 15:20:45 -05:00
|
|
|
void calcTotalForce();
|
|
|
|
void calcBuoyancyForce();
|
|
|
|
void calcGravityForce();
|
|
|
|
void calcDragForce();
|
|
|
|
|
|
|
|
int calc_derivatives();
|
|
|
|
int calc_state();
|
|
|
|
|
|
|
|
};
|
|
|
|
#endif
|