-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplotAll.m
93 lines (65 loc) · 2.07 KB
/
plotAll.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
function plotAccel(figNum, g, m, A_p, A_p_par, rho, C_d, C_d_par, T1, t_1, T2, t_2)
v_0 = 0;
x_0 = 0;
t_0 = 0;
%% initial burn (stage 1)
v_max = sqrt( (2 * T1 - m*g)/(rho * C_d * A_p) );
b = T1/m - g;
v = @(t) v_max * tanh(b / v_max * (t - t_0) + atanh(v_0 / v_max) ); %v_0 < v_max
x = @(t) x_0 + v_max^2/b * ...
(log(sinh( b/v_max * (t-t_0) + acoth(v_0/v_max) ) ) ...
- log(sinh(acoth(v_0/v_max))));
a_v = @(v) T1/m - 0.5 * C_d * A_p * rho/m * v * abs(v) - g;
a = @(t) a_v(v(t));
figure(figNum);
clf;
hold on;
fplot(a, [t_0 t_1], 'b');
fplot(v, [t_0 t_1], 'm');
fplot(x, [t_0 t_1], 'k');
v_1 = v(t_1);
x_1 = x(t_1);
%% sustainer burn (stage 2)
v_max = sqrt( (2 * T2 - m*g)/(rho * C_d * A_p) );
if v_1 < v_max
disp('The rocket will not decelerate in the second stage.');
else
disp('The rocket will decelerate in the second stage.')
end
b = T2/m - g;
v = @(t) v_max * tanh(b / v_max * (t - t_1) + atanh(v_1 / v_max) ); %v_1 < v_max
x = @(t) x_1 + v_max^2/b * ...
(log(sinh( b/v_max * (t-t_1) + acoth(v_1/v_max) ) ) ...
- log(sinh(acoth(v_1/v_max))));
a_v = @(v) T2/m - 0.5 * C_d * A_p * rho/m * v * abs(v) - g;
a = @(t) a_v(v(t));
fplot(a, [t_1 t_2], 'b');
fplot(v, [t_1 t_2], 'm');
fplot(x, [t_1 t_2], 'k');
v_2 = v(t_2);
x_2 = x(t_2);
%% thrustless ascent (stage 3)
v_t = sqrt( 2 * m * g / (rho * C_d * A_p));
t_3 = t_2 + v_t/g * atan(v_2/v_t); %time to apogee
v = @(t) v_t * tan( -g/v_t * (t - t_2) + atan(v_2/v_t));
x = @(t) x_2 + v_t^2/g * ...
(log( cos(g/v_t * (t - t_2) - atan(v_2/v_t))) ...
+ log( sqrt(1 + v_2^2/v_t^2)));
a_v = @(v) -g * (1 + v^2 / v_t^2);
a = @(t) a_v(v(t));
fplot(a, [t_2 t_3], 'b');
fplot(v, [t_2 t_3], 'm');
fplot(x, [t_2 t_3], 'k');
v_3 = v(t_3);
x_3 = x(t_3);
%% parachute descent (stage 4)
v_t = sqrt( 2 * m * g / (rho * C_d_par * A_p_par));
t_4 = t_3 + v_t/g * acosh(exp(g/v_t^2 * x_3));
v = @(t) v_t * tanh( -g/v_t *( t - t_3));
x = @(t) x_3 - v_t^2/g * log( cosh( -g/v_t * (t - t_3)));
a_v = @(v) -g * (1 - v^2/v_t^2);
a = @(t) a_v(v(t));
fplot(a, [t_3 t_4], 'b');
fplot(v, [t_3 t_4], 'm');
fplot(x, [t_3 t_4], 'k');
end