|
7 | 7 | end
|
8 | 8 |
|
9 | 9 | methods(Static = true)
|
10 |
| - function Match = discover_md(prof_mode, wrf_dirs) |
| 10 | + function Match = discover_md(prof_mode, wrf_dirs, varargin) |
| 11 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 12 | + |
11 | 13 | campaign_name = 'discover_md';
|
12 |
| - if ~exist('prof_mode', 'var') |
| 14 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
13 | 15 | prof_mode = 'daily';
|
14 | 16 | end
|
15 |
| - if ~exist('wrf_dirs', 'var') |
16 |
| - wrf_dirs = {'/Volumes/share-wrf1/Outputs/us/2011/07'}; |
| 17 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
| 18 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2011/07'}; |
17 | 19 | end
|
18 | 20 |
|
19 | 21 | Out = campaign_wide_ops(campaign_name, {'NO2_LIF', 'LONGITUDE', 'LATITUDE', 'PRESSURE'}, 'cat', 'datefmt','datenum');
|
|
24 | 26 | Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out);
|
25 | 27 | Raw.campaign = campaign_name;
|
26 | 28 |
|
| 29 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 30 | + |
27 | 31 | Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode);
|
28 | 32 | end
|
29 | 33 |
|
30 |
| - function Match = discover_ca(prof_mode, wrf_dirs) |
| 34 | + function Match = discover_ca(prof_mode, wrf_dirs, varargin) |
| 35 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 36 | + |
31 | 37 | campaign_name = 'discover_ca';
|
32 |
| - if ~exist('prof_mode', 'var') |
| 38 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
33 | 39 | prof_mode = 'daily';
|
34 | 40 | end
|
35 |
| - if ~exist('wrf_dirs', 'var') |
36 |
| - wrf_dirs = {'/Volumes/share-wrf1/Outputs/us/2013/01', '/Volumes/share-wrf1/Outputs/us/2013/02'}; |
| 41 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
| 42 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/01', '/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/02'}; |
37 | 43 | end
|
38 | 44 |
|
39 | 45 | Out = campaign_wide_ops(campaign_name, {'NO2_MixingRatio_LIF', 'LONGITUDE', 'LATITUDE', 'PRESSURE'}, 'cat', 'datefmt','datenum');
|
|
44 | 50 | Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out);
|
45 | 51 | Raw.campaign = campaign_name;
|
46 | 52 |
|
| 53 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 54 | + |
47 | 55 | Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode);
|
48 | 56 | end
|
49 | 57 |
|
50 |
| - function Match = discover_tx(prof_mode, wrf_dirs) |
| 58 | + function Match = discover_tx(prof_mode, wrf_dirs, varargin) |
| 59 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 60 | + |
51 | 61 | campaign_name = 'discover_tx';
|
52 |
| - if ~exist('prof_mode', 'var') |
| 62 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
53 | 63 | prof_mode = 'daily';
|
54 | 64 | end
|
55 |
| - if ~exist('wrf_dirs', 'var') |
56 |
| - wrf_dirs = {'/Volumes/share-wrf1/Outputs/us/2013/09'}; |
| 65 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
| 66 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/09'}; |
57 | 67 | end
|
58 | 68 |
|
59 | 69 | Out = campaign_wide_ops(campaign_name, {'NO2_MixingRatio_LIF', 'LONGITUDE', 'LATITUDE', 'PRESSURE'}, 'cat', 'datefmt','datenum');
|
|
64 | 74 | Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out);
|
65 | 75 | Raw.campaign = campaign_name;
|
66 | 76 |
|
| 77 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 78 | + |
67 | 79 | Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode);
|
68 | 80 | end
|
69 | 81 |
|
70 |
| - function Match = discover_co(prof_mode, wrf_dirs) |
| 82 | + function Match = discover_co(prof_mode, wrf_dirs, varargin) |
| 83 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 84 | + |
71 | 85 | campaign_name = 'discover_co';
|
72 |
| - if ~exist('prof_mode', 'var') |
| 86 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
73 | 87 | prof_mode = 'daily';
|
74 | 88 | end
|
75 |
| - if ~exist('wrf_dirs', 'var') |
76 |
| - wrf_dirs = {'/Volumes/share-wrf1/Outputs/us/2014/07','/Volumes/share-wrf1/Outputs/us/2014/08'}; |
| 89 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
| 90 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2014/07','/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2014/08'}; |
77 | 91 | end
|
78 | 92 |
|
79 | 93 | Out = campaign_wide_ops(campaign_name, {'NO2_LIF', 'LONGITUDE', 'LATITUDE', 'PRESSURE'}, 'cat', 'datefmt','datenum');
|
|
84 | 98 | Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out);
|
85 | 99 | Raw.campaign = campaign_name;
|
86 | 100 |
|
| 101 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 102 | + |
87 | 103 | Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode);
|
88 | 104 | end
|
89 | 105 |
|
90 |
| - function Match = dc3(prof_mode, wrf_dirs) |
| 106 | + function Match = dc3(prof_mode, wrf_dirs, varargin) |
| 107 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 108 | + |
91 | 109 | campaign_name = 'dc3';
|
92 |
| - if ~exist('wrf_dirs', 'var') |
| 110 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
93 | 111 | %wrf_dirs = '/Volumes/share2/USERS/LaughnerJ/WRF/DC3/lnox_off-fixed_BCs';
|
94 |
| - wrf_dirs = {'/Volumes/share-wrf1/Outputs/us/2012/05','/Volumes/share-wrf1/Outputs/us/2012/06'}; |
| 112 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2012/05','/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2012/06'}; |
95 | 113 | end
|
96 |
| - if ~exist('prof_mode', 'var') |
| 114 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
97 | 115 | prof_mode = 'daily';
|
98 | 116 | end
|
99 | 117 |
|
|
121 | 139 | % 2) The units for this mixing ratio are g/kg, in WRF it is kg/kg.
|
122 | 140 | Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out);
|
123 | 141 |
|
| 142 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 143 | + |
| 144 | + Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode); |
| 145 | + end |
| 146 | + |
| 147 | + function Match = soas(prof_mode, wrf_dirs, varargin) |
| 148 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 149 | + |
| 150 | + campaign_name = 'soas'; |
| 151 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
| 152 | + prof_mode = 'daily'; |
| 153 | + end |
| 154 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
| 155 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/05','/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/05','/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/07'}; |
| 156 | + end |
| 157 | + |
| 158 | + Out = campaign_wide_ops(campaign_name, {'NO2_ppbv', 'LONGITUDE', 'LATITUDE', 'StaticPrs'}, 'cat', 'datefmt','datenum'); |
| 159 | + |
| 160 | + Raw.campaign = campaign_name; |
| 161 | + Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out); |
| 162 | + Raw.no2 = Out.data.NO2_ppbv * 1e-9 * 1e6; |
| 163 | + Raw.lon = Out.data.LONGITUDE; |
| 164 | + Raw.lat = Out.data.LATITUDE; |
| 165 | + Raw.pres = Out.data.StaticPrs; |
| 166 | + |
| 167 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 168 | + |
| 169 | + Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode); |
| 170 | + end |
| 171 | + |
| 172 | + function Match = seac4rs(prof_mode, wrf_dirs, varargin) |
| 173 | + [utc_range, lst_range] = match_wrf2campaigns.parse_common_args(varargin{:}); |
| 174 | + |
| 175 | + campaign_name = 'seac4rs'; |
| 176 | + if ~exist('prof_mode', 'var') || isempty(prof_mode) |
| 177 | + prof_mode = 'daily'; |
| 178 | + end |
| 179 | + if ~exist('wrf_dirs', 'var') || isempty(wrf_dirs) |
| 180 | + wrf_dirs = {'/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/08','/Volumes/share-wrf1/BEHR-WRF/Outputs/us/2013/09'}; |
| 181 | + end |
| 182 | + |
| 183 | + Out = campaign_wide_ops(campaign_name, {'NO2_TDLIF', 'LONGITUDE', 'LATITUDE', 'PRESSURE'}, 'cat', 'datefmt','datenum'); |
| 184 | + |
| 185 | + Raw.campaign = campaign_name; |
| 186 | + Raw.dvec = match_wrf2campaigns.convert_aircraft_times(Out); |
| 187 | + Raw.no2 = Out.data.NO2_TDLIF * 1e-12 * 1e6; |
| 188 | + Raw.lon = Out.data.LONGITUDE; |
| 189 | + Raw.lat = Out.data.LATITUDE; |
| 190 | + Raw.pres = Out.data.PRESSURE; |
| 191 | + |
| 192 | + Raw = match_wrf2campaigns.restrict_by_time(Raw, Out.utcs, utc_range, lst_range); |
| 193 | + |
124 | 194 | Match = match_wrf2aircraft(Raw, wrf_dirs, prof_mode);
|
125 | 195 | end
|
126 | 196 | end
|
|
129 | 199 | function dvec = convert_aircraft_times(Out)
|
130 | 200 | dvec = Out.dates + Out.utcs ./ (60*60*24);
|
131 | 201 | end
|
| 202 | + |
| 203 | + function varargout = parse_common_args(varargin) |
| 204 | + p = inputParser; |
| 205 | + p.addParameter('utc_range', []); |
| 206 | + p.addParameter('lst_range', []); |
| 207 | + |
| 208 | + p.parse(varargin{:}); |
| 209 | + pout = p.Results; |
| 210 | + |
| 211 | + varargout{1} = pout.utc_range; |
| 212 | + varargout{2} = pout.lst_range; |
| 213 | + end |
| 214 | + |
| 215 | + function Raw = restrict_by_time(Raw, utcs, utc_range, lst_range) |
| 216 | + xx_in_range = true(size(utcs)); |
| 217 | + if ~isempty(utc_range) |
| 218 | + xx_in_range = xx_in_range & match_wrf2campaigns.time_range_logical(utcs, utc_range); |
| 219 | + end |
| 220 | + if ~isempty(lst_range) |
| 221 | + xx_in_range = xx_in_range & match_wrf2campaigns.time_range_logical(utc2local_sec(utcs, round(Raw.lon/15)), lst_range); |
| 222 | + end |
| 223 | + |
| 224 | + fns = fieldnames(Raw); |
| 225 | + for f = 1:numel(fns) |
| 226 | + if isnumeric(Raw.(fns{f})) |
| 227 | + Raw.(fns{f}) = Raw.(fns{f})(xx_in_range); |
| 228 | + end |
| 229 | + end |
| 230 | + end |
| 231 | + |
| 232 | + function xx = time_range_logical(sec_after_midnight, time_range) |
| 233 | + % Assume the range is given in hours after midnight. Convert to |
| 234 | + % seconds. |
| 235 | + range_start = time_range(1) * 60^2; |
| 236 | + range_end = time_range(2) * 60^2; |
| 237 | + xx = sec_after_midnight >= range_start & sec_after_midnight <= range_end; |
| 238 | + end |
132 | 239 | end
|
133 | 240 |
|
134 | 241 | end
|
|
0 commit comments