MODULE icethd_da !!====================================================================== !! *** MODULE icethd_da *** !! sea-ice : lateral melting !!====================================================================== !! History : 3.7 ! 2016-03 (C. Rousset) Original code !! 4.0 ! 2018 (many people) SI3 [aka Sea Ice cube] !!--------------------------------------------------------------------- #if defined key_si3 !!---------------------------------------------------------------------- !! 'key_si3' SI3 sea-ice model !!---------------------------------------------------------------------- !! ice_thd_da : sea ice lateral melting !! ice_thd_da_init : sea ice lateral melting initialization !!---------------------------------------------------------------------- USE par_oce ! ocean parameters USE phycst ! physical constants (ocean directory) USE ice ! sea-ice: variables USE ice1D ! sea-ice: thermodynamic 1D variables ! USE in_out_manager ! I/O manager USE lib_mpp ! MPP library USE lib_fortran ! Fortran utilities (allows no signed zero when 'key_nosignedzero' defined) IMPLICIT NONE PRIVATE PUBLIC ice_thd_da ! called by icethd.F90 PUBLIC ice_thd_da_init ! called by icestp.F90 ! !!** namelist (namthd_da) ** REAL(wp) :: rn_beta ! coef. beta for lateral melting param. REAL(wp) :: rn_dmin ! minimum floe diameter for lateral melting param. !!---------------------------------------------------------------------- !! NEMO/ICE 4.0 , NEMO Consortium (2018) !! $Id: icethd_da.F90 5123 2015-03-04 16:06:03Z clem $ !! Software governed by the CeCILL licence (./LICENSE) !!---------------------------------------------------------------------- CONTAINS SUBROUTINE ice_thd_da !!------------------------------------------------------------------- !! *** ROUTINE ice_thd_da *** !! !! ** Purpose : computes sea ice lateral melting !! !! ** Method : dA/dt = - P * W [s-1] !! W = melting velocity [m.s-1] !! P = perimeter of ice-ocean lateral interface normalized by grid cell area [m.m-2] !! !! W = m1 * (Tw -Tf)**m2 --- originally from Josberger 1979 --- !! (Tw - Tf) = elevation of water temp above freezing !! m1 and m2 = (1.6e-6 , 1.36) best fit from field experiment near the coast of Prince Patrick Island !! (Perovich 1983) => static ice !! m1 and m2 = (3.0e-6 , 1.36) best fit from MIZEX 84 experiment !! (Maykut and Perovich 1987) => moving ice !! !! P = N * pi * D --- from Rothrock and Thorndike 1984 --- !! D = mean floe caliper diameter !! N = number of floes = ice area / floe area(average) = A / (Cs * D**2) !! A = ice concentration !! Cs = deviation from a square (square:Cs=1 ; circle:Cs=pi/4 ; floe:Cs=0.66) !! !! D = Dmin * ( Astar / (Astar-A) )**beta --- from Lupkes et al., 2012 (eq. 26-27) --- !! !! Astar = 1 / ( 1 - (Dmin/Dmax)**(1/beta) ) !! Dmin = minimum floe diameter (recommended to be 8m +- 20%) !! Dmax = maximum floe diameter (recommended to be 300m, !! but it does not impact melting much except for Dmax<100m) !! beta = 1.0 +-20% (recommended value) !! = 0.3 best fit for western Fram Strait and Antarctica !! = 1.4 best fit for eastern Fram Strait !! !! ** Tunable parameters : We propose to tune the lateral melting via 2 parameters !! Dmin [6-10m] => 6 vs 8m = +40% melting at the peak (A~0.5) !! 10 vs 8m = -20% melting !! beta [0.8-1.2] => decrease = more melt and melt peaks toward higher concentration !! (A~0.5 for beta=1 ; A~0.8 for beta=0.2) !! 0.3 = best fit for western Fram Strait and Antarctica !! 1.4 = best fit for eastern Fram Strait !! !! ** Note : Former and more simple formulations for floe diameters can be found in Mai (1995), !! Birnbaum and Lupkes (2002), Lupkes and Birnbaum (2005). They are reviewed in Lupkes et al 2012 !! A simpler implementation for CICE can be found in Bitz et al (2001) and Tsamados et al (2015) !! !! ** References !! Bitz, C. M., Holland, M. M., Weaver, A. J., & Eby, M. (2001). !! Simulating the ice‐thickness distribution in a coupled climate model. !! Journal of Geophysical Research: Oceans, 106(C2), 2441-2463. !! Josberger, E. G. (1979). !! Laminar and turbulent boundary layers adjacent to melting vertical ice walls in salt water !! (No. SCIENTIFIC-16). WASHINGTON UNIV SEATTLE DEPT OF ATMOSPHERIC SCIENCES. !! Lüpkes, C., Gryanik, V. M., Hartmann, J., & Andreas, E. L. (2012). !! A parametrization, based on sea ice morphology, of the neutral atmospheric drag coefficients !! for weather prediction and climate models. !! Journal of Geophysical Research: Atmospheres, 117(D13). !! Maykut, G. A., & Perovich, D. K. (1987). !! The role of shortwave radiation in the summer decay of a sea ice cover. !! Journal of Geophysical Research: Oceans, 92(C7), 7032-7044. !! Perovich, D. K. (1983). !! On the summer decay of a sea ice cover. (Doctoral dissertation, University of Washington). !! Rothrock, D. A., & Thorndike, A. S. (1984). !! Measuring the sea ice floe size distribution. !! Journal of Geophysical Research: Oceans, 89(C4), 6477-6486. !! Tsamados, M., Feltham, D., Petty, A., Schroeder, D., & Flocco, D. (2015). !! Processes controlling surface, bottom and lateral melt of Arctic sea ice in a state of the art sea ice model. !! Phil. Trans. R. Soc. A, 373(2052), 20140167. !!--------------------------------------------------------------------- INTEGER :: ji ! dummy loop indices REAL(wp) :: zastar, zdfloe, zperi, zwlat, zda REAL(wp), PARAMETER :: zdmax = 300._wp REAL(wp), PARAMETER :: zcs = 0.66_wp REAL(wp), PARAMETER :: zm1 = 3.e-6_wp REAL(wp), PARAMETER :: zm2 = 1.36_wp ! REAL(wp), DIMENSION(jpij) :: zda_tot !!--------------------------------------------------------------------- ! zastar = 1._wp / ( 1._wp - (rn_dmin / zdmax)**(1._wp/rn_beta) ) ! DO ji = 1, npti ! --- Calculate reduction of total sea ice concentration --- ! zdfloe = rn_dmin * ( zastar / ( zastar - at_i_1d(ji) ) )**rn_beta ! Mean floe caliper diameter [m] ! zperi = at_i_1d(ji) * rpi / ( zcs * zdfloe ) ! Mean perimeter of the floe [m.m-2] ! ! = N*pi*D = (A/cs*D^2)*pi*D zwlat = zm1 * ( MAX( 0._wp, sst_1d(ji) - ( t_bo_1d(ji) - rt0 ) ) )**zm2 ! Melt speed rate [m/s] ! zda_tot(ji) = MIN( zwlat * zperi * rdt_ice, at_i_1d(ji) ) ! sea ice concentration decrease (>0) ! --- Distribute reduction among ice categories and calculate associated ice-ocean fluxes --- ! IF( a_i_1d(ji) > 0._wp ) THEN ! decrease of concentration for the category jl ! each category contributes to melting in proportion to its concentration zda = MIN( a_i_1d(ji), zda_tot(ji) * a_i_1d(ji) / at_i_1d(ji) ) ! Contribution to salt flux sfx_lam_1d(ji) = sfx_lam_1d(ji) + rhoic * h_i_1d(ji) * zda * s_i_1d(ji) * r1_rdtice ! Contribution to heat flux into the ocean [W.m-2], (<0) hfx_thd_1d(ji) = hfx_thd_1d(ji) - zda * r1_rdtice * ( h_i_1d(ji) * r1_nlay_i * SUM( e_i_1d(ji,1:nlay_i) ) & + h_s_1d(ji) * r1_nlay_s * SUM( e_s_1d(ji,1:nlay_s) ) ) ! Contribution to mass flux wfx_lam_1d(ji) = wfx_lam_1d(ji) + zda * r1_rdtice * ( rhoic * h_i_1d(ji) + rhosn * h_s_1d(ji) ) ! new concentration a_i_1d(ji) = a_i_1d(ji) - zda ! ensure that h_i = 0 where a_i = 0 IF( a_i_1d(ji) == 0._wp ) THEN h_i_1d(ji) = 0._wp h_s_1d(ji) = 0._wp ENDIF ENDIF END DO ! END SUBROUTINE ice_thd_da SUBROUTINE ice_thd_da_init !!----------------------------------------------------------------------- !! *** ROUTINE ice_thd_da_init *** !! !! ** Purpose : Physical constants and parameters associated with !! ice thermodynamics !! !! ** Method : Read the namthd_da namelist and check the parameters !! called at the first timestep (nit000) !! !! ** input : Namelist namthd_da !!------------------------------------------------------------------- INTEGER :: ios ! Local integer !! NAMELIST/namthd_da/ rn_beta, rn_dmin !!------------------------------------------------------------------- ! REWIND( numnam_ice_ref ) ! Namelist namthd_da in reference namelist : Ice thermodynamics READ ( numnam_ice_ref, namthd_da, IOSTAT = ios, ERR = 901) 901 IF( ios /= 0 ) CALL ctl_nam ( ios , 'namthd_da in reference namelist', lwp ) REWIND( numnam_ice_cfg ) ! Namelist namthd_da in configuration namelist : Ice thermodynamics READ ( numnam_ice_cfg, namthd_da, IOSTAT = ios, ERR = 902 ) 902 IF( ios > 0 ) CALL ctl_nam ( ios , 'namthd_da in configuration namelist', lwp ) IF(lwm) WRITE( numoni, namthd_da ) ! IF(lwp) THEN ! control print WRITE(numout,*) WRITE(numout,*) 'ice_thd_da_init: Ice lateral melting' WRITE(numout,*) '~~~~~~~~~~~~~~~' WRITE(numout,*) ' Namelist namthd_da:' WRITE(numout,*) ' Coef. beta for lateral melting param. rn_beta = ', rn_beta WRITE(numout,*) ' Minimum floe diameter for lateral melting param. rn_dmin = ', rn_dmin ENDIF ! END SUBROUTINE ice_thd_da_init #else !!---------------------------------------------------------------------- !! Default option Dummy Module NO SI3 sea-ice model !!---------------------------------------------------------------------- #endif !!====================================================================== END MODULE icethd_da