2017-05-11 17:44:43 -05:00
|
|
|
# SIM\_cannon\_analytic
|
2018-08-17 17:07:06 -05:00
|
|
|
|
2015-09-05 15:42:41 -05:00
|
|
|
---
|
2018-08-17 17:07:06 -05:00
|
|
|
|
2015-09-05 15:42:41 -05:00
|
|
|
This is first of eight Trick-based simulations that one builds in the Trick
|
2018-08-17 17:07:06 -05:00
|
|
|
Tutorial (Section 4). It's purpose is to introduce some of the fundamentals
|
2015-09-08 17:05:37 -05:00
|
|
|
of building a Trick simulation.
|
2015-09-05 15:42:41 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
Here we simulate the flight of a cannon ball. We want to know the position and
|
|
|
|
velocity of the cannon ball over time, given an initial position, and
|
2015-09-08 17:05:37 -05:00
|
|
|
velocity, and subject to the following assumptions and limitations:
|
2015-09-05 15:42:41 -05:00
|
|
|
|
|
|
|
* The **only** force acting on the cannon ball is gravity.
|
2015-09-09 17:42:57 -05:00
|
|
|
* The acceleration of gravity (g) is **constant** and equal to -9.81 meters per
|
2015-09-05 15:42:41 -05:00
|
|
|
second squared.
|
2015-09-05 17:12:52 -05:00
|
|
|
* The surface of the ground is defined as where y=0.
|
2015-09-05 15:42:41 -05:00
|
|
|
|
2015-09-08 17:05:37 -05:00
|
|
|
data:image/s3,"s3://crabby-images/7b748/7b748e94b5765047b61b1219a8185aabb485736a" alt=""
|
2015-09-05 15:42:41 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
## Parameterization
|
|
|
|
The following parameters are given default values in a "default_data" job called
|
|
|
|
**cannon\_default\_data**. Their values can be changed in the **input.py** file.
|
2015-09-05 15:42:41 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
| Name | Sim Variable | Type | Units | Symbol | default |
|
|
|
|
|------------------|------------------------|-----------|---------|:---------------------------------:|---------|
|
|
|
|
| Barrel Angle | dyn.cannon.init\_angle | double | radians | data:image/s3,"s3://crabby-images/21d1a/21d1a51fcdf3a5cdc13b2baa61475f2c30efbf3f" alt="theta" | 30*(π/180) |
|
|
|
|
| Speed | dyn.cannon.init\_speed | double | m/s | data:image/s3,"s3://crabby-images/59c58/59c586be31572bdc8dfd806e7f7f32eb0c72ee02" alt="speed" | 50.0 |
|
|
|
|
| Gravity | dyn.cannon.g | double | m/s | data:image/s3,"s3://crabby-images/20241/20241f6544b60083c6a0dfc8884dd08e034ad1ae" alt="g" | 9.81 |
|
|
|
|
| Initial Position | dyn.cannon.pos0 | double[2] | m | data:image/s3,"s3://crabby-images/fdc2d/fdc2d2297c56ce608ef3e582008a307ebba59524" alt="x_0" | data:image/s3,"s3://crabby-images/3cf66/3cf660a98e4c21d39449d4b141c857479a8b8f89" alt="" |
|
2015-09-08 17:05:37 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
## Initialization
|
|
|
|
The initial velocity is calculated in an "initialization" job.
|
2015-09-08 17:05:37 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
| Name | Sim Variable | Type | Units | Calculation |
|
|
|
|
|------------------|:----------------|-----------|-------|-------------------------------|
|
|
|
|
| Initial Velocity | dyn.cannon.vel0 | double[2] | m/s | data:image/s3,"s3://crabby-images/a5cc4/a5cc43a1c0e88d77a6173deae13da7b7dd18f147" alt="" |
|
2015-09-08 17:05:37 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
## State Propagation
|
|
|
|
For each time-step, the following are calculated in a "scheduled" job. Though acceleration is
|
|
|
|
constant in this simulation, it usually isn't for "F=ma" type simulations.
|
2015-09-08 17:05:37 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
| Name | Sim Variable | Type | Units | Calculation |
|
|
|
|
|------------------|:---------------|-----------|-----------|----------------------------------|
|
|
|
|
| Acceleration | dyn.cannon.acc | double[2] | m/s² | data:image/s3,"s3://crabby-images/5ac6e/5ac6ece8acd59106b0c11c04ae33f6366a981d87" alt="" |
|
|
|
|
| Velocity(t) | dyn.cannon.vel | double[2] | m/s | data:image/s3,"s3://crabby-images/89334/89334ace3d9c707f428b4fa6fa766f5edecef533" alt="" |
|
|
|
|
| Position(t) | dyn.cannon.pos | double[2] | m | data:image/s3,"s3://crabby-images/ffa32/ffa32903df28c5baf2d44c877710fba9c07e7c26" alt="" |
|
2015-09-09 17:42:57 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
## Calculating When the Ball Impacts the Ground.
|
|
|
|
The cannon ball will impact the ground, when y-element of the position vector is zero.
|
2015-09-05 15:42:41 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
| Name | Sim Variable | Type | Units | Calculation |
|
|
|
|
|------------------|:----------------------|--------|-------|--------------------------------|
|
|
|
|
| Time of Impact | dyn.cannon.impactTime | double | s | data:image/s3,"s3://crabby-images/93f23/93f23bfe22bdeabe9ac371e884d1e9a8b6fbb64e" alt="" |
|
2015-09-05 15:42:41 -05:00
|
|
|
|
2018-08-17 17:07:06 -05:00
|
|
|
<!--
|
|
|
|
t_{\textrm{impact}} = \frac{ -v_{0_y} - \sqrt{v_{0_y}^2 - 2 g x_{0_y} }}{g}
|
|
|
|
-->
|
2015-09-08 17:05:37 -05:00
|
|
|
|