-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdiag.trajectory.drifters.timeseries.extrapolated.ekman.jl
95 lines (82 loc) · 3.76 KB
/
diag.trajectory.drifters.timeseries.extrapolated.ekman.jl
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
#=
= Loop through the six-hourly Ekman timeseries and create the corresponding forward and
= backward extrapolated timeseries for the two (u,v) current components - RD April 2016.
=#
using My, Interpolations
const UCUR = 1 # indecies of all data variables
const VCUR = 2
const PARS = 2
const BEF = 1 # indecies of the source of extrapolations
const NOW = 2
const AFT = 3
const SRCS = 3
const EXTRA = 9 # number of points used for extrapolation
const TIMS = 3408 # number in timeseries
const MISS = -9999.0 # generic missing value
if (argc = length(ARGS)) != 2
print("\nUsage: jjj $(basename(@__FILE__)) v2.0_global_025_deg_ekman_15m z.listah\n\n")
exit(1)
end
inner = div(EXTRA - 1, 2)
outer = div(EXTRA + 1, 2)
dats = Array(UTF8String, TIMS)
data = Array(Float64, TIMS, SRCS, PARS)
fpa = My.ouvre("$(ARGS[1])/$(ARGS[2])", "r") # loop through the list of locations
files = readlines(fpa) ; close(fpa) # and process each timeseries
for fila in files
fila = strip(fila)
if isfile("$(ARGS[1])/$fila.bef") && isfile("$(ARGS[1])/$fila.aft") continue end
fpa = My.ouvre("$(ARGS[1])/$fila", "r", false)
lines = readlines(fpa) ; close(fpa)
for (a, line) in enumerate(lines)
vals = split(line)
data[a,NOW,UCUR] = float(vals[10])
data[a,NOW,VCUR] = float(vals[11])
dats[a] = vals[1]
end
for a = 1:PARS # set to missing the first few BEF
for b = 1:EXTRA+1 # extrapolations (not defined below)
data[b,BEF,a] = MISS
end
end
for a = 1:PARS # simultaneously extrap from BEF and AFT
for b = 1+outer:TIMS-outer
tmp = vec(data[b-inner:b+inner,NOW,a])
if all(-333 .< tmp .< 333)
tmpmax = maximum(tmp)
tmpmin = minimum(tmp)
itp = interpolate(tmp, BSpline(Quadratic(Line())), OnCell())
tmpbef = itp[10] ; tmpbef > tmpmax && (tmpbef = tmpmax) ; tmpbef < tmpmin && (tmpbef = tmpmin)
tmpaft = itp[ 0] ; tmpaft > tmpmax && (tmpaft = tmpmax) ; tmpaft < tmpmin && (tmpaft = tmpmin)
data[b+outer,BEF,a] = tmpbef
data[b-outer,AFT,a] = tmpaft
else
data[b+outer,BEF,a] = data[b-outer,AFT,a] = MISS
end
end
end
for a = 1:PARS # set to missing the last few AFT
for b = 0:EXTRA # extrapolations (not defined above)
data[TIMS-b,AFT,a] = MISS
end
end
filb = "$fila.bef" # then save all extrapolations
filc = "$fila.aft"
fpb = My.ouvre("$(ARGS[1])/$filb", "w", false)
fpc = My.ouvre("$(ARGS[1])/$filc", "w", false)
(lll, lat, lon) = split(replace(fila, r"[\.]{2,}", " "))
for a = 1:TIMS
formb = @sprintf("%10s %10.5f %10.5f 99999999 99999 9 -9999.00000 -9999.00000 -9999.00000 %11.5f %11.5f\n",
dats[a], float(lat), float(lon), data[a,BEF,UCUR], data[a,BEF,VCUR])
formc = @sprintf("%10s %10.5f %10.5f 99999999 99999 9 -9999.00000 -9999.00000 -9999.00000 %11.5f %11.5f\n",
dats[a], float(lat), float(lon), data[a,AFT,UCUR], data[a,AFT,VCUR])
write(fpb, formb)
write(fpc, formc)
end
close(fpb)
close(fpc)
end
exit(0)
#=
2012090600 13.87500 141.37500 99999999 99999 9 -9999.00000 -9999.00000 -9999.00000 -0.11356 -0.02688
=#