knitr::opts_chunk$set(
  collapse = TRUE,
  comment = "#>"
)

极度简单、皆可掌握的XAJ模型。 Rcpp版的XAJ模型为钟睿达师弟所写,使用请正确引用。

1. 输入

只需要输入以下三个变量:

即可实现径流模拟。模拟过程中,XAJ_calibKGE为目标函数,采用sceua实现自动率参。

2. 模型训练

下文模拟的是2021年10月山西暴雨中心的汾河流域,河津站。以2012-2018年作为率定期,将该时段的所有数据拿来训练。可以看到KGE最终可达0.707。

library(hydroTools) # remotes::install_github("rpkgs/hydroTools")

infile = system.file("extdata/XAJ_input_Hejin_2012-2018.rda", package = "hydroTools")
load(infile)

df = input$data
res <- XAJ_calib(df$Qobs, df$prcp, df$ET0, date = df$date,
    input$area, dt = 24, maxn = 1000)

print(str(res), 2)

从图来看,模型整体模拟结果尚可。但部分洪水过程无法捕捉到(如2018年春秋季节),怀疑是流域内水库放水的人为活动影响所致。

df_q = res$data[, c("date", "Qobs", "Qsim")]
df_prcp = res$data[, c("date", "prcp")]
# plot_calib(res$data, main = input$site)
plot_runoff(df_q, df_prcp, ylim2 = c(60, 0), legend.position = c(1, 0.6))

3. 模型验证

将2021年山西暴雨期间的气象数据输入,即可得到2021年山西暴雨洪水的模拟情况。这里暂且假设2021的气象数据newdata已知(用之前的数据df代替)。

newdata需包含如下变量:

newdata带入即可得到验证期的径流模拟情况:

res_valid = XAJ_predict(res$model, newdata = df)
head(res_valid)

安装方法

remotes::install_github("rpkgs/hydroTools")

使用请正确引用

  1. Dongdong Kong and Ruida Zhong (2021). hydroTools: Tools for hydrological model. R package version 0.1.4.

  2. Ruida Zhong, Dongdong Kong, Xiaohong Chen, Zhaoli Wang and Chengguang Lai (2021). VIC5: The Variable Infiltration Capacity (VIC) Hydrological Model. R package version 0.2.4. https://CRAN.R-project.org/package=VIC5

  3. Ruida Zhong (2018). XAJ: An R implementation of three-source Xinanjiang model by Renjun Zhao. R package version 0.0.1. https://github.com/Sibada/XAJ



rpkgs/hydroTools documentation built on Oct. 8, 2024, 7:47 p.m.