source: LMDZ6/branches/Ocean_skin/libf/dyn3dmem/vlspltgen_loc.F @ 5396

Last change on this file since 5396 was 4368, checked in by lguez, 2 years ago

Sync latest trunk changes to Ocean_skin

  • Property copyright set to
    Name of program: LMDZ
    Creation date: 1984
    Version: LMDZ5
    License: CeCILL version 2
    Holder: Laboratoire de m\'et\'eorologie dynamique, CNRS, UMR 8539
    See the license file in the root directory
File size: 14.4 KB
Line 
1!
2! $Header$
3!
4       SUBROUTINE vlspltgen_loc( q,pente_max,masse,w,pbaru,pbarv,
5     &                           pdt, p,pk,teta                 )
6     
7c
8c     Auteurs:   P.Le Van, F.Hourdin, F.Forget, F.Codron
9c
10c    ********************************************************************
11c          Shema  d'advection " pseudo amont " .
12c      + test sur humidite specifique: Q advecte< Qsat aval
13c                   (F. Codron, 10/99)
14c    ********************************************************************
15c     q,pbaru,pbarv,w sont des arguments d'entree  pour le s-pg ....
16c
17c     pente_max facteur de limitation des pentes: 2 en general
18c                                                0 pour un schema amont
19c     pbaru,pbarv,w flux de masse en u ,v ,w
20c     pdt pas de temps
21c
22c     teta temperature potentielle, p pression aux interfaces,
23c     pk exner au milieu des couches necessaire pour calculer Qsat
24c   --------------------------------------------------------------------
25      USE parallel_lmdz
26      USE mod_hallo
27      USE Write_Field_loc
28      USE VAMPIR
29      ! CRisi: on rajoute variables utiles d'infotrac 
30      USE infotrac, ONLY : nqtot, tracers, isoCheck
31      USE vlspltgen_mod
32      USE comconst_mod, ONLY: cpp
33      IMPLICIT NONE
34
35c
36      include "dimensions.h"
37      include "paramet.h"
38
39c
40c   Arguments:
41c   ----------
42      REAL masse(ijb_u:ije_u,llm),pente_max
43      REAL pbaru( ijb_u:ije_u,llm ),pbarv( ijb_v:ije_v,llm)
44      REAL q(ijb_u:ije_u,llm,nqtot)
45      REAL w(ijb_u:ije_u,llm),pdt
46      REAL p(ijb_u:ije_u,llmp1),teta(ijb_u:ije_u,llm)
47      REAL pk(ijb_u:ije_u,llm)
48c
49c      Local
50c   ---------
51c
52      INTEGER ij,l
53c
54      REAL zzpbar, zzw
55
56      REAL qmin,qmax
57      DATA qmin,qmax/0.,1.e33/
58
59c--pour rapport de melange saturant--
60
61      REAL rtt,retv,r2es,r3les,r3ies,r4les,r4ies,play
62      REAL ptarg,pdelarg,foeew,zdelta
63      REAL tempe(ijb_u:ije_u)
64      INTEGER ijb,ije,iq,iq2,ifils
65      LOGICAL, SAVE :: firstcall=.TRUE.
66!$OMP THREADPRIVATE(firstcall)
67      type(request),SAVE :: MyRequest1
68!$OMP THREADPRIVATE(MyRequest1)
69      type(request),SAVE :: MyRequest2
70!$OMP THREADPRIVATE(MyRequest2)
71c    fonction psat(T)
72
73       FOEEW ( PTARG,PDELARG ) = EXP (
74     *          (R3LES*(1.-PDELARG)+R3IES*PDELARG) * (PTARG-RTT)
75     * / (PTARG-(R4LES*(1.-PDELARG)+R4IES*PDELARG)) )
76
77        r2es  = 380.11733
78        r3les = 17.269
79        r3ies = 21.875
80        r4les = 35.86
81        r4ies = 7.66
82        retv = 0.6077667
83        rtt  = 273.16
84
85c Allocate variables depending on dynamic variable nqtot
86
87         IF (firstcall) THEN
88            firstcall=.FALSE.
89         END IF
90c-- Calcul de Qsat en chaque point
91c-- approximation: au milieu des couches play(l)=(p(l)+p(l+1))/2
92c   pour eviter une exponentielle.
93
94      call SetTag(MyRequest1,100)
95      call SetTag(MyRequest2,101)
96
97       
98        ijb=ij_begin-iip1
99        ije=ij_end+iip1
100        if (pole_nord) ijb=ij_begin
101        if (pole_sud) ije=ij_end
102       
103c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
104        DO l = 1, llm
105         DO ij = ijb, ije
106          tempe(ij) = teta(ij,l) * pk(ij,l) /cpp
107         ENDDO
108         DO ij = ijb, ije
109          zdelta = MAX( 0., SIGN(1., rtt - tempe(ij)) )
110          play   = 0.5*(p(ij,l)+p(ij,l+1))
111          qsat(ij,l) = MIN(0.5, r2es* FOEEW(tempe(ij),zdelta) / play )
112          qsat(ij,l) = qsat(ij,l) / ( 1. - retv * qsat(ij,l) )
113         ENDDO
114        ENDDO
115c$OMP END DO NOWAIT
116c      PRINT*,'Debut vlsplt version debug sans vlyqs'
117
118        zzpbar = 0.5 * pdt
119        zzw    = pdt
120
121      ijb=ij_begin
122      ije=ij_end
123      if (pole_nord) ijb=ijb+iip1
124      if (pole_sud)  ije=ije-iip1
125
126c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)       
127      DO l=1,llm
128        DO ij = ijb,ije
129            mu(ij,l)=pbaru(ij,l) * zzpbar
130         ENDDO
131      ENDDO
132c$OMP END DO NOWAIT
133     
134      ijb=ij_begin-iip1
135      ije=ij_end
136      if (pole_nord) ijb=ij_begin
137      if (pole_sud)  ije=ij_end-iip1
138
139c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
140      DO l=1,llm
141         DO ij=ijb,ije
142            mv(ij,l)=pbarv(ij,l) * zzpbar
143         ENDDO
144      ENDDO
145c$OMP END DO NOWAIT
146
147      ijb=ij_begin
148      ije=ij_end
149
150      DO iq=1,nqtot
151c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)     
152      DO l=1,llm
153         DO ij=ijb,ije
154            mw(ij,l,iq)=w(ij,l) * zzw
155         ENDDO
156      ENDDO
157c$OMP END DO NOWAIT
158      ENDDO
159
160      DO iq=1,nqtot 
161c$OMP MASTER
162      DO ij=ijb,ije
163         mw(ij,llm+1,iq)=0.
164      ENDDO
165c$OMP END MASTER
166      ENDDO
167
168c      CALL SCOPY(ijp1llm,q,1,zq,1)
169c      CALL SCOPY(ijp1llm,masse,1,zm,1)
170
171       ijb=ij_begin
172       ije=ij_end
173
174      DO iq=1,nqtot       
175c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
176        DO l=1,llm
177          zq(ijb:ije,l,iq)=q(ijb:ije,l,iq)
178          zm(ijb:ije,l,iq)=masse(ijb:ije,l)
179        ENDDO
180c$OMP END DO NOWAIT
181      ENDDO
182
183#ifdef DEBUG_IO     
184       CALL WriteField_u('mu',mu)
185       CALL WriteField_v('mv',mv)
186       CALL WriteField_u('mw',mw)
187       CALL WriteField_u('qsat',qsat)
188#endif
189
190      ! verif temporaire
191      ijb=ij_begin
192      ije=ij_end 
193      call check_isotopes(zq,ijb,ije,'vlspltgen_loc 191')
194
195c$OMP BARRIER           
196      DO iq=1,nqtot
197        ! CRisi: on ne boucle que sur les pères= ceux qui sont transportés directement par l'air
198        IF(tracers(iq)%parent /= 'air') CYCLE
199        !write(*,*) 'vlspltgen 192: iq,iadv=',iq,tracers(iq)%iadv
200#ifdef DEBUG_IO   
201        CALL WriteField_u('zq',zq(:,:,iq))
202        CALL WriteField_u('zm',zm(:,:,iq))
203#endif
204        SELECT CASE(tracers(iq)%iadv)
205          CASE(0); CYCLE
206          CASE(10)
207#ifdef _ADV_HALO       
208! CRisi: on ajoute les nombres de fils et tableaux des fils
209! On suppose qu'on ne peut advecter les fils que par le schéma 10. 
210          call vlx_loc(zq,pente_max,zm,mu,
211     &                     ij_begin,ij_begin+2*iip1-1,iq)
212          call vlx_loc(zq,pente_max,zm,mu,
213     &               ij_end-2*iip1+1,ij_end,iq)
214#else
215          call vlx_loc(zq,pente_max,zm,mu,
216     &                     ij_begin,ij_end,iq)
217#endif
218
219c$OMP MASTER
220          call VTb(VTHallo)
221c$OMP END MASTER
222          call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest1)
223          call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest1)
224! CRisi
225          do ifils=1,tracers(iq)%nqDescen
226            iq2=tracers(iq)%iqDescen(ifils)
227            call Register_Hallo_u(zq(:,:,iq2),llm,2,2,2,2,MyRequest1)
228            call Register_Hallo_u(zm(:,:,iq2),llm,1,1,1,1,MyRequest1)
229          enddo
230
231c$OMP MASTER
232          call VTe(VTHallo)
233c$OMP END MASTER
234          CASE(14)
235#ifdef _ADV_HALO           
236          call vlxqs_loc(zq,pente_max,zm,mu,
237     &                   qsat,ij_begin,ij_begin+2*iip1-1,iq)
238          call vlxqs_loc(zq,pente_max,zm,mu,
239     &                   qsat,ij_end-2*iip1+1,ij_end,iq)
240#else
241          call vlxqs_loc(zq,pente_max,zm,mu,
242     &                   qsat,ij_begin,ij_end,iq)
243#endif
244
245c$OMP MASTER
246          call VTb(VTHallo)
247c$OMP END MASTER
248
249          call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest1)
250          call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest1)
251          do ifils=1,tracers(iq)%nqDescen
252            iq2=tracers(iq)%iqDescen(ifils)
253            call Register_Hallo_u(zq(:,:,iq2),llm,2,2,2,2,MyRequest1)
254            call Register_Hallo_u(zm(:,:,iq2),llm,1,1,1,1,MyRequest1)
255          enddo
256
257c$OMP MASTER
258          call VTe(VTHallo)
259c$OMP END MASTER
260          CASE DEFAULT
261          stop 'vlspltgen_p : schema non parallelise'
262     
263        END SELECT
264     
265      enddo !DO iq=1,nqtot
266     
267     
268c$OMP BARRIER     
269c$OMP MASTER     
270      call VTb(VTHallo)
271c$OMP END MASTER
272
273      call SendRequest(MyRequest1)
274
275c$OMP MASTER
276      call VTe(VTHallo)
277c$OMP END MASTER       
278c$OMP BARRIER
279
280      ! verif temporaire
281      ijb=ij_begin-2*iip1
282      ije=ij_end+2*iip1 
283      if (pole_nord) ijb=ij_begin
284      if (pole_sud)  ije=ij_end 
285      call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 280')
286
287      do iq=1,nqtot
288        IF(tracers(iq)%parent /= 'air') CYCLE
289        !write(*,*) 'vlspltgen 279: iq=',iq
290
291        SELECT CASE(tracers(iq)%iadv)
292          CASE(0); CYCLE
293          CASE(10)
294#ifdef _ADV_HALLO
295          call vlx_loc(zq,pente_max,zm,mu,
296     &                 ij_begin+2*iip1,ij_end-2*iip1,iq)
297#endif       
298          CASE(14)
299#ifdef _ADV_HALLO
300          call vlxqs_loc(zq,pente_max,zm,mu,
301     &                    qsat,ij_begin+2*iip1,ij_end-2*iip1,iq)
302#endif   
303          CASE DEFAULT
304          stop 'vlspltgen_p : schema non parallelise'
305     
306        END SELECT
307     
308      enddo
309c$OMP BARRIER     
310c$OMP MASTER
311      call VTb(VTHallo)
312c$OMP END MASTER
313
314!      call WaitRecvRequest(MyRequest1)
315!      call WaitSendRequest(MyRequest1)
316c$OMP BARRIER
317       call WaitRequest(MyRequest1)
318
319
320c$OMP MASTER
321      call VTe(VTHallo)
322c$OMP END MASTER
323c$OMP BARRIER
324
325     
326      IF(isoCheck) THEN
327           call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 326')
328           ijb=ij_begin-2*iip1
329           ije=ij_end+2*iip1
330           if (pole_nord) ijb=ij_begin
331           if (pole_sud)  ije=ij_end
332           call check_isotopes(zq,ijb,ije,'vlspltgen_loc 336')
333      END IF
334
335      do iq = 1, nqtot
336       IF(tracers(iq)%parent /= 'air') CYCLE
337       !write(*,*) 'vlspltgen 321: iq=',iq
338#ifdef DEBUG_IO   
339       CALL WriteField_u('zq',zq(:,:,iq))
340       CALL WriteField_u('zm',zm(:,:,iq))
341#endif
342
343        SELECT CASE(tracers(iq)%iadv)
344          CASE(0); CYCLE
345          CASE(10); call   vly_loc(zq,pente_max,zm,mv,     iq)
346          CASE(14); call vlyqs_loc(zq,pente_max,zm,mv,qsat,iq)
347          CASE DEFAULT
348          stop 'vlspltgen_p : schema non parallelise'
349        END SELECT
350       
351       enddo
352
353      call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 357')
354
355      do iq = 1, nqtot
356       IF(tracers(iq)%parent /= 'air') CYCLE
357      !write(*,*) 'vlspltgen 349: iq=',iq
358#ifdef DEBUG_IO   
359       CALL WriteField_u('zq',zq(:,:,iq))
360       CALL WriteField_u('zm',zm(:,:,iq))
361#endif
362        SELECT CASE(tracers(iq)%iadv)
363          CASE(0); CYCLE
364          CASE(10,14)
365c$OMP BARRIER       
366#ifdef _ADV_HALLO
367          call vlz_loc(zq,pente_max,zm,mw,
368     &               ij_begin,ij_begin+2*iip1-1,iq)
369          call vlz_loc(zq,pente_max,zm,mw,
370     &               ij_end-2*iip1+1,ij_end,iq)
371#else
372          call vlz_loc(zq,pente_max,zm,mw,
373     &               ij_begin,ij_end,iq)
374#endif
375c$OMP BARRIER
376
377c$OMP MASTER
378          call VTb(VTHallo)
379c$OMP END MASTER
380
381          call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest2)
382          call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest2)
383          ! CRisi
384          do ifils=1,tracers(iq)%nqDescen
385            iq2=tracers(iq)%iqDescen(ifils)
386            call Register_Hallo_u(zq(:,:,iq2),llm,2,2,2,2,MyRequest2)
387            call Register_Hallo_u(zm(:,:,iq2),llm,1,1,1,1,MyRequest2)
388          enddo     
389c$OMP MASTER
390          call VTe(VTHallo)
391c$OMP END MASTER       
392c$OMP BARRIER
393          CASE DEFAULT
394          stop 'vlspltgen_p : schema non parallelise'
395     
396        END SELECT
397     
398      enddo
399c$OMP BARRIER     
400
401c$OMP MASTER       
402      call VTb(VTHallo)
403c$OMP END MASTER
404
405      call SendRequest(MyRequest2)
406
407c$OMP MASTER
408      call VTe(VTHallo)
409c$OMP END MASTER       
410
411
412      call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 429')
413
414c$OMP BARRIER
415      do iq=1,nqtot
416        IF(tracers(iq)%parent /= 'air') CYCLE
417      !write(*,*) 'vlspltgen 409: iq=',iq
418
419        SELECT CASE(tracers(iq)%iadv)
420          CASE(0); CYCLE
421          CASE(10,14)
422c$OMP BARRIER       
423
424#ifdef _ADV_HALLO
425          call vlz_loc(zq,pente_max,zm,mw,
426     &               ij_begin+2*iip1,ij_end-2*iip1,iq)
427#endif
428
429c$OMP BARRIER       
430          CASE DEFAULT
431          stop 'vlspltgen_p : schema non parallelise'
432        END SELECT
433     
434      enddo
435      !write(*,*) 'vlspltgen_loc 476'
436
437c$OMP BARRIER
438      !write(*,*) 'vlspltgen_loc 477'
439c$OMP MASTER
440      call VTb(VTHallo)
441c$OMP END MASTER
442
443!      call WaitRecvRequest(MyRequest2)
444!      call WaitSendRequest(MyRequest2)
445c$OMP BARRIER
446       CALL WaitRequest(MyRequest2)
447
448c$OMP MASTER
449      call VTe(VTHallo)
450c$OMP END MASTER
451c$OMP BARRIER
452
453
454      !write(*,*) 'vlspltgen_loc 494'
455      call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 461')
456
457      do iq=1,nqtot
458        IF(tracers(iq)%parent /= 'air') CYCLE
459      !write(*,*) 'vlspltgen 449: iq=',iq
460#ifdef DEBUG_IO   
461       CALL WriteField_u('zq',zq(:,:,iq))
462       CALL WriteField_u('zm',zm(:,:,iq))
463#endif
464        SELECT CASE(tracers(iq)%iadv)
465          CASE(0); CYCLE
466          CASE(10); call   vly_loc(zq,pente_max,zm,mv,     iq)
467          CASE(14); call vlyqs_loc(zq,pente_max,zm,mv,qsat,iq)
468          CASE DEFAULT; stop 'vlspltgen_p : schema non parallelise'
469        END SELECT
470       
471       enddo !do iq=1,nqtot
472
473      call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 493')
474
475      do iq=1,nqtot
476        IF(tracers(iq)%parent /= 'air') CYCLE
477      !write(*,*) 'vlspltgen 477: iq=',iq
478#ifdef DEBUG_IO   
479       CALL WriteField_u('zq',zq(:,:,iq))
480       CALL WriteField_u('zm',zm(:,:,iq))
481#endif
482        SELECT CASE(tracers(iq)%iadv)
483          CASE(0); CYCLE
484          CASE(10); call   vlx_loc(zq,pente_max,zm,mu,
485     &               ij_begin,ij_end,iq)
486          CASE(14); call vlxqs_loc(zq,pente_max,zm,mu,
487     &                 qsat, ij_begin,ij_end,iq)
488          CASE DEFAULT; stop 'vlspltgen_p : schema non parallelise'
489        END SELECT
490       
491       enddo !do iq=1,nqtot
492
493      !write(*,*) 'vlspltgen 550: apres derniere serie de call vlx'
494      call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 521')
495     
496      ijb=ij_begin
497      ije=ij_end
498      !write(*,*) 'vlspltgen_loc 557'
499c$OMP BARRIER     
500
501      !write(*,*) 'vlspltgen_loc 559' 
502      DO iq=1,nqtot
503       !write(*,*) 'vlspltgen_loc 561, iq=',iq 
504#ifdef DEBUG_IO   
505       CALL WriteField_u('zq',zq(:,:,iq))
506       CALL WriteField_u('zm',zm(:,:,iq))
507#endif
508c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)         
509        DO l=1,llm
510           DO ij=ijb,ije
511c             print *,'zq-->',ij,l,iq,zq(ij,l,iq)
512c             print *,'q-->',ij,l,iq,q(ij,l,iq)
513             q(ij,l,iq)=zq(ij,l,iq)
514           ENDDO
515        ENDDO
516c$OMP END DO NOWAIT   
517      !write(*,*) 'vlspltgen_loc 575'     
518
519c$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
520        DO l=1,llm
521           DO ij=ijb,ije-iip1+1,iip1
522              q(ij+iim,l,iq)=q(ij,l,iq)
523           ENDDO
524        ENDDO
525c$OMP END DO NOWAIT 
526      !write(*,*) 'vlspltgen_loc 583' 
527      ENDDO !DO iq=1,nqtot
528       
529      call check_isotopes(q,ij_begin,ij_end,'vlspltgen_loc 557')
530
531c$OMP BARRIER
532
533cc$OMP MASTER     
534c      call WaitSendRequest(MyRequest1)
535c      call WaitSendRequest(MyRequest2)
536cc$OMP END MASTER
537cc$OMP BARRIER
538
539      !write(*,*) 'vlspltgen 597: sortie' 
540      RETURN
541      END
Note: See TracBrowser for help on using the repository browser.