‘airGRdatassim’ is a package based on the ‘airGR’ hydrological modeling package. It provides the tools to assimilate observed discharges in the GR daily hydrological model (GR4J, GR5J and GR6J, with and without the CemaNeige snow model). The package is developed at INRAE-Antony (Catchment Hydrology research group of the HYCAR Research Unit, France). More information about the efficiency of these data assimilation schemes with GR5J can be found in Piazzi et al. (2021)
To install the version of the package that is on the CRAN, you just have to use the following command line:
install.packages("airGRdatassim")
To use the development version of the package that is on GitLab, you have first install the ‘remotes’ package. Then you can install the ‘airGRdatassim’ package in the R environment:
install.packages("remotes")
::install_gitlab(repo = "HYCAR-Hydro/airgrdatassim",
remoteshost = "https://gitlab.irstea.fr",
dependencies = TRUE,
build_vignettes = TRUE)
The ‘airGRdatassim’ package allows users of GR Hydrological models to assimilate discharge observations with the aim of improving streamflow simulations. The data assimilation (DA) scheme has been designed to allow the choice between two sequential ensemble-based DA techniques, namely the Ensemble Kalman filter (EnKF) and the Particle filter (PF). The functions are coded in R and both their names and arguments are consistent with the ‘airGR’ package.
With the aim of providing an user-friendly package, ‘airGRdatassim’ relies on two main functions :
CreateInputsPerturb()
generates the probabilistic model
inputs to perform the ensemble-based DA when accounting for the
uncertainty in meteorological forcings;RunModel_DA()
performs streamflow ensemble simulations
with the assimilation of observed discharges through the EnKF or the PF
scheme.Consistently with the ‘airGR’ package, both structure and class of function arguments are specifically defined to prevent the risk of mis-use and ensure the flexibility of functions. Advanced users wishing to apply the package to their own models will need to comply with these imposed structures and refer to the package source codes to get all the specification requirements.
DA schemes are designed to be coupled with GR daily hydrological
model, which is implemented in the ‘airGR’ package. This model can be
called within the ‘airGRdatassim’ package using the following ‘airGR’
functions (use the command ?airGR
to get the references of
the GR models):
RunModel_GR4J()
: four-parameter daily lumped
hydrological modelRunModel_GR5J()
: five-parameter daily lumped
hydrological modelRunModel_GR6J()
: six-parameter daily lumped
hydrological modelRunModel_CemaNeigeGR4J()
: combined use of GR4J and
CemaNeigeRunModel_CemaNeigeGR5J()
: combined use of GR5J and
CemaNeigeRunModel_CemaNeigeGR6J()
: combined use of GR6J and
CemaNeigeBecause ‘airGRdatassim’ is an airGR-based package, specific ‘airGR’ functions should be jointly used to ensure the proper use of the ‘airGRdatassim’ tools. Indeed, before performing the DA-based streamflow simulations, the hydrological model needs to be calibrated through the ‘airGR’ calibration function. Therefore, the following steps are recommended:
Calibration_Michel()
in the
‘airGR’ package, run the provided example and then refer to the help for
CreateCalibOptions()
to understand how a model calibration
is prepared/made;CreateInputsPerturb()
to
understand how the probabilistic model inputs are generated, if the
uncertainty in meteorological forcings is taken into account;RunModel_DA()
to understand how
to perform the DA-based streamflow simulations;ErrorCrit_NSE()
and
CreateInputsCrit()
in the ‘airGR’ package to understand how
the computation of an error criterion is prepared/made.For more information and to get started with the package, you can
refer to the vignette
(vignette("get_started", package = "airGRdatassim")
).