1 |
gforget |
1.1 |
%function: netcdf_ecco_read |
2 |
|
|
%object: read netcdf data files in the "MIT format" |
3 |
|
|
%author: Gael Forget (gforget@mit.edu) |
4 |
|
|
%date: june 21th, 2006 |
5 |
|
|
% |
6 |
|
|
%usage: [depth,myvars,prof_descr,mystruct,mystruct1D]=... |
7 |
|
|
% netcdf_ecco_read(rep_data,file_data); |
8 |
|
|
% ---> loads a data set |
9 |
|
|
% [depth,myvars,prof_descr,mystruct,mystruct1D]=... |
10 |
|
|
% netcdf_ecco_read(rep_equi,file_equi); |
11 |
|
|
% ---> loads model counterparts |
12 |
|
|
% [depth,myvars,prof_descr,mystruct,mystruct1D]=... |
13 |
|
|
% netcdf_ecco_read(rep_data,file_data,rep_equi,suff_equi); |
14 |
|
|
% ---> loads both the data set and model counterparts |
15 |
|
|
% |
16 |
|
|
%inputs: rep_data data file directory |
17 |
|
|
% file_data data file name |
18 |
|
|
% rep_equi model file directory |
19 |
|
|
% suff_equi model file suffix |
20 |
|
|
% |
21 |
|
|
%asumption: file_data is 'blabla.nc', and the |
22 |
|
|
% model file is named ['blabla' suff_equi] |
23 |
|
|
% |
24 |
|
|
%outputs: depth depth vector |
25 |
|
|
% myvars list of the variables |
26 |
|
|
% prof_descr instruments/cruises id |
27 |
|
|
% mystruct struct array containing the |
28 |
|
|
% data(+model counterparts) and weights(+model mask) |
29 |
|
|
% mystruct1D struct array of dates and positions |
30 |
|
|
|
31 |
|
|
function [depth,myvars,prof_descr,mystruct,mystruct1D]=... |
32 |
|
|
netcdf_ecco_read(rep_data,file_data,varargin); |
33 |
|
|
|
34 |
|
|
list_vars=strvcat('T','S','U','V','ptr','ssh'); |
35 |
|
|
|
36 |
|
|
if isempty(varargin) |
37 |
|
|
%either observations or model counterparts: |
38 |
|
|
ncload(deblank([rep_data file_data])); |
39 |
|
|
mystruct_txt='mystruct=struct('; myvars=''; |
40 |
|
|
for num_var=1:size(list_vars,1) |
41 |
|
|
name_var=deblank(list_vars(num_var,:)); |
42 |
|
|
if ~isempty(who(['prof_' name_var])); |
43 |
|
|
myvars=strvcat(myvars,name_var); |
44 |
|
|
mystruct_txt=[mystruct_txt '''prof_' name_var ''',{prof_' name_var '}']; |
45 |
|
|
%for observations: |
46 |
|
|
if ~isempty(who(['prof_' name_var 'weight'])); |
47 |
|
|
mystruct_txt=[mystruct_txt ',''prof_' name_var 'weight'',{prof_' name_var 'weight},']; |
48 |
|
|
%or for model counterparts case: |
49 |
|
|
else mystruct_txt=[mystruct_txt ',''prof_' name_var 'mask'',{prof_' name_var 'mask},']; end; |
50 |
|
|
end; |
51 |
|
|
end; |
52 |
|
|
|
53 |
|
|
else |
54 |
|
|
%read both observations and model: |
55 |
|
|
rep_equi=varargin{1}; suff_equi=varargin{2}; |
56 |
|
|
tmp1=strfind(file_data,'.nc'); |
57 |
|
|
% read the model: |
58 |
|
|
ncload(deblank([rep_equi file_data(1:tmp1-1) suff_equi])); |
59 |
|
|
mystruct_txt='mystruct=struct('; myvars=''; |
60 |
|
|
for num_var=1:size(list_vars,1) |
61 |
|
|
name_var=deblank(list_vars(num_var,:)); |
62 |
|
|
if ~isempty(who(['prof_' name_var])); |
63 |
|
|
myvars=strvcat(myvars,name_var); |
64 |
|
|
mystruct_txt=[mystruct_txt '''prof_' name_var ''',{prof_' name_var '},']; |
65 |
|
|
mystruct_txt=[mystruct_txt '''prof_' name_var 'weight'',{prof_' name_var 'weight},']; |
66 |
|
|
mystruct_txt=[mystruct_txt '''prof_' name_var 'equi'',{prof_' name_var 'equi},']; |
67 |
|
|
mystruct_txt=[mystruct_txt '''prof_' name_var 'mask'',{prof_' name_var 'mask},']; |
68 |
|
|
eval(['prof_' name_var 'equi=prof_' name_var ';']); |
69 |
|
|
end |
70 |
|
|
end |
71 |
|
|
% then read the observations: |
72 |
|
|
tmp1=strfind(file_data,'.nc'); |
73 |
|
|
ncload(deblank([rep_data file_data(1:tmp1-1) '.nc'])); |
74 |
|
|
end |
75 |
|
|
|
76 |
|
|
%structure the 2D arrays: |
77 |
|
|
mystruct_txt=[mystruct_txt(1:end-1) ');']; |
78 |
|
|
eval(mystruct_txt); |
79 |
|
|
|
80 |
|
|
%structure the 1D arrays: |
81 |
|
|
mystruct1D=struct('prof_YYYYMMDD',prof_YYYYMMDD,'prof_HHMMSS',prof_HHMMSS,... |
82 |
|
|
'prof_lon',prof_lon,'prof_lat',prof_lat); |
83 |
|
|
|