Skip to content

Working with a moving window (introducing seasonality)

miturbide edited this page Feb 25, 2016 · 18 revisions

By default, the whole train period as defined by the user is considered to calibrate the methods. It is also interesting to correct each day of the year (doy) independently by using a moving window centered on each doy to calibrate the correction. Therefore, instead of having one correction function for the whole period , there would be one correction for each doy. The user can specify the length (in days) of the moving window by means of the property CorrectionWindow.

Here, the same data as in the previous worked example is used (3.1. Simple application of the methods)

#observations: precipitation and mean temperature at the Igueldo station
# precipitation
data(VALUE_Igueldo_tp)
obs <- VALUE_Igueldo_tp

# temperature
data(VALUE_Igueldo_tas)
obs.t <- VALUE_Igueldo_tas

#reanalysis: NCEP reanalysis precipitation and mean temperature for 
#the Iberian peninsula

# precipitation
data(NCEP_Iberia_tp)
pred <- NCEP_Iberia_tp

# temperature
data(NCEP_Iberia_tas)
pred.t <- NCEP_Iberia_tas

###Bias correction

eQM

#WITHOUT WINDOW:
#For precipitation
cal <- biasCorrection (obs = obs, pred = pred, sim = pred, method = "eqm")
#For temperature
cal.t <- biasCorrection (obs = obs.t, pred = pred.t, sim = pred.t, method = "eqm")

#WITH WINDOW:
#For precipitation
wcal <- biasCorrection (obs = obs, pred = pred, sim = pred, method = "eqm", window = 11)
#For temperature
wcal.t <- biasCorrection (obs = obs.t, pred = pred.t, sim = pred.t, method = "eqm", window = 11)

Once we have the calibrated simulation for the test period, we can validate the result against the observational reference. Here we show the time series for the first year of the tested period (1991-2000) of the original simulation (red), the calibrated simulation (blue) and the observation (black) and the Pearson correlation r (for temperature) or Spearman correlation rho (for precipitation) and the Root Mean Square Error (RMSE) as accuracy measures for the calibrated simulation. Plots of the quantiles for the tested period are also shown, to better analyze the effect of the applied method:

# grid cell corresponding to the SAN SEBASTIAN - IGUELDO station

x <- cal$xyCoords$x[findInterval(x = obs$xyCoords[1], vec = cal$xyCoords$x)]
y <- cal$xyCoords$y[findInterval(x = obs$xyCoords[2], vec = cal$xyCoords$y)]

loc <- c(x,y)

WITHOUT WINDOW:

quickDiagnostics(obs = obs, sim = pred, downscaled = cal, location = loc)
quickDiagnostics(obs = obs.t, sim = pred.t, downscaled = cal.t, location = loc)

WITH WINDOW:

quickDiagnostics(obs = obs, sim = pred, downscaled = wcal, location = loc)
quickDiagnostics(obs = obs.t, sim = pred.t, downscaled = wcal.t, location = loc)

gQM

#WITHOUT WINDOW:
#For precipitation
cal <- biasCorrection (obs = obs, pred = pred, sim = pred, method = "gqm")

#WITH WINDOW:
#For precipitation
wcal <- biasCorrection (obs = obs, pred = pred, sim = pred, method = "gqm", window = 11)

WITHOUT WINDOW:

quickDiagnostics(obs = obs, sim = pred, downscaled = cal, location = loc)

WITH WINDOW:

quickDiagnostics(obs = obs, sim = pred, downscaled = wcal, location = loc)

<-- Home page of the Wiki

print(sessionInfo())
Clone this wiki locally