GCC Code Coverage Report
Directory: ./ Exec Total Coverage
File: phylmd/lmdz_thermcell_old.F90 Lines: 0 2015 0.0 %
Date: 2023-06-30 12:56:34 Branches: 0 1728 0.0 %

Line Branch Exec Source
1
MODULE lmdz_thermcell_old
2
CONTAINS
3
4
SUBROUTINE thermcell_2002(ngrid, nlay, ptimestep, iflag_thermals, pplay, &
5
    pplev, pphi, pu, pv, pt, po, pduadj, pdvadj, pdtadj, pdoadj, fm0, entr0, &
6
    fraca, wa_moy, r_aspect, l_mix, w2di, tho)
7
8
  USE dimphy
9
  USE write_field_phy
10
  USE lmdz_thermcell_dv2, ONLY : thermcell_dv2
11
  USE lmdz_thermcell_dq, ONLY : thermcell_dq
12
  IMPLICIT NONE
13
14
  ! =======================================================================
15
16
  ! Calcul du transport verticale dans la couche limite en presence
17
  ! de "thermiques" explicitement representes
18
19
  ! R��criture � partir d'un listing papier � Habas, le 14/02/00
20
21
  ! le thermique est suppos� homog�ne et dissip� par m�lange avec
22
  ! son environnement. la longueur l_mix contr�le l'efficacit� du
23
  ! m�lange
24
25
  ! Le calcul du transport des diff�rentes esp�ces se fait en prenant
26
  ! en compte:
27
  ! 1. un flux de masse montant
28
  ! 2. un flux de masse descendant
29
  ! 3. un entrainement
30
  ! 4. un detrainement
31
32
  ! =======================================================================
33
34
  ! -----------------------------------------------------------------------
35
  ! declarations:
36
  ! -------------
37
38
  include "YOMCST.h"
39
40
  ! arguments:
41
  ! ----------
42
43
  INTEGER ngrid, nlay, w2di, iflag_thermals
44
  REAL tho
45
  REAL ptimestep, l_mix, r_aspect
46
  REAL pt(ngrid, nlay), pdtadj(ngrid, nlay)
47
  REAL pu(ngrid, nlay), pduadj(ngrid, nlay)
48
  REAL pv(ngrid, nlay), pdvadj(ngrid, nlay)
49
  REAL po(ngrid, nlay), pdoadj(ngrid, nlay)
50
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
51
  REAL pphi(ngrid, nlay)
52
  REAL fraca(ngrid, nlay+1), zw2(ngrid, nlay+1)
53
54
  INTEGER, SAVE :: idetr = 3, lev_out = 1
55
  !$OMP THREADPRIVATE(idetr,lev_out)
56
57
  ! local:
58
  ! ------
59
60
  INTEGER, SAVE :: dvdq = 0, flagdq = 0, dqimpl = 1
61
  LOGICAL, SAVE :: debut = .TRUE.
62
  !$OMP THREADPRIVATE(dvdq,flagdq,debut,dqimpl)
63
64
  INTEGER ig, k, l, lmax(klon, klev+1), lmaxa(klon), lmix(klon)
65
  REAL zmax(klon), zw, zz, ztva(klon, klev), zzz
66
67
  REAL zlev(klon, klev+1), zlay(klon, klev)
68
  REAL zh(klon, klev), zdhadj(klon, klev)
69
  REAL ztv(klon, klev)
70
  REAL zu(klon, klev), zv(klon, klev), zo(klon, klev)
71
  REAL wh(klon, klev+1)
72
  REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1)
73
  REAL zla(klon, klev+1)
74
  REAL zwa(klon, klev+1)
75
  REAL zld(klon, klev+1)
76
  REAL zwd(klon, klev+1)
77
  REAL zsortie(klon, klev)
78
  REAL zva(klon, klev)
79
  REAL zua(klon, klev)
80
  REAL zoa(klon, klev)
81
82
  REAL zha(klon, klev)
83
  REAL wa_moy(klon, klev+1)
84
  REAL fracc(klon, klev+1)
85
  REAL zf, zf2
86
  REAL thetath2(klon, klev), wth2(klon, klev)
87
  ! common/comtherm/thetath2,wth2
88
89
  REAL count_time
90
91
  LOGICAL sorties
92
  REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev)
93
  REAL zpspsk(klon, klev)
94
95
  REAL wmax(klon, klev), wmaxa(klon)
96
97
  REAL wa(klon, klev, klev+1)
98
  REAL wd(klon, klev+1)
99
  REAL larg_part(klon, klev, klev+1)
100
  REAL fracd(klon, klev+1)
101
  REAL xxx(klon, klev+1)
102
  REAL larg_cons(klon, klev+1)
103
  REAL larg_detr(klon, klev+1)
104
  REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev)
105
  REAL pu_therm(klon, klev), pv_therm(klon, klev)
106
  REAL fm(klon, klev+1), entr(klon, klev)
107
  REAL fmc(klon, klev+1)
108
109
  CHARACTER (LEN=2) :: str2
110
  CHARACTER (LEN=10) :: str10
111
112
  CHARACTER (LEN=20) :: modname = 'thermcell2002'
113
  CHARACTER (LEN=80) :: abort_message
114
115
  LOGICAL vtest(klon), down
116
117
  EXTERNAL scopy
118
119
  INTEGER ncorrec, ll
120
  SAVE ncorrec
121
  DATA ncorrec/0/
122
  !$OMP THREADPRIVATE(ncorrec)
123
124
125
  ! -----------------------------------------------------------------------
126
  ! initialisation:
127
  ! ---------------
128
129
  sorties = .TRUE.
130
  IF (ngrid/=klon) THEN
131
    PRINT *
132
    PRINT *, 'STOP dans convadj'
133
    PRINT *, 'ngrid    =', ngrid
134
    PRINT *, 'klon  =', klon
135
  END IF
136
137
  ! -----------------------------------------------------------------------
138
  ! incrementation eventuelle de tendances precedentes:
139
  ! ---------------------------------------------------
140
141
  ! print*,'0 OK convect8'
142
143
  DO l = 1, nlay
144
    DO ig = 1, ngrid
145
      zpspsk(ig, l) = (pplay(ig,l)/pplev(ig,1))**rkappa
146
      zh(ig, l) = pt(ig, l)/zpspsk(ig, l)
147
      zu(ig, l) = pu(ig, l)
148
      zv(ig, l) = pv(ig, l)
149
      zo(ig, l) = po(ig, l)
150
      ztv(ig, l) = zh(ig, l)*(1.+0.61*zo(ig,l))
151
    END DO
152
  END DO
153
154
  ! print*,'1 OK convect8'
155
  ! --------------------
156
157
158
  ! + + + + + + + + + + +
159
160
161
  ! wa, fraca, wd, fracd --------------------   zlev(2), rhobarz
162
  ! wh,wt,wo ...
163
164
  ! + + + + + + + + + + +  zh,zu,zv,zo,rho
165
166
167
  ! --------------------   zlev(1)
168
  ! \\\\\\\\\\\\\\\\\\\\
169
170
171
172
  ! -----------------------------------------------------------------------
173
  ! Calcul des altitudes des couches
174
  ! -----------------------------------------------------------------------
175
176
  IF (debut) THEN
177
    flagdq = (iflag_thermals-1000)/100
178
    dvdq = (iflag_thermals-(1000+flagdq*100))/10
179
    IF (flagdq==2) dqimpl = -1
180
    IF (flagdq==3) dqimpl = 1
181
    debut = .FALSE.
182
  END IF
183
  PRINT *, 'TH flag th ', iflag_thermals, flagdq, dvdq, dqimpl
184
185
  DO l = 2, nlay
186
    DO ig = 1, ngrid
187
      zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg
188
    END DO
189
  END DO
190
  DO ig = 1, ngrid
191
    zlev(ig, 1) = 0.
192
    zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg
193
  END DO
194
  DO l = 1, nlay
195
    DO ig = 1, ngrid
196
      zlay(ig, l) = pphi(ig, l)/rg
197
    END DO
198
  END DO
199
200
  ! print*,'2 OK convect8'
201
  ! -----------------------------------------------------------------------
202
  ! Calcul des densites
203
  ! -----------------------------------------------------------------------
204
205
  DO l = 1, nlay
206
    DO ig = 1, ngrid
207
      rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*zh(ig,l))
208
    END DO
209
  END DO
210
211
  DO l = 2, nlay
212
    DO ig = 1, ngrid
213
      rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1))
214
    END DO
215
  END DO
216
217
  DO k = 1, nlay
218
    DO l = 1, nlay + 1
219
      DO ig = 1, ngrid
220
        wa(ig, k, l) = 0.
221
      END DO
222
    END DO
223
  END DO
224
225
  ! print*,'3 OK convect8'
226
  ! ------------------------------------------------------------------
227
  ! Calcul de w2, quarre de w a partir de la cape
228
  ! a partir de w2, on calcule wa, vitesse de l'ascendance
229
230
  ! ATTENTION: Dans cette version, pour cause d'economie de memoire,
231
  ! w2 est stoke dans wa
232
233
  ! ATTENTION: dans convect8, on n'utilise le calcule des wa
234
  ! independants par couches que pour calculer l'entrainement
235
  ! a la base et la hauteur max de l'ascendance.
236
237
  ! Indicages:
238
  ! l'ascendance provenant du niveau k traverse l'interface l avec
239
  ! une vitesse wa(k,l).
240
241
  ! --------------------
242
243
  ! + + + + + + + + + +
244
245
  ! wa(k,l)   ----       --------------------    l
246
  ! /\
247
  ! /||\       + + + + + + + + + +
248
  ! ||
249
  ! ||        --------------------
250
  ! ||
251
  ! ||        + + + + + + + + + +
252
  ! ||
253
  ! ||        --------------------
254
  ! ||__
255
  ! |___      + + + + + + + + + +     k
256
257
  ! --------------------
258
259
260
261
  ! ------------------------------------------------------------------
262
263
264
  DO k = 1, nlay - 1
265
    DO ig = 1, ngrid
266
      wa(ig, k, k) = 0.
267
      wa(ig, k, k+1) = 2.*rg*(ztv(ig,k)-ztv(ig,k+1))/ztv(ig, k+1)* &
268
        (zlev(ig,k+1)-zlev(ig,k))
269
    END DO
270
    DO l = k + 1, nlay - 1
271
      DO ig = 1, ngrid
272
        wa(ig, k, l+1) = wa(ig, k, l) + 2.*rg*(ztv(ig,k)-ztv(ig,l))/ztv(ig, l &
273
          )*(zlev(ig,l+1)-zlev(ig,l))
274
      END DO
275
    END DO
276
    DO ig = 1, ngrid
277
      wa(ig, k, nlay+1) = 0.
278
    END DO
279
  END DO
280
281
  ! print*,'4 OK convect8'
282
  ! Calcul de la couche correspondant a la hauteur du thermique
283
  DO k = 1, nlay - 1
284
    DO ig = 1, ngrid
285
      lmax(ig, k) = k
286
    END DO
287
    DO l = nlay, k + 1, -1
288
      DO ig = 1, ngrid
289
        IF (wa(ig,k,l)<=1.E-10) lmax(ig, k) = l - 1
290
      END DO
291
    END DO
292
  END DO
293
294
  ! print*,'5 OK convect8'
295
  ! Calcule du w max du thermique
296
  DO k = 1, nlay
297
    DO ig = 1, ngrid
298
      wmax(ig, k) = 0.
299
    END DO
300
  END DO
301
302
  DO k = 1, nlay - 1
303
    DO l = k, nlay
304
      DO ig = 1, ngrid
305
        IF (l<=lmax(ig,k)) THEN
306
          wa(ig, k, l) = sqrt(wa(ig,k,l))
307
          wmax(ig, k) = max(wmax(ig,k), wa(ig,k,l))
308
        ELSE
309
          wa(ig, k, l) = 0.
310
        END IF
311
      END DO
312
    END DO
313
  END DO
314
315
  DO k = 1, nlay - 1
316
    DO ig = 1, ngrid
317
      pu_therm(ig, k) = sqrt(wmax(ig,k))
318
      pv_therm(ig, k) = sqrt(wmax(ig,k))
319
    END DO
320
  END DO
321
322
  ! print*,'6 OK convect8'
323
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
324
  DO ig = 1, ngrid
325
    zmax(ig) = 500.
326
  END DO
327
  ! print*,'LMAX LMAX LMAX '
328
  DO k = 1, nlay - 1
329
    DO ig = 1, ngrid
330
      zmax(ig) = max(zmax(ig), zlev(ig,lmax(ig,k))-zlev(ig,k))
331
    END DO
332
    ! print*,k,lmax(1,k)
333
  END DO
334
  ! print*,'ZMAX ZMAX ZMAX ',zmax
335
  ! call dump2d(iim,jjm-1,zmax(2:ngrid-1),'ZMAX      ')
336
337
  ! print*,'OKl336'
338
  ! Calcul de l'entrainement.
339
  ! Le rapport d'aspect relie la largeur de l'ascendance a l'epaisseur
340
  ! de la couche d'alimentation en partant du principe que la vitesse
341
  ! maximum dans l'ascendance est la vitesse d'entrainement horizontale.
342
  DO k = 1, nlay
343
    DO ig = 1, ngrid
344
      zzz = rho(ig, k)*wmax(ig, k)*(zlev(ig,k+1)-zlev(ig,k))/ &
345
        (zmax(ig)*r_aspect)
346
      IF (w2di==2) THEN
347
        entr(ig, k) = entr(ig, k) + ptimestep*(zzz-entr(ig,k))/tho
348
      ELSE
349
        entr(ig, k) = zzz
350
      END IF
351
      ztva(ig, k) = ztv(ig, k)
352
    END DO
353
  END DO
354
355
356
  ! print*,'7 OK convect8'
357
  DO k = 1, klev + 1
358
    DO ig = 1, ngrid
359
      zw2(ig, k) = 0.
360
      fmc(ig, k) = 0.
361
      larg_cons(ig, k) = 0.
362
      larg_detr(ig, k) = 0.
363
      wa_moy(ig, k) = 0.
364
    END DO
365
  END DO
366
367
  ! print*,'8 OK convect8'
368
  DO ig = 1, ngrid
369
    lmaxa(ig) = 1
370
    lmix(ig) = 1
371
    wmaxa(ig) = 0.
372
  END DO
373
374
375
  ! print*,'OKl372'
376
  DO l = 1, nlay - 2
377
    DO ig = 1, ngrid
378
      ! if (zw2(ig,l).lt.1.e-10.and.ztv(ig,l).gt.ztv(ig,l+1)) then
379
      ! print*,'COUCOU ',l,zw2(ig,l),ztv(ig,l),ztv(ig,l+1)
380
      IF (zw2(ig,l)<1.E-10 .AND. ztv(ig,l)>ztv(ig,l+1) .AND. &
381
          entr(ig,l)>1.E-10) THEN
382
        ! print*,'COUCOU cas 1'
383
        ! Initialisation de l'ascendance
384
        ! lmix(ig)=1
385
        ztva(ig, l) = ztv(ig, l)
386
        fmc(ig, l) = 0.
387
        fmc(ig, l+1) = entr(ig, l)
388
        zw2(ig, l) = 0.
389
        ! if (.not.ztv(ig,l+1).gt.150.) then
390
        ! print*,'ig,l+1,ztv(ig,l+1)'
391
        ! print*, ig,l+1,ztv(ig,l+1)
392
        ! endif
393
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
394
          (zlev(ig,l+1)-zlev(ig,l))
395
        larg_detr(ig, l) = 0.
396
      ELSE IF (zw2(ig,l)>=1.E-10 .AND. fmc(ig,l)+entr(ig,l)>1.E-10) THEN
397
        ! Incrementation...
398
        fmc(ig, l+1) = fmc(ig, l) + entr(ig, l)
399
        ! if (.not.fmc(ig,l+1).gt.1.e-15) then
400
        ! print*,'ig,l+1,fmc(ig,l+1)'
401
        ! print*, ig,l+1,fmc(ig,l+1)
402
        ! print*,'Fmc ',(fmc(ig,ll),ll=1,klev+1)
403
        ! print*,'W2 ',(zw2(ig,ll),ll=1,klev+1)
404
        ! print*,'Tv ',(ztv(ig,ll),ll=1,klev)
405
        ! print*,'Entr ',(entr(ig,ll),ll=1,klev)
406
        ! endif
407
        ztva(ig, l) = (fmc(ig,l)*ztva(ig,l-1)+entr(ig,l)*ztv(ig,l))/ &
408
          fmc(ig, l+1)
409
        ! mise a jour de la vitesse ascendante (l'air entraine de la couche
410
        ! consideree commence avec une vitesse nulle).
411
        zw2(ig, l+1) = zw2(ig, l)*(fmc(ig,l)/fmc(ig,l+1))**2 + &
412
          2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l))
413
      END IF
414
      IF (zw2(ig,l+1)<0.) THEN
415
        zw2(ig, l+1) = 0.
416
        lmaxa(ig) = l
417
      ELSE
418
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
419
      END IF
420
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
421
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
422
        lmix(ig) = l + 1
423
        wmaxa(ig) = wa_moy(ig, l+1)
424
      END IF
425
      ! print*,'COUCOU cas 2 LMIX=',lmix(ig),wa_moy(ig,l+1),wmaxa(ig)
426
    END DO
427
  END DO
428
429
  ! print*,'9 OK convect8'
430
  ! print*,'WA1 ',wa_moy
431
432
  ! determination de l'indice du debut de la mixed layer ou w decroit
433
434
  ! calcul de la largeur de chaque ascendance dans le cas conservatif.
435
  ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant
436
  ! d'une couche est �gale � la hauteur de la couche alimentante.
437
  ! La vitesse maximale dans l'ascendance est aussi prise comme estimation
438
  ! de la vitesse d'entrainement horizontal dans la couche alimentante.
439
440
  ! print*,'OKl439'
441
  DO l = 2, nlay
442
    DO ig = 1, ngrid
443
      IF (l<=lmaxa(ig)) THEN
444
        zw = max(wa_moy(ig,l), 1.E-10)
445
        larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw)
446
      END IF
447
    END DO
448
  END DO
449
450
  DO l = 2, nlay
451
    DO ig = 1, ngrid
452
      IF (l<=lmaxa(ig)) THEN
453
        ! if (idetr.eq.0) then
454
        ! cette option est finalement en dur.
455
        larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l))
456
        ! else if (idetr.eq.1) then
457
        ! larg_detr(ig,l)=larg_cons(ig,l)
458
        ! s            *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig))
459
        ! else if (idetr.eq.2) then
460
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
461
        ! s            *sqrt(wa_moy(ig,l))
462
        ! else if (idetr.eq.4) then
463
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
464
        ! s            *wa_moy(ig,l)
465
        ! endif
466
      END IF
467
    END DO
468
  END DO
469
470
  ! print*,'10 OK convect8'
471
  ! print*,'WA2 ',wa_moy
472
  ! calcul de la fraction de la maille concern�e par l'ascendance en tenant
473
  ! compte de l'epluchage du thermique.
474
475
  DO l = 2, nlay
476
    DO ig = 1, ngrid
477
      IF (larg_cons(ig,l)>1.) THEN
478
        ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),'  KKK'
479
        fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig))
480
        IF (l>lmix(ig)) THEN
481
          xxx(ig, l) = (lmaxa(ig)+1.-l)/(lmaxa(ig)+1.-lmix(ig))
482
          IF (idetr==0) THEN
483
            fraca(ig, l) = fraca(ig, lmix(ig))
484
          ELSE IF (idetr==1) THEN
485
            fraca(ig, l) = fraca(ig, lmix(ig))*xxx(ig, l)
486
          ELSE IF (idetr==2) THEN
487
            fraca(ig, l) = fraca(ig, lmix(ig))*(1.-(1.-xxx(ig,l))**2)
488
          ELSE
489
            fraca(ig, l) = fraca(ig, lmix(ig))*xxx(ig, l)**2
490
          END IF
491
        END IF
492
        ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL'
493
        fraca(ig, l) = max(fraca(ig,l), 0.)
494
        fraca(ig, l) = min(fraca(ig,l), 0.5)
495
        fracd(ig, l) = 1. - fraca(ig, l)
496
        fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
497
      ELSE
498
        ! wa_moy(ig,l)=0.
499
        fraca(ig, l) = 0.
500
        fracc(ig, l) = 0.
501
        fracd(ig, l) = 1.
502
      END IF
503
    END DO
504
  END DO
505
506
  ! print*,'11 OK convect8'
507
  ! print*,'Ea3 ',wa_moy
508
  ! ------------------------------------------------------------------
509
  ! Calcul de fracd, wd
510
  ! somme wa - wd = 0
511
  ! ------------------------------------------------------------------
512
513
514
  DO ig = 1, ngrid
515
    fm(ig, 1) = 0.
516
    fm(ig, nlay+1) = 0.
517
  END DO
518
519
  DO l = 2, nlay
520
    DO ig = 1, ngrid
521
      fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l)
522
    END DO
523
    DO ig = 1, ngrid
524
      IF (fracd(ig,l)<0.1) THEN
525
        abort_message = 'fracd trop petit'
526
        CALL abort_physic(modname, abort_message, 1)
527
      ELSE
528
        ! vitesse descendante "diagnostique"
529
        wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l))
530
      END IF
531
    END DO
532
  END DO
533
534
  DO l = 1, nlay
535
    DO ig = 1, ngrid
536
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
537
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
538
    END DO
539
  END DO
540
541
  ! print*,'12 OK convect8'
542
  ! print*,'WA4 ',wa_moy
543
  ! c------------------------------------------------------------------
544
  ! calcul du transport vertical
545
  ! ------------------------------------------------------------------
546
547
  GO TO 4444
548
  ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep
549
  DO l = 2, nlay - 1
550
    DO ig = 1, ngrid
551
      IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( &
552
          ig,l+1)) THEN
553
        ! print*,'WARN!!! FM>M ig=',ig,' l=',l,'  FM='
554
        ! s         ,fm(ig,l+1)*ptimestep
555
        ! s         ,'   M=',masse(ig,l),masse(ig,l+1)
556
      END IF
557
    END DO
558
  END DO
559
560
  DO l = 1, nlay
561
    DO ig = 1, ngrid
562
      IF (entr(ig,l)*ptimestep>masse(ig,l)) THEN
563
        ! print*,'WARN!!! E>M ig=',ig,' l=',l,'  E=='
564
        ! s         ,entr(ig,l)*ptimestep
565
        ! s         ,'   M=',masse(ig,l)
566
      END IF
567
    END DO
568
  END DO
569
570
  DO l = 1, nlay
571
    DO ig = 1, ngrid
572
      IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN
573
        ! print*,'WARN!!! fm exagere ig=',ig,'   l=',l
574
        ! s         ,'   FM=',fm(ig,l)
575
      END IF
576
      IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN
577
        ! print*,'WARN!!! masse exagere ig=',ig,'   l=',l
578
        ! s         ,'   M=',masse(ig,l)
579
        ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)',
580
        ! s                 rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)
581
        ! print*,'zlev(ig,l+1),zlev(ig,l)'
582
        ! s                ,zlev(ig,l+1),zlev(ig,l)
583
        ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)'
584
        ! s                ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)
585
      END IF
586
      IF (.NOT. entr(ig,l)>=0. .OR. .NOT. entr(ig,l)<=10.) THEN
587
        ! print*,'WARN!!! entr exagere ig=',ig,'   l=',l
588
        ! s         ,'   E=',entr(ig,l)
589
      END IF
590
    END DO
591
  END DO
592
593
4444 CONTINUE
594
  ! print*,'OK 444 '
595
596
  IF (w2di==1) THEN
597
    fm0 = fm0 + ptimestep*(fm-fm0)/tho
598
    entr0 = entr0 + ptimestep*(entr-entr0)/tho
599
  ELSE
600
    fm0 = fm
601
    entr0 = entr
602
  END IF
603
604
  IF (flagdq==0) THEN
605
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zh, zdhadj, &
606
      zha)
607
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zo, pdoadj, &
608
      zoa)
609
    PRINT *, 'THERMALS OPT 1'
610
  ELSE IF (flagdq==1) THEN
611
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, &
612
      zdhadj, zha)
613
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, &
614
      pdoadj, zoa)
615
    PRINT *, 'THERMALS OPT 2'
616
  ELSE
617
    CALL thermcell_dq(ngrid, nlay, dqimpl, ptimestep, fm0, entr0, masse, zh, &
618
      zdhadj, zha, lev_out)
619
    CALL thermcell_dq(ngrid, nlay, dqimpl, ptimestep, fm0, entr0, masse, zo, &
620
      pdoadj, zoa, lev_out)
621
    PRINT *, 'THERMALS OPT 3', dqimpl
622
  END IF
623
624
  PRINT *, 'TH VENT ', dvdq
625
  IF (dvdq==0) THEN
626
    ! print*,'TH VENT OK ',dvdq
627
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, &
628
      zua)
629
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, &
630
      zva)
631
  ELSE IF (dvdq==1) THEN
632
    CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, &
633
      zu, zv, pduadj, pdvadj, zua, zva)
634
  ELSE IF (dvdq==2) THEN
635
    CALL thermcell_dv2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, &
636
      zmax, zu, zv, pduadj, pdvadj, zua, zva, lev_out)
637
  ELSE IF (dvdq==3) THEN
638
    CALL thermcell_dq(ngrid, nlay, dqimpl, ptimestep, fm0, entr0, masse, zu, &
639
      pduadj, zua, lev_out)
640
    CALL thermcell_dq(ngrid, nlay, dqimpl, ptimestep, fm0, entr0, masse, zv, &
641
      pdvadj, zva, lev_out)
642
  END IF
643
644
  ! CALL writefield_phy('duadj',pduadj,klev)
645
646
  DO l = 1, nlay
647
    DO ig = 1, ngrid
648
      zf = 0.5*(fracc(ig,l)+fracc(ig,l+1))
649
      zf2 = zf/(1.-zf)
650
      thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l))**2
651
      wth2(ig, l) = zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2
652
    END DO
653
  END DO
654
655
656
657
  ! print*,'13 OK convect8'
658
  ! print*,'WA5 ',wa_moy
659
  DO l = 1, nlay
660
    DO ig = 1, ngrid
661
      pdtadj(ig, l) = zdhadj(ig, l)*zpspsk(ig, l)
662
    END DO
663
  END DO
664
665
666
  ! do l=1,nlay
667
  ! do ig=1,ngrid
668
  ! if(abs(pdtadj(ig,l))*86400..gt.500.) then
669
  ! print*,'WARN!!! ig=',ig,'  l=',l
670
  ! s         ,'   pdtadj=',pdtadj(ig,l)
671
  ! endif
672
  ! if(abs(pdoadj(ig,l))*86400..gt.1.) then
673
  ! print*,'WARN!!! ig=',ig,'  l=',l
674
  ! s         ,'   pdoadj=',pdoadj(ig,l)
675
  ! endif
676
  ! enddo
677
  ! enddo
678
679
  ! print*,'14 OK convect8'
680
  ! ------------------------------------------------------------------
681
  ! Calculs pour les sorties
682
  ! ------------------------------------------------------------------
683
684
  IF (sorties) THEN
685
    DO l = 1, nlay
686
      DO ig = 1, ngrid
687
        zla(ig, l) = (1.-fracd(ig,l))*zmax(ig)
688
        zld(ig, l) = fracd(ig, l)*zmax(ig)
689
        IF (1.-fracd(ig,l)>1.E-10) zwa(ig, l) = wd(ig, l)*fracd(ig, l)/ &
690
          (1.-fracd(ig,l))
691
      END DO
692
    END DO
693
694
    DO l = 1, nlay
695
      DO ig = 1, ngrid
696
        detr(ig, l) = fm(ig, l) + entr(ig, l) - fm(ig, l+1)
697
        IF (detr(ig,l)<0.) THEN
698
          entr(ig, l) = entr(ig, l) - detr(ig, l)
699
          detr(ig, l) = 0.
700
          ! print*,'WARNING !!! detrainement negatif ',ig,l
701
        END IF
702
      END DO
703
    END DO
704
  END IF
705
706
  ! print*,'15 OK convect8'
707
708
709
  ! if(wa_moy(1,4).gt.1.e-10) stop
710
711
  ! print*,'19 OK convect8'
712
  RETURN
713
END SUBROUTINE thermcell_2002
714
715
SUBROUTINE thermcell_cld(ngrid, nlay, ptimestep, pplay, pplev, pphi, zlev, &
716
    debut, pu, pv, pt, po, pduadj, pdvadj, pdtadj, pdoadj, fm0, entr0, zqla, &
717
    lmax, zmax_sec, wmax_sec, zw_sec, lmix_sec, ratqscth, ratqsdiff & ! s
718
                                                                      ! ,pu_therm,pv_therm
719
    , r_aspect, l_mix, w2di, tho)
720
721
  USE dimphy
722
  IMPLICIT NONE
723
724
  ! =======================================================================
725
726
  ! Calcul du transport verticale dans la couche limite en presence
727
  ! de "thermiques" explicitement representes
728
729
  ! R��criture � partir d'un listing papier � Habas, le 14/02/00
730
731
  ! le thermique est suppos� homog�ne et dissip� par m�lange avec
732
  ! son environnement. la longueur l_mix contr�le l'efficacit� du
733
  ! m�lange
734
735
  ! Le calcul du transport des diff�rentes esp�ces se fait en prenant
736
  ! en compte:
737
  ! 1. un flux de masse montant
738
  ! 2. un flux de masse descendant
739
  ! 3. un entrainement
740
  ! 4. un detrainement
741
742
  ! =======================================================================
743
744
  ! -----------------------------------------------------------------------
745
  ! declarations:
746
  ! -------------
747
748
  include "YOMCST.h"
749
  include "YOETHF.h"
750
  include "FCTTRE.h"
751
752
  ! arguments:
753
  ! ----------
754
755
  INTEGER ngrid, nlay, w2di
756
  REAL tho
757
  REAL ptimestep, l_mix, r_aspect
758
  REAL pt(ngrid, nlay), pdtadj(ngrid, nlay)
759
  REAL pu(ngrid, nlay), pduadj(ngrid, nlay)
760
  REAL pv(ngrid, nlay), pdvadj(ngrid, nlay)
761
  REAL po(ngrid, nlay), pdoadj(ngrid, nlay)
762
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
763
  REAL pphi(ngrid, nlay)
764
765
  INTEGER idetr
766
  SAVE idetr
767
  DATA idetr/3/
768
  !$OMP THREADPRIVATE(idetr)
769
770
  ! local:
771
  ! ------
772
773
  INTEGER ig, k, l, lmaxa(klon), lmix(klon)
774
  REAL zsortie1d(klon)
775
  ! CR: on remplace lmax(klon,klev+1)
776
  INTEGER lmax(klon), lmin(klon), lentr(klon)
777
  REAL linter(klon)
778
  REAL zmix(klon), fracazmix(klon)
779
  REAL alpha
780
  SAVE alpha
781
  DATA alpha/1./
782
  !$OMP THREADPRIVATE(alpha)
783
784
  ! RC
785
  REAL zmax(klon), zw, zz, zw2(klon, klev+1), ztva(klon, klev), zzz
786
  REAL zmax_sec(klon)
787
  REAL zmax_sec2(klon)
788
  REAL zw_sec(klon, klev+1)
789
  INTEGER lmix_sec(klon)
790
  REAL w_est(klon, klev+1)
791
  ! on garde le zmax du pas de temps precedent
792
  ! real zmax0(klon)
793
  ! save zmax0
794
  ! real zmix0(klon)
795
  ! save zmix0
796
  REAL, SAVE, ALLOCATABLE :: zmax0(:), zmix0(:)
797
  !$OMP THREADPRIVATE(zmax0, zmix0)
798
799
  REAL zlev(klon, klev+1), zlay(klon, klev)
800
  REAL deltaz(klon, klev)
801
  REAL zh(klon, klev), zdhadj(klon, klev)
802
  REAL zthl(klon, klev), zdthladj(klon, klev)
803
  REAL ztv(klon, klev)
804
  REAL zu(klon, klev), zv(klon, klev), zo(klon, klev)
805
  REAL zl(klon, klev)
806
  REAL wh(klon, klev+1)
807
  REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1)
808
  REAL zla(klon, klev+1)
809
  REAL zwa(klon, klev+1)
810
  REAL zld(klon, klev+1)
811
  REAL zwd(klon, klev+1)
812
  REAL zsortie(klon, klev)
813
  REAL zva(klon, klev)
814
  REAL zua(klon, klev)
815
  REAL zoa(klon, klev)
816
817
  REAL zta(klon, klev)
818
  REAL zha(klon, klev)
819
  REAL wa_moy(klon, klev+1)
820
  REAL fraca(klon, klev+1)
821
  REAL fracc(klon, klev+1)
822
  REAL zf, zf2
823
  REAL thetath2(klon, klev), wth2(klon, klev), wth3(klon, klev)
824
  REAL q2(klon, klev)
825
  REAL dtheta(klon, klev)
826
  ! common/comtherm/thetath2,wth2
827
828
  REAL ratqscth(klon, klev)
829
  REAL sum
830
  REAL sumdiff
831
  REAL ratqsdiff(klon, klev)
832
  REAL count_time
833
  INTEGER ialt
834
835
  LOGICAL sorties
836
  REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev)
837
  REAL zpspsk(klon, klev)
838
839
  ! real wmax(klon,klev),wmaxa(klon)
840
  REAL wmax(klon), wmaxa(klon)
841
  REAL wmax_sec(klon)
842
  REAL wmax_sec2(klon)
843
  REAL wa(klon, klev, klev+1)
844
  REAL wd(klon, klev+1)
845
  REAL larg_part(klon, klev, klev+1)
846
  REAL fracd(klon, klev+1)
847
  REAL xxx(klon, klev+1)
848
  REAL larg_cons(klon, klev+1)
849
  REAL larg_detr(klon, klev+1)
850
  REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev)
851
  REAL massetot(klon, klev)
852
  REAL detr0(klon, klev)
853
  REAL alim0(klon, klev)
854
  REAL pu_therm(klon, klev), pv_therm(klon, klev)
855
  REAL fm(klon, klev+1), entr(klon, klev)
856
  REAL fmc(klon, klev+1)
857
858
  REAL zcor, zdelta, zcvm5, qlbef
859
  REAL tbef(klon), qsatbef(klon)
860
  REAL dqsat_dt, dt, num, denom
861
  REAL reps, rlvcp, ddt0
862
  REAL ztla(klon, klev), zqla(klon, klev), zqta(klon, klev)
863
  ! CR niveau de condensation
864
  REAL nivcon(klon)
865
  REAL zcon(klon)
866
  REAL zqsat(klon, klev)
867
  REAL zqsatth(klon, klev)
868
  PARAMETER (ddt0=.01)
869
870
871
  ! CR:nouvelles variables
872
  REAL f_star(klon, klev+1), entr_star(klon, klev)
873
  REAL detr_star(klon, klev)
874
  REAL alim_star_tot(klon), alim_star2(klon)
875
  REAL entr_star_tot(klon)
876
  REAL detr_star_tot(klon)
877
  REAL alim_star(klon, klev)
878
  REAL alim(klon, klev)
879
  REAL nu(klon, klev)
880
  REAL nu_e(klon, klev)
881
  REAL nu_min
882
  REAL nu_max
883
  REAL nu_r
884
  REAL f(klon)
885
  ! real f(klon), f0(klon)
886
  ! save f0
887
  REAL, SAVE, ALLOCATABLE :: f0(:)
888
  !$OMP THREADPRIVATE(f0)
889
890
  REAL f_old
891
  REAL zlevinter(klon)
892
  LOGICAL, SAVE :: first = .TRUE.
893
  !$OMP THREADPRIVATE(first)
894
  ! data first /.false./
895
  ! save first
896
  LOGICAL nuage
897
  ! save nuage
898
  LOGICAL boucle
899
  LOGICAL therm
900
  LOGICAL debut
901
  LOGICAL rale
902
  INTEGER test(klon)
903
  INTEGER signe_zw2
904
  ! RC
905
906
  CHARACTER *2 str2
907
  CHARACTER *10 str10
908
909
  CHARACTER (LEN=20) :: modname = 'thermcell_cld'
910
  CHARACTER (LEN=80) :: abort_message
911
912
  LOGICAL vtest(klon), down
913
  LOGICAL zsat(klon)
914
915
  EXTERNAL scopy
916
917
  INTEGER ncorrec, ll
918
  SAVE ncorrec
919
  DATA ncorrec/0/
920
  !$OMP THREADPRIVATE(ncorrec)
921
922
923
924
  ! -----------------------------------------------------------------------
925
  ! initialisation:
926
  ! ---------------
927
928
  IF (first) THEN
929
    ALLOCATE (zmix0(klon))
930
    ALLOCATE (zmax0(klon))
931
    ALLOCATE (f0(klon))
932
    first = .FALSE.
933
  END IF
934
935
  sorties = .FALSE.
936
  ! print*,'NOUVEAU DETR PLUIE '
937
  IF (ngrid/=klon) THEN
938
    PRINT *
939
    PRINT *, 'STOP dans convadj'
940
    PRINT *, 'ngrid    =', ngrid
941
    PRINT *, 'klon  =', klon
942
  END IF
943
944
  ! Initialisation
945
  rlvcp = rlvtt/rcpd
946
  reps = rd/rv
947
  ! initialisations de zqsat
948
  DO ll = 1, nlay
949
    DO ig = 1, ngrid
950
      zqsat(ig, ll) = 0.
951
      zqsatth(ig, ll) = 0.
952
    END DO
953
  END DO
954
955
  ! on met le first a true pour le premier passage de la journ�e
956
  DO ig = 1, klon
957
    test(ig) = 0
958
  END DO
959
  IF (debut) THEN
960
    DO ig = 1, klon
961
      test(ig) = 1
962
      f0(ig) = 0.
963
      zmax0(ig) = 0.
964
    END DO
965
  END IF
966
  DO ig = 1, klon
967
    IF ((.NOT. debut) .AND. (f0(ig)<1.E-10)) THEN
968
      test(ig) = 1
969
    END IF
970
  END DO
971
  ! do ig=1,klon
972
  ! print*,'test(ig)',test(ig),zmax0(ig)
973
  ! enddo
974
  nuage = .FALSE.
975
  ! -----------------------------------------------------------------------
976
  ! AM Calcul de T,q,ql a partir de Tl et qT
977
  ! ---------------------------------------------------
978
979
  ! Pr Tprec=Tl calcul de qsat
980
  ! Si qsat>qT T=Tl, q=qT
981
  ! Sinon DDT=(-Tprec+Tl+RLVCP (qT-qsat(T')) / (1+RLVCP dqsat/dt)
982
  ! On cherche DDT < DDT0
983
984
  ! defaut
985
  DO ll = 1, nlay
986
    DO ig = 1, ngrid
987
      zo(ig, ll) = po(ig, ll)
988
      zl(ig, ll) = 0.
989
      zh(ig, ll) = pt(ig, ll)
990
    END DO
991
  END DO
992
  DO ig = 1, ngrid
993
    zsat(ig) = .FALSE.
994
  END DO
995
996
997
  DO ll = 1, nlay
998
    ! les points insatures sont definitifs
999
    DO ig = 1, ngrid
1000
      tbef(ig) = pt(ig, ll)
1001
      zdelta = max(0., sign(1.,rtt-tbef(ig)))
1002
      qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, ll)
1003
      qsatbef(ig) = min(0.5, qsatbef(ig))
1004
      zcor = 1./(1.-retv*qsatbef(ig))
1005
      qsatbef(ig) = qsatbef(ig)*zcor
1006
      zsat(ig) = (max(0.,po(ig,ll)-qsatbef(ig))>1.E-10)
1007
    END DO
1008
1009
    DO ig = 1, ngrid
1010
      IF (zsat(ig) .AND. (1==1)) THEN
1011
        qlbef = max(0., po(ig,ll)-qsatbef(ig))
1012
        ! si sature: ql est surestime, d'ou la sous-relax
1013
        dt = 0.5*rlvcp*qlbef
1014
        ! write(18,*),'DT0=',DT
1015
        ! on pourra enchainer 2 ou 3 calculs sans Do while
1016
        DO WHILE (abs(dt)>ddt0)
1017
          ! il faut verifier si c,a conserve quand on repasse en insature ...
1018
          tbef(ig) = tbef(ig) + dt
1019
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
1020
          qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, ll)
1021
          qsatbef(ig) = min(0.5, qsatbef(ig))
1022
          zcor = 1./(1.-retv*qsatbef(ig))
1023
          qsatbef(ig) = qsatbef(ig)*zcor
1024
          ! on veut le signe de qlbef
1025
          qlbef = po(ig, ll) - qsatbef(ig)
1026
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
1027
          zcvm5 = r5les*(1.-zdelta) + r5ies*zdelta
1028
          zcor = 1./(1.-retv*qsatbef(ig))
1029
          dqsat_dt = foede(tbef(ig), zdelta, zcvm5, qsatbef(ig), zcor)
1030
          num = -tbef(ig) + pt(ig, ll) + rlvcp*qlbef
1031
          denom = 1. + rlvcp*dqsat_dt
1032
          IF (denom<1.E-10) THEN
1033
            PRINT *, 'pb denom'
1034
          END IF
1035
          dt = num/denom
1036
        END DO
1037
        ! on ecrit de maniere conservative (sat ou non)
1038
        zl(ig, ll) = max(0., qlbef)
1039
        ! T = Tl +Lv/Cp ql
1040
        zh(ig, ll) = pt(ig, ll) + rlvcp*zl(ig, ll)
1041
        zo(ig, ll) = po(ig, ll) - zl(ig, ll)
1042
      END IF
1043
      ! on ecrit zqsat
1044
      zqsat(ig, ll) = qsatbef(ig)
1045
    END DO
1046
  END DO
1047
  ! AM fin
1048
1049
  ! -----------------------------------------------------------------------
1050
  ! incrementation eventuelle de tendances precedentes:
1051
  ! ---------------------------------------------------
1052
1053
  ! print*,'0 OK convect8'
1054
1055
  DO l = 1, nlay
1056
    DO ig = 1, ngrid
1057
      zpspsk(ig, l) = (pplay(ig,l)/100000.)**rkappa
1058
      ! zpspsk(ig,l)=(pplay(ig,l)/pplev(ig,1))**RKAPPA
1059
      ! zh(ig,l)=pt(ig,l)/zpspsk(ig,l)
1060
      zu(ig, l) = pu(ig, l)
1061
      zv(ig, l) = pv(ig, l)
1062
      ! zo(ig,l)=po(ig,l)
1063
      ! ztv(ig,l)=zh(ig,l)*(1.+0.61*zo(ig,l))
1064
      ! AM attention zh est maintenant le profil de T et plus le profil de
1065
      ! theta !
1066
1067
      ! T-> Theta
1068
      ztv(ig, l) = zh(ig, l)/zpspsk(ig, l)
1069
      ! AM Theta_v
1070
      ztv(ig, l) = ztv(ig, l)*(1.+retv*(zo(ig,l))-zl(ig,l))
1071
      ! AM Thetal
1072
      zthl(ig, l) = pt(ig, l)/zpspsk(ig, l)
1073
1074
    END DO
1075
  END DO
1076
1077
  ! print*,'1 OK convect8'
1078
  ! --------------------
1079
1080
1081
  ! + + + + + + + + + + +
1082
1083
1084
  ! wa, fraca, wd, fracd --------------------   zlev(2), rhobarz
1085
  ! wh,wt,wo ...
1086
1087
  ! + + + + + + + + + + +  zh,zu,zv,zo,rho
1088
1089
1090
  ! --------------------   zlev(1)
1091
  ! \\\\\\\\\\\\\\\\\\\\
1092
1093
1094
1095
  ! -----------------------------------------------------------------------
1096
  ! Calcul des altitudes des couches
1097
  ! -----------------------------------------------------------------------
1098
1099
  DO l = 2, nlay
1100
    DO ig = 1, ngrid
1101
      zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg
1102
    END DO
1103
  END DO
1104
  DO ig = 1, ngrid
1105
    zlev(ig, 1) = 0.
1106
    zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg
1107
  END DO
1108
  DO l = 1, nlay
1109
    DO ig = 1, ngrid
1110
      zlay(ig, l) = pphi(ig, l)/rg
1111
    END DO
1112
  END DO
1113
  ! calcul de deltaz
1114
  DO l = 1, nlay
1115
    DO ig = 1, ngrid
1116
      deltaz(ig, l) = zlev(ig, l+1) - zlev(ig, l)
1117
    END DO
1118
  END DO
1119
1120
  ! print*,'2 OK convect8'
1121
  ! -----------------------------------------------------------------------
1122
  ! Calcul des densites
1123
  ! -----------------------------------------------------------------------
1124
1125
  DO l = 1, nlay
1126
    DO ig = 1, ngrid
1127
      ! rho(ig,l)=pplay(ig,l)/(zpspsk(ig,l)*RD*zh(ig,l))
1128
      rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*ztv(ig,l))
1129
    END DO
1130
  END DO
1131
1132
  DO l = 2, nlay
1133
    DO ig = 1, ngrid
1134
      rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1))
1135
    END DO
1136
  END DO
1137
1138
  DO k = 1, nlay
1139
    DO l = 1, nlay + 1
1140
      DO ig = 1, ngrid
1141
        wa(ig, k, l) = 0.
1142
      END DO
1143
    END DO
1144
  END DO
1145
  ! Cr:ajout:calcul de la masse
1146
  DO l = 1, nlay
1147
    DO ig = 1, ngrid
1148
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
1149
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
1150
    END DO
1151
  END DO
1152
  ! print*,'3 OK convect8'
1153
  ! ------------------------------------------------------------------
1154
  ! Calcul de w2, quarre de w a partir de la cape
1155
  ! a partir de w2, on calcule wa, vitesse de l'ascendance
1156
1157
  ! ATTENTION: Dans cette version, pour cause d'economie de memoire,
1158
  ! w2 est stoke dans wa
1159
1160
  ! ATTENTION: dans convect8, on n'utilise le calcule des wa
1161
  ! independants par couches que pour calculer l'entrainement
1162
  ! a la base et la hauteur max de l'ascendance.
1163
1164
  ! Indicages:
1165
  ! l'ascendance provenant du niveau k traverse l'interface l avec
1166
  ! une vitesse wa(k,l).
1167
1168
  ! --------------------
1169
1170
  ! + + + + + + + + + +
1171
1172
  ! wa(k,l)   ----       --------------------    l
1173
  ! /\
1174
  ! /||\       + + + + + + + + + +
1175
  ! ||
1176
  ! ||        --------------------
1177
  ! ||
1178
  ! ||        + + + + + + + + + +
1179
  ! ||
1180
  ! ||        --------------------
1181
  ! ||__
1182
  ! |___      + + + + + + + + + +     k
1183
1184
  ! --------------------
1185
1186
1187
1188
  ! ------------------------------------------------------------------
1189
1190
  ! CR: ponderation entrainement des couches instables
1191
  ! def des alim_star tels que alim=f*alim_star
1192
  DO l = 1, klev
1193
    DO ig = 1, ngrid
1194
      alim_star(ig, l) = 0.
1195
      alim(ig, l) = 0.
1196
    END DO
1197
  END DO
1198
  ! determination de la longueur de la couche d entrainement
1199
  DO ig = 1, ngrid
1200
    lentr(ig) = 1
1201
  END DO
1202
1203
  ! on ne considere que les premieres couches instables
1204
  therm = .FALSE.
1205
  DO k = nlay - 2, 1, -1
1206
    DO ig = 1, ngrid
1207
      IF (ztv(ig,k)>ztv(ig,k+1) .AND. ztv(ig,k+1)<=ztv(ig,k+2)) THEN
1208
        lentr(ig) = k + 1
1209
        therm = .TRUE.
1210
      END IF
1211
    END DO
1212
  END DO
1213
1214
  ! determination du lmin: couche d ou provient le thermique
1215
  DO ig = 1, ngrid
1216
    lmin(ig) = 1
1217
  END DO
1218
  DO ig = 1, ngrid
1219
    DO l = nlay, 2, -1
1220
      IF (ztv(ig,l-1)>ztv(ig,l)) THEN
1221
        lmin(ig) = l - 1
1222
      END IF
1223
    END DO
1224
  END DO
1225
1226
  ! definition de l'entrainement des couches
1227
  DO l = 1, klev - 1
1228
    DO ig = 1, ngrid
1229
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<lentr(ig)) THEN
1230
        ! def possibles pour alim_star: zdthetadz, dthetadz, zdtheta
1231
        alim_star(ig, l) = max((ztv(ig,l)-ztv(ig,l+1)), 0.) & ! s
1232
                                                              ! *(zlev(ig,l+1)-zlev(ig,l))
1233
          *sqrt(zlev(ig,l+1))
1234
        ! alim_star(ig,l)=zlev(ig,l+1)*(1.-(zlev(ig,l+1)
1235
        ! s                         /zlev(ig,lentr(ig)+2)))**(3./2.)
1236
      END IF
1237
    END DO
1238
  END DO
1239
1240
  ! pas de thermique si couche 1 stable
1241
  DO ig = 1, ngrid
1242
    ! if (lmin(ig).gt.1) then
1243
    ! CRnouveau test
1244
    IF (alim_star(ig,1)<1.E-10) THEN
1245
      DO l = 1, klev
1246
        alim_star(ig, l) = 0.
1247
      END DO
1248
    END IF
1249
  END DO
1250
  ! calcul de l entrainement total
1251
  DO ig = 1, ngrid
1252
    alim_star_tot(ig) = 0.
1253
    entr_star_tot(ig) = 0.
1254
    detr_star_tot(ig) = 0.
1255
  END DO
1256
  DO ig = 1, ngrid
1257
    DO k = 1, klev
1258
      alim_star_tot(ig) = alim_star_tot(ig) + alim_star(ig, k)
1259
    END DO
1260
  END DO
1261
1262
  ! Calcul entrainement normalise
1263
  DO ig = 1, ngrid
1264
    IF (alim_star_tot(ig)>1.E-10) THEN
1265
      ! do l=1,lentr(ig)
1266
      DO l = 1, klev
1267
        ! def possibles pour entr_star: zdthetadz, dthetadz, zdtheta
1268
        alim_star(ig, l) = alim_star(ig, l)/alim_star_tot(ig)
1269
      END DO
1270
    END IF
1271
  END DO
1272
1273
  ! print*,'fin calcul alim_star'
1274
1275
  ! AM:initialisations
1276
  DO k = 1, nlay
1277
    DO ig = 1, ngrid
1278
      ztva(ig, k) = ztv(ig, k)
1279
      ztla(ig, k) = zthl(ig, k)
1280
      zqla(ig, k) = 0.
1281
      zqta(ig, k) = po(ig, k)
1282
      zsat(ig) = .FALSE.
1283
    END DO
1284
  END DO
1285
  DO k = 1, klev
1286
    DO ig = 1, ngrid
1287
      detr_star(ig, k) = 0.
1288
      entr_star(ig, k) = 0.
1289
      detr(ig, k) = 0.
1290
      entr(ig, k) = 0.
1291
    END DO
1292
  END DO
1293
  ! print*,'7 OK convect8'
1294
  DO k = 1, klev + 1
1295
    DO ig = 1, ngrid
1296
      zw2(ig, k) = 0.
1297
      fmc(ig, k) = 0.
1298
      ! CR
1299
      f_star(ig, k) = 0.
1300
      ! RC
1301
      larg_cons(ig, k) = 0.
1302
      larg_detr(ig, k) = 0.
1303
      wa_moy(ig, k) = 0.
1304
    END DO
1305
  END DO
1306
1307
  ! n     print*,'8 OK convect8'
1308
  DO ig = 1, ngrid
1309
    linter(ig) = 1.
1310
    lmaxa(ig) = 1
1311
    lmix(ig) = 1
1312
    wmaxa(ig) = 0.
1313
  END DO
1314
1315
  nu_min = l_mix
1316
  nu_max = 1000.
1317
  ! do ig=1,ngrid
1318
  ! nu_max=wmax_sec(ig)
1319
  ! enddo
1320
  DO ig = 1, ngrid
1321
    DO k = 1, klev
1322
      nu(ig, k) = 0.
1323
      nu_e(ig, k) = 0.
1324
    END DO
1325
  END DO
1326
  ! Calcul de l'exc�s de temp�rature du � la diffusion turbulente
1327
  DO ig = 1, ngrid
1328
    DO l = 1, klev
1329
      dtheta(ig, l) = 0.
1330
    END DO
1331
  END DO
1332
  DO ig = 1, ngrid
1333
    DO l = 1, lentr(ig) - 1
1334
      dtheta(ig, l) = sqrt(10.*0.4*zlev(ig,l+1)**2*1.*((ztv(ig,l+1)- &
1335
        ztv(ig,l))/(zlev(ig,l+1)-zlev(ig,l)))**2)
1336
    END DO
1337
  END DO
1338
  ! do l=1,nlay-2
1339
  DO l = 1, klev - 1
1340
    DO ig = 1, ngrid
1341
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. alim_star(ig,l)>1.E-10 .AND. &
1342
          zw2(ig,l)<1E-10) THEN
1343
        ! AM
1344
        ! test:on rajoute un exc�s de T dans couche alim
1345
        ! ztla(ig,l)=zthl(ig,l)+dtheta(ig,l)
1346
        ztla(ig, l) = zthl(ig, l)
1347
        ! test: on rajoute un exc�s de q dans la couche alim
1348
        ! zqta(ig,l)=po(ig,l)+0.001
1349
        zqta(ig, l) = po(ig, l)
1350
        zqla(ig, l) = zl(ig, l)
1351
        ! AM
1352
        f_star(ig, l+1) = alim_star(ig, l)
1353
        ! test:calcul de dteta
1354
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
1355
          (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l))
1356
        w_est(ig, l+1) = zw2(ig, l+1)
1357
        larg_detr(ig, l) = 0.
1358
        ! print*,'coucou boucle 1'
1359
      ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+alim_star(ig, &
1360
          l))>1.E-10) THEN
1361
        ! print*,'coucou boucle 2'
1362
        ! estimation du detrainement a partir de la geometrie du pas
1363
        ! precedent
1364
        IF ((test(ig)==1) .OR. ((.NOT. debut) .AND. (f0(ig)<1.E-10))) THEN
1365
          detr_star(ig, l) = 0.
1366
          entr_star(ig, l) = 0.
1367
          ! print*,'coucou test(ig)',test(ig),f0(ig),zmax0(ig)
1368
        ELSE
1369
          ! print*,'coucou debut detr'
1370
          ! tests sur la definition du detr
1371
          IF (zqla(ig,l-1)>1.E-10) THEN
1372
            nuage = .TRUE.
1373
          END IF
1374
1375
          w_est(ig, l+1) = zw2(ig, l)*((f_star(ig,l))**2)/(f_star(ig,l)+ &
1376
            alim_star(ig,l))**2 + 2.*rg*(ztva(ig,l-1)-ztv(ig,l))/ztv(ig, l)*( &
1377
            zlev(ig,l+1)-zlev(ig,l))
1378
          IF (w_est(ig,l+1)<0.) THEN
1379
            w_est(ig, l+1) = zw2(ig, l)
1380
          END IF
1381
          IF (l>2) THEN
1382
            IF ((w_est(ig,l+1)>w_est(ig,l)) .AND. (zlev(ig, &
1383
                l+1)<zmax_sec(ig)) .AND. (zqla(ig,l-1)<1.E-10)) THEN
1384
              detr_star(ig, l) = max(0., (rhobarz(ig, &
1385
                l+1)*sqrt(w_est(ig,l+1))*sqrt(nu(ig,l)* &
1386
                zlev(ig,l+1))-rhobarz(ig,l)*sqrt(w_est(ig,l))*sqrt(nu(ig,l)* &
1387
                zlev(ig,l)))/(r_aspect*zmax_sec(ig)))
1388
            ELSE IF ((zlev(ig,l+1)<zmax_sec(ig)) .AND. (zqla(ig, &
1389
                l-1)<1.E-10)) THEN
1390
              detr_star(ig, l) = -f0(ig)*f_star(ig, lmix(ig))/(rhobarz(ig, &
1391
                lmix(ig))*wmaxa(ig))*(rhobarz(ig,l+1)*sqrt(w_est(ig, &
1392
                l+1))*((zmax_sec(ig)-zlev(ig,l+1))/((zmax_sec(ig)-zlev(ig, &
1393
                lmix(ig)))))**2.-rhobarz(ig,l)*sqrt(w_est(ig, &
1394
                l))*((zmax_sec(ig)-zlev(ig,l))/((zmax_sec(ig)-zlev(ig,lmix(ig &
1395
                )))))**2.)
1396
            ELSE
1397
              detr_star(ig, l) = 0.002*f0(ig)*f_star(ig, l)* &
1398
                (zlev(ig,l+1)-zlev(ig,l))
1399
1400
            END IF
1401
          ELSE
1402
            detr_star(ig, l) = 0.
1403
          END IF
1404
1405
          detr_star(ig, l) = detr_star(ig, l)/f0(ig)
1406
          IF (nuage) THEN
1407
            entr_star(ig, l) = 0.4*detr_star(ig, l)
1408
          ELSE
1409
            entr_star(ig, l) = 0.4*detr_star(ig, l)
1410
          END IF
1411
1412
          IF ((detr_star(ig,l))>f_star(ig,l)) THEN
1413
            detr_star(ig, l) = f_star(ig, l)
1414
            ! entr_star(ig,l)=0.
1415
          END IF
1416
1417
          IF ((l<lentr(ig))) THEN
1418
            entr_star(ig, l) = 0.
1419
            ! detr_star(ig,l)=0.
1420
          END IF
1421
1422
          ! print*,'ok detr_star'
1423
        END IF
1424
        ! prise en compte du detrainement dans le calcul du flux
1425
        f_star(ig, l+1) = f_star(ig, l) + alim_star(ig, l) + &
1426
          entr_star(ig, l) - detr_star(ig, l)
1427
        ! test
1428
        ! if (f_star(ig,l+1).lt.0.) then
1429
        ! f_star(ig,l+1)=0.
1430
        ! entr_star(ig,l)=0.
1431
        ! detr_star(ig,l)=f_star(ig,l)+alim_star(ig,l)
1432
        ! endif
1433
        ! test sur le signe de f_star
1434
        IF (f_star(ig,l+1)>1.E-10) THEN
1435
          ! then
1436
          ! test
1437
          ! if (((f_star(ig,l+1)+detr_star(ig,l)).gt.1.e-10)) then
1438
          ! AM on melange Tl et qt du thermique
1439
          ! on rajoute un exc�s de T dans la couche alim
1440
          ! if (l.lt.lentr(ig)) then
1441
          ! ztla(ig,l)=(f_star(ig,l)*ztla(ig,l-1)+
1442
          ! s
1443
          ! (alim_star(ig,l)+entr_star(ig,l))*(zthl(ig,l)+dtheta(ig,l)))
1444
          ! s     /(f_star(ig,l+1)+detr_star(ig,l))
1445
          ! else
1446
          ztla(ig, l) = (f_star(ig,l)*ztla(ig,l-1)+(alim_star(ig, &
1447
            l)+entr_star(ig,l))*zthl(ig,l))/(f_star(ig,l+1)+detr_star(ig,l))
1448
          ! s                    /(f_star(ig,l+1))
1449
          ! endif
1450
          ! on rajoute un exc�s de q dans la couche alim
1451
          ! if (l.lt.lentr(ig)) then
1452
          ! zqta(ig,l)=(f_star(ig,l)*zqta(ig,l-1)+
1453
          ! s           (alim_star(ig,l)+entr_star(ig,l))*(po(ig,l)+0.001))
1454
          ! s                 /(f_star(ig,l+1)+detr_star(ig,l))
1455
          ! else
1456
          zqta(ig, l) = (f_star(ig,l)*zqta(ig,l-1)+(alim_star(ig, &
1457
            l)+entr_star(ig,l))*po(ig,l))/(f_star(ig,l+1)+detr_star(ig,l))
1458
          ! s                   /(f_star(ig,l+1))
1459
          ! endif
1460
          ! AM on en deduit thetav et ql du thermique
1461
          ! CR test
1462
          ! Tbef(ig)=ztla(ig,l)*zpspsk(ig,l)
1463
          tbef(ig) = ztla(ig, l)*zpspsk(ig, l)
1464
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
1465
          qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, l)
1466
          qsatbef(ig) = min(0.5, qsatbef(ig))
1467
          zcor = 1./(1.-retv*qsatbef(ig))
1468
          qsatbef(ig) = qsatbef(ig)*zcor
1469
          zsat(ig) = (max(0.,zqta(ig,l)-qsatbef(ig))>1.E-10)
1470
1471
          IF (zsat(ig) .AND. (1==1)) THEN
1472
            qlbef = max(0., zqta(ig,l)-qsatbef(ig))
1473
            dt = 0.5*rlvcp*qlbef
1474
            ! write(17,*)'DT0=',DT
1475
            DO WHILE (abs(dt)>ddt0)
1476
              ! print*,'aie'
1477
              tbef(ig) = tbef(ig) + dt
1478
              zdelta = max(0., sign(1.,rtt-tbef(ig)))
1479
              qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, l)
1480
              qsatbef(ig) = min(0.5, qsatbef(ig))
1481
              zcor = 1./(1.-retv*qsatbef(ig))
1482
              qsatbef(ig) = qsatbef(ig)*zcor
1483
              qlbef = zqta(ig, l) - qsatbef(ig)
1484
1485
              zdelta = max(0., sign(1.,rtt-tbef(ig)))
1486
              zcvm5 = r5les*(1.-zdelta) + r5ies*zdelta
1487
              zcor = 1./(1.-retv*qsatbef(ig))
1488
              dqsat_dt = foede(tbef(ig), zdelta, zcvm5, qsatbef(ig), zcor)
1489
              num = -tbef(ig) + ztla(ig, l)*zpspsk(ig, l) + rlvcp*qlbef
1490
              denom = 1. + rlvcp*dqsat_dt
1491
              IF (denom<1.E-10) THEN
1492
                PRINT *, 'pb denom'
1493
              END IF
1494
              dt = num/denom
1495
              ! write(17,*)'DT=',DT
1496
            END DO
1497
            zqla(ig, l) = max(0., zqta(ig,l)-qsatbef(ig))
1498
            zqla(ig, l) = max(0., qlbef)
1499
            ! zqla(ig,l)=0.
1500
          END IF
1501
          ! zqla(ig,l) = max(0.,zqta(ig,l)-qsatbef(ig))
1502
1503
          ! on ecrit de maniere conservative (sat ou non)
1504
          ! T = Tl +Lv/Cp ql
1505
          ! CR rq utilisation de humidite specifique ou rapport de melange?
1506
          ztva(ig, l) = ztla(ig, l)*zpspsk(ig, l) + rlvcp*zqla(ig, l)
1507
          ztva(ig, l) = ztva(ig, l)/zpspsk(ig, l)
1508
          ! on rajoute le calcul de zha pour diagnostiques (temp potentielle)
1509
          zha(ig, l) = ztva(ig, l)
1510
          ! if (l.lt.lentr(ig)) then
1511
          ! ztva(ig,l) = ztva(ig,l)*(1.+RETV*(zqta(ig,l)
1512
          ! s              -zqla(ig,l))-zqla(ig,l)) + 0.1
1513
          ! else
1514
          ztva(ig, l) = ztva(ig, l)*(1.+retv*(zqta(ig,l)-zqla(ig, &
1515
            l))-zqla(ig,l))
1516
          ! endif
1517
          ! ztva(ig,l) = ztla(ig,l)*zpspsk(ig,l)+RLvCp*zqla(ig,l)
1518
          ! s                 /(1.-retv*zqla(ig,l))
1519
          ! ztva(ig,l) = ztva(ig,l)/zpspsk(ig,l)
1520
          ! ztva(ig,l) = ztva(ig,l)*(1.+RETV*(zqta(ig,l)
1521
          ! s                 /(1.-retv*zqta(ig,l))
1522
          ! s              -zqla(ig,l)/(1.-retv*zqla(ig,l)))
1523
          ! s              -zqla(ig,l)/(1.-retv*zqla(ig,l)))
1524
          ! write(13,*)zqla(ig,l),zqla(ig,l)/(1.-retv*zqla(ig,l))
1525
          ! on ecrit zqsat
1526
          zqsatth(ig, l) = qsatbef(ig)
1527
          ! enddo
1528
          ! DO ig=1,ngrid
1529
          ! if (zw2(ig,l).ge.1.e-10.and.
1530
          ! s               f_star(ig,l)+entr_star(ig,l).gt.1.e-10) then
1531
          ! mise a jour de la vitesse ascendante (l'air entraine de la couche
1532
          ! consideree commence avec une vitesse nulle).
1533
1534
          ! if (f_star(ig,l+1).gt.1.e-10) then
1535
          zw2(ig, l+1) = zw2(ig, l)* & ! s
1536
                                       ! ((f_star(ig,l)-detr_star(ig,l))**2)
1537
          ! s                  /f_star(ig,l+1)**2+
1538
            ((f_star(ig,l))**2)/(f_star(ig,l+1)+detr_star(ig,l))**2 + & ! s
1539
                                                                        ! /(f_star(ig,l+1))**2+
1540
            2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l))
1541
          ! s                   *(f_star(ig,l)/f_star(ig,l+1))**2
1542
1543
        END IF
1544
      END IF
1545
1546
      IF (zw2(ig,l+1)<0.) THEN
1547
        linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( &
1548
          ig,l))
1549
        zw2(ig, l+1) = 0.
1550
        ! print*,'linter=',linter(ig)
1551
        ! else if ((zw2(ig,l+1).lt.1.e-10).and.(zw2(ig,l+1).ge.0.)) then
1552
        ! linter(ig)=l+1
1553
        ! print*,'linter=l',zw2(ig,l),zw2(ig,l+1)
1554
      ELSE
1555
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
1556
        ! wa_moy(ig,l+1)=zw2(ig,l+1)
1557
      END IF
1558
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
1559
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
1560
        lmix(ig) = l + 1
1561
        wmaxa(ig) = wa_moy(ig, l+1)
1562
      END IF
1563
    END DO
1564
  END DO
1565
  PRINT *, 'fin calcul zw2'
1566
1567
  ! Calcul de la couche correspondant a la hauteur du thermique
1568
  DO ig = 1, ngrid
1569
    lmax(ig) = lentr(ig)
1570
  END DO
1571
  DO ig = 1, ngrid
1572
    DO l = nlay, lentr(ig) + 1, -1
1573
      IF (zw2(ig,l)<=1.E-10) THEN
1574
        lmax(ig) = l - 1
1575
      END IF
1576
    END DO
1577
  END DO
1578
  ! pas de thermique si couche 1 stable
1579
  DO ig = 1, ngrid
1580
    IF (lmin(ig)>1) THEN
1581
      lmax(ig) = 1
1582
      lmin(ig) = 1
1583
      lentr(ig) = 1
1584
    END IF
1585
  END DO
1586
1587
  ! Determination de zw2 max
1588
  DO ig = 1, ngrid
1589
    wmax(ig) = 0.
1590
  END DO
1591
1592
  DO l = 1, nlay
1593
    DO ig = 1, ngrid
1594
      IF (l<=lmax(ig)) THEN
1595
        IF (zw2(ig,l)<0.) THEN
1596
          PRINT *, 'pb2 zw2<0'
1597
        END IF
1598
        zw2(ig, l) = sqrt(zw2(ig,l))
1599
        wmax(ig) = max(wmax(ig), zw2(ig,l))
1600
      ELSE
1601
        zw2(ig, l) = 0.
1602
      END IF
1603
    END DO
1604
  END DO
1605
1606
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
1607
  DO ig = 1, ngrid
1608
    zmax(ig) = 0.
1609
    zlevinter(ig) = zlev(ig, 1)
1610
  END DO
1611
  DO ig = 1, ngrid
1612
    ! calcul de zlevinter
1613
    zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + &
1614
      zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))
1615
    ! pour le cas ou on prend tjs lmin=1
1616
    ! zmax(ig)=max(zmax(ig),zlevinter(ig)-zlev(ig,lmin(ig)))
1617
    zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,1))
1618
    zmax0(ig) = zmax(ig)
1619
    WRITE (11, *) 'ig,lmax,linter', ig, lmax(ig), linter(ig)
1620
    WRITE (12, *) 'ig,zlevinter,zmax', ig, zmax(ig), zlevinter(ig)
1621
  END DO
1622
1623
  ! Calcul de zmax_sec et wmax_sec
1624
  CALL fermeture_seche(ngrid, nlay, pplay, pplev, pphi, zlev, rhobarz, f0, &
1625
    zpspsk, alim, zh, zo, lentr, lmin, nu_min, nu_max, r_aspect, zmax_sec2, &
1626
    wmax_sec2)
1627
1628
  PRINT *, 'avant fermeture'
1629
  ! Fermeture,determination de f
1630
  ! en lmax f=d-e
1631
  DO ig = 1, ngrid
1632
    ! entr_star(ig,lmax(ig))=0.
1633
    ! f_star(ig,lmax(ig)+1)=0.
1634
    ! detr_star(ig,lmax(ig))=f_star(ig,lmax(ig))+entr_star(ig,lmax(ig))
1635
    ! s                       +alim_star(ig,lmax(ig))
1636
  END DO
1637
1638
  DO ig = 1, ngrid
1639
    alim_star2(ig) = 0.
1640
  END DO
1641
  ! calcul de entr_star_tot
1642
  DO ig = 1, ngrid
1643
    DO k = 1, lmix(ig)
1644
      entr_star_tot(ig) = entr_star_tot(ig) & ! s
1645
                                              ! +entr_star(ig,k)
1646
        +alim_star(ig, k)
1647
      ! s                        -detr_star(ig,k)
1648
      detr_star_tot(ig) = detr_star_tot(ig) & ! s
1649
                                              ! +alim_star(ig,k)
1650
        -detr_star(ig, k) + entr_star(ig, k)
1651
    END DO
1652
  END DO
1653
1654
  DO ig = 1, ngrid
1655
    IF (alim_star_tot(ig)<1.E-10) THEN
1656
      f(ig) = 0.
1657
    ELSE
1658
      ! do k=lmin(ig),lentr(ig)
1659
      DO k = 1, lentr(ig)
1660
        alim_star2(ig) = alim_star2(ig) + alim_star(ig, k)**2/(rho(ig,k)*( &
1661
          zlev(ig,k+1)-zlev(ig,k)))
1662
      END DO
1663
      IF ((zmax_sec(ig)>1.E-10) .AND. (1==1)) THEN
1664
        f(ig) = wmax_sec(ig)/(max(500.,zmax_sec(ig))*r_aspect*alim_star2(ig))
1665
        f(ig) = f(ig) + (f0(ig)-f(ig))*exp((-ptimestep/zmax_sec(ig))*wmax_sec &
1666
          (ig))
1667
      ELSE
1668
        f(ig) = wmax(ig)/(max(500.,zmax(ig))*r_aspect*alim_star2(ig))
1669
        f(ig) = f(ig) + (f0(ig)-f(ig))*exp((-ptimestep/zmax(ig))*wmax(ig))
1670
      END IF
1671
    END IF
1672
    f0(ig) = f(ig)
1673
  END DO
1674
  PRINT *, 'apres fermeture'
1675
  ! Calcul de l'entrainement
1676
  DO ig = 1, ngrid
1677
    DO k = 1, klev
1678
      alim(ig, k) = f(ig)*alim_star(ig, k)
1679
    END DO
1680
  END DO
1681
  ! CR:test pour entrainer moins que la masse
1682
  ! do ig=1,ngrid
1683
  ! do l=1,lentr(ig)
1684
  ! if ((alim(ig,l)*ptimestep).gt.(0.9*masse(ig,l))) then
1685
  ! alim(ig,l+1)=alim(ig,l+1)+alim(ig,l)
1686
  ! s                       -0.9*masse(ig,l)/ptimestep
1687
  ! alim(ig,l)=0.9*masse(ig,l)/ptimestep
1688
  ! endif
1689
  ! enddo
1690
  ! enddo
1691
  ! calcul du d�trainement
1692
  DO ig = 1, klon
1693
    DO k = 1, klev
1694
      detr(ig, k) = f(ig)*detr_star(ig, k)
1695
      IF (detr(ig,k)<0.) THEN
1696
        ! print*,'detr1<0!!!'
1697
      END IF
1698
    END DO
1699
    DO k = 1, klev
1700
      entr(ig, k) = f(ig)*entr_star(ig, k)
1701
      IF (entr(ig,k)<0.) THEN
1702
        ! print*,'entr1<0!!!'
1703
      END IF
1704
    END DO
1705
  END DO
1706
1707
  ! do ig=1,ngrid
1708
  ! do l=1,klev
1709
  ! if (((detr(ig,l)+entr(ig,l)+alim(ig,l))*ptimestep).gt.
1710
  ! s          (masse(ig,l))) then
1711
  ! print*,'d2+e2+a2>m2','ig=',ig,'l=',l,'lmax(ig)=',lmax(ig),'d+e+a='
1712
  ! s,(detr(ig,l)+entr(ig,l)+alim(ig,l))*ptimestep,'m=',masse(ig,l)
1713
  ! endif
1714
  ! enddo
1715
  ! enddo
1716
  ! Calcul des flux
1717
1718
  DO ig = 1, ngrid
1719
    DO l = 1, lmax(ig)
1720
      ! do l=1,klev
1721
      ! fmc(ig,l+1)=f(ig)*f_star(ig,l+1)
1722
      fmc(ig, l+1) = fmc(ig, l) + alim(ig, l) + entr(ig, l) - detr(ig, l)
1723
      ! print*,'??!!','ig=',ig,'l=',l,'lmax=',lmax(ig),'lmix=',lmix(ig),
1724
      ! s  'e=',entr(ig,l),'d=',detr(ig,l),'a=',alim(ig,l),'f=',fmc(ig,l),
1725
      ! s  'f+1=',fmc(ig,l+1)
1726
      IF (fmc(ig,l+1)<0.) THEN
1727
        PRINT *, 'fmc1<0', l + 1, lmax(ig), fmc(ig, l+1)
1728
        fmc(ig, l+1) = fmc(ig, l)
1729
        detr(ig, l) = alim(ig, l) + entr(ig, l)
1730
        ! fmc(ig,l+1)=0.
1731
        ! print*,'fmc1<0',l+1,lmax(ig),fmc(ig,l+1)
1732
      END IF
1733
      ! if ((fmc(ig,l+1).gt.fmc(ig,l)).and.(l.gt.lentr(ig))) then
1734
      ! f_old=fmc(ig,l+1)
1735
      ! fmc(ig,l+1)=fmc(ig,l)
1736
      ! detr(ig,l)=detr(ig,l)+f_old-fmc(ig,l+1)
1737
      ! endif
1738
1739
      ! if ((fmc(ig,l+1).gt.fmc(ig,l)).and.(l.gt.lentr(ig))) then
1740
      ! f_old=fmc(ig,l+1)
1741
      ! fmc(ig,l+1)=fmc(ig,l)
1742
      ! detr(ig,l)=detr(ig,l)+f_old-fmc(ig,l)
1743
      ! endif
1744
      ! rajout du test sur alpha croissant
1745
      ! if test
1746
      ! if (1.eq.0) then
1747
1748
      IF (l==klev) THEN
1749
        PRINT *, 'THERMCELL PB ig=', ig, '   l=', l
1750
        abort_message = 'THERMCELL PB'
1751
        CALL abort_physic(modname, abort_message, 1)
1752
      END IF
1753
      ! if ((zw2(ig,l+1).gt.1.e-10).and.(zw2(ig,l).gt.1.e-10).and.
1754
      ! s     (l.ge.lentr(ig)).and.
1755
      IF ((zw2(ig,l+1)>1.E-10) .AND. (zw2(ig,l)>1.E-10) .AND. (l>=lentr(ig))) &
1756
          THEN
1757
        IF (((fmc(ig,l+1)/(rhobarz(ig,l+1)*zw2(ig,l+1)))>(fmc(ig,l)/ &
1758
            (rhobarz(ig,l)*zw2(ig,l))))) THEN
1759
          f_old = fmc(ig, l+1)
1760
          fmc(ig, l+1) = fmc(ig, l)*rhobarz(ig, l+1)*zw2(ig, l+1)/ &
1761
            (rhobarz(ig,l)*zw2(ig,l))
1762
          detr(ig, l) = detr(ig, l) + f_old - fmc(ig, l+1)
1763
          ! detr(ig,l)=(fmc(ig,l+1)-fmc(ig,l))/(0.4-1.)
1764
          ! entr(ig,l)=0.4*detr(ig,l)
1765
          ! entr(ig,l)=fmc(ig,l+1)-fmc(ig,l)+detr(ig,l)
1766
        END IF
1767
      END IF
1768
      IF ((fmc(ig,l+1)>fmc(ig,l)) .AND. (l>lentr(ig))) THEN
1769
        f_old = fmc(ig, l+1)
1770
        fmc(ig, l+1) = fmc(ig, l)
1771
        detr(ig, l) = detr(ig, l) + f_old - fmc(ig, l+1)
1772
      END IF
1773
      IF (detr(ig,l)>fmc(ig,l)) THEN
1774
        detr(ig, l) = fmc(ig, l)
1775
        entr(ig, l) = fmc(ig, l+1) - alim(ig, l)
1776
      END IF
1777
      IF (fmc(ig,l+1)<0.) THEN
1778
        detr(ig, l) = detr(ig, l) + fmc(ig, l+1)
1779
        fmc(ig, l+1) = 0.
1780
        PRINT *, 'fmc2<0', l + 1, lmax(ig)
1781
      END IF
1782
1783
      ! test pour ne pas avoir f=0 et d=e/=0
1784
      ! if (fmc(ig,l+1).lt.1.e-10) then
1785
      ! detr(ig,l+1)=0.
1786
      ! entr(ig,l+1)=0.
1787
      ! zqla(ig,l+1)=0.
1788
      ! zw2(ig,l+1)=0.
1789
      ! lmax(ig)=l+1
1790
      ! zmax(ig)=zlev(ig,lmax(ig))
1791
      ! endif
1792
      IF (zw2(ig,l+1)>1.E-10) THEN
1793
        IF ((((fmc(ig,l+1))/(rhobarz(ig,l+1)*zw2(ig,l+1)))>1.)) THEN
1794
          f_old = fmc(ig, l+1)
1795
          fmc(ig, l+1) = rhobarz(ig, l+1)*zw2(ig, l+1)
1796
          zw2(ig, l+1) = 0.
1797
          zqla(ig, l+1) = 0.
1798
          detr(ig, l) = detr(ig, l) + f_old - fmc(ig, l+1)
1799
          lmax(ig) = l + 1
1800
          zmax(ig) = zlev(ig, lmax(ig))
1801
          PRINT *, 'alpha>1', l + 1, lmax(ig)
1802
        END IF
1803
      END IF
1804
      ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l)
1805
      ! endif test
1806
      ! endif
1807
    END DO
1808
  END DO
1809
  DO ig = 1, ngrid
1810
    ! if (fmc(ig,lmax(ig)+1).ne.0.) then
1811
    fmc(ig, lmax(ig)+1) = 0.
1812
    entr(ig, lmax(ig)) = 0.
1813
    detr(ig, lmax(ig)) = fmc(ig, lmax(ig)) + entr(ig, lmax(ig)) + &
1814
      alim(ig, lmax(ig))
1815
    ! endif
1816
  END DO
1817
  ! test sur le signe de fmc
1818
  DO ig = 1, ngrid
1819
    DO l = 1, klev + 1
1820
      IF (fmc(ig,l)<0.) THEN
1821
        PRINT *, 'fm1<0!!!', 'ig=', ig, 'l=', l, 'a=', alim(ig, l-1), 'e=', &
1822
          entr(ig, l-1), 'f=', fmc(ig, l-1), 'd=', detr(ig, l-1), 'f+1=', &
1823
          fmc(ig, l)
1824
      END IF
1825
    END DO
1826
  END DO
1827
  ! test de verification
1828
  DO ig = 1, ngrid
1829
    DO l = 1, lmax(ig)
1830
      IF ((abs(fmc(ig,l+1)-fmc(ig,l)-alim(ig,l)-entr(ig,l)+ &
1831
          detr(ig,l)))>1.E-4) THEN
1832
        ! print*,'pbcm!!','ig=',ig,'l=',l,'lmax=',lmax(ig),'lmix=',lmix(ig),
1833
        ! s  'e=',entr(ig,l),'d=',detr(ig,l),'a=',alim(ig,l),'f=',fmc(ig,l),
1834
        ! s  'f+1=',fmc(ig,l+1)
1835
      END IF
1836
      IF (detr(ig,l)<0.) THEN
1837
        PRINT *, 'detrdemi<0!!!'
1838
      END IF
1839
    END DO
1840
  END DO
1841
1842
  ! RC
1843
  ! CR def de  zmix continu (profil parabolique des vitesses)
1844
  DO ig = 1, ngrid
1845
    IF (lmix(ig)>1.) THEN
1846
      ! test
1847
      IF (((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
1848
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
1849
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))- &
1850
          (zlev(ig,lmix(ig)))))>1E-10) THEN
1851
1852
        zmix(ig) = ((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)) &
1853
          )**2-(zlev(ig,lmix(ig)+1))**2)-(zw2(ig,lmix(ig))-zw2(ig, &
1854
          lmix(ig)+1))*((zlev(ig,lmix(ig)-1))**2-(zlev(ig,lmix(ig)))**2))/ &
1855
          (2.*((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
1856
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
1857
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))-(zlev(ig,lmix(ig))))))
1858
      ELSE
1859
        zmix(ig) = zlev(ig, lmix(ig))
1860
        PRINT *, 'pb zmix'
1861
      END IF
1862
    ELSE
1863
      zmix(ig) = 0.
1864
    END IF
1865
    ! test
1866
    IF ((zmax(ig)-zmix(ig))<=0.) THEN
1867
      zmix(ig) = 0.9*zmax(ig)
1868
      ! print*,'pb zmix>zmax'
1869
    END IF
1870
  END DO
1871
  DO ig = 1, klon
1872
    zmix0(ig) = zmix(ig)
1873
  END DO
1874
1875
  ! calcul du nouveau lmix correspondant
1876
  DO ig = 1, ngrid
1877
    DO l = 1, klev
1878
      IF (zmix(ig)>=zlev(ig,l) .AND. zmix(ig)<zlev(ig,l+1)) THEN
1879
        lmix(ig) = l
1880
      END IF
1881
    END DO
1882
  END DO
1883
1884
  ! ne devrait pas arriver!!!!!
1885
  DO ig = 1, ngrid
1886
    DO l = 1, klev
1887
      IF (detr(ig,l)>(fmc(ig,l)+alim(ig,l))+entr(ig,l)) THEN
1888
        PRINT *, 'detr2>fmc2!!!', 'ig=', ig, 'l=', l, 'd=', detr(ig, l), &
1889
          'f=', fmc(ig, l), 'lmax=', lmax(ig)
1890
        ! detr(ig,l)=fmc(ig,l)+alim(ig,l)+entr(ig,l)
1891
        ! entr(ig,l)=0.
1892
        ! fmc(ig,l+1)=0.
1893
        ! zw2(ig,l+1)=0.
1894
        ! zqla(ig,l+1)=0.
1895
        PRINT *, 'pb!fm=0 et f_star>0', l, lmax(ig)
1896
        ! lmax(ig)=l
1897
      END IF
1898
    END DO
1899
  END DO
1900
  DO ig = 1, ngrid
1901
    DO l = lmax(ig) + 1, klev + 1
1902
      ! fmc(ig,l)=0.
1903
      ! detr(ig,l)=0.
1904
      ! entr(ig,l)=0.
1905
      ! zw2(ig,l)=0.
1906
      ! zqla(ig,l)=0.
1907
    END DO
1908
  END DO
1909
1910
  ! Calcul du detrainement lors du premier passage
1911
  ! print*,'9 OK convect8'
1912
  ! print*,'WA1 ',wa_moy
1913
1914
  ! determination de l'indice du debut de la mixed layer ou w decroit
1915
1916
  ! calcul de la largeur de chaque ascendance dans le cas conservatif.
1917
  ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant
1918
  ! d'une couche est �gale � la hauteur de la couche alimentante.
1919
  ! La vitesse maximale dans l'ascendance est aussi prise comme estimation
1920
  ! de la vitesse d'entrainement horizontal dans la couche alimentante.
1921
1922
  DO l = 2, nlay
1923
    DO ig = 1, ngrid
1924
      IF (l<=lmax(ig) .AND. (test(ig)==1)) THEN
1925
        zw = max(wa_moy(ig,l), 1.E-10)
1926
        larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw)
1927
      END IF
1928
    END DO
1929
  END DO
1930
1931
  DO l = 2, nlay
1932
    DO ig = 1, ngrid
1933
      IF (l<=lmax(ig) .AND. (test(ig)==1)) THEN
1934
        ! if (idetr.eq.0) then
1935
        ! cette option est finalement en dur.
1936
        IF ((l_mix*zlev(ig,l))<0.) THEN
1937
          PRINT *, 'pb l_mix*zlev<0'
1938
        END IF
1939
        ! CR: test: nouvelle def de lambda
1940
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
1941
        IF (zw2(ig,l)>1.E-10) THEN
1942
          larg_detr(ig, l) = sqrt((l_mix/zw2(ig,l))*zlev(ig,l))
1943
        ELSE
1944
          larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l))
1945
        END IF
1946
        ! else if (idetr.eq.1) then
1947
        ! larg_detr(ig,l)=larg_cons(ig,l)
1948
        ! s            *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig))
1949
        ! else if (idetr.eq.2) then
1950
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
1951
        ! s            *sqrt(wa_moy(ig,l))
1952
        ! else if (idetr.eq.4) then
1953
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
1954
        ! s            *wa_moy(ig,l)
1955
        ! endif
1956
      END IF
1957
    END DO
1958
  END DO
1959
1960
  ! print*,'10 OK convect8'
1961
  ! print*,'WA2 ',wa_moy
1962
  ! cal1cul de la fraction de la maille concern�e par l'ascendance en tenant
1963
  ! compte de l'epluchage du thermique.
1964
1965
1966
  DO l = 2, nlay
1967
    DO ig = 1, ngrid
1968
      IF (larg_cons(ig,l)>1. .AND. (test(ig)==1)) THEN
1969
        ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),'  KKK'
1970
        fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig))
1971
        ! test
1972
        fraca(ig, l) = max(fraca(ig,l), 0.)
1973
        fraca(ig, l) = min(fraca(ig,l), 0.5)
1974
        fracd(ig, l) = 1. - fraca(ig, l)
1975
        fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
1976
      ELSE
1977
        ! wa_moy(ig,l)=0.
1978
        fraca(ig, l) = 0.
1979
        fracc(ig, l) = 0.
1980
        fracd(ig, l) = 1.
1981
      END IF
1982
    END DO
1983
  END DO
1984
  ! CR: calcul de fracazmix
1985
  DO ig = 1, ngrid
1986
    IF (test(ig)==1) THEN
1987
      fracazmix(ig) = (fraca(ig,lmix(ig)+1)-fraca(ig,lmix(ig)))/ &
1988
        (zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))*zmix(ig) + &
1989
        fraca(ig, lmix(ig)) - zlev(ig, lmix(ig))*(fraca(ig,lmix(ig)+1)-fraca( &
1990
        ig,lmix(ig)))/(zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))
1991
    END IF
1992
  END DO
1993
1994
  DO l = 2, nlay
1995
    DO ig = 1, ngrid
1996
      IF (larg_cons(ig,l)>1. .AND. (test(ig)==1)) THEN
1997
        IF (l>lmix(ig)) THEN
1998
          ! test
1999
          IF (zmax(ig)-zmix(ig)<1.E-10) THEN
2000
            ! print*,'pb xxx'
2001
            xxx(ig, l) = (lmax(ig)+1.-l)/(lmax(ig)+1.-lmix(ig))
2002
          ELSE
2003
            xxx(ig, l) = (zmax(ig)-zlev(ig,l))/(zmax(ig)-zmix(ig))
2004
          END IF
2005
          IF (idetr==0) THEN
2006
            fraca(ig, l) = fracazmix(ig)
2007
          ELSE IF (idetr==1) THEN
2008
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)
2009
          ELSE IF (idetr==2) THEN
2010
            fraca(ig, l) = fracazmix(ig)*(1.-(1.-xxx(ig,l))**2)
2011
          ELSE
2012
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)**2
2013
          END IF
2014
          ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL'
2015
          fraca(ig, l) = max(fraca(ig,l), 0.)
2016
          fraca(ig, l) = min(fraca(ig,l), 0.5)
2017
          fracd(ig, l) = 1. - fraca(ig, l)
2018
          fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
2019
        END IF
2020
      END IF
2021
    END DO
2022
  END DO
2023
2024
  PRINT *, 'fin calcul fraca'
2025
  ! print*,'11 OK convect8'
2026
  ! print*,'Ea3 ',wa_moy
2027
  ! ------------------------------------------------------------------
2028
  ! Calcul de fracd, wd
2029
  ! somme wa - wd = 0
2030
  ! ------------------------------------------------------------------
2031
2032
2033
  DO ig = 1, ngrid
2034
    fm(ig, 1) = 0.
2035
    fm(ig, nlay+1) = 0.
2036
  END DO
2037
2038
  DO l = 2, nlay
2039
    DO ig = 1, ngrid
2040
      IF (test(ig)==1) THEN
2041
        fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l)
2042
        ! CR:test
2043
        IF (alim(ig,l-1)<1E-10 .AND. fm(ig,l)>fm(ig,l-1) .AND. l>lmix(ig)) &
2044
            THEN
2045
          fm(ig, l) = fm(ig, l-1)
2046
          ! write(1,*)'ajustement fm, l',l
2047
        END IF
2048
        ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l)
2049
        ! RC
2050
      END IF
2051
    END DO
2052
    DO ig = 1, ngrid
2053
      IF (fracd(ig,l)<0.1 .AND. (test(ig)==1)) THEN
2054
        abort_message = 'fracd trop petit'
2055
        CALL abort_physic(modname, abort_message, 1)
2056
      ELSE
2057
        ! vitesse descendante "diagnostique"
2058
        wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l))
2059
      END IF
2060
    END DO
2061
  END DO
2062
2063
  DO l = 1, nlay + 1
2064
    DO ig = 1, ngrid
2065
      IF (test(ig)==0) THEN
2066
        fm(ig, l) = fmc(ig, l)
2067
      END IF
2068
    END DO
2069
  END DO
2070
2071
  ! fin du first
2072
  DO l = 1, nlay
2073
    DO ig = 1, ngrid
2074
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
2075
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
2076
    END DO
2077
  END DO
2078
2079
  ! print*,'12 OK convect8'
2080
  ! print*,'WA4 ',wa_moy
2081
  ! c------------------------------------------------------------------
2082
  ! calcul du transport vertical
2083
  ! ------------------------------------------------------------------
2084
2085
  GO TO 4444
2086
  ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep
2087
  DO l = 2, nlay - 1
2088
    DO ig = 1, ngrid
2089
      IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( &
2090
          ig,l+1)) THEN
2091
        PRINT *, 'WARN!!! FM>M ig=', ig, ' l=', l, '  FM=', &
2092
          fm(ig, l+1)*ptimestep, '   M=', masse(ig, l), masse(ig, l+1)
2093
      END IF
2094
    END DO
2095
  END DO
2096
2097
  DO l = 1, nlay
2098
    DO ig = 1, ngrid
2099
      IF ((alim(ig,l)+entr(ig,l))*ptimestep>masse(ig,l)) THEN
2100
        PRINT *, 'WARN!!! E>M ig=', ig, ' l=', l, '  E==', &
2101
          (entr(ig,l)+alim(ig,l))*ptimestep, '   M=', masse(ig, l)
2102
      END IF
2103
    END DO
2104
  END DO
2105
2106
  DO l = 1, nlay
2107
    DO ig = 1, ngrid
2108
      IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN
2109
        ! print*,'WARN!!! fm exagere ig=',ig,'   l=',l
2110
        ! s         ,'   FM=',fm(ig,l)
2111
      END IF
2112
      IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN
2113
        ! print*,'WARN!!! masse exagere ig=',ig,'   l=',l
2114
        ! s         ,'   M=',masse(ig,l)
2115
        ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)',
2116
        ! s                 rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)
2117
        ! print*,'zlev(ig,l+1),zlev(ig,l)'
2118
        ! s                ,zlev(ig,l+1),zlev(ig,l)
2119
        ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)'
2120
        ! s                ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)
2121
      END IF
2122
      IF (.NOT. alim(ig,l)>=0. .OR. .NOT. alim(ig,l)<=10.) THEN
2123
        ! print*,'WARN!!! entr exagere ig=',ig,'   l=',l
2124
        ! s         ,'   E=',entr(ig,l)
2125
      END IF
2126
    END DO
2127
  END DO
2128
2129
4444 CONTINUE
2130
2131
  ! CR:redefinition du entr
2132
  ! CR:test:on ne change pas la def du entr mais la def du fm
2133
  DO l = 1, nlay
2134
    DO ig = 1, ngrid
2135
      IF (test(ig)==1) THEN
2136
        detr(ig, l) = fm(ig, l) + alim(ig, l) - fm(ig, l+1)
2137
        IF (detr(ig,l)<0.) THEN
2138
          ! entr(ig,l)=entr(ig,l)-detr(ig,l)
2139
          fm(ig, l+1) = fm(ig, l) + alim(ig, l)
2140
          detr(ig, l) = 0.
2141
          ! write(11,*)'l,ig,entr',l,ig,entr(ig,l)
2142
          ! print*,'WARNING !!! detrainement negatif ',ig,l
2143
        END IF
2144
      END IF
2145
    END DO
2146
  END DO
2147
  ! RC
2148
2149
  IF (w2di==1) THEN
2150
    fm0 = fm0 + ptimestep*(fm-fm0)/tho
2151
    entr0 = entr0 + ptimestep*(alim+entr-entr0)/tho
2152
  ELSE
2153
    fm0 = fm
2154
    entr0 = alim + entr
2155
    detr0 = detr
2156
    alim0 = alim
2157
    ! zoa=zqta
2158
    ! entr0=alim
2159
  END IF
2160
2161
  IF (1==1) THEN
2162
    ! call dqthermcell(ngrid,nlay,ptimestep,fm0,entr0,masse
2163
    ! .    ,zh,zdhadj,zha)
2164
    ! call dqthermcell(ngrid,nlay,ptimestep,fm0,entr0,masse
2165
    ! .    ,zo,pdoadj,zoa)
2166
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zthl, &
2167
      zdthladj, zta)
2168
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, po, pdoadj, &
2169
      zoa)
2170
  ELSE
2171
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, &
2172
      zdhadj, zha)
2173
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, &
2174
      pdoadj, zoa)
2175
  END IF
2176
2177
  IF (1==0) THEN
2178
    CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, &
2179
      zu, zv, pduadj, pdvadj, zua, zva)
2180
  ELSE
2181
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, &
2182
      zua)
2183
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, &
2184
      zva)
2185
  END IF
2186
2187
  ! Calcul des moments
2188
  ! do l=1,nlay
2189
  ! do ig=1,ngrid
2190
  ! zf=0.5*(fracc(ig,l)+fracc(ig,l+1))
2191
  ! zf2=zf/(1.-zf)
2192
  ! thetath2(ig,l)=zf2*(zha(ig,l)-zh(ig,l))**2
2193
  ! wth2(ig,l)=zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2
2194
  ! enddo
2195
  ! enddo
2196
2197
2198
2199
2200
2201
2202
  ! print*,'13 OK convect8'
2203
  ! print*,'WA5 ',wa_moy
2204
  DO l = 1, nlay
2205
    DO ig = 1, ngrid
2206
      ! pdtadj(ig,l)=zdhadj(ig,l)*zpspsk(ig,l)
2207
      pdtadj(ig, l) = zdthladj(ig, l)*zpspsk(ig, l)
2208
    END DO
2209
  END DO
2210
2211
2212
  ! do l=1,nlay
2213
  ! do ig=1,ngrid
2214
  ! if(abs(pdtadj(ig,l))*86400..gt.500.) then
2215
  ! print*,'WARN!!! ig=',ig,'  l=',l
2216
  ! s         ,'   pdtadj=',pdtadj(ig,l)
2217
  ! endif
2218
  ! if(abs(pdoadj(ig,l))*86400..gt.1.) then
2219
  ! print*,'WARN!!! ig=',ig,'  l=',l
2220
  ! s         ,'   pdoadj=',pdoadj(ig,l)
2221
  ! endif
2222
  ! enddo
2223
  ! enddo
2224
2225
  ! print*,'14 OK convect8'
2226
  ! ------------------------------------------------------------------
2227
  ! Calculs pour les sorties
2228
  ! ------------------------------------------------------------------
2229
  ! calcul de fraca pour les sorties
2230
  DO l = 2, klev
2231
    DO ig = 1, klon
2232
      IF (zw2(ig,l)>1.E-10) THEN
2233
        fraca(ig, l) = fm(ig, l)/(rhobarz(ig,l)*zw2(ig,l))
2234
      ELSE
2235
        fraca(ig, l) = 0.
2236
      END IF
2237
    END DO
2238
  END DO
2239
  IF (sorties) THEN
2240
    DO l = 1, nlay
2241
      DO ig = 1, ngrid
2242
        zla(ig, l) = (1.-fracd(ig,l))*zmax(ig)
2243
        zld(ig, l) = fracd(ig, l)*zmax(ig)
2244
        IF (1.-fracd(ig,l)>1.E-10) zwa(ig, l) = wd(ig, l)*fracd(ig, l)/ &
2245
          (1.-fracd(ig,l))
2246
      END DO
2247
    END DO
2248
    ! CR calcul du niveau de condensation
2249
    ! initialisation
2250
    DO ig = 1, ngrid
2251
      nivcon(ig) = 0.
2252
      zcon(ig) = 0.
2253
    END DO
2254
    DO k = nlay, 1, -1
2255
      DO ig = 1, ngrid
2256
        IF (zqla(ig,k)>1E-10) THEN
2257
          nivcon(ig) = k
2258
          zcon(ig) = zlev(ig, k)
2259
        END IF
2260
        ! if (zcon(ig).gt.1.e-10) then
2261
        ! nuage=.true.
2262
        ! else
2263
        ! nuage=.false.
2264
        ! endif
2265
      END DO
2266
    END DO
2267
2268
    DO l = 1, nlay
2269
      DO ig = 1, ngrid
2270
        zf = fraca(ig, l)
2271
        zf2 = zf/(1.-zf)
2272
        thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l)/zpspsk(ig,l))**2
2273
        wth2(ig, l) = zf2*(zw2(ig,l))**2
2274
        ! print*,'wth2=',wth2(ig,l)
2275
        wth3(ig, l) = zf2*(1-2.*fraca(ig,l))/(1-fraca(ig,l))*zw2(ig, l)* &
2276
          zw2(ig, l)*zw2(ig, l)
2277
        q2(ig, l) = zf2*(zqta(ig,l)*1000.-po(ig,l)*1000.)**2
2278
        ! test: on calcul q2/po=ratqsc
2279
        ! if (nuage) then
2280
        ratqscth(ig, l) = sqrt(q2(ig,l))/(po(ig,l)*1000.)
2281
        ! else
2282
        ! ratqscth(ig,l)=0.
2283
        ! endif
2284
      END DO
2285
    END DO
2286
    ! calcul du ratqscdiff
2287
    sum = 0.
2288
    sumdiff = 0.
2289
    ratqsdiff(:, :) = 0.
2290
    DO ig = 1, ngrid
2291
      DO l = 1, lentr(ig)
2292
        sum = sum + alim_star(ig, l)*zqta(ig, l)*1000.
2293
      END DO
2294
    END DO
2295
    DO ig = 1, ngrid
2296
      DO l = 1, lentr(ig)
2297
        zf = fraca(ig, l)
2298
        zf2 = zf/(1.-zf)
2299
        sumdiff = sumdiff + alim_star(ig, l)*(zqta(ig,l)*1000.-sum)**2
2300
        ! ratqsdiff=ratqsdiff+alim_star(ig,l)*
2301
        ! s          (zqta(ig,l)*1000.-po(ig,l)*1000.)**2
2302
      END DO
2303
    END DO
2304
    DO l = 1, klev
2305
      DO ig = 1, ngrid
2306
        ratqsdiff(ig, l) = sqrt(sumdiff)/(po(ig,l)*1000.)
2307
        ! write(11,*)'ratqsdiff=',ratqsdiff(ig,l)
2308
      END DO
2309
    END DO
2310
2311
  END IF
2312
2313
  ! print*,'19 OK convect8'
2314
  RETURN
2315
END SUBROUTINE thermcell_cld
2316
2317
SUBROUTINE thermcell_eau(ngrid, nlay, ptimestep, pplay, pplev, pphi, pu, pv, &
2318
    pt, po, pduadj, pdvadj, pdtadj, pdoadj, fm0, entr0 & ! s
2319
                                                         ! ,pu_therm,pv_therm
2320
    , r_aspect, l_mix, w2di, tho)
2321
2322
  USE dimphy
2323
  IMPLICIT NONE
2324
2325
  ! =======================================================================
2326
2327
  ! Calcul du transport verticale dans la couche limite en presence
2328
  ! de "thermiques" explicitement representes
2329
2330
  ! R��criture � partir d'un listing papier � Habas, le 14/02/00
2331
2332
  ! le thermique est suppos� homog�ne et dissip� par m�lange avec
2333
  ! son environnement. la longueur l_mix contr�le l'efficacit� du
2334
  ! m�lange
2335
2336
  ! Le calcul du transport des diff�rentes esp�ces se fait en prenant
2337
  ! en compte:
2338
  ! 1. un flux de masse montant
2339
  ! 2. un flux de masse descendant
2340
  ! 3. un entrainement
2341
  ! 4. un detrainement
2342
2343
  ! =======================================================================
2344
2345
  ! -----------------------------------------------------------------------
2346
  ! declarations:
2347
  ! -------------
2348
2349
  include "YOMCST.h"
2350
  include "YOETHF.h"
2351
  include "FCTTRE.h"
2352
2353
  ! arguments:
2354
  ! ----------
2355
2356
  INTEGER ngrid, nlay, w2di
2357
  REAL tho
2358
  REAL ptimestep, l_mix, r_aspect
2359
  REAL pt(ngrid, nlay), pdtadj(ngrid, nlay)
2360
  REAL pu(ngrid, nlay), pduadj(ngrid, nlay)
2361
  REAL pv(ngrid, nlay), pdvadj(ngrid, nlay)
2362
  REAL po(ngrid, nlay), pdoadj(ngrid, nlay)
2363
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
2364
  REAL pphi(ngrid, nlay)
2365
2366
  INTEGER idetr
2367
  SAVE idetr
2368
  DATA idetr/3/
2369
  !$OMP THREADPRIVATE(idetr)
2370
2371
  ! local:
2372
  ! ------
2373
2374
  INTEGER ig, k, l, lmaxa(klon), lmix(klon)
2375
  REAL zsortie1d(klon)
2376
  ! CR: on remplace lmax(klon,klev+1)
2377
  INTEGER lmax(klon), lmin(klon), lentr(klon)
2378
  REAL linter(klon)
2379
  REAL zmix(klon), fracazmix(klon)
2380
  ! RC
2381
  REAL zmax(klon), zw, zz, zw2(klon, klev+1), ztva(klon, klev), zzz
2382
2383
  REAL zlev(klon, klev+1), zlay(klon, klev)
2384
  REAL zh(klon, klev), zdhadj(klon, klev)
2385
  REAL zthl(klon, klev), zdthladj(klon, klev)
2386
  REAL ztv(klon, klev)
2387
  REAL zu(klon, klev), zv(klon, klev), zo(klon, klev)
2388
  REAL zl(klon, klev)
2389
  REAL wh(klon, klev+1)
2390
  REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1)
2391
  REAL zla(klon, klev+1)
2392
  REAL zwa(klon, klev+1)
2393
  REAL zld(klon, klev+1)
2394
  REAL zwd(klon, klev+1)
2395
  REAL zsortie(klon, klev)
2396
  REAL zva(klon, klev)
2397
  REAL zua(klon, klev)
2398
  REAL zoa(klon, klev)
2399
2400
  REAL zta(klon, klev)
2401
  REAL zha(klon, klev)
2402
  REAL wa_moy(klon, klev+1)
2403
  REAL fraca(klon, klev+1)
2404
  REAL fracc(klon, klev+1)
2405
  REAL zf, zf2
2406
  REAL thetath2(klon, klev), wth2(klon, klev)
2407
  ! common/comtherm/thetath2,wth2
2408
2409
  REAL count_time
2410
  INTEGER ialt
2411
2412
  LOGICAL sorties
2413
  REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev)
2414
  REAL zpspsk(klon, klev)
2415
2416
  ! real wmax(klon,klev),wmaxa(klon)
2417
  REAL wmax(klon), wmaxa(klon)
2418
  REAL wa(klon, klev, klev+1)
2419
  REAL wd(klon, klev+1)
2420
  REAL larg_part(klon, klev, klev+1)
2421
  REAL fracd(klon, klev+1)
2422
  REAL xxx(klon, klev+1)
2423
  REAL larg_cons(klon, klev+1)
2424
  REAL larg_detr(klon, klev+1)
2425
  REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev)
2426
  REAL pu_therm(klon, klev), pv_therm(klon, klev)
2427
  REAL fm(klon, klev+1), entr(klon, klev)
2428
  REAL fmc(klon, klev+1)
2429
2430
  REAL zcor, zdelta, zcvm5, qlbef
2431
  REAL tbef(klon), qsatbef(klon)
2432
  REAL dqsat_dt, dt, num, denom
2433
  REAL reps, rlvcp, ddt0
2434
  REAL ztla(klon, klev), zqla(klon, klev), zqta(klon, klev)
2435
2436
  PARAMETER (ddt0=.01)
2437
2438
  ! CR:nouvelles variables
2439
  REAL f_star(klon, klev+1), entr_star(klon, klev)
2440
  REAL entr_star_tot(klon), entr_star2(klon)
2441
  REAL f(klon), f0(klon)
2442
  REAL zlevinter(klon)
2443
  LOGICAL first
2444
  DATA first/.FALSE./
2445
  SAVE first
2446
  !$OMP THREADPRIVATE(first)
2447
2448
  ! RC
2449
2450
  CHARACTER *2 str2
2451
  CHARACTER *10 str10
2452
2453
  CHARACTER (LEN=20) :: modname = 'thermcell_eau'
2454
  CHARACTER (LEN=80) :: abort_message
2455
2456
  LOGICAL vtest(klon), down
2457
  LOGICAL zsat(klon)
2458
2459
  EXTERNAL scopy
2460
2461
  INTEGER ncorrec, ll
2462
  SAVE ncorrec
2463
  DATA ncorrec/0/
2464
  !$OMP THREADPRIVATE(ncorrec)
2465
2466
2467
2468
  ! -----------------------------------------------------------------------
2469
  ! initialisation:
2470
  ! ---------------
2471
2472
  sorties = .TRUE.
2473
  IF (ngrid/=klon) THEN
2474
    PRINT *
2475
    PRINT *, 'STOP dans convadj'
2476
    PRINT *, 'ngrid    =', ngrid
2477
    PRINT *, 'klon  =', klon
2478
  END IF
2479
2480
  ! Initialisation
2481
  rlvcp = rlvtt/rcpd
2482
  reps = rd/rv
2483
2484
  ! -----------------------------------------------------------------------
2485
  ! AM Calcul de T,q,ql a partir de Tl et qT
2486
  ! ---------------------------------------------------
2487
2488
  ! Pr Tprec=Tl calcul de qsat
2489
  ! Si qsat>qT T=Tl, q=qT
2490
  ! Sinon DDT=(-Tprec+Tl+RLVCP (qT-qsat(T')) / (1+RLVCP dqsat/dt)
2491
  ! On cherche DDT < DDT0
2492
2493
  ! defaut
2494
  DO ll = 1, nlay
2495
    DO ig = 1, ngrid
2496
      zo(ig, ll) = po(ig, ll)
2497
      zl(ig, ll) = 0.
2498
      zh(ig, ll) = pt(ig, ll)
2499
    END DO
2500
  END DO
2501
  DO ig = 1, ngrid
2502
    zsat(ig) = .FALSE.
2503
  END DO
2504
2505
2506
  DO ll = 1, nlay
2507
    ! les points insatures sont definitifs
2508
    DO ig = 1, ngrid
2509
      tbef(ig) = pt(ig, ll)
2510
      zdelta = max(0., sign(1.,rtt-tbef(ig)))
2511
      qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, ll)
2512
      qsatbef(ig) = min(0.5, qsatbef(ig))
2513
      zcor = 1./(1.-retv*qsatbef(ig))
2514
      qsatbef(ig) = qsatbef(ig)*zcor
2515
      zsat(ig) = (max(0.,po(ig,ll)-qsatbef(ig))>0.00001)
2516
    END DO
2517
2518
    DO ig = 1, ngrid
2519
      IF (zsat(ig)) THEN
2520
        qlbef = max(0., po(ig,ll)-qsatbef(ig))
2521
        ! si sature: ql est surestime, d'ou la sous-relax
2522
        dt = 0.5*rlvcp*qlbef
2523
        ! on pourra enchainer 2 ou 3 calculs sans Do while
2524
        DO WHILE (dt>ddt0)
2525
          ! il faut verifier si c,a conserve quand on repasse en insature ...
2526
          tbef(ig) = tbef(ig) + dt
2527
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
2528
          qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, ll)
2529
          qsatbef(ig) = min(0.5, qsatbef(ig))
2530
          zcor = 1./(1.-retv*qsatbef(ig))
2531
          qsatbef(ig) = qsatbef(ig)*zcor
2532
          ! on veut le signe de qlbef
2533
          qlbef = po(ig, ll) - qsatbef(ig)
2534
          ! dqsat_dT
2535
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
2536
          zcvm5 = r5les*(1.-zdelta) + r5ies*zdelta
2537
          zcor = 1./(1.-retv*qsatbef(ig))
2538
          dqsat_dt = foede(tbef(ig), zdelta, zcvm5, qsatbef(ig), zcor)
2539
          num = -tbef(ig) + pt(ig, ll) + rlvcp*qlbef
2540
          denom = 1. + rlvcp*dqsat_dt
2541
          dt = num/denom
2542
        END DO
2543
        ! on ecrit de maniere conservative (sat ou non)
2544
        zl(ig, ll) = max(0., qlbef)
2545
        ! T = Tl +Lv/Cp ql
2546
        zh(ig, ll) = pt(ig, ll) + rlvcp*zl(ig, ll)
2547
        zo(ig, ll) = po(ig, ll) - zl(ig, ll)
2548
      END IF
2549
    END DO
2550
  END DO
2551
  ! AM fin
2552
2553
  ! -----------------------------------------------------------------------
2554
  ! incrementation eventuelle de tendances precedentes:
2555
  ! ---------------------------------------------------
2556
2557
  ! print*,'0 OK convect8'
2558
2559
  DO l = 1, nlay
2560
    DO ig = 1, ngrid
2561
      zpspsk(ig, l) = (pplay(ig,l)/pplev(ig,1))**rkappa
2562
      ! zh(ig,l)=pt(ig,l)/zpspsk(ig,l)
2563
      zu(ig, l) = pu(ig, l)
2564
      zv(ig, l) = pv(ig, l)
2565
      ! zo(ig,l)=po(ig,l)
2566
      ! ztv(ig,l)=zh(ig,l)*(1.+0.61*zo(ig,l))
2567
      ! AM attention zh est maintenant le profil de T et plus le profil de
2568
      ! theta !
2569
2570
      ! T-> Theta
2571
      ztv(ig, l) = zh(ig, l)/zpspsk(ig, l)
2572
      ! AM Theta_v
2573
      ztv(ig, l) = ztv(ig, l)*(1.+retv*(zo(ig,l))-zl(ig,l))
2574
      ! AM Thetal
2575
      zthl(ig, l) = pt(ig, l)/zpspsk(ig, l)
2576
2577
    END DO
2578
  END DO
2579
2580
  ! print*,'1 OK convect8'
2581
  ! --------------------
2582
2583
2584
  ! + + + + + + + + + + +
2585
2586
2587
  ! wa, fraca, wd, fracd --------------------   zlev(2), rhobarz
2588
  ! wh,wt,wo ...
2589
2590
  ! + + + + + + + + + + +  zh,zu,zv,zo,rho
2591
2592
2593
  ! --------------------   zlev(1)
2594
  ! \\\\\\\\\\\\\\\\\\\\
2595
2596
2597
2598
  ! -----------------------------------------------------------------------
2599
  ! Calcul des altitudes des couches
2600
  ! -----------------------------------------------------------------------
2601
2602
  DO l = 2, nlay
2603
    DO ig = 1, ngrid
2604
      zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg
2605
    END DO
2606
  END DO
2607
  DO ig = 1, ngrid
2608
    zlev(ig, 1) = 0.
2609
    zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg
2610
  END DO
2611
  DO l = 1, nlay
2612
    DO ig = 1, ngrid
2613
      zlay(ig, l) = pphi(ig, l)/rg
2614
    END DO
2615
  END DO
2616
2617
  ! print*,'2 OK convect8'
2618
  ! -----------------------------------------------------------------------
2619
  ! Calcul des densites
2620
  ! -----------------------------------------------------------------------
2621
2622
  DO l = 1, nlay
2623
    DO ig = 1, ngrid
2624
      ! rho(ig,l)=pplay(ig,l)/(zpspsk(ig,l)*RD*zh(ig,l))
2625
      rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*ztv(ig,l))
2626
    END DO
2627
  END DO
2628
2629
  DO l = 2, nlay
2630
    DO ig = 1, ngrid
2631
      rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1))
2632
    END DO
2633
  END DO
2634
2635
  DO k = 1, nlay
2636
    DO l = 1, nlay + 1
2637
      DO ig = 1, ngrid
2638
        wa(ig, k, l) = 0.
2639
      END DO
2640
    END DO
2641
  END DO
2642
2643
  ! print*,'3 OK convect8'
2644
  ! ------------------------------------------------------------------
2645
  ! Calcul de w2, quarre de w a partir de la cape
2646
  ! a partir de w2, on calcule wa, vitesse de l'ascendance
2647
2648
  ! ATTENTION: Dans cette version, pour cause d'economie de memoire,
2649
  ! w2 est stoke dans wa
2650
2651
  ! ATTENTION: dans convect8, on n'utilise le calcule des wa
2652
  ! independants par couches que pour calculer l'entrainement
2653
  ! a la base et la hauteur max de l'ascendance.
2654
2655
  ! Indicages:
2656
  ! l'ascendance provenant du niveau k traverse l'interface l avec
2657
  ! une vitesse wa(k,l).
2658
2659
  ! --------------------
2660
2661
  ! + + + + + + + + + +
2662
2663
  ! wa(k,l)   ----       --------------------    l
2664
  ! /\
2665
  ! /||\       + + + + + + + + + +
2666
  ! ||
2667
  ! ||        --------------------
2668
  ! ||
2669
  ! ||        + + + + + + + + + +
2670
  ! ||
2671
  ! ||        --------------------
2672
  ! ||__
2673
  ! |___      + + + + + + + + + +     k
2674
2675
  ! --------------------
2676
2677
2678
2679
  ! ------------------------------------------------------------------
2680
2681
  ! CR: ponderation entrainement des couches instables
2682
  ! def des entr_star tels que entr=f*entr_star
2683
  DO l = 1, klev
2684
    DO ig = 1, ngrid
2685
      entr_star(ig, l) = 0.
2686
    END DO
2687
  END DO
2688
  ! determination de la longueur de la couche d entrainement
2689
  DO ig = 1, ngrid
2690
    lentr(ig) = 1
2691
  END DO
2692
2693
  ! on ne considere que les premieres couches instables
2694
  DO k = nlay - 1, 1, -1
2695
    DO ig = 1, ngrid
2696
      IF (ztv(ig,k)>ztv(ig,k+1) .AND. ztv(ig,k+1)<ztv(ig,k+2)) THEN
2697
        lentr(ig) = k
2698
      END IF
2699
    END DO
2700
  END DO
2701
2702
  ! determination du lmin: couche d ou provient le thermique
2703
  DO ig = 1, ngrid
2704
    lmin(ig) = 1
2705
  END DO
2706
  DO ig = 1, ngrid
2707
    DO l = nlay, 2, -1
2708
      IF (ztv(ig,l-1)>ztv(ig,l)) THEN
2709
        lmin(ig) = l - 1
2710
      END IF
2711
    END DO
2712
  END DO
2713
2714
  ! definition de l'entrainement des couches
2715
  DO l = 1, klev - 1
2716
    DO ig = 1, ngrid
2717
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<=lentr(ig)) THEN
2718
        entr_star(ig, l) = (ztv(ig,l)-ztv(ig,l+1))*(zlev(ig,l+1)-zlev(ig,l))
2719
      END IF
2720
    END DO
2721
  END DO
2722
  ! pas de thermique si couche 1 stable
2723
  DO ig = 1, ngrid
2724
    IF (lmin(ig)>1) THEN
2725
      DO l = 1, klev
2726
        entr_star(ig, l) = 0.
2727
      END DO
2728
    END IF
2729
  END DO
2730
  ! calcul de l entrainement total
2731
  DO ig = 1, ngrid
2732
    entr_star_tot(ig) = 0.
2733
  END DO
2734
  DO ig = 1, ngrid
2735
    DO k = 1, klev
2736
      entr_star_tot(ig) = entr_star_tot(ig) + entr_star(ig, k)
2737
    END DO
2738
  END DO
2739
2740
  DO k = 1, klev
2741
    DO ig = 1, ngrid
2742
      ztva(ig, k) = ztv(ig, k)
2743
    END DO
2744
  END DO
2745
  ! RC
2746
  ! AM:initialisations
2747
  DO k = 1, nlay
2748
    DO ig = 1, ngrid
2749
      ztva(ig, k) = ztv(ig, k)
2750
      ztla(ig, k) = zthl(ig, k)
2751
      zqla(ig, k) = 0.
2752
      zqta(ig, k) = po(ig, k)
2753
      zsat(ig) = .FALSE.
2754
    END DO
2755
  END DO
2756
2757
  ! print*,'7 OK convect8'
2758
  DO k = 1, klev + 1
2759
    DO ig = 1, ngrid
2760
      zw2(ig, k) = 0.
2761
      fmc(ig, k) = 0.
2762
      ! CR
2763
      f_star(ig, k) = 0.
2764
      ! RC
2765
      larg_cons(ig, k) = 0.
2766
      larg_detr(ig, k) = 0.
2767
      wa_moy(ig, k) = 0.
2768
    END DO
2769
  END DO
2770
2771
  ! print*,'8 OK convect8'
2772
  DO ig = 1, ngrid
2773
    linter(ig) = 1.
2774
    lmaxa(ig) = 1
2775
    lmix(ig) = 1
2776
    wmaxa(ig) = 0.
2777
  END DO
2778
2779
  ! CR:
2780
  DO l = 1, nlay - 2
2781
    DO ig = 1, ngrid
2782
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. entr_star(ig,l)>1.E-10 .AND. &
2783
          zw2(ig,l)<1E-10) THEN
2784
        ! AM
2785
        ztla(ig, l) = zthl(ig, l)
2786
        zqta(ig, l) = po(ig, l)
2787
        zqla(ig, l) = zl(ig, l)
2788
        ! AM
2789
        f_star(ig, l+1) = entr_star(ig, l)
2790
        ! test:calcul de dteta
2791
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
2792
          (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l))
2793
        larg_detr(ig, l) = 0.
2794
      ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+entr_star(ig, &
2795
          l)>1.E-10)) THEN
2796
        f_star(ig, l+1) = f_star(ig, l) + entr_star(ig, l)
2797
2798
        ! AM on melange Tl et qt du thermique
2799
        ztla(ig, l) = (f_star(ig,l)*ztla(ig,l-1)+entr_star(ig,l)*zthl(ig,l))/ &
2800
          f_star(ig, l+1)
2801
        zqta(ig, l) = (f_star(ig,l)*zqta(ig,l-1)+entr_star(ig,l)*po(ig,l))/ &
2802
          f_star(ig, l+1)
2803
2804
        ! ztva(ig,l)=(f_star(ig,l)*ztva(ig,l-1)+entr_star(ig,l)
2805
        ! s                    *ztv(ig,l))/f_star(ig,l+1)
2806
2807
        ! AM on en deduit thetav et ql du thermique
2808
        tbef(ig) = ztla(ig, l)*zpspsk(ig, l)
2809
        zdelta = max(0., sign(1.,rtt-tbef(ig)))
2810
        qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, l)
2811
        qsatbef(ig) = min(0.5, qsatbef(ig))
2812
        zcor = 1./(1.-retv*qsatbef(ig))
2813
        qsatbef(ig) = qsatbef(ig)*zcor
2814
        zsat(ig) = (max(0.,zqta(ig,l)-qsatbef(ig))>0.00001)
2815
      END IF
2816
    END DO
2817
    DO ig = 1, ngrid
2818
      IF (zsat(ig)) THEN
2819
        qlbef = max(0., zqta(ig,l)-qsatbef(ig))
2820
        dt = 0.5*rlvcp*qlbef
2821
        DO WHILE (dt>ddt0)
2822
          tbef(ig) = tbef(ig) + dt
2823
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
2824
          qsatbef(ig) = r2es*foeew(tbef(ig), zdelta)/pplev(ig, l)
2825
          qsatbef(ig) = min(0.5, qsatbef(ig))
2826
          zcor = 1./(1.-retv*qsatbef(ig))
2827
          qsatbef(ig) = qsatbef(ig)*zcor
2828
          qlbef = zqta(ig, l) - qsatbef(ig)
2829
2830
          zdelta = max(0., sign(1.,rtt-tbef(ig)))
2831
          zcvm5 = r5les*(1.-zdelta) + r5ies*zdelta
2832
          zcor = 1./(1.-retv*qsatbef(ig))
2833
          dqsat_dt = foede(tbef(ig), zdelta, zcvm5, qsatbef(ig), zcor)
2834
          num = -tbef(ig) + ztla(ig, l)*zpspsk(ig, l) + rlvcp*qlbef
2835
          denom = 1. + rlvcp*dqsat_dt
2836
          dt = num/denom
2837
        END DO
2838
        zqla(ig, l) = max(0., zqta(ig,l)-qsatbef(ig))
2839
      END IF
2840
      ! on ecrit de maniere conservative (sat ou non)
2841
      ! T = Tl +Lv/Cp ql
2842
      ztva(ig, l) = ztla(ig, l)*zpspsk(ig, l) + rlvcp*zqla(ig, l)
2843
      ztva(ig, l) = ztva(ig, l)/zpspsk(ig, l)
2844
      ztva(ig, l) = ztva(ig, l)*(1.+retv*(zqta(ig,l)-zqla(ig,l))-zqla(ig,l))
2845
2846
    END DO
2847
    DO ig = 1, ngrid
2848
      IF (zw2(ig,l)>=1.E-10 .AND. f_star(ig,l)+entr_star(ig,l)>1.E-10) THEN
2849
        ! mise a jour de la vitesse ascendante (l'air entraine de la couche
2850
        ! consideree commence avec une vitesse nulle).
2851
2852
        zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/f_star(ig,l+1))**2 + &
2853
          2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l))
2854
      END IF
2855
      ! determination de zmax continu par interpolation lineaire
2856
      IF (zw2(ig,l+1)<0.) THEN
2857
        linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( &
2858
          ig,l))
2859
        zw2(ig, l+1) = 0.
2860
        lmaxa(ig) = l
2861
      ELSE
2862
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
2863
      END IF
2864
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
2865
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
2866
        lmix(ig) = l + 1
2867
        wmaxa(ig) = wa_moy(ig, l+1)
2868
      END IF
2869
    END DO
2870
  END DO
2871
2872
  ! Calcul de la couche correspondant a la hauteur du thermique
2873
  DO ig = 1, ngrid
2874
    lmax(ig) = lentr(ig)
2875
  END DO
2876
  DO ig = 1, ngrid
2877
    DO l = nlay, lentr(ig) + 1, -1
2878
      IF (zw2(ig,l)<=1.E-10) THEN
2879
        lmax(ig) = l - 1
2880
      END IF
2881
    END DO
2882
  END DO
2883
  ! pas de thermique si couche 1 stable
2884
  DO ig = 1, ngrid
2885
    IF (lmin(ig)>1) THEN
2886
      lmax(ig) = 1
2887
      lmin(ig) = 1
2888
    END IF
2889
  END DO
2890
2891
  ! Determination de zw2 max
2892
  DO ig = 1, ngrid
2893
    wmax(ig) = 0.
2894
  END DO
2895
2896
  DO l = 1, nlay
2897
    DO ig = 1, ngrid
2898
      IF (l<=lmax(ig)) THEN
2899
        zw2(ig, l) = sqrt(zw2(ig,l))
2900
        wmax(ig) = max(wmax(ig), zw2(ig,l))
2901
      ELSE
2902
        zw2(ig, l) = 0.
2903
      END IF
2904
    END DO
2905
  END DO
2906
2907
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
2908
  DO ig = 1, ngrid
2909
    zmax(ig) = 500.
2910
    zlevinter(ig) = zlev(ig, 1)
2911
  END DO
2912
  DO ig = 1, ngrid
2913
    ! calcul de zlevinter
2914
    zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + &
2915
      zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))
2916
    zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,lmin(ig)))
2917
  END DO
2918
2919
  ! Fermeture,determination de f
2920
  DO ig = 1, ngrid
2921
    entr_star2(ig) = 0.
2922
  END DO
2923
  DO ig = 1, ngrid
2924
    IF (entr_star_tot(ig)<1.E-10) THEN
2925
      f(ig) = 0.
2926
    ELSE
2927
      DO k = lmin(ig), lentr(ig)
2928
        entr_star2(ig) = entr_star2(ig) + entr_star(ig, k)**2/(rho(ig,k)*( &
2929
          zlev(ig,k+1)-zlev(ig,k)))
2930
      END DO
2931
      ! Nouvelle fermeture
2932
      f(ig) = wmax(ig)/(zmax(ig)*r_aspect*entr_star2(ig))*entr_star_tot(ig)
2933
      ! test
2934
      IF (first) THEN
2935
        f(ig) = f(ig) + (f0(ig)-f(ig))*exp(-ptimestep/zmax(ig)*wmax(ig))
2936
      END IF
2937
    END IF
2938
    f0(ig) = f(ig)
2939
    first = .TRUE.
2940
  END DO
2941
2942
  ! Calcul de l'entrainement
2943
  DO k = 1, klev
2944
    DO ig = 1, ngrid
2945
      entr(ig, k) = f(ig)*entr_star(ig, k)
2946
    END DO
2947
  END DO
2948
  ! Calcul des flux
2949
  DO ig = 1, ngrid
2950
    DO l = 1, lmax(ig) - 1
2951
      fmc(ig, l+1) = fmc(ig, l) + entr(ig, l)
2952
    END DO
2953
  END DO
2954
2955
  ! RC
2956
2957
2958
  ! print*,'9 OK convect8'
2959
  ! print*,'WA1 ',wa_moy
2960
2961
  ! determination de l'indice du debut de la mixed layer ou w decroit
2962
2963
  ! calcul de la largeur de chaque ascendance dans le cas conservatif.
2964
  ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant
2965
  ! d'une couche est �gale � la hauteur de la couche alimentante.
2966
  ! La vitesse maximale dans l'ascendance est aussi prise comme estimation
2967
  ! de la vitesse d'entrainement horizontal dans la couche alimentante.
2968
2969
  DO l = 2, nlay
2970
    DO ig = 1, ngrid
2971
      IF (l<=lmaxa(ig)) THEN
2972
        zw = max(wa_moy(ig,l), 1.E-10)
2973
        larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw)
2974
      END IF
2975
    END DO
2976
  END DO
2977
2978
  DO l = 2, nlay
2979
    DO ig = 1, ngrid
2980
      IF (l<=lmaxa(ig)) THEN
2981
        ! if (idetr.eq.0) then
2982
        ! cette option est finalement en dur.
2983
        larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l))
2984
        ! else if (idetr.eq.1) then
2985
        ! larg_detr(ig,l)=larg_cons(ig,l)
2986
        ! s            *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig))
2987
        ! else if (idetr.eq.2) then
2988
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
2989
        ! s            *sqrt(wa_moy(ig,l))
2990
        ! else if (idetr.eq.4) then
2991
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
2992
        ! s            *wa_moy(ig,l)
2993
        ! endif
2994
      END IF
2995
    END DO
2996
  END DO
2997
2998
  ! print*,'10 OK convect8'
2999
  ! print*,'WA2 ',wa_moy
3000
  ! calcul de la fraction de la maille concern�e par l'ascendance en tenant
3001
  ! compte de l'epluchage du thermique.
3002
3003
  ! CR def de  zmix continu (profil parabolique des vitesses)
3004
  DO ig = 1, ngrid
3005
    IF (lmix(ig)>1.) THEN
3006
      zmix(ig) = ((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig))) &
3007
        **2-(zlev(ig,lmix(ig)+1))**2)-(zw2(ig,lmix(ig))-zw2(ig, &
3008
        lmix(ig)+1))*((zlev(ig,lmix(ig)-1))**2-(zlev(ig,lmix(ig)))**2))/ &
3009
        (2.*((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
3010
        (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))-zw2(ig,lmix(ig)+1))*((zlev( &
3011
        ig,lmix(ig)-1))-(zlev(ig,lmix(ig))))))
3012
    ELSE
3013
      zmix(ig) = 0.
3014
    END IF
3015
  END DO
3016
3017
  ! calcul du nouveau lmix correspondant
3018
  DO ig = 1, ngrid
3019
    DO l = 1, klev
3020
      IF (zmix(ig)>=zlev(ig,l) .AND. zmix(ig)<zlev(ig,l+1)) THEN
3021
        lmix(ig) = l
3022
      END IF
3023
    END DO
3024
  END DO
3025
3026
  DO l = 2, nlay
3027
    DO ig = 1, ngrid
3028
      IF (larg_cons(ig,l)>1.) THEN
3029
        ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),'  KKK'
3030
        fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig))
3031
        ! test
3032
        fraca(ig, l) = max(fraca(ig,l), 0.)
3033
        fraca(ig, l) = min(fraca(ig,l), 0.5)
3034
        fracd(ig, l) = 1. - fraca(ig, l)
3035
        fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
3036
      ELSE
3037
        ! wa_moy(ig,l)=0.
3038
        fraca(ig, l) = 0.
3039
        fracc(ig, l) = 0.
3040
        fracd(ig, l) = 1.
3041
      END IF
3042
    END DO
3043
  END DO
3044
  ! CR: calcul de fracazmix
3045
  DO ig = 1, ngrid
3046
    fracazmix(ig) = (fraca(ig,lmix(ig)+1)-fraca(ig,lmix(ig)))/ &
3047
      (zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))*zmix(ig) + &
3048
      fraca(ig, lmix(ig)) - zlev(ig, lmix(ig))*(fraca(ig,lmix(ig)+1)-fraca(ig &
3049
      ,lmix(ig)))/(zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))
3050
  END DO
3051
3052
  DO l = 2, nlay
3053
    DO ig = 1, ngrid
3054
      IF (larg_cons(ig,l)>1.) THEN
3055
        IF (l>lmix(ig)) THEN
3056
          xxx(ig, l) = (zmax(ig)-zlev(ig,l))/(zmax(ig)-zmix(ig))
3057
          IF (idetr==0) THEN
3058
            fraca(ig, l) = fracazmix(ig)
3059
          ELSE IF (idetr==1) THEN
3060
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)
3061
          ELSE IF (idetr==2) THEN
3062
            fraca(ig, l) = fracazmix(ig)*(1.-(1.-xxx(ig,l))**2)
3063
          ELSE
3064
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)**2
3065
          END IF
3066
          ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL'
3067
          fraca(ig, l) = max(fraca(ig,l), 0.)
3068
          fraca(ig, l) = min(fraca(ig,l), 0.5)
3069
          fracd(ig, l) = 1. - fraca(ig, l)
3070
          fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
3071
        END IF
3072
      END IF
3073
    END DO
3074
  END DO
3075
3076
  ! print*,'11 OK convect8'
3077
  ! print*,'Ea3 ',wa_moy
3078
  ! ------------------------------------------------------------------
3079
  ! Calcul de fracd, wd
3080
  ! somme wa - wd = 0
3081
  ! ------------------------------------------------------------------
3082
3083
3084
  DO ig = 1, ngrid
3085
    fm(ig, 1) = 0.
3086
    fm(ig, nlay+1) = 0.
3087
  END DO
3088
3089
  DO l = 2, nlay
3090
    DO ig = 1, ngrid
3091
      fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l)
3092
      ! CR:test
3093
      IF (entr(ig,l-1)<1E-10 .AND. fm(ig,l)>fm(ig,l-1) .AND. l>lmix(ig)) THEN
3094
        fm(ig, l) = fm(ig, l-1)
3095
        ! write(1,*)'ajustement fm, l',l
3096
      END IF
3097
      ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l)
3098
      ! RC
3099
    END DO
3100
    DO ig = 1, ngrid
3101
      IF (fracd(ig,l)<0.1) THEN
3102
        abort_message = 'fracd trop petit'
3103
        CALL abort_physic(modname, abort_message, 1)
3104
      ELSE
3105
        ! vitesse descendante "diagnostique"
3106
        wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l))
3107
      END IF
3108
    END DO
3109
  END DO
3110
3111
  DO l = 1, nlay
3112
    DO ig = 1, ngrid
3113
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
3114
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
3115
    END DO
3116
  END DO
3117
3118
  ! print*,'12 OK convect8'
3119
  ! print*,'WA4 ',wa_moy
3120
  ! c------------------------------------------------------------------
3121
  ! calcul du transport vertical
3122
  ! ------------------------------------------------------------------
3123
3124
  GO TO 4444
3125
  ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep
3126
  DO l = 2, nlay - 1
3127
    DO ig = 1, ngrid
3128
      IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( &
3129
          ig,l+1)) THEN
3130
        ! print*,'WARN!!! FM>M ig=',ig,' l=',l,'  FM='
3131
        ! s         ,fm(ig,l+1)*ptimestep
3132
        ! s         ,'   M=',masse(ig,l),masse(ig,l+1)
3133
      END IF
3134
    END DO
3135
  END DO
3136
3137
  DO l = 1, nlay
3138
    DO ig = 1, ngrid
3139
      IF (entr(ig,l)*ptimestep>masse(ig,l)) THEN
3140
        ! print*,'WARN!!! E>M ig=',ig,' l=',l,'  E=='
3141
        ! s         ,entr(ig,l)*ptimestep
3142
        ! s         ,'   M=',masse(ig,l)
3143
      END IF
3144
    END DO
3145
  END DO
3146
3147
  DO l = 1, nlay
3148
    DO ig = 1, ngrid
3149
      IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN
3150
        ! print*,'WARN!!! fm exagere ig=',ig,'   l=',l
3151
        ! s         ,'   FM=',fm(ig,l)
3152
      END IF
3153
      IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN
3154
        ! print*,'WARN!!! masse exagere ig=',ig,'   l=',l
3155
        ! s         ,'   M=',masse(ig,l)
3156
        ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)',
3157
        ! s                 rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)
3158
        ! print*,'zlev(ig,l+1),zlev(ig,l)'
3159
        ! s                ,zlev(ig,l+1),zlev(ig,l)
3160
        ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)'
3161
        ! s                ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)
3162
      END IF
3163
      IF (.NOT. entr(ig,l)>=0. .OR. .NOT. entr(ig,l)<=10.) THEN
3164
        ! print*,'WARN!!! entr exagere ig=',ig,'   l=',l
3165
        ! s         ,'   E=',entr(ig,l)
3166
      END IF
3167
    END DO
3168
  END DO
3169
3170
4444 CONTINUE
3171
3172
  IF (w2di==1) THEN
3173
    fm0 = fm0 + ptimestep*(fm-fm0)/tho
3174
    entr0 = entr0 + ptimestep*(entr-entr0)/tho
3175
  ELSE
3176
    fm0 = fm
3177
    entr0 = entr
3178
  END IF
3179
3180
  IF (1==1) THEN
3181
    ! call dqthermcell(ngrid,nlay,ptimestep,fm0,entr0,masse
3182
    ! .    ,zh,zdhadj,zha)
3183
    ! call dqthermcell(ngrid,nlay,ptimestep,fm0,entr0,masse
3184
    ! .    ,zo,pdoadj,zoa)
3185
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zthl, &
3186
      zdthladj, zta)
3187
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, po, pdoadj, &
3188
      zoa)
3189
  ELSE
3190
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, &
3191
      zdhadj, zha)
3192
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, &
3193
      pdoadj, zoa)
3194
  END IF
3195
3196
  IF (1==0) THEN
3197
    CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, &
3198
      zu, zv, pduadj, pdvadj, zua, zva)
3199
  ELSE
3200
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, &
3201
      zua)
3202
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, &
3203
      zva)
3204
  END IF
3205
3206
  DO l = 1, nlay
3207
    DO ig = 1, ngrid
3208
      zf = 0.5*(fracc(ig,l)+fracc(ig,l+1))
3209
      zf2 = zf/(1.-zf)
3210
      thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l))**2
3211
      wth2(ig, l) = zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2
3212
    END DO
3213
  END DO
3214
3215
3216
3217
  ! print*,'13 OK convect8'
3218
  ! print*,'WA5 ',wa_moy
3219
  DO l = 1, nlay
3220
    DO ig = 1, ngrid
3221
      ! pdtadj(ig,l)=zdhadj(ig,l)*zpspsk(ig,l)
3222
      pdtadj(ig, l) = zdthladj(ig, l)*zpspsk(ig, l)
3223
    END DO
3224
  END DO
3225
3226
3227
  ! do l=1,nlay
3228
  ! do ig=1,ngrid
3229
  ! if(abs(pdtadj(ig,l))*86400..gt.500.) then
3230
  ! print*,'WARN!!! ig=',ig,'  l=',l
3231
  ! s         ,'   pdtadj=',pdtadj(ig,l)
3232
  ! endif
3233
  ! if(abs(pdoadj(ig,l))*86400..gt.1.) then
3234
  ! print*,'WARN!!! ig=',ig,'  l=',l
3235
  ! s         ,'   pdoadj=',pdoadj(ig,l)
3236
  ! endif
3237
  ! enddo
3238
  ! enddo
3239
3240
  ! print*,'14 OK convect8'
3241
  ! ------------------------------------------------------------------
3242
  ! Calculs pour les sorties
3243
  ! ------------------------------------------------------------------
3244
3245
  RETURN
3246
END SUBROUTINE thermcell_eau
3247
3248
SUBROUTINE thermcell(ngrid, nlay, ptimestep, pplay, pplev, pphi, pu, pv, pt, &
3249
    po, pduadj, pdvadj, pdtadj, pdoadj, fm0, entr0 & ! s
3250
                                                     ! ,pu_therm,pv_therm
3251
    , r_aspect, l_mix, w2di, tho)
3252
3253
  USE dimphy
3254
  IMPLICIT NONE
3255
3256
  ! =======================================================================
3257
3258
  ! Calcul du transport verticale dans la couche limite en presence
3259
  ! de "thermiques" explicitement representes
3260
3261
  ! R��criture � partir d'un listing papier � Habas, le 14/02/00
3262
3263
  ! le thermique est suppos� homog�ne et dissip� par m�lange avec
3264
  ! son environnement. la longueur l_mix contr�le l'efficacit� du
3265
  ! m�lange
3266
3267
  ! Le calcul du transport des diff�rentes esp�ces se fait en prenant
3268
  ! en compte:
3269
  ! 1. un flux de masse montant
3270
  ! 2. un flux de masse descendant
3271
  ! 3. un entrainement
3272
  ! 4. un detrainement
3273
3274
  ! =======================================================================
3275
3276
  ! -----------------------------------------------------------------------
3277
  ! declarations:
3278
  ! -------------
3279
3280
  include "YOMCST.h"
3281
3282
  ! arguments:
3283
  ! ----------
3284
3285
  INTEGER ngrid, nlay, w2di
3286
  REAL tho
3287
  REAL ptimestep, l_mix, r_aspect
3288
  REAL pt(ngrid, nlay), pdtadj(ngrid, nlay)
3289
  REAL pu(ngrid, nlay), pduadj(ngrid, nlay)
3290
  REAL pv(ngrid, nlay), pdvadj(ngrid, nlay)
3291
  REAL po(ngrid, nlay), pdoadj(ngrid, nlay)
3292
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
3293
  REAL pphi(ngrid, nlay)
3294
3295
  INTEGER idetr
3296
  SAVE idetr
3297
  DATA idetr/3/
3298
  !$OMP THREADPRIVATE(idetr)
3299
3300
  ! local:
3301
  ! ------
3302
3303
  INTEGER ig, k, l, lmaxa(klon), lmix(klon)
3304
  REAL zsortie1d(klon)
3305
  ! CR: on remplace lmax(klon,klev+1)
3306
  INTEGER lmax(klon), lmin(klon), lentr(klon)
3307
  REAL linter(klon)
3308
  REAL zmix(klon), fracazmix(klon)
3309
  ! RC
3310
  REAL zmax(klon), zw, zz, zw2(klon, klev+1), ztva(klon, klev), zzz
3311
3312
  REAL zlev(klon, klev+1), zlay(klon, klev)
3313
  REAL zh(klon, klev), zdhadj(klon, klev)
3314
  REAL ztv(klon, klev)
3315
  REAL zu(klon, klev), zv(klon, klev), zo(klon, klev)
3316
  REAL wh(klon, klev+1)
3317
  REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1)
3318
  REAL zla(klon, klev+1)
3319
  REAL zwa(klon, klev+1)
3320
  REAL zld(klon, klev+1)
3321
  REAL zwd(klon, klev+1)
3322
  REAL zsortie(klon, klev)
3323
  REAL zva(klon, klev)
3324
  REAL zua(klon, klev)
3325
  REAL zoa(klon, klev)
3326
3327
  REAL zha(klon, klev)
3328
  REAL wa_moy(klon, klev+1)
3329
  REAL fraca(klon, klev+1)
3330
  REAL fracc(klon, klev+1)
3331
  REAL zf, zf2
3332
  REAL thetath2(klon, klev), wth2(klon, klev)
3333
  ! common/comtherm/thetath2,wth2
3334
3335
  REAL count_time
3336
  INTEGER ialt
3337
3338
  LOGICAL sorties
3339
  REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev)
3340
  REAL zpspsk(klon, klev)
3341
3342
  ! real wmax(klon,klev),wmaxa(klon)
3343
  REAL wmax(klon), wmaxa(klon)
3344
  REAL wa(klon, klev, klev+1)
3345
  REAL wd(klon, klev+1)
3346
  REAL larg_part(klon, klev, klev+1)
3347
  REAL fracd(klon, klev+1)
3348
  REAL xxx(klon, klev+1)
3349
  REAL larg_cons(klon, klev+1)
3350
  REAL larg_detr(klon, klev+1)
3351
  REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev)
3352
  REAL pu_therm(klon, klev), pv_therm(klon, klev)
3353
  REAL fm(klon, klev+1), entr(klon, klev)
3354
  REAL fmc(klon, klev+1)
3355
3356
  ! CR:nouvelles variables
3357
  REAL f_star(klon, klev+1), entr_star(klon, klev)
3358
  REAL entr_star_tot(klon), entr_star2(klon)
3359
  REAL f(klon), f0(klon)
3360
  REAL zlevinter(klon)
3361
  LOGICAL first
3362
  DATA first/.FALSE./
3363
  SAVE first
3364
  !$OMP THREADPRIVATE(first)
3365
  ! RC
3366
3367
  CHARACTER *2 str2
3368
  CHARACTER *10 str10
3369
3370
  CHARACTER (LEN=20) :: modname = 'thermcell'
3371
  CHARACTER (LEN=80) :: abort_message
3372
3373
  LOGICAL vtest(klon), down
3374
3375
  EXTERNAL scopy
3376
3377
  INTEGER ncorrec, ll
3378
  SAVE ncorrec
3379
  DATA ncorrec/0/
3380
  !$OMP THREADPRIVATE(ncorrec)
3381
3382
3383
  ! -----------------------------------------------------------------------
3384
  ! initialisation:
3385
  ! ---------------
3386
3387
  sorties = .TRUE.
3388
  IF (ngrid/=klon) THEN
3389
    PRINT *
3390
    PRINT *, 'STOP dans convadj'
3391
    PRINT *, 'ngrid    =', ngrid
3392
    PRINT *, 'klon  =', klon
3393
  END IF
3394
3395
  ! -----------------------------------------------------------------------
3396
  ! incrementation eventuelle de tendances precedentes:
3397
  ! ---------------------------------------------------
3398
3399
  ! print*,'0 OK convect8'
3400
3401
  DO l = 1, nlay
3402
    DO ig = 1, ngrid
3403
      zpspsk(ig, l) = (pplay(ig,l)/pplev(ig,1))**rkappa
3404
      zh(ig, l) = pt(ig, l)/zpspsk(ig, l)
3405
      zu(ig, l) = pu(ig, l)
3406
      zv(ig, l) = pv(ig, l)
3407
      zo(ig, l) = po(ig, l)
3408
      ztv(ig, l) = zh(ig, l)*(1.+0.61*zo(ig,l))
3409
    END DO
3410
  END DO
3411
3412
  ! print*,'1 OK convect8'
3413
  ! --------------------
3414
3415
3416
  ! + + + + + + + + + + +
3417
3418
3419
  ! wa, fraca, wd, fracd --------------------   zlev(2), rhobarz
3420
  ! wh,wt,wo ...
3421
3422
  ! + + + + + + + + + + +  zh,zu,zv,zo,rho
3423
3424
3425
  ! --------------------   zlev(1)
3426
  ! \\\\\\\\\\\\\\\\\\\\
3427
3428
3429
3430
  ! -----------------------------------------------------------------------
3431
  ! Calcul des altitudes des couches
3432
  ! -----------------------------------------------------------------------
3433
3434
  DO l = 2, nlay
3435
    DO ig = 1, ngrid
3436
      zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg
3437
    END DO
3438
  END DO
3439
  DO ig = 1, ngrid
3440
    zlev(ig, 1) = 0.
3441
    zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg
3442
  END DO
3443
  DO l = 1, nlay
3444
    DO ig = 1, ngrid
3445
      zlay(ig, l) = pphi(ig, l)/rg
3446
    END DO
3447
  END DO
3448
3449
  ! print*,'2 OK convect8'
3450
  ! -----------------------------------------------------------------------
3451
  ! Calcul des densites
3452
  ! -----------------------------------------------------------------------
3453
3454
  DO l = 1, nlay
3455
    DO ig = 1, ngrid
3456
      rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*zh(ig,l))
3457
    END DO
3458
  END DO
3459
3460
  DO l = 2, nlay
3461
    DO ig = 1, ngrid
3462
      rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1))
3463
    END DO
3464
  END DO
3465
3466
  DO k = 1, nlay
3467
    DO l = 1, nlay + 1
3468
      DO ig = 1, ngrid
3469
        wa(ig, k, l) = 0.
3470
      END DO
3471
    END DO
3472
  END DO
3473
3474
  ! print*,'3 OK convect8'
3475
  ! ------------------------------------------------------------------
3476
  ! Calcul de w2, quarre de w a partir de la cape
3477
  ! a partir de w2, on calcule wa, vitesse de l'ascendance
3478
3479
  ! ATTENTION: Dans cette version, pour cause d'economie de memoire,
3480
  ! w2 est stoke dans wa
3481
3482
  ! ATTENTION: dans convect8, on n'utilise le calcule des wa
3483
  ! independants par couches que pour calculer l'entrainement
3484
  ! a la base et la hauteur max de l'ascendance.
3485
3486
  ! Indicages:
3487
  ! l'ascendance provenant du niveau k traverse l'interface l avec
3488
  ! une vitesse wa(k,l).
3489
3490
  ! --------------------
3491
3492
  ! + + + + + + + + + +
3493
3494
  ! wa(k,l)   ----       --------------------    l
3495
  ! /\
3496
  ! /||\       + + + + + + + + + +
3497
  ! ||
3498
  ! ||        --------------------
3499
  ! ||
3500
  ! ||        + + + + + + + + + +
3501
  ! ||
3502
  ! ||        --------------------
3503
  ! ||__
3504
  ! |___      + + + + + + + + + +     k
3505
3506
  ! --------------------
3507
3508
3509
3510
  ! ------------------------------------------------------------------
3511
3512
  ! CR: ponderation entrainement des couches instables
3513
  ! def des entr_star tels que entr=f*entr_star
3514
  DO l = 1, klev
3515
    DO ig = 1, ngrid
3516
      entr_star(ig, l) = 0.
3517
    END DO
3518
  END DO
3519
  ! determination de la longueur de la couche d entrainement
3520
  DO ig = 1, ngrid
3521
    lentr(ig) = 1
3522
  END DO
3523
3524
  ! on ne considere que les premieres couches instables
3525
  DO k = nlay - 2, 1, -1
3526
    DO ig = 1, ngrid
3527
      IF (ztv(ig,k)>ztv(ig,k+1) .AND. ztv(ig,k+1)<=ztv(ig,k+2)) THEN
3528
        lentr(ig) = k
3529
      END IF
3530
    END DO
3531
  END DO
3532
3533
  ! determination du lmin: couche d ou provient le thermique
3534
  DO ig = 1, ngrid
3535
    lmin(ig) = 1
3536
  END DO
3537
  DO ig = 1, ngrid
3538
    DO l = nlay, 2, -1
3539
      IF (ztv(ig,l-1)>ztv(ig,l)) THEN
3540
        lmin(ig) = l - 1
3541
      END IF
3542
    END DO
3543
  END DO
3544
3545
  ! definition de l'entrainement des couches
3546
  DO l = 1, klev - 1
3547
    DO ig = 1, ngrid
3548
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<=lentr(ig)) THEN
3549
        entr_star(ig, l) = (ztv(ig,l)-ztv(ig,l+1))*(zlev(ig,l+1)-zlev(ig,l))
3550
      END IF
3551
    END DO
3552
  END DO
3553
  ! pas de thermique si couches 1->5 stables
3554
  DO ig = 1, ngrid
3555
    IF (lmin(ig)>5) THEN
3556
      DO l = 1, klev
3557
        entr_star(ig, l) = 0.
3558
      END DO
3559
    END IF
3560
  END DO
3561
  ! calcul de l entrainement total
3562
  DO ig = 1, ngrid
3563
    entr_star_tot(ig) = 0.
3564
  END DO
3565
  DO ig = 1, ngrid
3566
    DO k = 1, klev
3567
      entr_star_tot(ig) = entr_star_tot(ig) + entr_star(ig, k)
3568
    END DO
3569
  END DO
3570
3571
  PRINT *, 'fin calcul entr_star'
3572
  DO k = 1, klev
3573
    DO ig = 1, ngrid
3574
      ztva(ig, k) = ztv(ig, k)
3575
    END DO
3576
  END DO
3577
  ! RC
3578
  ! print*,'7 OK convect8'
3579
  DO k = 1, klev + 1
3580
    DO ig = 1, ngrid
3581
      zw2(ig, k) = 0.
3582
      fmc(ig, k) = 0.
3583
      ! CR
3584
      f_star(ig, k) = 0.
3585
      ! RC
3586
      larg_cons(ig, k) = 0.
3587
      larg_detr(ig, k) = 0.
3588
      wa_moy(ig, k) = 0.
3589
    END DO
3590
  END DO
3591
3592
  ! print*,'8 OK convect8'
3593
  DO ig = 1, ngrid
3594
    linter(ig) = 1.
3595
    lmaxa(ig) = 1
3596
    lmix(ig) = 1
3597
    wmaxa(ig) = 0.
3598
  END DO
3599
3600
  ! CR:
3601
  DO l = 1, nlay - 2
3602
    DO ig = 1, ngrid
3603
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. entr_star(ig,l)>1.E-10 .AND. &
3604
          zw2(ig,l)<1E-10) THEN
3605
        f_star(ig, l+1) = entr_star(ig, l)
3606
        ! test:calcul de dteta
3607
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
3608
          (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l))
3609
        larg_detr(ig, l) = 0.
3610
      ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+entr_star(ig, &
3611
          l)>1.E-10)) THEN
3612
        f_star(ig, l+1) = f_star(ig, l) + entr_star(ig, l)
3613
        ztva(ig, l) = (f_star(ig,l)*ztva(ig,l-1)+entr_star(ig,l)*ztv(ig,l))/ &
3614
          f_star(ig, l+1)
3615
        zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/f_star(ig,l+1))**2 + &
3616
          2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l))
3617
      END IF
3618
      ! determination de zmax continu par interpolation lineaire
3619
      IF (zw2(ig,l+1)<0.) THEN
3620
        ! test
3621
        IF (abs(zw2(ig,l+1)-zw2(ig,l))<1E-10) THEN
3622
          PRINT *, 'pb linter'
3623
        END IF
3624
        linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( &
3625
          ig,l))
3626
        zw2(ig, l+1) = 0.
3627
        lmaxa(ig) = l
3628
      ELSE
3629
        IF (zw2(ig,l+1)<0.) THEN
3630
          PRINT *, 'pb1 zw2<0'
3631
        END IF
3632
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
3633
      END IF
3634
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
3635
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
3636
        lmix(ig) = l + 1
3637
        wmaxa(ig) = wa_moy(ig, l+1)
3638
      END IF
3639
    END DO
3640
  END DO
3641
  PRINT *, 'fin calcul zw2'
3642
3643
  ! Calcul de la couche correspondant a la hauteur du thermique
3644
  DO ig = 1, ngrid
3645
    lmax(ig) = lentr(ig)
3646
  END DO
3647
  DO ig = 1, ngrid
3648
    DO l = nlay, lentr(ig) + 1, -1
3649
      IF (zw2(ig,l)<=1.E-10) THEN
3650
        lmax(ig) = l - 1
3651
      END IF
3652
    END DO
3653
  END DO
3654
  ! pas de thermique si couches 1->5 stables
3655
  DO ig = 1, ngrid
3656
    IF (lmin(ig)>5) THEN
3657
      lmax(ig) = 1
3658
      lmin(ig) = 1
3659
    END IF
3660
  END DO
3661
3662
  ! Determination de zw2 max
3663
  DO ig = 1, ngrid
3664
    wmax(ig) = 0.
3665
  END DO
3666
3667
  DO l = 1, nlay
3668
    DO ig = 1, ngrid
3669
      IF (l<=lmax(ig)) THEN
3670
        IF (zw2(ig,l)<0.) THEN
3671
          PRINT *, 'pb2 zw2<0'
3672
        END IF
3673
        zw2(ig, l) = sqrt(zw2(ig,l))
3674
        wmax(ig) = max(wmax(ig), zw2(ig,l))
3675
      ELSE
3676
        zw2(ig, l) = 0.
3677
      END IF
3678
    END DO
3679
  END DO
3680
3681
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
3682
  DO ig = 1, ngrid
3683
    zmax(ig) = 0.
3684
    zlevinter(ig) = zlev(ig, 1)
3685
  END DO
3686
  DO ig = 1, ngrid
3687
    ! calcul de zlevinter
3688
    zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + &
3689
      zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))
3690
    zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,lmin(ig)))
3691
  END DO
3692
3693
  PRINT *, 'avant fermeture'
3694
  ! Fermeture,determination de f
3695
  DO ig = 1, ngrid
3696
    entr_star2(ig) = 0.
3697
  END DO
3698
  DO ig = 1, ngrid
3699
    IF (entr_star_tot(ig)<1.E-10) THEN
3700
      f(ig) = 0.
3701
    ELSE
3702
      DO k = lmin(ig), lentr(ig)
3703
        entr_star2(ig) = entr_star2(ig) + entr_star(ig, k)**2/(rho(ig,k)*( &
3704
          zlev(ig,k+1)-zlev(ig,k)))
3705
      END DO
3706
      ! Nouvelle fermeture
3707
      f(ig) = wmax(ig)/(max(500.,zmax(ig))*r_aspect*entr_star2(ig))* &
3708
        entr_star_tot(ig)
3709
      ! test
3710
      ! if (first) then
3711
      ! f(ig)=f(ig)+(f0(ig)-f(ig))*exp(-ptimestep/zmax(ig)
3712
      ! s             *wmax(ig))
3713
      ! endif
3714
    END IF
3715
    ! f0(ig)=f(ig)
3716
    ! first=.true.
3717
  END DO
3718
  PRINT *, 'apres fermeture'
3719
3720
  ! Calcul de l'entrainement
3721
  DO k = 1, klev
3722
    DO ig = 1, ngrid
3723
      entr(ig, k) = f(ig)*entr_star(ig, k)
3724
    END DO
3725
  END DO
3726
  ! Calcul des flux
3727
  DO ig = 1, ngrid
3728
    DO l = 1, lmax(ig) - 1
3729
      fmc(ig, l+1) = fmc(ig, l) + entr(ig, l)
3730
    END DO
3731
  END DO
3732
3733
  ! RC
3734
3735
3736
  ! print*,'9 OK convect8'
3737
  ! print*,'WA1 ',wa_moy
3738
3739
  ! determination de l'indice du debut de la mixed layer ou w decroit
3740
3741
  ! calcul de la largeur de chaque ascendance dans le cas conservatif.
3742
  ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant
3743
  ! d'une couche est �gale � la hauteur de la couche alimentante.
3744
  ! La vitesse maximale dans l'ascendance est aussi prise comme estimation
3745
  ! de la vitesse d'entrainement horizontal dans la couche alimentante.
3746
3747
  DO l = 2, nlay
3748
    DO ig = 1, ngrid
3749
      IF (l<=lmaxa(ig)) THEN
3750
        zw = max(wa_moy(ig,l), 1.E-10)
3751
        larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw)
3752
      END IF
3753
    END DO
3754
  END DO
3755
3756
  DO l = 2, nlay
3757
    DO ig = 1, ngrid
3758
      IF (l<=lmaxa(ig)) THEN
3759
        ! if (idetr.eq.0) then
3760
        ! cette option est finalement en dur.
3761
        IF ((l_mix*zlev(ig,l))<0.) THEN
3762
          PRINT *, 'pb l_mix*zlev<0'
3763
        END IF
3764
        larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l))
3765
        ! else if (idetr.eq.1) then
3766
        ! larg_detr(ig,l)=larg_cons(ig,l)
3767
        ! s            *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig))
3768
        ! else if (idetr.eq.2) then
3769
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
3770
        ! s            *sqrt(wa_moy(ig,l))
3771
        ! else if (idetr.eq.4) then
3772
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
3773
        ! s            *wa_moy(ig,l)
3774
        ! endif
3775
      END IF
3776
    END DO
3777
  END DO
3778
3779
  ! print*,'10 OK convect8'
3780
  ! print*,'WA2 ',wa_moy
3781
  ! calcul de la fraction de la maille concern�e par l'ascendance en tenant
3782
  ! compte de l'epluchage du thermique.
3783
3784
  ! CR def de  zmix continu (profil parabolique des vitesses)
3785
  DO ig = 1, ngrid
3786
    IF (lmix(ig)>1.) THEN
3787
      ! test
3788
      IF (((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
3789
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
3790
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))- &
3791
          (zlev(ig,lmix(ig)))))>1E-10) THEN
3792
3793
        zmix(ig) = ((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)) &
3794
          )**2-(zlev(ig,lmix(ig)+1))**2)-(zw2(ig,lmix(ig))-zw2(ig, &
3795
          lmix(ig)+1))*((zlev(ig,lmix(ig)-1))**2-(zlev(ig,lmix(ig)))**2))/ &
3796
          (2.*((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
3797
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
3798
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))-(zlev(ig,lmix(ig))))))
3799
      ELSE
3800
        zmix(ig) = zlev(ig, lmix(ig))
3801
        PRINT *, 'pb zmix'
3802
      END IF
3803
    ELSE
3804
      zmix(ig) = 0.
3805
    END IF
3806
    ! test
3807
    IF ((zmax(ig)-zmix(ig))<0.) THEN
3808
      zmix(ig) = 0.99*zmax(ig)
3809
      ! print*,'pb zmix>zmax'
3810
    END IF
3811
  END DO
3812
3813
  ! calcul du nouveau lmix correspondant
3814
  DO ig = 1, ngrid
3815
    DO l = 1, klev
3816
      IF (zmix(ig)>=zlev(ig,l) .AND. zmix(ig)<zlev(ig,l+1)) THEN
3817
        lmix(ig) = l
3818
      END IF
3819
    END DO
3820
  END DO
3821
3822
  DO l = 2, nlay
3823
    DO ig = 1, ngrid
3824
      IF (larg_cons(ig,l)>1.) THEN
3825
        ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),'  KKK'
3826
        fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig))
3827
        ! test
3828
        fraca(ig, l) = max(fraca(ig,l), 0.)
3829
        fraca(ig, l) = min(fraca(ig,l), 0.5)
3830
        fracd(ig, l) = 1. - fraca(ig, l)
3831
        fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
3832
      ELSE
3833
        ! wa_moy(ig,l)=0.
3834
        fraca(ig, l) = 0.
3835
        fracc(ig, l) = 0.
3836
        fracd(ig, l) = 1.
3837
      END IF
3838
    END DO
3839
  END DO
3840
  ! CR: calcul de fracazmix
3841
  DO ig = 1, ngrid
3842
    fracazmix(ig) = (fraca(ig,lmix(ig)+1)-fraca(ig,lmix(ig)))/ &
3843
      (zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))*zmix(ig) + &
3844
      fraca(ig, lmix(ig)) - zlev(ig, lmix(ig))*(fraca(ig,lmix(ig)+1)-fraca(ig &
3845
      ,lmix(ig)))/(zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))
3846
  END DO
3847
3848
  DO l = 2, nlay
3849
    DO ig = 1, ngrid
3850
      IF (larg_cons(ig,l)>1.) THEN
3851
        IF (l>lmix(ig)) THEN
3852
          ! test
3853
          IF (zmax(ig)-zmix(ig)<1.E-10) THEN
3854
            ! print*,'pb xxx'
3855
            xxx(ig, l) = (lmaxa(ig)+1.-l)/(lmaxa(ig)+1.-lmix(ig))
3856
          ELSE
3857
            xxx(ig, l) = (zmax(ig)-zlev(ig,l))/(zmax(ig)-zmix(ig))
3858
          END IF
3859
          IF (idetr==0) THEN
3860
            fraca(ig, l) = fracazmix(ig)
3861
          ELSE IF (idetr==1) THEN
3862
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)
3863
          ELSE IF (idetr==2) THEN
3864
            fraca(ig, l) = fracazmix(ig)*(1.-(1.-xxx(ig,l))**2)
3865
          ELSE
3866
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)**2
3867
          END IF
3868
          ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL'
3869
          fraca(ig, l) = max(fraca(ig,l), 0.)
3870
          fraca(ig, l) = min(fraca(ig,l), 0.5)
3871
          fracd(ig, l) = 1. - fraca(ig, l)
3872
          fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
3873
        END IF
3874
      END IF
3875
    END DO
3876
  END DO
3877
3878
  PRINT *, 'fin calcul fraca'
3879
  ! print*,'11 OK convect8'
3880
  ! print*,'Ea3 ',wa_moy
3881
  ! ------------------------------------------------------------------
3882
  ! Calcul de fracd, wd
3883
  ! somme wa - wd = 0
3884
  ! ------------------------------------------------------------------
3885
3886
3887
  DO ig = 1, ngrid
3888
    fm(ig, 1) = 0.
3889
    fm(ig, nlay+1) = 0.
3890
  END DO
3891
3892
  DO l = 2, nlay
3893
    DO ig = 1, ngrid
3894
      fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l)
3895
      ! CR:test
3896
      IF (entr(ig,l-1)<1E-10 .AND. fm(ig,l)>fm(ig,l-1) .AND. l>lmix(ig)) THEN
3897
        fm(ig, l) = fm(ig, l-1)
3898
        ! write(1,*)'ajustement fm, l',l
3899
      END IF
3900
      ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l)
3901
      ! RC
3902
    END DO
3903
    DO ig = 1, ngrid
3904
      IF (fracd(ig,l)<0.1) THEN
3905
        abort_message = 'fracd trop petit'
3906
        CALL abort_physic(modname, abort_message, 1)
3907
      ELSE
3908
        ! vitesse descendante "diagnostique"
3909
        wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l))
3910
      END IF
3911
    END DO
3912
  END DO
3913
3914
  DO l = 1, nlay
3915
    DO ig = 1, ngrid
3916
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
3917
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
3918
    END DO
3919
  END DO
3920
3921
  ! print*,'12 OK convect8'
3922
  ! print*,'WA4 ',wa_moy
3923
  ! c------------------------------------------------------------------
3924
  ! calcul du transport vertical
3925
  ! ------------------------------------------------------------------
3926
3927
  GO TO 4444
3928
  ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep
3929
  DO l = 2, nlay - 1
3930
    DO ig = 1, ngrid
3931
      IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( &
3932
          ig,l+1)) THEN
3933
        ! print*,'WARN!!! FM>M ig=',ig,' l=',l,'  FM='
3934
        ! s         ,fm(ig,l+1)*ptimestep
3935
        ! s         ,'   M=',masse(ig,l),masse(ig,l+1)
3936
      END IF
3937
    END DO
3938
  END DO
3939
3940
  DO l = 1, nlay
3941
    DO ig = 1, ngrid
3942
      IF (entr(ig,l)*ptimestep>masse(ig,l)) THEN
3943
        ! print*,'WARN!!! E>M ig=',ig,' l=',l,'  E=='
3944
        ! s         ,entr(ig,l)*ptimestep
3945
        ! s         ,'   M=',masse(ig,l)
3946
      END IF
3947
    END DO
3948
  END DO
3949
3950
  DO l = 1, nlay
3951
    DO ig = 1, ngrid
3952
      IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN
3953
        ! print*,'WARN!!! fm exagere ig=',ig,'   l=',l
3954
        ! s         ,'   FM=',fm(ig,l)
3955
      END IF
3956
      IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN
3957
        ! print*,'WARN!!! masse exagere ig=',ig,'   l=',l
3958
        ! s         ,'   M=',masse(ig,l)
3959
        ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)',
3960
        ! s                 rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)
3961
        ! print*,'zlev(ig,l+1),zlev(ig,l)'
3962
        ! s                ,zlev(ig,l+1),zlev(ig,l)
3963
        ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)'
3964
        ! s                ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)
3965
      END IF
3966
      IF (.NOT. entr(ig,l)>=0. .OR. .NOT. entr(ig,l)<=10.) THEN
3967
        ! print*,'WARN!!! entr exagere ig=',ig,'   l=',l
3968
        ! s         ,'   E=',entr(ig,l)
3969
      END IF
3970
    END DO
3971
  END DO
3972
3973
4444 CONTINUE
3974
3975
  ! CR:redefinition du entr
3976
  DO l = 1, nlay
3977
    DO ig = 1, ngrid
3978
      detr(ig, l) = fm(ig, l) + entr(ig, l) - fm(ig, l+1)
3979
      IF (detr(ig,l)<0.) THEN
3980
        entr(ig, l) = entr(ig, l) - detr(ig, l)
3981
        detr(ig, l) = 0.
3982
        ! print*,'WARNING !!! detrainement negatif ',ig,l
3983
      END IF
3984
    END DO
3985
  END DO
3986
  ! RC
3987
  IF (w2di==1) THEN
3988
    fm0 = fm0 + ptimestep*(fm-fm0)/tho
3989
    entr0 = entr0 + ptimestep*(entr-entr0)/tho
3990
  ELSE
3991
    fm0 = fm
3992
    entr0 = entr
3993
  END IF
3994
3995
  IF (1==1) THEN
3996
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zh, zdhadj, &
3997
      zha)
3998
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zo, pdoadj, &
3999
      zoa)
4000
  ELSE
4001
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, &
4002
      zdhadj, zha)
4003
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, &
4004
      pdoadj, zoa)
4005
  END IF
4006
4007
  IF (1==0) THEN
4008
    CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, &
4009
      zu, zv, pduadj, pdvadj, zua, zva)
4010
  ELSE
4011
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, &
4012
      zua)
4013
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, &
4014
      zva)
4015
  END IF
4016
4017
  DO l = 1, nlay
4018
    DO ig = 1, ngrid
4019
      zf = 0.5*(fracc(ig,l)+fracc(ig,l+1))
4020
      zf2 = zf/(1.-zf)
4021
      thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l))**2
4022
      wth2(ig, l) = zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2
4023
    END DO
4024
  END DO
4025
4026
4027
4028
  ! print*,'13 OK convect8'
4029
  ! print*,'WA5 ',wa_moy
4030
  DO l = 1, nlay
4031
    DO ig = 1, ngrid
4032
      pdtadj(ig, l) = zdhadj(ig, l)*zpspsk(ig, l)
4033
    END DO
4034
  END DO
4035
4036
4037
  ! do l=1,nlay
4038
  ! do ig=1,ngrid
4039
  ! if(abs(pdtadj(ig,l))*86400..gt.500.) then
4040
  ! print*,'WARN!!! ig=',ig,'  l=',l
4041
  ! s         ,'   pdtadj=',pdtadj(ig,l)
4042
  ! endif
4043
  ! if(abs(pdoadj(ig,l))*86400..gt.1.) then
4044
  ! print*,'WARN!!! ig=',ig,'  l=',l
4045
  ! s         ,'   pdoadj=',pdoadj(ig,l)
4046
  ! endif
4047
  ! enddo
4048
  ! enddo
4049
4050
  ! print*,'14 OK convect8'
4051
  ! ------------------------------------------------------------------
4052
  ! Calculs pour les sorties
4053
  ! ------------------------------------------------------------------
4054
4055
  IF (sorties) THEN
4056
    DO l = 1, nlay
4057
      DO ig = 1, ngrid
4058
        zla(ig, l) = (1.-fracd(ig,l))*zmax(ig)
4059
        zld(ig, l) = fracd(ig, l)*zmax(ig)
4060
        IF (1.-fracd(ig,l)>1.E-10) zwa(ig, l) = wd(ig, l)*fracd(ig, l)/ &
4061
          (1.-fracd(ig,l))
4062
      END DO
4063
    END DO
4064
4065
    ! deja fait
4066
    ! do l=1,nlay
4067
    ! do ig=1,ngrid
4068
    ! detr(ig,l)=fm(ig,l)+entr(ig,l)-fm(ig,l+1)
4069
    ! if (detr(ig,l).lt.0.) then
4070
    ! entr(ig,l)=entr(ig,l)-detr(ig,l)
4071
    ! detr(ig,l)=0.
4072
    ! print*,'WARNING !!! detrainement negatif ',ig,l
4073
    ! endif
4074
    ! enddo
4075
    ! enddo
4076
4077
    ! print*,'15 OK convect8'
4078
4079
4080
    ! #define und
4081
    GO TO 123
4082
#ifdef und
4083
    CALL writeg1d(1, nlay, wd, 'wd      ', 'wd      ')
4084
    CALL writeg1d(1, nlay, zwa, 'wa      ', 'wa      ')
4085
    CALL writeg1d(1, nlay, fracd, 'fracd      ', 'fracd      ')
4086
    CALL writeg1d(1, nlay, fraca, 'fraca      ', 'fraca      ')
4087
    CALL writeg1d(1, nlay, wa_moy, 'wam         ', 'wam         ')
4088
    CALL writeg1d(1, nlay, zla, 'la      ', 'la      ')
4089
    CALL writeg1d(1, nlay, zld, 'ld      ', 'ld      ')
4090
    CALL writeg1d(1, nlay, pt, 'pt      ', 'pt      ')
4091
    CALL writeg1d(1, nlay, zh, 'zh      ', 'zh      ')
4092
    CALL writeg1d(1, nlay, zha, 'zha      ', 'zha      ')
4093
    CALL writeg1d(1, nlay, zu, 'zu      ', 'zu      ')
4094
    CALL writeg1d(1, nlay, zv, 'zv      ', 'zv      ')
4095
    CALL writeg1d(1, nlay, zo, 'zo      ', 'zo      ')
4096
    CALL writeg1d(1, nlay, wh, 'wh      ', 'wh      ')
4097
    CALL writeg1d(1, nlay, wu, 'wu      ', 'wu      ')
4098
    CALL writeg1d(1, nlay, wv, 'wv      ', 'wv      ')
4099
    CALL writeg1d(1, nlay, wo, 'w15uo     ', 'wXo     ')
4100
    CALL writeg1d(1, nlay, zdhadj, 'zdhadj      ', 'zdhadj      ')
4101
    CALL writeg1d(1, nlay, pduadj, 'pduadj      ', 'pduadj      ')
4102
    CALL writeg1d(1, nlay, pdvadj, 'pdvadj      ', 'pdvadj      ')
4103
    CALL writeg1d(1, nlay, pdoadj, 'pdoadj      ', 'pdoadj      ')
4104
    CALL writeg1d(1, nlay, entr, 'entr        ', 'entr        ')
4105
    CALL writeg1d(1, nlay, detr, 'detr        ', 'detr        ')
4106
    CALL writeg1d(1, nlay, fm, 'fm          ', 'fm          ')
4107
4108
    CALL writeg1d(1, nlay, pdtadj, 'pdtadj    ', 'pdtadj    ')
4109
    CALL writeg1d(1, nlay, pplay, 'pplay     ', 'pplay     ')
4110
    CALL writeg1d(1, nlay, pplev, 'pplev     ', 'pplev     ')
4111
4112
    ! recalcul des flux en diagnostique...
4113
    ! print*,'PAS DE TEMPS ',ptimestep
4114
    CALL dt2f(pplev, pplay, pt, pdtadj, wh)
4115
    CALL writeg1d(1, nlay, wh, 'wh2     ', 'wh2     ')
4116
#endif
4117
123 CONTINUE
4118
4119
  END IF
4120
4121
  ! if(wa_moy(1,4).gt.1.e-10) stop
4122
4123
  ! print*,'19 OK convect8'
4124
  RETURN
4125
END SUBROUTINE thermcell
4126
4127
SUBROUTINE dqthermcell(ngrid, nlay, ptimestep, fm, entr, masse, q, dq, qa)
4128
  USE dimphy
4129
  IMPLICIT NONE
4130
4131
  ! =======================================================================
4132
4133
  ! Calcul du transport verticale dans la couche limite en presence
4134
  ! de "thermiques" explicitement representes
4135
  ! calcul du dq/dt une fois qu'on connait les ascendances
4136
4137
  ! =======================================================================
4138
4139
  INTEGER ngrid, nlay
4140
4141
  REAL ptimestep
4142
  REAL masse(ngrid, nlay), fm(ngrid, nlay+1)
4143
  REAL entr(ngrid, nlay)
4144
  REAL q(ngrid, nlay)
4145
  REAL dq(ngrid, nlay)
4146
4147
  REAL qa(klon, klev), detr(klon, klev), wqd(klon, klev+1)
4148
4149
  INTEGER ig, k
4150
4151
  ! calcul du detrainement
4152
4153
  DO k = 1, nlay
4154
    DO ig = 1, ngrid
4155
      detr(ig, k) = fm(ig, k) - fm(ig, k+1) + entr(ig, k)
4156
      ! test
4157
      IF (detr(ig,k)<0.) THEN
4158
        entr(ig, k) = entr(ig, k) - detr(ig, k)
4159
        detr(ig, k) = 0.
4160
        ! print*,'detr2<0!!!','ig=',ig,'k=',k,'f=',fm(ig,k),
4161
        ! s         'f+1=',fm(ig,k+1),'e=',entr(ig,k),'d=',detr(ig,k)
4162
      END IF
4163
      IF (fm(ig,k+1)<0.) THEN
4164
        ! print*,'fm2<0!!!'
4165
      END IF
4166
      IF (entr(ig,k)<0.) THEN
4167
        ! print*,'entr2<0!!!'
4168
      END IF
4169
    END DO
4170
  END DO
4171
4172
  ! calcul de la valeur dans les ascendances
4173
  DO ig = 1, ngrid
4174
    qa(ig, 1) = q(ig, 1)
4175
  END DO
4176
4177
  DO k = 2, nlay
4178
    DO ig = 1, ngrid
4179
      IF ((fm(ig,k+1)+detr(ig,k))*ptimestep>1.E-5*masse(ig,k)) THEN
4180
        qa(ig, k) = (fm(ig,k)*qa(ig,k-1)+entr(ig,k)*q(ig,k))/ &
4181
          (fm(ig,k+1)+detr(ig,k))
4182
      ELSE
4183
        qa(ig, k) = q(ig, k)
4184
      END IF
4185
      IF (qa(ig,k)<0.) THEN
4186
        ! print*,'qa<0!!!'
4187
      END IF
4188
      IF (q(ig,k)<0.) THEN
4189
        ! print*,'q<0!!!'
4190
      END IF
4191
    END DO
4192
  END DO
4193
4194
  DO k = 2, nlay
4195
    DO ig = 1, ngrid
4196
      ! wqd(ig,k)=fm(ig,k)*0.5*(q(ig,k-1)+q(ig,k))
4197
      wqd(ig, k) = fm(ig, k)*q(ig, k)
4198
      IF (wqd(ig,k)<0.) THEN
4199
        ! print*,'wqd<0!!!'
4200
      END IF
4201
    END DO
4202
  END DO
4203
  DO ig = 1, ngrid
4204
    wqd(ig, 1) = 0.
4205
    wqd(ig, nlay+1) = 0.
4206
  END DO
4207
4208
  DO k = 1, nlay
4209
    DO ig = 1, ngrid
4210
      dq(ig, k) = (detr(ig,k)*qa(ig,k)-entr(ig,k)*q(ig,k)-wqd(ig,k)+wqd(ig,k+ &
4211
        1))/masse(ig, k)
4212
      ! if (dq(ig,k).lt.0.) then
4213
      ! print*,'dq<0!!!'
4214
      ! endif
4215
    END DO
4216
  END DO
4217
4218
  RETURN
4219
END SUBROUTINE dqthermcell
4220
SUBROUTINE dvthermcell(ngrid, nlay, ptimestep, fm, entr, masse, fraca, larga, &
4221
    u, v, du, dv, ua, va)
4222
  USE dimphy
4223
  IMPLICIT NONE
4224
4225
  ! =======================================================================
4226
4227
  ! Calcul du transport verticale dans la couche limite en presence
4228
  ! de "thermiques" explicitement representes
4229
  ! calcul du dq/dt une fois qu'on connait les ascendances
4230
4231
  ! =======================================================================
4232
4233
  INTEGER ngrid, nlay
4234
4235
  REAL ptimestep
4236
  REAL masse(ngrid, nlay), fm(ngrid, nlay+1)
4237
  REAL fraca(ngrid, nlay+1)
4238
  REAL larga(ngrid)
4239
  REAL entr(ngrid, nlay)
4240
  REAL u(ngrid, nlay)
4241
  REAL ua(ngrid, nlay)
4242
  REAL du(ngrid, nlay)
4243
  REAL v(ngrid, nlay)
4244
  REAL va(ngrid, nlay)
4245
  REAL dv(ngrid, nlay)
4246
4247
  REAL qa(klon, klev), detr(klon, klev)
4248
  REAL wvd(klon, klev+1), wud(klon, klev+1)
4249
  REAL gamma0, gamma(klon, klev+1)
4250
  REAL dua, dva
4251
  INTEGER iter
4252
4253
  INTEGER ig, k
4254
4255
  ! calcul du detrainement
4256
4257
  DO k = 1, nlay
4258
    DO ig = 1, ngrid
4259
      detr(ig, k) = fm(ig, k) - fm(ig, k+1) + entr(ig, k)
4260
    END DO
4261
  END DO
4262
4263
  ! calcul de la valeur dans les ascendances
4264
  DO ig = 1, ngrid
4265
    ua(ig, 1) = u(ig, 1)
4266
    va(ig, 1) = v(ig, 1)
4267
  END DO
4268
4269
  DO k = 2, nlay
4270
    DO ig = 1, ngrid
4271
      IF ((fm(ig,k+1)+detr(ig,k))*ptimestep>1.E-5*masse(ig,k)) THEN
4272
        ! On it�re sur la valeur du coeff de freinage.
4273
        ! gamma0=rho(ig,k)*(zlev(ig,k+1)-zlev(ig,k))
4274
        gamma0 = masse(ig, k)*sqrt(0.5*(fraca(ig,k+1)+fraca(ig, &
4275
          k)))*0.5/larga(ig)
4276
        ! gamma0=0.
4277
        ! la premi�re fois on multiplie le coefficient de freinage
4278
        ! par le module du vent dans la couche en dessous.
4279
        dua = ua(ig, k-1) - u(ig, k-1)
4280
        dva = va(ig, k-1) - v(ig, k-1)
4281
        DO iter = 1, 5
4282
          gamma(ig, k) = gamma0*sqrt(dua**2+dva**2)
4283
          ua(ig, k) = (fm(ig,k)*ua(ig,k-1)+(entr(ig,k)+gamma(ig, &
4284
            k))*u(ig,k))/(fm(ig,k+1)+detr(ig,k)+gamma(ig,k))
4285
          va(ig, k) = (fm(ig,k)*va(ig,k-1)+(entr(ig,k)+gamma(ig, &
4286
            k))*v(ig,k))/(fm(ig,k+1)+detr(ig,k)+gamma(ig,k))
4287
          ! print*,k,ua(ig,k),va(ig,k),u(ig,k),v(ig,k),dua,dva
4288
          dua = ua(ig, k) - u(ig, k)
4289
          dva = va(ig, k) - v(ig, k)
4290
        END DO
4291
      ELSE
4292
        ua(ig, k) = u(ig, k)
4293
        va(ig, k) = v(ig, k)
4294
        gamma(ig, k) = 0.
4295
      END IF
4296
    END DO
4297
  END DO
4298
4299
  DO k = 2, nlay
4300
    DO ig = 1, ngrid
4301
      wud(ig, k) = fm(ig, k)*u(ig, k)
4302
      wvd(ig, k) = fm(ig, k)*v(ig, k)
4303
    END DO
4304
  END DO
4305
  DO ig = 1, ngrid
4306
    wud(ig, 1) = 0.
4307
    wud(ig, nlay+1) = 0.
4308
    wvd(ig, 1) = 0.
4309
    wvd(ig, nlay+1) = 0.
4310
  END DO
4311
4312
  DO k = 1, nlay
4313
    DO ig = 1, ngrid
4314
      du(ig, k) = ((detr(ig,k)+gamma(ig,k))*ua(ig,k)-(entr(ig,k)+gamma(ig, &
4315
        k))*u(ig,k)-wud(ig,k)+wud(ig,k+1))/masse(ig, k)
4316
      dv(ig, k) = ((detr(ig,k)+gamma(ig,k))*va(ig,k)-(entr(ig,k)+gamma(ig, &
4317
        k))*v(ig,k)-wvd(ig,k)+wvd(ig,k+1))/masse(ig, k)
4318
    END DO
4319
  END DO
4320
4321
  RETURN
4322
END SUBROUTINE dvthermcell
4323
SUBROUTINE dqthermcell2(ngrid, nlay, ptimestep, fm, entr, masse, frac, q, dq, &
4324
    qa)
4325
  USE dimphy
4326
  IMPLICIT NONE
4327
4328
  ! =======================================================================
4329
4330
  ! Calcul du transport verticale dans la couche limite en presence
4331
  ! de "thermiques" explicitement representes
4332
  ! calcul du dq/dt une fois qu'on connait les ascendances
4333
4334
  ! =======================================================================
4335
4336
  INTEGER ngrid, nlay
4337
4338
  REAL ptimestep
4339
  REAL masse(ngrid, nlay), fm(ngrid, nlay+1)
4340
  REAL entr(ngrid, nlay), frac(ngrid, nlay)
4341
  REAL q(ngrid, nlay)
4342
  REAL dq(ngrid, nlay)
4343
4344
  REAL qa(klon, klev), detr(klon, klev), wqd(klon, klev+1)
4345
  REAL qe(klon, klev), zf, zf2
4346
4347
  INTEGER ig, k
4348
4349
  ! calcul du detrainement
4350
4351
  DO k = 1, nlay
4352
    DO ig = 1, ngrid
4353
      detr(ig, k) = fm(ig, k) - fm(ig, k+1) + entr(ig, k)
4354
    END DO
4355
  END DO
4356
4357
  ! calcul de la valeur dans les ascendances
4358
  DO ig = 1, ngrid
4359
    qa(ig, 1) = q(ig, 1)
4360
    qe(ig, 1) = q(ig, 1)
4361
  END DO
4362
4363
  DO k = 2, nlay
4364
    DO ig = 1, ngrid
4365
      IF ((fm(ig,k+1)+detr(ig,k))*ptimestep>1.E-5*masse(ig,k)) THEN
4366
        zf = 0.5*(frac(ig,k)+frac(ig,k+1))
4367
        zf2 = 1./(1.-zf)
4368
        qa(ig, k) = (fm(ig,k)*qa(ig,k-1)+zf2*entr(ig,k)*q(ig,k))/ &
4369
          (fm(ig,k+1)+detr(ig,k)+entr(ig,k)*zf*zf2)
4370
        qe(ig, k) = (q(ig,k)-zf*qa(ig,k))*zf2
4371
      ELSE
4372
        qa(ig, k) = q(ig, k)
4373
        qe(ig, k) = q(ig, k)
4374
      END IF
4375
    END DO
4376
  END DO
4377
4378
  DO k = 2, nlay
4379
    DO ig = 1, ngrid
4380
      ! wqd(ig,k)=fm(ig,k)*0.5*(q(ig,k-1)+q(ig,k))
4381
      wqd(ig, k) = fm(ig, k)*qe(ig, k)
4382
    END DO
4383
  END DO
4384
  DO ig = 1, ngrid
4385
    wqd(ig, 1) = 0.
4386
    wqd(ig, nlay+1) = 0.
4387
  END DO
4388
4389
  DO k = 1, nlay
4390
    DO ig = 1, ngrid
4391
      dq(ig, k) = (detr(ig,k)*qa(ig,k)-entr(ig,k)*qe(ig,k)-wqd(ig,k)+wqd(ig,k &
4392
        +1))/masse(ig, k)
4393
    END DO
4394
  END DO
4395
4396
  RETURN
4397
END SUBROUTINE dqthermcell2
4398
SUBROUTINE dvthermcell2(ngrid, nlay, ptimestep, fm, entr, masse, fraca, &
4399
    larga, u, v, du, dv, ua, va)
4400
  USE dimphy
4401
  IMPLICIT NONE
4402
4403
  ! =======================================================================
4404
4405
  ! Calcul du transport verticale dans la couche limite en presence
4406
  ! de "thermiques" explicitement representes
4407
  ! calcul du dq/dt une fois qu'on connait les ascendances
4408
4409
  ! =======================================================================
4410
4411
  INTEGER ngrid, nlay
4412
4413
  REAL ptimestep
4414
  REAL masse(ngrid, nlay), fm(ngrid, nlay+1)
4415
  REAL fraca(ngrid, nlay+1)
4416
  REAL larga(ngrid)
4417
  REAL entr(ngrid, nlay)
4418
  REAL u(ngrid, nlay)
4419
  REAL ua(ngrid, nlay)
4420
  REAL du(ngrid, nlay)
4421
  REAL v(ngrid, nlay)
4422
  REAL va(ngrid, nlay)
4423
  REAL dv(ngrid, nlay)
4424
4425
  REAL qa(klon, klev), detr(klon, klev), zf, zf2
4426
  REAL wvd(klon, klev+1), wud(klon, klev+1)
4427
  REAL gamma0, gamma(klon, klev+1)
4428
  REAL ue(klon, klev), ve(klon, klev)
4429
  REAL dua, dva
4430
  INTEGER iter
4431
4432
  INTEGER ig, k
4433
4434
  ! calcul du detrainement
4435
4436
  DO k = 1, nlay
4437
    DO ig = 1, ngrid
4438
      detr(ig, k) = fm(ig, k) - fm(ig, k+1) + entr(ig, k)
4439
    END DO
4440
  END DO
4441
4442
  ! calcul de la valeur dans les ascendances
4443
  DO ig = 1, ngrid
4444
    ua(ig, 1) = u(ig, 1)
4445
    va(ig, 1) = v(ig, 1)
4446
    ue(ig, 1) = u(ig, 1)
4447
    ve(ig, 1) = v(ig, 1)
4448
  END DO
4449
4450
  DO k = 2, nlay
4451
    DO ig = 1, ngrid
4452
      IF ((fm(ig,k+1)+detr(ig,k))*ptimestep>1.E-5*masse(ig,k)) THEN
4453
        ! On it�re sur la valeur du coeff de freinage.
4454
        ! gamma0=rho(ig,k)*(zlev(ig,k+1)-zlev(ig,k))
4455
        gamma0 = masse(ig, k)*sqrt(0.5*(fraca(ig,k+1)+fraca(ig, &
4456
          k)))*0.5/larga(ig)*1.
4457
        ! s         *0.5
4458
        ! gamma0=0.
4459
        zf = 0.5*(fraca(ig,k)+fraca(ig,k+1))
4460
        zf = 0.
4461
        zf2 = 1./(1.-zf)
4462
        ! la premi�re fois on multiplie le coefficient de freinage
4463
        ! par le module du vent dans la couche en dessous.
4464
        dua = ua(ig, k-1) - u(ig, k-1)
4465
        dva = va(ig, k-1) - v(ig, k-1)
4466
        DO iter = 1, 5
4467
          ! On choisit une relaxation lineaire.
4468
          gamma(ig, k) = gamma0
4469
          ! On choisit une relaxation quadratique.
4470
          gamma(ig, k) = gamma0*sqrt(dua**2+dva**2)
4471
          ua(ig, k) = (fm(ig,k)*ua(ig,k-1)+(zf2*entr(ig,k)+gamma(ig, &
4472
            k))*u(ig,k))/(fm(ig,k+1)+detr(ig,k)+entr(ig,k)*zf*zf2+gamma(ig,k) &
4473
            )
4474
          va(ig, k) = (fm(ig,k)*va(ig,k-1)+(zf2*entr(ig,k)+gamma(ig, &
4475
            k))*v(ig,k))/(fm(ig,k+1)+detr(ig,k)+entr(ig,k)*zf*zf2+gamma(ig,k) &
4476
            )
4477
          ! print*,k,ua(ig,k),va(ig,k),u(ig,k),v(ig,k),dua,dva
4478
          dua = ua(ig, k) - u(ig, k)
4479
          dva = va(ig, k) - v(ig, k)
4480
          ue(ig, k) = (u(ig,k)-zf*ua(ig,k))*zf2
4481
          ve(ig, k) = (v(ig,k)-zf*va(ig,k))*zf2
4482
        END DO
4483
      ELSE
4484
        ua(ig, k) = u(ig, k)
4485
        va(ig, k) = v(ig, k)
4486
        ue(ig, k) = u(ig, k)
4487
        ve(ig, k) = v(ig, k)
4488
        gamma(ig, k) = 0.
4489
      END IF
4490
    END DO
4491
  END DO
4492
4493
  DO k = 2, nlay
4494
    DO ig = 1, ngrid
4495
      wud(ig, k) = fm(ig, k)*ue(ig, k)
4496
      wvd(ig, k) = fm(ig, k)*ve(ig, k)
4497
    END DO
4498
  END DO
4499
  DO ig = 1, ngrid
4500
    wud(ig, 1) = 0.
4501
    wud(ig, nlay+1) = 0.
4502
    wvd(ig, 1) = 0.
4503
    wvd(ig, nlay+1) = 0.
4504
  END DO
4505
4506
  DO k = 1, nlay
4507
    DO ig = 1, ngrid
4508
      du(ig, k) = ((detr(ig,k)+gamma(ig,k))*ua(ig,k)-(entr(ig,k)+gamma(ig, &
4509
        k))*ue(ig,k)-wud(ig,k)+wud(ig,k+1))/masse(ig, k)
4510
      dv(ig, k) = ((detr(ig,k)+gamma(ig,k))*va(ig,k)-(entr(ig,k)+gamma(ig, &
4511
        k))*ve(ig,k)-wvd(ig,k)+wvd(ig,k+1))/masse(ig, k)
4512
    END DO
4513
  END DO
4514
4515
  RETURN
4516
END SUBROUTINE dvthermcell2
4517
SUBROUTINE thermcell_sec(ngrid, nlay, ptimestep, pplay, pplev, pphi, zlev, &
4518
    pu, pv, pt, po, pduadj, pdvadj, pdtadj, pdoadj, fm0, entr0 & ! s
4519
                                                                 ! ,pu_therm,pv_therm
4520
    , r_aspect, l_mix, w2di, tho)
4521
4522
  USE dimphy
4523
  IMPLICIT NONE
4524
4525
  ! =======================================================================
4526
4527
  ! Calcul du transport verticale dans la couche limite en presence
4528
  ! de "thermiques" explicitement representes
4529
4530
  ! R��criture � partir d'un listing papier � Habas, le 14/02/00
4531
4532
  ! le thermique est suppos� homog�ne et dissip� par m�lange avec
4533
  ! son environnement. la longueur l_mix contr�le l'efficacit� du
4534
  ! m�lange
4535
4536
  ! Le calcul du transport des diff�rentes esp�ces se fait en prenant
4537
  ! en compte:
4538
  ! 1. un flux de masse montant
4539
  ! 2. un flux de masse descendant
4540
  ! 3. un entrainement
4541
  ! 4. un detrainement
4542
4543
  ! =======================================================================
4544
4545
  ! -----------------------------------------------------------------------
4546
  ! declarations:
4547
  ! -------------
4548
4549
  include "YOMCST.h"
4550
4551
  ! arguments:
4552
  ! ----------
4553
4554
  INTEGER ngrid, nlay, w2di
4555
  REAL tho
4556
  REAL ptimestep, l_mix, r_aspect
4557
  REAL pt(ngrid, nlay), pdtadj(ngrid, nlay)
4558
  REAL pu(ngrid, nlay), pduadj(ngrid, nlay)
4559
  REAL pv(ngrid, nlay), pdvadj(ngrid, nlay)
4560
  REAL po(ngrid, nlay), pdoadj(ngrid, nlay)
4561
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
4562
  REAL pphi(ngrid, nlay)
4563
4564
  INTEGER idetr
4565
  SAVE idetr
4566
  DATA idetr/3/
4567
  !$OMP THREADPRIVATE(idetr)
4568
4569
  ! local:
4570
  ! ------
4571
4572
  INTEGER ig, k, l, lmaxa(klon), lmix(klon)
4573
  REAL zsortie1d(klon)
4574
  ! CR: on remplace lmax(klon,klev+1)
4575
  INTEGER lmax(klon), lmin(klon), lentr(klon)
4576
  REAL linter(klon)
4577
  REAL zmix(klon), fracazmix(klon)
4578
  ! RC
4579
  REAL zmax(klon), zw, zz, zw2(klon, klev+1), ztva(klon, klev), zzz
4580
4581
  REAL zlev(klon, klev+1), zlay(klon, klev)
4582
  REAL zh(klon, klev), zdhadj(klon, klev)
4583
  REAL ztv(klon, klev)
4584
  REAL zu(klon, klev), zv(klon, klev), zo(klon, klev)
4585
  REAL wh(klon, klev+1)
4586
  REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1)
4587
  REAL zla(klon, klev+1)
4588
  REAL zwa(klon, klev+1)
4589
  REAL zld(klon, klev+1)
4590
  REAL zwd(klon, klev+1)
4591
  REAL zsortie(klon, klev)
4592
  REAL zva(klon, klev)
4593
  REAL zua(klon, klev)
4594
  REAL zoa(klon, klev)
4595
4596
  REAL zha(klon, klev)
4597
  REAL wa_moy(klon, klev+1)
4598
  REAL fraca(klon, klev+1)
4599
  REAL fracc(klon, klev+1)
4600
  REAL zf, zf2
4601
  REAL thetath2(klon, klev), wth2(klon, klev)
4602
  ! common/comtherm/thetath2,wth2
4603
4604
  REAL count_time
4605
  INTEGER ialt
4606
4607
  LOGICAL sorties
4608
  REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev)
4609
  REAL zpspsk(klon, klev)
4610
4611
  ! real wmax(klon,klev),wmaxa(klon)
4612
  REAL wmax(klon), wmaxa(klon)
4613
  REAL wa(klon, klev, klev+1)
4614
  REAL wd(klon, klev+1)
4615
  REAL larg_part(klon, klev, klev+1)
4616
  REAL fracd(klon, klev+1)
4617
  REAL xxx(klon, klev+1)
4618
  REAL larg_cons(klon, klev+1)
4619
  REAL larg_detr(klon, klev+1)
4620
  REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev)
4621
  REAL pu_therm(klon, klev), pv_therm(klon, klev)
4622
  REAL fm(klon, klev+1), entr(klon, klev)
4623
  REAL fmc(klon, klev+1)
4624
4625
  ! CR:nouvelles variables
4626
  REAL f_star(klon, klev+1), entr_star(klon, klev)
4627
  REAL entr_star_tot(klon), entr_star2(klon)
4628
  REAL f(klon), f0(klon)
4629
  REAL zlevinter(klon)
4630
  LOGICAL first
4631
  DATA first/.FALSE./
4632
  SAVE first
4633
  !$OMP THREADPRIVATE(first)
4634
  ! RC
4635
4636
  CHARACTER *2 str2
4637
  CHARACTER *10 str10
4638
4639
  CHARACTER (LEN=20) :: modname = 'thermcell_sec'
4640
  CHARACTER (LEN=80) :: abort_message
4641
4642
  LOGICAL vtest(klon), down
4643
4644
  EXTERNAL scopy
4645
4646
  INTEGER ncorrec, ll
4647
  SAVE ncorrec
4648
  DATA ncorrec/0/
4649
  !$OMP THREADPRIVATE(ncorrec)
4650
4651
4652
  ! -----------------------------------------------------------------------
4653
  ! initialisation:
4654
  ! ---------------
4655
4656
  sorties = .TRUE.
4657
  IF (ngrid/=klon) THEN
4658
    PRINT *
4659
    PRINT *, 'STOP dans convadj'
4660
    PRINT *, 'ngrid    =', ngrid
4661
    PRINT *, 'klon  =', klon
4662
  END IF
4663
4664
  ! -----------------------------------------------------------------------
4665
  ! incrementation eventuelle de tendances precedentes:
4666
  ! ---------------------------------------------------
4667
4668
  ! print*,'0 OK convect8'
4669
4670
  DO l = 1, nlay
4671
    DO ig = 1, ngrid
4672
      zpspsk(ig, l) = (pplay(ig,l)/pplev(ig,1))**rkappa
4673
      zh(ig, l) = pt(ig, l)/zpspsk(ig, l)
4674
      zu(ig, l) = pu(ig, l)
4675
      zv(ig, l) = pv(ig, l)
4676
      zo(ig, l) = po(ig, l)
4677
      ztv(ig, l) = zh(ig, l)*(1.+0.61*zo(ig,l))
4678
    END DO
4679
  END DO
4680
4681
  ! print*,'1 OK convect8'
4682
  ! --------------------
4683
4684
4685
  ! + + + + + + + + + + +
4686
4687
4688
  ! wa, fraca, wd, fracd --------------------   zlev(2), rhobarz
4689
  ! wh,wt,wo ...
4690
4691
  ! + + + + + + + + + + +  zh,zu,zv,zo,rho
4692
4693
4694
  ! --------------------   zlev(1)
4695
  ! \\\\\\\\\\\\\\\\\\\\
4696
4697
4698
4699
  ! -----------------------------------------------------------------------
4700
  ! Calcul des altitudes des couches
4701
  ! -----------------------------------------------------------------------
4702
4703
  DO l = 2, nlay
4704
    DO ig = 1, ngrid
4705
      zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg
4706
    END DO
4707
  END DO
4708
  DO ig = 1, ngrid
4709
    zlev(ig, 1) = 0.
4710
    zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg
4711
  END DO
4712
  DO l = 1, nlay
4713
    DO ig = 1, ngrid
4714
      zlay(ig, l) = pphi(ig, l)/rg
4715
    END DO
4716
  END DO
4717
4718
  ! print*,'2 OK convect8'
4719
  ! -----------------------------------------------------------------------
4720
  ! Calcul des densites
4721
  ! -----------------------------------------------------------------------
4722
4723
  DO l = 1, nlay
4724
    DO ig = 1, ngrid
4725
      rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*zh(ig,l))
4726
    END DO
4727
  END DO
4728
4729
  DO l = 2, nlay
4730
    DO ig = 1, ngrid
4731
      rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1))
4732
    END DO
4733
  END DO
4734
4735
  DO k = 1, nlay
4736
    DO l = 1, nlay + 1
4737
      DO ig = 1, ngrid
4738
        wa(ig, k, l) = 0.
4739
      END DO
4740
    END DO
4741
  END DO
4742
4743
  ! print*,'3 OK convect8'
4744
  ! ------------------------------------------------------------------
4745
  ! Calcul de w2, quarre de w a partir de la cape
4746
  ! a partir de w2, on calcule wa, vitesse de l'ascendance
4747
4748
  ! ATTENTION: Dans cette version, pour cause d'economie de memoire,
4749
  ! w2 est stoke dans wa
4750
4751
  ! ATTENTION: dans convect8, on n'utilise le calcule des wa
4752
  ! independants par couches que pour calculer l'entrainement
4753
  ! a la base et la hauteur max de l'ascendance.
4754
4755
  ! Indicages:
4756
  ! l'ascendance provenant du niveau k traverse l'interface l avec
4757
  ! une vitesse wa(k,l).
4758
4759
  ! --------------------
4760
4761
  ! + + + + + + + + + +
4762
4763
  ! wa(k,l)   ----       --------------------    l
4764
  ! /\
4765
  ! /||\       + + + + + + + + + +
4766
  ! ||
4767
  ! ||        --------------------
4768
  ! ||
4769
  ! ||        + + + + + + + + + +
4770
  ! ||
4771
  ! ||        --------------------
4772
  ! ||__
4773
  ! |___      + + + + + + + + + +     k
4774
4775
  ! --------------------
4776
4777
4778
4779
  ! ------------------------------------------------------------------
4780
4781
  ! CR: ponderation entrainement des couches instables
4782
  ! def des entr_star tels que entr=f*entr_star
4783
  DO l = 1, klev
4784
    DO ig = 1, ngrid
4785
      entr_star(ig, l) = 0.
4786
    END DO
4787
  END DO
4788
  ! determination de la longueur de la couche d entrainement
4789
  DO ig = 1, ngrid
4790
    lentr(ig) = 1
4791
  END DO
4792
4793
  ! on ne considere que les premieres couches instables
4794
  DO k = nlay - 2, 1, -1
4795
    DO ig = 1, ngrid
4796
      IF (ztv(ig,k)>ztv(ig,k+1) .AND. ztv(ig,k+1)<=ztv(ig,k+2)) THEN
4797
        lentr(ig) = k
4798
      END IF
4799
    END DO
4800
  END DO
4801
4802
  ! determination du lmin: couche d ou provient le thermique
4803
  DO ig = 1, ngrid
4804
    lmin(ig) = 1
4805
  END DO
4806
  DO ig = 1, ngrid
4807
    DO l = nlay, 2, -1
4808
      IF (ztv(ig,l-1)>ztv(ig,l)) THEN
4809
        lmin(ig) = l - 1
4810
      END IF
4811
    END DO
4812
  END DO
4813
4814
  ! definition de l'entrainement des couches
4815
  DO l = 1, klev - 1
4816
    DO ig = 1, ngrid
4817
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<=lentr(ig)) THEN
4818
        entr_star(ig, l) = (ztv(ig,l)-ztv(ig,l+1))** & ! s
4819
                                                       ! (zlev(ig,l+1)-zlev(ig,l))
4820
          sqrt(zlev(ig,l+1))
4821
      END IF
4822
    END DO
4823
  END DO
4824
  ! pas de thermique si couche 1 stable
4825
  DO ig = 1, ngrid
4826
    IF (lmin(ig)>1) THEN
4827
      DO l = 1, klev
4828
        entr_star(ig, l) = 0.
4829
      END DO
4830
    END IF
4831
  END DO
4832
  ! calcul de l entrainement total
4833
  DO ig = 1, ngrid
4834
    entr_star_tot(ig) = 0.
4835
  END DO
4836
  DO ig = 1, ngrid
4837
    DO k = 1, klev
4838
      entr_star_tot(ig) = entr_star_tot(ig) + entr_star(ig, k)
4839
    END DO
4840
  END DO
4841
4842
  ! print*,'fin calcul entr_star'
4843
  DO k = 1, klev
4844
    DO ig = 1, ngrid
4845
      ztva(ig, k) = ztv(ig, k)
4846
    END DO
4847
  END DO
4848
  ! RC
4849
  ! print*,'7 OK convect8'
4850
  DO k = 1, klev + 1
4851
    DO ig = 1, ngrid
4852
      zw2(ig, k) = 0.
4853
      fmc(ig, k) = 0.
4854
      ! CR
4855
      f_star(ig, k) = 0.
4856
      ! RC
4857
      larg_cons(ig, k) = 0.
4858
      larg_detr(ig, k) = 0.
4859
      wa_moy(ig, k) = 0.
4860
    END DO
4861
  END DO
4862
4863
  ! print*,'8 OK convect8'
4864
  DO ig = 1, ngrid
4865
    linter(ig) = 1.
4866
    lmaxa(ig) = 1
4867
    lmix(ig) = 1
4868
    wmaxa(ig) = 0.
4869
  END DO
4870
4871
  ! CR:
4872
  DO l = 1, nlay - 2
4873
    DO ig = 1, ngrid
4874
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. entr_star(ig,l)>1.E-10 .AND. &
4875
          zw2(ig,l)<1E-10) THEN
4876
        f_star(ig, l+1) = entr_star(ig, l)
4877
        ! test:calcul de dteta
4878
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
4879
          (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l))
4880
        larg_detr(ig, l) = 0.
4881
      ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+entr_star(ig, &
4882
          l)>1.E-10)) THEN
4883
        f_star(ig, l+1) = f_star(ig, l) + entr_star(ig, l)
4884
        ztva(ig, l) = (f_star(ig,l)*ztva(ig,l-1)+entr_star(ig,l)*ztv(ig,l))/ &
4885
          f_star(ig, l+1)
4886
        zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/f_star(ig,l+1))**2 + &
4887
          2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l))
4888
      END IF
4889
      ! determination de zmax continu par interpolation lineaire
4890
      IF (zw2(ig,l+1)<0.) THEN
4891
        ! test
4892
        IF (abs(zw2(ig,l+1)-zw2(ig,l))<1E-10) THEN
4893
          ! print*,'pb linter'
4894
        END IF
4895
        linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( &
4896
          ig,l))
4897
        zw2(ig, l+1) = 0.
4898
        lmaxa(ig) = l
4899
      ELSE
4900
        IF (zw2(ig,l+1)<0.) THEN
4901
          ! print*,'pb1 zw2<0'
4902
        END IF
4903
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
4904
      END IF
4905
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
4906
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
4907
        lmix(ig) = l + 1
4908
        wmaxa(ig) = wa_moy(ig, l+1)
4909
      END IF
4910
    END DO
4911
  END DO
4912
  ! print*,'fin calcul zw2'
4913
4914
  ! Calcul de la couche correspondant a la hauteur du thermique
4915
  DO ig = 1, ngrid
4916
    lmax(ig) = lentr(ig)
4917
  END DO
4918
  DO ig = 1, ngrid
4919
    DO l = nlay, lentr(ig) + 1, -1
4920
      IF (zw2(ig,l)<=1.E-10) THEN
4921
        lmax(ig) = l - 1
4922
      END IF
4923
    END DO
4924
  END DO
4925
  ! pas de thermique si couche 1 stable
4926
  DO ig = 1, ngrid
4927
    IF (lmin(ig)>1) THEN
4928
      lmax(ig) = 1
4929
      lmin(ig) = 1
4930
    END IF
4931
  END DO
4932
4933
  ! Determination de zw2 max
4934
  DO ig = 1, ngrid
4935
    wmax(ig) = 0.
4936
  END DO
4937
4938
  DO l = 1, nlay
4939
    DO ig = 1, ngrid
4940
      IF (l<=lmax(ig)) THEN
4941
        IF (zw2(ig,l)<0.) THEN
4942
          ! print*,'pb2 zw2<0'
4943
        END IF
4944
        zw2(ig, l) = sqrt(zw2(ig,l))
4945
        wmax(ig) = max(wmax(ig), zw2(ig,l))
4946
      ELSE
4947
        zw2(ig, l) = 0.
4948
      END IF
4949
    END DO
4950
  END DO
4951
4952
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
4953
  DO ig = 1, ngrid
4954
    zmax(ig) = 0.
4955
    zlevinter(ig) = zlev(ig, 1)
4956
  END DO
4957
  DO ig = 1, ngrid
4958
    ! calcul de zlevinter
4959
    zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + &
4960
      zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))
4961
    zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,lmin(ig)))
4962
  END DO
4963
4964
  ! print*,'avant fermeture'
4965
  ! Fermeture,determination de f
4966
  DO ig = 1, ngrid
4967
    entr_star2(ig) = 0.
4968
  END DO
4969
  DO ig = 1, ngrid
4970
    IF (entr_star_tot(ig)<1.E-10) THEN
4971
      f(ig) = 0.
4972
    ELSE
4973
      DO k = lmin(ig), lentr(ig)
4974
        entr_star2(ig) = entr_star2(ig) + entr_star(ig, k)**2/(rho(ig,k)*( &
4975
          zlev(ig,k+1)-zlev(ig,k)))
4976
      END DO
4977
      ! Nouvelle fermeture
4978
      f(ig) = wmax(ig)/(max(500.,zmax(ig))*r_aspect*entr_star2(ig))* &
4979
        entr_star_tot(ig)
4980
      ! test
4981
      ! if (first) then
4982
      ! f(ig)=f(ig)+(f0(ig)-f(ig))*exp(-ptimestep/zmax(ig)
4983
      ! s             *wmax(ig))
4984
      ! endif
4985
    END IF
4986
    ! f0(ig)=f(ig)
4987
    ! first=.true.
4988
  END DO
4989
  ! print*,'apres fermeture'
4990
4991
  ! Calcul de l'entrainement
4992
  DO k = 1, klev
4993
    DO ig = 1, ngrid
4994
      entr(ig, k) = f(ig)*entr_star(ig, k)
4995
    END DO
4996
  END DO
4997
  ! CR:test pour entrainer moins que la masse
4998
  DO ig = 1, ngrid
4999
    DO l = 1, lentr(ig)
5000
      IF ((entr(ig,l)*ptimestep)>(0.9*masse(ig,l))) THEN
5001
        entr(ig, l+1) = entr(ig, l+1) + entr(ig, l) - &
5002
          0.9*masse(ig, l)/ptimestep
5003
        entr(ig, l) = 0.9*masse(ig, l)/ptimestep
5004
      END IF
5005
    END DO
5006
  END DO
5007
  ! CR: fin test
5008
  ! Calcul des flux
5009
  DO ig = 1, ngrid
5010
    DO l = 1, lmax(ig) - 1
5011
      fmc(ig, l+1) = fmc(ig, l) + entr(ig, l)
5012
    END DO
5013
  END DO
5014
5015
  ! RC
5016
5017
5018
  ! print*,'9 OK convect8'
5019
  ! print*,'WA1 ',wa_moy
5020
5021
  ! determination de l'indice du debut de la mixed layer ou w decroit
5022
5023
  ! calcul de la largeur de chaque ascendance dans le cas conservatif.
5024
  ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant
5025
  ! d'une couche est �gale � la hauteur de la couche alimentante.
5026
  ! La vitesse maximale dans l'ascendance est aussi prise comme estimation
5027
  ! de la vitesse d'entrainement horizontal dans la couche alimentante.
5028
5029
  DO l = 2, nlay
5030
    DO ig = 1, ngrid
5031
      IF (l<=lmaxa(ig)) THEN
5032
        zw = max(wa_moy(ig,l), 1.E-10)
5033
        larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw)
5034
      END IF
5035
    END DO
5036
  END DO
5037
5038
  DO l = 2, nlay
5039
    DO ig = 1, ngrid
5040
      IF (l<=lmaxa(ig)) THEN
5041
        ! if (idetr.eq.0) then
5042
        ! cette option est finalement en dur.
5043
        IF ((l_mix*zlev(ig,l))<0.) THEN
5044
          ! print*,'pb l_mix*zlev<0'
5045
        END IF
5046
        ! CR: test: nouvelle def de lambda
5047
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
5048
        IF (zw2(ig,l)>1.E-10) THEN
5049
          larg_detr(ig, l) = sqrt((l_mix/zw2(ig,l))*zlev(ig,l))
5050
        ELSE
5051
          larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l))
5052
        END IF
5053
        ! RC
5054
        ! else if (idetr.eq.1) then
5055
        ! larg_detr(ig,l)=larg_cons(ig,l)
5056
        ! s            *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig))
5057
        ! else if (idetr.eq.2) then
5058
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
5059
        ! s            *sqrt(wa_moy(ig,l))
5060
        ! else if (idetr.eq.4) then
5061
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
5062
        ! s            *wa_moy(ig,l)
5063
        ! endif
5064
      END IF
5065
    END DO
5066
  END DO
5067
5068
  ! print*,'10 OK convect8'
5069
  ! print*,'WA2 ',wa_moy
5070
  ! calcul de la fraction de la maille concern�e par l'ascendance en tenant
5071
  ! compte de l'epluchage du thermique.
5072
5073
  ! CR def de  zmix continu (profil parabolique des vitesses)
5074
  DO ig = 1, ngrid
5075
    IF (lmix(ig)>1.) THEN
5076
      ! test
5077
      IF (((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
5078
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
5079
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))- &
5080
          (zlev(ig,lmix(ig)))))>1E-10) THEN
5081
5082
        zmix(ig) = ((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)) &
5083
          )**2-(zlev(ig,lmix(ig)+1))**2)-(zw2(ig,lmix(ig))-zw2(ig, &
5084
          lmix(ig)+1))*((zlev(ig,lmix(ig)-1))**2-(zlev(ig,lmix(ig)))**2))/ &
5085
          (2.*((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
5086
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
5087
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))-(zlev(ig,lmix(ig))))))
5088
      ELSE
5089
        zmix(ig) = zlev(ig, lmix(ig))
5090
        ! print*,'pb zmix'
5091
      END IF
5092
    ELSE
5093
      zmix(ig) = 0.
5094
    END IF
5095
    ! test
5096
    IF ((zmax(ig)-zmix(ig))<0.) THEN
5097
      zmix(ig) = 0.99*zmax(ig)
5098
      ! print*,'pb zmix>zmax'
5099
    END IF
5100
  END DO
5101
5102
  ! calcul du nouveau lmix correspondant
5103
  DO ig = 1, ngrid
5104
    DO l = 1, klev
5105
      IF (zmix(ig)>=zlev(ig,l) .AND. zmix(ig)<zlev(ig,l+1)) THEN
5106
        lmix(ig) = l
5107
      END IF
5108
    END DO
5109
  END DO
5110
5111
  DO l = 2, nlay
5112
    DO ig = 1, ngrid
5113
      IF (larg_cons(ig,l)>1.) THEN
5114
        ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),'  KKK'
5115
        fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig))
5116
        ! test
5117
        fraca(ig, l) = max(fraca(ig,l), 0.)
5118
        fraca(ig, l) = min(fraca(ig,l), 0.5)
5119
        fracd(ig, l) = 1. - fraca(ig, l)
5120
        fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
5121
      ELSE
5122
        ! wa_moy(ig,l)=0.
5123
        fraca(ig, l) = 0.
5124
        fracc(ig, l) = 0.
5125
        fracd(ig, l) = 1.
5126
      END IF
5127
    END DO
5128
  END DO
5129
  ! CR: calcul de fracazmix
5130
  DO ig = 1, ngrid
5131
    fracazmix(ig) = (fraca(ig,lmix(ig)+1)-fraca(ig,lmix(ig)))/ &
5132
      (zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))*zmix(ig) + &
5133
      fraca(ig, lmix(ig)) - zlev(ig, lmix(ig))*(fraca(ig,lmix(ig)+1)-fraca(ig &
5134
      ,lmix(ig)))/(zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))
5135
  END DO
5136
5137
  DO l = 2, nlay
5138
    DO ig = 1, ngrid
5139
      IF (larg_cons(ig,l)>1.) THEN
5140
        IF (l>lmix(ig)) THEN
5141
          ! test
5142
          IF (zmax(ig)-zmix(ig)<1.E-10) THEN
5143
            ! print*,'pb xxx'
5144
            xxx(ig, l) = (lmaxa(ig)+1.-l)/(lmaxa(ig)+1.-lmix(ig))
5145
          ELSE
5146
            xxx(ig, l) = (zmax(ig)-zlev(ig,l))/(zmax(ig)-zmix(ig))
5147
          END IF
5148
          IF (idetr==0) THEN
5149
            fraca(ig, l) = fracazmix(ig)
5150
          ELSE IF (idetr==1) THEN
5151
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)
5152
          ELSE IF (idetr==2) THEN
5153
            fraca(ig, l) = fracazmix(ig)*(1.-(1.-xxx(ig,l))**2)
5154
          ELSE
5155
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)**2
5156
          END IF
5157
          ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL'
5158
          fraca(ig, l) = max(fraca(ig,l), 0.)
5159
          fraca(ig, l) = min(fraca(ig,l), 0.5)
5160
          fracd(ig, l) = 1. - fraca(ig, l)
5161
          fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
5162
        END IF
5163
      END IF
5164
    END DO
5165
  END DO
5166
5167
  ! print*,'fin calcul fraca'
5168
  ! print*,'11 OK convect8'
5169
  ! print*,'Ea3 ',wa_moy
5170
  ! ------------------------------------------------------------------
5171
  ! Calcul de fracd, wd
5172
  ! somme wa - wd = 0
5173
  ! ------------------------------------------------------------------
5174
5175
5176
  DO ig = 1, ngrid
5177
    fm(ig, 1) = 0.
5178
    fm(ig, nlay+1) = 0.
5179
  END DO
5180
5181
  DO l = 2, nlay
5182
    DO ig = 1, ngrid
5183
      fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l)
5184
      ! CR:test
5185
      IF (entr(ig,l-1)<1E-10 .AND. fm(ig,l)>fm(ig,l-1) .AND. l>lmix(ig)) THEN
5186
        fm(ig, l) = fm(ig, l-1)
5187
        ! write(1,*)'ajustement fm, l',l
5188
      END IF
5189
      ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l)
5190
      ! RC
5191
    END DO
5192
    DO ig = 1, ngrid
5193
      IF (fracd(ig,l)<0.1) THEN
5194
        abort_message = 'fracd trop petit'
5195
        CALL abort_physic(modname, abort_message, 1)
5196
      ELSE
5197
        ! vitesse descendante "diagnostique"
5198
        wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l))
5199
      END IF
5200
    END DO
5201
  END DO
5202
5203
  DO l = 1, nlay
5204
    DO ig = 1, ngrid
5205
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
5206
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
5207
    END DO
5208
  END DO
5209
5210
  ! print*,'12 OK convect8'
5211
  ! print*,'WA4 ',wa_moy
5212
  ! c------------------------------------------------------------------
5213
  ! calcul du transport vertical
5214
  ! ------------------------------------------------------------------
5215
5216
  GO TO 4444
5217
  ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep
5218
  DO l = 2, nlay - 1
5219
    DO ig = 1, ngrid
5220
      IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( &
5221
          ig,l+1)) THEN
5222
        ! print*,'WARN!!! FM>M ig=',ig,' l=',l,'  FM='
5223
        ! s         ,fm(ig,l+1)*ptimestep
5224
        ! s         ,'   M=',masse(ig,l),masse(ig,l+1)
5225
      END IF
5226
    END DO
5227
  END DO
5228
5229
  DO l = 1, nlay
5230
    DO ig = 1, ngrid
5231
      IF (entr(ig,l)*ptimestep>masse(ig,l)) THEN
5232
        ! print*,'WARN!!! E>M ig=',ig,' l=',l,'  E=='
5233
        ! s         ,entr(ig,l)*ptimestep
5234
        ! s         ,'   M=',masse(ig,l)
5235
      END IF
5236
    END DO
5237
  END DO
5238
5239
  DO l = 1, nlay
5240
    DO ig = 1, ngrid
5241
      IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN
5242
        ! print*,'WARN!!! fm exagere ig=',ig,'   l=',l
5243
        ! s         ,'   FM=',fm(ig,l)
5244
      END IF
5245
      IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN
5246
        ! print*,'WARN!!! masse exagere ig=',ig,'   l=',l
5247
        ! s         ,'   M=',masse(ig,l)
5248
        ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)',
5249
        ! s                 rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)
5250
        ! print*,'zlev(ig,l+1),zlev(ig,l)'
5251
        ! s                ,zlev(ig,l+1),zlev(ig,l)
5252
        ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)'
5253
        ! s                ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)
5254
      END IF
5255
      IF (.NOT. entr(ig,l)>=0. .OR. .NOT. entr(ig,l)<=10.) THEN
5256
        ! print*,'WARN!!! entr exagere ig=',ig,'   l=',l
5257
        ! s         ,'   E=',entr(ig,l)
5258
      END IF
5259
    END DO
5260
  END DO
5261
5262
4444 CONTINUE
5263
5264
  ! CR:redefinition du entr
5265
  DO l = 1, nlay
5266
    DO ig = 1, ngrid
5267
      detr(ig, l) = fm(ig, l) + entr(ig, l) - fm(ig, l+1)
5268
      IF (detr(ig,l)<0.) THEN
5269
        entr(ig, l) = entr(ig, l) - detr(ig, l)
5270
        detr(ig, l) = 0.
5271
        ! print*,'WARNING !!! detrainement negatif ',ig,l
5272
      END IF
5273
    END DO
5274
  END DO
5275
  ! RC
5276
  IF (w2di==1) THEN
5277
    fm0 = fm0 + ptimestep*(fm-fm0)/tho
5278
    entr0 = entr0 + ptimestep*(entr-entr0)/tho
5279
  ELSE
5280
    fm0 = fm
5281
    entr0 = entr
5282
  END IF
5283
5284
  IF (1==1) THEN
5285
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zh, zdhadj, &
5286
      zha)
5287
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zo, pdoadj, &
5288
      zoa)
5289
  ELSE
5290
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, &
5291
      zdhadj, zha)
5292
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, &
5293
      pdoadj, zoa)
5294
  END IF
5295
5296
  IF (1==0) THEN
5297
    CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, &
5298
      zu, zv, pduadj, pdvadj, zua, zva)
5299
  ELSE
5300
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, &
5301
      zua)
5302
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, &
5303
      zva)
5304
  END IF
5305
5306
  DO l = 1, nlay
5307
    DO ig = 1, ngrid
5308
      zf = 0.5*(fracc(ig,l)+fracc(ig,l+1))
5309
      zf2 = zf/(1.-zf)
5310
      thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l))**2
5311
      wth2(ig, l) = zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2
5312
    END DO
5313
  END DO
5314
5315
5316
5317
  ! print*,'13 OK convect8'
5318
  ! print*,'WA5 ',wa_moy
5319
  DO l = 1, nlay
5320
    DO ig = 1, ngrid
5321
      pdtadj(ig, l) = zdhadj(ig, l)*zpspsk(ig, l)
5322
    END DO
5323
  END DO
5324
5325
5326
  ! do l=1,nlay
5327
  ! do ig=1,ngrid
5328
  ! if(abs(pdtadj(ig,l))*86400..gt.500.) then
5329
  ! print*,'WARN!!! ig=',ig,'  l=',l
5330
  ! s         ,'   pdtadj=',pdtadj(ig,l)
5331
  ! endif
5332
  ! if(abs(pdoadj(ig,l))*86400..gt.1.) then
5333
  ! print*,'WARN!!! ig=',ig,'  l=',l
5334
  ! s         ,'   pdoadj=',pdoadj(ig,l)
5335
  ! endif
5336
  ! enddo
5337
  ! enddo
5338
5339
  ! print*,'14 OK convect8'
5340
  ! ------------------------------------------------------------------
5341
  ! Calculs pour les sorties
5342
  ! ------------------------------------------------------------------
5343
5344
  RETURN
5345
END SUBROUTINE thermcell_sec
5346
5347
SUBROUTINE calcul_sec(ngrid, nlay, ptimestep, pplay, pplev, pphi, zlev, pu, &
5348
    pv, pt, po, zmax, wmax, zw2, lmix & ! s
5349
                                        ! ,pu_therm,pv_therm
5350
    , r_aspect, l_mix, w2di, tho)
5351
5352
  USE dimphy
5353
  IMPLICIT NONE
5354
5355
  ! =======================================================================
5356
5357
  ! Calcul du transport verticale dans la couche limite en presence
5358
  ! de "thermiques" explicitement representes
5359
5360
  ! R��criture � partir d'un listing papier � Habas, le 14/02/00
5361
5362
  ! le thermique est suppos� homog�ne et dissip� par m�lange avec
5363
  ! son environnement. la longueur l_mix contr�le l'efficacit� du
5364
  ! m�lange
5365
5366
  ! Le calcul du transport des diff�rentes esp�ces se fait en prenant
5367
  ! en compte:
5368
  ! 1. un flux de masse montant
5369
  ! 2. un flux de masse descendant
5370
  ! 3. un entrainement
5371
  ! 4. un detrainement
5372
5373
  ! =======================================================================
5374
5375
  ! -----------------------------------------------------------------------
5376
  ! declarations:
5377
  ! -------------
5378
5379
  include "YOMCST.h"
5380
5381
  ! arguments:
5382
  ! ----------
5383
5384
  INTEGER ngrid, nlay, w2di
5385
  REAL tho
5386
  REAL ptimestep, l_mix, r_aspect
5387
  REAL pt(ngrid, nlay), pdtadj(ngrid, nlay)
5388
  REAL pu(ngrid, nlay), pduadj(ngrid, nlay)
5389
  REAL pv(ngrid, nlay), pdvadj(ngrid, nlay)
5390
  REAL po(ngrid, nlay), pdoadj(ngrid, nlay)
5391
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
5392
  REAL pphi(ngrid, nlay)
5393
5394
  INTEGER idetr
5395
  SAVE idetr
5396
  DATA idetr/3/
5397
  !$OMP THREADPRIVATE(idetr)
5398
  ! local:
5399
  ! ------
5400
5401
  INTEGER ig, k, l, lmaxa(klon), lmix(klon)
5402
  REAL zsortie1d(klon)
5403
  ! CR: on remplace lmax(klon,klev+1)
5404
  INTEGER lmax(klon), lmin(klon), lentr(klon)
5405
  REAL linter(klon)
5406
  REAL zmix(klon), fracazmix(klon)
5407
  ! RC
5408
  REAL zmax(klon), zw, zw2(klon, klev+1), ztva(klon, klev)
5409
5410
  REAL zlev(klon, klev+1), zlay(klon, klev)
5411
  REAL zh(klon, klev), zdhadj(klon, klev)
5412
  REAL ztv(klon, klev)
5413
  REAL zu(klon, klev), zv(klon, klev), zo(klon, klev)
5414
  REAL wh(klon, klev+1)
5415
  REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1)
5416
  REAL zla(klon, klev+1)
5417
  REAL zwa(klon, klev+1)
5418
  REAL zld(klon, klev+1)
5419
  ! real zwd(klon,klev+1)
5420
  REAL zsortie(klon, klev)
5421
  REAL zva(klon, klev)
5422
  REAL zua(klon, klev)
5423
  REAL zoa(klon, klev)
5424
5425
  REAL zha(klon, klev)
5426
  REAL wa_moy(klon, klev+1)
5427
  REAL fraca(klon, klev+1)
5428
  REAL fracc(klon, klev+1)
5429
  REAL zf, zf2
5430
  REAL thetath2(klon, klev), wth2(klon, klev)
5431
  ! common/comtherm/thetath2,wth2
5432
5433
  REAL count_time
5434
  ! integer isplit,nsplit
5435
  INTEGER isplit, nsplit, ialt
5436
  PARAMETER (nsplit=10)
5437
  DATA isplit/0/
5438
  SAVE isplit
5439
  !$OMP THREADPRIVATE(isplit)
5440
5441
  LOGICAL sorties
5442
  REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev)
5443
  REAL zpspsk(klon, klev)
5444
5445
  ! real wmax(klon,klev),wmaxa(klon)
5446
  REAL wmax(klon), wmaxa(klon)
5447
  REAL wa(klon, klev, klev+1)
5448
  REAL wd(klon, klev+1)
5449
  REAL larg_part(klon, klev, klev+1)
5450
  REAL fracd(klon, klev+1)
5451
  REAL xxx(klon, klev+1)
5452
  REAL larg_cons(klon, klev+1)
5453
  REAL larg_detr(klon, klev+1)
5454
  REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev)
5455
  REAL pu_therm(klon, klev), pv_therm(klon, klev)
5456
  REAL fm(klon, klev+1), entr(klon, klev)
5457
  REAL fmc(klon, klev+1)
5458
5459
  ! CR:nouvelles variables
5460
  REAL f_star(klon, klev+1), entr_star(klon, klev)
5461
  REAL entr_star_tot(klon), entr_star2(klon)
5462
  REAL zalim(klon)
5463
  INTEGER lalim(klon)
5464
  REAL norme(klon)
5465
  REAL f(klon), f0(klon)
5466
  REAL zlevinter(klon)
5467
  LOGICAL therm
5468
  LOGICAL first
5469
  DATA first/.FALSE./
5470
  SAVE first
5471
  !$OMP THREADPRIVATE(first)
5472
  ! RC
5473
5474
  CHARACTER *2 str2
5475
  CHARACTER *10 str10
5476
5477
  CHARACTER (LEN=20) :: modname = 'calcul_sec'
5478
  CHARACTER (LEN=80) :: abort_message
5479
5480
5481
  ! LOGICAL vtest(klon),down
5482
5483
  EXTERNAL scopy
5484
5485
  INTEGER ncorrec
5486
  SAVE ncorrec
5487
  DATA ncorrec/0/
5488
  !$OMP THREADPRIVATE(ncorrec)
5489
5490
5491
  ! -----------------------------------------------------------------------
5492
  ! initialisation:
5493
  ! ---------------
5494
5495
  sorties = .TRUE.
5496
  IF (ngrid/=klon) THEN
5497
    PRINT *
5498
    PRINT *, 'STOP dans convadj'
5499
    PRINT *, 'ngrid    =', ngrid
5500
    PRINT *, 'klon  =', klon
5501
  END IF
5502
5503
  ! -----------------------------------------------------------------------
5504
  ! incrementation eventuelle de tendances precedentes:
5505
  ! ---------------------------------------------------
5506
5507
  ! print*,'0 OK convect8'
5508
5509
  DO l = 1, nlay
5510
    DO ig = 1, ngrid
5511
      zpspsk(ig, l) = (pplay(ig,l)/pplev(ig,1))**rkappa
5512
      zh(ig, l) = pt(ig, l)/zpspsk(ig, l)
5513
      zu(ig, l) = pu(ig, l)
5514
      zv(ig, l) = pv(ig, l)
5515
      zo(ig, l) = po(ig, l)
5516
      ztv(ig, l) = zh(ig, l)*(1.+0.61*zo(ig,l))
5517
    END DO
5518
  END DO
5519
5520
  ! print*,'1 OK convect8'
5521
  ! --------------------
5522
5523
5524
  ! + + + + + + + + + + +
5525
5526
5527
  ! wa, fraca, wd, fracd --------------------   zlev(2), rhobarz
5528
  ! wh,wt,wo ...
5529
5530
  ! + + + + + + + + + + +  zh,zu,zv,zo,rho
5531
5532
5533
  ! --------------------   zlev(1)
5534
  ! \\\\\\\\\\\\\\\\\\\\
5535
5536
5537
5538
  ! -----------------------------------------------------------------------
5539
  ! Calcul des altitudes des couches
5540
  ! -----------------------------------------------------------------------
5541
5542
  DO l = 2, nlay
5543
    DO ig = 1, ngrid
5544
      zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg
5545
    END DO
5546
  END DO
5547
  DO ig = 1, ngrid
5548
    zlev(ig, 1) = 0.
5549
    zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg
5550
  END DO
5551
  DO l = 1, nlay
5552
    DO ig = 1, ngrid
5553
      zlay(ig, l) = pphi(ig, l)/rg
5554
    END DO
5555
  END DO
5556
5557
  ! print*,'2 OK convect8'
5558
  ! -----------------------------------------------------------------------
5559
  ! Calcul des densites
5560
  ! -----------------------------------------------------------------------
5561
5562
  DO l = 1, nlay
5563
    DO ig = 1, ngrid
5564
      rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*zh(ig,l))
5565
    END DO
5566
  END DO
5567
5568
  DO l = 2, nlay
5569
    DO ig = 1, ngrid
5570
      rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1))
5571
    END DO
5572
  END DO
5573
5574
  DO k = 1, nlay
5575
    DO l = 1, nlay + 1
5576
      DO ig = 1, ngrid
5577
        wa(ig, k, l) = 0.
5578
      END DO
5579
    END DO
5580
  END DO
5581
5582
  ! print*,'3 OK convect8'
5583
  ! ------------------------------------------------------------------
5584
  ! Calcul de w2, quarre de w a partir de la cape
5585
  ! a partir de w2, on calcule wa, vitesse de l'ascendance
5586
5587
  ! ATTENTION: Dans cette version, pour cause d'economie de memoire,
5588
  ! w2 est stoke dans wa
5589
5590
  ! ATTENTION: dans convect8, on n'utilise le calcule des wa
5591
  ! independants par couches que pour calculer l'entrainement
5592
  ! a la base et la hauteur max de l'ascendance.
5593
5594
  ! Indicages:
5595
  ! l'ascendance provenant du niveau k traverse l'interface l avec
5596
  ! une vitesse wa(k,l).
5597
5598
  ! --------------------
5599
5600
  ! + + + + + + + + + +
5601
5602
  ! wa(k,l)   ----       --------------------    l
5603
  ! /\
5604
  ! /||\       + + + + + + + + + +
5605
  ! ||
5606
  ! ||        --------------------
5607
  ! ||
5608
  ! ||        + + + + + + + + + +
5609
  ! ||
5610
  ! ||        --------------------
5611
  ! ||__
5612
  ! |___      + + + + + + + + + +     k
5613
5614
  ! --------------------
5615
5616
5617
5618
  ! ------------------------------------------------------------------
5619
5620
  ! CR: ponderation entrainement des couches instables
5621
  ! def des entr_star tels que entr=f*entr_star
5622
  DO l = 1, klev
5623
    DO ig = 1, ngrid
5624
      entr_star(ig, l) = 0.
5625
    END DO
5626
  END DO
5627
  ! determination de la longueur de la couche d entrainement
5628
  DO ig = 1, ngrid
5629
    lentr(ig) = 1
5630
  END DO
5631
5632
  ! on ne considere que les premieres couches instables
5633
  therm = .FALSE.
5634
  DO k = nlay - 2, 1, -1
5635
    DO ig = 1, ngrid
5636
      IF (ztv(ig,k)>ztv(ig,k+1) .AND. ztv(ig,k+1)<=ztv(ig,k+2)) THEN
5637
        lentr(ig) = k + 1
5638
        therm = .TRUE.
5639
      END IF
5640
    END DO
5641
  END DO
5642
  ! limitation de la valeur du lentr
5643
  ! do ig=1,ngrid
5644
  ! lentr(ig)=min(5,lentr(ig))
5645
  ! enddo
5646
  ! determination du lmin: couche d ou provient le thermique
5647
  DO ig = 1, ngrid
5648
    lmin(ig) = 1
5649
  END DO
5650
  DO ig = 1, ngrid
5651
    DO l = nlay, 2, -1
5652
      IF (ztv(ig,l-1)>ztv(ig,l)) THEN
5653
        lmin(ig) = l - 1
5654
      END IF
5655
    END DO
5656
  END DO
5657
  ! initialisations
5658
  DO ig = 1, ngrid
5659
    zalim(ig) = 0.
5660
    norme(ig) = 0.
5661
    lalim(ig) = 1
5662
  END DO
5663
  DO k = 1, klev - 1
5664
    DO ig = 1, ngrid
5665
      zalim(ig) = zalim(ig) + zlev(ig, k)*max(0., (ztv(ig,k)-ztv(ig, &
5666
        k+1))/(zlev(ig,k+1)-zlev(ig,k)))
5667
      ! s         *(zlev(ig,k+1)-zlev(ig,k))
5668
      norme(ig) = norme(ig) + max(0., (ztv(ig,k)-ztv(ig,k+1))/(zlev(ig, &
5669
        k+1)-zlev(ig,k)))
5670
      ! s          *(zlev(ig,k+1)-zlev(ig,k))
5671
    END DO
5672
  END DO
5673
  DO ig = 1, ngrid
5674
    IF (norme(ig)>1.E-10) THEN
5675
      zalim(ig) = max(10.*zalim(ig)/norme(ig), zlev(ig,2))
5676
      ! zalim(ig)=min(zalim(ig),zlev(ig,lentr(ig)))
5677
    END IF
5678
  END DO
5679
  ! d�termination du lalim correspondant
5680
  DO k = 1, klev - 1
5681
    DO ig = 1, ngrid
5682
      IF ((zalim(ig)>zlev(ig,k)) .AND. (zalim(ig)<=zlev(ig,k+1))) THEN
5683
        lalim(ig) = k
5684
      END IF
5685
    END DO
5686
  END DO
5687
5688
  ! definition de l'entrainement des couches
5689
  DO l = 1, klev - 1
5690
    DO ig = 1, ngrid
5691
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<lentr(ig)) THEN
5692
        entr_star(ig, l) = max((ztv(ig,l)-ztv(ig,l+1)), 0.) & ! s
5693
                                                              ! *(zlev(ig,l+1)-zlev(ig,l))
5694
          *sqrt(zlev(ig,l+1))
5695
        ! autre def
5696
        ! entr_star(ig,l)=zlev(ig,l+1)*(1.-(zlev(ig,l+1)
5697
        ! s                         /zlev(ig,lentr(ig)+2)))**(3./2.)
5698
      END IF
5699
    END DO
5700
  END DO
5701
  ! nouveau test
5702
  ! if (therm) then
5703
  DO l = 1, klev - 1
5704
    DO ig = 1, ngrid
5705
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<=lalim(ig) .AND. &
5706
          zalim(ig)>1.E-10) THEN
5707
        ! if (l.le.lentr(ig)) then
5708
        ! entr_star(ig,l)=zlev(ig,l+1)*(1.-(zlev(ig,l+1)
5709
        ! s                         /zalim(ig)))**(3./2.)
5710
        ! write(10,*)zlev(ig,l),entr_star(ig,l)
5711
      END IF
5712
    END DO
5713
  END DO
5714
  ! endif
5715
  ! pas de thermique si couche 1 stable
5716
  DO ig = 1, ngrid
5717
    IF (lmin(ig)>5) THEN
5718
      DO l = 1, klev
5719
        entr_star(ig, l) = 0.
5720
      END DO
5721
    END IF
5722
  END DO
5723
  ! calcul de l entrainement total
5724
  DO ig = 1, ngrid
5725
    entr_star_tot(ig) = 0.
5726
  END DO
5727
  DO ig = 1, ngrid
5728
    DO k = 1, klev
5729
      entr_star_tot(ig) = entr_star_tot(ig) + entr_star(ig, k)
5730
    END DO
5731
  END DO
5732
  ! Calcul entrainement normalise
5733
  DO ig = 1, ngrid
5734
    IF (entr_star_tot(ig)>1.E-10) THEN
5735
      ! do l=1,lentr(ig)
5736
      DO l = 1, klev
5737
        ! def possibles pour entr_star: zdthetadz, dthetadz, zdtheta
5738
        entr_star(ig, l) = entr_star(ig, l)/entr_star_tot(ig)
5739
      END DO
5740
    END IF
5741
  END DO
5742
5743
  ! print*,'fin calcul entr_star'
5744
  DO k = 1, klev
5745
    DO ig = 1, ngrid
5746
      ztva(ig, k) = ztv(ig, k)
5747
    END DO
5748
  END DO
5749
  ! RC
5750
  ! print*,'7 OK convect8'
5751
  DO k = 1, klev + 1
5752
    DO ig = 1, ngrid
5753
      zw2(ig, k) = 0.
5754
      fmc(ig, k) = 0.
5755
      ! CR
5756
      f_star(ig, k) = 0.
5757
      ! RC
5758
      larg_cons(ig, k) = 0.
5759
      larg_detr(ig, k) = 0.
5760
      wa_moy(ig, k) = 0.
5761
    END DO
5762
  END DO
5763
5764
  ! print*,'8 OK convect8'
5765
  DO ig = 1, ngrid
5766
    linter(ig) = 1.
5767
    lmaxa(ig) = 1
5768
    lmix(ig) = 1
5769
    wmaxa(ig) = 0.
5770
  END DO
5771
5772
  ! CR:
5773
  DO l = 1, nlay - 2
5774
    DO ig = 1, ngrid
5775
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. entr_star(ig,l)>1.E-10 .AND. &
5776
          zw2(ig,l)<1E-10) THEN
5777
        f_star(ig, l+1) = entr_star(ig, l)
5778
        ! test:calcul de dteta
5779
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
5780
          (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l))
5781
        larg_detr(ig, l) = 0.
5782
      ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+entr_star(ig, &
5783
          l)>1.E-10)) THEN
5784
        f_star(ig, l+1) = f_star(ig, l) + entr_star(ig, l)
5785
        ztva(ig, l) = (f_star(ig,l)*ztva(ig,l-1)+entr_star(ig,l)*ztv(ig,l))/ &
5786
          f_star(ig, l+1)
5787
        zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/f_star(ig,l+1))**2 + &
5788
          2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l))
5789
      END IF
5790
      ! determination de zmax continu par interpolation lineaire
5791
      IF (zw2(ig,l+1)<0.) THEN
5792
        ! test
5793
        IF (abs(zw2(ig,l+1)-zw2(ig,l))<1E-10) THEN
5794
          ! print*,'pb linter'
5795
        END IF
5796
        linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( &
5797
          ig,l))
5798
        zw2(ig, l+1) = 0.
5799
        lmaxa(ig) = l
5800
      ELSE
5801
        IF (zw2(ig,l+1)<0.) THEN
5802
          ! print*,'pb1 zw2<0'
5803
        END IF
5804
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
5805
      END IF
5806
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
5807
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
5808
        lmix(ig) = l + 1
5809
        wmaxa(ig) = wa_moy(ig, l+1)
5810
      END IF
5811
    END DO
5812
  END DO
5813
  ! print*,'fin calcul zw2'
5814
5815
  ! Calcul de la couche correspondant a la hauteur du thermique
5816
  DO ig = 1, ngrid
5817
    lmax(ig) = lentr(ig)
5818
    ! lmax(ig)=lalim(ig)
5819
  END DO
5820
  DO ig = 1, ngrid
5821
    DO l = nlay, lentr(ig) + 1, -1
5822
      ! do l=nlay,lalim(ig)+1,-1
5823
      IF (zw2(ig,l)<=1.E-10) THEN
5824
        lmax(ig) = l - 1
5825
      END IF
5826
    END DO
5827
  END DO
5828
  ! pas de thermique si couche 1 stable
5829
  DO ig = 1, ngrid
5830
    IF (lmin(ig)>5) THEN
5831
      lmax(ig) = 1
5832
      lmin(ig) = 1
5833
      lentr(ig) = 1
5834
      lalim(ig) = 1
5835
    END IF
5836
  END DO
5837
5838
  ! Determination de zw2 max
5839
  DO ig = 1, ngrid
5840
    wmax(ig) = 0.
5841
  END DO
5842
5843
  DO l = 1, nlay
5844
    DO ig = 1, ngrid
5845
      IF (l<=lmax(ig)) THEN
5846
        IF (zw2(ig,l)<0.) THEN
5847
          ! print*,'pb2 zw2<0'
5848
        END IF
5849
        zw2(ig, l) = sqrt(zw2(ig,l))
5850
        wmax(ig) = max(wmax(ig), zw2(ig,l))
5851
      ELSE
5852
        zw2(ig, l) = 0.
5853
      END IF
5854
    END DO
5855
  END DO
5856
5857
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
5858
  DO ig = 1, ngrid
5859
    zmax(ig) = 0.
5860
    zlevinter(ig) = zlev(ig, 1)
5861
  END DO
5862
  DO ig = 1, ngrid
5863
    ! calcul de zlevinter
5864
    zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + &
5865
      zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))
5866
    zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,lmin(ig)))
5867
  END DO
5868
  DO ig = 1, ngrid
5869
    ! write(8,*)zmax(ig),lmax(ig),lentr(ig),lmin(ig)
5870
  END DO
5871
  ! on stope apr�s les calculs de zmax et wmax
5872
  RETURN
5873
5874
  ! print*,'avant fermeture'
5875
  ! Fermeture,determination de f
5876
  ! Attention! entrainement normalis� ou pas?
5877
  DO ig = 1, ngrid
5878
    entr_star2(ig) = 0.
5879
  END DO
5880
  DO ig = 1, ngrid
5881
    IF (entr_star_tot(ig)<1.E-10) THEN
5882
      f(ig) = 0.
5883
    ELSE
5884
      DO k = lmin(ig), lentr(ig)
5885
        ! do k=lmin(ig),lalim(ig)
5886
        entr_star2(ig) = entr_star2(ig) + entr_star(ig, k)**2/(rho(ig,k)*( &
5887
          zlev(ig,k+1)-zlev(ig,k)))
5888
      END DO
5889
      ! Nouvelle fermeture
5890
      f(ig) = wmax(ig)/(max(500.,zmax(ig))*r_aspect*entr_star2(ig))
5891
      ! s            *entr_star_tot(ig)
5892
      ! test
5893
      ! if (first) then
5894
      f(ig) = f(ig) + (f0(ig)-f(ig))*exp(-ptimestep/zmax(ig)*wmax(ig))
5895
      ! endif
5896
    END IF
5897
    f0(ig) = f(ig)
5898
    ! first=.true.
5899
  END DO
5900
  ! print*,'apres fermeture'
5901
  ! on stoppe apr�s la fermeture
5902
  RETURN
5903
  ! Calcul de l'entrainement
5904
  DO k = 1, klev
5905
    DO ig = 1, ngrid
5906
      entr(ig, k) = f(ig)*entr_star(ig, k)
5907
    END DO
5908
  END DO
5909
  ! on stoppe apr�s le calcul de entr
5910
  ! RETURN
5911
  ! CR:test pour entrainer moins que la masse
5912
  ! do ig=1,ngrid
5913
  ! do l=1,lentr(ig)
5914
  ! if ((entr(ig,l)*ptimestep).gt.(0.9*masse(ig,l))) then
5915
  ! entr(ig,l+1)=entr(ig,l+1)+entr(ig,l)
5916
  ! s                       -0.9*masse(ig,l)/ptimestep
5917
  ! entr(ig,l)=0.9*masse(ig,l)/ptimestep
5918
  ! endif
5919
  ! enddo
5920
  ! enddo
5921
  ! CR: fin test
5922
  ! Calcul des flux
5923
  DO ig = 1, ngrid
5924
    DO l = 1, lmax(ig) - 1
5925
      fmc(ig, l+1) = fmc(ig, l) + entr(ig, l)
5926
    END DO
5927
  END DO
5928
5929
  ! RC
5930
5931
5932
  ! print*,'9 OK convect8'
5933
  ! print*,'WA1 ',wa_moy
5934
5935
  ! determination de l'indice du debut de la mixed layer ou w decroit
5936
5937
  ! calcul de la largeur de chaque ascendance dans le cas conservatif.
5938
  ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant
5939
  ! d'une couche est �gale � la hauteur de la couche alimentante.
5940
  ! La vitesse maximale dans l'ascendance est aussi prise comme estimation
5941
  ! de la vitesse d'entrainement horizontal dans la couche alimentante.
5942
5943
  DO l = 2, nlay
5944
    DO ig = 1, ngrid
5945
      IF (l<=lmaxa(ig)) THEN
5946
        zw = max(wa_moy(ig,l), 1.E-10)
5947
        larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw)
5948
      END IF
5949
    END DO
5950
  END DO
5951
5952
  DO l = 2, nlay
5953
    DO ig = 1, ngrid
5954
      IF (l<=lmaxa(ig)) THEN
5955
        ! if (idetr.eq.0) then
5956
        ! cette option est finalement en dur.
5957
        IF ((l_mix*zlev(ig,l))<0.) THEN
5958
          ! print*,'pb l_mix*zlev<0'
5959
        END IF
5960
        ! CR: test: nouvelle def de lambda
5961
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
5962
        IF (zw2(ig,l)>1.E-10) THEN
5963
          larg_detr(ig, l) = sqrt((l_mix/zw2(ig,l))*zlev(ig,l))
5964
        ELSE
5965
          larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l))
5966
        END IF
5967
        ! RC
5968
        ! else if (idetr.eq.1) then
5969
        ! larg_detr(ig,l)=larg_cons(ig,l)
5970
        ! s            *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig))
5971
        ! else if (idetr.eq.2) then
5972
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
5973
        ! s            *sqrt(wa_moy(ig,l))
5974
        ! else if (idetr.eq.4) then
5975
        ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l))
5976
        ! s            *wa_moy(ig,l)
5977
        ! endif
5978
      END IF
5979
    END DO
5980
  END DO
5981
5982
  ! print*,'10 OK convect8'
5983
  ! print*,'WA2 ',wa_moy
5984
  ! calcul de la fraction de la maille concern�e par l'ascendance en tenant
5985
  ! compte de l'epluchage du thermique.
5986
5987
  ! CR def de  zmix continu (profil parabolique des vitesses)
5988
  DO ig = 1, ngrid
5989
    IF (lmix(ig)>1.) THEN
5990
      ! test
5991
      IF (((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
5992
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
5993
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))- &
5994
          (zlev(ig,lmix(ig)))))>1E-10) THEN
5995
5996
        zmix(ig) = ((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)) &
5997
          )**2-(zlev(ig,lmix(ig)+1))**2)-(zw2(ig,lmix(ig))-zw2(ig, &
5998
          lmix(ig)+1))*((zlev(ig,lmix(ig)-1))**2-(zlev(ig,lmix(ig)))**2))/ &
5999
          (2.*((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- &
6000
          (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- &
6001
          zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))-(zlev(ig,lmix(ig))))))
6002
      ELSE
6003
        zmix(ig) = zlev(ig, lmix(ig))
6004
        ! print*,'pb zmix'
6005
      END IF
6006
    ELSE
6007
      zmix(ig) = 0.
6008
    END IF
6009
    ! test
6010
    IF ((zmax(ig)-zmix(ig))<0.) THEN
6011
      zmix(ig) = 0.99*zmax(ig)
6012
      ! print*,'pb zmix>zmax'
6013
    END IF
6014
  END DO
6015
6016
  ! calcul du nouveau lmix correspondant
6017
  DO ig = 1, ngrid
6018
    DO l = 1, klev
6019
      IF (zmix(ig)>=zlev(ig,l) .AND. zmix(ig)<zlev(ig,l+1)) THEN
6020
        lmix(ig) = l
6021
      END IF
6022
    END DO
6023
  END DO
6024
6025
  DO l = 2, nlay
6026
    DO ig = 1, ngrid
6027
      IF (larg_cons(ig,l)>1.) THEN
6028
        ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),'  KKK'
6029
        fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig))
6030
        ! test
6031
        fraca(ig, l) = max(fraca(ig,l), 0.)
6032
        fraca(ig, l) = min(fraca(ig,l), 0.5)
6033
        fracd(ig, l) = 1. - fraca(ig, l)
6034
        fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
6035
      ELSE
6036
        ! wa_moy(ig,l)=0.
6037
        fraca(ig, l) = 0.
6038
        fracc(ig, l) = 0.
6039
        fracd(ig, l) = 1.
6040
      END IF
6041
    END DO
6042
  END DO
6043
  ! CR: calcul de fracazmix
6044
  DO ig = 1, ngrid
6045
    fracazmix(ig) = (fraca(ig,lmix(ig)+1)-fraca(ig,lmix(ig)))/ &
6046
      (zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))*zmix(ig) + &
6047
      fraca(ig, lmix(ig)) - zlev(ig, lmix(ig))*(fraca(ig,lmix(ig)+1)-fraca(ig &
6048
      ,lmix(ig)))/(zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))
6049
  END DO
6050
6051
  DO l = 2, nlay
6052
    DO ig = 1, ngrid
6053
      IF (larg_cons(ig,l)>1.) THEN
6054
        IF (l>lmix(ig)) THEN
6055
          ! test
6056
          IF (zmax(ig)-zmix(ig)<1.E-10) THEN
6057
            ! print*,'pb xxx'
6058
            xxx(ig, l) = (lmaxa(ig)+1.-l)/(lmaxa(ig)+1.-lmix(ig))
6059
          ELSE
6060
            xxx(ig, l) = (zmax(ig)-zlev(ig,l))/(zmax(ig)-zmix(ig))
6061
          END IF
6062
          IF (idetr==0) THEN
6063
            fraca(ig, l) = fracazmix(ig)
6064
          ELSE IF (idetr==1) THEN
6065
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)
6066
          ELSE IF (idetr==2) THEN
6067
            fraca(ig, l) = fracazmix(ig)*(1.-(1.-xxx(ig,l))**2)
6068
          ELSE
6069
            fraca(ig, l) = fracazmix(ig)*xxx(ig, l)**2
6070
          END IF
6071
          ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL'
6072
          fraca(ig, l) = max(fraca(ig,l), 0.)
6073
          fraca(ig, l) = min(fraca(ig,l), 0.5)
6074
          fracd(ig, l) = 1. - fraca(ig, l)
6075
          fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig))
6076
        END IF
6077
      END IF
6078
    END DO
6079
  END DO
6080
6081
  ! print*,'fin calcul fraca'
6082
  ! print*,'11 OK convect8'
6083
  ! print*,'Ea3 ',wa_moy
6084
  ! ------------------------------------------------------------------
6085
  ! Calcul de fracd, wd
6086
  ! somme wa - wd = 0
6087
  ! ------------------------------------------------------------------
6088
6089
6090
  DO ig = 1, ngrid
6091
    fm(ig, 1) = 0.
6092
    fm(ig, nlay+1) = 0.
6093
  END DO
6094
6095
  DO l = 2, nlay
6096
    DO ig = 1, ngrid
6097
      fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l)
6098
      ! CR:test
6099
      IF (entr(ig,l-1)<1E-10 .AND. fm(ig,l)>fm(ig,l-1) .AND. l>lmix(ig)) THEN
6100
        fm(ig, l) = fm(ig, l-1)
6101
        ! write(1,*)'ajustement fm, l',l
6102
      END IF
6103
      ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l)
6104
      ! RC
6105
    END DO
6106
    DO ig = 1, ngrid
6107
      IF (fracd(ig,l)<0.1) THEN
6108
        abort_message = 'fracd trop petit'
6109
        CALL abort_physic(modname, abort_message, 1)
6110
6111
      ELSE
6112
        ! vitesse descendante "diagnostique"
6113
        wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l))
6114
      END IF
6115
    END DO
6116
  END DO
6117
6118
  DO l = 1, nlay
6119
    DO ig = 1, ngrid
6120
      ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l))
6121
      masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg
6122
    END DO
6123
  END DO
6124
6125
  ! print*,'12 OK convect8'
6126
  ! print*,'WA4 ',wa_moy
6127
  ! c------------------------------------------------------------------
6128
  ! calcul du transport vertical
6129
  ! ------------------------------------------------------------------
6130
6131
  GO TO 4444
6132
  ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep
6133
  DO l = 2, nlay - 1
6134
    DO ig = 1, ngrid
6135
      IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( &
6136
          ig,l+1)) THEN
6137
        ! print*,'WARN!!! FM>M ig=',ig,' l=',l,'  FM='
6138
        ! s         ,fm(ig,l+1)*ptimestep
6139
        ! s         ,'   M=',masse(ig,l),masse(ig,l+1)
6140
      END IF
6141
    END DO
6142
  END DO
6143
6144
  DO l = 1, nlay
6145
    DO ig = 1, ngrid
6146
      IF (entr(ig,l)*ptimestep>masse(ig,l)) THEN
6147
        ! print*,'WARN!!! E>M ig=',ig,' l=',l,'  E=='
6148
        ! s         ,entr(ig,l)*ptimestep
6149
        ! s         ,'   M=',masse(ig,l)
6150
      END IF
6151
    END DO
6152
  END DO
6153
6154
  DO l = 1, nlay
6155
    DO ig = 1, ngrid
6156
      IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN
6157
        ! print*,'WARN!!! fm exagere ig=',ig,'   l=',l
6158
        ! s         ,'   FM=',fm(ig,l)
6159
      END IF
6160
      IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN
6161
        ! print*,'WARN!!! masse exagere ig=',ig,'   l=',l
6162
        ! s         ,'   M=',masse(ig,l)
6163
        ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)',
6164
        ! s                 rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)
6165
        ! print*,'zlev(ig,l+1),zlev(ig,l)'
6166
        ! s                ,zlev(ig,l+1),zlev(ig,l)
6167
        ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)'
6168
        ! s                ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)
6169
      END IF
6170
      IF (.NOT. entr(ig,l)>=0. .OR. .NOT. entr(ig,l)<=10.) THEN
6171
        ! print*,'WARN!!! entr exagere ig=',ig,'   l=',l
6172
        ! s         ,'   E=',entr(ig,l)
6173
      END IF
6174
    END DO
6175
  END DO
6176
6177
4444 CONTINUE
6178
6179
  ! CR:redefinition du entr
6180
  DO l = 1, nlay
6181
    DO ig = 1, ngrid
6182
      detr(ig, l) = fm(ig, l) + entr(ig, l) - fm(ig, l+1)
6183
      IF (detr(ig,l)<0.) THEN
6184
        ! entr(ig,l)=entr(ig,l)-detr(ig,l)
6185
        fm(ig, l+1) = fm(ig, l) + entr(ig, l)
6186
        detr(ig, l) = 0.
6187
        ! print*,'WARNING !!! detrainement negatif ',ig,l
6188
      END IF
6189
    END DO
6190
  END DO
6191
  ! RC
6192
  IF (w2di==1) THEN
6193
    fm0 = fm0 + ptimestep*(fm-fm0)/tho
6194
    entr0 = entr0 + ptimestep*(entr-entr0)/tho
6195
  ELSE
6196
    fm0 = fm
6197
    entr0 = entr
6198
  END IF
6199
6200
  IF (1==1) THEN
6201
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zh, zdhadj, &
6202
      zha)
6203
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zo, pdoadj, &
6204
      zoa)
6205
  ELSE
6206
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, &
6207
      zdhadj, zha)
6208
    CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, &
6209
      pdoadj, zoa)
6210
  END IF
6211
6212
  IF (1==0) THEN
6213
    CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, &
6214
      zu, zv, pduadj, pdvadj, zua, zva)
6215
  ELSE
6216
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, &
6217
      zua)
6218
    CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, &
6219
      zva)
6220
  END IF
6221
6222
  DO l = 1, nlay
6223
    DO ig = 1, ngrid
6224
      zf = 0.5*(fracc(ig,l)+fracc(ig,l+1))
6225
      zf2 = zf/(1.-zf)
6226
      thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l))**2
6227
      wth2(ig, l) = zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2
6228
    END DO
6229
  END DO
6230
6231
6232
6233
  ! print*,'13 OK convect8'
6234
  ! print*,'WA5 ',wa_moy
6235
  DO l = 1, nlay
6236
    DO ig = 1, ngrid
6237
      pdtadj(ig, l) = zdhadj(ig, l)*zpspsk(ig, l)
6238
    END DO
6239
  END DO
6240
6241
6242
  ! do l=1,nlay
6243
  ! do ig=1,ngrid
6244
  ! if(abs(pdtadj(ig,l))*86400..gt.500.) then
6245
  ! print*,'WARN!!! ig=',ig,'  l=',l
6246
  ! s         ,'   pdtadj=',pdtadj(ig,l)
6247
  ! endif
6248
  ! if(abs(pdoadj(ig,l))*86400..gt.1.) then
6249
  ! print*,'WARN!!! ig=',ig,'  l=',l
6250
  ! s         ,'   pdoadj=',pdoadj(ig,l)
6251
  ! endif
6252
  ! enddo
6253
  ! enddo
6254
6255
  ! print*,'14 OK convect8'
6256
  ! ------------------------------------------------------------------
6257
  ! Calculs pour les sorties
6258
  ! ------------------------------------------------------------------
6259
6260
  IF (sorties) THEN
6261
    DO l = 1, nlay
6262
      DO ig = 1, ngrid
6263
        zla(ig, l) = (1.-fracd(ig,l))*zmax(ig)
6264
        zld(ig, l) = fracd(ig, l)*zmax(ig)
6265
        IF (1.-fracd(ig,l)>1.E-10) zwa(ig, l) = wd(ig, l)*fracd(ig, l)/ &
6266
          (1.-fracd(ig,l))
6267
      END DO
6268
    END DO
6269
6270
    ! deja fait
6271
    ! do l=1,nlay
6272
    ! do ig=1,ngrid
6273
    ! detr(ig,l)=fm(ig,l)+entr(ig,l)-fm(ig,l+1)
6274
    ! if (detr(ig,l).lt.0.) then
6275
    ! entr(ig,l)=entr(ig,l)-detr(ig,l)
6276
    ! detr(ig,l)=0.
6277
    ! print*,'WARNING !!! detrainement negatif ',ig,l
6278
    ! endif
6279
    ! enddo
6280
    ! enddo
6281
6282
    ! print*,'15 OK convect8'
6283
6284
    isplit = isplit + 1
6285
6286
6287
    ! #define und
6288
    GO TO 123
6289
#ifdef und
6290
    CALL writeg1d(1, nlay, wd, 'wd      ', 'wd      ')
6291
    CALL writeg1d(1, nlay, zwa, 'wa      ', 'wa      ')
6292
    CALL writeg1d(1, nlay, fracd, 'fracd      ', 'fracd      ')
6293
    CALL writeg1d(1, nlay, fraca, 'fraca      ', 'fraca      ')
6294
    CALL writeg1d(1, nlay, wa_moy, 'wam         ', 'wam         ')
6295
    CALL writeg1d(1, nlay, zla, 'la      ', 'la      ')
6296
    CALL writeg1d(1, nlay, zld, 'ld      ', 'ld      ')
6297
    CALL writeg1d(1, nlay, pt, 'pt      ', 'pt      ')
6298
    CALL writeg1d(1, nlay, zh, 'zh      ', 'zh      ')
6299
    CALL writeg1d(1, nlay, zha, 'zha      ', 'zha      ')
6300
    CALL writeg1d(1, nlay, zu, 'zu      ', 'zu      ')
6301
    CALL writeg1d(1, nlay, zv, 'zv      ', 'zv      ')
6302
    CALL writeg1d(1, nlay, zo, 'zo      ', 'zo      ')
6303
    CALL writeg1d(1, nlay, wh, 'wh      ', 'wh      ')
6304
    CALL writeg1d(1, nlay, wu, 'wu      ', 'wu      ')
6305
    CALL writeg1d(1, nlay, wv, 'wv      ', 'wv      ')
6306
    CALL writeg1d(1, nlay, wo, 'w15uo     ', 'wXo     ')
6307
    CALL writeg1d(1, nlay, zdhadj, 'zdhadj      ', 'zdhadj      ')
6308
    CALL writeg1d(1, nlay, pduadj, 'pduadj      ', 'pduadj      ')
6309
    CALL writeg1d(1, nlay, pdvadj, 'pdvadj      ', 'pdvadj      ')
6310
    CALL writeg1d(1, nlay, pdoadj, 'pdoadj      ', 'pdoadj      ')
6311
    CALL writeg1d(1, nlay, entr, 'entr        ', 'entr        ')
6312
    CALL writeg1d(1, nlay, detr, 'detr        ', 'detr        ')
6313
    CALL writeg1d(1, nlay, fm, 'fm          ', 'fm          ')
6314
6315
    CALL writeg1d(1, nlay, pdtadj, 'pdtadj    ', 'pdtadj    ')
6316
    CALL writeg1d(1, nlay, pplay, 'pplay     ', 'pplay     ')
6317
    CALL writeg1d(1, nlay, pplev, 'pplev     ', 'pplev     ')
6318
6319
    ! recalcul des flux en diagnostique...
6320
    ! print*,'PAS DE TEMPS ',ptimestep
6321
    CALL dt2f(pplev, pplay, pt, pdtadj, wh)
6322
    CALL writeg1d(1, nlay, wh, 'wh2     ', 'wh2     ')
6323
#endif
6324
123 CONTINUE
6325
6326
  END IF
6327
6328
  ! if(wa_moy(1,4).gt.1.e-10) stop
6329
6330
  ! print*,'19 OK convect8'
6331
  RETURN
6332
END SUBROUTINE calcul_sec
6333
6334
SUBROUTINE fermeture_seche(ngrid, nlay, pplay, pplev, pphi, zlev, rhobarz, &
6335
    f0, zpspsk, alim_star, zh, zo, lentr, lmin, nu_min, nu_max, r_aspect, &
6336
    zmax, wmax)
6337
6338
  USE dimphy
6339
  IMPLICIT NONE
6340
6341
  include "YOMCST.h"
6342
6343
  INTEGER ngrid, nlay
6344
  REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1)
6345
  REAL pphi(ngrid, nlay)
6346
  REAL zlev(klon, klev+1)
6347
  REAL alim_star(klon, klev)
6348
  REAL f0(klon)
6349
  INTEGER lentr(klon)
6350
  INTEGER lmin(klon)
6351
  REAL zmax(klon)
6352
  REAL wmax(klon)
6353
  REAL nu_min
6354
  REAL nu_max
6355
  REAL r_aspect
6356
  REAL rhobarz(klon, klev+1)
6357
  REAL zh(klon, klev)
6358
  REAL zo(klon, klev)
6359
  REAL zpspsk(klon, klev)
6360
6361
  INTEGER ig, l
6362
6363
  REAL f_star(klon, klev+1)
6364
  REAL detr_star(klon, klev)
6365
  REAL entr_star(klon, klev)
6366
  REAL zw2(klon, klev+1)
6367
  REAL linter(klon)
6368
  INTEGER lmix(klon)
6369
  INTEGER lmax(klon)
6370
  REAL zlevinter(klon)
6371
  REAL wa_moy(klon, klev+1)
6372
  REAL wmaxa(klon)
6373
  REAL ztv(klon, klev)
6374
  REAL ztva(klon, klev)
6375
  REAL nu(klon, klev)
6376
  ! real zmax0_sec(klon)
6377
  ! save zmax0_sec
6378
  REAL, SAVE, ALLOCATABLE :: zmax0_sec(:)
6379
  !$OMP THREADPRIVATE(zmax0_sec)
6380
  LOGICAL, SAVE :: first = .TRUE.
6381
  !$OMP THREADPRIVATE(first)
6382
6383
  IF (first) THEN
6384
    ALLOCATE (zmax0_sec(klon))
6385
    first = .FALSE.
6386
  END IF
6387
6388
  DO l = 1, nlay
6389
    DO ig = 1, ngrid
6390
      ztv(ig, l) = zh(ig, l)/zpspsk(ig, l)
6391
      ztv(ig, l) = ztv(ig, l)*(1.+retv*zo(ig,l))
6392
    END DO
6393
  END DO
6394
  DO l = 1, nlay - 2
6395
    DO ig = 1, ngrid
6396
      IF (ztv(ig,l)>ztv(ig,l+1) .AND. alim_star(ig,l)>1.E-10 .AND. &
6397
          zw2(ig,l)<1E-10) THEN
6398
        f_star(ig, l+1) = alim_star(ig, l)
6399
        ! test:calcul de dteta
6400
        zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* &
6401
          (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l))
6402
      ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+alim_star(ig, &
6403
          l))>1.E-10) THEN
6404
        ! estimation du detrainement a partir de la geometrie du pas
6405
        ! precedent
6406
        ! tests sur la definition du detr
6407
        nu(ig, l) = (nu_min+nu_max)/2.*(1.-(nu_max-nu_min)/(nu_max+nu_min)* &
6408
          tanh((((ztva(ig,l-1)-ztv(ig,l))/ztv(ig,l))/0.0005)))
6409
6410
        detr_star(ig, l) = rhobarz(ig, l)*sqrt(zw2(ig,l))/ &
6411
          (r_aspect*zmax0_sec(ig))* & ! s
6412
                                      ! /(r_aspect*zmax0(ig))*
6413
          (sqrt(nu(ig,l)*zlev(ig,l+1)/sqrt(zw2(ig,l)))-sqrt(nu(ig,l)*zlev(ig, &
6414
          l)/sqrt(zw2(ig,l))))
6415
        detr_star(ig, l) = detr_star(ig, l)/f0(ig)
6416
        IF ((detr_star(ig,l))>f_star(ig,l)) THEN
6417
          detr_star(ig, l) = f_star(ig, l)
6418
        END IF
6419
        entr_star(ig, l) = 0.9*detr_star(ig, l)
6420
        IF ((l<lentr(ig))) THEN
6421
          entr_star(ig, l) = 0.
6422
          ! detr_star(ig,l)=0.
6423
        END IF
6424
        ! print*,'ok detr_star'
6425
        ! prise en compte du detrainement dans le calcul du flux
6426
        f_star(ig, l+1) = f_star(ig, l) + alim_star(ig, l) + &
6427
          entr_star(ig, l) - detr_star(ig, l)
6428
        ! test sur le signe de f_star
6429
        IF ((f_star(ig,l+1)+detr_star(ig,l))>1.E-10) THEN
6430
          ! AM on melange Tl et qt du thermique
6431
          ztva(ig, l) = (f_star(ig,l)*ztva(ig,l-1)+(entr_star(ig, &
6432
            l)+alim_star(ig,l))*ztv(ig,l))/(f_star(ig,l+1)+detr_star(ig,l))
6433
          zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/(f_star(ig, &
6434
            l+1)+detr_star(ig,l)))**2 + 2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, &
6435
            l)*(zlev(ig,l+1)-zlev(ig,l))
6436
        END IF
6437
      END IF
6438
6439
      IF (zw2(ig,l+1)<0.) THEN
6440
        linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( &
6441
          ig,l))
6442
        zw2(ig, l+1) = 0.
6443
        ! print*,'linter=',linter(ig)
6444
      ELSE
6445
        wa_moy(ig, l+1) = sqrt(zw2(ig,l+1))
6446
      END IF
6447
      IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN
6448
        ! lmix est le niveau de la couche ou w (wa_moy) est maximum
6449
        lmix(ig) = l + 1
6450
        wmaxa(ig) = wa_moy(ig, l+1)
6451
      END IF
6452
    END DO
6453
  END DO
6454
  ! print*,'fin calcul zw2'
6455
6456
  ! Calcul de la couche correspondant a la hauteur du thermique
6457
  DO ig = 1, ngrid
6458
    lmax(ig) = lentr(ig)
6459
  END DO
6460
  DO ig = 1, ngrid
6461
    DO l = nlay, lentr(ig) + 1, -1
6462
      IF (zw2(ig,l)<=1.E-10) THEN
6463
        lmax(ig) = l - 1
6464
      END IF
6465
    END DO
6466
  END DO
6467
  ! pas de thermique si couche 1 stable
6468
  DO ig = 1, ngrid
6469
    IF (lmin(ig)>1) THEN
6470
      lmax(ig) = 1
6471
      lmin(ig) = 1
6472
      lentr(ig) = 1
6473
    END IF
6474
  END DO
6475
6476
  ! Determination de zw2 max
6477
  DO ig = 1, ngrid
6478
    wmax(ig) = 0.
6479
  END DO
6480
6481
  DO l = 1, nlay
6482
    DO ig = 1, ngrid
6483
      IF (l<=lmax(ig)) THEN
6484
        IF (zw2(ig,l)<0.) THEN
6485
          ! print*,'pb2 zw2<0'
6486
        END IF
6487
        zw2(ig, l) = sqrt(zw2(ig,l))
6488
        wmax(ig) = max(wmax(ig), zw2(ig,l))
6489
      ELSE
6490
        zw2(ig, l) = 0.
6491
      END IF
6492
    END DO
6493
  END DO
6494
6495
  ! Longueur caracteristique correspondant a la hauteur des thermiques.
6496
  DO ig = 1, ngrid
6497
    zmax(ig) = 0.
6498
    zlevinter(ig) = zlev(ig, 1)
6499
  END DO
6500
  DO ig = 1, ngrid
6501
    ! calcul de zlevinter
6502
    zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + &
6503
      zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))
6504
    ! pour le cas ou on prend tjs lmin=1
6505
    ! zmax(ig)=max(zmax(ig),zlevinter(ig)-zlev(ig,lmin(ig)))
6506
    zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,1))
6507
    zmax0_sec(ig) = zmax(ig)
6508
  END DO
6509
6510
  RETURN
6511
END SUBROUTINE fermeture_seche
6512
6513
END MODULE lmdz_thermcell_old