VIC分布式水文模型——冻土模型设置Frozen Soil Formulation

2024-01-29 07:30

本文主要是介绍VIC分布式水文模型——冻土模型设置Frozen Soil Formulation,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1 前言

2 全局参数设置

2.1 Simulation Parameters

 2.2 Soil parameters

3 总结


1 前言

如前文所述,VIC可以使用Liang et al. (1999) 的近似土壤温度曲线,也可以使用Cherkauer and Lettenmaier (1999) 所述的将土壤含冰量考虑在内的有限差分解法。

采用冻土模型时,在全局文件和土壤参数文件中一些参数都要做相应的修改和设置。我采用的VIC的版本是4.1.2d版本,全局参数的版本是4.1.x版的。

我在做冻土模式的时候,在网上没有找到相应的参数设置的教程,于是阅读了官网上和文献中的有关论述,做出了下面的总结,如有不正确,请帮忙指出,欢迎交流!

2 全局参数设置

  • Liang et al. (1999): 设置 QUICK_FLUX = TRUE ,这是 FULL_ENERGY = TRUEFROZEN_SOIL = FALSE 的默认值。
  • Cherkaure et al. (1999): 设置 QUICK_FLUX = FALSE, 这是 FROZEN_SOIL = TRUE 的默认值。

        * 默认情况下,有限差分法采用隐格式求解;

        * 默认情况下,有限差分公式的节点呈指数分布。

 在Cherkaure et al. (1999)的算法中,涉及对永久冻土的考虑。在上面的全局参数设置的基础上,另外设置

  • 采用隐格式求解土壤热分布,这是默认设置。IMPLICIT    TRUE
  • 采用指数节点间距,即土壤表面节点间距密集,深处节点间距稀疏。EXP_TRANS   TRUE   如下图所示。

2.1 Simulation Parameters

# Simulation Parameters
#######################################################################
NLAYER        3          # number of soil layers
NODES        12         # number of soil thermal nodes 

第一行是土壤层数,一般为2层或者3层,2层就是不包含顶薄层,3层是VIC-3L改进后的增加了顶薄层之后的,在新版本的VIC中一般设置为3层,因为在土壤参数中需要率定的参数包含3层土壤厚度DEPTH1,2,3。

第二行为土壤节点数,这一行在采用能量平衡或者冻土模式的时候需要设置,即上面的图片中的求解热通量时求解的热节点数量,在节点处求解土壤温度Soil T,这里的数量需要合理选择,节点数多精度高但是计算时间长,且和土壤厚度也有关。如果数量太少的话,求解时会报错,说明Thermal Nodes数量太少。


TIME_STEP     12     # model time step in hours (set to 24 if FULL_ENERGY = FALSE, set to <                                          24 if FULL_ENERGY = TRUE)
SNOW_STEP    12    # time step in hours for which to solve the snow model (should =                                                       TIME_STEP if TIME_STEP < 24)

这两行是求解的时间步长,如果单纯是水量平衡的时候,TIME_STEP设置为24,如果是能量平衡或者是冻土模式,则需要设置的小于24h,但是要注意的是此时SNOW_STEP和TIME_STEP的值应该设置为相同的数值。


STARTYEAR    1985    # year model simulation starts
STARTMONTH    01     # month model simulation starts
STARTDAY    01           # day model simulation starts
STARTHOUR    00       # hour model simulation starts
ENDYEAR     2009       # year model simulation ends
ENDMONTH    12         # month model simulation ends
ENDDAY        31           # day model simulation ends

上面是计算的起止时间,应该和之前制备的气象强迫数据对应。需要注意的是制备气象数据的时候data文件里面是没有日期的,所以应该和制备时的气象数据完全对应,如果data文件里面的数据时间更长,那么就会从data数据的第一行开始算,就会导致计算出来的时间节点和实际不对应


FULL_ENERGY     FALSE    # TRUE = calculate full energy balance; FALSE = compute water                                                        balance only
FROZEN_SOIL    TRUE      # TRUE = calculate frozen soils

如果开启冻土模式,则就应该是能量平衡模式。冻土模式设置见最上面的说明。Cherkaure et al. (1999)的算法中应该设置为TRUE。

#######################################################################

#######################################################################
# Soil Temperature Parameters
# VIC will choose appropriate values for QUICK_FLUX and IMPLICIT depending on values of         FULL_ENERGY and FROZEN_SOIL; the user should only need to override VIC's choices in         special cases.
# The other options in this section are only applicable when FROZEN_SOIL is TRUE and their          values depend on the application.
#######################################################################
QUICK_FLUX    FALSE    # TRUE = use simplified ground heat flux method of Liang et al                                                           (1999); FALSE = use finite element method of Cherkauer et al (1999)
IMPLICIT    TRUE    # TRUE = use implicit solution for soil heat flux equation of Cherkauer et al                                        (1999), otherwise uses original explicit solution.

上面这两个参数应根据所选用的冻土算法设置,一般在上面的参数中根据选择的FROZEN_SOIL和FULL_ENERGY模型会自动设置,可以把这两行注释掉,除非要另外更改。比如采用Cherkauer et al (1999)算法时就是FALSE和TRUE。若不采用隐格式求解的话,则程序不稳定。


QUICK_SOLVE    FALSE    # TRUE = Use Liang et al., 1999 formulation for iteration, but explicit                                                  finite difference method for final step.

这里TRUE的话就是采用Liang et al. (1999) 的算法迭代,但是最后一步采用显格式有限差分。


NO_FLUX        FALSE    # TRUE = use no flux lower boundary for ground heat flux computation;                                             FALSE = use constant flux lower boundary condition.  If NO_FLUX =                                               TRUE, QUICK_FLUX MUST = FALSE

若选择TRUE则在有限差分计算热通量的时候,下边界没有通量,只有QUICK_FLUX = FALSE或FULL_ENERGY = TRUE 或 FROZEN_SOIL = TRUE时有效。如果选择FALSE则下边界为一恒定温度。默认选择FALSE。


EXP_TRANS    TRUE    # TRUE = exponentially distributes the thermal nodes in the Cherkauer                                            et al. (1999) finite difference algorithm, otherwise uses linear distribution

这里是选择土壤热节点上的温度分布为指数分布还是线性分布,默认为指数分布。如上面的图片。


GRND_FLUX_TYPE    GF_410    # Options for ground flux:
                                                      # GF_406 = use (flawed) formulas for ground flux, deltaH, and                                                          fusion from VIC 4.0.6 and earlier;
                                                      # GF_410 = use formulas from VIC 4.1.0 (ground flux, deltaH,                                                           and fusion are correct; deltaH and fusion ignore surf_atten);
                                                      # Default = GF_410
TFALLBACK    TRUE    # TRUE = when temperature iteration fails to converge, use previous                                                 time step's T value

这个选项用于处理土壤温度迭代失败。若选择FALSE,则当温度迭代不收敛时报错,即显示error:----等,我在测试中发现即使有网格迭代不收敛,计算仍然可以继续,但是计算结果不理想。该选项将影响积雪、地表和土壤节点的温度。若选择TRUE,模型将在每个网格计算结束时报告使用前一时间步的T的总次数。默认值为TRUE。

#######################################################################

 2.2 Soil parameters

 除了水量平衡也要设置和率定的参数之外,以下几个参数在冻土算法中参与计算。

Avg_T       平均温度,一般设置为年平均气温,作为土壤热通量计算的下边界条件

DP            damping depth 求解土壤热通量的土壤深度,要比D1+D2+D3大

BUBBLE_1,2,3    土壤的气泡压力,可以根据土壤的类型查表,也可以根据水力传导度估算

                              bubble = 0.32*expt + 4.3

3 总结

以上是目前对冻土算法具体设置的一些总结,来源于我在阅读文献时的经验以及对官网上相关论述的总结,但是在具体的实践中,还没有得出满意的结果,所以可能还会持续的增添总结。

后面打算对在计算时出现的报错及原因进行分析和总结,欢迎交流。

这篇关于VIC分布式水文模型——冻土模型设置Frozen Soil Formulation的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/656176

相关文章

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

Redis分布式锁中Redission底层实现方式

《Redis分布式锁中Redission底层实现方式》Redission基于Redis原子操作和Lua脚本实现分布式锁,通过SETNX命令、看门狗续期、可重入机制及异常处理,确保锁的可靠性和一致性,是... 目录Redis分布式锁中Redission底层实现一、Redission分布式锁的基本使用二、Red

redis和redission分布式锁原理及区别说明

《redis和redission分布式锁原理及区别说明》文章对比了synchronized、乐观锁、Redis分布式锁及Redission锁的原理与区别,指出在集群环境下synchronized失效,... 目录Redis和redission分布式锁原理及区别1、有的同伴想到了synchronized关键字

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE