! $Id: cv30_routines.F90 4491 2023-04-03 08:25:44Z lebasn $ SUBROUTINE cv30_param(nd, delt) IMPLICIT NONE ! ------------------------------------------------------------ ! Set parameters for convectL for iflag_con = 3 ! ------------------------------------------------------------ ! *** PBCRIT IS THE CRITICAL CLOUD DEPTH (MB) BENEATH WHICH THE *** ! *** PRECIPITATION EFFICIENCY IS ASSUMED TO BE ZERO *** ! *** PTCRIT IS THE CLOUD DEPTH (MB) ABOVE WHICH THE PRECIP. *** ! *** EFFICIENCY IS ASSUMED TO BE UNITY *** ! *** SIGD IS THE FRACTIONAL AREA COVERED BY UNSATURATED DNDRAFT *** ! *** SPFAC IS THE FRACTION OF PRECIPITATION FALLING OUTSIDE *** ! *** OF CLOUD *** ! [TAU: CHARACTERISTIC TIMESCALE USED TO COMPUTE ALPHA & BETA] ! *** ALPHA AND BETA ARE PARAMETERS THAT CONTROL THE RATE OF *** ! *** APPROACH TO QUASI-EQUILIBRIUM *** ! *** (THEIR STANDARD VALUES ARE 1.0 AND 0.96, RESPECTIVELY) *** ! *** (BETA MUST BE LESS THAN OR EQUAL TO 1) *** ! *** DTCRIT IS THE CRITICAL BUOYANCY (K) USED TO ADJUST THE *** ! *** APPROACH TO QUASI-EQUILIBRIUM *** ! *** IT MUST BE LESS THAN 0 *** include "cv30param.h" include "conema3.h" INTEGER nd REAL delt ! timestep (seconds) ! noff: integer limit for convection (nd-noff) ! minorig: First level of convection ! -- limit levels for convection: noff = 1 minorig = 1 nl = nd - noff nlp = nl + 1 nlm = nl - 1 ! -- "microphysical" parameters: sigd = 0.01 spfac = 0.15 pbcrit = 150.0 ptcrit = 500.0 ! IM cf. FH epmax = 0.993 omtrain = 45.0 ! used also for snow (no disctinction rain/snow) ! -- misc: dtovsh = -0.2 ! dT for overshoot dpbase = -40. ! definition cloud base (400m above LCL) dttrig = 5. ! (loose) condition for triggering ! -- rate of approach to quasi-equilibrium: dtcrit = -2.0 tau = 8000. beta = 1.0 - delt/tau alpha = 1.5E-3*delt/tau ! increase alpha to compensate W decrease: alpha = alpha*1.5 ! -- interface cloud parameterization: delta = 0.01 ! cld ! -- interface with boundary-layer (gust factor): (sb) betad = 10.0 ! original value (from convect 4.3) RETURN END SUBROUTINE cv30_param SUBROUTINE cv30_prelim(len, nd, ndp1, t, q, p, ph, lv, cpn, tv, gz, h, hm, & th) IMPLICIT NONE ! ===================================================================== ! --- CALCULATE ARRAYS OF GEOPOTENTIAL, HEAT CAPACITY & STATIC ENERGY ! "ori": from convect4.3 (vectorized) ! "convect3": to be exactly consistent with convect3 ! ===================================================================== ! inputs: INTEGER len, nd, ndp1 REAL t(len, nd), q(len, nd), p(len, nd), ph(len, ndp1) ! outputs: REAL lv(len, nd), cpn(len, nd), tv(len, nd) REAL gz(len, nd), h(len, nd), hm(len, nd) REAL th(len, nd) ! local variables: INTEGER k, i REAL rdcp REAL tvx, tvy ! convect3 REAL cpx(len, nd) include "cvthermo.h" include "cv30param.h" ! ori do 110 k=1,nlp DO k = 1, nl ! convect3 DO i = 1, len ! debug lv(i,k)= lv0-clmcpv*(t(i,k)-t0) lv(i, k) = lv0 - clmcpv*(t(i,k)-273.15) cpn(i, k) = cpd*(1.0-q(i,k)) + cpv*q(i, k) cpx(i, k) = cpd*(1.0-q(i,k)) + cl*q(i, k) ! ori tv(i,k)=t(i,k)*(1.0+q(i,k)*epsim1) tv(i, k) = t(i, k)*(1.0+q(i,k)/eps-q(i,k)) rdcp = (rrd*(1.-q(i,k))+q(i,k)*rrv)/cpn(i, k) th(i, k) = t(i, k)*(1000.0/p(i,k))**rdcp END DO END DO ! gz = phi at the full levels (same as p). DO i = 1, len gz(i, 1) = 0.0 END DO ! ori do 140 k=2,nlp DO k = 2, nl ! convect3 DO i = 1, len tvx = t(i, k)*(1.+q(i,k)/eps-q(i,k)) !convect3 tvy = t(i, k-1)*(1.+q(i,k-1)/eps-q(i,k-1)) !convect3 gz(i, k) = gz(i, k-1) + 0.5*rrd*(tvx+tvy) & !convect3 *(p(i,k-1)-p(i,k))/ph(i, k) !convect3 ! ori gz(i,k)=gz(i,k-1)+hrd*(tv(i,k-1)+tv(i,k)) ! ori & *(p(i,k-1)-p(i,k))/ph(i,k) END DO END DO ! h = phi + cpT (dry static energy). ! hm = phi + cp(T-Tbase)+Lq ! ori do 170 k=1,nlp DO k = 1, nl ! convect3 DO i = 1, len h(i, k) = gz(i, k) + cpn(i, k)*t(i, k) hm(i, k) = gz(i, k) + cpx(i, k)*(t(i,k)-t(i,1)) + lv(i, k)*q(i, k) END DO END DO RETURN END SUBROUTINE cv30_prelim SUBROUTINE cv30_feed(len, nd, t, q, qs, p, ph, hm, gz, nk, icb, icbmax, & iflag, tnk, qnk, gznk, plcl & #ifdef ISO ,xt,xtnk & #endif ) #ifdef ISO USE infotrac_phy, ONLY: ntraciso=>ntiso #endif IMPLICIT NONE ! ================================================================ ! Purpose: CONVECTIVE FEED ! Main differences with cv_feed: ! - ph added in input ! - here, nk(i)=minorig ! - icb defined differently (plcl compared with ph instead of p) ! Main differences with convect3: ! - we do not compute dplcldt and dplcldr of CLIFT anymore ! - values iflag different (but tests identical) ! - A,B explicitely defined (!...) ! ================================================================ include "cv30param.h" ! inputs: INTEGER len, nd REAL t(len, nd), q(len, nd), qs(len, nd), p(len, nd) REAL hm(len, nd), gz(len, nd) REAL ph(len, nd+1) #ifdef ISO real xt(ntraciso,len,nd) #endif ! outputs: INTEGER iflag(len), nk(len), icb(len), icbmax REAL tnk(len), qnk(len), gznk(len), plcl(len) #ifdef ISO real xtnk(ntraciso,len) #endif ! local variables: INTEGER i, k #ifdef ISO integer ixt #endif INTEGER ihmin(len) REAL work(len) REAL pnk(len), qsnk(len), rh(len), chi(len) REAL a, b ! convect3 ! ym plcl = 0.0 ! @ !------------------------------------------------------------------- ! @ ! --- Find level of minimum moist static energy ! @ ! --- If level of minimum moist static energy coincides with ! @ ! --- or is lower than minimum allowable parcel origin level, ! @ ! --- set iflag to 6. ! @ !------------------------------------------------------------------- ! @ ! @ do 180 i=1,len ! @ work(i)=1.0e12 ! @ ihmin(i)=nl ! @ 180 continue ! @ do 200 k=2,nlp ! @ do 190 i=1,len ! @ if((hm(i,k).lt.work(i)).and. ! @ & (hm(i,k).lt.hm(i,k-1)))then ! @ work(i)=hm(i,k) ! @ ihmin(i)=k ! @ endif ! @ 190 continue ! @ 200 continue ! @ do 210 i=1,len ! @ ihmin(i)=min(ihmin(i),nlm) ! @ if(ihmin(i).le.minorig)then ! @ iflag(i)=6 ! @ endif ! @ 210 continue ! @ c ! @ !------------------------------------------------------------------- ! @ ! --- Find that model level below the level of minimum moist static ! @ ! --- energy that has the maximum value of moist static energy ! @ !------------------------------------------------------------------- ! @ ! @ do 220 i=1,len ! @ work(i)=hm(i,minorig) ! @ nk(i)=minorig ! @ 220 continue ! @ do 240 k=minorig+1,nl ! @ do 230 i=1,len ! @ if((hm(i,k).gt.work(i)).and.(k.le.ihmin(i)))then ! @ work(i)=hm(i,k) ! @ nk(i)=k ! @ endif ! @ 230 continue ! @ 240 continue ! ------------------------------------------------------------------- ! --- Origin level of ascending parcels for convect3: ! ------------------------------------------------------------------- DO i = 1, len nk(i) = minorig END DO ! ------------------------------------------------------------------- ! --- Check whether parcel level temperature and specific humidity ! --- are reasonable ! ------------------------------------------------------------------- DO i = 1, len IF (((t(i,nk(i))<250.0) .OR. (q(i,nk(i))<=0.0)) & ! @ & .or.( ! p(i,ihmin(i)).lt.400.0 ! ) ) .AND. (iflag(i)==0)) iflag(i) = 7 END DO ! ------------------------------------------------------------------- ! --- Calculate lifted condensation level of air at parcel origin level ! --- (Within 0.2% of formula of Bolton, MON. WEA. REV.,1980) ! ------------------------------------------------------------------- a = 1669.0 ! convect3 b = 122.0 ! convect3 DO i = 1, len IF (iflag(i)/=7) THEN ! modif sb Jun7th 2002 tnk(i) = t(i, nk(i)) qnk(i) = q(i, nk(i)) gznk(i) = gz(i, nk(i)) pnk(i) = p(i, nk(i)) qsnk(i) = qs(i, nk(i)) #ifdef ISO do ixt=1,ntraciso xtnk(ixt,i) = xt(ixt,i, nk(i)) enddo #endif rh(i) = qnk(i)/qsnk(i) ! ori rh(i)=min(1.0,rh(i)) ! removed for convect3 ! ori chi(i)=tnk(i)/(1669.0-122.0*rh(i)-tnk(i)) chi(i) = tnk(i)/(a-b*rh(i)-tnk(i)) ! convect3 plcl(i) = pnk(i)*(rh(i)**chi(i)) IF (((plcl(i)<200.0) .OR. (plcl(i)>=2000.0)) .AND. (iflag(i)==0)) iflag & (i) = 8 END IF ! iflag=7 END DO ! ------------------------------------------------------------------- ! --- Calculate first level above lcl (=icb) ! ------------------------------------------------------------------- ! @ do 270 i=1,len ! @ icb(i)=nlm ! @ 270 continue ! @c ! @ do 290 k=minorig,nl ! @ do 280 i=1,len ! @ if((k.ge.(nk(i)+1)).and.(p(i,k).lt.plcl(i))) ! @ & icb(i)=min(icb(i),k) ! @ 280 continue ! @ 290 continue ! @c ! @ do 300 i=1,len ! @ if((icb(i).ge.nlm).and.(iflag(i).eq.0))iflag(i)=9 ! @ 300 continue DO i = 1, len icb(i) = nlm END DO ! la modification consiste a comparer plcl a ph et non a p: ! icb est defini par : ph(icb)ntiso USE isotopes_mod, ONLY: pxtmelt,pxtice,pxtmin,pxtmax,cond_temp_env, & iso_eau,iso_HDO, ridicule USE isotopes_routines_mod, ONLY: condiso_liq_ice_vectall #ifdef ISOTRAC USE isotopes_routines_mod, ONLY: condiso_liq_ice_vectall_trac #ifdef ISOVERIF use isotopes_verif_mod, ONLY: iso_verif_traceur #endif #endif #ifdef ISOVERIF use isotopes_verif_mod, ONLY: errmax,errmaxrel,Tmin_verif, & iso_verif_egalite_choix, iso_verif_noNaN,iso_verif_aberrant, & iso_verif_egalite,iso_verif_egalite_choix_nostop,iso_verif_positif_nostop, & iso_verif_egalite_nostop,iso_verif_aberrant_nostop,deltaD,iso_verif_noNaN_nostop, & iso_verif_positif,iso_verif_egalite_vect2D #endif #endif IMPLICIT NONE ! ---------------------------------------------------------------- ! Equivalent de TLIFT entre NK et ICB+1 inclus ! Differences with convect4: ! - specify plcl in input ! - icbs is the first level above LCL (may differ from icb) ! - in the iterations, used x(icbs) instead x(icb) ! - many minor differences in the iterations ! - tvp is computed in only one time ! - icbs: first level above Plcl (IMIN de TLIFT) in output ! - if icbs=icb, compute also tp(icb+1),tvp(icb+1) & clw(icb+1) ! ---------------------------------------------------------------- include "cvthermo.h" include "cv30param.h" ! inputs: INTEGER len, nd INTEGER nk(len), icb(len) REAL t(len, nd), q(len, nd), qs(len, nd), gz(len, nd) REAL p(len, nd) REAL plcl(len) ! convect3 #ifdef ISO real xt(ntraciso,len,nd) #endif ! outputs: REAL tp(len, nd), tvp(len, nd), clw(len, nd) #ifdef ISO real xtclw(ntraciso,len,nd) real tg_save(len,nd) #endif ! local variables: INTEGER i, k INTEGER icb1(len), icbs(len), icbsmax2 ! convect3 REAL tg, qg, alv, s, ahg, tc, denom, es, rg REAL ah0(len), cpp(len) REAL tnk(len), qnk(len), gznk(len), ticb(len), gzicb(len) REAL qsicb(len) ! convect3 REAL cpinv(len) ! convect3 #ifdef ISO integer ixt real zfice(len),zxtliq(ntraciso,len),zxtice(ntraciso,len) real q_k(len),clw_k(len),tg_k(len),xt_k(ntraciso,len) !#ifdef ISOVERIF ! integer iso_verif_positif_nostop !#endif #endif ! ------------------------------------------------------------------- ! --- Calculates the lifted parcel virtual temperature at nk, ! --- the actual temperature, and the adiabatic ! --- liquid water content. The procedure is to solve the equation. ! cp*tp+L*qp+phi=cp*tnk+L*qnk+gznk. ! ------------------------------------------------------------------- #ifdef ISOVERIF write(*,*) 'cv30_routine undilute 1 413: entree' #endif DO i = 1, len tnk(i) = t(i, nk(i)) qnk(i) = q(i, nk(i)) gznk(i) = gz(i, nk(i)) ! ori ticb(i)=t(i,icb(i)) ! ori gzicb(i)=gz(i,icb(i)) END DO ! *** Calculate certain parcel quantities, including static energy *** DO i = 1, len ah0(i) = (cpd*(1.-qnk(i))+cl*qnk(i))*tnk(i) + qnk(i)*(lv0-clmcpv*(tnk(i)- & 273.15)) + gznk(i) cpp(i) = cpd*(1.-qnk(i)) + qnk(i)*cpv cpinv(i) = 1./cpp(i) END DO ! *** Calculate lifted parcel quantities below cloud base *** DO i = 1, len !convect3 icb1(i) = min(max(icb(i), 2), nl) ! if icb is below LCL, start loop at ICB+1: ! (icbs est le premier niveau au-dessus du LCL) icbs(i) = icb1(i) !convect3 IF (plcl(i)p(icb), then icbs=icb ! * the routine above computes tvp from minorig to icbs (included). ! * to compute buoybase (in cv3_trigger.F), both tvp(icb) and tvp(icb+1) ! must be known. This is the case if icbs=icb+1, but not if icbs=icb. ! * therefore, in the case icbs=icb, we compute tvp at level icb+1 ! (tvp at other levels will be computed in cv3_undilute2.F) DO i = 1, len ticb(i) = t(i, icb(i)+1) gzicb(i) = gz(i, icb(i)+1) qsicb(i) = qs(i, icb(i)+1) END DO DO i = 1, len tg = ticb(i) qg = qsicb(i) ! convect3 ! debug alv=lv0-clmcpv*(ticb(i)-t0) alv = lv0 - clmcpv*(ticb(i)-273.15) ! First iteration. ! ori s=cpd+alv*alv*qg/(rrv*ticb(i)*ticb(i)) s = cpd*(1.-qnk(i)) + cl*qnk(i) & ! convect3 +alv*alv*qg/(rrv*ticb(i)*ticb(i)) ! convect3 s = 1./s ! ori ahg=cpd*tg+(cl-cpd)*qnk(i)*ticb(i)+alv*qg+gzicb(i) ahg = cpd*tg + (cl-cpd)*qnk(i)*tg + alv*qg + gzicb(i) ! convect3 tg = tg + s*(ah0(i)-ahg) ! ori tg=max(tg,35.0) ! debug tc=tg-t0 tc = tg - 273.15 denom = 243.5 + tc denom = max(denom, 1.0) ! convect3 ! ori if(tc.ge.0.0)then es = 6.112*exp(17.67*tc/denom) ! ori else ! ori es=exp(23.33086-6111.72784/tg+0.15215*log(tg)) ! ori endif ! ori qg=eps*es/(p(i,icb(i))-es*(1.-eps)) qg = eps*es/(p(i,icb(i)+1)-es*(1.-eps)) ! qg=max(0.0,qg) ! C Risi ! Second iteration. ! ori s=cpd+alv*alv*qg/(rrv*ticb(i)*ticb(i)) ! ori s=1./s ! ori ahg=cpd*tg+(cl-cpd)*qnk(i)*ticb(i)+alv*qg+gzicb(i) ahg = cpd*tg + (cl-cpd)*qnk(i)*tg + alv*qg + gzicb(i) ! convect3 tg = tg + s*(ah0(i)-ahg) ! ori tg=max(tg,35.0) ! debug tc=tg-t0 tc = tg - 273.15 denom = 243.5 + tc denom = max(denom, 1.0) ! convect3 ! ori if(tc.ge.0.0)then es = 6.112*exp(17.67*tc/denom) ! ori else ! ori es=exp(23.33086-6111.72784/tg+0.15215*log(tg)) ! ori end if ! ori qg=eps*es/(p(i,icb(i))-es*(1.-eps)) qg = eps*es/(p(i,icb(i)+1)-es*(1.-eps)) ! qg=max(0.0,qg) ! C Risi alv = lv0 - clmcpv*(ticb(i)-273.15) ! ori c approximation here: ! ori tp(i,icb(i))=(ah0(i)-(cl-cpd)*qnk(i)*ticb(i) ! ori & -gz(i,icb(i))-alv*qg)/cpd ! convect3: no approximation: tp(i, icb(i)+1) = (ah0(i)-gz(i,icb(i)+1)-alv*qg)/(cpd+(cl-cpd)*qnk(i)) ! ori clw(i,icb(i))=qnk(i)-qg ! ori clw(i,icb(i))=max(0.0,clw(i,icb(i))) clw(i, icb(i)+1) = qnk(i) - qg clw(i, icb(i)+1) = max(0.0, clw(i,icb(i)+1)) rg = qg/(1.-qnk(i)) ! ori tvp(i,icb(i))=tp(i,icb(i))*(1.+rg*epsi) ! convect3: (qg utilise au lieu du vrai mixing ratio rg) tvp(i, icb(i)+1) = tp(i, icb(i)+1)*(1.+qg/eps-qnk(i)) !whole thing END DO #ifdef ISO do i=1,len zfice(i) = 1.0-(t(i,icb(i)+1)-pxtice)/(pxtmelt-pxtice) zfice(i) = MIN(MAX(zfice(i),0.0),1.0) ! call calcul_zfice(tp(i,icb(i)+1),zfice) enddo !do i=1,len do i=1,len clw_k(i)=clw(i,icb(i)+1) tg_k(i)=t(i,icb(i)+1) #ifdef ISOVERIF call iso_verif_positif(tg_k(i)-Tmin_verif,'cv30_routines 750') #endif do ixt=1,ntraciso xt_k(ixt,i)=xt(ixt,i,nk(i)) enddo enddo !do i=1,len #ifdef ISOVERIF write(*,*) 'cv30_routines 739: avant condiso' if (iso_HDO.gt.0) then do i=1,len call iso_verif_aberrant(xt_k(iso_hdo,i)/qnk(i), & & 'cv30_routines 725') enddo endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC do i=1,len call iso_verif_traceur(xtclw(1,i,k),'cv30_routines 738') enddo #endif #endif call condiso_liq_ice_vectall(xt_k(1,1),qnk(1), & & clw_k(1),tg_k(1), & & zfice(1),zxtice(1,1),zxtliq(1,1),len) #ifdef ISOTRAC call condiso_liq_ice_vectall_trac(xt_k(1,1),qnk(1), & & clw_k(1),tg_k(1), & & zfice(1),zxtice(1,1),zxtliq(1,1),len) #endif do i=1,len do ixt = 1, ntraciso xtclw(ixt,i,icb(i)+1)=zxtice(ixt,i)+zxtliq(ixt,i) xtclw(ixt,i,icb(i)+1)=max(0.0,xtclw(ixt,i,icb(i)+1)) enddo !do ixt = 1, niso enddo !do i=1,len #ifdef ISOVERIF !write(*,*) 'DEBUG ISO B' do i=1,len if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtclw(iso_eau,i,icb(i)+1), & & clw(i,icb(i)+1),'cv30_routines 708',errmax,errmaxrel) endif ! if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur(xtclw(1,i,icb(i)+1), & & 'cv30_routines 760') #endif enddo !do i=1,len !write(*,*) 'FIN DEBUG ISO B' #endif #endif RETURN END SUBROUTINE cv30_undilute1 SUBROUTINE cv30_trigger(len, nd, icb, plcl, p, th, tv, tvp, pbase, buoybase, & iflag, sig, w0) IMPLICIT NONE ! ------------------------------------------------------------------- ! --- TRIGGERING ! - computes the cloud base ! - triggering (crude in this version) ! - relaxation of sig and w0 when no convection ! Caution1: if no convection, we set iflag=4 ! (it used to be 0 in convect3) ! Caution2: at this stage, tvp (and thus buoy) are know up ! through icb only! ! -> the buoyancy below cloud base not (yet) set to the cloud base buoyancy ! ------------------------------------------------------------------- include "cv30param.h" ! input: INTEGER len, nd INTEGER icb(len) REAL plcl(len), p(len, nd) REAL th(len, nd), tv(len, nd), tvp(len, nd) ! output: REAL pbase(len), buoybase(len) ! input AND output: INTEGER iflag(len) REAL sig(len, nd), w0(len, nd) ! local variables: INTEGER i, k REAL tvpbase, tvbase, tdif, ath, ath1 ! *** set cloud base buoyancy at (plcl+dpbase) level buoyancy DO i = 1, len pbase(i) = plcl(i) + dpbase tvpbase = tvp(i, icb(i))*(pbase(i)-p(i,icb(i)+1))/ & (p(i,icb(i))-p(i,icb(i)+1)) + tvp(i, icb(i)+1)*(p(i,icb(i))-pbase(i))/( & p(i,icb(i))-p(i,icb(i)+1)) tvbase = tv(i, icb(i))*(pbase(i)-p(i,icb(i)+1))/ & (p(i,icb(i))-p(i,icb(i)+1)) + tv(i, icb(i)+1)*(p(i,icb(i))-pbase(i))/(p & (i,icb(i))-p(i,icb(i)+1)) buoybase(i) = tvpbase - tvbase END DO ! *** make sure that column is dry adiabatic between the surface *** ! *** and cloud base, and that lifted air is positively buoyant *** ! *** at cloud base *** ! *** if not, return to calling program after resetting *** ! *** sig(i) and w0(i) *** ! oct3 do 200 i=1,len ! oct3 ! oct3 tdif = buoybase(i) ! oct3 ath1 = th(i,1) ! oct3 ath = th(i,icb(i)-1) - dttrig ! oct3 ! oct3 if (tdif.lt.dtcrit .or. ath.gt.ath1) then ! oct3 do 60 k=1,nl ! oct3 sig(i,k) = beta*sig(i,k) - 2.*alpha*tdif*tdif ! oct3 sig(i,k) = AMAX1(sig(i,k),0.0) ! oct3 w0(i,k) = beta*w0(i,k) ! oct3 60 continue ! oct3 iflag(i)=4 ! pour version vectorisee ! oct3c convect3 iflag(i)=0 ! oct3cccc return ! oct3 endif ! oct3 ! oct3200 continue ! -- oct3: on reecrit la boucle 200 (pour la vectorisation) DO k = 1, nl DO i = 1, len tdif = buoybase(i) ath1 = th(i, 1) ath = th(i, icb(i)-1) - dttrig IF (tdifath1) THEN sig(i, k) = beta*sig(i, k) - 2.*alpha*tdif*tdif sig(i, k) = amax1(sig(i,k), 0.0) w0(i, k) = beta*w0(i, k) iflag(i) = 4 ! pour version vectorisee ! convect3 iflag(i)=0 END IF END DO END DO ! fin oct3 -- RETURN END SUBROUTINE cv30_trigger SUBROUTINE cv30_compress(len, nloc, ncum, nd, ntra, iflag1, nk1, icb1, icbs1, & plcl1, tnk1, qnk1, gznk1, pbase1, buoybase1, t1, q1, qs1, u1, v1, gz1, & th1, tra1, h1, lv1, cpn1, p1, ph1, tv1, tp1, tvp1, clw1, sig1, w01, & iflag, nk, icb, icbs, plcl, tnk, qnk, gznk, pbase, buoybase, t, q, qs, u, & v, gz, th, tra, h, lv, cpn, p, ph, tv, tp, tvp, clw, sig, w0 & #ifdef ISO & ,xtnk1,xt1,xtclw1 & & ,xtnk,xt,xtclw & #endif & ) USE print_control_mod, ONLY: lunout #ifdef ISO use infotrac_phy, ONLY: ntraciso=>ntiso use isotopes_mod, ONLY: essai_convergence, iso_eau,iso_HDO #ifdef ISOVERIF use isotopes_verif_mod, ONLY: errmax,errmaxrel,Tmin_verif, & iso_verif_egalite_choix, iso_verif_noNaN,iso_verif_aberrant, & iso_verif_egalite,iso_verif_egalite_choix_nostop,iso_verif_positif_nostop, & iso_verif_egalite_nostop,iso_verif_aberrant_nostop,deltaD,iso_verif_noNaN_nostop, & iso_verif_positif,iso_verif_egalite_vect2D #endif #endif IMPLICIT NONE include "cv30param.h" ! inputs: INTEGER len, ncum, nd, ntra, nloc INTEGER iflag1(len), nk1(len), icb1(len), icbs1(len) REAL plcl1(len), tnk1(len), qnk1(len), gznk1(len) REAL pbase1(len), buoybase1(len) REAL t1(len, nd), q1(len, nd), qs1(len, nd), u1(len, nd), v1(len, nd) REAL gz1(len, nd), h1(len, nd), lv1(len, nd), cpn1(len, nd) REAL p1(len, nd), ph1(len, nd+1), tv1(len, nd), tp1(len, nd) REAL tvp1(len, nd), clw1(len, nd) REAL th1(len, nd) REAL sig1(len, nd), w01(len, nd) REAL tra1(len, nd, ntra) #ifdef ISO !integer niso real xt1(ntraciso,len,nd), xtclw1(ntraciso,len,nd) real xtnk1(ntraciso,len) #endif ! outputs: ! en fait, on a nloc=len pour l'instant (cf cv_driver) INTEGER iflag(nloc), nk(nloc), icb(nloc), icbs(nloc) REAL plcl(nloc), tnk(nloc), qnk(nloc), gznk(nloc) REAL pbase(nloc), buoybase(nloc) REAL t(nloc, nd), q(nloc, nd), qs(nloc, nd), u(nloc, nd), v(nloc, nd) REAL gz(nloc, nd), h(nloc, nd), lv(nloc, nd), cpn(nloc, nd) REAL p(nloc, nd), ph(nloc, nd+1), tv(nloc, nd), tp(nloc, nd) REAL tvp(nloc, nd), clw(nloc, nd) REAL th(nloc, nd) REAL sig(nloc, nd), w0(nloc, nd) REAL tra(nloc, nd, ntra) #ifdef ISO real xt(ntraciso,nloc,nd), xtclw(ntraciso,nloc,nd) real xtnk(ntraciso,nloc) #endif ! local variables: INTEGER i, k, nn, j #ifdef ISO integer ixt #endif CHARACTER (LEN=20) :: modname = 'cv30_compress' CHARACTER (LEN=80) :: abort_message #ifdef ISO ! initialisation des champs compresses: do k=1,nd do i=1,nloc if (essai_convergence) then else q(i,k)=0.0 clw(i,k)=0.0 ! mise en commentaire le 5 avril pour verif ! convergence endif !f (negation(essai_convergence)) then do ixt=1,ntraciso xt(ixt,i,k)=0.0 xtclw(ixt,i,k)=0.0 enddo !do ixt=1,niso enddo !do i=1,len enddo !do k=1,nd ! write(*,*) 'q(1,1),xt(iso_eau,1,1)=',q(1,1),xt(iso_eau,1,1) #endif DO k = 1, nl + 1 nn = 0 DO i = 1, len IF (iflag1(i)==0) THEN nn = nn + 1 sig(nn, k) = sig1(i, k) w0(nn, k) = w01(i, k) t(nn, k) = t1(i, k) q(nn, k) = q1(i, k) qs(nn, k) = qs1(i, k) u(nn, k) = u1(i, k) v(nn, k) = v1(i, k) gz(nn, k) = gz1(i, k) h(nn, k) = h1(i, k) lv(nn, k) = lv1(i, k) cpn(nn, k) = cpn1(i, k) p(nn, k) = p1(i, k) ph(nn, k) = ph1(i, k) tv(nn, k) = tv1(i, k) tp(nn, k) = tp1(i, k) tvp(nn, k) = tvp1(i, k) clw(nn, k) = clw1(i, k) th(nn, k) = th1(i, k) #ifdef ISO do ixt = 1, ntraciso xt(ixt,nn,k)=xt1(ixt,i,k) xtclw(ixt,nn,k)=xtclw1(ixt,i,k) enddo ! write(*,*) 'nn,i,k,q(nn,k),xt(iso_eau,nn,k)=', & ! & nn,i,k,q(nn, k),xt(ixt,nn,k) #endif END IF END DO END DO ! do 121 j=1,ntra ! do 111 k=1,nd ! nn=0 ! do 101 i=1,len ! if(iflag1(i).eq.0)then ! nn=nn+1 ! tra(nn,k,j)=tra1(i,k,j) ! endif ! 101 continue ! 111 continue ! 121 continue IF (nn/=ncum) THEN WRITE (lunout, *) 'strange! nn not equal to ncum: ', nn, ncum abort_message = '' CALL abort_physic(modname, abort_message, 1) END IF nn = 0 DO i = 1, len IF (iflag1(i)==0) THEN nn = nn + 1 pbase(nn) = pbase1(i) buoybase(nn) = buoybase1(i) plcl(nn) = plcl1(i) tnk(nn) = tnk1(i) qnk(nn) = qnk1(i) gznk(nn) = gznk1(i) nk(nn) = nk1(i) icb(nn) = icb1(i) icbs(nn) = icbs1(i) iflag(nn) = iflag1(i) #ifdef ISO do ixt=1,ntraciso xtnk(ixt,nn) = xtnk1(ixt,i) enddo #endif END IF END DO #ifdef ISO #ifdef ISOVERIF if (iso_eau.gt.0) then do k = 1, nd do i = 1, nloc !write(*,*) 'i,k=',i,k call iso_verif_egalite_choix(xtclw(iso_eau,i,k),clw(i,k), & & 'compress 973',errmax,errmaxrel) call iso_verif_egalite_choix(xt(iso_eau,i,k),q(i,k), & & 'compress 975',errmax,errmaxrel) enddo enddo endif !if (iso_eau.gt.0) then do k = 1, nd do i = 1, nn call iso_verif_positif(q(i,k),'compress 1004') enddo enddo #endif #endif RETURN END SUBROUTINE cv30_compress SUBROUTINE cv30_undilute2(nloc, ncum, nd, icb, icbs, nk, tnk, qnk, gznk, t, & q, qs, gz, p, h, tv, lv, pbase, buoybase, plcl, inb, tp, tvp, clw, hp, & ep, sigp, buoy & #ifdef ISO & ,xtnk,xt,xtclw & #endif & ) ! epmax_cape: ajout arguments #ifdef ISO use infotrac_phy, ONLY: ntraciso=>ntiso USE isotopes_mod, ONLY: pxtmelt,pxtice,pxtmin,pxtmax,cond_temp_env, iso_eau,iso_HDO USE isotopes_routines_mod, ONLY: condiso_liq_ice_vectall #ifdef ISOTRAC USE isotopes_routines_mod, ONLY: condiso_liq_ice_vectall_trac #ifdef ISOVERIF USE isotopes_verif_mod, ONLY: iso_verif_traceur #endif #endif #ifdef ISOVERIF use isotopes_verif_mod, ONLY: errmax,errmaxrel,Tmin_verif,Tmax_verif, & iso_verif_egalite_choix, iso_verif_noNaN,iso_verif_aberrant, & iso_verif_egalite,iso_verif_egalite_choix_nostop,iso_verif_positif_nostop, & iso_verif_egalite_nostop,iso_verif_aberrant_nostop,deltaD,iso_verif_noNaN_nostop, & iso_verif_positif,iso_verif_egalite_vect2D #endif #endif IMPLICIT NONE ! --------------------------------------------------------------------- ! Purpose: ! FIND THE REST OF THE LIFTED PARCEL TEMPERATURES ! & ! COMPUTE THE PRECIPITATION EFFICIENCIES AND THE ! FRACTION OF PRECIPITATION FALLING OUTSIDE OF CLOUD ! & ! FIND THE LEVEL OF NEUTRAL BUOYANCY ! Main differences convect3/convect4: ! - icbs (input) is the first level above LCL (may differ from icb) ! - many minor differences in the iterations ! - condensed water not removed from tvp in convect3 ! - vertical profile of buoyancy computed here (use of buoybase) ! - the determination of inb is different ! - no inb1, only inb in output ! --------------------------------------------------------------------- include "cvthermo.h" include "cv30param.h" include "conema3.h" ! inputs: INTEGER ncum, nd, nloc INTEGER icb(nloc), icbs(nloc), nk(nloc) REAL t(nloc, nd), q(nloc, nd), qs(nloc, nd), gz(nloc, nd) REAL p(nloc, nd) REAL tnk(nloc), qnk(nloc), gznk(nloc) REAL lv(nloc, nd), tv(nloc, nd), h(nloc, nd) REAL pbase(nloc), buoybase(nloc), plcl(nloc) ! outputs: INTEGER inb(nloc) REAL tp(nloc, nd), tvp(nloc, nd), clw(nloc, nd) REAL ep(nloc, nd), sigp(nloc, nd), hp(nloc, nd) REAL buoy(nloc, nd) ! local variables: INTEGER i, k REAL tg, qg, ahg, alv, s, tc, es, denom, rg, tca, elacrit REAL by, defrac, pden REAL ah0(nloc), cape(nloc), capem(nloc), byp(nloc) LOGICAL lcape(nloc) #ifdef ISO real xt(ntraciso,nloc,nd), xtclw(ntraciso,nloc,nd) real xtnk(ntraciso,nloc) ! real xtep(ntraciso,nloc,nd) ! le 7 mai: on supprime xtep, car pas besoin ! la chute de precip ne fractionne pas. integer ixt real zfice(nloc),zxtliq(ntraciso,nloc),zxtice(ntraciso,nloc) real clw_k(nloc),tg_k(nloc) #ifdef ISOVERIF real qg_save(nloc,nd) ! inout !integer iso_verif_positif_nostop #endif #endif ! ===================================================================== ! --- SOME INITIALIZATIONS ! ===================================================================== DO k = 1, nl DO i = 1, ncum ep(i, k) = 0.0 sigp(i, k) = spfac clw(i,k)=0.0 ! C Risi END DO END DO ! ===================================================================== ! --- FIND THE REST OF THE LIFTED PARCEL TEMPERATURES ! ===================================================================== ! --- The procedure is to solve the equation. ! cp*tp+L*qp+phi=cp*tnk+L*qnk+gznk. ! *** Calculate certain parcel quantities, including static energy *** DO i = 1, ncum ah0(i) = (cpd*(1.-qnk(i))+cl*qnk(i))*tnk(i) & ! debug & ! +qnk(i)*(lv0-clmcpv*(tnk(i)-t0))+gznk(i) +qnk(i)*(lv0-clmcpv*(tnk(i)-273.15)) + gznk(i) END DO ! *** Find lifted parcel quantities above cloud base *** DO k = minorig + 1, nl DO i = 1, ncum ! ori if(k.ge.(icb(i)+1))then IF (k>=(icbs(i)+1)) THEN ! convect3 tg = t(i, k) qg = qs(i, k) ! debug alv=lv0-clmcpv*(t(i,k)-t0) alv = lv0 - clmcpv*(t(i,k)-273.15) ! First iteration. ! ori s=cpd+alv*alv*qg/(rrv*t(i,k)*t(i,k)) s = cpd*(1.-qnk(i)) + cl*qnk(i) & ! convect3 +alv*alv*qg/(rrv*t(i,k)*t(i,k)) ! convect3 s = 1./s ! ori ahg=cpd*tg+(cl-cpd)*qnk(i)*t(i,k)+alv*qg+gz(i,k) ahg = cpd*tg + (cl-cpd)*qnk(i)*tg + alv*qg + gz(i, k) ! convect3 tg = tg + s*(ah0(i)-ahg) ! ori tg=max(tg,35.0) ! debug tc=tg-t0 tc = tg - 273.15 denom = 243.5 + tc denom = max(denom, 1.0) ! convect3 ! ori if(tc.ge.0.0)then es = 6.112*exp(17.67*tc/denom) ! ori else ! ori es=exp(23.33086-6111.72784/tg+0.15215*log(tg)) ! ori endif qg = eps*es/(p(i,k)-es*(1.-eps)) ! qg=max(0.0,qg) ! C Risi ! Second iteration. ! ori s=cpd+alv*alv*qg/(rrv*t(i,k)*t(i,k)) ! ori s=1./s ! ori ahg=cpd*tg+(cl-cpd)*qnk(i)*t(i,k)+alv*qg+gz(i,k) ahg = cpd*tg + (cl-cpd)*qnk(i)*tg + alv*qg + gz(i, k) ! convect3 tg = tg + s*(ah0(i)-ahg) ! ori tg=max(tg,35.0) ! debug tc=tg-t0 tc = tg - 273.15 denom = 243.5 + tc denom = max(denom, 1.0) ! convect3 ! ori if(tc.ge.0.0)then es = 6.112*exp(17.67*tc/denom) ! ori else ! ori es=exp(23.33086-6111.72784/tg+0.15215*log(tg)) ! ori endif qg = eps*es/(p(i,k)-es*(1.-eps)) ! qg=max(0.0,qg) ! C Risi ! debug alv=lv0-clmcpv*(t(i,k)-t0) alv = lv0 - clmcpv*(t(i,k)-273.15) ! print*,'cpd dans convect2 ',cpd ! print*,'tp(i,k),ah0(i),cl,cpd,qnk(i),t(i,k),gz(i,k),alv,qg,cpd' ! print*,tp(i,k),ah0(i),cl,cpd,qnk(i),t(i,k),gz(i,k),alv,qg,cpd ! ori c approximation here: ! ori ! tp(i,k)=(ah0(i)-(cl-cpd)*qnk(i)*t(i,k)-gz(i,k)-alv*qg)/cpd ! convect3: no approximation: tp(i, k) = (ah0(i)-gz(i,k)-alv*qg)/(cpd+(cl-cpd)*qnk(i)) clw(i, k) = qnk(i) - qg clw(i, k) = max(0.0, clw(i,k)) rg = qg/(1.-qnk(i)) ! ori tvp(i,k)=tp(i,k)*(1.+rg*epsi) ! convect3: (qg utilise au lieu du vrai mixing ratio rg): tvp(i, k) = tp(i, k)*(1.+qg/eps-qnk(i)) ! whole thing END IF END DO #ifdef ISO ! calcul de zfice do i=1,ncum zfice(i) = 1.0-(t(i,k)-pxtice)/(pxtmelt-pxtice) zfice(i) = MIN(MAX(zfice(i),0.0),1.0) enddo do i=1,ncum clw_k(i)=clw(i,k) tg_k(i)=t(i,k) enddo !do i=1,ncum #ifdef ISOVERIF !write(*,*) 'cv30_routine 1259: avant condiso' if (iso_HDO.gt.0) then do i=1,ncum call iso_verif_aberrant(xtnk(iso_hdo,i)/qnk(i), & & 'cv30_routines 1231') enddo endif !if (iso_HDO.gt.0) then if (iso_eau.gt.0) then do i=1,ncum call iso_verif_egalite(xtnk(iso_eau,i),qnk(i), & & 'cv30_routines 1373') enddo endif !if (iso_HDO.gt.0) then do i=1,ncum if ((iso_verif_positif_nostop(qnk(i)-clw_k(i), & & 'cv30_routines 1275').eq.1).or. & & (iso_verif_positif_nostop(tg_k(i)-Tmin_verif, & & 'cv30_routines 1297a').eq.1).or. & & (iso_verif_positif_nostop(Tmax_verif-tg_k(i), & & 'cv30_routines 1297b').eq.1)) then write(*,*) 'i,k,qnk,clw_k=',i,k,qnk(i),clw_k(i) write(*,*) 'tg,t,qg=',tg_k(i),t(i,k),qg_save(i,k) write(*,*) 'icbs(i)=',icbs(i) stop endif ! if ((iso_verif_positif_nostop enddo !do i=1,ncum #ifdef ISOTRAC do i=1,ncum call iso_verif_traceur(xtnk(1,i),'cv30_routines 1251') enddo !do i=1,ncum #endif #endif call condiso_liq_ice_vectall(xtnk(1,1),qnk(1), & & clw_k(1),tg_k(1), & & zfice(1),zxtice(1,1),zxtliq(1,1),ncum) #ifdef ISOTRAC #ifdef ISOVERIF write(*,*) 'cv30_routines 1283: condiso pour traceurs' #endif call condiso_liq_ice_vectall_trac(xtnk(1,1),qnk(1), & & clw_k(1),tg_k(1), & & zfice(1),zxtice(1,1),zxtliq(1,1),ncum) #endif do i=1,ncum do ixt=1,ntraciso xtclw(ixt,i,k)=zxtice(ixt,i)+zxtliq(ixt,i) xtclw(ixt,i,k)=max(0.0,xtclw(ixt,i,k)) enddo !do ixt=1,niso enddo !do i=1,ncum #ifdef ISOVERIF if (iso_eau.gt.0) then do i=1,ncum call iso_verif_egalite_choix(xtclw(iso_eau,i,k), & & clw(i,k),'cv30_routines 1223',errmax,errmaxrel) enddo endif !if (iso_eau.gt.0) then #ifdef ISOTRAC do i=1,ncum call iso_verif_traceur(xtclw(1,i,k),'cv30_routines 1275') enddo #endif #endif #endif END DO ! ===================================================================== ! --- SET THE PRECIPITATION EFFICIENCIES AND THE FRACTION OF ! --- PRECIPITATION FALLING OUTSIDE OF CLOUD ! --- THESE MAY BE FUNCTIONS OF TP(I), P(I) AND CLW(I) ! ===================================================================== ! ori do 320 k=minorig+1,nl DO k = 1, nl ! convect3 DO i = 1, ncum pden = ptcrit - pbcrit ep(i, k) = (plcl(i)-p(i,k)-pbcrit)/pden*epmax ep(i, k) = amax1(ep(i,k), 0.0) ep(i, k) = amin1(ep(i,k), epmax) sigp(i, k) = spfac ! ori if(k.ge.(nk(i)+1))then ! ori tca=tp(i,k)-t0 ! ori if(tca.ge.0.0)then ! ori elacrit=elcrit ! ori else ! ori elacrit=elcrit*(1.0-tca/tlcrit) ! ori endif ! ori elacrit=max(elacrit,0.0) ! ori ep(i,k)=1.0-elacrit/max(clw(i,k),1.0e-8) ! ori ep(i,k)=max(ep(i,k),0.0 ) ! ori ep(i,k)=min(ep(i,k),1.0 ) ! ori sigp(i,k)=sigs ! ori endif END DO END DO ! ===================================================================== ! --- CALCULATE VIRTUAL TEMPERATURE AND LIFTED PARCEL ! --- VIRTUAL TEMPERATURE ! ===================================================================== ! dans convect3, tvp est calcule en une seule fois, et sans retirer ! l'eau condensee (~> reversible CAPE) ! ori do 340 k=minorig+1,nl ! ori do 330 i=1,ncum ! ori if(k.ge.(icb(i)+1))then ! ori tvp(i,k)=tvp(i,k)*(1.0-qnk(i)+ep(i,k)*clw(i,k)) ! oric print*,'i,k,tvp(i,k),qnk(i),ep(i,k),clw(i,k)' ! oric print*, i,k,tvp(i,k),qnk(i),ep(i,k),clw(i,k) ! ori endif ! ori 330 continue ! ori 340 continue ! ori do 350 i=1,ncum ! ori tvp(i,nlp)=tvp(i,nl)-(gz(i,nlp)-gz(i,nl))/cpd ! ori 350 continue DO i = 1, ncum ! convect3 tp(i, nlp) = tp(i, nl) ! convect3 END DO ! convect3 ! ===================================================================== ! --- EFFECTIVE VERTICAL PROFILE OF BUOYANCY (convect3 only): ! ===================================================================== ! -- this is for convect3 only: ! first estimate of buoyancy: DO i = 1, ncum DO k = 1, nl buoy(i, k) = tvp(i, k) - tv(i, k) END DO END DO ! set buoyancy=buoybase for all levels below base ! for safety, set buoy(icb)=buoybase DO i = 1, ncum DO k = 1, nl IF ((k>=icb(i)) .AND. (k<=nl) .AND. (p(i,k)>=pbase(i))) THEN buoy(i, k) = buoybase(i) END IF END DO ! IM cf. CRio/JYG 270807 buoy(icb(i),k)=buoybase(i) buoy(i, icb(i)) = buoybase(i) END DO ! -- end convect3 ! ===================================================================== ! --- FIND THE FIRST MODEL LEVEL (INB) ABOVE THE PARCEL'S ! --- LEVEL OF NEUTRAL BUOYANCY ! ===================================================================== ! -- this is for convect3 only: DO i = 1, ncum inb(i) = nl - 1 END DO DO i = 1, ncum DO k = 1, nl - 1 IF ((k>=icb(i)) .AND. (buoy(i,k)=icb(i)) .AND. (k<=inb(i))) THEN hp(i, k) = h(i, nk(i)) + (lv(i,k)+(cpd-cpv)*t(i,k))*ep(i, k)*clw(i, k & ) END IF END DO END DO RETURN END SUBROUTINE cv30_undilute2 SUBROUTINE cv30_closure(nloc, ncum, nd, icb, inb, pbase, p, ph, tv, buoy, & sig, w0, cape, m) IMPLICIT NONE ! =================================================================== ! --- CLOSURE OF CONVECT3 ! vectorization: S. Bony ! =================================================================== include "cvthermo.h" include "cv30param.h" ! input: INTEGER ncum, nd, nloc INTEGER icb(nloc), inb(nloc) REAL pbase(nloc) REAL p(nloc, nd), ph(nloc, nd+1) REAL tv(nloc, nd), buoy(nloc, nd) ! input/output: REAL sig(nloc, nd), w0(nloc, nd) ! output: REAL cape(nloc) REAL m(nloc, nd) ! local variables: INTEGER i, j, k, icbmax REAL deltap, fac, w, amu REAL dtmin(nloc, nd), sigold(nloc, nd) ! ------------------------------------------------------- ! -- Initialization ! ------------------------------------------------------- DO k = 1, nl DO i = 1, ncum m(i, k) = 0.0 END DO END DO ! ------------------------------------------------------- ! -- Reset sig(i) and w0(i) for i>inb and i=(inb(i)+1))) THEN sig(i, k) = beta*sig(i, k) + 2.*alpha*buoy(i, inb(i))*abs(buoy(i,inb( & i))) sig(i, k) = amax1(sig(i,k), 0.0) w0(i, k) = beta*w0(i, k) END IF END DO END DO ! compute icbmax: icbmax = 2 DO i = 1, ncum icbmax = max(icbmax, icb(i)) END DO ! update sig and w0 below cloud base: DO k = 1, icbmax DO i = 1, ncum IF (k<=icb(i)) THEN sig(i, k) = beta*sig(i, k) - 2.*alpha*buoy(i, icb(i))*buoy(i, icb(i)) sig(i, k) = amax1(sig(i,k), 0.0) w0(i, k) = beta*w0(i, k) END IF END DO END DO ! ! if(inb.lt.(nl-1))then ! ! do 85 i=inb+1,nl-1 ! ! sig(i)=beta*sig(i)+2.*alpha*buoy(inb)* ! ! 1 abs(buoy(inb)) ! ! sig(i)=amax1(sig(i),0.0) ! ! w0(i)=beta*w0(i) ! ! 85 continue ! ! end if ! ! do 87 i=1,icb ! ! sig(i)=beta*sig(i)-2.*alpha*buoy(icb)*buoy(icb) ! ! sig(i)=amax1(sig(i),0.0) ! ! w0(i)=beta*w0(i) ! ! 87 continue ! ------------------------------------------------------------- ! -- Reset fractional areas of updrafts and w0 at initial time ! -- and after 10 time steps of no convection ! ------------------------------------------------------------- DO k = 1, nl - 1 DO i = 1, ncum IF (sig(i,nd)<1.5 .OR. sig(i,nd)>12.0) THEN sig(i, k) = 0.0 w0(i, k) = 0.0 END IF END DO END DO ! ------------------------------------------------------------- ! -- Calculate convective available potential energy (cape), ! -- vertical velocity (w), fractional area covered by ! -- undilute updraft (sig), and updraft mass flux (m) ! ------------------------------------------------------------- DO i = 1, ncum cape(i) = 0.0 END DO ! compute dtmin (minimum buoyancy between ICB and given level k): DO i = 1, ncum DO k = 1, nl dtmin(i, k) = 100.0 END DO END DO DO i = 1, ncum DO k = 1, nl DO j = minorig, nl IF ((k>=(icb(i)+1)) .AND. (k<=inb(i)) .AND. (j>=icb(i)) .AND. (j<=(k- & 1))) THEN dtmin(i, k) = amin1(dtmin(i,k), buoy(i,j)) END IF END DO END DO END DO ! the interval on which cape is computed starts at pbase : DO k = 1, nl DO i = 1, ncum IF ((k>=(icb(i)+1)) .AND. (k<=inb(i))) THEN deltap = min(pbase(i), ph(i,k-1)) - min(pbase(i), ph(i,k)) cape(i) = cape(i) + rrd*buoy(i, k-1)*deltap/p(i, k-1) cape(i) = amax1(0.0, cape(i)) sigold(i, k) = sig(i, k) ! dtmin(i,k)=100.0 ! do 97 j=icb(i),k-1 ! mauvaise vectorisation ! dtmin(i,k)=AMIN1(dtmin(i,k),buoy(i,j)) ! 97 continue sig(i, k) = beta*sig(i, k) + alpha*dtmin(i, k)*abs(dtmin(i,k)) sig(i, k) = amax1(sig(i,k), 0.0) sig(i, k) = amin1(sig(i,k), 0.01) fac = amin1(((dtcrit-dtmin(i,k))/dtcrit), 1.0) w = (1.-beta)*fac*sqrt(cape(i)) + beta*w0(i, k) amu = 0.5*(sig(i,k)+sigold(i,k))*w m(i, k) = amu*0.007*p(i, k)*(ph(i,k)-ph(i,k+1))/tv(i, k) w0(i, k) = w END IF END DO END DO DO i = 1, ncum w0(i, icb(i)) = 0.5*w0(i, icb(i)+1) m(i, icb(i)) = 0.5*m(i, icb(i)+1)*(ph(i,icb(i))-ph(i,icb(i)+1))/ & (ph(i,icb(i)+1)-ph(i,icb(i)+2)) sig(i, icb(i)) = sig(i, icb(i)+1) sig(i, icb(i)-1) = sig(i, icb(i)) END DO ! ! cape=0.0 ! ! do 98 i=icb+1,inb ! ! deltap = min(pbase,ph(i-1))-min(pbase,ph(i)) ! ! cape=cape+rrd*buoy(i-1)*deltap/p(i-1) ! ! dcape=rrd*buoy(i-1)*deltap/p(i-1) ! ! dlnp=deltap/p(i-1) ! ! cape=amax1(0.0,cape) ! ! sigold=sig(i) ! ! dtmin=100.0 ! ! do 97 j=icb,i-1 ! ! dtmin=amin1(dtmin,buoy(j)) ! ! 97 continue ! ! sig(i)=beta*sig(i)+alpha*dtmin*abs(dtmin) ! ! sig(i)=amax1(sig(i),0.0) ! ! sig(i)=amin1(sig(i),0.01) ! ! fac=amin1(((dtcrit-dtmin)/dtcrit),1.0) ! ! w=(1.-beta)*fac*sqrt(cape)+beta*w0(i) ! ! amu=0.5*(sig(i)+sigold)*w ! ! m(i)=amu*0.007*p(i)*(ph(i)-ph(i+1))/tv(i) ! ! w0(i)=w ! ! 98 continue ! ! w0(icb)=0.5*w0(icb+1) ! ! m(icb)=0.5*m(icb+1)*(ph(icb)-ph(icb+1))/(ph(icb+1)-ph(icb+2)) ! ! sig(icb)=sig(icb+1) ! ! sig(icb-1)=sig(icb) RETURN END SUBROUTINE cv30_closure SUBROUTINE cv30_mixing(nloc, ncum, nd, na, ntra, icb, nk, inb, ph, t, rr, rs, & u, v, tra, h, lv, qnk, hp, tv, tvp, ep, clw, m, sig, ment, qent, uent, & vent, sij, elij, ments, qents, traent & #ifdef ISO & ,xt,xtnk,xtclw & & ,xtent,xtelij & #endif & ) #ifdef ISO use infotrac_phy, ONLY: ntraciso=>ntiso,niso,itZonIso USE isotopes_mod, ONLY: pxtmelt,pxtice,pxtmin,pxtmax, iso_eau,iso_HDO, & ridicule USE isotopes_routines_mod, ONLY: condiso_liq_ice_vectall #ifdef ISOVERIF use isotopes_verif_mod, ONLY: errmax,errmaxrel,Tmin_verif,deltalim, & iso_verif_egalite_choix,iso_verif_aberrant_choix, iso_verif_noNaN, & iso_verif_aberrant, & iso_verif_egalite,iso_verif_egalite_choix_nostop,iso_verif_positif_nostop, & iso_verif_egalite_nostop,iso_verif_aberrant_nostop,deltaD,iso_verif_noNaN_nostop, & iso_verif_positif,iso_verif_egalite_vect2D #endif #ifdef ISOTRAC use isotrac_mod, only: option_tmin,option_traceurs,seuil_tag_tmin, & & option_cond,index_zone,izone_cond,index_iso use isotrac_routines_mod, only: iso_recolorise_condensation use isotopes_routines_mod, only: condiso_liq_ice_vectall_trac #ifdef ISOVERIF use isotopes_verif_mod, ONLY: iso_verif_trac17_q_deltad,iso_verif_traceur, & & iso_verif_traceur_justmass #endif #endif #endif IMPLICIT NONE ! --------------------------------------------------------------------- ! a faire: ! - changer rr(il,1) -> qnk(il) ! - vectorisation de la partie normalisation des flux (do 789...) ! --------------------------------------------------------------------- include "cvthermo.h" include "cv30param.h" ! inputs: INTEGER ncum, nd, na, ntra, nloc INTEGER icb(nloc), inb(nloc), nk(nloc) REAL sig(nloc, nd) REAL qnk(nloc) REAL ph(nloc, nd+1) REAL t(nloc, nd), rr(nloc, nd), rs(nloc, nd) REAL u(nloc, nd), v(nloc, nd) REAL tra(nloc, nd, ntra) ! input of convect3 REAL lv(nloc, na), h(nloc, na), hp(nloc, na) REAL tv(nloc, na), tvp(nloc, na), ep(nloc, na), clw(nloc, na) REAL m(nloc, na) ! input of convect3 #ifdef ISO real xt(ntraciso,nloc,na), xtclw(ntraciso,nloc,na) real tg_save(nloc,nd) real xtnk(ntraciso,nloc) ! real xtep(ntraciso,nloc,na) #endif ! outputs: REAL ment(nloc, na, na), qent(nloc, na, na) REAL uent(nloc, na, na), vent(nloc, na, na) REAL sij(nloc, na, na), elij(nloc, na, na) REAL traent(nloc, nd, nd, ntra) REAL ments(nloc, nd, nd), qents(nloc, nd, nd) REAL sigij(nloc, nd, nd) #ifdef ISO real xtent(ntraciso,nloc,nd,nd) real xtelij(ntraciso,nloc,nd,nd) #endif ! local variables: INTEGER i, j, k, il, im, jm INTEGER num1, num2 INTEGER nent(nloc, na) REAL rti, bf2, anum, denom, dei, altem, cwat, stemp, qp REAL alt, smid, sjmin, sjmax, delp, delm REAL asij(nloc), smax(nloc), scrit(nloc) REAL asum(nloc, nd), bsum(nloc, nd), csum(nloc, nd) REAL wgh REAL zm(nloc, na) LOGICAL lwork(nloc) #ifdef ISO integer ixt real xtrti(ntraciso,nloc) real xtres(ntraciso) ! on ajoute la dimension nloc a xtrti pour verifs dans les tags: 5 fev ! 2010 real zfice(nloc),zxtliq(ntraciso,nloc),zxtice(ntraciso,nloc) ! real xt_reduit(ntraciso) ! logical negation !#ifdef ISOVERIF ! integer iso_verif_positif_nostop !#endif #endif ! ===================================================================== ! --- INITIALIZE VARIOUS ARRAYS USED IN THE COMPUTATIONS ! ===================================================================== #ifdef ISO #ifdef ISOVERIF write(*,*) 'cv30_routines 1820: entree dans cv3_mixing' if (iso_eau.gt.0) then call iso_verif_egalite_vect2D( & & xtclw,clw, & & 'cv30_mixing 1841',ntraciso,nloc,na) endif #endif #endif ! ori do 360 i=1,ncum*nlp DO j = 1, nl DO i = 1, ncum nent(i, j) = 0 ! in convect3, m is computed in cv3_closure ! ori m(i,1)=0.0 END DO END DO ! ori do 400 k=1,nlp ! ori do 390 j=1,nlp DO j = 1, nl DO k = 1, nl DO i = 1, ncum qent(i, k, j) = rr(i, j) uent(i, k, j) = u(i, j) vent(i, k, j) = v(i, j) elij(i, k, j) = 0.0 ! ym ment(i,k,j)=0.0 ! ym sij(i,k,j)=0.0 END DO END DO END DO #ifdef ISO do j=1,nd do k=1,nd do i=1,ncum do ixt =1,ntraciso xtent(ixt,i,k,j)=xt(ixt,i,j) xtelij(ixt,i,k,j)=0.0 enddo !do ixt =1,niso ! on initialise mieux que ca qent et elij, meme si au final les ! valeurs en nd=nl+1 ne sont pas utilisees qent(i,k,j)=rr(i,j) elij(i,k,j)=0.0 enddo !do i=1,ncum enddo !do k=1,nl enddo !do j=1,nl #endif ! ym ment(1:ncum, 1:nd, 1:nd) = 0.0 sij(1:ncum, 1:nd, 1:nd) = 0.0 ! do k=1,ntra ! do j=1,nd ! instead nlp ! do i=1,nd ! instead nlp ! do il=1,ncum ! traent(il,i,j,k)=tra(il,j,k) ! enddo ! enddo ! enddo ! enddo zm(:, :) = 0. ! ===================================================================== ! --- CALCULATE ENTRAINED AIR MASS FLUX (ment), TOTAL WATER MIXING ! --- RATIO (QENT), TOTAL CONDENSED WATER (elij), AND MIXING ! --- FRACTION (sij) ! ===================================================================== DO i = minorig + 1, nl DO j = minorig, nl DO il = 1, ncum IF ((i>=icb(il)) .AND. (i<=inb(il)) .AND. (j>=(icb(il)- & 1)) .AND. (j<=inb(il))) THEN rti = rr(il, 1) - ep(il, i)*clw(il, i) bf2 = 1. + lv(il, j)*lv(il, j)*rs(il, j)/(rrv*t(il,j)*t(il,j)*cpd) anum = h(il, j) - hp(il, i) + (cpv-cpd)*t(il, j)*(rti-rr(il,j)) denom = h(il, i) - hp(il, i) + (cpd-cpv)*(rr(il,i)-rti)*t(il, j) dei = denom IF (abs(dei)<0.01) dei = 0.01 sij(il, i, j) = anum/dei sij(il, i, i) = 1.0 altem = sij(il, i, j)*rr(il, i) + (1.-sij(il,i,j))*rti - rs(il, j) altem = altem/bf2 cwat = clw(il, j)*(1.-ep(il,j)) stemp = sij(il, i, j) IF ((stemp<0.0 .OR. stemp>1.0 .OR. altem>cwat) .AND. j>i) THEN anum = anum - lv(il, j)*(rti-rs(il,j)-cwat*bf2) denom = denom + lv(il, j)*(rr(il,i)-rti) IF (abs(denom)<0.01) denom = 0.01 sij(il, i, j) = anum/denom altem = sij(il, i, j)*rr(il, i) + (1.-sij(il,i,j))*rti - & rs(il, j) altem = altem - (bf2-1.)*cwat END IF IF (sij(il,i,j)>0.0 .AND. sij(il,i,j)<0.95) THEN qent(il, i, j) = sij(il, i, j)*rr(il, i) + (1.-sij(il,i,j))*rti uent(il, i, j) = sij(il, i, j)*u(il, i) + & (1.-sij(il,i,j))*u(il, nk(il)) vent(il, i, j) = sij(il, i, j)*v(il, i) + & (1.-sij(il,i,j))*v(il, nk(il)) ! !!! do k=1,ntra ! !!! traent(il,i,j,k)=sij(il,i,j)*tra(il,i,k) ! !!! : +(1.-sij(il,i,j))*tra(il,nk(il),k) ! !!! end do elij(il, i, j) = altem elij(il, i, j) = amax1(0.0, elij(il,i,j)) ment(il, i, j) = m(il, i)/(1.-sij(il,i,j)) nent(il, i) = nent(il, i) + 1 END IF sij(il, i, j) = amax1(0.0, sij(il,i,j)) sij(il, i, j) = amin1(1.0, sij(il,i,j)) END IF ! new END DO #ifdef ISO #ifdef ISOVERIF !write(*,*) 'cv30_routines tmp 2078' #endif do il=1,ncum zfice(il) = 1.0-(t(il,j)-pxtice)/(pxtmelt-pxtice) zfice(il) = MIN(MAX(zfice(il),0.0),1.0) if( (i.ge.icb(il)).and.(i.le.inb(il)).and. & & (j.ge.(icb(il)-1)).and.(j.le.inb(il)))then do ixt=1,ntraciso ! xtrti(ixt)=xt(ixt,il,1)-xtep(ixt,il,i)*xtclw(ixt,il,i) ! le 7 mai: on supprime xtep xtrti(ixt,il)=xt(ixt,il,1)-ep(il,i)*xtclw(ixt,il,i) enddo if(sij(il,i,j).gt.0.0.and.sij(il,i,j).lt.0.95)then ! temperature of condensation (within mixtures): ! tcond(il)=t(il,j) ! : + ( sij(il,i,j)*rr(il,i)+(1.-sij(il,i,j))*rti ! : - elij(il,i,j) - rs(il,j) ) ! : / ( cpd*(bf2-1.0)/lv(il,j) ) do ixt = 1, ntraciso ! total mixing ratio in the mixtures before precipitation: xtent(ixt,il,i,j)=sij(il,i,j)*xt(ixt,il,i) & & +(1.-sij(il,i,j))*xtrti(ixt,il) enddo !do ixt = 1, ntraciso endif !if(sij(il,i,j).gt.0.0.and.sij(il,i,j).lt.0.95)then endif !if( (i.ge.icb(il)).and.(i.le.inb(il)).and. enddo !do il=1,ncum call condiso_liq_ice_vectall(xtent(1,1,i,j),qent(1,i,j), & & elij(1,i,j), & & t(1,j),zfice(1),zxtice(1,1),zxtliq(1,1),ncum) #ifdef ISOTRAC call condiso_liq_ice_vectall_trac(xtent(1,1,i,j),qent(1,i,j), & & elij(1,i,j), & & t(1,j),zfice(1),zxtice(1,1),zxtliq(1,1),ncum) #ifdef ISOVERIF do il=1,ncum call iso_verif_traceur(xt(1,il,i),'cv30_routines 1967') if( (i.ge.icb(il)).and.(i.le.inb(il)).and. & & (j.ge.(icb(il)-1)).and.(j.le.inb(il)))then call iso_verif_traceur(xtrti(1,il),'cv30_routines 1968') endif !if( (i.ge.icb(il)).and.(i.le.inb(il)).and. call iso_verif_traceur(xtent(1,il,i,j),'cv30_routines 1969') enddo !do il=1,ncum #endif #endif do il=1,ncum do ixt = 1, ntraciso xtelij(ixt,il,i,j)=zxtice(ixt,il)+zxtliq(ixt,il) enddo !do ixt = 1, ntraciso enddo !do il=1,ncum #ifdef ISOVERIF if ((j.eq.15).and.(i.eq.15)) then il=2722 if (il.le.ncum) then write(*,*) 'cv30_routines tmp 2194, il,i,j=',il,i,j write(*,*) 'qent,elij=',qent(il,i,j),elij(il,i,j) write(*,*) 'tgsave,zfice=',t(il,j),zfice(il) write(*,*) 'deltaDqent=',deltaD(xtent(iso_HDO,il,i,j)/qent(il,i,j)) write(*,*) 'deltaDelij=',deltaD(xtelij(iso_HDO,il,i,j)/elij(il,i,j)) write(*,*) 'deltaDice=',deltaD(zxtice(iso_HDO,il)/(zfice(il)*elij(il,i,j))) write(*,*) 'deltaDliq=',deltaD(zxtliq(iso_HDO,il)/(1.0-zfice(il)*elij(il,i,j))) endif endif #endif #ifdef ISOTRAC ! write(*,*) 'cv30_routines tmp 1987,option_traceurs=', ! : option_traceurs if (option_tmin.ge.1) then do il=1,ncum ! write(*,*) 'cv3 tmp 1991 il,i,j,xtent(:,il,i,j),', ! : 'tcond(il),rs(il,j)=', ! : il,i,j,xtent(:,il,i,j),tcond(il),rs(il,j) ! colorier la vapeur residuelle selon temperature de ! condensation, et le condensat en un tag spEcifique if ((elij(il,i,j).gt.0.0).and.(qent(il,i,j).gt.0.0)) then if (option_traceurs.eq.17) then call iso_recolorise_condensation(qent(il,i,j),elij(il,i,j), & & xtent(1,il,i,j),xtelij(1,il,i,j),t(1,j), & & 0.0,xtres, & & seuil_tag_tmin) else !if (option_traceurs.eq.17) then ! write(*,*) 'cv3 2002: il,i,j =',il,i,j call iso_recolorise_condensation(qent(il,i,j),elij(il,i,j), & & xtent(1,il,i,j),xtelij(1,il,i,j),rs(il,j),0.0,xtres, & & seuil_tag_tmin) endif !if (option_traceurs.eq.17) then do ixt=1+niso,ntraciso xtent(ixt,il,i,j)=xtres(ixt) enddo endif !if (cond.gt.0.0) then enddo !do il=1,ncum #ifdef ISOVERIF do il=1,ncum call iso_verif_traceur(xtent(1,il,i,j),'cv30_routines 1996') call iso_verif_traceur(xtelij(1,il,i,j),'cv30_routines 1997') call iso_verif_trac17_q_deltaD(xtent(1,il,i,j), & & 'cv30_routines 2042') enddo !do il=1,ncum #endif endif !if (option_tmin.ge.1) then #endif ! fractionation: #ifdef ISOVERIF ! write(*,*) 'cv30_routines 2050: avant condiso' do il=1,ncum if ((i.ge.icb(il)).and.(i.le.inb(il)).and. & & (j.ge.(icb(il)-1)).and.(j.le.inb(il))) then if (sij(il,i,j).gt.0.0.and.sij(il,i,j).lt.0.95) then if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtent(iso_eau,il,i,j), & & qent(il,i,j),'cv30_routines 1889',errmax,errmaxrel) call iso_verif_egalite_choix(xtelij(iso_eau,il,i,j), & & elij(il,i,j),'cv30_routines 1890',errmax,errmaxrel) endif if (iso_HDO.gt.0) then call iso_verif_aberrant_choix(xt(iso_HDO,il,i),rr(il,i), & & ridicule,deltalim,'cv30_routines 1997') call iso_verif_aberrant_choix( & & xtent(iso_HDO,il,i,j),qent(il,i,j), & & ridicule,deltalim,'cv30_routines 1931') call iso_verif_aberrant_choix( & & xtelij(iso_HDO,il,i,j),elij(il,i,j), & & ridicule,deltalim,'cv30_routines 1993') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC ! write(*,*) 'cv30_routines tmp 2039 il=',il call iso_verif_traceur(xtent(1,il,i,j), & & 'cv30_routines 2031') call iso_verif_traceur(xtelij(1,il,i,j), & & 'cv30_routines 2033') #endif endif !if(sij(il,i,j).gt.0.0.and.sij(il,i,j).lt.0.95)then endif !if( (i.ge.icb(il)).and.(i.le.inb(il)).and. enddo !do il=1,ncum #endif ! write(*,*) 'cv30_routine tmp 1984: cond=',elij(il,i,j) #endif END DO ! do k=1,ntra ! do j=minorig,nl ! do il=1,ncum ! if( (i.ge.icb(il)).and.(i.le.inb(il)).and. ! : (j.ge.(icb(il)-1)).and.(j.le.inb(il)))then ! traent(il,i,j,k)=sij(il,i,j)*tra(il,i,k) ! : +(1.-sij(il,i,j))*tra(il,nk(il),k) ! endif ! enddo ! enddo ! enddo ! *** if no air can entrain at level i assume that updraft detrains ! *** ! *** at that level and calculate detrained air flux and properties ! *** ! @ do 170 i=icb(il),inb(il) DO il = 1, ncum IF ((i>=icb(il)) .AND. (i<=inb(il)) .AND. (nent(il,i)==0)) THEN ! @ if(nent(il,i).eq.0)then ment(il, i, i) = m(il, i) qent(il, i, i) = rr(il, nk(il)) - ep(il, i)*clw(il, i) uent(il, i, i) = u(il, nk(il)) vent(il, i, i) = v(il, nk(il)) elij(il, i, i) = clw(il, i) ! MAF sij(il,i,i)=1.0 sij(il, i, i) = 0.0 #ifdef ISO do ixt = 1, ntraciso xtent(ixt,il,i,i)=xt(ixt,il,nk(il))-ep(il,i)*xtclw(ixt,il,i) ! xtent(ixt,il,i,i)=xt(ixt,il,nk(il))-xtep(ixt,il,i)*xtclw(ixt,il,i) ! le 7 mai: on supprime xtep xtelij(ixt,il,i,i)=xtclw(ixt,il,i) ! rq: ne sera pas utilise ensuite enddo !do ixt = 1, ntraciso #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtelij(iso_eau,il,i,i), & & elij(il,i,i),'cv30_mixing 2117',errmax,errmaxrel) endif !if (iso_eau.gt.0) then #endif #ifdef ISOTRAC if (option_tmin.ge.1) then ! colorier la vapeur residuelle selon temperature de ! condensation, et le condensat en un tag specifique ! write(*,*) 'cv3 tmp 2095 il,i,j,xtent(:,il,i,j)=', ! : il,i,j,xtent(:,il,i,j) if ((elij(il,i,i).gt.0.0).and.(qent(il,i,i).gt.0.0)) then if (option_traceurs.eq.17) then call iso_recolorise_condensation(qent(il,i,i), & & elij(il,i,i), & & xt(1,il,nk(il)),xtclw(1,il,i),t(il,i),ep(il,i), & & xtres, & & seuil_tag_tmin) else !if (option_traceurs.eq.17) then call iso_recolorise_condensation(qent(il,i,i), & & elij(il,i,i), & & xt(1,il,nk(il)),xtclw(1,il,i),rs(il,i),ep(il,i), & & xtres, & & seuil_tag_tmin) endif !if (option_traceurs.eq.17) then do ixt=1+niso,ntraciso xtent(ixt,il,i,i)=xtres(ixt) enddo #ifdef ISOVERIF do ixt=1,niso call iso_verif_egalite_choix(xtres(ixt),xtent(ixt,il,i,i), & & 'cv30_routines 2102',errmax,errmaxrel) call iso_verif_trac17_q_deltaD(xtent(1,il,i,j), & & 'cv30_routines 2154') enddo #endif endif !if (cond.gt.0.0) then #ifdef ISOVERIF call iso_verif_egalite_choix(xtent(iso_eau,il,i,i), & & qent(il,i,i),'cv30_routines 2103',errmax,errmaxrel) call iso_verif_traceur(xtent(1,il,i,i),'cv30_routines 2095') call iso_verif_traceur(xtelij(1,il,i,i),'cv30_routines 2096') #endif endif !if (option_tmin.ge.1) then #endif #endif END IF END DO END DO ! do j=1,ntra ! do i=minorig+1,nl ! do il=1,ncum ! if (i.ge.icb(il) .and. i.le.inb(il) .and. nent(il,i).eq.0) then ! traent(il,i,i,j)=tra(il,nk(il),j) ! endif ! enddo ! enddo ! enddo DO j = minorig, nl DO i = minorig, nl DO il = 1, ncum IF ((j>=(icb(il)-1)) .AND. (j<=inb(il)) .AND. (i>=icb(il)) .AND. (i<= & inb(il))) THEN sigij(il, i, j) = sij(il, i, j) END IF END DO END DO END DO ! @ enddo ! @170 continue ! ===================================================================== ! --- NORMALIZE ENTRAINED AIR MASS FLUXES ! --- TO REPRESENT EQUAL PROBABILITIES OF MIXING ! ===================================================================== ! ym call zilch(asum,ncum*nd) ! ym call zilch(bsum,ncum*nd) ! ym call zilch(csum,ncum*nd) CALL zilch(asum, nloc*nd) CALL zilch(csum, nloc*nd) CALL zilch(csum, nloc*nd) DO il = 1, ncum lwork(il) = .FALSE. END DO DO i = minorig + 1, nl num1 = 0 DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il)) num1 = num1 + 1 END DO IF (num1<=0) GO TO 789 DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il)) THEN lwork(il) = (nent(il,i)/=0) qp = rr(il, 1) - ep(il, i)*clw(il, i) anum = h(il, i) - hp(il, i) - lv(il, i)*(qp-rs(il,i)) + & (cpv-cpd)*t(il, i)*(qp-rr(il,i)) denom = h(il, i) - hp(il, i) + lv(il, i)*(rr(il,i)-qp) + & (cpd-cpv)*t(il, i)*(rr(il,i)-qp) IF (abs(denom)<0.01) denom = 0.01 scrit(il) = anum/denom alt = qp - rs(il, i) + scrit(il)*(rr(il,i)-qp) IF (scrit(il)<=0.0 .OR. alt<=0.0) scrit(il) = 1.0 smax(il) = 0.0 asij(il) = 0.0 END IF END DO DO j = nl, minorig, -1 num2 = 0 DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. j>=(icb( & il)-1) .AND. j<=inb(il) .AND. lwork(il)) num2 = num2 + 1 END DO IF (num2<=0) GO TO 175 DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. j>=(icb( & il)-1) .AND. j<=inb(il) .AND. lwork(il)) THEN IF (sij(il,i,j)>1.0E-16 .AND. sij(il,i,j)<0.95) THEN wgh = 1.0 IF (j>i) THEN sjmax = amax1(sij(il,i,j+1), smax(il)) sjmax = amin1(sjmax, scrit(il)) smax(il) = amax1(sij(il,i,j), smax(il)) sjmin = amax1(sij(il,i,j-1), smax(il)) sjmin = amin1(sjmin, scrit(il)) IF (sij(il,i,j)<(smax(il)-1.0E-16)) wgh = 0.0 smid = amin1(sij(il,i,j), scrit(il)) ELSE sjmax = amax1(sij(il,i,j+1), scrit(il)) smid = amax1(sij(il,i,j), scrit(il)) sjmin = 0.0 IF (j>1) sjmin = sij(il, i, j-1) sjmin = amax1(sjmin, scrit(il)) END IF delp = abs(sjmax-smid) delm = abs(sjmin-smid) asij(il) = asij(il) + wgh*(delp+delm) ment(il, i, j) = ment(il, i, j)*(delp+delm)*wgh END IF END IF END DO 175 END DO DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il)) THEN asij(il) = amax1(1.0E-16, asij(il)) asij(il) = 1.0/asij(il) asum(il, i) = 0.0 bsum(il, i) = 0.0 csum(il, i) = 0.0 END IF END DO DO j = minorig, nl DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il) .AND. j>=(icb( & il)-1) .AND. j<=inb(il)) THEN ment(il, i, j) = ment(il, i, j)*asij(il) END IF END DO END DO DO j = minorig, nl DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il) .AND. j>=(icb( & il)-1) .AND. j<=inb(il)) THEN asum(il, i) = asum(il, i) + ment(il, i, j) ment(il, i, j) = ment(il, i, j)*sig(il, j) bsum(il, i) = bsum(il, i) + ment(il, i, j) END IF END DO END DO DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il)) THEN bsum(il, i) = amax1(bsum(il,i), 1.0E-16) bsum(il, i) = 1.0/bsum(il, i) END IF END DO DO j = minorig, nl DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il) .AND. j>=(icb( & il)-1) .AND. j<=inb(il)) THEN ment(il, i, j) = ment(il, i, j)*asum(il, i)*bsum(il, i) END IF END DO END DO DO j = minorig, nl DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il) .AND. j>=(icb( & il)-1) .AND. j<=inb(il)) THEN csum(il, i) = csum(il, i) + ment(il, i, j) END IF END DO END DO DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. lwork(il) .AND. & csum(il,i)>> DO i = 1, nd DO il = 1, ncum wdtraina(il, i) = 0.0 wdtrainm(il, i) = 0.0 END DO END DO ! ! RomP <<< ! *** check whether ep(inb)=0, if so, skip precipitating *** ! *** downdraft calculation *** DO il = 1, ncum lwork(il) = .TRUE. IF (ep(il,inb(il))<0.0001) lwork(il) = .FALSE. END DO CALL zilch(wdtrain, ncum) #ifdef ISO call zilch(xtwdtrain,ncum*ntraciso) #endif DO i = nl + 1, 1, -1 num1 = 0 DO il = 1, ncum IF (i<=inb(il) .AND. lwork(il)) num1 = num1 + 1 END DO IF (num1<=0) GO TO 400 ! *** integrate liquid water equation to find condensed water *** ! *** and condensed water flux *** ! *** begin downdraft loop *** ! *** calculate detrained precipitation *** DO il = 1, ncum IF (i<=inb(il) .AND. lwork(il)) THEN IF (cvflag_grav) THEN wdtrain(il) = grav*ep(il, i)*m(il, i)*clw(il, i) wdtraina(il, i) = wdtrain(il)/grav ! Pa 26/08/10 RomP #ifdef ISO do ixt=1,ntraciso ! xtwdtrain(ixt,il)=grav*xtep(ixt,il,i)*m(il,i)*xtclw(ixt,il,i) xtwdtrain(ixt,il)=grav*ep(il,i)*m(il,i)*xtclw(ixt,il,i) enddo !--debug: #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtwdtrain(iso_eau,il), & & wdtrain(il),'cv30_routines 2313',errmax,errmaxrel) endif !if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur(xtwdtrain(1,il),'cv30_routine 2480') #endif #endif !--end debug #endif ELSE wdtrain(il) = 10.0*ep(il, i)*m(il, i)*clw(il, i) wdtraina(il, i) = wdtrain(il)/10. ! Pa 26/08/10 RomP #ifdef ISO do ixt=1,ntraciso ! xtwdtrain(ixt,il)=10.0*xtep(ixt,il,i)*m(il,i)*xtclw(ixt,il,i) xtwdtrain(ixt,il)=10.0*ep(il,i)*m(il,i)*xtclw(ixt,il,i) xtwdtraina(ixt,il, i) = xtwdtrain(ixt,il)/10. enddo #endif END IF END IF END DO IF (i>1) THEN DO j = 1, i - 1 DO il = 1, ncum IF (i<=inb(il) .AND. lwork(il)) THEN awat = elij(il, j, i) - (1.-ep(il,i))*clw(il, i) awat = amax1(awat, 0.0) #ifdef ISO ! precip mixed drafts computed from: xtawat/xtelij = awat/elij if (elij(il,j,i).ne.0.0) then do ixt=1,ntraciso xtawat(ixt)=xtelij(ixt,il,j,i)*(awat/elij(il,j,i)) xtawat(ixt)=amax1(xtawat(ixt),0.0) enddo !! xtawat(ixt)=amin1(xtawat(ixt),xtelij(ixt,il,j,i)) !security.. else do ixt=1,ntraciso xtawat(ixt)=0.0 enddo !do ixt=1,niso endif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtawat(iso_eau), & & awat,'cv30_routines 2391',errmax,errmaxrel) endif !if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur(xtawat(1),'cv30_routine 2522') #endif #endif #endif IF (cvflag_grav) THEN wdtrain(il) = wdtrain(il) + grav*awat*ment(il, j, i) #ifdef ISO do ixt=1,ntraciso xtwdtrain(ixt,il)=xtwdtrain(ixt,il) & & +grav*xtawat(ixt)*ment(il,j,i) enddo !do ixt=1,ntraciso #endif ELSE wdtrain(il) = wdtrain(il) + 10.0*awat*ment(il, j, i) #ifdef ISO do ixt=1,ntraciso xtwdtrain(ixt,il)=xtwdtrain(ixt,il) & & +10.0*xtawat(ixt)*ment(il,j,i) enddo !!do ixt=1,ntraciso #endif END IF !if (cvflag_grav) then #ifdef ISO !--debug: #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtwdtrain(iso_eau,il), & & wdtrain(il),'cv30_routines 2366',errmax,errmaxrel) endif !if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur(xtwdtrain(1,il),'cv30_routine 2540') if (option_cond.ge.1) then ! on verifie que tout le detrainement est tagge condensat if (iso_verif_positif_nostop( & & xtwdtrain(itZonIso(izone_cond,iso_eau),il) & & -xtwdtrain(iso_eau,il), & & 'cv30_routines 2795').eq.1) then write(*,*) 'xtwdtrain(:,il)=',xtwdtrain(:,il) write(*,*) 'xtelij(:,il,j,i)=',xtelij(:,il,j,i) write(*,*) 'xtclw(:,il,i)=',xtclw(:,il,i) stop endif !if (iso_verif_positif_nostop(Pxtisup(iso_eau,il)- endif !if (option_cond.ge.1) then #endif #endif #endif END IF !IF (i<=inb(il) .AND. lwork(il)) THEN END DO END DO DO il = 1, ncum IF (cvflag_grav) THEN wdtrainm(il, i) = wdtrain(il)/grav - wdtraina(il, i) ! Pm 26/08/10 RomP ELSE wdtrainm(il, i) = wdtrain(il)/10. - wdtraina(il, i) ! Pm 26/08/10 RomP END IF END DO END IF ! *** find rain water and evaporation using provisional *** ! *** estimates of rp(i)and rp(i-1) *** DO il = 1, ncum IF (i<=inb(il) .AND. lwork(il)) THEN wt(il, i) = 45.0 IF (iph(i), pr1=1 & pr2=0 ! pour ph(i+1)0.0) THEN revap = 0.5*(-b6+sqrt(b6*b6+4.*c6)) evap(il, i) = sigt*afac*revap water(il, i) = revap*revap ELSE evap(il, i) = -evap(il, i+1) + 0.02*(wdtrain(il)+sigd*wt(il,i)* & water(il,i+1))/(sigd*(ph(il,i)-ph(il,i+1))) END IF #ifdef ISO ! ajout cam: eviter les evaporations ou eaux negatives ! water(il,i)=max(0.0,water(il,i)) ! ceci est toujours verifie #ifdef ISOVERIF call iso_verif_positif(water(il,i),'cv30_unsat 2376') #endif ! evap(il,i)=max(0.0,evap(il,i)) ! evap<0 permet la conservation de ! l'eau ! fin ajout cam #endif ! *** calculate precipitating downdraft mass flux under *** ! *** hydrostatic approximation *** IF (i/=1) THEN tevap = amax1(0.0, evap(il,i)) delth = amax1(0.001, (th(il,i)-th(il,i-1))) IF (cvflag_grav) THEN mp(il, i) = 100.*ginv*lvcp(il, i)*sigd*tevap*(p(il,i-1)-p(il,i))/ & delth ELSE mp(il, i) = 10.*lvcp(il, i)*sigd*tevap*(p(il,i-1)-p(il,i))/delth END IF ! *** if hydrostatic assumption fails, *** ! *** solve cubic difference equation for downdraft theta *** ! *** and mass flux from two simultaneous differential eqns *** amfac = sigd*sigd*70.0*ph(il, i)*(p(il,i-1)-p(il,i))* & (th(il,i)-th(il,i-1))/(tv(il,i)*th(il,i)) amp2 = abs(mp(il,i+1)*mp(il,i+1)-mp(il,i)*mp(il,i)) IF (amp2>(0.1*amfac)) THEN xf = 100.0*sigd*sigd*sigd*(ph(il,i)-ph(il,i+1)) tf = b(il, i) - 5.0*(th(il,i)-th(il,i-1))*t(il, i)/(lvcp(il,i)* & sigd*th(il,i)) af = xf*tf + mp(il, i+1)*mp(il, i+1)*tinv bf = 2.*(tinv*mp(il,i+1))**3 + tinv*mp(il, i+1)*xf*tf + & 50.*(p(il,i-1)-p(il,i))*xf*tevap fac2 = 1.0 IF (bf<0.0) fac2 = -1.0 bf = abs(bf) ur = 0.25*bf*bf - af*af*af*tinv*tinv*tinv IF (ur>=0.0) THEN sru = sqrt(ur) fac = 1.0 IF ((0.5*bf-sru)<0.0) fac = -1.0 mp(il, i) = mp(il, i+1)*tinv + (0.5*bf+sru)**tinv + & fac*(abs(0.5*bf-sru))**tinv ELSE d = atan(2.*sqrt(-ur)/(bf+1.0E-28)) IF (fac2<0.0) d = 3.14159 - d mp(il, i) = mp(il, i+1)*tinv + 2.*sqrt(af*tinv)*cos(d*tinv) END IF mp(il, i) = amax1(0.0, mp(il,i)) IF (cvflag_grav) THEN ! jyg : il y a vraisemblablement une erreur dans la ligne 2 ! suivante: ! il faut diviser par (mp(il,i)*sigd*grav) et non par ! (mp(il,i)+sigd*0.1). ! Et il faut bien revoir les facteurs 100. b(il, i-1) = b(il, i) + 100.0*(p(il,i-1)-p(il,i))*tevap/(mp(il, & i)+sigd*0.1) - 10.0*(th(il,i)-th(il,i-1))*t(il, i)/(lvcp(il,i & )*sigd*th(il,i)) ELSE b(il, i-1) = b(il, i) + 100.0*(p(il,i-1)-p(il,i))*tevap/(mp(il, & i)+sigd*0.1) - 10.0*(th(il,i)-th(il,i-1))*t(il, i)/(lvcp(il,i & )*sigd*th(il,i)) END IF b(il, i-1) = amax1(b(il,i-1), 0.0) END IF ! *** limit magnitude of mp(i) to meet cfl condition ! *** ampmax = 2.0*(ph(il,i)-ph(il,i+1))*delti amp2 = 2.0*(ph(il,i-1)-ph(il,i))*delti ampmax = amin1(ampmax, amp2) mp(il, i) = amin1(mp(il,i), ampmax) ! *** force mp to decrease linearly to zero ! *** ! *** between cloud base and the surface ! *** IF (p(il,i)>p(il,icb(il))) THEN mp(il, i) = mp(il, icb(il))*(p(il,1)-p(il,i))/ & (p(il,1)-p(il,icb(il))) END IF END IF ! i.eq.1 ! *** find mixing ratio of precipitating downdraft *** IF (i/=inb(il)) THEN rp(il, i) = rr(il, i) IF (mp(il,i)>mp(il,i+1)) THEN IF (cvflag_grav) THEN rp(il, i) = rp(il, i+1)*mp(il, i+1) + & rr(il, i)*(mp(il,i)-mp(il,i+1)) + 100.*ginv*0.5*sigd*(ph(il,i & )-ph(il,i+1))*(evap(il,i+1)+evap(il,i)) ELSE rp(il, i) = rp(il, i+1)*mp(il, i+1) + & rr(il, i)*(mp(il,i)-mp(il,i+1)) + 5.*sigd*(ph(il,i)-ph(il,i+1 & ))*(evap(il,i+1)+evap(il,i)) END IF rp(il, i) = rp(il, i)/mp(il, i) up(il, i) = up(il, i+1)*mp(il, i+1) + u(il, i)*(mp(il,i)-mp(il,i+ & 1)) up(il, i) = up(il, i)/mp(il, i) vp(il, i) = vp(il, i+1)*mp(il, i+1) + v(il, i)*(mp(il,i)-mp(il,i+ & 1)) vp(il, i) = vp(il, i)/mp(il, i) ! do j=1,ntra ! trap(il,i,j)=trap(il,i+1,j)*mp(il,i+1) ! testmaf : +trap(il,i,j)*(mp(il,i)-mp(il,i+1)) ! : +tra(il,i,j)*(mp(il,i)-mp(il,i+1)) ! trap(il,i,j)=trap(il,i,j)/mp(il,i) ! end do ELSE IF (mp(il,i+1)>1.0E-16) THEN IF (cvflag_grav) THEN rp(il, i) = rp(il, i+1) + 100.*ginv*0.5*sigd*(ph(il,i)-ph(il, & i+1))*(evap(il,i+1)+evap(il,i))/mp(il, i+1) ELSE rp(il, i) = rp(il, i+1) + 5.*sigd*(ph(il,i)-ph(il,i+1))*(evap & (il,i+1)+evap(il,i))/mp(il, i+1) END IF up(il, i) = up(il, i+1) vp(il, i) = vp(il, i+1) ! do j=1,ntra ! trap(il,i,j)=trap(il,i+1,j) ! end do END IF END IF #ifdef ISO rpprec(il,i)=max(rp(il,i),0.0) #endif rp(il, i) = amin1(rp(il,i), rs(il,i)) rp(il, i) = amax1(rp(il,i), 0.0) END IF END IF END DO #ifdef ISO #ifdef ISOVERIF ! verif des inputs a appel stewart ! write(*,*) 'cv30_routines 2842 tmp: appel de appel_stewart' do il=1,ncum if (i.le.inb(il) .and. lwork(il)) then if (iso_eau.gt.0) then call iso_verif_egalite_choix(xt(iso_eau,il,i), & & rr(il,i),'appel_stewart 262, cas 1.1',errmax,errmaxrel) endif !if (iso_eau.gt.0) then !#ifdef ISOTRAC ! if (option_tmin.ge.1) then ! call iso_verif_positif(xtwater( ! : itZonIso(izone_cond,iso_eau),il,i+1) ! : -xtwater(iso_eau,il,i+1), ! : 'cv30_routines 3083') ! endif !if (option_tmin.ge.1) then !#endif endif enddo #endif if (1.eq.0) then ! appel de appel_stewart_vectorise call appel_stewart_vectall(lwork,ncum, & & ph,t,evap,xtwdtrain, & & wdtrain, & & water,rr,xt,rs,rpprec,mp,wt, & ! inputs physiques & xtwater,xtp, & ! outputs indispensables & xtevap, & ! diagnostiques & sigd, & ! inputs tunables & i,inb, & ! altitude: car cas particulier en INB & na,nd,nloc,cvflag_grav,ginv,1e-16) else !if (1.eq.0) then ! truc simple sans fractionnement ! juste pour debuggage call appel_stewart_debug(lwork,nloc,inb,na,i, & evap,water,rpprec,rr,wdtrain, & xtevap,xtwater,xtp,xt,xtwdtrain) endif ! if (1.eq.0) then #ifdef ISOVERIF ! write(*,*) 'cv30_routines 2864 tmp: sortie de appel_stewart' ! verif des outputs de appel stewart do il=1,ncum if (i.le.inb(il) .and. lwork(il)) then do ixt=1,ntraciso call iso_verif_noNAN(xtp(ixt,il,i),'cv30_unsat 3382') call iso_verif_noNAN(xtwater(ixt,il,i),'cv30_unsat 3381') call iso_verif_noNAN(xtevap(ixt,il,i),'cv30_unsat 2661') enddo if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtp(iso_eau,il,i), & & rpprec(il,i),'cv30_unsat 2736',errmax,errmaxrel) call iso_verif_egalite_choix(xtwater(iso_eau,il,i), & & water(il,i),'cv30_unsat 2747',errmax,errmaxrel) ! write(*,*) 'xtwater(4,il,i)=',xtwater(4,il,i) ! write(*,*) 'water(il,i)=',water(il,i) call iso_verif_egalite_choix(xtevap(iso_eau,il,i), & & evap(il,i),'cv30_unsat 2751',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and. & & (rp(il,i).gt.ridicule)) then call iso_verif_aberrant(xtp(iso_HDO,il,i)/rpprec(il,i), & & 'cv3unsat 2756') endif !if ((iso_HDO.gt.0).and. #ifdef ISOTRAC ! if (il.eq.602) then ! write(*,*) 'cv30_routine tmp: il,i=',il,i ! write(*,*) 'xtp(iso_eau:ntraciso:3,il,i)=', ! : xtp(iso_eau:ntraciso:3,il,i) ! endif call iso_verif_traceur(xtp(1,il,i),'cv30_routine 2852') call iso_verif_traceur(xtwater(1,il,1), & & 'cv30_routine 2853 unsat apres appel') call iso_verif_traceur_pbidouille(xtwater(1,il,i), & & 'cv30_routine 2853b') call iso_verif_traceur_justmass(xtevap(1,il,i), & & 'cv30_routine 2854') ! if (option_tmin.ge.1) then ! call iso_verif_positif(xtwater( ! : itZonIso(izone_cond,iso_eau),il,i) ! : -xtwater(iso_eau,il,i), ! : 'cv30_routines 3143') ! endif !if (option_tmin.ge.1) then #endif endif !if (i.le.inb(il) .and. lwork(il)) then enddo !do il=1,ncum #endif ! equivalent isotopique de rp(il,i)=amin1(rp(il,i),rs(il,i)) do il=1,ncum if (i.lt.inb(il) .and. lwork(il)) then if (rpprec(il,i).gt.rs(il,i)) then if (rs(il,i).le.0) then write(*,*) 'cv3unsat 2640' stop endif do ixt=1,ntraciso xtp(ixt,il,i)=xtp(ixt,il,i)/rpprec(il,i)*rs(il,i) xtp(ixt,il,i)=max(0.0,xtp(ixt,il,i)) enddo !do ixt=1,niso #ifdef ISOVERIF do ixt=1,ntraciso call iso_verif_noNaN(xtp(ixt,il,i),'cv3unsat 2641') enddo !do ixt=1,niso if (iso_eau.gt.0) then ! write(*,*) 'xtp(iso_eau,il,i)=',xtp(iso_eau,il,i) call iso_verif_egalite_choix(xtp(iso_eau,il,i),rp(il,i), & & 'cv3unsat 2653',errmax,errmaxrel) call iso_verif_egalite_choix(xtp(iso_eau,il,i), & & rs(il,i),'cv3unsat 2654',errmax,errmaxrel) endif if ((iso_HDO.gt.0).and. & & (rp(il,i).gt.ridicule)) then if (iso_verif_aberrant_nostop(xtp(iso_HDO,il,i)/rp(il,i), & & 'cv3unsat 2658').eq.1) then write(*,*) 'rpprec(il,i),rs(il,i),rp(il,i)=', & & rpprec(il,i),rs(il,i),rp(il,i) stop endif endif #ifdef ISOTRAC call iso_verif_traceur(xtp(1,il,i),'cv30_routine 2893') #endif #endif rpprec(il,i)=rs(il,i) endif !if (rp(il,i).gt.rs(il,i)) then endif !if (i.lt.INB et lwork) enddo ! il=1,ncum #endif 400 END DO ! fin de la boucle en i (altitude) #ifdef ISO write(*,*) 'nl=',nl,'nd=',nd,'; ncum=',ncum #ifdef ISOVERIF do i=1,nl !nl do il=1,ncum if (iso_eau.gt.0) then ! write(*,*) 'cv30_routines 2767:i,il,lwork(il),inb(il)=', ! : i,il,lwork(il),inb(il) ! write(*,*) 'rp(il,i),xtp(iso_eau,il,i)=', ! : rp(il,i),xtp(iso_eau,il,i) call iso_verif_egalite_choix(xt(iso_eau,il,i), & & rr(il,i),'cv30_unsat 2668',errmax,errmaxrel) call iso_verif_egalite_choix(xtp(iso_eau,il,i), & & rp(il,i),'cv30_unsat 2670',errmax,errmaxrel) call iso_verif_egalite_choix(xtwater(iso_eau,il,i), & & water(il,i),'cv30_unsat 2672',errmax,errmaxrel) endif !if (iso_eau.gt.0) then !#ifdef ISOTRAC ! if (iso_verif_traceur_choix_nostop(xtwater(1,il,i), ! : 'cv30_routine 2982 unsat',errmax, ! : errmaxrel,ridicule_trac,deltalimtrac).eq.1) then ! write(*,*) 'il,i,inb(il),lwork(il)=', ! : il,i,inb(il),lwork(il) ! write(*,*) 'xtwater(:,il,i)=',xtwater(:,il,i) ! stop ! endif !#endif enddo !do il=1,nloc!ncum enddo !do i=1,nl!nl il=5 i=39 write(*,*) 'cv30_unsat 2780: il,water(il,i),xtwater(iso_eau,il,i)=' & ,il,water(il,i),xtwater(iso_eau,il,i) #endif #endif RETURN END SUBROUTINE cv30_unsat SUBROUTINE cv30_yield(nloc, ncum, nd, na, ntra, icb, inb, delt, t, rr, u, v, & tra, gz, p, ph, h, hp, lv, cpn, th, ep, clw, m, tp, mp, rp, up, vp, trap, & wt, water, evap, b, ment, qent, uent, vent, nent, elij, traent, sig, tv, & tvp, iflag, precip, vprecip, ft, fr, fu, fv, ftra, upwd, dnwd, dnwd0, ma, & mike, tls, tps, qcondc, wd & #ifdef ISO & ,xt,xtclw,xtp,xtwater,xtevap & & ,xtent,xtelij,xtprecip,fxt,xtVprecip & #ifdef DIAGISO & ,fq_detrainement,fq_ddft,fq_fluxmasse,fq_evapprecip & & ,fxt_detrainement,fxt_ddft,fxt_fluxmasse,fxt_evapprecip & & ,f_detrainement,q_detrainement,xt_detrainement & #endif #endif & ) #ifdef ISO use infotrac_phy, ONLY: ntraciso=>ntiso, niso, nzone, itZonIso use isotopes_mod, ONLY: essai_convergence,ridicule,iso_eau,iso_HDO,iso_O18 #ifdef ISOVERIF use isotopes_verif_mod, ONLY: errmax,errmaxrel, & iso_verif_egalite_choix, iso_verif_noNaN,iso_verif_aberrant, & iso_verif_egalite,iso_verif_egalite_choix_nostop,iso_verif_positif_nostop, & iso_verif_egalite_nostop,iso_verif_aberrant_nostop,deltaD,iso_verif_noNaN_nostop, & iso_verif_positif,iso_verif_egalite_vect2D, & iso_verif_aberrant_enc_nostop,iso_verif_aberrant_encadre,iso_verif_o18_aberrant, & iso_verif_O18_aberrant_nostop,deltaO #endif #ifdef ISOTRAC use isotrac_mod, only: option_traceurs, & izone_revap,izone_poubelle,izone_ddft #ifdef ISOVERIF use isotopes_verif_mod, ONLY: iso_verif_traceur_choix_nostop,deltalimtrac, & & iso_verif_tracpos_choix_nostop,iso_verif_traceur,iso_verif_traceur_justmass use isotrac_mod, only: ridicule_trac #endif #endif #endif IMPLICIT NONE include "cvthermo.h" include "cv30param.h" include "cvflag.h" include "conema3.h" ! inputs: INTEGER ncum, nd, na, ntra, nloc INTEGER icb(nloc), inb(nloc) REAL delt REAL t(nloc, nd), rr(nloc, nd), u(nloc, nd), v(nloc, nd) REAL tra(nloc, nd, ntra), sig(nloc, nd) REAL gz(nloc, na), ph(nloc, nd+1), h(nloc, na), hp(nloc, na) REAL th(nloc, na), p(nloc, nd), tp(nloc, na) REAL lv(nloc, na), cpn(nloc, na), ep(nloc, na), clw(nloc, na) REAL m(nloc, na), mp(nloc, na), rp(nloc, na), up(nloc, na) REAL vp(nloc, na), wt(nloc, nd), trap(nloc, nd, ntra) REAL water(nloc, na), evap(nloc, na), b(nloc, na) REAL ment(nloc, na, na), qent(nloc, na, na), uent(nloc, na, na) ! ym real vent(nloc,na,na), nent(nloc,na), elij(nloc,na,na) REAL vent(nloc, na, na), elij(nloc, na, na) INTEGER nent(nloc, na) REAL traent(nloc, na, na, ntra) REAL tv(nloc, nd), tvp(nloc, nd) #ifdef ISO real xt(ntraciso,nloc,nd) ! real xtep(ntraciso,nloc,na) ! le 7 mai: on supprime xtep real xtclw(ntraciso,nloc,na), xtp(ntraciso,nloc,na) real xtwater(ntraciso,nloc,na), xtevap(ntraciso,nloc,na) real xtent(ntraciso,nloc,na,na), xtelij(ntraciso,nloc,na,na) #ifdef ISOVERIF CHARACTER (LEN=20) :: modname='cv30_compress' CHARACTER (LEN=80) :: abort_message #endif #endif ! input/output: INTEGER iflag(nloc) ! outputs: REAL precip(nloc) REAL vprecip(nloc, nd+1) REAL ft(nloc, nd), fr(nloc, nd), fu(nloc, nd), fv(nloc, nd) REAL ftra(nloc, nd, ntra) REAL upwd(nloc, nd), dnwd(nloc, nd), ma(nloc, nd) REAL dnwd0(nloc, nd), mike(nloc, nd) REAL tls(nloc, nd), tps(nloc, nd) REAL qcondc(nloc, nd) ! cld REAL wd(nloc) ! gust #ifdef ISO real xtprecip(ntraciso,nloc), fxt(ntraciso,nloc,nd) real xtVprecip(ntraciso,nloc,nd+1) #endif ! local variables: INTEGER i, k, il, n, j, num1 REAL rat, awat, delti REAL ax, bx, cx, dx, ex REAL cpinv, rdcp, dpinv REAL lvcp(nloc, na), mke(nloc, na) REAL am(nloc), work(nloc), ad(nloc), amp1(nloc) ! !! real up1(nloc), dn1(nloc) REAL up1(nloc, nd, nd), dn1(nloc, nd, nd) REAL asum(nloc), bsum(nloc), csum(nloc), dsum(nloc) REAL qcond(nloc, nd), nqcond(nloc, nd), wa(nloc, nd) ! cld REAL siga(nloc, nd), sax(nloc, nd), mac(nloc, nd) ! cld #ifdef ISO integer ixt real xtbx(ntraciso), xtawat(ntraciso) ! cam debug ! pour l'homogeneisation sous le nuage: real frsum(nloc), bxtsum(ntraciso,nloc), fxtsum(ntraciso,nloc) ! correction dans calcul tendance liee a Am: real dq_tmp,k_tmp,dx_tmp,R_tmp,dqreste_tmp,dxreste_tmp,kad_tmp logical correction_excess_aberrant parameter (correction_excess_aberrant=.false.) ! correction qui permettait d'eviter deltas et dexcess aberrants. Mais ! pb: ne conserve pas la masse d'isotopes! #ifdef DIAGISO ! diagnostiques juste: tendance des differents processus real fxt_detrainement(ntraciso,nloc,nd) real fxt_fluxmasse(ntraciso,nloc,nd) real fxt_evapprecip(ntraciso,nloc,nd) real fxt_ddft(ntraciso,nloc,nd) real fq_detrainement(nloc,nd) real q_detrainement(nloc,nd) real xt_detrainement(ntraciso,nloc,nd) real f_detrainement(nloc,nd) real fq_fluxmasse(nloc,nd) real fq_evapprecip(nloc,nd) real fq_ddft(nloc,nd) #endif !#ifdef ISOVERIF ! integer iso_verif_aberrant_nostop ! real deltaD !#endif #ifdef ISOTRAC ! integer iso_verif_traceur_choix_nostop ! integer iso_verif_tracpos_choix_nostop real xtnew(ntraciso) ! real conversion(niso) real fxtYe(niso) real fxtqe(niso) real fxtXe(niso) real fxt_revap(niso) real Xe(niso) integer ixt_revap,izone integer ixt_poubelle, ixt_ddft,iiso #endif #endif ! ------------------------------------------------------------- ! initialization: delti = 1.0/delt DO il = 1, ncum precip(il) = 0.0 wd(il) = 0.0 ! gust vprecip(il, nd+1) = 0. #ifdef ISO ! cam debug ! write(*,*) 'cv30_routines 3082: entree dans cv3_yield' ! en cam debug do ixt = 1, ntraciso xtprecip(ixt,il)=0.0 xtVprecip(ixt,il,nd+1)=0.0 enddo #endif END DO DO i = 1, nd DO il = 1, ncum vprecip(il, i) = 0.0 ft(il, i) = 0.0 fr(il, i) = 0.0 fu(il, i) = 0.0 fv(il, i) = 0.0 qcondc(il, i) = 0.0 ! cld qcond(il, i) = 0.0 ! cld nqcond(il, i) = 0.0 ! cld #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)=0.0 xtVprecip(ixt,il,i)=0.0 enddo #ifdef DIAGISO fq_fluxmasse(il,i)=0.0 fq_detrainement(il,i)=0.0 f_detrainement(il,i)=0.0 q_detrainement(il,i)=0.0 fq_evapprecip(il,i)=0.0 fq_ddft(il,i)=0.0 do ixt = 1, niso fxt_fluxmasse(ixt,il,i)=0.0 fxt_detrainement(ixt,il,i)=0.0 xt_detrainement(ixt,il,i)=0.0 fxt_evapprecip(ixt,il,i)=0.0 fxt_ddft(ixt,il,i)=0.0 enddo #endif #endif END DO END DO ! do j=1,ntra ! do i=1,nd ! do il=1,ncum ! ftra(il,i,j)=0.0 ! enddo ! enddo ! enddo DO i = 1, nl DO il = 1, ncum lvcp(il, i) = lv(il, i)/cpn(il, i) END DO END DO ! *** calculate surface precipitation in mm/day *** DO il = 1, ncum IF (ep(il,inb(il))>=0.0001) THEN IF (cvflag_grav) THEN precip(il) = wt(il, 1)*sigd*water(il, 1)*86400.*1000./(rowl*grav) #ifdef ISO do ixt = 1, ntraciso xtprecip(ixt,il)=wt(il,1)*sigd*xtwater(ixt,il,1) & & *86400.*1000./(rowl*grav) ! en mm/jour enddo ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then ! write(*,*) 'cv30_yield 2952: '// ! : 'il,water(il,1),xtwater(iso_eau,il,1)=' ! : ,il,water(il,1),xtwater(iso_eau,il,1) call iso_verif_egalite_choix(xtwater(iso_eau,il,1), & & water(il,1),'cv30_routines 2959', & & errmax,errmaxrel) !Rq: wt(il,1)*sigd*86400.*1000./(rowl*grav)=3964.6565 ! -> on auatorise 3e3 fois plus d'erreur dans precip call iso_verif_egalite_choix(xtprecip(iso_eau,il), & & precip(il),'cv30_routines 3138', & & errmax*4e3,errmaxrel) endif !if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur(xtwater(1,il,1), & & 'cv30_routine 3146') if (iso_verif_traceur_choix_nostop(xtprecip(1,il), & & 'cv30_routine 3147',errmax*1e2, & & errmaxrel,ridicule_trac,deltalimtrac).eq.1) then write(*,*) 'il,inb(il)=',il,inb(il) write(*,*) 'xtwater(:,il,1)=',xtwater(:,il,1) write(*,*) 'xtprecip(:,il)=',xtprecip(:,il) write(*,*) 'fac=',wt(il,1)*sigd*86400.*1000./(rowl*grav) stop endif #endif #endif ! end cam verif #endif ELSE precip(il) = wt(il, 1)*sigd*water(il, 1)*8640. #ifdef ISO do ixt = 1, ntraciso xtprecip(ixt,il)=wt(il,1)*sigd*xtwater(ixt,il,1)*8640. enddo ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtprecip(iso_eau,il), & & precip(il),'cv30_routines 3139', & & errmax,errmaxrel) endif !if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur(xtprecip(1,il),'cv30_routine 3166') #endif #endif ! end cam verif #endif END IF !IF (cvflag_grav) THEN END IF !IF (cvflag_grav) THEN END DO ! *** CALCULATE VERTICAL PROFILE OF PRECIPITATIONs IN kg/m2/s === ! MAF rajout pour lessivage DO k = 1, nl DO il = 1, ncum IF (k<=inb(il)) THEN IF (cvflag_grav) THEN vprecip(il, k) = wt(il, k)*sigd*water(il, k)/grav #ifdef ISO do ixt=1,ntraciso xtVPrecip(ixt,il,k) = wt(il,k)*sigd & & *xtwater(ixt,il,k)/grav enddo #endif ELSE vprecip(il, k) = wt(il, k)*sigd*water(il, k)/10. #ifdef ISO do ixt=1,ntraciso xtVPrecip(ixt,il,k) = wt(il,k)*sigd & & *xtwater(ixt,il,k)/10.0 enddo #endif END IF END IF END DO END DO ! *** Calculate downdraft velocity scale *** ! *** NE PAS UTILISER POUR L'INSTANT *** ! ! do il=1,ncum ! ! wd(il)=betad*abs(mp(il,icb(il)))*0.01*rrd*t(il,icb(il)) ! ! : /(sigd*p(il,icb(il))) ! ! enddo ! *** calculate tendencies of lowest level potential temperature *** ! *** and mixing ratio *** DO il = 1, ncum work(il) = 1.0/(ph(il,1)-ph(il,2)) am(il) = 0.0 END DO DO k = 2, nl DO il = 1, ncum IF (k<=inb(il)) THEN am(il) = am(il) + m(il, k) END IF END DO END DO DO il = 1, ncum ! convect3 if((0.1*dpinv*am).ge.delti)iflag(il)=4 IF (cvflag_grav) THEN IF ((0.01*grav*work(il)*am(il))>=delti) iflag(il) = 1 !consist vect ft(il, 1) = 0.01*grav*work(il)*am(il)*(t(il,2)-t(il,1)+(gz(il,2)-gz(il, & 1))/cpn(il,1)) ELSE IF ((0.1*work(il)*am(il))>=delti) iflag(il) = 1 !consistency vect ft(il, 1) = 0.1*work(il)*am(il)*(t(il,2)-t(il,1)+(gz(il,2)-gz(il, & 1))/cpn(il,1)) END IF ft(il, 1) = ft(il, 1) - 0.5*lvcp(il, 1)*sigd*(evap(il,1)+evap(il,2)) IF (cvflag_grav) THEN ft(il, 1) = ft(il, 1) - 0.009*grav*sigd*mp(il, 2)*t(il, 1)*b(il, 1)* & work(il) ELSE ft(il, 1) = ft(il, 1) - 0.09*sigd*mp(il, 2)*t(il, 1)*b(il, 1)*work(il) END IF ft(il, 1) = ft(il, 1) + 0.01*sigd*wt(il, 1)*(cl-cpd)*water(il, 2)*(t(il,2 & )-t(il,1))*work(il)/cpn(il, 1) IF (cvflag_grav) THEN ! jyg1 Correction pour mieux conserver l'eau (conformite avec ! CONVECT4.3) ! (sb: pour l'instant, on ne fait que le chgt concernant grav, pas ! evap) fr(il, 1) = 0.01*grav*mp(il, 2)*(rp(il,2)-rr(il,1))*work(il) + & sigd*0.5*(evap(il,1)+evap(il,2)) ! +tard : +sigd*evap(il,1) fr(il, 1) = fr(il, 1) + 0.01*grav*am(il)*(rr(il,2)-rr(il,1))*work(il) #ifdef ISO ! juste Mp et evap pour l'instant, voir plus bas pour am do ixt = 1, ntraciso fxt(ixt,il,1)= & & 0.01*grav*mp(il,2)*(xtp(ixt,il,2)-xt(ixt,il,1))*work(il) & & +sigd*0.5*(xtevap(ixt,il,1)+xtevap(ixt,il,2)) !c+tard : +sigd*xtevap(ixt,il,1) enddo !do ixt = 1, ntraciso ! pour water tagging option 6: pas besoin ici de faire de conversion. #ifdef DIAGISO fq_ddft(il,1)=fq_ddft(il,1) & & +0.01*grav*mp(il,2)*(rp(il,2)-rr(il,1))*work(il) fq_evapprecip(il,1)=fq_evapprecip(il,1) & & +sigd*0.5*(evap(il,1)+evap(il,2)) fq_fluxmasse(il,1)=fq_fluxmasse(il,1) & & +0.01*grav*am(il)*(rr(il,2)-rr(il,1))*work(il) do ixt = 1, ntraciso ! fxt_fluxmasse(ixt,il,1)=fxt_fluxmasse(ixt,il,1) & ! & +0.01*grav*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il) ! deplace ! plus haut car il existe differents cas fxt_ddft(ixt,il,1)=fxt_ddft(ixt,il,1) & & +0.01*grav*mp(il,2)*(xtp(ixt,il,2)-xt(ixt,il,1))*work(il) fxt_evapprecip(ixt,il,1)=fxt_evapprecip(ixt,il,1) & & +sigd*0.5*(xtevap(ixt,il,1)+xtevap(ixt,il,2)) enddo #endif ! pour l'ajout de la tendance liee au flux de masse Am, il faut etre ! prudent. ! On a dq1=k*(q2-q1) avec k=dt*0.01*grav*am(il)*work(il) ! Pour les isotopes, la formule utilisee depuis 2006 et qui avait toujours marche est: ! dx1=k*(x2-x1) ! Mais on plante dans un cas pathologique en decembre 2017 lors du test ! d'un cas d'Anne Cozic: les isotopes deviennent negatifs. ! C'est un cas pas physique: on perd 99% de la masse de vapeur d'eau! ! q2=1.01e-3 et q1=1.25e-3 kg/kg ! et dq=-1.24e-3: comment est-ce possible qu'un flux venant d'un air a ! q2= 1.01e-3 asseche q1 jusqu'a 0.01e-3kg/kg! ! Pour les isotopes, ca donne des x1+dx negatifs. ! Ce n'est pas physique mais il faut quand meme s'adapter. ! Pour cela, on considere que d'abord on fait rentrer le flux de masse ! descendant, et ensuite seulement on fait sortir le flux de masse ! sortant. ! Ainsi, le flux de masse sortant ne modifie pas la composition ! isotopique de la vapeur d'eau q1. ! A la fin, on a R=(x1+dx)/(q1+dq)=(x1+k*x2)/(q1+k*q2) ! On verifie que quand k est petit, on tend vers la formulation ! habituelle. ! Comme on est habitues a la formulation habituelle, qu'elle a fait ses ! preuves, on la garde sauf dans le cas ou dq/q<-0.9 ou on utilise la ! nouvelle formulation. ! rappel: dq_tmp=0.01*grav*am(il)*(rr(il,2)-rr(il,1))*work(il)*delt ! Meme avec cette nouvelle foirmulation, on a encore des isotopes ! negatifs, cette fois a cause des ddfts ! On considere donc les tendances et serie et non en parallele quand on ! calcule R_tmp. dq_tmp=0.01*grav*am(il)*(rr(il,2)-rr(il,1))*work(il)*delt ! utile ci-dessous if ((dq_tmp/rr(il,1).lt.-0.9).and.correction_excess_aberrant) then ! nouvelle formulation ou on fait d'abord entrer k*q2 et ensuite ! seulement on fait sortir k*q1 sans changement de composition ! isotopique k_tmp=0.01*grav*am(il)*work(il)*delt dqreste_tmp= 0.01*grav*mp(il, 2)*(rp(il,2)-rr(il,1))*work(il)*delt + & & sigd*0.5*(evap(il,1)+evap(il,2))*delt do ixt = 1, ntraciso dxreste_tmp= 0.01*grav*mp(il,2)*(xtp(ixt,il,2)-xt(ixt,il,1))*work(il)*delt & & +sigd*0.5*(xtevap(ixt,il,1)+xtevap(ixt,il,2))*delt R_tmp=(xt(ixt,il,1)+dxreste_tmp+k_tmp*xt(ixt,il,2))/(rr(il,1)+dqreste_tmp+k_tmp*rr(il,2)) dx_tmp=R_tmp*(rr(il,1)+dqreste_tmp+dq_tmp)-(xt(ixt,il,1)+dxreste_tmp) fxt(ixt,il,1)=fxt(ixt,il,1) & & + dx_tmp/delt #ifdef ISOVERIF if (ixt.eq.iso_HDO) then write(*,*) 'cv30_routines 3888: il=',il write(*,*) 'dq_tmp,rr(il,1)=',dq_tmp,rr(il,1) write(*,*) 'R_tmp,dx_tmp,delt=',R_tmp,dx_tmp,delt write(*,*) 'xt(ixt,il,1:2)=',xt(ixt,il,1:2) write(*,*) 'rr(il,1:2)=',rr(il,1:2) write(*,*) 'fxt=',dx_tmp/delt write(*,*) 'rr(il,1)+dq_tmp=',rr(il,1)+dq_tmp write(*,*) 'xt(ixt,il,1)+dx_tmp=',xt(ixt,il,1)+dx_tmp write(*,*) 'xt(ixt,il,1)+fxt(ixt,il,1)*delt=', & & xt(ixt,il,1)+fxt(ixt,il,1)*delt write(*,*) 'dqreste_tmp,dxreste_tmp=',dqreste_tmp,dxreste_tmp write(*,*) 'formule classique: fxt_Am=',0.01*grav*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il) write(*,*) 'donnerait dxt=',0.01*grav*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il)*delt endif !if (ixt.eq.iso_HDO) then #endif #ifdef DIAGISO if (ixt.le.niso) then fxt_fluxmasse(ixt,il,1)=fxt_fluxmasse(ixt,il,1) & & + dx_tmp/delt endif #endif enddo ! do ixt = 1, ntraciso else !if (dq_tmp/rr(il,1).lt.-0.9) then ! formulation habituelle qui avait toujours marche de 2006 a ! decembre 2017. do ixt = 1, ntraciso fxt(ixt,il,1)=fxt(ixt,il,1) & & +0.01*grav*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il) #ifdef DIAGISO if (ixt.le.niso) then fxt_fluxmasse(ixt,il,1)=fxt_fluxmasse(ixt,il,1) & & +0.01*grav*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il) endif #endif enddo !do ixt = 1, ntraciso endif !if (dq_tmp/rr(il,1).lt.-0.9) then ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,1), & & fr(il,1),'cv30_routines 3251', & & errmax,errmaxrel) endif !if (iso_eau.gt.0) then !write(*,*) 'il,am(il)=',il,am(il) if ((iso_HDO.gt.0).and. & & (rr(il,1)+delt*fr(il,1).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop((xt(iso_HDO,il,1) & & +delt*fxt(iso_HDO,il,1))/(rr(il,1)+delt*fr(il,1)), & & 'cv30_yield 3125, ddft en 1').eq.1) then write(*,*) 'il,rr(il,1),delt=',il,rr(il,1),delt write(*,*) 'deltaDxt=',deltaD(xt(iso_HDO,il,1)/rr(il,1)) write(*,*) 'delt*fr(il,1),fr(il,1)=',delt*fr(il,1),fr(il,1) write(*,*) 'fxt=',fxt(iso_HDO,il,1) write(*,*) 'fq_ddft(il,1)=',0.01*grav*mp(il,2)*(rp(il,2)-rr(il,1))*work(il) write(*,*) 'fq_evapprecip(il,1)=',sigd*0.5*(evap(il,1)+evap(il,2)) write(*,*) 'fq_fluxmasse(il,1)=', 0.01*grav*am(il)*(rr(il,2)-rr(il,1))*work(il) write(*,*) 'deltaDfq_ddft=',deltaD((xtp(iso_HDO,il,2)-xt(iso_HDO,il,1))/(rp(il,2)-rr(il,1))) write(*,*) 'deltaDfq_evapprecip=',deltaD((xtevap(iso_HDO,il,1)+xtevap(iso_HDO,il,2))/(evap(il,1)+evap(il,2))) write(*,*) 'deltaDfq_fluxmasse=',deltaD((xt(iso_HDO,il,2)-xt(iso_HDO,il,1))/(rr(il,2)-rr(il,1))) write(*,*) 'rr(il,2),rr(il,1)=',rr(il,2),rr(il,1) write(*,*) 'xt(iso_HDO,il,2),xt(iso_HDO,il,1)',xt(iso_HDO,il,2),xt(iso_HDO,il,1) write(*,*) 'dq_tmp=',dq_tmp call abort_physic('cv30_routines','cv30_yield',1) endif ! iso_verif_aberrant_enc_nostop endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,1),'cv30_routine 3417') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,1)+delt*fxt(ixt,il,1) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3395',1e-5) & & .eq.1) then write(*,*) 'il=',il write(*,*) 'delt,fxt(:,il,1)=',delt,fxt(:,il,1) write(*,*) 'xt(:,il,1)=' ,xt(:,il,1) #ifdef DIAGISO write(*,*) 'fxt_fluxmasse(:,il,1)=',fxt_fluxmasse(:,il,1) write(*,*) 'fxt_ddft(:,il,1)=',fxt_ddft(:,il,1) write(*,*) 'fxt_evapprecip(:,il,1)=', & & fxt_evapprecip(:,il,1) write(*,*) 'xt(:,il,2)=',xt(:,il,2) write(*,*) 'xtp(:,il,2)=',xtp(:,il,2) write(*,*) 'xtevap(:,il,1)=',xtevap(:,il,1) write(*,*) 'xtevap(:,il,2)=',xtevap(:,il,2) write(*,*) 'facam,facmp,facev=',0.01*grav*am(il)*work(il), & & 0.01*grav*mp(il,2)*work(il),sigd*0.5 #endif ! stop endif #endif #endif ! end cam verif #endif fu(il, 1) = fu(il, 1) + 0.01*grav*work(il)*(mp(il,2)*(up(il,2)-u(il, & 1))+am(il)*(u(il,2)-u(il,1))) fv(il, 1) = fv(il, 1) + 0.01*grav*work(il)*(mp(il,2)*(vp(il,2)-v(il, & 1))+am(il)*(v(il,2)-v(il,1))) ELSE ! cvflag_grav fr(il, 1) = 0.1*mp(il, 2)*(rp(il,2)-rr(il,1))*work(il) + & sigd*0.5*(evap(il,1)+evap(il,2)) fr(il, 1) = fr(il, 1) + 0.1*am(il)*(rr(il,2)-rr(il,1))*work(il) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,1)=0.1*mp(il,2)*(xtp(ixt,il,2)-xt(ixt,il,1))*work(il) & & +sigd*0.5*(xtevap(ixt,il,1)+xtevap(ixt,il,2)) fxt(ixt,il,1)=fxt(ixt,il,1) & & +0.1*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il) enddo #ifdef DIAGISO fq_ddft(il,1)=fq_ddft(il,1) & & +0.1*mp(il,2)*(rp(il,2)-rr(il,1))*work(il) fq_evapprecip(il,1)=fq_evapprecip(il,1) & & +sigd*0.5*(evap(il,1)+evap(il,2)) fq_fluxmasse(il,1)=fq_fluxmasse(il,1) & & +0.1*am(il)*(rr(il,2)-rr(il,1))*work(il) do ixt = 1, niso fxt_fluxmasse(ixt,il,1)=fxt(ixt,il,1) & & +0.1*am(il)*(xt(ixt,il,2)-xt(ixt,il,1))*work(il) fxt_ddft(ixt,il,1)=fxt(ixt,il,1) & & +0.1*mp(il,2)*(xtp(ixt,il,2)-xt(ixt,il,1))*work(il) fxt_evapprecip(ixt,il,1)=fxt(ixt,il,1) & & +sigd*0.5*(xtevap(ixt,il,1)+xtevap(ixt,il,2)) enddo #endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,1), & & fr(il,1),'cv30_routines 3023', & & errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,1)+delt*fr(il,1).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,1) & & +delt*fxt(iso_HDO,il,1)) & & /(rr(il,1)+delt*fr(il,1)), & & 'cv30_yield 3125b, ddft en 1') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,1), & & 'cv30_routine 3417') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,1)+delt*fxt(ixt,il,1) enddo if (iso_verif_tracpos_choix_nostop(xtnew, & & 'cv30_yield 3449',1e-5) & & .eq.1) then write(*,*) 'il=',il write(*,*) 'delt,fxt(:,il,1)=',delt,fxt(:,il,1) write(*,*) 'xt(:,il,1)=' ,xt(:,il,1) ! stop endif #endif #endif ! end cam verif #endif fu(il, 1) = fu(il, 1) + 0.1*work(il)*(mp(il,2)*(up(il,2)-u(il, & 1))+am(il)*(u(il,2)-u(il,1))) fv(il, 1) = fv(il, 1) + 0.1*work(il)*(mp(il,2)*(vp(il,2)-v(il, & 1))+am(il)*(v(il,2)-v(il,1))) END IF ! cvflag_grav END DO ! il ! do j=1,ntra ! do il=1,ncum ! if (cvflag_grav) then ! ftra(il,1,j)=ftra(il,1,j)+0.01*grav*work(il) ! : *(mp(il,2)*(trap(il,2,j)-tra(il,1,j)) ! : +am(il)*(tra(il,2,j)-tra(il,1,j))) ! else ! ftra(il,1,j)=ftra(il,1,j)+0.1*work(il) ! : *(mp(il,2)*(trap(il,2,j)-tra(il,1,j)) ! : +am(il)*(tra(il,2,j)-tra(il,1,j))) ! endif ! enddo ! enddo DO j = 2, nl DO il = 1, ncum IF (j<=inb(il)) THEN IF (cvflag_grav) THEN fr(il, 1) = fr(il, 1) + 0.01*grav*work(il)*ment(il, j, 1)*(qent(il, & j,1)-rr(il,1)) fu(il, 1) = fu(il, 1) + 0.01*grav*work(il)*ment(il, j, 1)*(uent(il, & j,1)-u(il,1)) fv(il, 1) = fv(il, 1) + 0.01*grav*work(il)*ment(il, j, 1)*(vent(il, & j,1)-v(il,1)) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,1)=fxt(ixt,il,1) & & +0.01*grav*work(il)*ment(il,j,1)*(xtent(ixt,il,j,1)-xt(ixt,il,1)) enddo #ifdef DIAGISO fq_detrainement(il,1)=fq_detrainement(il,1) & & +0.01*grav*work(il)*ment(il,j,1)*(qent(il,j,1)-rr(il,1)) f_detrainement(il,1)=f_detrainement(il,1) & & +0.01*grav*work(il)*ment(il,j,1) q_detrainement(il,1)=q_detrainement(il,1) & & +0.01*grav*work(il)*ment(il,j,1)*qent(il,j,1) do ixt = 1, niso fxt_detrainement(ixt,il,1)=fxt_detrainement(ixt,il,1) & & +0.01*grav*work(il)*ment(il,j,1)*(xtent(ixt,il,j,1)-xt(ixt,il,1)) xt_detrainement(ixt,il,1)=xt_detrainement(ixt,il,1) & & +0.01*grav*work(il)*ment(il,j,1)*xtent(ixt,il,j,1) enddo #endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,1), & & fr(il,1),'cv30_routines 3251',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,1)+delt*fr(il,1).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,1) & & +delt*fxt(iso_HDO,il,1))/(rr(il,1)+delt*fr(il,1)), & & 'cv30_yield 3127, dtr melanges') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,1),'cv30_routine 3417') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,1)+delt*fxt(ixt,il,1) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3525',1e-5) & & .eq.1) then write(*,*) 'il=',il write(*,*) 'delt,fxt(:,il,1)=',delt,fxt(:,il,1) write(*,*) 'fac=', 0.01*grav*work(il)*ment(il,j,1) write(*,*) 'xt(:,il,1)=' ,xt(:,il,1) write(*,*) 'xtent(:,il,j,1)=' ,xtent(:,il,j,1) ! stop endif #endif #endif ! end cam verif #endif ELSE ! cvflag_grav fr(il, 1) = fr(il, 1) + 0.1*work(il)*ment(il, j, 1)*(qent(il,j,1)- & rr(il,1)) fu(il, 1) = fu(il, 1) + 0.1*work(il)*ment(il, j, 1)*(uent(il,j,1)-u & (il,1)) fv(il, 1) = fv(il, 1) + 0.1*work(il)*ment(il, j, 1)*(vent(il,j,1)-v & (il,1)) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,1)=fxt(ixt,il,1) & & +0.1*work(il)*ment(il,j,1)*(xtent(ixt,il,j,1)-xt(ixt,il,1)) enddo #ifdef DIAGISO fq_detrainement(il,1)=fq_detrainement(il,1) & & +0.1*work(il)*ment(il,j,1)*(qent(il,j,1)-rr(il,1)) f_detrainement(il,1)=f_detrainement(il,1) & & +0.1*work(il)*ment(il,j,1) q_detrainement(il,1)=q_detrainement(il,1) & & +0.1*work(il)*ment(il,j,1)*qent(il,j,1) do ixt = 1, niso fxt_detrainement(ixt,il,1)=fxt_detrainement(ixt,il,1) & & +0.1*work(il)*ment(il,j,1)*(xtent(ixt,il,j,1)-xt(ixt,il,1)) xt_detrainement(ixt,il,1)=xt_detrainement(ixt,il,1) & & +0.1*work(il)*ment(il,j,1)*xtent(ixt,il,j,1) enddo #endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,1), & & fr(il,1),'cv30_routines 3092',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,1)+delt*fr(il,1).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,1) & & +delt*fxt(iso_HDO,il,1))/(rr(il,1)+delt*fr(il,1)), & & 'cv30_yield 3127b, dtr melanges') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,1),'cv30_routine 3462') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,1)+delt*fxt(ixt,il,1) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3753',1e-5) & & .eq.1) then write(*,*) 'il=',il endif #endif #endif ! end cam verif #endif END IF ! cvflag_grav END IF ! j END DO END DO ! do k=1,ntra ! do j=2,nl ! do il=1,ncum ! if (j.le.inb(il)) then ! if (cvflag_grav) then ! ftra(il,1,k)=ftra(il,1,k)+0.01*grav*work(il)*ment(il,j,1) ! : *(traent(il,j,1,k)-tra(il,1,k)) ! else ! ftra(il,1,k)=ftra(il,1,k)+0.1*work(il)*ment(il,j,1) ! : *(traent(il,j,1,k)-tra(il,1,k)) ! endif ! endif ! enddo ! enddo ! enddo ! *** calculate tendencies of potential temperature and mixing ratio *** ! *** at levels above the lowest level *** ! *** first find the net saturated updraft and downdraft mass fluxes *** ! *** through each level *** DO i = 2, nl + 1 ! newvecto: mettre nl au lieu nl+1? num1 = 0 DO il = 1, ncum IF (i<=inb(il)) num1 = num1 + 1 END DO IF (num1<=0) GO TO 500 CALL zilch(amp1, ncum) CALL zilch(ad, ncum) DO k = i + 1, nl + 1 DO il = 1, ncum IF (i<=inb(il) .AND. k<=(inb(il)+1)) THEN amp1(il) = amp1(il) + m(il, k) END IF END DO END DO DO k = 1, i DO j = i + 1, nl + 1 DO il = 1, ncum IF (i<=inb(il) .AND. j<=(inb(il)+1)) THEN amp1(il) = amp1(il) + ment(il, k, j) END IF END DO END DO END DO DO k = 1, i - 1 DO j = i, nl + 1 ! newvecto: nl au lieu nl+1? DO il = 1, ncum IF (i<=inb(il) .AND. j<=inb(il)) THEN ad(il) = ad(il) + ment(il, j, k) END IF END DO END DO END DO DO il = 1, ncum IF (i<=inb(il)) THEN dpinv = 1.0/(ph(il,i)-ph(il,i+1)) cpinv = 1.0/cpn(il, i) ! convect3 if((0.1*dpinv*amp1).ge.delti)iflag(il)=4 IF (cvflag_grav) THEN IF ((0.01*grav*dpinv*amp1(il))>=delti) iflag(il) = 1 ! vecto ELSE IF ((0.1*dpinv*amp1(il))>=delti) iflag(il) = 1 ! vecto END IF IF (cvflag_grav) THEN ft(il, i) = 0.01*grav*dpinv*(amp1(il)*(t(il,i+1)-t(il, & i)+(gz(il,i+1)-gz(il,i))*cpinv)-ad(il)*(t(il,i)-t(il, & i-1)+(gz(il,i)-gz(il,i-1))*cpinv)) - 0.5*sigd*lvcp(il, i)*(evap( & il,i)+evap(il,i+1)) rat = cpn(il, i-1)*cpinv ft(il, i) = ft(il, i) - 0.009*grav*sigd*(mp(il,i+1)*t(il,i)*b(il,i) & -mp(il,i)*t(il,i-1)*rat*b(il,i-1))*dpinv ft(il, i) = ft(il, i) + 0.01*grav*dpinv*ment(il, i, i)*(hp(il,i)-h( & il,i)+t(il,i)*(cpv-cpd)*(rr(il,i)-qent(il,i,i)))*cpinv ELSE ! cvflag_grav ft(il, i) = 0.1*dpinv*(amp1(il)*(t(il,i+1)-t(il, & i)+(gz(il,i+1)-gz(il,i))*cpinv)-ad(il)*(t(il,i)-t(il, & i-1)+(gz(il,i)-gz(il,i-1))*cpinv)) - 0.5*sigd*lvcp(il, i)*(evap( & il,i)+evap(il,i+1)) rat = cpn(il, i-1)*cpinv ft(il, i) = ft(il, i) - 0.09*sigd*(mp(il,i+1)*t(il,i)*b(il,i)-mp(il & ,i)*t(il,i-1)*rat*b(il,i-1))*dpinv ft(il, i) = ft(il, i) + 0.1*dpinv*ment(il, i, i)*(hp(il,i)-h(il,i)+ & t(il,i)*(cpv-cpd)*(rr(il,i)-qent(il,i,i)))*cpinv END IF ! cvflag_grav ft(il, i) = ft(il, i) + 0.01*sigd*wt(il, i)*(cl-cpd)*water(il, i+1)*( & t(il,i+1)-t(il,i))*dpinv*cpinv IF (cvflag_grav) THEN fr(il, i) = 0.01*grav*dpinv*(amp1(il)*(rr(il,i+1)-rr(il, & i))-ad(il)*(rr(il,i)-rr(il,i-1))) fu(il, i) = fu(il, i) + 0.01*grav*dpinv*(amp1(il)*(u(il,i+1)-u(il, & i))-ad(il)*(u(il,i)-u(il,i-1))) fv(il, i) = fv(il, i) + 0.01*grav*dpinv*(amp1(il)*(v(il,i+1)-v(il, & i))-ad(il)*(v(il,i)-v(il,i-1))) #ifdef ISO #ifdef DIAGISO fq_fluxmasse(il,i)=fq_fluxmasse(il,i) & & +0.01*grav*dpinv*(amp1(il)*(rr(il,i+1)-rr(il,i)) & & -ad(il)*(rr(il,i)-rr(il,i-1))) ! modif 2 fev: pour avoir subsidence compensatoire totale, on retranche ! ad. #endif ! ici, on separe 2 cas, pour eviter le cas pathologique decrit plus haut ! pour la tendance liee a Am en i=1, qui peut conduire a des isotopes ! negatifs dans les cas ou les flux de masse soustrait plus de 90% de la ! vapeur de la couche. Voir plus haut le detail des equations. ! La difference ici est qu'on considere les flux de masse amp1 et ad en ! meme temps. dq_tmp= 0.01*grav*dpinv*(amp1(il)*(rr(il,i+1)-rr(il,i)) & & -ad(il)*(rr(il,i)-rr(il,i-1)))*delt ! c'est equivalent a dqi= kamp1*qip1+kad*qim1-(kamp1+kad)*qi if ((dq_tmp/rr(il,i).lt.-0.9).and.correction_excess_aberrant) then ! nouvelle formulation k_tmp=0.01*grav*dpinv*amp1(il)*delt kad_tmp=0.01*grav*dpinv*ad(il)*delt do ixt = 1, ntraciso R_tmp=(xt(ixt,il,i)+k_tmp*xt(ixt,il,i+1)+kad_tmp*xt(ixt,il,i-1)) & & /(rr(il,i)+k_tmp*rr(il,i+1)+kad_tmp*rr(il,i-1)) dx_tmp= R_tmp*( rr(il,i)+ dq_tmp)-xt(ixt,il,i) fxt(ixt,il,i)= dx_tmp/delt #ifdef ISOVERIF if ((ixt.eq.iso_HDO).or.(ixt.eq.iso_eau)) then write(*,*) 'cv30_routines 4367: il,i,ixt=',il,i,ixt write(*,*) 'dq_tmp,rr(il,i)=',dq_tmp,rr(il,i) write(*,*) 'R_tmp,dx_tmp,delt=',R_tmp,dx_tmp,delt write(*,*) 'amp1(il),ad(il)=',amp1(il),ad(il) write(*,*) 'xt(ixt,il,i-1:i+1)=',xt(ixt,il,i-1:i+1) write(*,*) 'rr(il,i-1:i+1)=',rr(il,i-1:i+1) write(*,*) 'fxt=',dx_tmp/delt write(*,*) 'rr(il,i)+dq_tmp=',rr(il,1)+dq_tmp write(*,*) 'xt(ixt,il,i)+dx_tmp=',xt(ixt,il,i)+dx_tmp write(*,*) 'xt(ixt,il,i)+fxt(ixt,il,i)*delt=', & & xt(ixt,il,i)+fxt(ixt,il,i)*delt write(*,*) 'fxt(:,il,i)=',fxt(:,il,i) endif !if (ixt.eq.iso_HDO) then #endif enddo ! do ixt = 1, ntraciso #ifdef DIAGISO do ixt = 1, niso fxt_fluxmasse(ixt,il,i)=fxt(ixt,il,i) enddo #endif else !if (dq_tmp/rr(il,i).lt.-0.9) then ! ancienne formulation do ixt = 1, ntraciso fxt(ixt,il,i)= & & 0.01*grav*dpinv*(amp1(il)*(xt(ixt,il,i+1)-xt(ixt,il,i)) & & -ad(il)*(xt(ixt,il,i)-xt(ixt,il,i-1))) enddo #ifdef DIAGISO do ixt = 1, niso fxt_fluxmasse(ixt,il,i)=fxt_fluxmasse(ixt,il,i)+ & & 0.01*grav*dpinv*(amp1(il)*(xt(ixt,il,i+1)-xt(ixt,il,i)) & & -ad(il)*(xt(ixt,il,i)-xt(ixt,il,i-1))) enddo #endif endif !if (dq_tmp/rr(il,i).lt.-0.9) then ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3226',errmax,errmaxrel) endif !if (iso_eau.gt.0) then do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3229') enddo if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3384, flux masse') endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3384,O18, flux masse') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,1),'cv30_routine 3626') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3727',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i write(*,*) 'fxt(:,il,i)=',fxt(:,il,i) write(*,*) 'amp1(il),ad(il),fac=', & & amp1(il),ad(il),0.01*grav*dpinv write(*,*) 'xt(:,il,i+1)=' ,xt(:,il,i+1) write(*,*) 'xt(:,il,i)=' ,xt(:,il,i) write(*,*) 'xt(:,il,i-1)=' ,xt(:,il,i-1) ! stop endif #endif #endif ! end cam verif #endif ELSE ! cvflag_grav fr(il, i) = 0.1*dpinv*(amp1(il)*(rr(il,i+1)-rr(il, & i))-ad(il)*(rr(il,i)-rr(il,i-1))) fu(il, i) = fu(il, i) + 0.1*dpinv*(amp1(il)*(u(il,i+1)-u(il, & i))-ad(il)*(u(il,i)-u(il,i-1))) fv(il, i) = fv(il, i) + 0.1*dpinv*(amp1(il)*(v(il,i+1)-v(il, & i))-ad(il)*(v(il,i)-v(il,i-1))) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)= & & 0.1*dpinv*(amp1(il)*(xt(ixt,il,i+1)-xt(ixt,il,i)) & & -ad(il)*(xt(ixt,il,i)-xt(ixt,il,i-1))) enddo #ifdef DIAGISO fq_fluxmasse(il,i)=fq_fluxmasse(il,i) & & +0.1*dpinv*(amp1(il)*(rr(il,i+1)-rr(il,i)) & & -ad(il)*(rr(il,i)-rr(il,i-1))) do ixt = 1, niso fxt_fluxmasse(ixt,il,i)=fxt_fluxmasse(ixt,il,i)+ & & 0.1*dpinv*(amp1(il)*(xt(ixt,il,i+1)-xt(ixt,il,i)) & & -ad(il)*(xt(ixt,il,i)-xt(ixt,il,i-1))) enddo #endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3252',errmax,errmaxrel) endif !if (iso_eau.gt.0) then do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3229') enddo ! correction 21 oct 2008 if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3384b flux masse') if (iso_O18.gt.0) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3384bO18 flux masse') endif !if (iso_O18.gt.0) then endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,1),'cv30_routine 3674') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3775',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif #endif #endif ! end cam verif #endif END IF ! cvflag_grav END IF ! i END DO ! do k=1,ntra ! do il=1,ncum ! if (i.le.inb(il)) then ! dpinv=1.0/(ph(il,i)-ph(il,i+1)) ! cpinv=1.0/cpn(il,i) ! if (cvflag_grav) then ! ftra(il,i,k)=ftra(il,i,k)+0.01*grav*dpinv ! : *(amp1(il)*(tra(il,i+1,k)-tra(il,i,k)) ! : -ad(il)*(tra(il,i,k)-tra(il,i-1,k))) ! else ! ftra(il,i,k)=ftra(il,i,k)+0.1*dpinv ! : *(amp1(il)*(tra(il,i+1,k)-tra(il,i,k)) ! : -ad(il)*(tra(il,i,k)-tra(il,i-1,k))) ! endif ! endif ! enddo ! enddo DO k = 1, i - 1 DO il = 1, ncum IF (i<=inb(il)) THEN dpinv = 1.0/(ph(il,i)-ph(il,i+1)) cpinv = 1.0/cpn(il, i) awat = elij(il, k, i) - (1.-ep(il,i))*clw(il, i) awat = amax1(awat, 0.0) #ifdef ISO ! on change le traitement de cette ligne le 8 mai 2009: ! avant, on avait: xtawat=xtelij(il,k,i)-(1.-xtep(il,i))*xtclw(il,i) ! c'est a dire que Rawat=Relij+(1-ep)*clw/awat*(Relij-Rclw) ! si Relij!=Rclw, alors un fractionnement isotopique non physique etait ! introduit. ! En fait, awat represente le surplus de condensat dans le melange par ! rapport a celui restant dans la colonne adiabatique ! ce surplus a la meme compo que le elij, sans fractionnement. ! d'ou le nouveau traitement ci-dessous. if (elij(il,k,i).gt.0.0) then do ixt = 1, ntraciso xtawat(ixt)=awat*(xtelij(ixt,il,k,i)/elij(il,k,i)) ! xtawat(ixt)=amax1(xtawat(ixt),0.0) ! pas necessaire enddo else !if (elij(il,k,i).gt.0.0) then ! normalement, si elij(il,k,i)<=0, alors awat=0 ! on le verifie. Si c'est vrai -> xtawat=0 aussi #ifdef ISOVERIF call iso_verif_egalite(awat,0.0,'cv30_yield 3779') #endif do ixt = 1, ntraciso xtawat(ixt)=0.0 enddo endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(xtawat(iso_eau), & & awat,'cv30_routines 3301',errmax,errmaxrel) endif !if (iso_eau.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(xtawat(1),'cv30_routine 3729') #endif #endif ! end cam verif #endif IF (cvflag_grav) THEN fr(il, i) = fr(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(qent(il,k & ,i)-awat-rr(il,i)) fu(il, i) = fu(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(uent(il,k & ,i)-u(il,i)) fv(il, i) = fv(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(vent(il,k & ,i)-v(il,i)) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.01*grav*dpinv*ment(il,k,i) & & *(xtent(ixt,il,k,i)-xtawat(ixt)-xt(ixt,il,i)) enddo #ifdef DIAGISO fq_detrainement(il,i)=fq_detrainement(il,i) & & +0.01*grav*dpinv*ment(il,k,i) & & *(qent(il,k,i)-awat-rr(il,i)) f_detrainement(il,i)=f_detrainement(il,i)& & +0.01*grav*dpinv*ment(il,k,i) q_detrainement(il,i)=q_detrainement(il,i) & & +0.01*grav*dpinv*ment(il,k,i)*qent(il,k,i) do ixt = 1, niso fxt_detrainement(ixt,il,i)=fxt_detrainement(ixt,il,i) & & +0.01*grav*dpinv*ment(il,k,i) & & *(xtent(ixt,il,k,i)-xtawat(ixt)-xt(ixt,il,i)) xt_detrainement(ixt,il,i)=xt_detrainement(ixt,il,i) & & +0.01*grav*dpinv*ment(il,k,i)*xtent(ixt,il,k,i) enddo #endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3325',errmax,errmaxrel) endif !if (iso_eau.gt.0) then do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3328') enddo if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3396a, dtr mels') & & .eq.1) then write(*,*) 'il,k,i=',il,k,i write(*,*) 'rr,delt,fr=',rr(il,i),delt,fr(il,i) write(*,*) 'frnew=',0.01*grav*dpinv*ment(il, k, i)*(qent(il,k,i)-awat-rr(il,i)) write(*,*) 'frold=',fr(il,i)-0.01*grav*dpinv*ment(il, k, i)*(qent(il,k,i)-awat-rr(il,i)) write(*,*) 'deltaDfrnew=',deltaD((xtent(iso_HDO,il,k,i)-xtawat(iso_HDO)-xt(iso_HDO,il,i)) & /(qent(il,k,i)-awat-rr(il,i))) write(*,*) 'deltaDfrold=',deltaD((fxt(iso_HDO,il,i) & -0.01*grav*dpinv*ment(il, k, i)*(xtent(iso_HDO,il,k,i)-xtawat(iso_HDO)-xt(iso_HDO,il,i))) & /(fr(il,i)-0.01*grav*dpinv*ment(il, k, i)*(qent(il,k,i)-awat-rr(il,i)))) write(*,*) 'q+=',rr(il,i)+delt*fr(il,i) write(*,*) 'qent,awat=',qent(il,k,i),awat write(*,*) 'elij,clw,ep=',elij(il,k,i),clw(il,i),ep(il,i) write(*,*) 'deltaDfr=',deltaD(fxt(iso_hdo,il,i)/fr(il,i)) write(*,*) 'deltaDrr=',deltaD(xt(iso_hdo,il,i)/rr(il,i)) write(*,*) 'deltaDqent=',deltaD(xtent(iso_hdo,il,k,i) & & /qent(il,k,i)) write(*,*) 'deltaDqent-awat=',deltaD((xtent(iso_hdo,il,k,i)-xtawat(iso_HDO)) & & /(qent(il,k,i)-awat)) write(*,*) 'deltaDawat=',deltaD(xtawat(iso_hdo)/awat) write(*,*) 'deltaDclw=',deltaD(xtclw(iso_hdo,il,i)/clw(il,i)) ! stop endif if (iso_O18.gt.0) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3396aO18, dtr mels') endif !if (iso_O18.gt.0) then endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,i),'cv30_routine 3784') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3905',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif ! call iso_verif_tracpos_choix(xtnew,'cv30_yield 3905',1e-5) #endif #endif #endif ELSE ! cvflag_grav fr(il, i) = fr(il, i) + 0.1*dpinv*ment(il, k, i)*(qent(il,k,i)- & awat-rr(il,i)) fu(il, i) = fu(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(uent(il,k & ,i)-u(il,i)) fv(il, i) = fv(il, i) + 0.1*dpinv*ment(il, k, i)*(vent(il,k,i)-v( & il,i)) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.1*dpinv*ment(il,k,i) & & *(xtent(ixt,il,k,i)-xtawat(ixt)-xt(ixt,il,i)) enddo #ifdef DIAGISO fq_detrainement(il,i)=fq_detrainement(il,i) & & +0.1*dpinv*ment(il,k,i)*(qent(il,k,i)-awat-rr(il,i)) f_detrainement(il,i)=f_detrainement(il,i) & & +0.1*dpinv*ment(il,k,i) q_detrainement(il,i)=q_detrainement(il,i) & & +0.1*dpinv*ment(il,k,i)*qent(il,k,i) do ixt = 1, niso fxt_detrainement(ixt,il,i)=fxt_detrainement(ixt,il,i) & & +0.1*dpinv*ment(il,k,i) & & *(xtent(ixt,il,k,i)-xtawat(ixt)-xt(ixt,il,i)) xt_detrainement(ixt,il,i)=xt_detrainement(ixt,il,i) & & +0.1*dpinv*ment(il,k,i)*xtent(ixt,il,k,i) enddo #endif ! cam verif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3350',errmax,errmaxrel) endif !if (iso_eau.gt.0) then do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3353') enddo if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3396b, dtr mels') endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3396b,O18, dtr mels') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,i),'cv30_routine 3828') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 3949',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif ! call iso_verif_tracpos_choix(xtnew,'cv30_yield 3949',1e-5) #endif #endif ! end cam verif #endif END IF ! cvflag_grav ! (saturated updrafts resulting from mixing) ! cld qcond(il, i) = qcond(il, i) + (elij(il,k,i)-awat) ! cld nqcond(il, i) = nqcond(il, i) + 1. ! cld END IF ! i END DO END DO ! do j=1,ntra ! do k=1,i-1 ! do il=1,ncum ! if (i.le.inb(il)) then ! dpinv=1.0/(ph(il,i)-ph(il,i+1)) ! cpinv=1.0/cpn(il,i) ! if (cvflag_grav) then ! ftra(il,i,j)=ftra(il,i,j)+0.01*grav*dpinv*ment(il,k,i) ! : *(traent(il,k,i,j)-tra(il,i,j)) ! else ! ftra(il,i,j)=ftra(il,i,j)+0.1*dpinv*ment(il,k,i) ! : *(traent(il,k,i,j)-tra(il,i,j)) ! endif ! endif ! enddo ! enddo ! enddo DO k = i, nl + 1 DO il = 1, ncum IF (i<=inb(il) .AND. k<=inb(il)) THEN dpinv = 1.0/(ph(il,i)-ph(il,i+1)) cpinv = 1.0/cpn(il, i) IF (cvflag_grav) THEN fr(il, i) = fr(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(qent(il,k & ,i)-rr(il,i)) fu(il, i) = fu(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(uent(il,k & ,i)-u(il,i)) fv(il, i) = fv(il, i) + 0.01*grav*dpinv*ment(il, k, i)*(vent(il,k & ,i)-v(il,i)) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.01*grav*dpinv*ment(il,k,i)*(xtent(ixt,il,k,i)-xt(ixt,il,i)) enddo #ifdef DIAGISO fq_detrainement(il,i)=fq_detrainement(il,i) & & +0.01*grav*dpinv*ment(il,k,i)*(qent(il,k,i)-rr(il,i)) f_detrainement(il,i)=f_detrainement(il,i) & & +0.01*grav*dpinv*ment(il,k,i) q_detrainement(il,i)=q_detrainement(il,i) & & +0.01*grav*dpinv*ment(il,k,i)*qent(il,k,i) do ixt = 1, niso fxt_detrainement(ixt,il,i)=fxt_detrainement(ixt,il,i) & & +0.01*grav*dpinv*ment(il,k,i)*(xtent(ixt,il,k,i)-xt(ixt,il,i)) xt_detrainement(ixt,il,i)=xt_detrainement(ixt,il,i) & & +0.01*grav*dpinv*ment(il,k,i)*xtent(ixt,il,k,i) enddo #endif ! cam verif #ifdef ISOVERIF if ((il.eq.1636).and.(i.eq.9)) then write(*,*) 'cv30 4785: on ajoute le dtr ici:' write(*,*) 'M=',0.01*grav*dpinv*ment(il, k, i) write(*,*) 'q,qe=',rr(il,i),qent(il,k,i) bx=0.01*grav*dpinv*ment(il,k,i)*(qent(il,k,i)-rr(il,i)) do ixt=1,niso xtbx(ixt)=0.01*grav*dpinv*ment(il,k,i)*(xtent(ixt,il,k,i)-xt(ixt,il,i)) enddo endif do ixt=1,niso call iso_verif_noNaN(fxt(ixt,il,i),'cv30_yield 4351') enddo #endif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3408',errmax,errmaxrel) endif !if (iso_eau.gt.0) then do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3411') enddo if (1.eq.0) then if ((iso_HDO.gt.0).and.(delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop( & & fxt(iso_HDO,il,i)/fr(il,i), & & 'cv30_yield 3572, dtr mels').eq.1) then write(*,*) 'i,icb(il),inb(il)=',i,icb(il),inb(il) write(*,*) 'fr(il,i)=',fr(il,i) ! if (fr(il,i).gt.ridicule*1e5) then ! stop ! endif endif endif !if (iso_HDO.gt.0) then endif !if (1.eq.0) then if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3605, dtr mels') if (iso_O18.gt.0) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3605O18, dtr mels') if ((il.eq.1636).and.(i.eq.9)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*(fxt(iso_HDO,il,i)-xtbx(iso_HDO))) & & /(rr(il,i)+delt*(fr(il,i)-bx)), & & (xt(iso_O18,il,i)+delt*(fxt(iso_O18,il,i)-xtbx(iso_O18))) & & /(rr(il,i)+delt*(fr(il,i)-bx)), & & 'cv30_yield 3605O18_nobx, dtr mels') endif !if ((il.eq.1636).and.(i.eq.9)) then endif !if (iso_O18.gt.0) then endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,i),'cv30_routine 3921') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 4036',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif ! call iso_verif_tracpos_choix(xtnew,'cv30_yield 4036',1e-5) #endif #endif ! end cam verif #endif ELSE ! cvflag_grav fr(il, i) = fr(il, i) + 0.1*dpinv*ment(il, k, i)*(qent(il,k,i)-rr & (il,i)) fu(il, i) = fu(il, i) + 0.1*dpinv*ment(il, k, i)*(uent(il,k,i)-u( & il,i)) fv(il, i) = fv(il, i) + 0.1*dpinv*ment(il, k, i)*(vent(il,k,i)-v( & il,i)) #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.1*dpinv*ment(il,k,i)*(xtent(ixt,il,k,i)-xt(ixt,il,i)) enddo #ifdef DIAGISO fq_detrainement(il,i)=fq_detrainement(il,i) & & +0.1*dpinv*ment(il,k,i)*(qent(il,k,i)-rr(il,i)) f_detrainement(il,i)=f_detrainement(il,i) & & +0.1*dpinv*ment(il,k,i) q_detrainement(il,i)=q_detrainement(il,i) & & +0.1*dpinv*ment(il,k,i)*qent(il,k,i) do ixt = 1, niso fxt_detrainement(ixt,il,i)=fxt_detrainement(ixt,il,i) & & +0.1*dpinv*ment(il,k,i)*(xtent(ixt,il,k,i)-xt(ixt,il,i)) xt_detrainement(ixt,il,i)=xt_detrainement(ixt,il,i) & & +0.1*dpinv*ment(il,k,i)*xtent(ixt,il,k,i) enddo #endif ! cam verif #ifdef ISOVERIF if ((il.eq.1636).and.(i.eq.9)) then write(*,*) 'cv30 4785b: on ajoute le dtr ici:' write(*,*) 'M=',0.1*dpinv*ment(il, k, i) write(*,*) 'q,qe=',rr(il,i),qent(il,k,i) endif if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3433',errmax,errmaxrel) endif !if (iso_eau.gt.0) then do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3436') enddo if ((iso_HDO.gt.0).and.(delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop( & & fxt(iso_HDO,il,i)/fr(il,i), & & 'cv30_yield 3597').eq.1) then write(*,*) 'i,icb(il),inb(il)=',i,icb(il),inb(il) stop endif endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3605b, dtr mels') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,i),'cv30_routine 3972') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 4091',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif ! call iso_verif_tracpos_choix(xtnew,'cv30_yield 4091',1e-5) #endif #endif ! end cam verif #endif END IF ! cvflag_grav END IF ! i and k END DO END DO ! do j=1,ntra ! do k=i,nl+1 ! do il=1,ncum ! if (i.le.inb(il) .and. k.le.inb(il)) then ! dpinv=1.0/(ph(il,i)-ph(il,i+1)) ! cpinv=1.0/cpn(il,i) ! if (cvflag_grav) then ! ftra(il,i,j)=ftra(il,i,j)+0.01*grav*dpinv*ment(il,k,i) ! : *(traent(il,k,i,j)-tra(il,i,j)) ! else ! ftra(il,i,j)=ftra(il,i,j)+0.1*dpinv*ment(il,k,i) ! : *(traent(il,k,i,j)-tra(il,i,j)) ! endif ! endif ! i and k ! enddo ! enddo ! enddo DO il = 1, ncum IF (i<=inb(il)) THEN dpinv = 1.0/(ph(il,i)-ph(il,i+1)) cpinv = 1.0/cpn(il, i) IF (cvflag_grav) THEN ! sb: on ne fait pas encore la correction permettant de mieux ! conserver l'eau: fr(il, i) = fr(il, i) + 0.5*sigd*(evap(il,i)+evap(il,i+1)) + & 0.01*grav*(mp(il,i+1)*(rp(il,i+1)-rr(il,i))-mp(il,i)*(rp(il, & i)-rr(il,i-1)))*dpinv fu(il, i) = fu(il, i) + 0.01*grav*(mp(il,i+1)*(up(il,i+1)-u(il, & i))-mp(il,i)*(up(il,i)-u(il,i-1)))*dpinv fv(il, i) = fv(il, i) + 0.01*grav*(mp(il,i+1)*(vp(il,i+1)-v(il, & i))-mp(il,i)*(vp(il,i)-v(il,i-1)))*dpinv #ifdef ISO do ixt = 1, niso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) & & +0.01*grav*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i) & & *(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo #ifdef DIAGISO fq_evapprecip(il,i)=fq_evapprecip(il,i) & & +0.5*sigd*(evap(il,i)+evap(il,i+1)) fq_ddft(il,i)=fq_ddft(il,i) & & +0.01*grav*(mp(il,i+1)*(rp(il,i+1)-rr(il,i))-mp(il,i) & & *(rp(il,i)-rr(il,i-1)))*dpinv do ixt = 1, niso fxt_evapprecip(ixt,il,i)=fxt_evapprecip(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) fxt_ddft(ixt,il,i)=fxt_ddft(ixt,il,i) & & +0.01*grav*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo #endif #ifdef ISOVERIF do ixt=1,niso call iso_verif_noNaN(xt(ixt,il,i),'cv30_yield 4514') call iso_verif_noNaN(fxt(ixt,il,i),'cv30_yield 4515') enddo if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 4175') & & .eq.1) then write(*,*) 'il,i=',il,i if (rr(il,i).ne.0.0) then write(*,*) 'il,i,rr,deltaD=',il,i,rr(il,i),deltaD & & (xt(iso_HDO,il,i)/rr(il,i)) endif if (fr(il,i).ne.0.0) then write(*,*) 'fr,fxt,deltaD=',fr(il,i),fxt(iso_HDO,il,i), & & deltaD(fxt(iso_HDO,il,i)/fr(il,i)) endif #ifdef DIAGISO if (fq_ddft(il,i).ne.0.0) then write(*,*) 'fq_ddft,deltaD=',fq_ddft(il,i),deltaD( & & fxt_ddft(iso_HDO,il,i)/fq_ddft(il,i)) endif if (fq_evapprecip(il,i).ne.0.0) then write(*,*) 'fq_evapprecip,deltaD=',fq_evapprecip(il,i),deltaD( & & fxt_evapprecip(iso_HDO,il,i)/fq_evapprecip(il,i)) endif #endif write(*,*) 'sigd,evap(il,i),evap(il,i+1)=', & & sigd,evap(il,i),evap(il,i+1) write(*,*) 'xtevap(iso_HDO,il,i),xtevap(iso_HDO,il,i+1)=', & & xtevap(iso_HDO,il,i),xtevap(iso_HDO,il,i+1) write(*,*) 'grav,mp(il,i+1),mp(il,i),dpinv=', & & grav,mp(il,i+1),mp(il,i),dpinv write(*,*) 'rp(il,i+1),rr(il,i),rp(il,i),rr(il,i-1)=', & & rp(il,i+1),rr(il,i),rp(il,i),rr(il,i-1) write(*,*) 'xtp(il,i+1),xt(il,i),xtp(il,i),xt(il,i-1)=', & & xtp(iso_HDO,il,i+1),xt(iso_HDO,il,i), & & xtp(iso_HDO,il,i),xt(iso_HDO,il,i-1) stop endif endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 5029,O18, evap') if ((il.eq.1636).and.(i.eq.9)) then write(*,*) 'cv30_yield 5057: ici, on verifie deltaD_nobx' write(*,*) 'il,i=',il,i write(*,*) 'fr(il,i),bx,fr(il,i)-bx=',fr(il,i),bx,fr(il,i)-bx write(*,*) 'q,q+=',rr(il,i),rr(il,i)+delt*(fr(il,i)-bx) write(*,*) 'deltaD,deltaD+=',deltaD(xt(iso_HDO,il,inb(il))/rr(il,inb(il))), & & deltaD( (xt(iso_HDO,il,i)+delt*(fxt(iso_HDO,il,i)-xtbx(iso_HDO)))/(rr(il,i)+delt*(fr(il,i)-bx))) write(*,*) 'deltaO18,deltaO18+=',deltaO(xt(iso_O18,il,inb(il))/rr(il,inb(il))), & & deltaO( (xt(iso_O18,il,i)+delt*(fxt(iso_O18,il,i)-xtbx(iso_O18)))/(rr(il,i)+delt*(fr(il,i)-bx))) call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*(fxt(iso_HDO,il,i)-xtbx(iso_HDO))) & & /(rr(il,i)+delt*(fr(il,i)-bx)), & & (xt(iso_O18,il,i)+delt*(fxt(iso_O18,il,i)-xtbx(iso_O18))) & & /(rr(il,i)+delt*(fr(il,i)-bx)), & & 'cv30_yield 5029_nobx,O18, evap, no bx') endif !if ((il.eq.1636).and.(i.eq.9)) then endif !if (iso_HDO.gt.0) then #endif #ifdef ISOTRAC if ((option_traceurs.ne.6).and.(option_traceurs.ne.19)) then ! facile: on fait comme l'eau do ixt = 1+niso,ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) & & +0.01*grav*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo !do ixt = 1+niso,ntraciso else ! taggage des ddfts: ! la formule pour fq_ddft suppose que le ddft est en RP. Ce n'est pas le ! cas pour le water tagging puisqu'il y a conversion des molecules ! blances entrainees en molecule rouges. ! Il faut donc prendre en compte ce taux de conversion quand ! entrainement d'env vers ddft ! conversion(iiso)=0.01*grav*dpinv ! : *(mp(il,i)-mp(il,i+1))*xt(ixt_poubelle,il,i) ! fxt(ixt_ddft,il,i)=fxt(ixt_ddft,il,i)+conversion(iiso) ! fxt(ixt_poubelle,il,i)=fxt(ixt_poubelle,il,i) ! : -conversion(iiso) ! Pb: quand on discretise, dqp/dt n'est pas verifee numeriquement. ! on se retrouve donc avec des d Ye/dt differents de 0 meme si ye=0 ( on ! note X les molecules poubelles et Y les molecules ddfts). ! Solution alternative: Dans le cas entrainant, Ye ne varie que par ! ascendance compensatoire des ddfts et par perte de Ye vers le ddft. On ! calcule donc ce terme directement avec schema amont: ! ajout deja de l'evap do ixt = 1+niso,ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) enddo !do ixt = 1+niso,ntraciso ! ajout du terme des ddfts sensi stricto ! write(*,*) 'tmp cv3_yield 4165: i,il=',i,il ! if (option_traceurs.eq.6) then do iiso = 1, niso ixt_ddft=itZonIso(izone_ddft,iiso) if (mp(il,i).gt.mp(il,i+1)) then fxtYe(iiso)=0.01*grav*dpinv*mp(il,i) & & *(xt(ixt_ddft,il,i-1)-xt(ixt_ddft,il,i)) else !if (mp(il,i).gt.mp(il,i+1)) then fxtYe(iiso)=0.01*grav*dpinv*(mp(il,i) & & *xt(ixt_ddft,il,i-1)-mp(il,i+1)*xt(ixt_ddft,il,i) & & +(mp(il,i+1)-mp(il,i))*xtp(ixt_ddft,il,i)) endif !if (mp(il,i).gt.mp(il,i+1)) then fxtqe(iiso)=0.01*grav*dpinv* & & (mp(il,i+1)*(xtp(iiso,il,i+1)-xt(iiso,il,i)) & & -mp(il,i)*(xtp(iiso,il,i)-xt(iiso,il,i-1))) ixt_poubelle=itZonIso(izone_poubelle,iiso) fxt(ixt_ddft,il,i)=fxt(ixt_ddft,il,i)+fxtYe(iiso) fxt(ixt_poubelle,il,i)=fxt(ixt_poubelle,il,i) & & +fxtqe(iiso)-fxtYe(iiso) enddo !do iiso = 1, niso else !if (option_traceurs.eq.6) then if (mp(il,i).gt.mp(il,i+1)) then ! cas entrainant: faire attention do iiso = 1, niso fxtqe(iiso)=0.01*grav*dpinv* & & (mp(il,i+1)*(xtp(iiso,il,i+1)-xt(iiso,il,i)) & & -mp(il,i)*(xtp(iiso,il,i)-xt(iiso,il,i-1))) ixt_ddft=itZonIso(izone_ddft,iiso) fxtYe(iiso)=0.01*grav*dpinv*mp(il,i) & & *(xt(ixt_ddft,il,i-1)-xt(ixt_ddft,il,i)) fxt(ixt_ddft,il,i)=fxt(ixt_ddft,il,i)+fxtYe(iiso) ixt_revap=itZonIso(izone_revap,iiso) fxt_revap(iiso)=0.01*grav*dpinv*(mp(il,i+1)* & & (xtp(ixt_revap,il,i+1)-xt(ixt_revap,il,i)) & & -mp(il,i)*(xtp(ixt_revap,il,i)-xt(ixt_revap,il,i-1))) fxt(ixt_revap,il,i)=fxt(ixt_revap,il,i) & & +fxt_revap(iiso) fxtXe(iiso)=fxtqe(iiso)-fxtYe(iiso)-fxt_revap(iiso) Xe(iiso)=xt(iiso,il,i) & & -xt(ixt_ddft,il,i)-xt(ixt_revap,il,i) if (Xe(iiso).gt.ridicule) then do izone=1,nzone if ((izone.ne.izone_revap).and. & & (izone.ne.izone_ddft)) then ixt=itZonIso(izone,iiso) fxt(ixt,il,i)=fxt(ixt,il,i) & & +xt(ixt,il,i)/Xe(iiso)*fxtXe(iiso) endif !if ((izone.ne.izone_revap).and. enddo !do izone=1,nzone #ifdef ISOVERIF ! write(*,*) 'iiso=',iiso ! write(*,*) 'fxtqe=',fxtqe(iiso) ! write(*,*) 'fxtYe=',fxtYe(iiso) ! write(*,*) 'fxt_revap=',fxt_revap(iiso) ! write(*,*) 'fxtXe=',fxtXe(iiso) ! write(*,*) 'Xe=',Xe(iiso) ! write(*,*) 'xt=',xt(:,il,i) call iso_verif_traceur_justmass(fxt(1,il,i), & & 'cv30_routine 4646') #endif else !if (abs(dXe).gt.ridicule) then ! dans ce cas, fxtXe doit etre faible #ifdef ISOVERIF if (delt*fxtXe(iiso).gt.ridicule) then write(*,*) 'cv30_routines 6563: delt*fxtXe(iiso)=', & & delt*fxtXe(iiso) stop endif #endif do izone=1,nzone if ((izone.ne.izone_revap).and. & & (izone.ne.izone_ddft)) then ixt=itZonIso(izone,iiso) if (izone.eq.izone_poubelle) then fxt(ixt,il,i)=fxt(ixt,il,i)+fxtXe(iiso) else !if (izone.eq.izone_poubelle) then ! pas de tendance pour ce tag la endif !if (izone.eq.izone_poubelle) then endif !if ((izone.ne.izone_revap).and. enddo !do izone=1,nzone #ifdef ISOVERIF call iso_verif_traceur_justmass(fxt(1,il,i), & & 'cv30_routine 4671') #endif endif !if (abs(dXe).gt.ridicule) then enddo !do iiso = 1, niso else !if (mp(il,i).gt.mp(il,i+1)) then ! cas detrainant: pas de problemes do ixt=1+niso,ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.01*grav*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo !do ixt=1+niso,ntraciso #ifdef ISOVERIF call iso_verif_traceur_justmass(fxt(1,il,i), & & 'cv30_routine 4685') #endif endif !if (mp(il,i).gt.mp(il,i+1)) then endif !if (option_traceurs.eq.6) then ! write(*,*) 'delt*conversion=',delt*conversion(iso_eau) ! write(*,*) 'delt*fxtYe=',delt*fxtYe(iso_eau) ! write(*,*) 'delt*fxtqe=',delt*fxtqe(iso_eau) endif ! if ((option_traceurs.ne.6).and.(option_traceurs.ne.19)) then #endif ! cam verif #ifdef ISOVERIF do ixt=1,niso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_routines 3496') enddo #endif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3493',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if (1.eq.0) then if ((iso_HDO.gt.0).and.(delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop( & & fxt(iso_HDO,il,i)/fr(il,i), & & 'cv30_yield 3662').eq.1) then write(*,*) 'il,i,icb(il),inb(il)=',il,i,icb(il),inb(il) write(*,*) 'fr(il,i),delt=',fr(il,i),delt #ifdef DIAGISO if (fq_ddft(il,i).ne.0.0) then write(*,*) 'fq_ddft,deltaD=',fq_ddft(il,i),deltaD( & & fxt_ddft(iso_HDO,il,i)/fq_ddft(il,i)) endif !if (fq_ddft(il,i).ne.0.0) then if (fq_evapprecip(il,i).ne.0.0) then write(*,*) 'fq_evapprecip,deltaD=',fq_evapprecip(il,i), & & deltaD(fxt_evapprecip(iso_HDO,il,i) & & /fq_evapprecip(il,i)) endif !if (fq_evapprecip(il,i).ne.0.0) then #endif endif !if (iso_verif_aberrant_enc_nostop( endif !if (iso_HDO.gt.0) then endif !if (1.eq.0) then if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3757, ddfts') & & .eq.1) then write(*,*) 'i,il,q,deltaD=',i,il,rr(il,i),deltaD( & & xt(iso_HDO,il,i)/rr(il,i)) write(*,*) 'i,il,fr,deltaD=',i,il,fr(il,i),deltaD( & & fxt(iso_HDO,il,i)/fr(il,i)) stop endif ! if (iso_verif_aberrant_enc_nostop endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 5250,O18, ddfts') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC ! write(*,*) 'tmp cv3_yield 4224: i,il=',i,il call iso_verif_traceur_justmass(fxt(1,il,i),'cv30_routine 4107') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,i)+delt*fxt(ixt,il,i) enddo if (iso_verif_tracpos_choix_nostop(xtnew, & & 'cv30_yield 4221',1e-5).eq.1) then write(*,*) 'delt*fxt(,il,i)=',delt*fxt(1:ntraciso:2,il,i) write(*,*) 'delt*fxt(,il,i)=',delt*fxt(:,il,i) write(*,*) 'xt(,il,i)=',xt(:,il,i) write(*,*) 'delt,sigd,grav,dpinv=',delt,sigd,grav,dpinv write(*,*) 'xtevap(,il,i)=',xtevap(:,il,i) write(*,*) 'xtevap(,il,i+1)=',xtevap(:,il,i+1) write(*,*) 'mp(il,i+1),mp(il,i)=',mp(il,i+1),mp(il,i) write(*,*) 'xtp(,il,i)=',xtp(:,il,i) write(*,*) 'xtp(,il,i+1)=',xtp(:,il,i+1) write(*,*) 'xt(,il,i)=',xt(:,il,i) write(*,*) 'xt(,il,i-1)=',xt(:,il,i-1) ! rappel: fxt(ixt,il,i)=fxt(ixt,il,i) ! 0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) ! : +0.01*grav*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) ! : -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv ! stop endif #endif #endif #endif ELSE ! cvflag_grav fr(il, i) = fr(il, i) + 0.5*sigd*(evap(il,i)+evap(il,i+1)) + & 0.1*(mp(il,i+1)*(rp(il,i+1)-rr(il,i))-mp(il,i)*(rp(il,i)-rr(il, & i-1)))*dpinv fu(il, i) = fu(il, i) + 0.1*(mp(il,i+1)*(up(il,i+1)-u(il, & i))-mp(il,i)*(up(il,i)-u(il,i-1)))*dpinv fv(il, i) = fv(il, i) + 0.1*(mp(il,i+1)*(vp(il,i+1)-v(il, & i))-mp(il,i)*(vp(il,i)-v(il,i-1)))*dpinv #ifdef ISO do ixt = 1, ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) & & +0.1*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo ! ixt=1,niso #ifdef ISOTRAC if (option_traceurs.ne.6) then ! facile: on fait comme l'eau do ixt = 1+niso,ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) & & +0.01*grav*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo !do ixt = 1+niso,ntraciso else !if (option_traceurs.ne.6) then ! taggage des ddfts: voir blabla + haut do ixt = 1+niso,ntraciso fxt(ixt,il,i)=fxt(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) enddo !do ixt = 1+niso,ntraciso ! write(*,*) 'tmp cv3_yield 4165: i,il=',i,il ! ixt_poubelle=itZonIso(izone_poubelle,iso_eau) ! ixt_ddft=itZonIso(izone_ddft,iso_eau) ! write(*,*) 'delt*fxt(ixt_poubelle,il,i)=', ! : delt*fxt(ixt_poubelle,il,i) ! write(*,*) 'delt*fxt(ixt_ddft,il,i)=',delt*fxt(ixt_ddft,il,i) ! write(*,*) 'xt(iso_eau,il,i)=',xt(iso_eau,il,i) do iiso = 1, niso ixt_poubelle=itZonIso(izone_poubelle,iiso) ixt_ddft=itZonIso(izone_ddft,iiso) if (mp(il,i).gt.mp(il,i+1)) then fxtYe(iiso)=0.01*grav*dpinv*mp(il,i) & & *(xt(ixt_ddft,il,i-1)-xt(ixt_ddft,il,i)) else !if (mp(il,i).gt.mp(il,i+1)) then fxtYe(iiso)=0.01*grav*dpinv*(mp(il,i) & & *xt(ixt_ddft,il,i-1)-mp(il,i+1)*xt(ixt_ddft,il,i) & & +(mp(il,i+1)-mp(il,i))*xtp(ixt_ddft,il,i)) endif !if (mp(il,i).gt.mp(il,i+1)) then fxtqe(iiso)=0.01*grav*dpinv* & & (mp(il,i+1)*(xtp(iiso,il,i+1)-xt(iiso,il,i)) & & -mp(il,i)*(xtp(iiso,il,i)-xt(iiso,il,i-1))) fxt(ixt_ddft,il,i)=fxt(ixt_ddft,il,i)+fxtYe(iiso) fxt(ixt_poubelle,il,i)=fxt(ixt_poubelle,il,i) & & +fxtqe(iiso)-fxtYe(iiso) enddo !do iiso = 1, niso ! write(*,*) 'delt*conversion=',delt*conversion(iso_eau) ! write(*,*) 'delt*fxtYe=',delt*fxtYe(iso_eau) ! write(*,*) 'delt*fxtqe=',delt*fxtqe(iso_eau) endif !if (option_traceurs.eq.6) then #endif #ifdef DIAGISO fq_evapprecip(il,i)=fq_evapprecip(il,i) & & +0.5*sigd*(evap(il,i)+evap(il,i+1)) fq_ddft(il,i)=fq_ddft(il,i) & & +0.1*(mp(il,i+1)*(rp(il,i+1)-rr(il,i))-mp(il,i) & & *(rp(il,i)-rr(il,i-1)))*dpinv do ixt = 1, niso fxt_evapprecip(ixt,il,i)=fxt_evapprecip(ixt,il,i) & & +0.5*sigd*(xtevap(ixt,il,i)+xtevap(ixt,il,i+1)) fxt_ddft(ixt,il,i)=fxt_ddft(ixt,il,i) & & +0.1*(mp(il,i+1)*(xtp(ixt,il,i+1)-xt(ixt,il,i)) & & -mp(il,i)*(xtp(ixt,il,i)-xt(ixt,il,i-1)))*dpinv enddo ! ixt=1,niso #endif ! cam verif #ifdef ISOVERIF do ixt=1,niso call iso_verif_noNaN(fxt(ixt,il,i),'cv30_yield 5083') enddo #endif #ifdef ISOVERIF if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_routines 3522',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and.(delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop( & & fxt(iso_HDO,il,i)/fr(il,i), & & 'cv30_yield 3690').eq.1) then write(*,*) 'i,icb(il),inb(il)=',i,icb(il),inb(il) stop endif endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3757b, ddfts') endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3757b,O18, ddfts') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,i),'cv30_routine 4172') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,1)+delt*fxt(ixt,il,1) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 4295',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif ! call iso_verif_tracpos_choix(xtnew,'cv30_yield 4295',1e-5) #endif #endif ! end cam verif #endif END IF ! cvflag_grav END IF ! i END DO ! sb: interface with the cloud parameterization: ! cld DO k = i + 1, nl DO il = 1, ncum IF (k<=inb(il) .AND. i<=inb(il)) THEN ! cld ! (saturated downdrafts resulting from mixing) ! cld qcond(il, i) = qcond(il, i) + elij(il, k, i) ! cld nqcond(il, i) = nqcond(il, i) + 1. ! cld END IF ! cld END DO ! cld END DO ! cld ! (particular case: no detraining level is found) ! cld DO il = 1, ncum ! cld IF (i<=inb(il) .AND. nent(il,i)==0) THEN ! cld qcond(il, i) = qcond(il, i) + (1.-ep(il,i))*clw(il, i) ! cld nqcond(il, i) = nqcond(il, i) + 1. ! cld END IF ! cld END DO ! cld DO il = 1, ncum ! cld IF (i<=inb(il) .AND. nqcond(il,i)/=0.) THEN ! cld qcond(il, i) = qcond(il, i)/nqcond(il, i) ! cld END IF ! cld END DO ! do j=1,ntra ! do il=1,ncum ! if (i.le.inb(il)) then ! dpinv=1.0/(ph(il,i)-ph(il,i+1)) ! cpinv=1.0/cpn(il,i) ! if (cvflag_grav) then ! ftra(il,i,j)=ftra(il,i,j)+0.01*grav*dpinv ! : *(mp(il,i+1)*(trap(il,i+1,j)-tra(il,i,j)) ! : -mp(il,i)*(trap(il,i,j)-tra(il,i-1,j))) ! else ! ftra(il,i,j)=ftra(il,i,j)+0.1*dpinv ! : *(mp(il,i+1)*(trap(il,i+1,j)-tra(il,i,j)) ! : -mp(il,i)*(trap(il,i,j)-tra(il,i-1,j))) ! endif ! endif ! i ! enddo ! enddo 500 END DO ! *** move the detrainment at level inb down to level inb-1 *** ! *** in such a way as to preserve the vertically *** ! *** integrated enthalpy and water tendencies *** DO il = 1, ncum ! attention, on corrige un probleme C Risi IF (cvflag_grav) then ax = 0.01*grav*ment(il, inb(il), inb(il))*(hp(il,inb(il))-h(il,inb(il))+t(il, & inb(il))*(cpv-cpd)*(rr(il,inb(il))-qent(il,inb(il), & inb(il))))/(cpn(il,inb(il))*(ph(il,inb(il))-ph(il,inb(il)+1))) ft(il, inb(il)) = ft(il, inb(il)) - ax ft(il, inb(il)-1) = ft(il, inb(il)-1) + ax*cpn(il, inb(il))*(ph(il,inb(il & ))-ph(il,inb(il)+1))/(cpn(il,inb(il)-1)*(ph(il,inb(il)-1)-ph(il, & inb(il)))) bx = 0.01*grav*ment(il, inb(il), inb(il))*(qent(il,inb(il),inb(il))-rr(il,inb( & il)))/(ph(il,inb(il))-ph(il,inb(il)+1)) fr(il, inb(il)) = fr(il, inb(il)) - bx fr(il, inb(il)-1) = fr(il, inb(il)-1) + bx*(ph(il,inb(il))-ph(il,inb(il)+ & 1))/(ph(il,inb(il)-1)-ph(il,inb(il))) cx = 0.01*grav*ment(il, inb(il), inb(il))*(uent(il,inb(il),inb(il))-u(il,inb(il & )))/(ph(il,inb(il))-ph(il,inb(il)+1)) fu(il, inb(il)) = fu(il, inb(il)) - cx fu(il, inb(il)-1) = fu(il, inb(il)-1) + cx*(ph(il,inb(il))-ph(il,inb(il)+ & 1))/(ph(il,inb(il)-1)-ph(il,inb(il))) dx = 0.01*grav*ment(il, inb(il), inb(il))*(vent(il,inb(il),inb(il))-v(il,inb(il & )))/(ph(il,inb(il))-ph(il,inb(il)+1)) fv(il, inb(il)) = fv(il, inb(il)) - dx fv(il, inb(il)-1) = fv(il, inb(il)-1) + dx*(ph(il,inb(il))-ph(il,inb(il)+ & 1))/(ph(il,inb(il)-1)-ph(il,inb(il))) #ifdef ISO do ixt = 1, ntraciso xtbx(ixt)=0.01*grav*ment(il,inb(il),inb(il)) & & *(xtent(ixt,il,inb(il),inb(il)) & & -xt(ixt,il,inb(il)))/(ph(il,inb(il))-ph(il,inb(il)+1)) fxt(ixt,il,inb(il))=fxt(ixt,il,inb(il))-xtbx(ixt) fxt(ixt,il,inb(il)-1)=fxt(ixt,il,inb(il)-1) & & +xtbx(ixt)*(ph(il,inb(il))-ph(il,inb(il)+1)) & & /(ph(il,inb(il)-1)-ph(il,inb(il))) enddo !do ixt = 1, niso #endif else !IF (cvflag_grav) ax = 0.1*ment(il, inb(il), inb(il))*(hp(il,inb(il))-h(il,inb(il))+t(il, & inb(il))*(cpv-cpd)*(rr(il,inb(il))-qent(il,inb(il), & inb(il))))/(cpn(il,inb(il))*(ph(il,inb(il))-ph(il,inb(il)+1))) ft(il, inb(il)) = ft(il, inb(il)) - ax ft(il, inb(il)-1) = ft(il, inb(il)-1) + ax*cpn(il, inb(il))*(ph(il,inb(il & ))-ph(il,inb(il)+1))/(cpn(il,inb(il)-1)*(ph(il,inb(il)-1)-ph(il, & inb(il)))) bx = 0.1*ment(il, inb(il), inb(il))*(qent(il,inb(il),inb(il))-rr(il,inb( & il)))/(ph(il,inb(il))-ph(il,inb(il)+1)) fr(il, inb(il)) = fr(il, inb(il)) - bx fr(il, inb(il)-1) = fr(il, inb(il)-1) + bx*(ph(il,inb(il))-ph(il,inb(il)+ & 1))/(ph(il,inb(il)-1)-ph(il,inb(il))) cx = 0.1*ment(il, inb(il), inb(il))*(uent(il,inb(il),inb(il))-u(il,inb(il & )))/(ph(il,inb(il))-ph(il,inb(il)+1)) fu(il, inb(il)) = fu(il, inb(il)) - cx fu(il, inb(il)-1) = fu(il, inb(il)-1) + cx*(ph(il,inb(il))-ph(il,inb(il)+ & 1))/(ph(il,inb(il)-1)-ph(il,inb(il))) dx = 0.1*ment(il, inb(il), inb(il))*(vent(il,inb(il),inb(il))-v(il,inb(il & )))/(ph(il,inb(il))-ph(il,inb(il)+1)) fv(il, inb(il)) = fv(il, inb(il)) - dx fv(il, inb(il)-1) = fv(il, inb(il)-1) + dx*(ph(il,inb(il))-ph(il,inb(il)+ & 1))/(ph(il,inb(il)-1)-ph(il,inb(il))) #ifdef ISO do ixt = 1, ntraciso xtbx(ixt)=0.1*ment(il,inb(il),inb(il)) & & *(xtent(ixt,il,inb(il),inb(il)) & & -xt(ixt,il,inb(il)))/(ph(il,inb(il))-ph(il,inb(il)+1)) fxt(ixt,il,inb(il))=fxt(ixt,il,inb(il))-xtbx(ixt) fxt(ixt,il,inb(il)-1)=fxt(ixt,il,inb(il)-1) & & +xtbx(ixt)*(ph(il,inb(il))-ph(il,inb(il)+1)) & & /(ph(il,inb(il)-1)-ph(il,inb(il))) enddo !do ixt = 1, niso #endif endif !IF (cvflag_grav) #ifdef ISO #ifdef DIAGISO fq_detrainement(il,inb(il))=fq_detrainement(il,inb(il))-bx fq_detrainement(il,inb(il)-1)=fq_detrainement(il,inb(il)-1) & & +bx*(ph(il,inb(il))-ph(il,inb(il)+1)) & & /(ph(il,inb(il)-1)-ph(il,inb(il))) do ixt = 1, niso fxt_detrainement(ixt,il,inb(il))= & & fxt_detrainement(ixt,il,inb(il))-xtbx(ixt) fxt_detrainement(ixt,il,inb(il)-1)= & & fxt_detrainement(ixt,il,inb(il)-1) & & +xtbx(ixt)*(ph(il,inb(il))-ph(il,inb(il)+1)) & & /(ph(il,inb(il)-1)-ph(il,inb(il))) enddo #endif ! cam verif #ifdef ISOVERIF do ixt=1,niso call iso_verif_noNaN(fxt(ixt,il,inb(il)),'cv30_yield 5083') enddo if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,inb(il)), & & fr(il,inb(il)),'cv30_routines 3638',errmax,errmaxrel) call iso_verif_egalite_choix(fxt(iso_eau,il,inb(il)-1), & & fr(il,inb(il)-1),'cv30_routines 3640',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,inb(il))+delt*fr(il,inb(il)).gt.ridicule)) then call iso_verif_aberrant_encadre( & & (xt(iso_HDO,il,inb(il))+delt*fxt(iso_HDO,il,inb(il))) & & /(rr(il,inb(il))+delt*fr(il,inb(il))), & & 'cv30_yield 3921, en inb') if (iso_O18.gt.0) then if (iso_verif_O18_aberrant_nostop( & & (xt(iso_HDO,il,inb(il))+delt*fxt(iso_HDO,il,inb(il))) & & /(rr(il,inb(il))+delt*fr(il,inb(il))), & & (xt(iso_O18,il,inb(il))+delt*fxt(iso_O18,il,inb(il))) & & /(rr(il,inb(il))+delt*fr(il,inb(il))), & & 'cv30_yield 3921O18, en inb').eq.1) then write(*,*) 'il,inb(il)=',il,inb(il) k_tmp=0.1*ment(il,inb(il),inb(il))/(ph(il,inb(il))-ph(il,inb(il)+1)) write(*,*) 'fr,frprec=',fr(il,inb(il)),fr(il,inb(il))+bx write(*,*) 'M,dt,k_tmp*dt=',k_tmp,delt,k_tmp*delt write(*,*) 'q,qe=',rr(il,inb(il)),qent(il,inb(il),inb(il)) write(*,*) 'r=',k_tmp*delt*qent(il,inb(il),inb(il))/rr(il,inb(il)) write(*,*) 'deltaDR,Re=',deltaD(xt(iso_HDO,il,inb(il))/rr(il,inb(il))), & & deltaD(xtent(iso_HDO,il,inb(il),inb(il))/qent(il,inb(il),inb(il))) write(*,*) 'deltaO18R,Re=',deltaO(xt(iso_O18,il,inb(il))/rr(il,inb(il))), & & deltaO(xtent(iso_O18,il,inb(il),inb(il))/qent(il,inb(il),inb(il))) stop endif !if (iso_verif_O18_aberrant_nostop endif !if (iso_O18.gt.0) then endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,inb(il)-1)+delt*fr(il,inb(il)-1).gt.ridicule)) then call iso_verif_aberrant_encadre( & & (xt(iso_HDO,il,inb(il)-1) & & +delt*fxt(iso_HDO,il,inb(il)-1)) & & /(rr(il,inb(il)-1)+delt*fr(il,inb(il)-1)), & & 'cv30_yield 3921b, en inb-1') if (iso_O18.gt.0) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,inb(il)-1)+delt*fxt(iso_HDO,il,inb(il)-1)) & & /(rr(il,inb(il)-1)+delt*fr(il,inb(il)-1)), & & (xt(iso_O18,il,inb(il)-1)+delt*fxt(iso_O18,il,inb(il)-1)) & & /(rr(il,inb(il)-1)+delt*fr(il,inb(il)-1)), & & 'cv30_yield 3921cO18, en inb-1') endif endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,inb(il)-1), & & 'cv30_routine 4364') call iso_verif_traceur_justmass(fxt(1,il,inb(il)), & & 'cv30_routine 4364b') do ixt=1,ntraciso xtnew(ixt)=xt(ixt,il,inb(il))+delt*fxt(ixt,il,inb(il)) enddo if (iso_verif_tracpos_choix_nostop(xtnew,'cv30_yield 4492',1e-5) & & .eq.1) then write(*,*) 'il,i=',il,i endif ! call iso_verif_tracpos_choix(xtnew,'cv30_yield 4492',1e-5) #endif #endif ! end cam verif #endif END DO ! do j=1,ntra ! do il=1,ncum ! ex=0.1*ment(il,inb(il),inb(il)) ! : *(traent(il,inb(il),inb(il),j)-tra(il,inb(il),j)) ! : /(ph(il,inb(il))-ph(il,inb(il)+1)) ! ftra(il,inb(il),j)=ftra(il,inb(il),j)-ex ! ftra(il,inb(il)-1,j)=ftra(il,inb(il)-1,j) ! : +ex*(ph(il,inb(il))-ph(il,inb(il)+1)) ! : /(ph(il,inb(il)-1)-ph(il,inb(il))) ! enddo ! enddo ! *** homoginize tendencies below cloud base *** DO il = 1, ncum asum(il) = 0.0 bsum(il) = 0.0 csum(il) = 0.0 dsum(il) = 0.0 #ifdef ISO frsum(il)=0.0 do ixt=1,ntraciso fxtsum(ixt,il)=0.0 bxtsum(ixt,il)=0.0 enddo #endif END DO DO i = 1, nl DO il = 1, ncum IF (i<=(icb(il)-1)) THEN asum(il) = asum(il) + ft(il, i)*(ph(il,i)-ph(il,i+1)) bsum(il) = bsum(il) + fr(il, i)*(lv(il,i)+(cl-cpd)*(t(il,i)-t(il, & 1)))*(ph(il,i)-ph(il,i+1)) csum(il) = csum(il) + (lv(il,i)+(cl-cpd)*(t(il,i)-t(il, & 1)))*(ph(il,i)-ph(il,i+1)) dsum(il) = dsum(il) + t(il, i)*(ph(il,i)-ph(il,i+1))/th(il, i) #ifdef ISO frsum(il)=frsum(il)+fr(il,i) do ixt=1,ntraciso fxtsum(ixt,il)=fxtsum(ixt,il)+fxt(ixt,il,i) bxtsum(ixt,il)=bxtsum(ixt,il)+fxt(ixt,il,i) & & *(lv(il,i)+(cl-cpd)*(t(il,i)-t(il,1))) & & *(ph(il,i)-ph(il,i+1)) enddo #endif END IF END DO END DO ! !!! do 700 i=1,icb(il)-1 DO i = 1, nl DO il = 1, ncum IF (i<=(icb(il)-1)) THEN ft(il, i) = asum(il)*t(il, i)/(th(il,i)*dsum(il)) fr(il, i) = bsum(il)/csum(il) #ifdef ISO if (abs(csum(il)).gt.0.0) then do ixt=1,ntraciso fxt(ixt,il,i)=bxtsum(ixt,il)/csum(il) enddo else !if (frsum(il).gt.ridicule) then if (abs(frsum(il)).gt.0.0) then do ixt=1,ntraciso fxt(ixt,il,i)=fr(il,i)*fxtsum(ixt,il)/frsum(il) enddo else !if (abs(frsum(il)).gt.0.0) then if (abs(fr(il,i))*delt.gt.ridicule) then write(*,*) 'cv30_yield 4048: fr(il,i)=',fr(il,i) stop else !if (abs(fr(il,i))*delt.gt.ridicule) then do ixt=1,ntraciso fxt(ixt,il,i)=0.0 enddo if (iso_eau.gt.0) then fxt(iso_eau,il,i)=1.0 endif endif !if (abs(fr(il,i))*delt.gt.ridicule) then endif !if (abs(frsum(il)).gt.0.0) then endif !if (frsum(il).gt.0) then #endif END IF END DO END DO #ifdef ISO #ifdef ISOVERIF do i=1,nl do il=1,ncum do ixt=1,ntraciso call iso_verif_noNAN(fxt(ixt,il,i),'cv30_yield 3826') enddo enddo enddo #endif #ifdef ISOVERIF do i=1,nl ! write(*,*) 'cv30_routines temp 3967: i=',i do il=1,ncum ! write(*,*) 'cv30_routines 3969: il=',il ! write(*,*) 'cv30_routines temp 3967: il,i,inb(il),ncum=', ! : il,i,inb(il),ncum ! write(*,*) 'cv30_routines 3974' if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_yield 3830',errmax,errmaxrel) endif !if (iso_eau.gt.0) then ! write(*,*) 'cv30_routines 3979' if ((iso_HDO.gt.0).and. & & (delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop( & & fxt(iso_HDO,il,i)/fr(il,i), & & 'cv30_yield 3834').eq.1) then if (fr(il,i).gt.ridicule*1e5) then write(*,*) 'il,i,icb(il)=',il,i,icb(il) write(*,*) 'frsum(il)=',frsum(il) write(*,*) 'fr(il,i)=',fr(il,i) write(*,*) 'csum(il)=',csum(il) write(*,*) & & 'deltaD(bxtsum(iso_HDO,il)/csum(il))=', & & deltaD(bxtsum(iso_HDO,il)/csum(il)) ! stop endif ! write(*,*) 'cv30_routines 3986: temporaire' endif !if (iso_verif_aberrant_enc_nostop endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then if (iso_verif_aberrant_enc_nostop( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)),'cv30_yield 3921c, dans la CL') & & .eq.1) then write(*,*) 'il,i,icb(il)=',il,i,icb(il) write(*,*) 'frsum(il)=',frsum(il) write(*,*) 'fr(il,i)=',fr(il,i) stop endif endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 3921d, dans la CL') endif !if (iso_HDO.gt.0) then #ifdef ISOTRAC call iso_verif_traceur_justmass(fxt(1,il,i), & & 'cv30_routine 4523') #endif ! write(*,*) 'cv30_routines 3994' enddo !do il=1,ncum ! write(*,*) 'cv30_routine 3990: fin des il pour i=',i enddo !do i=1,nl ! write(*,*) 'cv30_routine 3990: fin des verifs sur homogen' #endif #ifdef ISOVERIF ! verif finale des tendances: do i=1,nl do il=1,ncum if (iso_eau.gt.0) then call iso_verif_egalite_choix(fxt(iso_eau,il,i), & & fr(il,i),'cv30_yield 3830',errmax,errmaxrel) endif !if (iso_eau.gt.0) then if ((iso_HDO.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_aberrant_encadre((xt(iso_HDO,il,i) & & +delt*fxt(iso_HDO,il,i)) & & /(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 5710a, final') endif !if (iso_HDO.gt.0) then if ((iso_HDO.gt.0).and.(iso_O18.gt.0).and. & & (rr(il,i)+delt*fr(il,i).gt.ridicule)) then call iso_verif_O18_aberrant( & & (xt(iso_HDO,il,i)+delt*fxt(iso_HDO,il,i))/(rr(il,i)+delt*fr(il,i)), & & (xt(iso_O18,il,i)+delt*fxt(iso_O18,il,i))/(rr(il,i)+delt*fr(il,i)), & & 'cv30_yield 5710b, final') endif !if (iso_HDO.gt.0) then enddo !do il=1,ncum enddo !do i=1,nl #endif #endif ! *** reset counter and return *** DO il = 1, ncum sig(il, nd) = 2.0 END DO DO i = 1, nd DO il = 1, ncum upwd(il, i) = 0.0 dnwd(il, i) = 0.0 END DO END DO DO i = 1, nl DO il = 1, ncum dnwd0(il, i) = -mp(il, i) END DO END DO DO i = nl + 1, nd DO il = 1, ncum dnwd0(il, i) = 0. END DO END DO DO i = 1, nl DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il)) THEN upwd(il, i) = 0.0 dnwd(il, i) = 0.0 END IF END DO END DO DO i = 1, nl DO k = 1, nl DO il = 1, ncum up1(il, k, i) = 0.0 dn1(il, k, i) = 0.0 END DO END DO END DO DO i = 1, nl DO k = i, nl DO n = 1, i - 1 DO il = 1, ncum IF (i>=icb(il) .AND. i<=inb(il) .AND. k<=inb(il)) THEN up1(il, k, i) = up1(il, k, i) + ment(il, n, k) dn1(il, k, i) = dn1(il, k, i) - ment(il, k, n) END IF END DO END DO END DO END DO DO i = 2, nl DO k = i, nl DO il = 1, ncum ! test if (i.ge.icb(il).and.i.le.inb(il).and.k.le.inb(il)) ! then IF (i<=inb(il) .AND. k<=inb(il)) THEN upwd(il, i) = upwd(il, i) + m(il, k) + up1(il, k, i) dnwd(il, i) = dnwd(il, i) + dn1(il, k, i) END IF END DO END DO END DO ! !!! DO il=1,ncum ! !!! do i=icb(il),inb(il) ! !!! ! !!! upwd(il,i)=0.0 ! !!! dnwd(il,i)=0.0 ! !!! do k=i,inb(il) ! !!! up1=0.0 ! !!! dn1=0.0 ! !!! do n=1,i-1 ! !!! up1=up1+ment(il,n,k) ! !!! dn1=dn1-ment(il,k,n) ! !!! enddo ! !!! upwd(il,i)=upwd(il,i)+m(il,k)+up1 ! !!! dnwd(il,i)=dnwd(il,i)+dn1 ! !!! enddo ! !!! enddo ! !!! ! !!! ENDDO ! ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc ! determination de la variation de flux ascendant entre ! deux niveau non dilue mike ! ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc DO i = 1, nl DO il = 1, ncum mike(il, i) = m(il, i) END DO END DO DO i = nl + 1, nd DO il = 1, ncum mike(il, i) = 0. END DO END DO DO i = 1, nd DO il = 1, ncum ma(il, i) = 0 END DO END DO DO i = 1, nl DO j = i, nl DO il = 1, ncum ma(il, i) = ma(il, i) + m(il, j) END DO END DO END DO DO i = nl + 1, nd DO il = 1, ncum ma(il, i) = 0. END DO END DO DO i = 1, nl DO il = 1, ncum IF (i<=(icb(il)-1)) THEN ma(il, i) = 0 END IF END DO END DO ! cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc ! icb represente de niveau ou se trouve la ! base du nuage , et inb le top du nuage ! ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc DO i = 1, nd DO il = 1, ncum mke(il, i) = upwd(il, i) + dnwd(il, i) END DO END DO DO i = 1, nd DO il = 1, ncum rdcp = (rrd*(1.-rr(il,i))-rr(il,i)*rrv)/(cpd*(1.-rr(il, & i))+rr(il,i)*cpv) tls(il, i) = t(il, i)*(1000.0/p(il,i))**rdcp tps(il, i) = tp(il, i) END DO END DO ! *** diagnose the in-cloud mixing ratio *** ! cld ! *** of condensed water *** ! cld ! ! cld DO i = 1, nd ! cld DO il = 1, ncum ! cld mac(il, i) = 0.0 ! cld wa(il, i) = 0.0 ! cld siga(il, i) = 0.0 ! cld sax(il, i) = 0.0 ! cld END DO ! cld END DO ! cld DO i = minorig, nl ! cld DO k = i + 1, nl + 1 ! cld DO il = 1, ncum ! cld IF (i<=inb(il) .AND. k<=(inb(il)+1)) THEN ! cld mac(il, i) = mac(il, i) + m(il, k) ! cld END IF ! cld END DO ! cld END DO ! cld END DO ! cld DO i = 1, nl ! cld DO j = 1, i ! cld DO il = 1, ncum ! cld IF (i>=icb(il) .AND. i<=(inb(il)-1) & ! cld .AND. j>=icb(il)) THEN ! cld sax(il, i) = sax(il, i) + rrd*(tvp(il,j)-tv(il,j)) & ! cld *(ph(il,j)-ph(il,j+1))/p(il, j) ! cld END IF ! cld END DO ! cld END DO ! cld END DO ! cld DO i = 1, nl ! cld DO il = 1, ncum ! cld IF (i>=icb(il) .AND. i<=(inb(il)-1) & ! cld .AND. sax(il,i)>0.0) THEN ! cld wa(il, i) = sqrt(2.*sax(il,i)) ! cld END IF ! cld END DO ! cld END DO ! cld DO i = 1, nl ! cld DO il = 1, ncum ! cld IF (wa(il,i)>0.0) & ! cld siga(il, i) = mac(il, i)/wa(il, i) & ! cld *rrd*tvp(il, i)/p(il, i)/100./delta ! cld siga(il, i) = min(siga(il,i), 1.0) ! cld ! IM cf. FH IF (iflag_clw==0) THEN qcondc(il, i) = siga(il, i)*clw(il, i)*(1.-ep(il,i)) & ! cld +(1.-siga(il,i))*qcond(il, i) ! cld ELSE IF (iflag_clw==1) THEN qcondc(il, i) = qcond(il, i) ! cld END IF END DO ! cld END DO ! cld RETURN END SUBROUTINE cv30_yield ! !RomP >>> SUBROUTINE cv30_tracer(nloc, len, ncum, nd, na, ment, sij, da, phi, phi2, & d1a, dam, ep, vprecip, elij, clw, epmlmmm, eplamm, icb, inb) IMPLICIT NONE include "cv30param.h" ! inputs: INTEGER ncum, nd, na, nloc, len REAL ment(nloc, na, na), sij(nloc, na, na) REAL clw(nloc, nd), elij(nloc, na, na) REAL ep(nloc, na) INTEGER icb(nloc), inb(nloc) REAL vprecip(nloc, nd+1) ! ouputs: REAL da(nloc, na), phi(nloc, na, na) REAL phi2(nloc, na, na) REAL d1a(nloc, na), dam(nloc, na) REAL epmlmmm(nloc, na, na), eplamm(nloc, na) ! variables pour tracer dans precip de l'AA et des mel ! local variables: INTEGER i, j, k, nam1 REAL epm(nloc, na, na) nam1=na-1 ! Introduced because ep is not defined for j=na ! variables d'Emanuel : du second indice au troisieme ! ---> tab(i,k,j) -> de l origine k a l arrivee j ! ment, sij, elij ! variables personnelles : du troisieme au second indice ! ---> tab(i,j,k) -> de k a j ! phi, phi2 ! initialisations DO j = 1, na DO i = 1, ncum da(i, j) = 0. d1a(i, j) = 0. dam(i, j) = 0. eplamm(i, j) = 0. END DO END DO DO k = 1, na DO j = 1, na DO i = 1, ncum epm(i, j, k) = 0. epmlmmm(i, j, k) = 0. phi(i, j, k) = 0. phi2(i, j, k) = 0. END DO END DO END DO ! fraction deau condensee dans les melanges convertie en precip : epm ! et eau condensee precipitee dans masse d'air sature : l_m*dM_m/dzdz.dzdz DO j = 1, nam1 DO k = 1, j - 1 DO i = 1, ncum IF (k>=icb(i) .AND. k<=inb(i) .AND. j<=inb(i)) THEN ! !jyg epm(i,j,k)=1.-(1.-ep(i,j))*clw(i,j)/elij(i,k,j) epm(i, j, k) = 1. - (1.-ep(i,j))*clw(i, j)/max(elij(i,k,j), 1.E-16) ! ! epm(i, j, k) = max(epm(i,j,k), 0.0) END IF END DO END DO END DO DO j = 1, nam1 DO k = 1, nam1 DO i = 1, ncum IF (k>=icb(i) .AND. k<=inb(i)) THEN eplamm(i, j) = eplamm(i, j) + ep(i, j)*clw(i, j)*ment(i, j, k)*(1.- & sij(i,j,k)) END IF END DO END DO END DO DO j = 1, nam1 DO k = 1, j - 1 DO i = 1, ncum IF (k>=icb(i) .AND. k<=inb(i) .AND. j<=inb(i)) THEN epmlmmm(i, j, k) = epm(i, j, k)*elij(i, k, j)*ment(i, k, j) END IF END DO END DO END DO ! matrices pour calculer la tendance des concentrations dans cvltr.F90 DO j = 1, nam1 DO k = 1, nam1 DO i = 1, ncum da(i, j) = da(i, j) + (1.-sij(i,k,j))*ment(i, k, j) phi(i, j, k) = sij(i, k, j)*ment(i, k, j) d1a(i, j) = d1a(i, j) + ment(i, k, j)*ep(i, k)*(1.-sij(i,k,j)) END DO END DO END DO DO j = 1, nam1 DO k = 1, j - 1 DO i = 1, ncum dam(i, j) = dam(i, j) + ment(i, k, j)*epm(i, j, k)*(1.-ep(i,k))*(1.- & sij(i,k,j)) phi2(i, j, k) = phi(i, j, k)*epm(i, j, k) END DO END DO END DO RETURN END SUBROUTINE cv30_tracer ! RomP <<< SUBROUTINE cv30_uncompress(nloc, len, ncum, nd, ntra, idcum, iflag, precip, & vprecip, evap, ep, sig, w0, ft, fq, fu, fv, ftra, inb, ma, upwd, dnwd, & dnwd0, qcondc, wd, cape, da, phi, mp, phi2, d1a, dam, sij, elij, clw, & epmlmmm, eplamm, wdtraina, wdtrainm,epmax_diag, iflag1, precip1, vprecip1, evap1, & ep1, sig1, w01, ft1, fq1, fu1, fv1, ftra1, inb1, ma1, upwd1, dnwd1, & dnwd01, qcondc1, wd1, cape1, da1, phi1, mp1, phi21, d1a1, dam1, sij1, & elij1, clw1, epmlmmm1, eplamm1, wdtraina1, wdtrainm1,epmax_diag1 & ! epmax_cape #ifdef ISO & ,xtprecip,fxt,xtVPrecip,xtevap,xtclw,xtwdtraina & & ,xtprecip1,fxt1,xtVPrecip1,xtevap1,xtclw1,xtwdtraina1 & #ifdef DIAGISO & , water,xtwater,qp,xtp & & , fq_detrainement,fq_ddft,fq_fluxmasse,fq_evapprecip & & , fxt_detrainement,fxt_ddft,fxt_fluxmasse, fxt_evapprecip & & , f_detrainement,q_detrainement,xt_detrainement & & , water1,xtwater1,qp1,xtp1 & & , fq_detrainement1,fq_ddft1,fq_fluxmasse1,fq_evapprecip1 & & , fxt_detrainement1,fxt_ddft1,fxt_fluxmasse1, fxt_evapprecip1 & & , f_detrainement1,q_detrainement1,xt_detrainement1 & #endif #endif & ) #ifdef ISO use infotrac_phy, ONLY: ntraciso=>ntiso #ifdef ISOVERIF use isotopes_verif_mod, ONLY: Tmin_verif,iso_verif_aberrant, & iso_verif_egalite,iso_verif_egalite_choix_nostop,iso_verif_positif_nostop, & iso_verif_egalite_nostop,iso_verif_aberrant_nostop,deltaD,iso_verif_noNaN_nostop, & iso_verif_positif,iso_verif_egalite_vect2D #endif #endif IMPLICIT NONE include "cv30param.h" ! inputs: INTEGER len, ncum, nd, ntra, nloc INTEGER idcum(nloc) INTEGER iflag(nloc) INTEGER inb(nloc) REAL precip(nloc) REAL vprecip(nloc, nd+1), evap(nloc, nd) REAL ep(nloc, nd) REAL sig(nloc, nd), w0(nloc, nd) REAL ft(nloc, nd), fq(nloc, nd), fu(nloc, nd), fv(nloc, nd) REAL ftra(nloc, nd, ntra) REAL ma(nloc, nd) REAL upwd(nloc, nd), dnwd(nloc, nd), dnwd0(nloc, nd) REAL qcondc(nloc, nd) REAL wd(nloc), cape(nloc) REAL da(nloc, nd), phi(nloc, nd, nd), mp(nloc, nd) REAL epmax_diag(nloc) ! epmax_cape ! RomP >>> REAL phi2(nloc, nd, nd) REAL d1a(nloc, nd), dam(nloc, nd) REAL wdtraina(nloc, nd), wdtrainm(nloc, nd) REAL sij(nloc, nd, nd) REAL elij(nloc, nd, nd), clw(nloc, nd) REAL epmlmmm(nloc, nd, nd), eplamm(nloc, nd) ! RomP <<< #ifdef ISO REAL xtprecip(ntraciso,nloc) REAL xtvprecip(ntraciso,nloc, nd+1), xtevap(ntraciso,nloc, nd) real fxt(ntraciso,nloc,nd) real xtclw(ntraciso,nloc,nd) REAL xtwdtraina(ntraciso,nloc, nd) #endif ! outputs: INTEGER iflag1(len) INTEGER inb1(len) REAL precip1(len) REAL vprecip1(len, nd+1), evap1(len, nd) !<<< RomP REAL ep1(len, nd) !<<< RomP REAL sig1(len, nd), w01(len, nd) REAL ft1(len, nd), fq1(len, nd), fu1(len, nd), fv1(len, nd) REAL ftra1(len, nd, ntra) REAL ma1(len, nd) REAL upwd1(len, nd), dnwd1(len, nd), dnwd01(len, nd) REAL qcondc1(nloc, nd) REAL wd1(nloc), cape1(nloc) REAL da1(nloc, nd), phi1(nloc, nd, nd), mp1(nloc, nd) REAL epmax_diag1(len) ! epmax_cape ! RomP >>> REAL phi21(len, nd, nd) REAL d1a1(len, nd), dam1(len, nd) REAL wdtraina1(len, nd), wdtrainm1(len, nd) REAL sij1(len, nd, nd) REAL elij1(len, nd, nd), clw1(len, nd) REAL epmlmmm1(len, nd, nd), eplamm1(len, nd) ! RomP <<< #ifdef ISO real xtprecip1(ntraciso,len) real fxt1(ntraciso,len,nd) real xtVPrecip1(ntraciso,len,nd+1),xtevap1(ntraciso,len, nd) REAL xtwdtraina1(ntraciso,len, nd) REAL xtclw1(ntraciso,len, nd) #endif ! local variables: INTEGER i, k, j #ifdef ISO integer ixt #endif #ifdef DIAGISO real water(nloc,nd) real xtwater(ntraciso,nloc,nd) real qp(nloc,nd),xtp(ntraciso,nloc,nd) real fq_detrainement(nloc,nd) real f_detrainement(nloc,nd) real q_detrainement(nloc,nd) real fq_ddft(nloc,nd) real fq_fluxmasse(nloc,nd) real fq_evapprecip(nloc,nd) real fxt_detrainement(ntraciso,nloc,nd) real xt_detrainement(ntraciso,nloc,nd) real fxt_ddft(ntraciso,nloc,nd) real fxt_fluxmasse(ntraciso,nloc,nd) real fxt_evapprecip(ntraciso,nloc,nd) real water1(len,nd) real xtwater1(ntraciso,len,nd) real qp1(len,nd),xtp1(ntraciso,len,nd) real fq_detrainement1(len,nd) real f_detrainement1(len,nd) real q_detrainement1(len,nd) real fq_ddft1(len,nd) real fq_fluxmasse1(len,nd) real fq_evapprecip1(len,nd) real fxt_detrainement1(ntraciso,len,nd) real xt_detrainement1(ntraciso,len,nd) real fxt_ddft1(ntraciso,len,nd) real fxt_fluxmasse1(ntraciso,len,nd) real fxt_evapprecip1(ntraciso,len,nd) #endif #ifdef ISOVERIF write(*,*) 'cv30_routines 4293: entree dans cv3_uncompress' #endif DO i = 1, ncum precip1(idcum(i)) = precip(i) iflag1(idcum(i)) = iflag(i) wd1(idcum(i)) = wd(i) inb1(idcum(i)) = inb(i) cape1(idcum(i)) = cape(i) epmax_diag1(idcum(i))=epmax_diag(i) ! epmax_cape #ifdef ISO do ixt = 1, ntraciso xtprecip1(ixt,idcum(i))=xtprecip(ixt,i) enddo #endif END DO DO k = 1, nl DO i = 1, ncum vprecip1(idcum(i), k) = vprecip(i, k) evap1(idcum(i), k) = evap(i, k) !<<< RomP sig1(idcum(i), k) = sig(i, k) w01(idcum(i), k) = w0(i, k) ft1(idcum(i), k) = ft(i, k) fq1(idcum(i), k) = fq(i, k) fu1(idcum(i), k) = fu(i, k) fv1(idcum(i), k) = fv(i, k) ma1(idcum(i), k) = ma(i, k) upwd1(idcum(i), k) = upwd(i, k) dnwd1(idcum(i), k) = dnwd(i, k) dnwd01(idcum(i), k) = dnwd0(i, k) qcondc1(idcum(i), k) = qcondc(i, k) da1(idcum(i), k) = da(i, k) mp1(idcum(i), k) = mp(i, k) ! RomP >>> ep1(idcum(i), k) = ep(i, k) d1a1(idcum(i), k) = d1a(i, k) dam1(idcum(i), k) = dam(i, k) clw1(idcum(i), k) = clw(i, k) eplamm1(idcum(i), k) = eplamm(i, k) wdtraina1(idcum(i), k) = wdtraina(i, k) wdtrainm1(idcum(i), k) = wdtrainm(i, k) ! RomP <<< #ifdef ISO do ixt = 1, ntraciso fxt1(ixt,idcum(i),k)=fxt(ixt,i,k) xtVPrecip1(ixt,idcum(i),k)=xtVPrecip(ixt,i,k) xtevap1(ixt,idcum(i),k)=xtevap(ixt,i,k) xtwdtraina1(ixt,idcum(i),k)=xtwdtraina(ixt,i,k) xtclw1(ixt,idcum(i),k)=xtclw(ixt,i,k) enddo #endif END DO END DO DO i = 1, ncum sig1(idcum(i), nd) = sig(i, nd) END DO #ifdef ISO #ifdef DIAGISO do k=1,nl do i=1,ncum water1(idcum(i),k)=water(i,k) qp1(idcum(i),k)=qp(i,k) evap1(idcum(i),k)=evap(i,k) fq_detrainement1(idcum(i),k)=fq_detrainement(i,k) f_detrainement1(idcum(i),k)=f_detrainement(i,k) q_detrainement1(idcum(i),k)=q_detrainement(i,k) fq_ddft1(idcum(i),k)=fq_ddft(i,k) fq_evapprecip1(idcum(i),k)=fq_evapprecip(i,k) fq_fluxmasse1(idcum(i),k)=fq_fluxmasse(i,k) do ixt = 1, ntraciso xtwater1(ixt,idcum(i),k)=xtwater(ixt,i,k) xtp1(ixt,idcum(i),k)=xtp(ixt,i,k) fxt_detrainement1(ixt,idcum(i),k)=fxt_detrainement(ixt,i,k) xt_detrainement1(ixt,idcum(i),k)=xt_detrainement(ixt,i,k) fxt_ddft1(ixt,idcum(i),k)=fxt_ddft(ixt,i,k) fxt_fluxmasse1(ixt,idcum(i),k)=fxt_fluxmasse(ixt,i,k) fxt_evapprecip1(ixt,idcum(i),k)=fxt_evapprecip(ixt,i,k) enddo enddo enddo do i=1,ncum epmax_diag1(idcum(i))=epmax_diag(i) enddo #endif #endif ! do 2100 j=1,ntra ! do 2110 k=1,nd ! oct3 ! do 2120 i=1,ncum ! ftra1(idcum(i),k,j)=ftra(i,k,j) ! 2120 continue ! 2110 continue ! 2100 continue DO j = 1, nd DO k = 1, nd DO i = 1, ncum sij1(idcum(i), k, j) = sij(i, k, j) phi1(idcum(i), k, j) = phi(i, k, j) phi21(idcum(i), k, j) = phi2(i, k, j) elij1(idcum(i), k, j) = elij(i, k, j) epmlmmm1(idcum(i), k, j) = epmlmmm(i, k, j) END DO END DO END DO RETURN END SUBROUTINE cv30_uncompress subroutine cv30_epmax_fn_cape(nloc,ncum,nd & ,cape,ep,hp,icb,inb,clw,nk,t,h,lv & ,epmax_diag) implicit none ! On fait varier epmax en fn de la cape ! Il faut donc recalculer ep, et hp qui a deja ete calcule et ! qui en depend ! Toutes les autres variables fn de ep sont calculees plus bas. #include "cvthermo.h" #include "cv30param.h" #include "conema3.h" ! inputs: integer ncum, nd, nloc integer icb(nloc), inb(nloc) real cape(nloc) real clw(nloc,nd),lv(nloc,nd),t(nloc,nd),h(nloc,nd) integer nk(nloc) ! inouts: real ep(nloc,nd) real hp(nloc,nd) ! outputs ou local real epmax_diag(nloc) ! locals integer i,k real hp_bak(nloc,nd) CHARACTER (LEN=20) :: modname='cv30_epmax_fn_cape' CHARACTER (LEN=80) :: abort_message ! on recalcule ep et hp if (coef_epmax_cape.gt.1e-12) then do i=1,ncum epmax_diag(i)=epmax-coef_epmax_cape*sqrt(cape(i)) do k=1,nl ep(i,k)=ep(i,k)/epmax*epmax_diag(i) ep(i,k)=amax1(ep(i,k),0.0) ep(i,k)=amin1(ep(i,k),epmax_diag(i)) enddo enddo ! On recalcule hp: do k=1,nl do i=1,ncum hp_bak(i,k)=hp(i,k) enddo enddo do k=1,nlp do i=1,ncum hp(i,k)=h(i,k) enddo enddo do k=minorig+1,nl do i=1,ncum if((k.ge.icb(i)).and.(k.le.inb(i)))then hp(i,k)=h(i,nk(i))+(lv(i,k)+(cpd-cpv)*t(i,k))*ep(i,k)*clw(i,k) endif enddo enddo !do k=minorig+1,n ! write(*,*) 'cv30_routines 6218: hp(1,20)=',hp(1,20) do i=1,ncum do k=1,nl if (abs(hp_bak(i,k)-hp(i,k)).gt.0.01) then write(*,*) 'i,k=',i,k write(*,*) 'coef_epmax_cape=',coef_epmax_cape write(*,*) 'epmax_diag(i)=',epmax_diag(i) write(*,*) 'ep(i,k)=',ep(i,k) write(*,*) 'hp(i,k)=',hp(i,k) write(*,*) 'hp_bak(i,k)=',hp_bak(i,k) write(*,*) 'h(i,k)=',h(i,k) write(*,*) 'nk(i)=',nk(i) write(*,*) 'h(i,nk(i))=',h(i,nk(i)) write(*,*) 'lv(i,k)=',lv(i,k) write(*,*) 't(i,k)=',t(i,k) write(*,*) 'clw(i,k)=',clw(i,k) write(*,*) 'cpd,cpv=',cpd,cpv CALL abort_physic(modname,abort_message,0) endif enddo !do k=1,nl enddo !do i=1,ncum endif !if (coef_epmax_cape.gt.1e-12) then return end subroutine cv30_epmax_fn_cape