| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
/* |
|
2
|
|
|
|
|
|
|
*+ |
|
3
|
|
|
|
|
|
|
* Name: |
|
4
|
|
|
|
|
|
|
* palRefro |
|
5
|
|
|
|
|
|
|
|
|
6
|
|
|
|
|
|
|
* Purpose: |
|
7
|
|
|
|
|
|
|
* Atmospheric refraction for radio and optical/IR wavelengths |
|
8
|
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
* Language: |
|
10
|
|
|
|
|
|
|
* Starlink ANSI C |
|
11
|
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
* Type of Module: |
|
13
|
|
|
|
|
|
|
* Library routine |
|
14
|
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
* Invocation: |
|
16
|
|
|
|
|
|
|
* void palRefro( double zobs, double hm, double tdk, double pmb, |
|
17
|
|
|
|
|
|
|
* double rh, double wl, double phi, double tlr, |
|
18
|
|
|
|
|
|
|
* double eps, double * ref ) { |
|
19
|
|
|
|
|
|
|
|
|
20
|
|
|
|
|
|
|
* Arguments: |
|
21
|
|
|
|
|
|
|
* zobs = double (Given) |
|
22
|
|
|
|
|
|
|
* Observed zenith distance of the source (radian) |
|
23
|
|
|
|
|
|
|
* hm = double (Given) |
|
24
|
|
|
|
|
|
|
* Height of the observer above sea level (metre) |
|
25
|
|
|
|
|
|
|
* tdk = double (Given) |
|
26
|
|
|
|
|
|
|
* Ambient temperature at the observer (K) |
|
27
|
|
|
|
|
|
|
* pmb = double (Given) |
|
28
|
|
|
|
|
|
|
* Pressure at the observer (millibar) |
|
29
|
|
|
|
|
|
|
* rh = double (Given) |
|
30
|
|
|
|
|
|
|
* Relative humidity at the observer (range 0-1) |
|
31
|
|
|
|
|
|
|
* wl = double (Given) |
|
32
|
|
|
|
|
|
|
* Effective wavelength of the source (micrometre) |
|
33
|
|
|
|
|
|
|
* phi = double (Given) |
|
34
|
|
|
|
|
|
|
* Latitude of the observer (radian, astronomical) |
|
35
|
|
|
|
|
|
|
* tlr = double (Given) |
|
36
|
|
|
|
|
|
|
* Temperature lapse rate in the troposphere (K/metre) |
|
37
|
|
|
|
|
|
|
* eps = double (Given) |
|
38
|
|
|
|
|
|
|
* Precision required to terminate iteration (radian) |
|
39
|
|
|
|
|
|
|
* ref = double * (Returned) |
|
40
|
|
|
|
|
|
|
* Refraction: in vacuao ZD minus observed ZD (radian) |
|
41
|
|
|
|
|
|
|
|
|
42
|
|
|
|
|
|
|
* Description: |
|
43
|
|
|
|
|
|
|
* Calculates the atmospheric refraction for radio and optical/IR |
|
44
|
|
|
|
|
|
|
* wavelengths. |
|
45
|
|
|
|
|
|
|
|
|
46
|
|
|
|
|
|
|
* Authors: |
|
47
|
|
|
|
|
|
|
* PTW: Patrick T. Wallace |
|
48
|
|
|
|
|
|
|
* TIMJ: Tim Jenness (JAC, Hawaii) |
|
49
|
|
|
|
|
|
|
* {enter_new_authors_here} |
|
50
|
|
|
|
|
|
|
|
|
51
|
|
|
|
|
|
|
* Notes: |
|
52
|
|
|
|
|
|
|
* - A suggested value for the TLR argument is 0.0065. The |
|
53
|
|
|
|
|
|
|
* refraction is significantly affected by TLR, and if studies |
|
54
|
|
|
|
|
|
|
* of the local atmosphere have been carried out a better TLR |
|
55
|
|
|
|
|
|
|
* value may be available. The sign of the supplied TLR value |
|
56
|
|
|
|
|
|
|
* is ignored. |
|
57
|
|
|
|
|
|
|
* |
|
58
|
|
|
|
|
|
|
* - A suggested value for the EPS argument is 1E-8. The result is |
|
59
|
|
|
|
|
|
|
* usually at least two orders of magnitude more computationally |
|
60
|
|
|
|
|
|
|
* precise than the supplied EPS value. |
|
61
|
|
|
|
|
|
|
* |
|
62
|
|
|
|
|
|
|
* - The routine computes the refraction for zenith distances up |
|
63
|
|
|
|
|
|
|
* to and a little beyond 90 deg using the method of Hohenkerk |
|
64
|
|
|
|
|
|
|
* and Sinclair (NAO Technical Notes 59 and 63, subsequently adopted |
|
65
|
|
|
|
|
|
|
* in the Explanatory Supplement, 1992 edition - see section 3.281). |
|
66
|
|
|
|
|
|
|
* |
|
67
|
|
|
|
|
|
|
* - The code is a development of the optical/IR refraction subroutine |
|
68
|
|
|
|
|
|
|
* AREF of C.Hohenkerk (HMNAO, September 1984), with extensions to |
|
69
|
|
|
|
|
|
|
* support the radio case. Apart from merely cosmetic changes, the |
|
70
|
|
|
|
|
|
|
* following modifications to the original HMNAO optical/IR refraction |
|
71
|
|
|
|
|
|
|
* code have been made: |
|
72
|
|
|
|
|
|
|
* |
|
73
|
|
|
|
|
|
|
* . The angle arguments have been changed to radians. |
|
74
|
|
|
|
|
|
|
* |
|
75
|
|
|
|
|
|
|
* . Any value of ZOBS is allowed (see note 6, below). |
|
76
|
|
|
|
|
|
|
* |
|
77
|
|
|
|
|
|
|
* . Other argument values have been limited to safe values. |
|
78
|
|
|
|
|
|
|
* |
|
79
|
|
|
|
|
|
|
* . Murray's values for the gas constants have been used |
|
80
|
|
|
|
|
|
|
* (Vectorial Astrometry, Adam Hilger, 1983). |
|
81
|
|
|
|
|
|
|
* |
|
82
|
|
|
|
|
|
|
* . The numerical integration phase has been rearranged for |
|
83
|
|
|
|
|
|
|
* extra clarity. |
|
84
|
|
|
|
|
|
|
* |
|
85
|
|
|
|
|
|
|
* . A better model for Ps(T) has been adopted (taken from |
|
86
|
|
|
|
|
|
|
* Gill, Atmosphere-Ocean Dynamics, Academic Press, 1982). |
|
87
|
|
|
|
|
|
|
* |
|
88
|
|
|
|
|
|
|
* . More accurate expressions for Pwo have been adopted |
|
89
|
|
|
|
|
|
|
* (again from Gill 1982). |
|
90
|
|
|
|
|
|
|
* |
|
91
|
|
|
|
|
|
|
* . The formula for the water vapour pressure, given the |
|
92
|
|
|
|
|
|
|
* saturation pressure and the relative humidity, is from |
|
93
|
|
|
|
|
|
|
* Crane (1976), expression 2.5.5. |
|
94
|
|
|
|
|
|
|
|
|
95
|
|
|
|
|
|
|
* . Provision for radio wavelengths has been added using |
|
96
|
|
|
|
|
|
|
* expressions devised by A.T.Sinclair, RGO (private |
|
97
|
|
|
|
|
|
|
* communication 1989). The refractivity model currently |
|
98
|
|
|
|
|
|
|
* used is from J.M.Rueger, "Refractive Index Formulae for |
|
99
|
|
|
|
|
|
|
* Electronic Distance Measurement with Radio and Millimetre |
|
100
|
|
|
|
|
|
|
* Waves", in Unisurv Report S-68 (2002), School of Surveying |
|
101
|
|
|
|
|
|
|
* and Spatial Information Systems, University of New South |
|
102
|
|
|
|
|
|
|
* Wales, Sydney, Australia. |
|
103
|
|
|
|
|
|
|
* |
|
104
|
|
|
|
|
|
|
* . The optical refractivity for dry air is from Resolution 3 of |
|
105
|
|
|
|
|
|
|
* the International Association of Geodesy adopted at the XXIIth |
|
106
|
|
|
|
|
|
|
* General Assembly in Birmingham, UK, 1999. |
|
107
|
|
|
|
|
|
|
* |
|
108
|
|
|
|
|
|
|
* . Various small changes have been made to gain speed. |
|
109
|
|
|
|
|
|
|
* |
|
110
|
|
|
|
|
|
|
* - The radio refraction is chosen by specifying WL > 100 micrometres. |
|
111
|
|
|
|
|
|
|
* Because the algorithm takes no account of the ionosphere, the |
|
112
|
|
|
|
|
|
|
* accuracy deteriorates at low frequencies, below about 30 MHz. |
|
113
|
|
|
|
|
|
|
* |
|
114
|
|
|
|
|
|
|
* - Before use, the value of ZOBS is expressed in the range +/- pi. |
|
115
|
|
|
|
|
|
|
* If this ranged ZOBS is -ve, the result REF is computed from its |
|
116
|
|
|
|
|
|
|
* absolute value before being made -ve to match. In addition, if |
|
117
|
|
|
|
|
|
|
* it has an absolute value greater than 93 deg, a fixed REF value |
|
118
|
|
|
|
|
|
|
* equal to the result for ZOBS = 93 deg is returned, appropriately |
|
119
|
|
|
|
|
|
|
* signed. |
|
120
|
|
|
|
|
|
|
* |
|
121
|
|
|
|
|
|
|
* - As in the original Hohenkerk and Sinclair algorithm, fixed values |
|
122
|
|
|
|
|
|
|
* of the water vapour polytrope exponent, the height of the |
|
123
|
|
|
|
|
|
|
* tropopause, and the height at which refraction is negligible are |
|
124
|
|
|
|
|
|
|
* used. |
|
125
|
|
|
|
|
|
|
* |
|
126
|
|
|
|
|
|
|
* - The radio refraction has been tested against work done by |
|
127
|
|
|
|
|
|
|
* Iain Coulson, JACH, (private communication 1995) for the |
|
128
|
|
|
|
|
|
|
* James Clerk Maxwell Telescope, Mauna Kea. For typical conditions, |
|
129
|
|
|
|
|
|
|
* agreement at the 0.1 arcsec level is achieved for moderate ZD, |
|
130
|
|
|
|
|
|
|
* worsening to perhaps 0.5-1.0 arcsec at ZD 80 deg. At hot and |
|
131
|
|
|
|
|
|
|
* humid sea-level sites the accuracy will not be as good. |
|
132
|
|
|
|
|
|
|
* |
|
133
|
|
|
|
|
|
|
* - It should be noted that the relative humidity RH is formally |
|
134
|
|
|
|
|
|
|
* defined in terms of "mixing ratio" rather than pressures or |
|
135
|
|
|
|
|
|
|
* densities as is often stated. It is the mass of water per unit |
|
136
|
|
|
|
|
|
|
* mass of dry air divided by that for saturated air at the same |
|
137
|
|
|
|
|
|
|
* temperature and pressure (see Gill 1982). |
|
138
|
|
|
|
|
|
|
|
|
139
|
|
|
|
|
|
|
* - The algorithm is designed for observers in the troposphere. The |
|
140
|
|
|
|
|
|
|
* supplied temperature, pressure and lapse rate are assumed to be |
|
141
|
|
|
|
|
|
|
* for a point in the troposphere and are used to define a model |
|
142
|
|
|
|
|
|
|
* atmosphere with the tropopause at 11km altitude and a constant |
|
143
|
|
|
|
|
|
|
* temperature above that. However, in practice, the refraction |
|
144
|
|
|
|
|
|
|
* values returned for stratospheric observers, at altitudes up to |
|
145
|
|
|
|
|
|
|
* 25km, are quite usable. |
|
146
|
|
|
|
|
|
|
|
|
147
|
|
|
|
|
|
|
* History: |
|
148
|
|
|
|
|
|
|
* 2012-08-24 (TIMJ): |
|
149
|
|
|
|
|
|
|
* Initial version, direct port of SLA Fortran source. |
|
150
|
|
|
|
|
|
|
* Adapted with permission from the Fortran SLALIB library. |
|
151
|
|
|
|
|
|
|
* {enter_further_changes_here} |
|
152
|
|
|
|
|
|
|
|
|
153
|
|
|
|
|
|
|
* Copyright: |
|
154
|
|
|
|
|
|
|
* Copyright (C) 2005 Patrick T. Wallace |
|
155
|
|
|
|
|
|
|
* Copyright (C) 2012 Science and Technology Facilities Council. |
|
156
|
|
|
|
|
|
|
* All Rights Reserved. |
|
157
|
|
|
|
|
|
|
|
|
158
|
|
|
|
|
|
|
* Licence: |
|
159
|
|
|
|
|
|
|
* This program is free software; you can redistribute it and/or |
|
160
|
|
|
|
|
|
|
* modify it under the terms of the GNU General Public License as |
|
161
|
|
|
|
|
|
|
* published by the Free Software Foundation; either version 3 of |
|
162
|
|
|
|
|
|
|
* the License, or (at your option) any later version. |
|
163
|
|
|
|
|
|
|
* |
|
164
|
|
|
|
|
|
|
* This program is distributed in the hope that it will be |
|
165
|
|
|
|
|
|
|
* useful, but WITHOUT ANY WARRANTY; without even the implied |
|
166
|
|
|
|
|
|
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR |
|
167
|
|
|
|
|
|
|
* PURPOSE. See the GNU General Public License for more details. |
|
168
|
|
|
|
|
|
|
* |
|
169
|
|
|
|
|
|
|
* You should have received a copy of the GNU General Public License |
|
170
|
|
|
|
|
|
|
* along with this program; if not, write to the Free Software |
|
171
|
|
|
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, |
|
172
|
|
|
|
|
|
|
* MA 02110-1301, USA. |
|
173
|
|
|
|
|
|
|
|
|
174
|
|
|
|
|
|
|
* Bugs: |
|
175
|
|
|
|
|
|
|
* {note_any_bugs_here} |
|
176
|
|
|
|
|
|
|
*- |
|
177
|
|
|
|
|
|
|
*/ |
|
178
|
|
|
|
|
|
|
|
|
179
|
|
|
|
|
|
|
#include |
|
180
|
|
|
|
|
|
|
|
|
181
|
|
|
|
|
|
|
#include "pal.h" |
|
182
|
|
|
|
|
|
|
#include "pal1.h" |
|
183
|
|
|
|
|
|
|
#include "palmac.h" |
|
184
|
|
|
|
|
|
|
|
|
185
|
25
|
|
|
|
|
|
void palRefro( double zobs, double hm, double tdk, double pmb, |
|
186
|
|
|
|
|
|
|
double rh, double wl, double phi, double tlr, |
|
187
|
|
|
|
|
|
|
double eps, double * ref ) { |
|
188
|
|
|
|
|
|
|
|
|
189
|
|
|
|
|
|
|
/* |
|
190
|
|
|
|
|
|
|
* Fixed parameters |
|
191
|
|
|
|
|
|
|
*/ |
|
192
|
|
|
|
|
|
|
|
|
193
|
|
|
|
|
|
|
/* 93 degrees in radians */ |
|
194
|
|
|
|
|
|
|
const double D93 = 1.623156204; |
|
195
|
|
|
|
|
|
|
/* Universal gas constant */ |
|
196
|
|
|
|
|
|
|
const double GCR = 8314.32; |
|
197
|
|
|
|
|
|
|
/* Molecular weight of dry air */ |
|
198
|
|
|
|
|
|
|
const double DMD = 28.9644; |
|
199
|
|
|
|
|
|
|
/* Molecular weight of water vapour */ |
|
200
|
|
|
|
|
|
|
const double DMW = 18.0152; |
|
201
|
|
|
|
|
|
|
/* Mean Earth radius (metre) */ |
|
202
|
|
|
|
|
|
|
const double S = 6378120.; |
|
203
|
|
|
|
|
|
|
/* Exponent of temperature dependence of water vapour pressure */ |
|
204
|
|
|
|
|
|
|
const double DELTA = 18.36; |
|
205
|
|
|
|
|
|
|
/* Height of tropopause (metre) */ |
|
206
|
|
|
|
|
|
|
const double HT = 11000.; |
|
207
|
|
|
|
|
|
|
/* Upper limit for refractive effects (metre) */ |
|
208
|
|
|
|
|
|
|
const double HS = 80000.; |
|
209
|
|
|
|
|
|
|
/* Numerical integration: maximum number of strips. */ |
|
210
|
|
|
|
|
|
|
const int ISMAX=16384l; |
|
211
|
|
|
|
|
|
|
|
|
212
|
|
|
|
|
|
|
/* Local variables */ |
|
213
|
|
|
|
|
|
|
int is, k, n, i, j; |
|
214
|
|
|
|
|
|
|
|
|
215
|
|
|
|
|
|
|
int optic, loop; /* booleans */ |
|
216
|
|
|
|
|
|
|
|
|
217
|
|
|
|
|
|
|
double zobs1,zobs2,hmok,tdkok,pmbok,rhok,wlok,alpha, |
|
218
|
|
|
|
|
|
|
tol,wlsq,gb,a,gamal,gamma,gamm2,delm2, |
|
219
|
|
|
|
|
|
|
tdc,psat,pwo,w, |
|
220
|
|
|
|
|
|
|
c1,c2,c3,c4,c5,c6,r0,tempo,dn0,rdndr0,sk0,f0, |
|
221
|
|
|
|
|
|
|
rt,tt,dnt,rdndrt,sine,zt,ft,dnts,rdndrp,zts,fts, |
|
222
|
|
|
|
|
|
|
rs,dns,rdndrs,zs,fs,refold,z0,zrange,fb,ff,fo,fe, |
|
223
|
|
|
|
|
|
|
h,r,sz,rg,dr,tg,dn,rdndr,t,f,refp,reft; |
|
224
|
|
|
|
|
|
|
|
|
225
|
|
|
|
|
|
|
/* The refraction integrand */ |
|
226
|
|
|
|
|
|
|
#define refi(DN,RDNDR) RDNDR/(DN+RDNDR) |
|
227
|
|
|
|
|
|
|
|
|
228
|
|
|
|
|
|
|
/* Transform ZOBS into the normal range. */ |
|
229
|
25
|
|
|
|
|
|
zobs1 = palDrange(zobs); |
|
230
|
25
|
50
|
|
|
|
|
zobs2 = DMIN(fabs(zobs1),D93); |
|
231
|
|
|
|
|
|
|
|
|
232
|
|
|
|
|
|
|
/* keep other arguments within safe bounds. */ |
|
233
|
25
|
50
|
|
|
|
|
hmok = DMIN(DMAX(hm,-1e3),HS); |
|
|
|
50
|
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
234
|
25
|
50
|
|
|
|
|
tdkok = DMIN(DMAX(tdk,100.0),500.0); |
|
|
|
50
|
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
235
|
25
|
50
|
|
|
|
|
pmbok = DMIN(DMAX(pmb,0.0),10000.0); |
|
|
|
50
|
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
236
|
25
|
50
|
|
|
|
|
rhok = DMIN(DMAX(rh,0.0),1.0); |
|
|
|
50
|
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
237
|
25
|
50
|
|
|
|
|
wlok = DMAX(wl,0.1); |
|
238
|
25
|
50
|
|
|
|
|
alpha = DMIN(DMAX(fabs(tlr),0.001),0.01); |
|
|
|
50
|
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
239
|
|
|
|
|
|
|
|
|
240
|
|
|
|
|
|
|
/* tolerance for iteration. */ |
|
241
|
25
|
100
|
|
|
|
|
tol = DMIN(DMAX(fabs(eps),1e-12),0.1)/2.0; |
|
|
|
50
|
|
|
|
|
|
|
|
|
100
|
|
|
|
|
|
|
242
|
|
|
|
|
|
|
|
|
243
|
|
|
|
|
|
|
/* decide whether optical/ir or radio case - switch at 100 microns. */ |
|
244
|
|
|
|
|
|
|
optic = wlok < 100.0; |
|
245
|
|
|
|
|
|
|
|
|
246
|
|
|
|
|
|
|
/* set up model atmosphere parameters defined at the observer. */ |
|
247
|
25
|
|
|
|
|
|
wlsq = wlok*wlok; |
|
248
|
25
|
|
|
|
|
|
gb = 9.784*(1.0-0.0026*cos(phi+phi)-0.00000028*hmok); |
|
249
|
25
|
100
|
|
|
|
|
if (optic) { |
|
250
|
20
|
|
|
|
|
|
a = (287.6155+(1.62887+0.01360/wlsq)/wlsq) * 273.15e-6/1013.25; |
|
251
|
|
|
|
|
|
|
} else { |
|
252
|
|
|
|
|
|
|
a = 77.6890e-6; |
|
253
|
|
|
|
|
|
|
} |
|
254
|
25
|
|
|
|
|
|
gamal = (gb*DMD)/GCR; |
|
255
|
25
|
|
|
|
|
|
gamma = gamal/alpha; |
|
256
|
25
|
|
|
|
|
|
gamm2 = gamma-2.0; |
|
257
|
|
|
|
|
|
|
delm2 = DELTA-2.0; |
|
258
|
25
|
|
|
|
|
|
tdc = tdkok-273.15; |
|
259
|
50
|
|
|
|
|
|
psat = pow(10.0,(0.7859+0.03477*tdc)/(1.0+0.00412*tdc)) * |
|
260
|
25
|
|
|
|
|
|
(1.0+pmbok*(4.5e-6+6.0e-10*tdc*tdc)); |
|
261
|
25
|
50
|
|
|
|
|
if (pmbok > 0.0) { |
|
262
|
25
|
|
|
|
|
|
pwo = rhok*psat/(1.0-(1.0-rhok)*psat/pmbok); |
|
263
|
|
|
|
|
|
|
} else { |
|
264
|
|
|
|
|
|
|
pwo = 0.0; |
|
265
|
|
|
|
|
|
|
} |
|
266
|
25
|
|
|
|
|
|
w = pwo*(1.0-DMW/DMD)*gamma/(DELTA-gamma); |
|
267
|
25
|
|
|
|
|
|
c1 = a*(pmbok+w)/tdkok; |
|
268
|
25
|
100
|
|
|
|
|
if (optic) { |
|
269
|
20
|
|
|
|
|
|
c2 = (a*w+11.2684e-6*pwo)/tdkok; |
|
270
|
|
|
|
|
|
|
} else { |
|
271
|
5
|
|
|
|
|
|
c2 = (a*w+6.3938e-6*pwo)/tdkok; |
|
272
|
|
|
|
|
|
|
} |
|
273
|
25
|
|
|
|
|
|
c3 = (gamma-1.0)*alpha*c1/tdkok; |
|
274
|
25
|
|
|
|
|
|
c4 = (DELTA-1.0)*alpha*c2/tdkok; |
|
275
|
25
|
100
|
|
|
|
|
if (optic) { |
|
276
|
|
|
|
|
|
|
c5 = 0.0; |
|
277
|
|
|
|
|
|
|
c6 = 0.0; |
|
278
|
|
|
|
|
|
|
} else { |
|
279
|
5
|
|
|
|
|
|
c5 = 375463e-6*pwo/tdkok; |
|
280
|
5
|
|
|
|
|
|
c6 = c5*delm2*alpha/(tdkok*tdkok); |
|
281
|
|
|
|
|
|
|
} |
|
282
|
|
|
|
|
|
|
|
|
283
|
|
|
|
|
|
|
/* conditions at the observer. */ |
|
284
|
25
|
|
|
|
|
|
r0 = S+hmok; |
|
285
|
25
|
|
|
|
|
|
pal1Atmt(r0,tdkok,alpha,gamm2,delm2,c1,c2,c3,c4,c5,c6, |
|
286
|
|
|
|
|
|
|
r0,&tempo,&dn0,&rdndr0); |
|
287
|
25
|
|
|
|
|
|
sk0 = dn0*r0*sin(zobs2); |
|
288
|
25
|
|
|
|
|
|
f0 = refi(dn0,rdndr0); |
|
289
|
|
|
|
|
|
|
|
|
290
|
|
|
|
|
|
|
/* conditions in the troposphere at the tropopause. */ |
|
291
|
25
|
50
|
|
|
|
|
rt = S+DMAX(HT,hmok); |
|
292
|
25
|
|
|
|
|
|
pal1Atmt(r0,tdkok,alpha,gamm2,delm2,c1,c2,c3,c4,c5,c6, |
|
293
|
|
|
|
|
|
|
rt,&tt,&dnt,&rdndrt); |
|
294
|
25
|
|
|
|
|
|
sine = sk0/(rt*dnt); |
|
295
|
25
|
50
|
|
|
|
|
zt = atan2(sine,sqrt(DMAX(1.0-sine*sine,0.0))); |
|
296
|
25
|
|
|
|
|
|
ft = refi(dnt,rdndrt); |
|
297
|
|
|
|
|
|
|
|
|
298
|
|
|
|
|
|
|
/* conditions in the stratosphere at the tropopause. */ |
|
299
|
25
|
|
|
|
|
|
pal1Atms(rt,tt,dnt,gamal,rt,&dnts,&rdndrp); |
|
300
|
25
|
|
|
|
|
|
sine = sk0/(rt*dnts); |
|
301
|
25
|
50
|
|
|
|
|
zts = atan2(sine,sqrt(DMAX(1.0-sine*sine,0.0))); |
|
302
|
25
|
|
|
|
|
|
fts = refi(dnts,rdndrp); |
|
303
|
|
|
|
|
|
|
|
|
304
|
|
|
|
|
|
|
/* conditions at the stratosphere limit. */ |
|
305
|
|
|
|
|
|
|
rs = S+HS; |
|
306
|
25
|
|
|
|
|
|
pal1Atms(rt,tt,dnt,gamal,rs,&dns,&rdndrs); |
|
307
|
25
|
|
|
|
|
|
sine = sk0/(rs*dns); |
|
308
|
25
|
50
|
|
|
|
|
zs = atan2(sine,sqrt(DMAX(1.0-sine*sine,0.0))); |
|
309
|
25
|
|
|
|
|
|
fs = refi(dns,rdndrs); |
|
310
|
|
|
|
|
|
|
|
|
311
|
|
|
|
|
|
|
/* variable initialization to avoid compiler warning. */ |
|
312
|
|
|
|
|
|
|
reft = 0.0; |
|
313
|
|
|
|
|
|
|
|
|
314
|
|
|
|
|
|
|
/* integrate the refraction integral in two parts; first in the |
|
315
|
|
|
|
|
|
|
* troposphere (k=1), then in the stratosphere (k=2). */ |
|
316
|
|
|
|
|
|
|
|
|
317
|
75
|
100
|
|
|
|
|
for (k=1; k<=2; k++) { |
|
318
|
|
|
|
|
|
|
|
|
319
|
|
|
|
|
|
|
/* initialize previous refraction to ensure at least two iterations. */ |
|
320
|
|
|
|
|
|
|
refold = 1.0; |
|
321
|
|
|
|
|
|
|
|
|
322
|
|
|
|
|
|
|
/* start off with 8 strips. */ |
|
323
|
|
|
|
|
|
|
is = 8; |
|
324
|
|
|
|
|
|
|
|
|
325
|
|
|
|
|
|
|
/* start z, z range, and start and end values. */ |
|
326
|
50
|
100
|
|
|
|
|
if (k==1) { |
|
327
|
|
|
|
|
|
|
z0 = zobs2; |
|
328
|
25
|
|
|
|
|
|
zrange = zt-z0; |
|
329
|
|
|
|
|
|
|
fb = f0; |
|
330
|
|
|
|
|
|
|
ff = ft; |
|
331
|
|
|
|
|
|
|
} else { |
|
332
|
|
|
|
|
|
|
z0 = zts; |
|
333
|
25
|
|
|
|
|
|
zrange = zs-z0; |
|
334
|
|
|
|
|
|
|
fb = fts; |
|
335
|
|
|
|
|
|
|
ff = fs; |
|
336
|
|
|
|
|
|
|
} |
|
337
|
|
|
|
|
|
|
|
|
338
|
|
|
|
|
|
|
/* sums of odd and even values. */ |
|
339
|
|
|
|
|
|
|
fo = 0.0; |
|
340
|
|
|
|
|
|
|
fe = 0.0; |
|
341
|
|
|
|
|
|
|
|
|
342
|
|
|
|
|
|
|
/* first time through the loop we have to do every point. */ |
|
343
|
|
|
|
|
|
|
n = 1; |
|
344
|
|
|
|
|
|
|
|
|
345
|
|
|
|
|
|
|
/* start of iteration loop (terminates at specified precision). */ |
|
346
|
|
|
|
|
|
|
loop = 1; |
|
347
|
289
|
100
|
|
|
|
|
while (loop) { |
|
348
|
|
|
|
|
|
|
|
|
349
|
|
|
|
|
|
|
/* strip width. */ |
|
350
|
239
|
|
|
|
|
|
h = zrange/((double)is); |
|
351
|
|
|
|
|
|
|
|
|
352
|
|
|
|
|
|
|
/* initialize distance from earth centre for quadrature pass. */ |
|
353
|
239
|
100
|
|
|
|
|
if (k == 1) { |
|
354
|
|
|
|
|
|
|
r = r0; |
|
355
|
|
|
|
|
|
|
} else { |
|
356
|
|
|
|
|
|
|
r = rt; |
|
357
|
|
|
|
|
|
|
} |
|
358
|
|
|
|
|
|
|
|
|
359
|
|
|
|
|
|
|
/* one pass (no need to compute evens after first time). */ |
|
360
|
14461
|
100
|
|
|
|
|
for (i=1; i
|
|
361
|
|
|
|
|
|
|
|
|
362
|
|
|
|
|
|
|
/* sine of observed zenith distance. */ |
|
363
|
14222
|
|
|
|
|
|
sz = sin(z0+h*(double)(i)); |
|
364
|
|
|
|
|
|
|
|
|
365
|
|
|
|
|
|
|
/* find r (to the nearest metre, maximum four iterations). */ |
|
366
|
14222
|
50
|
|
|
|
|
if (sz > 1e-20) { |
|
367
|
14222
|
|
|
|
|
|
w = sk0/sz; |
|
368
|
|
|
|
|
|
|
rg = r; |
|
369
|
|
|
|
|
|
|
dr = 1.0e6; |
|
370
|
|
|
|
|
|
|
j = 0; |
|
371
|
44274
|
100
|
|
|
|
|
while ( fabs(dr) > 1.0 && j < 4 ) { |
|
|
|
50
|
|
|
|
|
|
|
372
|
30052
|
|
|
|
|
|
j++; |
|
373
|
30052
|
100
|
|
|
|
|
if (k==1) { |
|
374
|
3662
|
|
|
|
|
|
pal1Atmt(r0,tdkok,alpha,gamm2,delm2, |
|
375
|
|
|
|
|
|
|
c1,c2,c3,c4,c5,c6,rg,&tg,&dn,&rdndr); |
|
376
|
|
|
|
|
|
|
} else { |
|
377
|
26390
|
|
|
|
|
|
pal1Atms(rt,tt,dnt,gamal,rg,&dn,&rdndr); |
|
378
|
|
|
|
|
|
|
} |
|
379
|
30052
|
|
|
|
|
|
dr = (rg*dn-w)/(dn+rdndr); |
|
380
|
30052
|
|
|
|
|
|
rg = rg-dr; |
|
381
|
|
|
|
|
|
|
} |
|
382
|
|
|
|
|
|
|
r = rg; |
|
383
|
|
|
|
|
|
|
} |
|
384
|
|
|
|
|
|
|
|
|
385
|
|
|
|
|
|
|
/* find the refractive index and integrand at r. */ |
|
386
|
14222
|
100
|
|
|
|
|
if (k==1) { |
|
387
|
1575
|
|
|
|
|
|
pal1Atmt(r0,tdkok,alpha,gamm2,delm2, |
|
388
|
|
|
|
|
|
|
c1,c2,c3,c4,c5,c6,r,&t,&dn,&rdndr); |
|
389
|
|
|
|
|
|
|
} else { |
|
390
|
12647
|
|
|
|
|
|
pal1Atms(rt,tt,dnt,gamal,r,&dn,&rdndr); |
|
391
|
|
|
|
|
|
|
} |
|
392
|
14222
|
|
|
|
|
|
f = refi(dn,rdndr); |
|
393
|
|
|
|
|
|
|
|
|
394
|
|
|
|
|
|
|
/* accumulate odd and (first time only) even values. */ |
|
395
|
14222
|
100
|
|
|
|
|
if (n==1 && i%2 == 0) { |
|
|
|
100
|
|
|
|
|
|
|
396
|
150
|
|
|
|
|
|
fe += f; |
|
397
|
|
|
|
|
|
|
} else { |
|
398
|
14072
|
|
|
|
|
|
fo += f; |
|
399
|
|
|
|
|
|
|
} |
|
400
|
|
|
|
|
|
|
} |
|
401
|
|
|
|
|
|
|
|
|
402
|
|
|
|
|
|
|
/* evaluate the integrand using simpson's rule. */ |
|
403
|
239
|
|
|
|
|
|
refp = h*(fb+4.0*fo+2.0*fe+ff)/3.0; |
|
404
|
|
|
|
|
|
|
|
|
405
|
|
|
|
|
|
|
/* has the required precision been achieved (or can't be)? */ |
|
406
|
239
|
100
|
|
|
|
|
if (fabs(refp-refold) > tol && is < ISMAX) { |
|
|
|
50
|
|
|
|
|
|
|
407
|
|
|
|
|
|
|
|
|
408
|
|
|
|
|
|
|
/* no: prepare for next iteration.*/ |
|
409
|
|
|
|
|
|
|
|
|
410
|
|
|
|
|
|
|
/* save current value for convergence test. */ |
|
411
|
|
|
|
|
|
|
refold = refp; |
|
412
|
|
|
|
|
|
|
|
|
413
|
|
|
|
|
|
|
/* double the number of strips. */ |
|
414
|
189
|
|
|
|
|
|
is += is; |
|
415
|
|
|
|
|
|
|
|
|
416
|
|
|
|
|
|
|
/* sum of all current values = sum of next pass's even values. */ |
|
417
|
189
|
|
|
|
|
|
fe += fo; |
|
418
|
|
|
|
|
|
|
|
|
419
|
|
|
|
|
|
|
/* prepare for new odd values. */ |
|
420
|
|
|
|
|
|
|
fo = 0.0; |
|
421
|
|
|
|
|
|
|
|
|
422
|
|
|
|
|
|
|
/* skip even values next time. */ |
|
423
|
189
|
|
|
|
|
|
n = 2; |
|
424
|
|
|
|
|
|
|
} else { |
|
425
|
|
|
|
|
|
|
|
|
426
|
|
|
|
|
|
|
/* yes: save troposphere component and terminate the loop. */ |
|
427
|
239
|
100
|
|
|
|
|
if (k==1) reft = refp; |
|
428
|
|
|
|
|
|
|
loop = 0; |
|
429
|
|
|
|
|
|
|
} |
|
430
|
|
|
|
|
|
|
} |
|
431
|
|
|
|
|
|
|
} |
|
432
|
|
|
|
|
|
|
|
|
433
|
|
|
|
|
|
|
/* result. */ |
|
434
|
25
|
|
|
|
|
|
*ref = reft+refp; |
|
435
|
25
|
50
|
|
|
|
|
if (zobs1 < 0.0) *ref = -(*ref); |
|
436
|
|
|
|
|
|
|
|
|
437
|
25
|
|
|
|
|
|
} |