-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathSatellite_positions_and_velocities.m
75 lines (60 loc) · 2.75 KB
/
Satellite_positions_and_velocities.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
function [sat_r_es_e,sat_v_es_e] = Satellite_positions_and_velocities(time,...
GNSS_config)
%Satellite_positions_and_velocities - returns ECEF Cartesian positions and
%ECEF velocities of all satellites in the constellation. Simple circular
%orbits with regularly distributed satellites are modeled.
%
% Software for use with "Principles of GNSS, Inertial, and Multisensor
% Integrated Navigation Systems," Second Edition.
%
% This function created 11/4/2012 by Paul Groves
%
% Inputs:
% time Current simulation time(s)
% GNSS_config
% .no_sat Number of satellites in constellation
% .r_os Orbital radius of satellites (m)
% .inclination Inclination angle of satellites (deg)
% .const_delta_lambda Longitude offset of constellation (deg)
% .const_delta_t Timing offset of constellation (s)
% Outputs:
% sat_r_es_e (no_sat x 3) ECEF satellite position
% sat_v_es_e (no_sat x 3) ECEF satellite velocity
%
% Copyright 2012, Paul Groves
% License: BSD; see license.txt for details
% Constants (sone of these could be changed to inputs at a later date)
mu = 3.986004418E14; %WGS84 Earth gravitational constant (m^3 s^-2)
omega_ie = 7.292115E-5; % Earth rotation rate in rad/s
% Begins
% Convert inclination angle to degrees
inclination = degtorad(GNSS_config.inclination);
% Determine orbital angular rate using (8.8)
omega_is = sqrt(mu / GNSS_config.r_os^3);
% Determine constellation time
const_time = time + GNSS_config.const_delta_t;
% Loop satellites
for j = 1:GNSS_config.no_sat
% (Corrected) argument of latitude
u_os_o = 2*pi*(j-1)/GNSS_config.no_sat + omega_is*const_time;
% Satellite position in the orbital frame from (8.14)
r_os_o = GNSS_config.r_os*[cos(u_os_o);sin(u_os_o);0];
% Longitude of the ascending node from (8.16)
Omega = (pi*mod(j,6)/3 + degtorad(GNSS_config.const_delta_lambda)) -...
omega_ie*const_time;
% ECEF Satellite Position from (8.19)
sat_r_es_e(j,1:3) = [r_os_o(1)*cos(Omega) - r_os_o(2)*...
cos(inclination)*sin(Omega);...
r_os_o(1)*sin(Omega) + r_os_o(2)*cos(inclination)*cos(Omega);...
r_os_o(2)*sin(inclination)]';
% Satellite velocity in the orbital frame from (8.25), noting that with
% a circular orbit r_os_o is constant and the time derivative of u_os_o
% is omega_is.
v_os_o = GNSS_config.r_os*omega_is*[-sin(u_os_o);cos(u_os_o);0];
% ECEF Satellite velocity from (8.26)
sat_v_es_e(j,1:3) = [v_os_o(1)*cos(Omega) - v_os_o(2)*...
cos(inclination)*sin(Omega) + omega_ie*sat_r_es_e(j,2);...
(v_os_o(1)*sin(Omega) + v_os_o(2)*cos(inclination)*cos(Omega) -...
omega_ie*sat_r_es_e(j,1)); v_os_o(2)*sin(inclination)]';
end % for j
% Ends