Skip to content

Commit

Permalink
Don't include damage in uncoupled effectiveViscosity calculation
Browse files Browse the repository at this point in the history
Remove damage factor from calculation for uncoupled effectiveViscosity
  • Loading branch information
trhille committed Sep 28, 2023
1 parent db25426 commit c8739af
Showing 1 changed file with 14 additions and 4 deletions.
18 changes: 14 additions & 4 deletions components/mpas-albany-landice/src/mode_forward/mpas_li_velocity.F
Original file line number Diff line number Diff line change
Expand Up @@ -916,6 +916,7 @@ subroutine calculate_strain_rates_and_stresses(meshPool, geometryPool, thermalPo

integer, pointer :: nVertLevels
integer, pointer :: nCells
logical, pointer :: config_damage_rheology_coupling
real (kind=RKIND), pointer :: config_damage_stiffness_min

integer :: iCell
Expand All @@ -929,6 +930,7 @@ subroutine calculate_strain_rates_and_stresses(meshPool, geometryPool, thermalPo

call mpas_pool_get_config(liConfigs, 'config_flowLawExponent', config_flowLawExponent)
call mpas_pool_get_config(liConfigs, 'config_damage_stiffness_min', config_damage_stiffness_min)
call mpas_pool_get_config(liConfigs, 'config_damage_rheology_coupling', config_damage_rheology_coupling)

call mpas_pool_get_dimension(meshPool, 'nVertLevels', nVertLevels)
call mpas_pool_get_dimension(meshPool, 'nCells', nCells)
Expand Down Expand Up @@ -988,10 +990,18 @@ subroutine calculate_strain_rates_and_stresses(meshPool, geometryPool, thermalPo
if ( (eEff == 0.0_RKIND) .or. (meanFlowParamA(iCell) == 0.0_RKIND) ) then
effectiveViscosity(iCell) = 0.0_RKIND
else
effectiveViscosity(iCell) = &
0.5_RKIND * max(1.0_RKIND - damage(iCell), config_damage_stiffness_min) * &
stiffnessFactor(iCell)*meanFlowParamA(iCell)**(-1.0_RKIND/config_flowLawExponent)* &
eEff**((1.0_RKIND-config_flowLawExponent)/config_flowLawExponent)
if ( config_damage_rheology_coupling ) then
effectiveViscosity(iCell) = &
0.5_RKIND * max(1.0_RKIND - damage(iCell), config_damage_stiffness_min) * &
stiffnessFactor(iCell)*meanFlowParamA(iCell)**(-1.0_RKIND/config_flowLawExponent)* &
eEff**((1.0_RKIND-config_flowLawExponent)/config_flowLawExponent)
else
effectiveViscosity(iCell) = &
0.5_RKIND * stiffnessFactor(iCell)*meanFlowParamA(iCell)** &
(-1.0_RKIND/config_flowLawExponent)* &
eEff**((1.0_RKIND-config_flowLawExponent)/config_flowLawExponent)
endif

endif
enddo

Expand Down

0 comments on commit c8739af

Please sign in to comment.