Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implementation of HDS in SUMMA #568

Open
wants to merge 21 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -35,3 +35,5 @@ Makefile-*
*.backup
# site directory from mkdocs
site/
# vscode setting files
.vscode
1 change: 1 addition & 0 deletions build/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,7 @@ SUMMA_SOLVER= \
opSplittin.f90 \
coupled_em.f90 \
run_oneHRU.f90 \
HDS.f90 \
run_oneGRU.f90
SOLVER = $(patsubst %, $(ENGINE_DIR)/%, $(SUMMA_SOLVER))

Expand Down
1 change: 0 additions & 1 deletion build/source/driver/.gitignore

This file was deleted.

1 change: 1 addition & 0 deletions build/source/driver/summa_modelRun.f90
Original file line number Diff line number Diff line change
Expand Up @@ -250,6 +250,7 @@ subroutine summa_runPhysics(modelTimeStep, summa1_struc, err, message)
typeStruct%gru(iGRU), & ! intent(in): local classification of soil veg etc. for each HRU
idStruct%gru(iGRU), & ! intent(in): local classification of soil veg etc. for each HRU
attrStruct%gru(iGRU), & ! intent(in): local attributes for each HRU
bparStruct%gru(iGRU), & ! intent(in): basin-average parameters for HDS
! data structures (input-output)
mparStruct%gru(iGRU), & ! intent(inout): local model parameters
indxStruct%gru(iGRU), & ! intent(inout): model indices
Expand Down
11 changes: 10 additions & 1 deletion build/source/driver/summa_restart.f90
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ module summa_restart
USE var_lookup,only:iLookDIAG ! look-up values for local column model diagnostic variables
USE var_lookup,only:iLookFLUX ! look-up values for local column model fluxes
USE var_lookup,only:iLookBVAR ! look-up values for basin-average model variables
USE var_lookup,only:iLookBPAR ! look-up values for basin-average model parameters used by HDS
USE var_lookup,only:iLookDECISIONS ! look-up values for model decisions

! safety: set private unless specified otherwise
Expand Down Expand Up @@ -67,7 +68,9 @@ subroutine summa_readRestart(summa1_struc, err, message)
! model decisions
USE mDecisions_module,only:& ! look-up values for the choice of method for the spatial representation of groundwater
localColumn, & ! separate groundwater representation in each local soil column
singleBasin ! single groundwater store over the entire basin
singleBasin, & ! single groundwater store over the entire basin
HDSmodel ! Hysteretic Depressional Storage model implementation for prairie potholes
USE HDS,only:init_summa_HDS ! initialize HDS variables at the GRU level
! ---------------------------------------------------------------------------------------
! * variables
! ---------------------------------------------------------------------------------------
Expand Down Expand Up @@ -227,6 +230,12 @@ subroutine summa_readRestart(summa1_struc, err, message)
dt_init%gru(iGRU)%hru(iHRU) = progStruct%gru(iGRU)%hru(iHRU)%var(iLookPROG%dt_init)%dat(1) ! seconds
end do

! *****************************************************************************
! *** initialize HDS variables at the GRU level
! *****************************************************************************
if(model_decisions(iLookDECISIONS%prPotholes)%iDecision == HDSmodel)then
call init_summa_HDS(bvarStruct%gru(iGRU), bparStruct%gru(iGRU))
endif
end do ! end looping through GRUs

! *****************************************************************************
Expand Down
2 changes: 1 addition & 1 deletion build/source/driver/summa_setup.f90
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ module summa_setup
USE var_lookup,only:iLookATTR ! look-up values for local attributes
USE var_lookup,only:iLookTYPE ! look-up values for classification of veg, soils etc.
USE var_lookup,only:iLookPARAM ! look-up values for local column model parameters
USE var_lookup,only:iLookID ! look-up values for local column model parameters
USE var_lookup,only:iLookID ! look-up values for local column model parameters
USE var_lookup,only:iLookBVAR ! look-up values for basin-average model variables
USE var_lookup,only:iLookDECISIONS ! look-up values for model decisions
USE globalData,only:urbanVegCategory ! vegetation category for urban areas
Expand Down
19 changes: 19 additions & 0 deletions build/source/dshare/get_ixname.f90
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ function get_ixdecisions(varName)
case('subRouting' ); get_ixdecisions=iLookDECISIONS%subRouting ! choice of method for sub-grid routing
case('snowDenNew' ); get_ixdecisions=iLookDECISIONS%snowDenNew ! choice of method for new snow density
case('snowUnload' ); get_ixdecisions=iLookDECISIONS%snowUnload ! choice of parameterization for snow unloading from canopy
case('prPotholes' ); get_ixdecisions=iLookDECISIONS%prPotholes ! choice of parameterization for prairie potholes
! get to here if cannot find the variable
case default
get_ixdecisions = integerMissing
Expand Down Expand Up @@ -403,6 +404,9 @@ function get_ixparam(varName)
case('zmaxLayer2_upper' ); get_ixparam = iLookPARAM%zmaxLayer2_upper ! maximum layer depth for the 2nd layer when > 2 layers (m)
case('zmaxLayer3_upper' ); get_ixparam = iLookPARAM%zmaxLayer3_upper ! maximum layer depth for the 3rd layer when > 3 layers (m)
case('zmaxLayer4_upper' ); get_ixparam = iLookPARAM%zmaxLayer4_upper ! maximum layer depth for the 4th layer when > 4 layers (m)
! Oudin et al. (2005) PET parameters (for HDS)
case('oudinPETScaleK1' ); get_ixparam = iLookPARAM%oudinPETScaleK1 ! Oudin PET formula scaling factor (deg C)
case('oudinPETTempThrK2' ); get_ixparam = iLookPARAM%oudinPETTempThrK2 ! Oudin PET formula temperature threshold (deg C)
! get to here if cannot find the variable
case default
get_ixparam = integerMissing
Expand Down Expand Up @@ -861,6 +865,12 @@ function get_ixbpar(varName)
! sub-grid routing
case('routingGammaShape' ); get_ixbpar = iLookBPAR%routingGammaShape ! shape parameter in Gamma distribution used for sub-grid routing (-)
case('routingGammaScale' ); get_ixbpar = iLookBPAR%routingGammaScale ! scale parameter in Gamma distribution used for sub-grid routing (s)
! parameters for HDS pothole storage
case('depressionDepth' ); get_ixbpar = iLookBPAR%depressionDepth ! average depth of depressional storage (depressionVol/depressionArea) (m)
case('depressionAreaFrac' ); get_ixbpar = iLookBPAR%depressionAreaFrac ! fractional depressional area (depressionArea/basinArea) (-)
case('depressionCatchAreaFrac'); get_ixbpar = iLookBPAR%depressionCatchAreaFrac ! fractional area (of the landArea= basinArea - depressionArea) that drains to the depressions (-)
case('depression_p' ); get_ixbpar = iLookBPAR%depression_p ! shape of the slope profile (-)
case('depression_b' ); get_ixbpar = iLookBPAR%depression_b ! shape of contributing fraction curve (-)
! get to here if cannot find the variable
case default
get_ixbpar = integerMissing
Expand Down Expand Up @@ -895,6 +905,15 @@ function get_ixbvar(varName)
case('routingFractionFuture' ); get_ixbvar = iLookBVAR%routingFractionFuture ! fraction of runoff in future time steps (-)
case('averageInstantRunoff' ); get_ixbvar = iLookBVAR%averageInstantRunoff ! instantaneous runoff (m s-1)
case('averageRoutedRunoff' ); get_ixbvar = iLookBVAR%averageRoutedRunoff ! routed runoff (m s-1)
! variables for pothole storage (HDS)
case('vMin' ); get_ixbvar = iLookBVAR%vMin ! volume of water in the meta depression at the start of a fill period (m3)
case('depConAreaFrac' ); get_ixbvar = iLookBVAR%depConAreaFrac ! contributing area fraction of pothole dominated areas [-]
case('basinConAreaFrac' ); get_ixbvar = iLookBVAR%basinConAreaFrac ! contributing area fraction per the entire subbasin from pothole and non-pothole areas [-]
case('pondVolFrac' ); get_ixbvar = iLookBVAR%pondVolFrac ! fractional pond volume = pondVol/depressionVol (-)
case('pondVol' ); get_ixbvar = iLookBVAR%pondVol ! pond volume at the end of time step (m3)
case('pondArea' ); get_ixbvar = iLookBVAR%pondArea ! pond area at the end of the time step (m2)
case('pondOutflow' ); get_ixbvar = iLookBVAR%pondOutflow ! pond outflow (m3)
case('pondEvap' ); get_ixbvar = iLookBVAR%pondEvap ! pond evaporation (kg m-2 s-1)
! get to here if cannot find the variable
case default
get_ixbvar = integerMissing
Expand Down
24 changes: 24 additions & 0 deletions build/source/dshare/popMetadat.f90
Original file line number Diff line number Diff line change
Expand Up @@ -284,6 +284,9 @@ subroutine popMetadat(err,message)
mpar_meta(iLookPARAM%zmaxLayer2_upper) = var_info('zmaxLayer2_upper' , 'maximum layer depth for the 2nd layer when > 2 layers' , 'm' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
mpar_meta(iLookPARAM%zmaxLayer3_upper) = var_info('zmaxLayer3_upper' , 'maximum layer depth for the 3rd layer when > 3 layers' , 'm' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
mpar_meta(iLookPARAM%zmaxLayer4_upper) = var_info('zmaxLayer4_upper' , 'maximum layer depth for the 4th layer when > 4 layers' , 'm' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
!
mpar_meta(iLookPARAM%oudinPETScaleK1) = var_info('oudinPETScaleK1' , 'Oudin PET formula scaling factor' , 'deg C' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
mpar_meta(iLookPARAM%oudinPETTempThrK2) = var_info('oudinPETTempThrK2' , 'Oudin PET formula temperature threshold' , 'deg C' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)

! -----
! * basin parameter data...
Expand All @@ -293,6 +296,15 @@ subroutine popMetadat(err,message)
bpar_meta(iLookBPAR%basin__aquiferBaseflowExp) = var_info('basin__aquiferBaseflowExp', 'baseflow exponent for the big bucket' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bpar_meta(iLookBPAR%routingGammaShape) = var_info('routingGammaShape' , 'shape parameter in Gamma distribution used for sub-grid routing', '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bpar_meta(iLookBPAR%routingGammaScale) = var_info('routingGammaScale' , 'scale parameter in Gamma distribution used for sub-grid routing', 's' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)

! -----
! * HDS pothole storage parameters...
! -----------------------------------
bpar_meta(iLookBPAR%depressionDepth) = var_info('depressionDepth' , 'average depth of depressional storage (depressionVol/depressionArea)' , 'm' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bpar_meta(iLookBPAR%depressionAreaFrac) = var_info('depressionAreaFrac' , 'fractional depressional area (depressionArea/basinArea)' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bpar_meta(iLookBPAR%depressionCatchAreaFrac) = var_info('depressionCatchAreaFrac' , 'fractional area of the landArea (basinArea - depressionArea) that drains to the depressions', '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bpar_meta(iLookBPAR%depression_p) = var_info('depression_p' , 'shape of the slope profile' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bpar_meta(iLookBPAR%depression_b) = var_info('depression_b' , 'shape of contributing fraction curve' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)

! -----
! * local model prognostic (state) variables...
Expand Down Expand Up @@ -596,6 +608,18 @@ subroutine popMetadat(err,message)
bvar_meta(iLookBVAR%routingFractionFuture) = var_info('routingFractionFuture' , 'fraction of runoff in future time steps' , '-' , get_ixVarType('routing'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%averageInstantRunoff) = var_info('averageInstantRunoff' , 'instantaneous runoff' , 'm s-1' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%averageRoutedRunoff) = var_info('averageRoutedRunoff' , 'routed runoff' , 'm s-1' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)

! -----
! * basin-wide HDS pothole storage fluxes/variables...
! -----------------------------------------
bvar_meta(iLookBVAR%vMin) = var_info('vMin' , 'volume of water in the meta depression at the start of a fill period' , 'm3' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%depConAreaFrac) = var_info('depConAreaFrac' , 'contributing area fraction of pothole dominated areas' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%basinConAreaFrac) = var_info('basinConAreaFrac' , 'contributing area fraction per the entire subbasin from pothole and non-pothole areas' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%pondVolFrac) = var_info('pondVolFrac' , 'fractional pond volume at the end of time step' , '-' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%pondVol) = var_info('pondVol' , 'pond volume at the end of time step' , 'm3' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%pondArea) = var_info('pondArea' , 'pond area at the end of the time step' , 'm2' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%pondOutflow) = var_info('pondOutflow' , 'pond outflow' , 'm3' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)
bvar_meta(iLookBVAR%pondEvap) = var_info('pondEvap' , 'pond evaporation' , 'kg m-2 s-1' , get_ixVarType('scalarv'), iMissVec, iMissVec, .false.)

! -----
! * model indices...
Expand Down
Loading