-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathLz.m
77 lines (61 loc) · 2.25 KB
/
Lz.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
function [R_rytov, k_v, index_valid, R_rytov_Bust] = Lz(V, Psi_v, az, ze, thickness, height, f)
%Lz rytov approximation
% Given: az, azimuth angle; ze, zenith angle; thickness; height;
% f, nyquist frequencies corresponding to given sampling rate
% Return: R_rytov, Rytov ratio vector; k_par, corresponding wavenumber vector
% See also spectral
%convert L,z to km
% thickness = thickness;
% height = height;
%speed of light in vaccum
c = 299792458;
%frequency ranges from 0 to half the sampling rate 100Hz
% ff = [linspace(0,Fs,NFFT/2+1)]';
% ff = [0:Fs/NFFT:Fs]';
k_v = 2 * pi * f / V;
%limit the wavenumber within [10^-3, 0.5*10^-2]
% k_par_ind = find(k_par<=10^-1&k_par>=10^-3);
% index_valid = find(k_v >= 0);
index_valid = find(f > 0.2 & k_v <= 0.11);
% index_valid = find(f > 0.2);
%incident wave number of the signal
k = 2 * pi * 1575.42 * 10^6 / c;
% az is measured from north in North East Down Coords
% az= -az+90;
% if az > 180
% az = az-360;
% end
% Dr. Bust's way
k_x = k_v * cos(Psi_v);
k_y = k_v * sin(Psi_v);
k_squared_Bust = repmat(k_v.^2, 1, length(az)) + ...
(k_x.^2 * cos(az).^2 + k_y.^2 * sin(az).^2) .* repmat(tan(ze).^2, length(k_v), 1);
% Our way
k_squared = k_v.^2 * (sin(Psi_v+az).^2 .* sec(ze).^2 + cos(Psi_v+az).^2);
%effective thickness and height along signal ray path
thickness_effective = thickness * repmat(sec(ze), length(k_v), 1);
height_effective = height * repmat(sec(ze), length(k_v), 1);
ratio = k_squared ./ k;
ratio_Bust = k_squared_Bust ./ k;
dummy = 2 ./ (ratio .* thickness_effective) ...
.* sin(.5*ratio.*thickness_effective) ...
.* cos(ratio.*(height_effective - .5 * thickness_effective));
dummy_Bust = 2 ./ (ratio_Bust .* thickness) ...
.* sin(.5*ratio_Bust.*thickness) ...
.* cos(ratio_Bust.*(height - thickness)/2);
if thickness == 0
S_minus = sin(ratio.*height_effective).^2;
S_plus = cos(ratio.*height_effective).^2;
else
S_minus = 1 - dummy;
S_plus = 1 + dummy;
S_minus_Bust = 1 - dummy_Bust;
S_plus_Bust = 1 + dummy_Bust;
end
R_rytov = S_minus ./ S_plus;
R_rytov_Bust = S_minus_Bust ./ S_plus_Bust;
% loglog(k_v, R_rytov, k_v, R_rytov_Bust);
% Difference between Bust and Ours
% diff_sqr = sumsqr(R_rytov-R_rytov_Bust);
% fprintf('%f\n', diff_sqr);
end