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

402 merge from am3 params #404

Merged
merged 15 commits into from
Nov 6, 2024
Merged
Show file tree
Hide file tree
Changes from 11 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
8 changes: 7 additions & 1 deletion src/coupled/AM3/control/casa/shared/progs_cnp_vars_mod.F90
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,15 @@ MODULE progs_cnp_vars_mod
PUBLIC :: progs_cnp_vars_assoc
PUBLIC :: progs_cnp_vars_data_type
PUBLIC :: progs_cnp_vars_type
PUBLIC :: nCpool_casa
PUBLIC :: nNpool_casa
PUBLIC :: nPPool_casa
PRIVATE

INTEGER, PARAMETER :: nCpool_casa = 10
INTEGER, PARAMETER :: nNpool_casa = 10
INTEGER, PARAMETER :: nPPool_casa = 12

CHARACTER(LEN=*), PARAMETER, PRIVATE :: ModuleName='PROGS_CNP_VARS_MOD'
! Prognostic Fields for CASA-CNP to be initialized from IO
TYPE :: progs_cnp_vars_data_type
Expand Down Expand Up @@ -54,7 +61,6 @@ MODULE progs_cnp_vars_mod

SUBROUTINE progs_cnp_vars_alloc(land_pts, nsurft, progs_cnp_vars_data )

USE grid_constants_mod_cbl, ONLY : nCpool_casa, nNpool_casa, nPpool_casa
USE casadimension, ONLY: mwood

IMPLICIT NONE
Expand Down
2 changes: 1 addition & 1 deletion src/offline/cable_parameters.F90
Original file line number Diff line number Diff line change
Expand Up @@ -2474,7 +2474,7 @@ SUBROUTINE consistency_ice_veg_soil(soil, veg)
! Ensure that when an active patch has a veg type of ice then its soil type is also ice and vice versa
! Any change effected to enforce this consistency includes correcting the appropriate paramter values

USE grid_constants_mod_cbl, ONLY : ICE_SoilType, ICE_VegType
USE grid_constants_mod_cbl, ONLY : ICE_SoilType, ICE_VegType => ice_cable
USE cable_phys_constants_mod, ONLY : csice, density_ice

TYPE (soil_parameter_type), INTENT(INOUT) :: soil ! soil parameter data
Expand Down
16 changes: 5 additions & 11 deletions src/params/cable_other_constants_mod.F90
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,10 @@ MODULE cable_other_constants_mod
!-----------------------------------------------------------------------------
!CABLE science not yet in JAC uses msn to describe number of snow layers
USE grid_constants_mod_cbl, ONLY: nrb, nsl, nsCs, nvCs, msn => nsnl
USE grid_constants_mod_cbl, ONLY: n_soiltypes => nsoil_max ! # of soil types [9]
USE grid_constants_mod_cbl, ONLY: niter ! # iterations za/L
USE grid_constants_mod_cbl, ONLY: mf !sunlit/shaded leaves
USE grid_constants_mod_cbl, ONLY: swb ! 2 shortwave bands (VIS,NIR)

IMPLICIT NONE

Expand All @@ -28,17 +32,7 @@ MODULE cable_other_constants_mod
REAL, PARAMETER :: rad_thresh = 0.001 ! min. zenithal angle for downward SW
REAL, PARAMETER :: lai_thresh = 0.001 ! min. LAI to be considered as vegetated

INTEGER, PARAMETER :: &
swb = 2, & ! 2 shortwave bands (initial division - visible /
! near infrared)
n_sw_bands = 4, & ! total number of shortwave radiation bands
! (above divided into direct / diffuse)
mf = 2, & ! types of leaves (sunlit / shaded)
r_2 = SELECTED_REAL_KIND(12, 50), &!this will be removed
! double precision real dimension
niter = 4, & ! number of iterations for za/L
n_assim_rates = 3, & ! Rubisco, RuBP and Sink-limited rates of photosynthesis
n_soiltypes = 9 ! number of soil types
INTEGER, PARAMETER :: r_2 = KIND(1.d0) ! SELECTED_REAL_KIND(12, 50)

REAL, PARAMETER :: &
max_snow_depth = 50000.0, & ! maximum depth of lying snow on tiles (kg/m2)
Expand Down
18 changes: 12 additions & 6 deletions src/params/grid_constants_cbl.F90
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
!#define UM_CBL YES
!******************************************************************************
! This source code is part of the Community Atmosphere Biosphere Land Exchange
! (CABLE) model. This work is licensed under the CSIRO Open Source Software
Expand Down Expand Up @@ -45,12 +46,17 @@ MODULE grid_constants_mod_cbl
INTEGER, PARAMETER :: nsCs = 2 ! # soil carbon stores
INTEGER, PARAMETER :: nvCs = 3 ! # vegetation carbon stores
INTEGER, PARAMETER :: ICE_SoilType = 9 ! SoilType Index (soilparm_cable.nml JAC)
INTEGER, PARAMETER :: lakes_cable = 16! SoilType Index (soilparm_cable.nml JAC)

INTEGER, PARAMETER :: ICE_VegType = 17 ! permanent ice index for veg

INTEGER, PARAMETER :: mf = 2 ! # leaves (sunlit, shaded)
INTEGER, PARAMETER :: niter = 4 ! number of iterations for za/L
#ifndef UM_CBL
! UM_CBL gets from cable_surface_types namelist
INTEGER, PARAMETER :: lakes_cable = 16 ! cable_surface_type (nml) Index
INTEGER, PARAMETER :: ice_cable = 17 ! cable_surface_type (nml) Index
#endif
INTEGER, PARAMETER :: mf = 2 ! # leaves (sunlit, shaded)
INTEGER, PARAMETER :: niter = 4 ! number of iterations for za/L
INTEGER, PARAMETER :: swb = 2 ! # SW bands (VIS+NIR) - CM3 alloc TYPEs
INTEGER, PARAMETER :: nCpool_casa = 10
INTEGER, PARAMETER :: nNpool_casa = 10
INTEGER, PARAMETER :: nPPool_casa = 12
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved

! Strictly NOT a constant. # of active tiles, length of CABLE working vectors
INTEGER :: mp
Expand Down
10 changes: 7 additions & 3 deletions src/science/albedo/cbl_snow_albedo.F90
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,9 @@ SUBROUTINE surface_albedosn( AlbSnow, AlbSoil, mp, nrb, ICE_SoilType, &
alvo = 0.95, & ! albedo for vis. on a new snow
aliro = 0.70 ! albedo for near-infr. on a new snow

REAL, PARAMETER :: sfact_default = 0.68
REAL, PARAMETER :: sfact_dark = 0.62
REAL, PARAMETER :: sfact_darker = 0.5
INTEGER :: i !looping variable

!initialise to the no-snow value for albedo for all land points
Expand All @@ -89,11 +92,12 @@ SUBROUTINE surface_albedosn( AlbSnow, AlbSoil, mp, nrb, ICE_SoilType, &
SoilAlbsoilF = 0.85
END WHERE

sfact(:) = 0.68
!initialize all land points
sfact(:) = sfact_default
WHERE (SoilAlbsoilF <= 0.14)
sfact = 0.5
sfact = sfact_darker ! NB: .14 corresponds to snow albedo < liq lakes
ELSE WHERE (SoilAlbsoilF > 0.14 .AND. SoilAlbsoilF <= 0.20)
sfact = 0.62
sfact = sfact_dark ! captures liq lakes & similar snow albedo cells
END WHERE

!first estimate of snow-affected surface albedos
Expand Down
29 changes: 21 additions & 8 deletions src/science/misc/cable_carbon.F90
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,11 @@ SUBROUTINE carbon_pl(dels, soil, ssnow, veg, canopy, bgc)
coef_drght, & ! coeff. for drought stress (eq. 8)
wbav ! water stress index

REAL :: CampbellExp(mp)
REAL :: EffStressIndexWater(mp)
REAL :: EffStressIndexWilting(mp)
REAL :: RelativeStress(mp)

REAL, DIMENSION(:), ALLOCATABLE :: &
rw, & !
tfcl, & !
Expand Down Expand Up @@ -150,8 +155,16 @@ SUBROUTINE carbon_pl(dels, soil, ssnow, veg, canopy, bgc)
wbav = MAX( 0.01, wbav ) ! EAK Jan2011

! drought stress
coef_drght = EXP( 5.*( MIN( 1., MAX( 1., wbav**( 2 - soil%ibp2 ) - 1.) / &
( soil%swilt**( 2 - soil%ibp2 ) - 1. ) ) - 1. ) )
CampbellExp = 2.0 - soil%ibp2
EffStressIndexWater = wbav**( CampbellExp ) - 1.0
EffStressIndexWater = MAX( 1.0, EffStressIndexWater )

EffStressIndexWilting = soil%swilt**( CampbellExp ) - 1.0

RelativeStress = EffStressIndexWater / EffStressIndexWilting
RelativeStress = MIN( 1.0, RelativeStress )

coef_drght = EXP( 5.0 * ( RelativeStress - 1.0 ) )
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved

coef_cd = ( coef_cold + coef_drght ) * 2.0e-7

Expand Down Expand Up @@ -212,13 +225,13 @@ SUBROUTINE soilcarb( soil, ssnow, veg, bgc, met, canopy)

USE cable_common_module

TYPE (soil_snow_type), INTENT(IN) :: ssnow
TYPE (bgc_pool_type), INTENT(IN) :: bgc
TYPE (met_type), INTENT(IN) :: met
TYPE (canopy_type), INTENT(INOUT) :: canopy
TYPE (soil_snow_type), INTENT(IN) :: ssnow
TYPE (bgc_pool_type), INTENT(IN) :: bgc
TYPE (met_type), INTENT(IN) :: met
TYPE (canopy_type), INTENT(INOUT) :: canopy

TYPE (soil_parameter_type), INTENT(IN) :: soil
TYPE (veg_parameter_type), INTENT(IN) :: veg
TYPE (soil_parameter_type), INTENT(IN) :: soil
TYPE (veg_parameter_type), INTENT(IN) :: veg

REAL, DIMENSION(mp) :: &
den, & ! sib3
Expand Down
5 changes: 2 additions & 3 deletions src/science/radiation/cbl_init_radiation.F90
Original file line number Diff line number Diff line change
Expand Up @@ -378,9 +378,8 @@ SUBROUTINE BeamFraction( RadFbeam, mp, nrb, Cpi,Ccoszen_tols_huge, metDoy, &


! Define beam fraction, fbeam:
! #355 beam fraction defined using total SW_down; applies to VIS&NIR equally
RadFbeam(:,1) = spitter(mp, cpi, metDoy, coszen, SW_down(:,1)+SW_down(:,2))
RadFbeam(:,2) = RadFbeam(:,1)
RadFbeam(:,1) = spitter(mp, cpi, metDoy, coszen, SW_down(:,1))
RadfBeam(:,2) = spitter(mp, cpi, metDoy, coszen, SW_down(:,2))
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved

! coszen is set during met data read in.
WHERE (coszen < Ccoszen_tols_huge )
Expand Down
36 changes: 22 additions & 14 deletions src/science/roughness/cable_roughness.F90
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
!#define UM_CBL YES
!==============================================================================
! This source code is part of the
! Australian Community Atmosphere Biosphere Land Exchange (CABLE) model.
Expand All @@ -22,17 +23,22 @@

MODULE cable_roughness_module

USE cable_phys_constants_mod, ONLY : CCSD => CSD
USE cable_phys_constants_mod, ONLY : CCRD => CRD
USE cable_phys_constants_mod, ONLY : CCCD => CCD
USE cable_phys_constants_mod, ONLY : CCCW_C => CCW_C
USE cable_phys_constants_mod, ONLY : CUSUHM => USUHM
USE cable_phys_constants_mod, ONLY : CVONK => VONK
USE cable_phys_constants_mod, ONLY : CA33 => A33
USE cable_phys_constants_mod, ONLY : CCTL => CTL
USE cable_phys_constants_mod, ONLY : CZDLIN => ZDLIN
USE cable_phys_constants_mod, ONLY : CCSW => CSW
USE cable_phys_constants_mod, ONLY : CGRAV => GRAV
#ifdef UM_CBL
USE cable_surface_types_mod, ONLY: ICE_SurfaceType => ICE_cable
#else
USE grid_constants_mod_cbl, ONLY: ICE_SurfaceType => ICE_cable
#endif
USE cable_phys_constants_mod, ONLY: CCSD => CSD
USE cable_phys_constants_mod, ONLY: CCRD => CRD
USE cable_phys_constants_mod, ONLY: CCCD => CCD
USE cable_phys_constants_mod, ONLY: CCCW_C => CCW_C
USE cable_phys_constants_mod, ONLY: CUSUHM => USUHM
USE cable_phys_constants_mod, ONLY: CVONK => VONK
USE cable_phys_constants_mod, ONLY: CA33 => A33
USE cable_phys_constants_mod, ONLY: CCTL => CTL
USE cable_phys_constants_mod, ONLY: CZDLIN => ZDLIN
USE cable_phys_constants_mod, ONLY: CCSW => CSW
USE cable_phys_constants_mod, ONLY: CGRAV => GRAV
USE cable_other_constants_mod, ONLY : CLAI_THRESH => LAI_THRESH

!*# Overview
Expand Down Expand Up @@ -133,7 +139,7 @@ SUBROUTINE ruff_resist(veg, rough, ssnow, canopy, LAI_pft, HGT_pft, reducedLAIdu



USE cable_common_module, ONLY : cable_user
USE cable_common_module, ONLY : cable_user, cable_runtime
USE cable_def_types_mod, ONLY : veg_parameter_type, roughness_type, &
soil_snow_type, canopy_type, mp
!subrs
Expand Down Expand Up @@ -171,12 +177,14 @@ SUBROUTINE ruff_resist(veg, rough, ssnow, canopy, LAI_pft, HGT_pft, reducedLAIdu
!* * evaluates the canopy height and leaf area given the presence of snow
! (or not) using [[HgtAboveSnow]] and [[LAI_eff]]
rough%hruff = HeightAboveSnow

!why are we using veg% for LAI and height-although this is synced now
IF(cable_runtime%um_radiation .OR. cable_runtime%offline ) THEN
! LAI decreases due to snow: formerly canopy%vlaiw
call LAI_eff( mp, veg%vlai, veg%hc, HeightAboveSnow, &
reducedLAIdue2snow )

canopy%vlaiw = reducedLAIdue2snow
ENDIF
canopy%rghlai = canopy%vlaiw

!* * sets the value of soil and snow roughness lengths
Expand All @@ -195,7 +203,7 @@ SUBROUTINE ruff_resist(veg, rough, ssnow, canopy, LAI_pft, HGT_pft, reducedLAIdu
WHERE( ssnow%snowd .GT. 0.01 ) &
rough%z0soilsn = MAX(z0soilsn_min, &
rough%z0soil - rough%z0soil*MIN(ssnow%snowd,10.)/10.)
WHERE( ssnow%snowd .GT. 0.01 .AND. veg%iveg == 17 ) &
WHERE( ssnow%snowd .GT. 0.01 .AND. veg%iveg == ICE_SurfaceType ) &
rough%z0soilsn = MAX(rough%z0soilsn, z0soilsn_min_PF )

ELSEIF (cable_user%soil_struc=='sli') THEN
Expand Down
6 changes: 6 additions & 0 deletions src/science/roughness/roughnessHGT_effLAI_cbl.F90
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,12 @@ MODULE hruff_eff_LAI_mod_cbl
!
!-----------------------------------------------------------------------------

!* The first procedure in this module evaluates the canopy height
! given the effect of any snow present.

!* The secone procedure in this module computes the effective LAI of a canopy
! given the effect of any snow present

JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved
IMPLICIT NONE

PUBLIC :: HgtAboveSnow
Expand Down
11 changes: 8 additions & 3 deletions src/science/soilsnow/cbl_surfbv.F90
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
!#define UM_CBL YES
MODULE surfbv_mod

USE cbl_ssnow_data_mod
Expand All @@ -10,8 +11,13 @@ SUBROUTINE surfbv (dels, met, ssnow, soil, veg, canopy )

USE smoisturev_mod, ONLY: smoisturev
USE cable_common_module
USE grid_constants_mod_cbl, ONLY : lakes_cable

! data
#ifdef UM_CBL
USE cable_surface_types_mod, ONLY: lakes_cable
#else
USE grid_constants_mod_cbl, ONLY: lakes_cable
#endif

IMPLICIT NONE

REAL, INTENT(IN) :: dels ! integration time step (s)
Expand All @@ -29,7 +35,6 @@ SUBROUTINE surfbv (dels, met, ssnow, soil, veg, canopy )

REAL, DIMENSION(mp) :: &
rnof5, & !
sfact, & !
sgamm, & !
smasstot, & !
talb, & ! snow albedo
Expand Down
2 changes: 1 addition & 1 deletion src/util/cable_runtime_opts_mod.F90
JhanSrbinovsky marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ MODULE cable_runtime_opts_mod
!jhan:make this logical
CHARACTER(LEN=3) :: diag_soil_resp=''

CHARACTER(LEN=20) :: fwsoil_switch=''
CHARACTER(LEN=20) :: fwsoil_switch='standard'

! Ticket #56
!jhan:options?
Expand Down
Loading