-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathfunc_read_hires.ncl
101 lines (75 loc) · 3.51 KB
/
func_read_hires.ncl
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
;===================================================================================================
; read in atmospheric data from high-resolution files
;
; performs temporal interpolation if flag_interp = .TRUE.
; reads in only level indicated by lev_count
;===============================================================
function func_read_hires(generic_path:string,timestep_path:integer,timestep_idx:integer,time_in:double,\
filename:string,filetype:string,variable_file:string,variable_name:string,\
CG_resol:string,region:string,lev_count:integer)
local generic_path,timestep_path,timestep_idx,time_in,filename,filetype,variable_file,variable_name,\
CG_resol,region,lev_count,no_time_slices,t_count,data_path_matr,data_path,in_file,\
in_data_tmp,var_dims,data_size,data_size_new,in_data,i_dim
begin
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; READ IN DATA
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; 1. work out how many time slices we have in total
no_time_slices = dimsizes(timestep_idx)
do t_count = 0,dimsizes(timestep_path)-1
if (filetype.eq."atm2_2d").or.(filetype.eq."atm4_2d") then
data_path_matr = (/generic_path,CG_resol,"/",region,"/",filename,CG_resol,"_",filetype,"_ml_",tostring(timestep_path(t_count)),"T000000Z_",region,".nc"/)
else
data_path_matr = (/generic_path,CG_resol,"/",region,"/",filename,CG_resol,"_",filetype,"_",variable_file,"_ml_",tostring(timestep_path(t_count)),"T000000Z_",region,".nc"/)
end if
data_path = str_concat(data_path_matr)
; Input variable dimensions: (time, latitude, longitude) ;
in_file = addfile(data_path,"r")
; data check
if (t_count.eq.0) then
tmptmp = in_file->$variable_name$
; check dimension time
tmpsize = dimsizes(tmptmp)
;print(tmpsize)
if (tmpsize(0).ne.8)
print(" ERROR: UNEXPECTED NUMBER OF INPUT TIME SLICES")
tmp = nope
end if
delete([/tmptmp, tmpsize/])
end if
if (lev_count.eq.999) then
; 2D field: only one level available
in_data_tmp = in_file->$variable_name$(timestep_idx(t_count),:,:)
else
; 3D field
in_data_tmp = in_file->$variable_name$(timestep_idx(t_count),lev_count,:,:)
end if
; set up the new empty array into which we will put our multiple time data
if (t_count.eq.0) then
var_dims = getvardims(in_data_tmp)
data_size = dimsizes(in_data_tmp)
data_size_new = array_append_record(no_time_slices,data_size,0)
delete([/data_size/])
data_size = data_size_new
delete([/data_size_new/])
in_data = new(data_size,float)
in_data!0 = "time"
do i_dim = 0,dimsizes(var_dims)-1
in_data!(i_dim+1) = in_data_tmp!(i_dim)
in_data&$in_data!(i_dim+1)$ = in_data_tmp&$in_data_tmp!(i_dim)$
end do
delete([/var_dims,i_dim,data_size/])
copy_VarAtts(in_data_tmp,in_data)
end if
; put time slice into in_data
data_size = dimsizes(in_data)
if (dimsizes(data_size).eq.3) then ; time, lat, lon
in_data(t_count,:,:) = (/in_data_tmp(lat|:,lon|:)/)
else ; time, lev, lat, lon
in_data(t_count,:,:,:) = (/in_data_tmp(lev|:,lat|:,lon|:)/)
end if
delete([/data_path_matr,data_path,in_file,data_size,in_data_tmp/])
end do
in_data&time = time_in
return(in_data)
end