mirror of
https://github.com/nasa/trick.git
synced 2025-03-01 11:41:40 +00:00
312 lines
11 KiB
Markdown
312 lines
11 KiB
Markdown
# SIM_splashdown
|
||
|
||
SIM_splashdown is a simulation of a space craft crew module dropping into a body of water.
|
||
|
||
data:image/s3,"s3://crabby-images/3997e/3997e63919df24fb232d637740ea83de55e6f03f" alt="Crew Module Picture"
|
||
|
||
## 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.
|
||
|
||
<!--
|
||
|
||
| Variable | Definition|
|
||
|---|---|
|
||
|data:image/s3,"s3://crabby-images/140eb/140ebe4caf2ea88204c4e0662e0fa872a027426a" alt=""| Center of buoyancy, that is, the center of gravity of the displaced water mass.|
|
||
|data:image/s3,"s3://crabby-images/20c51/20c51915ebefb1ff23c6861e47cde74aa0302656" alt=""| Center of mass of the vehicle. [Frame??]|
|
||
|data:image/s3,"s3://crabby-images/30d31/30d313acdb15073f8b202fce1ec0e1f1b20fc020" alt=""| Force of buoyancy acting on the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/66df2/66df2ddbfe5d0d574f36a4285224ea898943191a" alt=""| Force of gravity.|
|
||
|data:image/s3,"s3://crabby-images/41f88/41f888f66c190fb1a304314780f0515e51324b6b" alt=""|Total force acting on the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/86165/8616552a17dfb4422c39e86ce5e1f033309d8c34" alt=""|Inertia Tensor of the vehicle in the body frame of reference.|
|
||
|data:image/s3,"s3://crabby-images/ddca2/ddca247ce1edbceab78c62705ed348fb424bc261" alt=""|Inertia Tensor of the vehicle in the world frame of reference.|
|
||
|data:image/s3,"s3://crabby-images/aeacd/aeacd99be294ba322cc4f0f463b573f35cdb4515" alt=""|Linear momentum of the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/8707f/8707f7d059be9d942a95d5842faaabff5381386b" alt=""|Body to World rotation matrix.|
|
||
|data:image/s3,"s3://crabby-images/62eaa/62eaa513a65da422700b03c695452181b44b9304" alt=""|Body to World rotation matrix derivative with respect to time.|
|
||
|data:image/s3,"s3://crabby-images/2f332/2f332939404167204281ae0fbfec0cbe88b5c4fc" alt=""| Torque acting on the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/26252/262525a0c3900ca555b9f26b6f95de846418d666" alt=""| Volume of the water displaced by the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/8c4a7/8c4a7acf6fddacedf33f3bb8cb0f7428d7b3688b" alt=""| Angular momentum of the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/ab899/ab89976a5337da8d2b1fe879d1864395868ef80b" alt=""|Angular velocity of the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/ec5ad/ec5ad5465f073307bf6be820166faea70420e8a3" alt=""|Acceleration of gravity.|
|
||
|data:image/s3,"s3://crabby-images/439af/439afe7bcb330883c0dd49e43a9f923491864ea1" alt=""|Mass of displaced water.|
|
||
|data:image/s3,"s3://crabby-images/a62be/a62be770ad38099d39fe1cf45856aa6ef8e90c0c" alt=""|Mass of vehicle.|
|
||
|data:image/s3,"s3://crabby-images/31b56/31b566cc32129c4e1c0311c619e065ccf8bf5cad" alt=""|Angular velocity Skew matrix |
|
||
|data:image/s3,"s3://crabby-images/e44b2/e44b2547d9c457624ed8affddaf8167c279a3054" alt=""|Vehicle position.|
|
||
|data:image/s3,"s3://crabby-images/2c352/2c3524ec206369d82f34238fe26b1fd00d79f2f2" alt=""|Vehicle velocity.|
|
||
|
||
# Coordinate Systems
|
||
|
||
Coordinate systems here are all right-handed. That is, if the right thumb points along the Z-axis, then the fingers move from the X-axis to the Y-axis as you close your hand.
|
||
|
||
## Body Coordinates
|
||
The geometry of the crew module is defined in **body** coordinates.
|
||
The origin of this coordinate system is the center of gravity of the vehicle.
|
||
Positive Z is toward the top of the vehicle.
|
||
|
||
## World Coordinates
|
||
|
||
-->
|
||
|
||
## 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.
|
||
|
||
<a id=linear_momentum></a>
|
||
#### Linear momentum
|
||
|
||
The linear momentum of the vehicle is determined by integrating the [total force](#total_force) on the vehicle over time.
|
||
|
||
data:image/s3,"s3://crabby-images/39ad2/39ad24a49c4515eadd7faa0498fc00dd10a9984f" alt="linear_momentum_equation"
|
||
|
||
- **```crewModule.dyn.momentum```** ( double[3] )
|
||
|
||
<a id=position></a>
|
||
#### Position
|
||
|
||
The position of the vehicle is determined by integrating the [linear velocity](#linear_velocity) of the vehicle over time.
|
||
|
||
data:image/s3,"s3://crabby-images/ebb14/ebb14e7653bce6a5759003190c4500a239b5501d" alt="position_equation"
|
||
|
||
- **```crewModule.dyn.position```** ( double[3] )
|
||
|
||
<a id=angular_momentum></a>
|
||
#### Angular momentum
|
||
|
||
The angular momentum of the vehicle is determined by integrating the [total torque](#total_torque) of the vehicle over time.
|
||
|
||
data:image/s3,"s3://crabby-images/77cf2/77cf235d085b43fda1c256862365f0984a2b7603" alt="angular_momentum_equation"
|
||
|
||
- **```crewModule.dyn.angular_momentum```** ( double[3] )
|
||
|
||
<a id=body_rotation></a>
|
||
#### 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.
|
||
|
||
data:image/s3,"s3://crabby-images/02462/024621fd8b0f9b36ed8eb83af979f36e8b364d3f" alt="body_rotation_equation"
|
||
|
||
- **```crewModule.dyn.R```** ( double[3][3] )
|
||
|
||
### Vehicle State Derivatives and Dependencies
|
||
|
||
<a id=total_force></a>
|
||
#### 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).
|
||
|
||
<a id=Equation-1></a>
|
||
data:image/s3,"s3://crabby-images/8f133/8f1338ec96657eaab402c29e494fa0f1f7fe0118" alt="F_total_equation"
|
||
|
||
- **```crewModule.dyn.force_total```** ( double[3] )
|
||
|
||
|
||
<a id=force_of_gravity></a>
|
||
#### 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).
|
||
|
||
<a id=Equation-2></a>
|
||
data:image/s3,"s3://crabby-images/965e2/965e2634c2d6d723adbe844bd1649776af8e28da" alt="F_gravity_equation"
|
||
|
||
- **```crewModule.dyn.force_gravity```** ( double[3] )
|
||
|
||
<a id=acceleration_of_gravity></a>
|
||
#### Acceleration of Gravity
|
||
|
||
In this simulation the acceleration is fixed at:
|
||
|
||
<a id=acceleration_of_gravity_equation></a>
|
||
data:image/s3,"s3://crabby-images/73be4/73be4a6e563b5a44c6966c305c2a87509c4351b3" alt="acceleration_of_gravity_equation"
|
||
|
||
<a id=vehicle_mass></a>
|
||
#### Vehicle Mass
|
||
|
||
Default value of the vehicle mass is:
|
||
|
||
data:image/s3,"s3://crabby-images/6760c/6760c283636cc93a8fd306a80806a982fa7c3788" alt="mass_vehicle_equation"
|
||
|
||
- **```crewModule.dyn.mass_vehicle```** ( double )
|
||
|
||
<a id=force_of_buoyancy></a>
|
||
#### 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).
|
||
|
||
<a id=Equation-3></a>
|
||
data:image/s3,"s3://crabby-images/e1268/e12680431283c7f20bb6ab3362cd4630bd17be53" alt="F_buoyancy_equation"
|
||
|
||
- **```crewModule.dyn.force_buoyancy```** ( double[3] )
|
||
|
||
|
||
<a id=force_of_drag></a>
|
||
#### 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.
|
||
|
||
data:image/s3,"s3://crabby-images/41dc8/41dc8808d524a400fac4c159123a90e84d50bc88" alt="Force_drag_equation"
|
||
|
||
- **```crewModule.dyn.force_drag```** ( double[3] )
|
||
|
||
<a id=displaced_mass></a>
|
||
#### Displaced Mass
|
||
|
||
The displaced mass of the water is equal to the [density of water](#density_of_water) times its [displaced volume](#displaced_volume).
|
||
|
||
<a id=Equation-4></a>
|
||
data:image/s3,"s3://crabby-images/2fa69/2fa691b34f59790fbf92ad1a443f558f92f45444" alt="mass_displaced_equation"
|
||
|
||
- **```crewModule.dyn.mass_displaced```** (double)
|
||
|
||
<a id=density_of_water></a>
|
||
#### Density of Water
|
||
|
||
Default value is the density of sea water:
|
||
|
||
<a id=Equation-4></a>
|
||
data:image/s3,"s3://crabby-images/444ac/444ac76c6bb484c9d5c3103421fd10d1f97dba31" alt="density_of_water_equation"
|
||
|
||
- **```crewModule.dyn.density_of_water```** (double)
|
||
|
||
<a id=total_torque></a>
|
||
#### Total Torque
|
||
|
||
The total torque acting on the crew module is the sum of the [buoyancy torque](#buoyancy_torque), and [drag torque](#drag_torque).
|
||
|
||
data:image/s3,"s3://crabby-images/894ea/894ea5899003b24e2d3b461801fdab69691434c6" alt="torque_total_equation"
|
||
|
||
- **```crewModule.dyn.torque_total```** (double[3])
|
||
|
||
<a id=buoyancy_torque></a>
|
||
#### 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:
|
||
|
||
<a id=Equation-5></a>
|
||
data:image/s3,"s3://crabby-images/5083e/5083e2bc039e7d223443b11968c6cfed9bce40b0" alt="Equation 5"
|
||
|
||
- **```crewModule.dyn.torque_buoyancy```** (double[3])
|
||
|
||
<a id=drag_torque></a>
|
||
#### 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.
|
||
|
||
<a id=Equation-6></a>
|
||
data:image/s3,"s3://crabby-images/e2d3f/e2d3fb57bc3c40b0bebcb3ecc33cd9bfa46ffb3a" alt="Equation 6"
|
||
|
||
- **```crewModule.dyn.torque_drag```** (double[3])
|
||
|
||
<a id=angular_velocity></a>
|
||
#### 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).
|
||
|
||
<a id=Equation-7></a>
|
||
data:image/s3,"s3://crabby-images/9fa15/9fa15222cb216eaeed852a295882cc372ba27541" alt="Equation 7"
|
||
|
||
where:
|
||
|
||
<a id=Equation-8></a>
|
||
data:image/s3,"s3://crabby-images/0ecd4/0ecd40a20179ebd0e3f12102148fd67a42b6cc03" alt="Equation 8"
|
||
|
||
- **```crewModule.dyn.angular_velocity```** (double[3])
|
||
|
||
<a id=body_rotation_rate></a>
|
||
#### 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.
|
||
|
||
<a id=Equation-9></a>
|
||
data:image/s3,"s3://crabby-images/f332b/f332b787c539c4aef968dbf727c7fb28aad433b4" alt="Equation 9"
|
||
|
||
- **```crewModule.dyn.Rdot```** (double[3][3])
|
||
|
||
|
||
<a id=linear_velocity></a>
|
||
#### Linear Velocity
|
||
|
||
The linear velocity of the vehicle is the [linear momentum](#linear_momentum) of the vehicle divided by its [mass](#vehicle_mass).
|
||
|
||
<a id=Equation-10></a>
|
||
data:image/s3,"s3://crabby-images/05a4d/05a4de486b00e9bf8982cb6aa5cb62d4a0c40036" alt="Equation 10"
|
||
|
||
- **```crewModule.dyn.velocity```** (double[3])
|
||
|
||
<a id=inertia_tensor></a>
|
||
#### Inertia Tensor
|
||
|
||
Default value is:
|
||
|
||
data:image/s3,"s3://crabby-images/8f115/8f115304c188cdfda9fc4ef3a2dbac7da402326d" alt="Equation 10"
|
||
|
||
- **```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.
|
||
|
||
---
|
||
|
||
<a id=displaced_volume></a>
|
||
#### Displaced Volume
|
||
|
||
The displaced volume is the volume that is 1) within the vehicle and 2) within the body of water.
|
||
|
||
<a id=Equation-11></a>
|
||
data:image/s3,"s3://crabby-images/b395d/b395d289e4f09dd47e0cd510ae511b6f6c32666f" alt="Equation 11"
|
||
|
||
- **```crewModule.dyn.volume_displaced```** (double)
|
||
|
||
<a id=center_of_buoyancy></a>
|
||
#### Center of Buoyancy
|
||
|
||
The center of buoyancy is the center of gravity of the displaced volume of water.
|
||
|
||
<a id=Equation-12></a>
|
||
data:image/s3,"s3://crabby-images/6df1b/6df1b959a94ae16917f525543fc3c0bad51ad9fb" alt="Equation 12"
|
||
|
||
- **```crewModule.dyn.center_of_buoyancy```** (double[3])
|
||
|
||
<a id=vehicle_shape></a>
|
||
## 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.
|
||
|
||
data:image/s3,"s3://crabby-images/fdd44/fdd44d5d28fc5ff74b46eceac63f41e2904fe080" alt="Equation 12"
|
||
|
||
```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.
|
||
|
||
<a id=inside_pseudo_function></a>
|
||
The pseudo-function ```inside(double p[3])``` used in the integrals [above](#displaced_volume) 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.
|