mirror of
https://github.com/nasa/trick.git
synced 2025-03-01 03:36:25 +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/6a5a4/6a5a4fb7c69208721c5e828d813ad8dc38f48b28" 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/8c29a/8c29a837a033e0e5ab2fe784d60ded48786a70d3" alt=""| Center of buoyancy, that is, the center of gravity of the displaced water mass.|
|
||
|data:image/s3,"s3://crabby-images/d2488/d24885eccef5324dfa7679fc4e05ab04dc12c27f" alt=""| Center of mass of the vehicle. [Frame??]|
|
||
|data:image/s3,"s3://crabby-images/12c02/12c0296039d96311a7db6ef04bb24b09582ce777" alt=""| Force of buoyancy acting on the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/63079/63079841d540f389805f15ca960309785cc32082" alt=""| Force of gravity.|
|
||
|data:image/s3,"s3://crabby-images/61dc8/61dc85119b8500fc6f3b401467daff54b4447e47" alt=""|Total force acting on the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/ed02a/ed02a92e2d68dd31e839975c478aa216a1fdaa2e" alt=""|Inertia Tensor of the vehicle in the body frame of reference.|
|
||
|data:image/s3,"s3://crabby-images/7b8ea/7b8eadd3021738090f5a72418847cb3e1e348c96" alt=""|Inertia Tensor of the vehicle in the world frame of reference.|
|
||
|data:image/s3,"s3://crabby-images/6289b/6289bcd028d08ad249e08522a777c28075fe40ac" alt=""|Linear momentum of the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/c1e32/c1e322f5b690aac1e28dde0fbef2249f2fd110c1" alt=""|Body to World rotation matrix.|
|
||
|data:image/s3,"s3://crabby-images/95956/95956a14262a22408381c6e4590e63c1b394f947" alt=""|Body to World rotation matrix derivative with respect to time.|
|
||
|data:image/s3,"s3://crabby-images/0d355/0d3556eb40570ad6cc3d63f05de73df658d4d7ae" alt=""| Torque acting on the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/6ee8e/6ee8eddc231f3f1a1711582641eca0845e9dc69d" alt=""| Volume of the water displaced by the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/8e8c9/8e8c96a524e70313243c6038f5f56db56480e336" alt=""| Angular momentum of the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/32ece/32ececfd3b2587d17416123f95a45187b0ba8b25" alt=""|Angular velocity of the vehicle.|
|
||
|data:image/s3,"s3://crabby-images/1fbbd/1fbbd18ed1035ab40f1f5c6cda5ec15a103e25e5" alt=""|Acceleration of gravity.|
|
||
|data:image/s3,"s3://crabby-images/57d9b/57d9b9384f3658ef690300736f8d2659ab08cbce" alt=""|Mass of displaced water.|
|
||
|data:image/s3,"s3://crabby-images/f3c31/f3c319180480ceecca0dd2ac20b9034300610e88" alt=""|Mass of vehicle.|
|
||
|data:image/s3,"s3://crabby-images/5c14c/5c14c4edb65b6da2a481d1ee763e2195b946019e" alt=""|Angular velocity Skew matrix |
|
||
|data:image/s3,"s3://crabby-images/f39c0/f39c0da887616c321360eb3d1e6ebef1ce93346e" alt=""|Vehicle position.|
|
||
|data:image/s3,"s3://crabby-images/a8475/a8475f9eb08d49c9340f8552071faae00dca0e1f" 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/e2f6d/e2f6dcd54ec57337b692f61f04f47f0b6cc35afd" 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/cc7f6/cc7f6987c91f0230a72aaabcbb99e80c92ca28fe" 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/d32a2/d32a232fa18c8da8962adaa50692f04a687c4c02" 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/0153a/0153aa7c58ee95e35221d3d571bcbcee1d3ff336" 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/82b1a/82b1a01f174ab3e16e653aec26cc35532b6682fa" 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/39b04/39b043ef5389c5811804c7dbfdd8fc8ce8336558" 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/9c050/9c0502e0b5bc62f397d2c4280f3dc61005912b58" 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/79685/79685836f7ebc08a1a55c3739ba4fb40ba6f4f36" 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/bacb2/bacb20985394f0979f51c050512f834e38175419" 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/4f990/4f9907617898992d267b459a874f7945e558debe" 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/cb682/cb682d67b23e9987c172a411d0597ce2617af01f" 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/55879/55879406dd12fbce7fb0dbcc130e968bd2b8a060" 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/b97f6/b97f6a77f115277701af3fa8724d474704aa60e9" 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/3344c/3344c5df3cbd8f3f9be4b0668f2d26c56714cdce" 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/ba21f/ba21f4f8363a14b7d28c75ccc2803d880a88aa00" 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/ea6b8/ea6b82fbfb949e1f6afa1806c3df3c79a0784006" alt="Equation 7"
|
||
|
||
where:
|
||
|
||
<a id=Equation-8></a>
|
||
data:image/s3,"s3://crabby-images/7adf6/7adf685825e6679100188e41b8c9734d4afffe61" 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/99089/99089361bf487e29451cdab33e98bbea69529ade" 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/52d9f/52d9f2eda49eac4f94c7c82f85122a885cb891ee" alt="Equation 10"
|
||
|
||
- **```crewModule.dyn.velocity```** (double[3])
|
||
|
||
<a id=inertia_tensor></a>
|
||
#### Inertia Tensor
|
||
|
||
Default value is:
|
||
|
||
data:image/s3,"s3://crabby-images/7d881/7d881bbb2a4b3e103b4e00b686a035c2f8db5ef2" 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/86f05/86f0520b2e5772a209cf693d3ab445672dbccd6d" 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/58696/586969ff45f5d8805d75b67de4fd2b6fd1505493" 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/0bbed/0bbed636d4a9559f344b9374fc6343b1fafb949f" 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.
|