mirror of
https://gitlab.com/lander-team/lander-sim.git
synced 2025-08-02 11:21:27 +00:00
Replace burnStartTimeCalc.m
This commit is contained in:
@@ -1,27 +1,25 @@
|
||||
function [h0, vb, burnStartTime] = burnStartTimeCalc(Tcurve, tb, M0, mdot, Mb)
|
||||
Mavg = (M0 + Mb)/2;
|
||||
function [h0, vb, burnStartTime] = burnStartTimeCalc(Tcurve, tb, M0, mdot, Mb, v0)
|
||||
g = -9.81;
|
||||
v_prev = v0;
|
||||
h_prev = 0;
|
||||
|
||||
A_tot = 0;
|
||||
|
||||
% Riemann Sum
|
||||
for i = 2:length(Tcurve)
|
||||
if i > 1
|
||||
A = (Tcurve(i, 1) - Tcurve(i - 1, 1)) * Tcurve(i, 2);
|
||||
for i = 1:length(Tcurve)
|
||||
if i < length(Tcurve)
|
||||
dt = Tcurve(i + 1, 1) - Tcurve(i, 1);
|
||||
a = (Tcurve(i, 2) / (M0 - mdot * Tcurve(i + 1, 1))) + g;
|
||||
else
|
||||
A = Tcurve(i, 1) * Tcurve(i, 2);
|
||||
dt = 0;
|
||||
a = (Tcurve(i, 2) / Mb) + g;
|
||||
end
|
||||
A_tot = A_tot + A;
|
||||
|
||||
v = a * dt + v_prev;
|
||||
v_prev = v;
|
||||
h = v*dt + h_prev;
|
||||
h_prev = h;
|
||||
end
|
||||
|
||||
Tavg = A_tot / tb;
|
||||
ueq = Tavg / mdot;
|
||||
delta_ub = ueq * log(M0/Mb) + g*tb;
|
||||
a_avg = (Tavg/Mavg) + g;
|
||||
|
||||
hf = ((delta_ub^2) / (2*-g));
|
||||
hb = ((delta_ub^2) / (2*a_avg))
|
||||
|
||||
h0 = hf + hb + 1;
|
||||
vb = delta_ub;
|
||||
hb = h;
|
||||
hf = v^2 / (2*-g);
|
||||
h0 = hb + hf;
|
||||
vb = v;
|
||||
burnStartTime = vb / -g;
|
Reference in New Issue
Block a user