Ignore:
Timestamp:
Jun 11, 2020, 11:09:43 AM (4 years ago)
Author:
adurocher
Message:

cv3p_mixing_new : change array temporaries into scalars

with reordered loops, some array temporaries are no longer necessary.
cv3p_mixing_new generates different results than
cv3p_mixing_old with -fp-model fast but not with -fp-model precise

File:
1 edited

Legend:

Unmodified
Added
Removed
  • LMDZ6/branches/Optimisation_LMDZ/libf/phylmd/cv3p_mixing.f90

    r3714 r3715  
    112112    REAL                               :: rti, bf2, anum, denom, dei, altem, cwat, stemp
    113113    REAL                               :: alt, delp, delm
    114     REAL, DIMENSION(nloc)             :: Qmixmax, Rmixmax, sqmrmax
    115     REAL, DIMENSION(nloc)             :: Qmixmin, Rmixmin, sqmrmin
    116     REAL, DIMENSION(nloc)             :: signhpmh
    117     REAL, DIMENSION(nloc)             :: Sx, smin
    118     REAL                               :: Scrit2
    119     REAL, DIMENSION(nloc)             :: Sjmin, Sjmax
    120     REAL, DIMENSION(nloc)             :: Sbef, sup
    121     REAL, DIMENSION(nloc, nd)         :: ASij
    122     REAL, DIMENSION(nloc)             :: ASij_inv, smax, Scrit
    123     REAL, DIMENSION(nloc, nd, nd)     :: Sij
    124     REAL, DIMENSION(nloc, nd)         :: csum
     114    REAL, DIMENSION(nloc, nd)          :: ASij
     115    REAL, DIMENSION(nloc, nd, nd)      :: Sij
    125116    REAL                               :: awat
    126117    REAL                               :: cpm        !Mixed draught heat capacity
     
    179170    Ment(1:ncum, 1:nd, 1:nd) = 0.0
    180171    Sij(1:ncum, 1:nd, 1:nd) = 0.0
    181     Sigij(1:ncum, 1:nd, 1:nd) = 0.0
    182172
    183173    ! =====================================================================
     
    287277    ! ---  TO REPRESENT EQUAL PROBABILITIES OF MIXING
    288278    ! =====================================================================
    289 
    290279    DO il = 1, ncum
    291280      DO i = icb(il), inb(il)      !Loop on origin level "i"
    292         signhpmh(il) = sign(1., hp(il, i) - h(il, i))
    293 
    294         Sx(il) = max(maxval(Sij(il, i, i + 1:inb(il))), 0., signhpmh(il))
    295 
    296         rti = qta(il, i - 1) - ep(il, i)*clw(il, i)
    297         IF (cvflag_ice) THEN
    298           anum = h(il, i) - hp(il, i) - (lv(il, i) + frac(il, i)*lf(il, i))* &
    299                  (rti - rs(il, i)) + (cpv - cpd)*t(il, i)*(rti - rr(il, i))
    300           denom = h(il, i) - hp(il, i) + (lv(il, i) + frac(il, i)*lf(il, i))* &
    301                   (rr(il, i) - rti) + (cpd - cpv)*t(il, i)*(rr(il, i) - rti)
    302         ELSE
    303           anum = h(il, i) - hp(il, i) - lv(il, i)*(rti - rs(il, i)) + &
    304                  (cpv - cpd)*t(il, i)*(rti - rr(il, i))
    305           denom = h(il, i) - hp(il, i) + lv(il, i)*(rr(il, i) - rti) + &
    306                   (cpd - cpv)*t(il, i)*(rr(il, i) - rti)
    307         END IF
    308         IF (abs(denom) < 0.01) denom = 0.01
    309         Scrit(il) = min(anum/denom, 1.)
    310         alt = rti - rs(il, i) + Scrit(il)*(rr(il, i) - rti)
    311 
    312         ! Find new critical value Scrit2
    313         ! such that : Sij > Scrit2  => mixed draught will detrain at J<I
    314         !             Sij < Scrit2  => mixed draught will detrain at J>I
    315         Scrit2 = min(Scrit(il), Sx(il))*max(0., -signhpmh(il)) + &
    316                  Scrit(il)*max(0., signhpmh(il))
    317         Scrit(il) = Scrit2
    318 
    319         ! Correction pour la nouvelle logique; la correction pour ALT
    320         ! est un peu au hazard
    321         IF (Scrit(il) <= 0.0) Scrit(il) = 0.0
    322         IF (alt <= 0.0) Scrit(il) = 1.0
    323 
    324         smax(il) = 0.0
    325         ASij(il, i) = 0.0
    326         sup(il) = 0.      ! upper S-value reached by descending draughts
    327 
    328         if (i < inb(il)) then
    329           Sbef(il) = Sij(il, i, inb(il))
    330         else
    331           Sbef(il) = max(0., signhpmh(il))
    332         endif
    333 
    334         DO j = (icb(il) - 1), inb(il) !Loop on destination level "j"
    335           IF (Sij(il, i, j) > 0.0) THEN
    336             ! -----------------------------------------------
    337             IF (j > i) THEN
    338               Smid = min(Sij(il, i, j), Scrit(il))
    339               Sjmax(il) = Smid
    340               Sjmin(il) = Smid
    341               IF (Smid < smin(il) .AND. Sij(il, i, j + 1) < Smid) THEN
    342                 smin(il) = min(smin(il), Smid)
    343                 Sjmax(il) = min((Sij(il, i, j + 1) + Sij(il, i, j))/2., Sij(il, i, j), Scrit(il))
    344                 Sjmin(il) = max((Sbef(il) + Sij(il, i, j))/2., Sij(il, i, j))
    345                 Sjmin(il) = min(Sjmin(il), Scrit(il))
    346                 Sbef(il) = Sij(il, i, j)
    347               END IF
    348             ELSE IF (j == i) THEN
    349               Smid = 1.
    350               Sjmin(il) = max((Sij(il, i, j - 1) + Smid)/2., Scrit(il))*max(0., -signhpmh(il)) + &
    351                           min((Sij(il, i, j + 1) + Smid)/2., Scrit(il))*max(0., signhpmh(il))
    352               Sjmin(il) = max(Sjmin(il), sup(il))
    353               Sjmax(il) = 1.
    354               ! preparation des variables Scrit, Smin et Sbef pour la partie j>i
    355               Scrit(il) = min(Sjmin(il), Sjmax(il), Scrit(il))
    356 
    357               smin(il) = 1.
    358               Sbef(il) = max(0., signhpmh(il))
    359               supmax(il, i) = sign(Scrit(il), -signhpmh(il))
    360             ELSE IF (j < i) THEN
    361               Smid = max(Sij(il, i, j), Scrit(il))
    362               Sjmax(il) = Smid
    363               Sjmin(il) = Smid
    364               IF (Smid > smax(il) .AND. Sij(il, i, j + 1) > Smid) THEN
    365                 smax(il) = Smid
    366                 Sjmax(il) = max((Sij(il, i, j + 1) + Sij(il, i, j))/2., Sij(il, i, j))
    367                 Sjmax(il) = max(Sjmax(il), Scrit(il))
    368                 Sjmin(il) = min((Sbef(il) + Sij(il, i, j))/2., Sij(il, i, j))
    369                 Sjmin(il) = max(Sjmin(il), Scrit(il))
    370                 Sbef(il) = Sij(il, i, j)
    371               END IF
    372               IF (abs(Sjmin(il) - Sjmax(il)) > 1.E-10) &
    373                 sup(il) = max(Sjmin(il), Sjmax(il), sup(il))
     281        block
     282          real :: signhpmh, Sx, Scrit
     283          real :: smax, sup, Sbef, smin
     284
     285          signhpmh = sign(1., hp(il, i) - h(il, i))
     286
     287          rti = qta(il, i - 1) - ep(il, i)*clw(il, i)
     288          IF (cvflag_ice) THEN
     289            anum = h(il, i) - hp(il, i) - (lv(il, i) + frac(il, i)*lf(il, i))* &
     290                   (rti - rs(il, i)) + (cpv - cpd)*t(il, i)*(rti - rr(il, i))
     291            denom = h(il, i) - hp(il, i) + (lv(il, i) + frac(il, i)*lf(il, i))* &
     292                    (rr(il, i) - rti) + (cpd - cpv)*t(il, i)*(rr(il, i) - rti)
     293          ELSE
     294            anum = h(il, i) - hp(il, i) - lv(il, i)*(rti - rs(il, i)) + &
     295                   (cpv - cpd)*t(il, i)*(rti - rr(il, i))
     296            denom = h(il, i) - hp(il, i) + lv(il, i)*(rr(il, i) - rti) + &
     297                    (cpd - cpv)*t(il, i)*(rr(il, i) - rti)
     298          END IF
     299          IF (abs(denom) < 0.01) denom = 0.01
     300          Scrit = min(anum/denom, 1.)
     301          alt = rti - rs(il, i) + Scrit*(rr(il, i) - rti)
     302
     303          ! Get max of Sij
     304          Sx = max(maxval(Sij(il, i, i + 1:inb(il))), 0., signhpmh)
     305          ! Find new critical value Scrit
     306          ! such that : Sij > Scrit  => mixed draught will detrain at J<I
     307          !             Sij < Scrit  => mixed draught will detrain at J>I
     308          Scrit = min(Scrit, Sx*max(0., -signhpmh)) + Scrit*max(0., signhpmh)
     309
     310          ! Correction pour la nouvelle logique; la correction pour ALT
     311          ! est un peu au hazard
     312          IF (Scrit <= 0.0) Scrit = 0.0
     313          IF (alt <= 0.0) Scrit = 1.0
     314
     315          smax = 0.0
     316          ASij(il, i) = 0.0
     317          sup = 0.      ! upper S-value reached by descending draughts
     318
     319          ! Glitchy : why?
     320          if (i < inb(il)) then
     321            Sbef = Sij(il, i, inb(il))
     322          else
     323            Sbef = max(0., signhpmh)
     324          endif
     325
     326          DO j = (icb(il) - 1), inb(il) !Loop on destination level "j"
     327            IF (Sij(il, i, j) > 0.0) THEN
     328              block
     329                real :: Sjmax, Sjmin, Qmixmax, Qmixmin, Rmixmax, Rmixmin, sqmrmax, sqmrmin
     330                ! -----------------------------------------------
     331                IF (j > i) THEN
     332                  Smid = min(Sij(il, i, j), Scrit)
     333                  Sjmax = Smid
     334                  Sjmin = Smid
     335                  IF (Smid < smin .AND. Sij(il, i, j + 1) < Smid) THEN
     336                    smin = min(smin, Smid)
     337                    Sjmax = min((Sij(il, i, j + 1) + Sij(il, i, j))/2., Sij(il, i, j), Scrit)
     338                    Sjmin = max((Sbef + Sij(il, i, j))/2., Sij(il, i, j))
     339                    Sjmin = min(Sjmin, Scrit)
     340                    Sbef = Sij(il, i, j)
     341                  END IF
     342                ELSE IF (j == i) THEN
     343                  Smid = 1.
     344                  Sjmin = max((Sij(il, i, j - 1) + Smid)/2., Scrit)*max(0., -signhpmh) + &
     345                          min((Sij(il, i, j + 1) + Smid)/2., Scrit)*max(0., signhpmh)
     346                  Sjmin = max(Sjmin, sup)
     347                  Sjmax = 1.
     348                  ! preparation des variables Scrit, Smin et Sbef pour la partie j>i
     349                  Scrit = min(Sjmin, Sjmax, Scrit)
     350
     351                  smin = 1.
     352                  Sbef = max(0., signhpmh)
     353                  supmax(il, i) = sign(Scrit, -signhpmh)
     354                ELSE IF (j < i) THEN
     355                  Smid = max(Sij(il, i, j), Scrit)
     356                  Sjmax = Smid
     357                  Sjmin = Smid
     358                  IF (Smid > smax .AND. Sij(il, i, j + 1) > Smid) THEN
     359                    smax = Smid
     360                    Sjmax = max((Sij(il, i, j + 1) + Sij(il, i, j))/2., Sij(il, i, j))
     361                    Sjmax = max(Sjmax, Scrit)
     362                    Sjmin = min((Sbef + Sij(il, i, j))/2., Sij(il, i, j))
     363                    Sjmin = max(Sjmin, Scrit)
     364                    Sbef = Sij(il, i, j)
     365                  END IF
     366                  IF (abs(Sjmin - Sjmax) > 1.E-10) &
     367                    sup = max(Sjmin, Sjmax, sup)
     368                END IF
     369                ! -----------------------------------------------
     370
     371                rti = qta(il, i - 1) - ep(il, i)*clw(il, i)
     372                Qmixmax = Qmix(Sjmax)
     373                Qmixmin = Qmix(Sjmin)
     374                Rmixmax = Rmix(Sjmax)
     375                Rmixmin = Rmix(Sjmin)
     376                sqmrmax = Sjmax*Qmix(Sjmax) - Rmix(Sjmax)
     377                sqmrmin = Sjmin*Qmix(Sjmin) - Rmix(Sjmin)
     378
     379                Ment(il, i, j) = abs(Qmixmax - Qmixmin)*Ment(il, i, j)
     380                IF (abs(Qmixmax - Qmixmin) > 1.E-10) THEN
     381                  Sigij(il, i, j) = (sqmrmax - sqmrmin)/(Qmixmax - Qmixmin)
     382                ELSE
     383                  Sigij(il, i, j) = 0.
     384                END IF
     385
     386                ! Compute Qent, uent, vent according to the true mixing fraction
     387                Qent(il, i, j) = (1.-Sigij(il, i, j))*rti + Sigij(il, i, j)*rr(il, i)
     388                uent(il, i, j) = (1.-Sigij(il, i, j))*unk(il) + Sigij(il, i, j)*u(il, i)
     389                vent(il, i, j) = (1.-Sigij(il, i, j))*vnk(il) + Sigij(il, i, j)*v(il, i)
     390
     391                ! Compute liquid water static energy of mixed draughts
     392                hent(il, i, j) = (1.-Sigij(il, i, j))*hp(il, i) + Sigij(il, i, j)*h(il, i)
     393                !  Heat capacity of mixed draught
     394                cpm = cpd + Qent(il, i, j)*(cpv - cpd)
     395
     396                elij(il, i, j) = Qent(il, i, j) - rs(il, j)
     397                elij(il, i, j) = elij(il, i, j) + &
     398                                 (h(il, j) - hent(il, i, j) + (cpv - cpd)*(Qent(il, i, j) - rr(il, j))*t(il, j))* &
     399                                 rs(il, j)*lv(il, j)/(cpm*rrv*t(il, j)*t(il, j))
     400                IF (cvflag_ice .and. frac(il, j) .gt. 0.) THEN
     401                  elij(il, i, j) = elij(il, i, j)/ &
     402                                   (1.+(lv(il, j) + frac(il, j)*lf(il, j))*lv(il, j)*rs(il, j)/ &
     403                                    (cpm*rrv*t(il, j)*t(il, j)))
     404                ELSE
     405
     406                  elij(il, i, j) = elij(il, i, j)/ &
     407                                   (1.+lv(il, j)*lv(il, j)*rs(il, j)/ &
     408                                    (cpm*rrv*t(il, j)*t(il, j)))
     409                ENDIF
     410                elij(il, i, j) = max(elij(il, i, j), 0.)
     411                elij(il, i, j) = min(elij(il, i, j), Qent(il, i, j))
     412
     413                IF (j > i) THEN
     414                  awat = elij(il, i, j) - (1.-ep(il, j))*clw(il, j)
     415                  awat = amax1(awat, 0.0)
     416                ELSE
     417                  awat = 0.
     418                END IF
     419
     420                ! Mixed draught temperature at level j
     421                Tm = t(il, j) + (Qent(il, i, j) - elij(il, i, j) - rs(il, j))*rrv*t(il, j)*t(il, j)/(lv(il, j)*rs(il, j))
     422                IF (cvflag_ice .and. frac(il, j) .gt. 0.) THEN
     423                  hent(il, i, j) = hent(il, i, j) + (lv(il, j) + frac(il, j)*lf(il, j) + (cpd - cpv)*Tm)*awat
     424                ELSE
     425                  hent(il, i, j) = hent(il, i, j) + (lv(il, j) + (cpd - cpv)*Tm)*awat
     426                ENDIF
     427
     428                ! ASij is the integral of P(F) over the relevant F interval
     429                ASij(il, i) = ASij(il, i) + abs(Qmixmax*(1.-Sjmax) + Rmixmax - &
     430                                                Qmixmin*(1.-Sjmin) - Rmixmin)
     431
     432                ! If I=J (detrainement and entrainement at the same level), then only the
     433                ! adiabatic ascent part of the mixture is considered
     434                IF (i == j) THEN
     435                  rti = qta(il, i - 1) - ep(il, i)*clw(il, i)
     436                  Ment(il, i, i) = abs(Qmixmax*(1.-Sjmax) + Rmixmax - &
     437                                       Qmixmin*(1.-Sjmin) - Rmixmin)
     438                  Qent(il, i, i) = rti
     439                  uent(il, i, i) = unk(il)
     440                  vent(il, i, i) = vnk(il)
     441                  hent(il, i, i) = hp(il, i)
     442                  elij(il, i, i) = clw(il, i)*(1.-ep(il, i))
     443                  Sigij(il, i, i) = 0.
     444                END IF
     445              end block
    374446            END IF
    375             ! -----------------------------------------------
    376 
    377             rti = qta(il, i - 1) - ep(il, i)*clw(il, i)
    378             Qmixmax(il) = Qmix(Sjmax(il))
    379             Qmixmin(il) = Qmix(Sjmin(il))
    380             Rmixmax(il) = Rmix(Sjmax(il))
    381             Rmixmin(il) = Rmix(Sjmin(il))
    382             sqmrmax(il) = Sjmax(il)*Qmix(Sjmax(il)) - Rmix(Sjmax(il))
    383             sqmrmin(il) = Sjmin(il)*Qmix(Sjmin(il)) - Rmix(Sjmin(il))
    384 
    385             Ment(il, i, j) = abs(Qmixmax(il) - Qmixmin(il))*Ment(il, i, j)
    386             IF (abs(Qmixmax(il) - Qmixmin(il)) > 1.E-10) THEN
    387               Sigij(il, i, j) = (sqmrmax(il) - sqmrmin(il))/(Qmixmax(il) - Qmixmin(il))
    388             ELSE
    389               Sigij(il, i, j) = 0.
    390             END IF
    391 
    392             ! Compute Qent, uent, vent according to the true mixing fraction
    393             Qent(il, i, j) = (1.-Sigij(il, i, j))*rti + Sigij(il, i, j)*rr(il, i)
    394             uent(il, i, j) = (1.-Sigij(il, i, j))*unk(il) + Sigij(il, i, j)*u(il, i)
    395             vent(il, i, j) = (1.-Sigij(il, i, j))*vnk(il) + Sigij(il, i, j)*v(il, i)
    396 
    397             ! Compute liquid water static energy of mixed draughts
    398             hent(il, i, j) = (1.-Sigij(il, i, j))*hp(il, i) + Sigij(il, i, j)*h(il, i)
    399             !  Heat capacity of mixed draught
    400             cpm = cpd + Qent(il, i, j)*(cpv - cpd)
    401             IF (cvflag_ice .and. frac(il, j) .gt. 0.) THEN
    402               elij(il, i, j) = Qent(il, i, j) - rs(il, j)
    403               elij(il, i, j) = elij(il, i, j) + &
    404                                (h(il, j) - hent(il, i, j) + (cpv - cpd)*(Qent(il, i, j) - rr(il, j))*t(il, j))* &
    405                                rs(il, j)*lv(il, j)/(cpm*rrv*t(il, j)*t(il, j))
    406               elij(il, i, j) = elij(il, i, j)/ &
    407                                (1.+(lv(il, j) + frac(il, j)*lf(il, j))*lv(il, j)*rs(il, j)/ &
    408                                 (cpm*rrv*t(il, j)*t(il, j)))
    409             ELSE
    410               elij(il, i, j) = Qent(il, i, j) - rs(il, j)
    411               elij(il, i, j) = elij(il, i, j) + &
    412                                (h(il, j) - hent(il, i, j) + (cpv - cpd)*(Qent(il, i, j) - rr(il, j))*t(il, j))* &
    413                                rs(il, j)*lv(il, j)/(cpm*rrv*t(il, j)*t(il, j))
    414               elij(il, i, j) = elij(il, i, j)/ &
    415                                (1.+lv(il, j)*lv(il, j)*rs(il, j)/ &
    416                                 (cpm*rrv*t(il, j)*t(il, j)))
    417             ENDIF
    418             elij(il, i, j) = max(elij(il, i, j), 0.)
    419 
    420             elij(il, i, j) = min(elij(il, i, j), Qent(il, i, j))
    421 
    422             IF (j > i) THEN
    423               awat = elij(il, i, j) - (1.-ep(il, j))*clw(il, j)
    424               awat = amax1(awat, 0.0)
    425             ELSE
    426               awat = 0.
    427             END IF
    428 
    429             ! Mixed draught temperature at level j
    430             Tm = t(il, j) + (Qent(il, i, j) - elij(il, i, j) - rs(il, j))*rrv*t(il, j)*t(il, j)/(lv(il, j)*rs(il, j))
    431             IF (cvflag_ice .and. frac(il, j) .gt. 0.) THEN
    432               hent(il, i, j) = hent(il, i, j) + (lv(il, j) + frac(il, j)*lf(il, j) + (cpd - cpv)*Tm)*awat
    433             ELSE
    434               hent(il, i, j) = hent(il, i, j) + (lv(il, j) + (cpd - cpv)*Tm)*awat
    435             ENDIF
    436 
    437             ! ASij is the integral of P(F) over the relevant F interval
    438             ASij(il, i) = ASij(il, i) + abs(Qmixmax(il)*(1.-Sjmax(il)) + Rmixmax(il) - &
    439                                             Qmixmin(il)*(1.-Sjmin(il)) - Rmixmin(il))
    440 
    441             ! If I=J (detrainement and entrainement at the same level), then only the
    442             ! adiabatic ascent part of the mixture is considered
    443             IF (i == j) THEN
    444               rti = qta(il, i - 1) - ep(il, i)*clw(il, i)
    445               Ment(il, i, i) = abs(Qmixmax(il)*(1.-Sjmax(il)) + Rmixmax(il) - &
    446                                    Qmixmin(il)*(1.-Sjmin(il)) - Rmixmin(il))
    447               Qent(il, i, i) = rti
    448               uent(il, i, i) = unk(il)
    449               vent(il, i, i) = vnk(il)
    450               hent(il, i, i) = hp(il, i)
    451               elij(il, i, i) = clw(il, i)*(1.-ep(il, i))
    452               Sigij(il, i, i) = 0.
    453             END IF
    454           END IF
    455         END DO ! Loop j = (icb(il) - 1), inb(il)
     447          END DO ! Loop j = (icb(il) - 1), inb(il)
     448        end block
    456449      END DO ! Loop i = icb(il), inb(il)
    457450    END DO ! Loop il = 1, ncum
     
    459452    DO il = 1, ncum
    460453      DO i = icb(il), inb(il) !Loop on origin level "i"
    461         csum(il, i) = 0
    462         DO j = (icb(il) - 1), inb(il)
    463           ASij(il, i) = amax1(1.0E-16, ASij(il, i))
    464           ASij_inv(il) = 1.0/ASij(il, i)
    465           ! IF the F-interval spanned by possible mixtures is less than 0.01, no mixing occurs
    466           IF (ASij_inv(il) > 100.) ASij_inv(il) = 0.
    467           Ment(il, i, j) = Ment(il, i, j)*ASij_inv(il)
    468           csum(il, i) = csum(il, i) + Ment(il, i, j)
    469         END DO
    470         IF (csum(il, i) < 1.) THEN
    471           nent(il, i) = 0
    472           Ment(il, i, i) = 1.
    473           Qent(il, i, i) = qta(il, i - 1) - ep(il, i)*clw(il, i)
    474           uent(il, i, i) = unk(il)
    475           vent(il, i, i) = vnk(il)
    476           elij(il, i, i) = clw(il, i)*(1.-ep(il, i))
    477           IF (fl_cor_ebil .GE. 2) THEN
    478             hent(il, i, i) = hp(il, i)
    479             Sigij(il, i, i) = 0.0
    480           ELSE
    481             Sij(il, i, i) = 0.0
     454        block
     455          real :: csum, ASij_inv
     456          csum = 0
     457          DO j = (icb(il) - 1), inb(il)
     458            ASij(il, i) = amax1(1.0E-16, ASij(il, i))
     459            ASij_inv = 1.0/ASij(il, i)
     460            ! IF the F-interval spanned by possible mixtures is less than 0.01, no mixing occurs
     461            IF (ASij_inv > 100.) ASij_inv = 0.
     462            Ment(il, i, j) = Ment(il, i, j)*ASij_inv
     463            csum = csum + Ment(il, i, j)
     464          END DO
     465          IF (csum < 1.) THEN
     466            nent(il, i) = 0
     467            Ment(il, i, i) = 1.
     468            Qent(il, i, i) = qta(il, i - 1) - ep(il, i)*clw(il, i)
     469            uent(il, i, i) = unk(il)
     470            vent(il, i, i) = vnk(il)
     471            elij(il, i, i) = clw(il, i)*(1.-ep(il, i))
     472            IF (fl_cor_ebil .GE. 2) THEN
     473              hent(il, i, i) = hp(il, i)
     474              Sigij(il, i, i) = 0.0
     475            ELSE
     476              Sij(il, i, i) = 0.0
     477            ENDIF
    482478          ENDIF
    483         ENDIF
     479        end block
    484480      END DO ! Loop il = 1, ncum
    485481    END DO ! End loop on origin level "i"
Note: See TracChangeset for help on using the changeset viewer.