diff --git a/model/src/w3srcemd.F90 b/model/src/w3srcemd.F90 index e90ba88eb..04ce25633 100644 --- a/model/src/w3srcemd.F90 +++ b/model/src/w3srcemd.F90 @@ -1324,6 +1324,15 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & ! UNRESOLVED OBSTACLES CALL UOST_SRCTRMCOMPUTE(IX, IY, SPEC, CG1, DT, & U10ABS, U10DIR, VSUO, VDUO) +#endif + ! + ! Sea Ice Damping Source Term + ! +#ifdef IC4_ACCURATE_NUMERICS +#ifdef W3_IC4 + if (ICE.GT.0) CALL W3SIC4 ( SPEC,DEPTH, CG1, & + IX, IY, VSIC, VDIC ) +#endif #endif ! ! 2.g Dump training data if necessary @@ -1384,6 +1393,10 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & VDIN(1:NSPECH) = ICESCALEIN * VDIN(1:NSPECH) VSDS(1:NSPECH) = ICESCALEDS * VSDS(1:NSPECH) VDDS(1:NSPECH) = ICESCALEDS * VDDS(1:NSPECH) +#ifdef IC4_ACCURATE_NUMERICS + VSIC(1:NSPECH) = ICE * VSIC(1:NSPECH) ! (see Rogers et al 2016) + VDIC(1:NSPECH) = ICE * VDIC(1:NSPECH) ! ************** +#endif END IF #ifdef W3_PDLIB @@ -1422,6 +1435,9 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & #endif #ifdef W3_UOST VS(IS) = VS(IS) + VSUO(IS) +#endif +#ifdef IC4_ACCURATE_NUMERICS + IF ( ICE.GT.0. ) VS(IS) = VS(IS) + VSIC(IS) #endif VD(IS) = VDIN(IS) + VDNL(IS) & + VDDS(IS) + VDBT(IS) @@ -1436,6 +1452,9 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & #endif #ifdef W3_UOST VD(IS) = VD(IS) + VDUO(IS) +#endif +#ifdef IC4_ACCURATE_NUMERICS + IF ( ICE.GT.0. ) VD(IS) = VD(IS) + VDIC(IS) #endif DAMAX = MIN ( DAM(IS) , MAX ( XREL*SPECINIT(IS) , AFILT ) ) AFAC = 1. / MAX( 1.E-10 , ABS(VS(IS)/DAMAX) ) @@ -1455,6 +1474,9 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & ! DT = MAX ( 0.5, DT ) ! The hardcoded min. dt is a problem for certain cases e.g. laborotary scale problems. ! +#ifdef IC4_ACCURATE_NUMERICS + if (ICE.gt.0.01 .and. ICE.lt.0.95) DT=DTMIN ! always use a small timestep in ice +#endif DTDYN = DTDYN + DT #ifdef W3_T DTRAW = DT @@ -1743,6 +1765,14 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & / MAX ( 1. , (1.-HDT*VDBT(IS))) ! semi-implict integration scheme PHINL = PHINL + VSNL(IS)* DT * FACTOR & / MAX ( 1. , (1.-HDT*VDNL(IS))) ! semi-implict integration scheme +#ifdef IC4_ACCURATE_NUMERICS + IF ( ICE.GT.0 ) THEN + PHICE = PHICE + VSIC(IS) * DT * FACTOR & + / MAX ( 1. , (1.-HDT*VDIC(IS))) ! semi-implicit integration + TAUICE(:) = TAUICE(:) - FACTOR2*COSI(:)*VSIC(IS) * DT & + / MAX ( 1. , (1.-HDT*VDIC(IS))) + END IF +#endif IF (VSIN(IS).GT.0.) WHITECAP(3) = WHITECAP(3) + SPEC(IS) * FACTOR HSTOT = HSTOT + SPEC(IS) * FACTOR END DO @@ -2011,6 +2041,11 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & TAUBBL(:)=TAUBBL(:)/DTG TAUOCX=DAIR*COEF*COEF*USTAR*USTAR*COS(USTDIR) + DWAT*(TAUOX-TAUWIX) TAUOCY=DAIR*COEF*COEF*USTAR*USTAR*SIN(USTDIR) + DWAT*(TAUOY-TAUWIY) +#ifdef IC4_ACCURATE_NUMERICS + TAUICE(:)=TAUICE(:)/DTG + TAUOX = TAUOX - TAUICE(1) + TAUOY = TAUOY - TAUICE(2) +#endif ! ! Transformation in wave energy flux in W/m^2=kg / s^3 ! @@ -2018,6 +2053,9 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & PHIAW =DWAT*GRAV*PHIAW /DTG PHINL =DWAT*GRAV*PHINL /DTG PHIBBL=DWAT*GRAV*PHIBBL/DTG +#ifdef IC4_ACCURATE_NUMERICS + PHICE =-1.*DWAT*GRAV*PHICE/DTG +#endif ! ! 10.1 Adds ice scattering and dissipation: implicit integration---------------- * ! INFLAGS2(4) is true if ice concentration was ever read during @@ -2028,7 +2066,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & WRITE(740+IAPROC,*) '3 : sum(SPEC)=', sum(SPEC) END IF #endif - +#ifndef IC4_ACCURATE_NUMERICS IF ( INFLAGS2(4).AND.ICE.GT.0 ) THEN IF (IICEDISP) THEN @@ -2037,6 +2075,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & SIG,WN_R,CG_ICE,ALPHA_LIU) ! IF (IICESMOOTH) THEN +#endif #ifdef W3_IS2 DO IK=1,NK SMOOTH_ICEDISP=0. @@ -2046,6 +2085,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & WN_R(IK)=WN1(IK)*(1-SMOOTH_ICEDISP)+WN_R(IK)*(SMOOTH_ICEDISP) END DO #endif +#ifndef IC4_ACCURATE_NUMERICS END IF ELSE WN_R=WN1 @@ -2054,6 +2094,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & ! R(:)=1 ! In case IC2 is defined but not IS2 ! +#endif #ifdef W3_IC1 CALL W3SIC1 ( SPEC,DEPTH, CG1, IX, IY, VSIC, VDIC ) #endif @@ -2068,7 +2109,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & #ifdef W3_IC3 CALL W3SIC3 ( SPEC,DEPTH, CG1, WN1, IX, IY, VSIC, VDIC ) #endif -#ifdef W3_IC4 +#ifndef IC4_ACCURATE_NUMERICS CALL W3SIC4 ( SPEC,DEPTH, CG1, IX, IY, VSIC, VDIC ) #endif #ifdef W3_IC5 @@ -2078,6 +2119,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & #ifdef W3_IS1 CALL W3SIS1 ( SPEC, ICE, VSIR ) #endif +#ifndef IC4_ACCURATE_NUMERICS SPEC2 = SPEC ! TAUICE(:) = 0. @@ -2088,6 +2130,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & ! First part of ice term integration: dissipation part ! ATT=1. +#endif #ifdef W3_IC1 ATT=EXP(ICE*VDIC(IS)*DTG) #endif @@ -2097,7 +2140,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & #ifdef W3_IC3 ATT=EXP(ICE*VDIC(IS)*DTG) #endif -#ifdef W3_IC4 +#ifndef IC4_ACCURATE_NUMERICS ATT=EXP(ICE*VDIC(IS)*DTG) #endif #ifdef W3_IC5 @@ -2115,7 +2158,9 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & ATT=ATT*EXP((ICE*VDIR(IS))*DTG) END IF #endif +#ifndef IC4_ACCURATE_NUMERICS SPEC(1+(IK-1)*NTH:NTH+(IK-1)*NTH) = ATT*SPEC2(1+(IK-1)*NTH:NTH+(IK-1)*NTH) +#endif ! ! Second part of ice term integration: scattering including re-distribution in directions ! @@ -2142,6 +2187,7 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & END IF END IF #endif +#ifndef IC4_ACCURATE_NUMERICS ! ! 10.2 Fluxes of energy and momentum due to ice effects ! @@ -2158,12 +2204,15 @@ SUBROUTINE W3SRCE ( srce_call, IT, ISEA, JSEA, IX, IY, IMOD, & PHICE =-1.*DWAT*GRAV*PHICE /DTG TAUICE(:)=TAUICE(:)/DTG ELSE +#endif #ifdef W3_IS2 IF (IS2PARS(10).LT.0.5) THEN ICEF = 0. ENDIF #endif +#ifndef IC4_ACCURATE_NUMERICS END IF +#endif ! ! ! - - - - - - - - - - - - - - - - - - - - - -