-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathGS_antenna.m
262 lines (217 loc) · 9.47 KB
/
GS_antenna.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
clc,clear,close all
%% create satellite scenario
startTime = datetime(2024,3,16,8,0,0);
stopTime = startTime + minutes(10);
sampleTime = 60; % seconds
sc = satelliteScenario(startTime,stopTime,sampleTime);
%% Add Medium-Earth Orbit Satellite
Re = 6378e3; % Radius of Earth
LEO_altitude = 650e3;
semiMajorAxis = Re + LEO_altitude; % In m
eccentricity = 0.000258;
inclination = 51.65; % In degrees
raan = 0; % Right ascension of ascending node, in degrees
argOfPeriapsis = 0; % In degrees
trueAnomaly = 0; % In degrees
leoSat = satellite(sc, semiMajorAxis, ...
eccentricity, ...
inclination, ...
raan, ...
argOfPeriapsis, ...
trueAnomaly, ...
Name = "LEO Satellite", ...
OrbitPropagator = "two-body-keplerian");
%% Add Interfering Satellite Constellation
interferingSat = satellite(sc,"leoSatelliteConstellation.tle");
%% Add Transmitter to LEO Satellite
interferenceFreq = 2.99e9; % In Hz
rng("default");
txInterferingSat = transmitter(interferingSat, ...
Frequency = interferenceFreq, ... % In Hz
Power = 10+10*rand(1,numel(interferingSat))); % In dBW
gaussianAntenna(txInterferingSat, ...
DishDiameter = 0.2); % In m
%% Add GS(TW_TASA 國家太空中心)
gs = groundStation(sc, ...
24.4703, ... % Latitude in degrees
121.0015, ... % Longitude in degrees
Name = "TW_GS");
%% groundStationAntennaType
groundStationAntennaType = "Uniform Rectangular Array";
%% Add receiver to GS
switch groundStationAntennaType
case {"Gaussian Antenna","Parabolic Reflector"}
% When Gaussian Antenna or Parabolic Reflector is selected, attach
% a gimbal to the ground station.
gim = gimbal(gs, ...
MountingLocation = [0;0;-5], ... % In m
MountingAngles = [0;180;0]); % In degrees
% Set the gimbal to track the MEO satellite.
pointAt(gim,meoSat);
if groundStationAntennaType == "Gaussian Antenna"
% When Gaussian Antenna is selected
% Create the receiver object and add it to the gimbal
rxGs = receiver(gim, ...
MountingLocation = [0;0;1]); % In m
% Provide the Gaussian Antenna specifications
gaussianAntenna(rxGs, ...
DishDiameter = 0.8); % In m
else
% When Parabolic Reflector is selected
% Size the antenna based on the frequency
% Requires Antenna Toolbox(TM)
ant = design(reflectorParabolic,interferenceFreq);
% Create the receiver object and add it to the gimbal
rxGs = receiver(gim, ...
Antenna = ant, ...
MountingLocation = [0;0;1]); % In m
end
case "Uniform Rectangular Array"
% When Uniform Rectangular Array is selected
% Determine the wavelength of the downlink signal
c = physconst('LightSpeed');
lambda = c/interferenceFreq;
% Define array size
nrow = 8;
ncol = 8;
% Define element spacing
drow = lambda/2;
dcol = lambda/2;
% Create a back-baffled 6-by-6 antenna array
% Requires Phased Array System Toolbox(TM)
ant = phased.URA(Size = [nrow ncol], ...
ElementSpacing = [drow dcol]);
ant.Element.BackBaffled = true;
% Create the receiver object and add it to the ground station
rxGs = receiver(gs, ...
Antenna = ant, ...
MountingAngles = [0;90;0]); % In degrees
end
c = physconst('LightSpeed');
lambda = c/interferenceFreq;
% Define array size
nrow = 8;
ncol = 8;
% Define element spacing
drow = lambda/2;
dcol = lambda/2;
% Create a back-baffled 6-by-6 antenna array
% Requires Phased Array System Toolbox(TM)
ant = phased.URA(Size = [nrow ncol], ...
ElementSpacing = [drow dcol]);
ant.Element.BackBaffled = true;
% Create the receiver object and add it to the ground station
rxGs = receiver(gs, ...
Antenna = ant, ...
MountingAngles = [0;90;0]); % In degrees
% Create Access Analysis Between Interfering Satellite Constellation and Ground Station
ac = access(interferingSat,gs);
ac.LineColor = [1 1 0];
% set tracking targets for satellite
pointAt([leoSat interferingSat],gs);
downlink = link(txInterferingSat,rxGs);
lnkInterference = link(txInterferingSat,rxGs);
v = satelliteScenarioViewer(sc,ShowDetails=false);
pattern(txInterferingSat, ...
Size = 1000000); % In m
pattern(rxGs,interferenceFreq, ...
Size = 1000000); % In m
% Set camera position and orientation to view the ground station antenna
% radiation pattern.
campos(v,-8,172,2500000);
camheading(v,40);
campitch(v,-60);
if groundStationAntennaType == "Gaussian Antenna" || groundStationAntennaType == "Parabolic Reflector"
play(sc);
campos(v,-8,172,2500000);
camheading(v,40);
campitch(v,-60);
end
if groundStationAntennaType == "Gaussian Antenna" || groundStationAntennaType == "Parabolic Reflector"
v.CurrentTime = datetime(2024,4,18,22,0,0);
end
if groundStationAntennaType == "Uniform Rectangular Array"
play(sc);
campos(v,-8,172,2500000);
camheading(v,40);
campitch(v,-60);
end
%% play scenario video
% can be modify to other type
if groundStationAntennaType == "Uniform Rectangular Array"
% Set AutoSimulate to false.
sc.AutoSimulate = false;
while advance(sc)
% Determine the access status history for each LEO satellite
% corresponding to the current SimulationTime.
acStatusHistory = accessStatus(ac);
acStatus = acStatusHistory(:,end);
% Determine the LEO satellites that are visible to the ground
% station. These are the satellites that will potentially
% interfere with the ground station at the current simulation
% time.
currentInterferingSat = interferingSat(acStatus == true);
% Determine the direction of the MEO satellite in the body frame of
% the Uniform Rectangular Array. This is the lookout direction of
% the array.
[azdHistory,eldHistory] = aer(rxGs,leoSat,CoordinateFrame='body');
azd = azdHistory(:,end);
eld = eldHistory(:,end);
% Determine the direction of these interfering satellites in
% the body frame of the Uniform Rectangular Array. These are
% the directions in which the array must point a null.
[aznHistory,elnHistory] = aer(rxGs,currentInterferingSat,CoordinateFrame='body');
azn = aznHistory(:,end);
eln = elnHistory(:,end);
% Calculate the steering vectors for lookout direction.
% Requires Phased Array System Toolbox.
wd = steervec(getElementPosition(ant)/lambda,[wrapTo180(azd);-eld]);
% Calculate the steering vector for null directions.
% Requires Phased Array System Toolbox.
wn = steervec(getElementPosition(ant)/lambda,[wrapTo180(azn)';-eln']);
% Compute the response of desired steering at null direction.
rn = (wn'*wn)\(wn'*wd);
% Sidelobe canceler - remove the response at null direction.
w = wd-wn*rn;
% Assign the weights to the phased array.
pointAt(rxGs,Weights=w);
end
end
% Helper Functions
function overlapFactor = getOverlapFactor(txFreq,txBW,interferenceFreq,interferenceBW)
% getOverlapFactor provides the amount of interference bandwidth overlapped
% with transmission bandwidth
txFreq_Limits = [txFreq-(txBW/2) txFreq+(txBW/2)];
interferenceFreq_Limits = [interferenceFreq-(interferenceBW/2) ...
interferenceFreq+(interferenceBW/2)];
if (interferenceFreq_Limits(2) < txFreq_Limits(1)) || ...
(interferenceFreq_Limits(1) > txFreq_Limits(2))
% If no overlap exists between transmission bandwidth and
% interfering bandwidth, then overlap factor is 0
overlapFactor = 0;
elseif (interferenceFreq_Limits(2) <= txFreq_Limits(2)) && ...
(interferenceFreq_Limits(1) >= txFreq_Limits(1))
% If interfering bandwidth lies completely within transmission
% bandwidth, then overlap factor is 1
overlapFactor = 1;
elseif (interferenceFreq_Limits(2) > txFreq_Limits(2)) && ...
(interferenceFreq_Limits(1) < txFreq_Limits(1))
% If transmission bandwidth lies completely within interfering
% bandwidth, then overlap factor is the ratio of transmission
% bandwidth with that of interference bandwidth
overlapFactor = txBW/interferenceBW;
elseif (interferenceFreq_Limits(2) <= txFreq_Limits(2)) && ...
(interferenceFreq_Limits(1) <= txFreq_Limits(1))
% If the start edge of transmission bandwidth lies within
% interfering bandwidth, then overlap factor is the ratio of
% difference from last edge of interfering bandwidth and first edge
% of signal bandwidth, with that of interference bandwidth
overlapFactor = (interferenceFreq_Limits(2)-txFreq_Limits(1))/interferenceBW;
else
% If the last edge of transmission bandwidth lies within
% interfering bandwidth, then overlap factor is the ratio of difference
% from last edge of signal bandwidth and first edge of interfering
% bandwidth, with that of interference bandwidth
overlapFactor = (-interferenceFreq_Limits(1)+txFreq_Limits(2))/interferenceBW;
end
end