-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfill_soil_temperature_gaps.m
49 lines (44 loc) · 1.63 KB
/
fill_soil_temperature_gaps.m
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
function Tsoil = fill_soil_temperature_gaps( Tsoil, pcp, draw_plots )
% FILL_SOIL_TEMPERATURE_GAPS - fill gaps in soil temperature record by linear
% interpolation.
%
% Fill gaps between 0 and 5 days in length with linear interpolation between the
% last pre-gap observation and the first post-gap observation. Gaps longer than
% five days are left alone.
%
% USAGE
% Tsoil = fill_soil_temperature_gaps( Tsoil, pcp, draw_plots );
%
% INPUTS:
% Tsoil: dataset array; soil temperature data
% pcp: numeric vector: preciptation observations
% draw_plots: logical; if true, draws a diagnostic plot using
% plot_soil_pit_data showing filled and unfilled Tsoil and precipitation
%
% OUTPUTS:
% Tsoil: dataset array; soil temperature data with gaps filled as
% described above.
%
% SEE ALSO
% plot_soil_pit_data, dataset
%
% author: Timothy W. Hilton, UNM, Aug 2012
Tsoil_dbl = double( Tsoil );
nan_idx = isnan( Tsoil_dbl );
interp_method = 4;
Tsoil_dbl = column_inpaint_nans( Tsoil_dbl, interp_method );
% locate gaps of more than five days and put NaNs back - linear interpolation
% doesn't do well in those cases
orig_size = size( Tsoil_dbl );
rle_idx = rle( reshape( double( nan_idx ), [], 1 ) );
five_days = 48 * 5; % five days in units of 30-minute periods
five_day_gaps = find( ( rle_idx{ 1 } == 1 ) & ( rle_idx{ 2 } > five_days ) );
rle_idx{ 1 }( five_day_gaps ) = NaN;
nan_idx = isnan( reshape( rle( rle_idx ), orig_size ) );
Tsoil_dbl( nan_idx ) = NaN;
Tsoil = replacedata( Tsoil, Tsoil_dbl );
if draw_plots
plot_soil_pit_data( Tsoil, ...
nan_idx, ...
pcp );
end