Skip to contents

Trains an SWR model based on input and target time series data.

Usage

trainSWR(
  ts_input,
  ts_output,
  iter = 5,
  runs,
  log = FALSE,
  parallel,
  return = "best",
  param_selection = "best_bic",
  algorithm = "GENOUD"
)

Arguments

ts_input

a vector or ts object containing the input time series

ts_output

a vector or ts object (on the same time scale as ts_input) containing the target time series

iter

number of iterations (maximum number of windows)

runs

[Deprecated] number of independent model runs; no longer supported due to deterministic window initialization

log

whether a log-linear model should be used

parallel

[Deprecated] should the runs be computed in parallel? If FALSE, all runs are computed in serial. If TRUE, all runs are computed in parallel with a maximum number of cores. If a scalar is provided, the number of cores is set manually. No longer supported for single-run models

return

[Deprecated] either "best" (best model run is returned), or "all" (all model runs are returned)

param_selection

either "max" (maximum number of windows), or "best_rmse", "best_aic", or "best_bic" to optimize RMSE, AIC, or BIC, respectively

algorithm

either "GENOUD" (genetic optimization using derivatives), or "BOBYQA" (bound optimization by quadratic approximation)

Value

an object of type SWR model

Details

The training procedure implements an iterative algorithm described in schrunner2023gaussianSlidingWindowReg. A new window is added in each iteration, hence the number of windows equals to the iteration counter. Input and output time series are provided in ts_input and ts_output, respectively. Both are required to have equal lengths. The optimization is performed using the GENOUD algorithm mebanesekhon2011genoudSlidingWindowReg, implemented in rgenoud rgenoudSlidingWindowReg, or alternatively using the BOBYQA algorithm powell2009bobyqaSlidingWindowReg, implemented in nloptr nloptrSlidingWindowReg. As training hyperparameter, iter indicates the number of iterations, which equals to the maximum number of windows selected by the model. Parameters return and param_selection indicate which criterion should be used to determine the number of windows; option are: return="all" (no hyperparameter selection) or return="best", which allows one of the following options:

  • param_selection="best_aic": select model with lowest AIC,

  • param_selection="best_bic": select model with lowest BIC,

  • param_selection="best_rmse": select model with lowest RMSE. Arguments runs, parallel are deprecated and should not be used.

References

Examples

# train a model based on one year of observations
set.seed(42)
data(sampleWatershed)
mod <- trainSWR(sampleWatershed$rain[1:365],
                sampleWatershed$gauge[1:365],
                iter = 2)
#> Warning: The `runs` argument of `trainSWR()` is deprecated as of SlidingWindowReg 0.1.1.
#>  Multiple model runs are not useful with deterministic window initializations.
#> Warning: The `parallel` argument of `trainSWR()` is deprecated as of SlidingWindowReg
#> 0.1.1.
#>  Parallel model runs are not useful with deterministic window initializations.
#> Warning: The `return` argument of `trainSWR()` is deprecated as of SlidingWindowReg
#> 0.1.1.
#>  Return argument is unused.
summary(mod)
#> SlidingWindowReg (SWR) model object with k = 2 windows
#> 
#> | window| delta| sigma| beta|
#> |------:|-----:|-----:|----:|
#> |      1|  0.17| 21.28| 0.36|
#> |      2|  0.86|  0.36| 0.67|
#>