source: LMDZ6/branches/Amaury_dev/libf/dyn3d_common/advx.f90 @ 5423

Last change on this file since 5423 was 5159, checked in by abarral, 5 months ago

Put dimensions.h and paramet.h into modules

  • 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
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 10.8 KB
RevLine 
[5099]1
[524]2! $Header$
[5099]3
[5105]4SUBROUTINE  advx(limit,dtx,pbaru,sm,s0, &
5        sx,sy,sz,lati,latf)
[5159]6  USE lmdz_dimensions, ONLY: iim, jjm, llm, ndm
7  USE lmdz_paramet
[5105]8  IMPLICIT NONE
[524]9
[5105]10  !CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
11  !                                                                C
12  !  first-order moments (FOM) advection of tracer in X direction  C
13  !                                                                C
14  !  Source : Pascal Simon (Meteo,CNRM)                            C
15  !  Adaptation : A.Armengaud (LGGE) juin 94                       C
16  !                                                                C
17  !  limit,dtx,pbaru,pbarv,sm,s0,sx,sy,sz                       C
18  !  sont des arguments d'entree pour le s-pg...                   C
19  !                                                                C
20  !  sm,s0,sx,sy,sz                                                C
21  !  sont les arguments de sortie pour le s-pg                     C
22  !                                                                C
23  !CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
[5159]24
[5105]25  !  parametres principaux du modele
26  !
[524]27
[5159]28
29
[5105]30  !  Arguments :
31  !  -----------
32  !  dtx : frequence fictive d'appel du transport
33  !  pbaru, pbarv : flux de masse en x et y en Pa.m2.s-1
[524]34
[5105]35   INTEGER :: ntra
36   PARAMETER (ntra = 1)
[524]37
[5105]38  ! ATTENTION partout ou on trouve ntra, insertion de boucle
39        ! possible dans l'avenir.
[524]40
[5105]41  REAL :: dtx
42  REAL :: pbaru ( iip1,jjp1,llm )
[524]43
[5105]44  !  moments: SM  total mass in each grid box
45        ! S0  mass of tracer in each grid box
46        ! Si  1rst order moment in i direction
[5159]47
[5105]48  REAL :: SM(iip1,jjp1,llm),S0(iip1,jjp1,llm,ntra)
49  REAL :: sx(iip1,jjp1,llm,ntra) &
50        ,sy(iip1,jjp1,llm,ntra)
51  REAL :: sz(iip1,jjp1,llm,ntra)
[524]52
[5105]53  !  Local :
54  !  -------
[524]55
[5105]56  !  mass fluxes across the boundaries (UGRI,VGRI,WGRI)
57  !  mass fluxes in kg
58  !  declaration :
[524]59
[5105]60  REAL :: UGRI(iip1,jjp1,llm)
[524]61
[5105]62  !  Rem : VGRI et WGRI ne sont pas utilises dans
63  !  cette SUBROUTINE ( advection en x uniquement )
[5159]64
[5105]65  !  Ti are the moments for the current latitude and level
[5159]66
[5105]67  REAL :: TM(iim)
68  REAL :: T0(iim,ntra),TX(iim,ntra)
69  REAL :: TY(iim,ntra),TZ(iim,ntra)
70  REAL :: TEMPTM                ! just a temporary variable
[5159]71
[5105]72  !  the moments F are similarly defined and used as temporary
73  !  storage for portions of the grid boxes in transit
[5159]74
[5105]75  REAL :: FM(iim)
76  REAL :: F0(iim,ntra),FX(iim,ntra)
77  REAL :: FY(iim,ntra),FZ(iim,ntra)
[5159]78
[5105]79  !  work arrays
[5159]80
[5105]81  REAL :: ALF(iim),ALF1(iim),ALFQ(iim),ALF1Q(iim)
[5159]82
[5105]83  REAL :: SMNEW(iim),UEXT(iim)
[5159]84
[5105]85  REAL :: sqi,sqf
[524]86
[5105]87  LOGICAL :: LIMIT
88  INTEGER :: NUM(jjp1),LONK,NUMK
89  INTEGER :: lon,lati,latf,niv
90  INTEGER :: i,i2,i3,j,jv,l,k,itrac
[524]91
[5105]92  lon = iim
93  niv = llm
[524]94
[5105]95  ! *** Test de passage d'arguments ******
[524]96
97
[5105]98  !  -------------------------------------
99  DO j = 1,jjp1
100     NUM(j) = 1
101  END DO
102  sqi = 0.
103  sqf = 0.
[524]104
[5105]105  DO l = 1,llm
106     DO j = 1,jjp1
107        DO i = 1,iim
108  !IM 240305            sqi = sqi + S0(i,j,l,9)
109           sqi = sqi + S0(i,j,l,ntra)
110        ENDDO
111     ENDDO
112  ENDDO
113  PRINT*,'-------- DIAG DANS ADVX - ENTREE ---------'
114  PRINT*,'sqi=',sqi
[524]115
116
[5105]117  !  Interface : adaptation nouveau modele
118  !  -------------------------------------
[5159]119
[5105]120  !  ---------------------------------------------------------
121  !  Conversion des flux de masses en kg/s
122  !  pbaru est en N/s d'ou :
123  !  ugri est en kg/s
[524]124
[5105]125  DO l = 1,llm
126     DO j = 1,jjm+1
127        DO i = 1,iip1
128         ! ugri (i,j,llm+1-l) = pbaru (i,j,l) * ( dsig(l) / g )
129         ugri (i,j,llm+1-l) = pbaru (i,j,l)
130  END DO
131  END DO
132  END DO
[524]133
134
[5105]135  !  ---------------------------------------------------------
136  !  ---------------------------------------------------------
137  !  ---------------------------------------------------------
138
139  !  start here
[5159]140
[5105]141  !  boucle principale sur les niveaux et les latitudes
[5159]142
[5105]143  DO L=1,NIV
144  DO K=lati,latf
[5159]145
[5105]146  !  initialisation
[5159]147
[5105]148  !  program assumes periodic boundaries in X
[5159]149
[5105]150  DO I=2,LON
151     SMNEW(I)=SM(I,K,L)+(UGRI(I-1,K,L)-UGRI(I,K,L))*DTX
152  END DO
153  SMNEW(1)=SM(1,K,L)+(UGRI(LON,K,L)-UGRI(1,K,L))*DTX
[5159]154
[5105]155  !  modifications for extended polar zones
[5159]156
[5105]157  NUMK=NUM(K)
158  LONK=LON/NUMK
[5159]159
[5105]160  IF(NUMK>1) THEN
[5159]161
[5105]162  DO I=1,LON
163     TM(I)=0.
164  END DO
165  DO JV=1,NTRA
166  DO I=1,LON
167     T0(I,JV)=0.
168     TX(I,JV)=0.
169     TY(I,JV)=0.
170     TZ(I,JV)=0.
171  END DO
172  END DO
[5159]173
[5105]174  DO I2=1,NUMK
[5159]175
[5105]176     DO I=1,LONK
177        I3=(I-1)*NUMK+I2
178        TM(I)=TM(I)+SM(I3,K,L)
179        ALF(I)=SM(I3,K,L)/TM(I)
180        ALF1(I)=1.-ALF(I)
181  END DO
[5159]182
[5105]183     DO  JV=1,NTRA
184     DO  I=1,LONK
185        I3=(I-1)*NUMK+I2
186        TEMPTM=-ALF(I)*T0(I,JV)+ALF1(I) &
187              *S0(I3,K,L,JV)
188        T0(I,JV)=T0(I,JV)+S0(I3,K,L,JV)
189        TX(I,JV)=ALF(I)  *sx(I3,K,L,JV)+ &
190              ALF1(I)*TX(I,JV) +3.*TEMPTM
191        TY(I,JV)=TY(I,JV)+sy(I3,K,L,JV)
192        TZ(I,JV)=TZ(I,JV)+sz(I3,K,L,JV)
193     ENDDO
194     ENDDO
[5159]195
[5105]196  END DO
[5159]197
[5105]198  ELSE
[5159]199
[5105]200  DO I=1,LON
201     TM(I)=SM(I,K,L)
202  END DO
203  DO JV=1,NTRA
204  DO I=1,LON
205     T0(I,JV)=S0(I,K,L,JV)
206     TX(I,JV)=sx(I,K,L,JV)
207     TY(I,JV)=sy(I,K,L,JV)
208     TZ(I,JV)=sz(I,K,L,JV)
209  END DO
210  END DO
[5159]211
[5105]212  ENDIF
[5159]213
[5105]214  DO I=1,LONK
215     UEXT(I)=UGRI(I*NUMK,K,L)
216  END DO
[5159]217
[5105]218  !  place limits on appropriate moments before transport
219  !  (if flux-limiting is to be applied)
[5159]220
[5105]221  IF(.NOT.LIMIT) GO TO 13
[5159]222
[5105]223  DO JV=1,NTRA
224  DO I=1,LONK
225    TX(I,JV)=SIGN(AMIN1(AMAX1(T0(I,JV),0.),ABS(TX(I,JV))),TX(I,JV))
226  END DO
227  END DO
[5159]228
[524]229 13   CONTINUE
[5159]230
[5105]231  !  calculate flux and moments between adjacent boxes
232  !  1- create temporary moments/masses for partial boxes in transit
233  !  2- reajusts moments remaining in the box
[5159]234
[5105]235  !  flux from IP to I if U(I).lt.0
[5159]236
[5105]237  DO I=1,LONK-1
238     IF(UEXT(I)<0.) THEN
239       FM(I)=-UEXT(I)*DTX
240       ALF(I)=FM(I)/TM(I+1)
241       TM(I+1)=TM(I+1)-FM(I)
242     ENDIF
243  END DO
[5159]244
[5105]245  I=LONK
246  IF(UEXT(I)<0.) THEN
247    FM(I)=-UEXT(I)*DTX
248    ALF(I)=FM(I)/TM(1)
249    TM(1)=TM(1)-FM(I)
250  ENDIF
[5159]251
[5105]252  !  flux from I to IP if U(I).gt.0
[5159]253
[5105]254  DO I=1,LONK
255     IF(UEXT(I)>=0.) THEN
256       FM(I)=UEXT(I)*DTX
257       ALF(I)=FM(I)/TM(I)
258       TM(I)=TM(I)-FM(I)
259     ENDIF
260  END DO
[5159]261
[5105]262  DO I=1,LONK
263     ALFQ(I)=ALF(I)*ALF(I)
264     ALF1(I)=1.-ALF(I)
265     ALF1Q(I)=ALF1(I)*ALF1(I)
266  END DO
[5159]267
[5105]268  DO JV=1,NTRA
269  DO I=1,LONK-1
[5159]270
[5105]271     IF(UEXT(I)<0.) THEN
[5159]272
[5105]273       F0(I,JV)=ALF (I)* ( T0(I+1,JV)-ALF1(I)*TX(I+1,JV) )
274       FX(I,JV)=ALFQ(I)*TX(I+1,JV)
275       FY(I,JV)=ALF (I)*TY(I+1,JV)
276       FZ(I,JV)=ALF (I)*TZ(I+1,JV)
[5159]277
[5105]278       T0(I+1,JV)=T0(I+1,JV)-F0(I,JV)
279       TX(I+1,JV)=ALF1Q(I)*TX(I+1,JV)
280       TY(I+1,JV)=TY(I+1,JV)-FY(I,JV)
281       TZ(I+1,JV)=TZ(I+1,JV)-FZ(I,JV)
[5159]282
[5105]283     ENDIF
[5159]284
[5105]285  END DO
286  END DO
[5159]287
[5105]288  I=LONK
289  IF(UEXT(I)<0.) THEN
[5159]290
[5105]291    DO JV=1,NTRA
[5159]292
[5105]293       F0 (I,JV)=ALF (I)* ( T0(1,JV)-ALF1(I)*TX(1,JV) )
294       FX (I,JV)=ALFQ(I)*TX(1,JV)
295       FY (I,JV)=ALF (I)*TY(1,JV)
296       FZ (I,JV)=ALF (I)*TZ(1,JV)
[5159]297
[5105]298       T0(1,JV)=T0(1,JV)-F0(I,JV)
299       TX(1,JV)=ALF1Q(I)*TX(1,JV)
300       TY(1,JV)=TY(1,JV)-FY(I,JV)
301       TZ(1,JV)=TZ(1,JV)-FZ(I,JV)
[5159]302
[5105]303  END DO
[5159]304
[5105]305  ENDIF
[5159]306
[5105]307  DO JV=1,NTRA
308  DO I=1,LONK
[5159]309
[5105]310     IF(UEXT(I)>=0.) THEN
[5159]311
[5105]312       F0(I,JV)=ALF (I)* ( T0(I,JV)+ALF1(I)*TX(I,JV) )
313       FX(I,JV)=ALFQ(I)*TX(I,JV)
314       FY(I,JV)=ALF (I)*TY(I,JV)
315       FZ(I,JV)=ALF (I)*TZ(I,JV)
[5159]316
[5105]317       T0(I,JV)=T0(I,JV)-F0(I,JV)
318       TX(I,JV)=ALF1Q(I)*TX(I,JV)
319       TY(I,JV)=TY(I,JV)-FY(I,JV)
320       TZ(I,JV)=TZ(I,JV)-FZ(I,JV)
[5159]321
[5105]322     ENDIF
[5159]323
[5105]324  END DO
325  END DO
[5159]326
[5105]327  !  puts the temporary moments Fi into appropriate neighboring boxes
[5159]328
[5105]329  DO I=1,LONK
330     IF(UEXT(I)<0.) THEN
331       TM(I)=TM(I)+FM(I)
332       ALF(I)=FM(I)/TM(I)
333     ENDIF
334  END DO
[5159]335
[5105]336  DO I=1,LONK-1
337     IF(UEXT(I)>=0.) THEN
338       TM(I+1)=TM(I+1)+FM(I)
339       ALF(I)=FM(I)/TM(I+1)
340     ENDIF
341  END DO
[5159]342
[5105]343  I=LONK
344  IF(UEXT(I)>=0.) THEN
345    TM(1)=TM(1)+FM(I)
346    ALF(I)=FM(I)/TM(1)
347  ENDIF
[5159]348
[5105]349  DO I=1,LONK
350     ALF1(I)=1.-ALF(I)
351  END DO
[5159]352
[5105]353  DO JV=1,NTRA
354  DO I=1,LONK
[5159]355
[5105]356     IF(UEXT(I)<0.) THEN
[5159]357
[5105]358       TEMPTM=-ALF(I)*T0(I,JV)+ALF1(I)*F0(I,JV)
359       T0(I,JV)=T0(I,JV)+F0(I,JV)
360       TX(I,JV)=ALF(I)*FX(I,JV)+ALF1(I)*TX(I,JV)+3.*TEMPTM
361       TY(I,JV)=TY(I,JV)+FY(I,JV)
362       TZ(I,JV)=TZ(I,JV)+FZ(I,JV)
[5159]363
[5105]364     ENDIF
[5159]365
[5105]366  END DO
367  END DO
[5159]368
[5105]369  DO JV=1,NTRA
370  DO I=1,LONK-1
[5159]371
[5105]372     IF(UEXT(I)>=0.) THEN
[5159]373
[5105]374       TEMPTM=ALF(I)*T0(I+1,JV)-ALF1(I)*F0(I,JV)
375       T0(I+1,JV)=T0(I+1,JV)+F0(I,JV)
376       TX(I+1,JV)=ALF(I)*FX(I,JV)+ALF1(I)*TX(I+1,JV)+3.*TEMPTM
377       TY(I+1,JV)=TY(I+1,JV)+FY(I,JV)
378       TZ(I+1,JV)=TZ(I+1,JV)+FZ(I,JV)
[5159]379
[5105]380     ENDIF
[5159]381
[5105]382  END DO
383  END DO
[5159]384
[5105]385  I=LONK
386  IF(UEXT(I)>=0.) THEN
387    DO JV=1,NTRA
388       TEMPTM=ALF(I)*T0(1,JV)-ALF1(I)*F0(I,JV)
389       T0(1,JV)=T0(1,JV)+F0(I,JV)
390       TX(1,JV)=ALF(I)*FX(I,JV)+ALF1(I)*TX(1,JV)+3.*TEMPTM
391       TY(1,JV)=TY(1,JV)+FY(I,JV)
392       TZ(1,JV)=TZ(1,JV)+FZ(I,JV)
393  END DO
394  ENDIF
[5159]395
[5105]396  !  retour aux mailles d'origine (passage des Tij aux Sij)
[5159]397
[5105]398  IF(NUMK>1) THEN
[5159]399
[5105]400  DO I2=1,NUMK
[5159]401
[5105]402     DO I=1,LONK
[5159]403
[5105]404        I3=I2+(I-1)*NUMK
405        SM(I3,K,L)=SMNEW(I3)
406        ALF(I)=SMNEW(I3)/TM(I)
407        TM(I)=TM(I)-SMNEW(I3)
[5159]408
[5105]409        ALFQ(I)=ALF(I)*ALF(I)
410        ALF1(I)=1.-ALF(I)
411        ALF1Q(I)=ALF1(I)*ALF1(I)
[5159]412
[5105]413  END DO
414  END DO
[5159]415
[5105]416     DO  JV=1,NTRA
417     DO  I=1,LONK
[5159]418
[5105]419        I3=I2+(I-1)*NUMK
420        S0(I3,K,L,JV)=ALF (I) &
421              * (T0(I,JV)-ALF1(I)*TX(I,JV))
422        sx(I3,K,L,JV)=ALFQ(I)*TX(I,JV)
423        sy(I3,K,L,JV)=ALF (I)*TY(I,JV)
424        sz(I3,K,L,JV)=ALF (I)*TZ(I,JV)
[5159]425
[5105]426  !   reajusts moments remaining in the box
[5159]427
[5105]428        T0(I,JV)=T0(I,JV)-S0(I3,K,L,JV)
429        TX(I,JV)=ALF1Q(I)*TX(I,JV)
430        TY(I,JV)=TY(I,JV)-sy(I3,K,L,JV)
431        TZ(I,JV)=TZ(I,JV)-sz(I3,K,L,JV)
432      ENDDO
433      ENDDO
[5159]434
435
[5105]436  ELSE
[5159]437
[5105]438  DO I=1,LON
439     SM(I,K,L)=TM(I)
440  END DO
441  DO JV=1,NTRA
442  DO I=1,LON
443     S0(I,K,L,JV)=T0(I,JV)
444     sx(I,K,L,JV)=TX(I,JV)
445     sy(I,K,L,JV)=TY(I,JV)
446     sz(I,K,L,JV)=TZ(I,JV)
447  END DO
448  END DO
[5159]449
[5105]450  ENDIF
[5159]451
[5105]452  END DO
453  END DO
[5159]454
[5105]455  ! ----------- AA Test en fin de ADVX ------ Controle des S*
456  ! OK
457  !  DO 9998 l = 1, llm
458  !  DO 9998 j = 1, jjp1
459  !  DO 9998 i = 1, iip1
460  !     IF (S0(i,j,l,ntra).lt.0..and.LIMIT) THEN
461  !        PRINT*, '-------------------'
462  !        PRINT*, 'En fin de ADVX'
463  !        PRINT*,'SM(',i,j,l,')=',SM(i,j,l)
464  !        PRINT*,'S0(',i,j,l,')=',S0(i,j,l,ntra)
465  !        PRINT*, 'sx(',i,j,l,')=',sx(i,j,l,ntra)
466  !        PRINT*, 'sy(',i,j,l,')=',sy(i,j,l,ntra)
467  !        PRINT*, 'sz(',i,j,l,')=',sz(i,j,l,ntra)
468  !        WRITE (*,*) 'On arrete !! - pbl en fin de ADVX1'
469  !c            STOP
470  !     ENDIF
471  ! 9998 CONTINUE
[5159]472
[5105]473  ! ---------- bouclage cyclique
474  DO itrac=1,ntra
475  DO l = 1,llm
476    DO j = lati,latf
477       SM(iip1,j,l) = SM(1,j,l)
478       S0(iip1,j,l,itrac) = S0(1,j,l,itrac)
479       sx(iip1,j,l,itrac) = sx(1,j,l,itrac)
480       sy(iip1,j,l,itrac) = sy(1,j,l,itrac)
481       sz(iip1,j,l,itrac) = sz(1,j,l,itrac)
482    END DO
483  END DO
484  ENDDO
[524]485
[5105]486  ! ----------- qqtite totale de traceur dans tte l'atmosphere
487  DO l = 1, llm
488    DO j = 1, jjp1
489      DO i = 1, iim
490  !IM 240405          sqf = sqf + S0(i,j,l,9)
491         sqf = sqf + S0(i,j,l,ntra)
[524]492      END DO
[5105]493    END DO
494  END DO
[5159]495
[5105]496  PRINT*,'------ DIAG DANS ADVX - SORTIE -----'
497  PRINT*,'sqf=',sqf
498  !-------------
[524]499
[5105]500  RETURN
501END SUBROUTINE advx
502!_________________________________________________________________
503!_________________________________________________________________
Note: See TracBrowser for help on using the repository browser.