-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuniversal_lagrange.m
62 lines (57 loc) · 2.17 KB
/
universal_lagrange.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
function [R , V] = universal_lagrange(R0,V0,dt,mu)
%% Universal Lagrange Function and True Anomoly
%
% Jeremy Penn
% 22 September 2017
%
% Revision: 22/09/2017
% 19/10/2017 - Moved the ploting to outside functions to
% increase encapsulation.
% 30/10/2017 - Moved calculation of lagrange functions to
% outisde functions to increase encapsulation.
%
% function [R , V] = UniversalLagrange(R0,V0,dt)
%
% Purpose: This function calculates the true anomaly to find the f and
% g lagrange functions used to calculate the time-dependent
% position and velocity of a satellite.
%
% Inputs: o R0 - A 1x3 vector of the satellite's initial position
% o V0 - A 1x3 vector of the satellite's initial velocity
% o dt - The final time in seconds [s]
% o mu - The Standard Grav Parameter [OPTIONAL]. Defaults
% to Earth [km^3/s^2]
%
% Outputs: o R - The new position.
% o V - The new velocity.
%
% Requires: f_and_g.m, fdot_and_gdot.m
%
if nargin == 3
mu = 398600; % [km^3/s^2] Standard Gravitational Parameter
end
r0 = norm(R0); % [km] Magnitude of initial position
v0 = norm(V0); % [km/s] Magnitude of initival velocity
vr0 = R0*V0'/r0; % [km/s] Orbital velocity
alpha = 2/r0 - v0^2/mu;
X0 = mu^0.5*abs(alpha)*dt; %[km^0.5]Initial estimate of Xi
Xi = X0;
tol = 1E-10; % Tolerance
while(1)
zi = alpha*Xi^2;
[ Cz,Sz] = stumpff( zi );
fX = r0*vr0/(mu)^0.5*Xi^2*Cz + (1 - alpha*r0)*Xi^3*Sz + r0*Xi -(mu)^0.5*dt;
fdX = r0*vr0/(mu)^0.5*Xi*(1 - alpha*Xi^2*Sz) + (1 - alpha*r0)*Xi^2*Cz + r0;
eps = fX/fdX;
Xi = Xi - eps;
if(abs(eps) < tol )
break
end
end
%% Lagrange f and g coefficients in terms of the universal anomaly
[f, g] = f_and_g(Xi,R0, dt, alpha, mu);
R = f*R0 + g*V0;
r = norm(R);
[df, dg] = fdot_and_gdot(Xi, R0, r, alpha, mu);
V = df*R0 + dg*V0;
end