# SIM_splashdown SIM_splashdown is a simulation of a space craft crew module dropping into a body of water. ![Crew Module Picture](Images/CM_picture.png) ## Building the Simulation In the ```SIM_splashdown ``` directory, type **```trick-CP```** to build the simulation executable. When it's complete, you should see: ``` === Simulation make complete === ``` Now **cd** into ```models/CrewModuleGraphics/``` and type **mvn package**. This builds the graphics client for the simulation. ## Running the Simulation In the SIM_splashdown directory: ``` % S_main_*.exe RUN_test/input.py ``` The Sim Control Panel, and a graphics client called "CM Display" should appear. Click the Start on the Trick Sim Control Panel. Click and drag the mouse on the display to change the viewing orientation. The black and white center of gravity symbol indicates the center of gravity of the vehicle. The blue and white center of gravity symbol indicates the center of gravity of the water that is displaced by the vehicle, that is: the center of buoyancy. ## Dynamics Model ### Vehicle State The vehicle state is defined by the following variables. These are calculated by numerically integrating force, velocity, torque, and body rotation rate over time. #### Linear momentum The linear momentum of the vehicle is determined by integrating the [total force](#total_force) on the vehicle over time. ![linear_momentum_equation](Images/linear_momentum_equation_12_pt.png) - **```crewModule.dyn.momentum```** ( double[3] ) #### Position The position of the vehicle is determined by integrating the [linear velocity](#linear_velocity) of the vehicle over time. ![position_equation](Images/position_equation_12_pt.png) - **```crewModule.dyn.position```** ( double[3] ) #### Angular momentum The angular momentum of the vehicle is determined by integrating the [total torque](#total_torque) of the vehicle over time. ![angular_momentum_equation](Images/angular_momentum_equation_12_pt.png) - **```crewModule.dyn.angular_momentum```** ( double[3] ) #### Body rotation The body rotation matrix of the vehicle is determined by integrating the [body rotation rate](#body_rotation_rate) matrix of the vehicle over time. ![body_rotation_equation](Images/body_rotation_equation_12_pt.png) - **```crewModule.dyn.R```** ( double[3][3] ) ### Vehicle State Derivatives and Dependencies #### Total Force The total force acting on the crew module is the sum of the [force of gravity](#force_of_gravity), the [force of buoyancy](#force_of_buoyancy), and the [force of drag](#force_of_drag). ![F_total_equation](Images/F_total_equation_12_pt.png) - **```crewModule.dyn.force_total```** ( double[3] ) #### Force of Gravity By Newton’s 2nd Law, the force of gravity on the vehicle is the [mass of the vehicle](#vehicle_mass) times the [acceleration of gravity](#acceleration_of_gravity). ![F_gravity_equation](Images/F_gravity_equation_12_pt.png) - **```crewModule.dyn.force_gravity```** ( double[3] ) #### Acceleration of Gravity In this simulation the acceleration is fixed at: ![acceleration_of_gravity_equation](Images/acceleration_of_gravity_equation_12_pt.png) #### Vehicle Mass Default value of the vehicle mass is: ![mass_vehicle_equation](Images/mass_vehicle_equation_12_pt.png) - **```crewModule.dyn.mass_vehicle```** ( double ) #### Force of Buoyancy Buoyancy is a force on an object, that opposes gravity, by a fluid within which it’s immersed. This force is equal to the [mass of the displaced water](#displaced_mass) times the [acceleration of gravity](#acceleration_of_gravity). ![F_buoyancy_equation](Images/F_buoyancy_equation_12_pt.png) - **```crewModule.dyn.force_buoyancy```** ( double[3] ) #### Drag force This drag force is not accurate. It's simply opposes the [linear velocity](#linear_velocity), as a means of sapping energy from the system. ![Force_drag_equation](Images/Force_drag_equation_12_pt.png) - **```crewModule.dyn.force_drag```** ( double[3] ) #### Displaced Mass The displaced mass of the water is equal to the [density of water](#density_of_water) times its [displaced volume](#displaced_volume). ![mass_displaced_equation](Images/mass_displaced_equation_12_pt.png) - **```crewModule.dyn.mass_displaced```** (double) #### Density of Water Default value is the density of sea water: ![density_of_water_equation](Images/density_of_water_equation_12_pt.png) - **```crewModule.dyn.density_of_water```** (double) #### Total Torque The total torque acting on the crew module is the sum of the [buoyancy torque](#buoyancy_torque), and [drag torque](drag_torque). ![torque_total_equation](Images/torque_total_equation_12_pt.png) - **```crewModule.dyn.torque_total```** (double[3]) #### Buoyancy Torque The [force of buoyancy](force_of_buoyancy) acts on the [center of buoyancy](#center_of_buoyancy), that is: the center of mass of the displaced water. So the torque on the vehicle due to buoyancy is: ![Equation 5](Images/torque_buoyancy_equation_12_pt.png) - **```crewModule.dyn.torque_buoyancy```** (double[3]) #### Drag Torque We won't even pretend this drag torque is accurate. It's simply opposes the [angular velocity](#angular_velocity), as a means of sapping energy from the system, to settle the rocking of the crew module. ![Equation 6](Images/torque_drag_12_pt.png) - **```crewModule.dyn.torque_drag```** (double[3]) #### Angular Velocity The angular velocity of the vehicle is a function of the [angular momentum](#angular_momentum), the vehicle [inertia tensor](#inertia_tensor) and the [vehicle body rotation](#body_rotation). ![Equation 7](Images/angular_velocity_equation_12_pt.png) where: ![Equation 8](Images/I_world_inverse_equation_12_pt.png) - **```crewModule.dyn.angular_velocity```** (double[3]) #### Body Rotation Rate The body rotation rate is the product of the skew-symetric-matrix form of the [angular velocity](#angular_velocity), and the [body rotation](#body_rotation) matrix. ![Equation 9](Images/Rdot_equation_12_pt.png) - **```crewModule.dyn.Rdot```** (double[3][3]) #### Linear Velocity The linear velocity of the vehicle is the [linear momentum](#linear_momentum) of the vehicle divided by its [mass](#vehicle_mass). ![Equation 10](Images/velocity_equation_12_pt.png) - **```crewModule.dyn.velocity```** (double[3]) #### Inertia Tensor Default value is: ![Equation 10](Images/inertia_tensor_equation_12_pt.png) - **```crewModule.dyn.I_body ```** (double[3][3]) --- The following convenience function: ```crewModule.dyn.init_inertia_tensor(double A, double B, double C);``` sets the diagonal elements as follows: ``` I_body[0][0] = mass_vehicle * (B*B + C*C); I_body[1][1] = mass_vehicle * (A*A + C*C); I_body[2][2] = mass_vehicle * (A*A + B*B); ``` All other ```I_body``` elements are set to 0. --- #### Displaced Volume The displaced volume is the volume that is 1) within the vehicle and 2) within the body of water. ![Equation 11](Images/Volume_displaced_equation_12_pt.png) - **```crewModule.dyn.volume_displaced```** (double) #### Center of Buoyancy The center of buoyancy is the center of gravity of the displaced volume of water. ![Equation 12](Images/CB_equation_12_pt.png) - **```crewModule.dyn.center_of_buoyancy```** (double[3]) ## Vehicle Shape In this simulation, the shape of the crew module is defined by a sphere, a cone, and a plane, as shown in the picture below. ![Equation 12](Images/CM_shape.png) ```bool CrewModuleShape::containsPoint(double (&test_point)[3])``` returns ```true``` if the given point is 1) in the sphere, 2) in the cone, and 3) on the correct side of the plane. The pseudo-function ```inside(double p[3])``` used in the integrals above represents logic that determines whether a point is within the displaced volume of water. A point is within the displaced volume if 1) it is within the crew module volume, that is ```containsPoint``` returns ```true```, and 2) it is below the surface of the water, that is the z component of the point is less than 0.