source: trunk/libf/dyn3d/calfis.F @ 16

Last change on this file since 16 was 6, checked in by slebonnois, 14 years ago

cf commit_v6.log :

  • manipulation traceurs
  • homogeneisation .def
  • bilan_dyn
  • etats initiaux start.nc
  • appels specifiques pour physique
File size: 20.2 KB
Line 
1!
2! $Id: calfis.F 1407 2010-07-07 10:31:52Z fairhead $
3!
4C
5C
6      SUBROUTINE calfis(lafin,
7     $                  jD_cur, jH_cur,
8     $                  pucov,
9     $                  pvcov,
10     $                  pteta,
11     $                  pq,
12     $                  pmasse,
13     $                  pps,
14     $                  pp,
15     $                  ppk,
16     $                  pphis,
17     $                  pphi,
18     $                  pducov,
19     $                  pdvcov,
20     $                  pdteta,
21     $                  pdq,
22     $                  flxw,
23     $                  clesphy0,
24     $                  pdufi,
25     $                  pdvfi,
26     $                  pdhfi,
27     $                  pdqfi,
28     $                  pdpsfi)
29c
30c    Auteur :  P. Le Van, F. Hourdin
31c   .........
32      USE infotrac
33      USE control_mod
34 
35
36      IMPLICIT NONE
37c=======================================================================
38c
39c   1. rearrangement des tableaux et transformation
40c      variables dynamiques  >  variables physiques
41c   2. calcul des termes physiques
42c   3. retransformation des tendances physiques en tendances dynamiques
43c
44c   remarques:
45c   ----------
46c
47c    - les vents sont donnes dans la physique par leurs composantes
48c      naturelles.
49c    - la variable thermodynamique de la physique est une variable
50c      intensive :   T
51c      pour la dynamique on prend    T * ( preff / p(l) ) **kappa
52c    - les deux seules variables dependant de la geometrie necessaires
53c      pour la physique sont la latitude pour le rayonnement et
54c      l'aire de la maille quand on veut integrer une grandeur
55c      horizontalement.
56c    - les points de la physique sont les points scalaires de la
57c      la dynamique; numerotation:
58c          1 pour le pole nord
59c          (jjm-1)*iim pour l'interieur du domaine
60c          ngridmx pour le pole sud
61c      ---> ngridmx=2+(jjm-1)*iim
62c
63c     Input :
64c     -------
65c       pucov           covariant zonal velocity
66c       pvcov           covariant meridional velocity
67c       pteta           potential temperature
68c       pps             surface pressure
69c       pmasse          masse d'air dans chaque maille
70c       pts             surface temperature  (K)
71c       callrad         clef d'appel au rayonnement
72c
73c    Output :
74c    --------
75c        pdufi          tendency for the natural zonal velocity (ms-1)
76c        pdvfi          tendency for the natural meridional velocity
77c        pdhfi          tendency for the potential temperature (K/s)
78c        pdtsfi         tendency for the surface temperature
79c
80c        pdtrad         radiative tendencies  \  both input
81c        pfluxrad       radiative fluxes      /  and output
82c
83c=======================================================================
84c
85c-----------------------------------------------------------------------
86c
87c    0.  Declarations :
88c    ------------------
89
90#include "dimensions.h"
91#include "paramet.h"
92#include "temps.h"
93
94      INTEGER ngridmx
95      PARAMETER( ngridmx = 2+(jjm-1)*iim - 1/jjm   )
96
97#include "comconst.h"
98#include "comvert.h"
99#include "comgeom2.h"
100#include "iniprint.h"
101
102c    Arguments :
103c    -----------
104      LOGICAL  lafin
105
106
107      REAL pvcov(iip1,jjm,llm)
108      REAL pucov(iip1,jjp1,llm)
109      REAL pteta(iip1,jjp1,llm)
110      REAL pmasse(iip1,jjp1,llm)
111      REAL pq(iip1,jjp1,llm,nqtot)
112      REAL pphis(iip1,jjp1)
113      REAL pphi(iip1,jjp1,llm)
114c
115      REAL pdvcov(iip1,jjm,llm)
116      REAL pducov(iip1,jjp1,llm)
117      REAL pdteta(iip1,jjp1,llm)
118! commentaire SL: pdq ne sert que pour le calcul de pcvgq,
119! qui lui meme ne sert a rien dans la routine telle qu'elle est
120! ecrite, et que j'ai donc commente....
121      REAL pdq(iip1,jjp1,llm,nqtot)
122c
123      REAL pps(iip1,jjp1)
124      REAL pp(iip1,jjp1,llmp1)
125      REAL ppk(iip1,jjp1,llm)
126c
127c TENDENCIES in */s
128      REAL pdvfi(iip1,jjm,llm)
129      REAL pdufi(iip1,jjp1,llm)
130      REAL pdhfi(iip1,jjp1,llm)
131      REAL pdqfi(iip1,jjp1,llm,nqtot)
132      REAL pdpsfi(iip1,jjp1)
133
134      INTEGER        longcles
135      PARAMETER    ( longcles = 20 )
136      REAL clesphy0( longcles )
137
138
139c    Local variables :
140c    -----------------
141
142      INTEGER i,j,l,ig0,ig,iq,iiq
143      REAL zpsrf(ngridmx)
144      REAL zplev(ngridmx,llm+1),zplay(ngridmx,llm)
145      REAL zphi(ngridmx,llm),zphis(ngridmx)
146c
147      REAL zufi(ngridmx,llm), zvfi(ngridmx,llm)
148      REAL ztfi(ngridmx,llm),zqfi(ngridmx,llm,nqtot)
149! ADAPTATION GCM POUR CP(T)
150      REAL zteta(ngridmx,llm)
151      REAL zpk(ngridmx,llm)
152c
153! RQ SL 13/10/10:
154! Ces calculs ne servent pas.
155! Si necessaire, decommenter ces variables et les calculs...
156!      REAL pcvgu(ngridmx,llm), pcvgv(ngridmx,llm)
157!      REAL pcvgt(ngridmx,llm), pcvgq(ngridmx,llm,2)
158c
159      REAL zdufi(ngridmx,llm),zdvfi(ngridmx,llm)
160      REAL zdtfi(ngridmx,llm),zdqfi(ngridmx,llm,nqtot)
161      REAL zdpsrf(ngridmx)
162c
163      REAL zdufic(ngridmx,llm),zdvfic(ngridmx,llm)
164      REAL zdtfic(ngridmx,llm),zdqfic(ngridmx,llm,nqtot)
165      REAL jH_cur_split,zdt_split
166      LOGICAL debut_split,lafin_split
167      INTEGER isplit
168
169      REAL zsin(iim),zcos(iim),z1(iim)
170      REAL zsinbis(iim),zcosbis(iim),z1bis(iim)
171      REAL unskap, pksurcp
172c
173cIM diagnostique PVteta, Amip2
174      INTEGER ntetaSTD
175      PARAMETER(ntetaSTD=3)
176      REAL rtetaSTD(ntetaSTD)
177      DATA rtetaSTD/350., 380., 405./
178      REAL PVteta(ngridmx,ntetaSTD)
179c
180      REAL flxw(iip1,jjp1,llm)  ! Flux de masse verticale sur la grille dynamique
181      REAL flxwfi(ngridmx,llm)  ! Flux de masse verticale sur la grille physiq
182c
183     
184      REAL SSUM
185
186      LOGICAL firstcal, debut
187      DATA firstcal/.true./
188      SAVE firstcal,debut
189!      REAL rdayvrai
190      REAL, intent(in):: jD_cur, jH_cur
191c
192c-----------------------------------------------------------------------
193c
194c    1. Initialisations :
195c    --------------------
196c
197c
198      IF ( firstcal )  THEN
199        debut = .TRUE.
200        IF (ngridmx.NE.2+(jjm-1)*iim) THEN
201         write(lunout,*) 'STOP dans calfis'
202         write(lunout,*)
203     &   'La dimension ngridmx doit etre egale a 2 + (jjm-1)*iim'
204         write(lunout,*) '  ngridmx  jjm   iim   '
205         write(lunout,*) ngridmx,jjm,iim
206         STOP
207        ENDIF
208      ELSE
209        debut = .FALSE.
210      ENDIF ! of IF (firstcal)
211
212c
213c
214c-----------------------------------------------------------------------
215c   40. transformation des variables dynamiques en variables physiques:
216c   ---------------------------------------------------------------
217
218c   41. pressions au sol (en Pascals)
219c   ----------------------------------
220
221       
222      zpsrf(1) = pps(1,1)
223
224      ig0  = 2
225      DO j = 2,jjm
226         CALL SCOPY( iim,pps(1,j),1,zpsrf(ig0), 1 )
227         ig0 = ig0+iim
228      ENDDO
229
230      zpsrf(ngridmx) = pps(1,jjp1)
231
232
233c   42. pression intercouches et fonction d'Exner:
234c
235c   -----------------------------------------------------------------
236c     .... zplev  definis aux (llm +1) interfaces des couches  ....
237c     .... zplay  definis aux (  llm )    milieux des couches  ....
238c   -----------------------------------------------------------------
239
240c    ...    Exner = cp * ( p(l) / preff ) ** kappa     ....
241c
242       unskap   = 1./ kappa
243c
244! ADAPTATION GCM POUR CP(T)
245      DO l = 1, llm
246        zpk(   1,l ) = ppk(1,1,l)
247        zteta( 1,l ) = pteta(1,1,l)
248        zplev( 1,l ) = pp(1,1,l)
249        ig0 = 2
250          DO j = 2, jjm
251             DO i =1, iim
252              zpk(   ig0,l ) = ppk(i,j,l)
253              zteta( ig0,l ) = pteta(i,j,l)
254              zplev( ig0,l ) = pp(i,j,l)
255              ig0 = ig0 +1
256             ENDDO
257          ENDDO
258        zpk(   ngridmx,l ) = ppk(1,jjp1,l)
259        zteta( ngridmx,l ) = pteta(1,jjp1,l)
260        zplev( ngridmx,l ) = pp(1,jjp1,l)
261      ENDDO
262        zplev( 1,llmp1 ) = pp(1,1,llmp1)
263        ig0 = 2
264          DO j = 2, jjm
265             DO i =1, iim
266              zplev( ig0,llmp1 ) = pp(i,j,llmp1)
267              ig0 = ig0 +1
268             ENDDO
269          ENDDO
270        zplev( ngridmx,llmp1 ) = pp(1,jjp1,llmp1)
271c
272c
273
274c   43. temperature naturelle (en K) et pressions milieux couches .
275c   ---------------------------------------------------------------
276
277! ADAPTATION GCM POUR CP(T)
278         call tpot2t(ngridmx*llm,zteta,ztfi,zpk)
279
280      DO l=1,llm
281
282         pksurcp     =  ppk(1,1,l) / cpp
283         zplay(1,l)  =  preff * pksurcp ** unskap
284!         pcvgt(1,l)  =  pdteta(1,1,l) * pksurcp / pmasse(1,1,l)
285         ig0         = 2
286
287         DO j = 2, jjm
288            DO i = 1, iim
289              pksurcp        = ppk(i,j,l) / cpp
290              zplay(ig0,l)   = preff * pksurcp ** unskap
291!              pcvgt(ig0,l)   = pdteta(i,j,l) * pksurcp / pmasse(i,j,l)
292              ig0            = ig0 + 1
293            ENDDO
294         ENDDO
295
296         pksurcp       = ppk(1,jjp1,l) / cpp
297         zplay(ig0,l)  = preff * pksurcp ** unskap
298!         pcvgt(ig0,l)  = pdteta(1,jjp1,l) * pksurcp/ pmasse(1,jjp1,l)
299
300      ENDDO
301
302c   43.bis traceurs (tous intensifs)
303c   ---------------
304c
305      DO iq=1,nqtot
306          iiq=niadv(iq)
307         DO l=1,llm
308            zqfi(1,l,iq) = pq(1,1,l,iiq)
309            ig0          = 2
310            DO j=2,jjm
311               DO i = 1, iim
312                  zqfi(ig0,l,iq)  = pq(i,j,l,iiq)
313                  ig0             = ig0 + 1
314               ENDDO
315            ENDDO
316            zqfi(ig0,l,iq) = pq(1,jjp1,l,iiq)
317         ENDDO
318      ENDDO  ! boucle sur traceurs
319
320!-----------------
321! RQ SL 13/10/10:
322! Ces calculs ne servent pas.
323! Si necessaire, decommenter ces variables et les calculs...
324!
325!   convergence dynamique pour les traceurs "EAU"
326! Earth-specific treatment of first 2 tracers (water)
327!      if (planet_type=="earth") then
328!       DO iq=1,2
329!        DO l=1,llm
330!           pcvgq(1,l,iq)= pdq(1,1,l,iq) / pmasse(1,1,l)
331!           ig0          = 2
332!           DO j=2,jjm
333!              DO i = 1, iim
334!                 pcvgq(ig0,l,iq) = pdq(i,j,l,iq) / pmasse(i,j,l)
335!                 ig0             = ig0 + 1
336!              ENDDO
337!           ENDDO
338!           pcvgq(ig0,l,iq)= pdq(1,jjp1,l,iq) / pmasse(1,jjp1,l)
339!        ENDDO
340!       ENDDO
341!      endif ! of if (planet_type=="earth")
342!----------------
343
344c   Geopotentiel calcule par rapport a la surface locale:
345c   -----------------------------------------------------
346
347      CALL gr_dyn_fi(llm,iip1,jjp1,ngridmx,pphi,zphi)
348      CALL gr_dyn_fi(1,iip1,jjp1,ngridmx,pphis,zphis)
349      DO l=1,llm
350         DO ig=1,ngridmx
351           zphi(ig,l)=zphi(ig,l)-zphis(ig)
352         ENDDO
353      ENDDO
354
355c   ....  Calcul de la vitesse  verticale  ( en Pa*m*s  ou Kg/s )  ....
356c JG : ancien calcule de omega utilise dans physiq.F. Maintenant le flux
357c    de masse est calclue dans advtrac.F 
358c      DO l=1,llm
359c        pvervel(1,l)=pw(1,1,l) * g /apoln
360c        ig0=2
361c       DO j=2,jjm
362c           DO i = 1, iim
363c              pvervel(ig0,l) = pw(i,j,l) * g * unsaire(i,j)
364c              ig0 = ig0 + 1
365c           ENDDO
366c       ENDDO
367c        pvervel(ig0,l)=pw(1,jjp1,l) * g /apols
368c      ENDDO
369
370c
371c   45. champ u:
372c   ------------
373
374      DO 50 l=1,llm
375
376         DO 25 j=2,jjm
377            ig0 = 1+(j-2)*iim
378            zufi(ig0+1,l)= 0.5 *
379     $      ( pucov(iim,j,l)/cu(iim,j) + pucov(1,j,l)/cu(1,j) )
380!            pcvgu(ig0+1,l)= 0.5 *
381!     $      ( pducov(iim,j,l)/cu(iim,j) + pducov(1,j,l)/cu(1,j) )
382            DO 10 i=2,iim
383               zufi(ig0+i,l)= 0.5 *
384     $         ( pucov(i-1,j,l)/cu(i-1,j) + pucov(i,j,l)/cu(i,j) )
385!               pcvgu(ig0+i,l)= 0.5 *
386!     $         ( pducov(i-1,j,l)/cu(i-1,j) + pducov(i,j,l)/cu(i,j) )
38710         CONTINUE
38825      CONTINUE
389
39050    CONTINUE
391
392
393c   46.champ v:
394c   -----------
395
396      DO l=1,llm
397         DO j=2,jjm
398            ig0=1+(j-2)*iim
399            DO i=1,iim
400               zvfi(ig0+i,l)= 0.5 *
401     $         ( pvcov(i,j-1,l)/cv(i,j-1) + pvcov(i,j,l)/cv(i,j) )
402c               pcvgv(ig0+i,l)= 0.5 *
403c     $         ( pdvcov(i,j-1,l)/cv(i,j-1) + pdvcov(i,j,l)/cv(i,j) )
404            ENDDO
405         ENDDO
406      ENDDO
407
408
409c   47. champs de vents aux pole nord   
410c   ------------------------------
411c        U = 1 / pi  *  integrale [ v * cos(long) * d long ]
412c        V = 1 / pi  *  integrale [ v * sin(long) * d long ]
413
414      DO l=1,llm
415
416         z1(1)   =(rlonu(1)-rlonu(iim)+2.*pi)*pvcov(1,1,l)/cv(1,1)
417         z1bis(1)=(rlonu(1)-rlonu(iim)+2.*pi)*pdvcov(1,1,l)/cv(1,1)
418         DO i=2,iim
419            z1(i)   =(rlonu(i)-rlonu(i-1))*pvcov(i,1,l)/cv(i,1)
420            z1bis(i)=(rlonu(i)-rlonu(i-1))*pdvcov(i,1,l)/cv(i,1)
421         ENDDO
422
423         DO i=1,iim
424            zcos(i)   = COS(rlonv(i))*z1(i)
425            zcosbis(i)= COS(rlonv(i))*z1bis(i)
426            zsin(i)   = SIN(rlonv(i))*z1(i)
427            zsinbis(i)= SIN(rlonv(i))*z1bis(i)
428         ENDDO
429
430         zufi(1,l)  = SSUM(iim,zcos,1)/pi
431!         pcvgu(1,l) = SSUM(iim,zcosbis,1)/pi
432         zvfi(1,l)  = SSUM(iim,zsin,1)/pi
433!         pcvgv(1,l) = SSUM(iim,zsinbis,1)/pi
434
435      ENDDO
436
437
438c   48. champs de vents aux pole sud:
439c   ---------------------------------
440c        U = 1 / pi  *  integrale [ v * cos(long) * d long ]
441c        V = 1 / pi  *  integrale [ v * sin(long) * d long ]
442
443      DO l=1,llm
444
445         z1(1)   =(rlonu(1)-rlonu(iim)+2.*pi)*pvcov(1,jjm,l)/cv(1,jjm)
446         z1bis(1)=(rlonu(1)-rlonu(iim)+2.*pi)*pdvcov(1,jjm,l)/cv(1,jjm)
447         DO i=2,iim
448            z1(i)   =(rlonu(i)-rlonu(i-1))*pvcov(i,jjm,l)/cv(i,jjm)
449            z1bis(i)=(rlonu(i)-rlonu(i-1))*pdvcov(i,jjm,l)/cv(i,jjm)
450         ENDDO
451
452         DO i=1,iim
453            zcos(i)    = COS(rlonv(i))*z1(i)
454            zcosbis(i) = COS(rlonv(i))*z1bis(i)
455            zsin(i)    = SIN(rlonv(i))*z1(i)
456            zsinbis(i) = SIN(rlonv(i))*z1bis(i)
457         ENDDO
458
459         zufi(ngridmx,l)  = SSUM(iim,zcos,1)/pi
460!         pcvgu(ngridmx,l) = SSUM(iim,zcosbis,1)/pi
461         zvfi(ngridmx,l)  = SSUM(iim,zsin,1)/pi
462!         pcvgv(ngridmx,l) = SSUM(iim,zsinbis,1)/pi
463
464      ENDDO
465c
466      if (planet_type=="earth") then
467#ifdef CPP_EARTH
468cIM calcul PV a teta=350, 380, 405K
469      CALL PVtheta(ngridmx,llm,pucov,pvcov,pteta,
470     $           ztfi,zplay,zplev,
471     $           ntetaSTD,rtetaSTD,PVteta)
472#endif
473      endif
474c
475c On change de grille, dynamique vers physiq, pour le flux de masse verticale
476      CALL gr_dyn_fi(llm,iip1,jjp1,ngridmx,flxw,flxwfi)
477
478c-----------------------------------------------------------------------
479c   Appel de la physique:
480c   ---------------------
481
482! Appel de la physique: pose probleme quand on tourne
483! SANS physique, car physiq.F est dans le repertoire phy[]...
484! Il faut une cle CPP_PHYS
485
486! Le fait que les arguments de physiq soient differents selon les planetes
487! ne pose pas de probleme a priori.
488
489! #ifdef CPP_PHYS
490
491!      write(lunout,*) 'PHYSIQUE AVEC NSPLIT_PHYS=',nsplit_phys
492      zdt_split=dtphys/nsplit_phys
493      zdufic(:,:)=0.
494      zdvfic(:,:)=0.
495      zdtfic(:,:)=0.
496      zdqfic(:,:,:)=0.
497
498      do isplit=1,nsplit_phys
499
500         jH_cur_split=jH_cur+(isplit-1) * dtvr / (daysec *nsplit_phys)
501         debut_split=debut.and.isplit==1
502         lafin_split=lafin.and.isplit==nsplit_phys
503
504      if (planet_type.eq."earth") then
505         CALL physiq (ngridmx,
506     .             llm,
507     .             debut_split,
508     .             lafin_split,
509     .             jD_cur,
510     .             jH_cur_split,
511     .             zdt_split,
512     .             zplev,
513     .             zplay,
514     .             zphi,
515     .             zphis,
516     .             presnivs,
517     .             clesphy0,
518     .             zufi,
519     .             zvfi,
520     .             ztfi,
521     .             zqfi,
522     .             flxwfi,
523     .             zdufi,
524     .             zdvfi,
525     .             zdtfi,
526     .             zdqfi,
527     .             zdpsrf,
528cIM diagnostique PVteta, Amip2         
529     .             pducov,
530     .             PVteta)
531
532      else  ! a moduler pour Mars !!
533
534         CALL physiq (ngridmx,
535     .             llm,
536     .             nqtot,
537     .             debut_split,
538     .             lafin_split,
539     .             jD_cur,
540     .             jH_cur_split,
541     .             zdt_split,
542     .             zplev,
543     .             zplay,
544     .             zpk,
545     .             zphi,
546     .             zphis,
547     .             presnivs,
548     .             clesphy0,
549     .             zufi,
550     .             zvfi,
551     .             ztfi,
552     .             zqfi,
553     .             flxwfi,
554     .             zdufi,
555     .             zdvfi,
556     .             zdtfi,
557     .             zdqfi,
558     .             zdpsrf)
559
560      endif ! planet_type
561
562         zufi(:,:)=zufi(:,:)+zdufi(:,:)*zdt_split
563         zvfi(:,:)=zvfi(:,:)+zdvfi(:,:)*zdt_split
564         ztfi(:,:)=ztfi(:,:)+zdtfi(:,:)*zdt_split
565         zqfi(:,:,:)=zqfi(:,:,:)+zdqfi(:,:,:)*zdt_split
566
567         zdufic(:,:)=zdufic(:,:)+zdufi(:,:)
568         zdvfic(:,:)=zdvfic(:,:)+zdvfi(:,:)
569         zdtfic(:,:)=zdtfic(:,:)+zdtfi(:,:)
570         zdqfic(:,:,:)=zdqfic(:,:,:)+zdqfi(:,:,:)
571
572      enddo
573      zdufi(:,:)=zdufic(:,:)/nsplit_phys
574      zdvfi(:,:)=zdvfic(:,:)/nsplit_phys
575      zdtfi(:,:)=zdtfic(:,:)/nsplit_phys
576      zdqfi(:,:,:)=zdqfic(:,:,:)/nsplit_phys
577
578! #endif ! CPP_PHYS
579
580500   CONTINUE
581
582c-----------------------------------------------------------------------
583c   transformation des tendances physiques en tendances dynamiques:
584c   ---------------------------------------------------------------
585
586c  tendance sur la pression :
587c  -----------------------------------
588
589      CALL gr_fi_dyn(1,ngridmx,iip1,jjp1,zdpsrf,pdpsfi)
590c
591c   62. enthalpie potentielle
592c   ---------------------
593
594! ADAPTATION GCM POUR CP(T)
595         ztfi=ztfi+zdtfi*dtphys
596      call t2tpot(ngridmx*llm,ztfi,zteta,zpk)
597
598         DO i=1,iip1
599      pdhfi(i,1,:) = (zteta(1,:) - pteta(i,1,:))/dtphys
600      pdhfi(i,jjp1,:) = (zteta(ngridmx,:) - pteta(i,jjp1,:))/dtphys
601         ENDDO
602
603         DO j=2,jjm
604            ig0=1+(j-2)*iim
605            DO i=1,iim
606      pdhfi(i,j,:) = (zteta(ig0+i,:) - pteta(i,j,:))/dtphys
607            ENDDO
608               pdhfi(iip1,j,:) =  pdhfi(1,j,:)
609         ENDDO
610
611
612c   62. humidite specifique
613c   ---------------------
614! Ehouarn: removed this useless bit: was overwritten at step 63 anyways
615!      DO iq=1,nqtot
616!         DO l=1,llm
617!            DO i=1,iip1
618!               pdqfi(i,1,l,iq)    = zdqfi(1,l,iq)
619!               pdqfi(i,jjp1,l,iq) = zdqfi(ngridmx,l,iq)
620!            ENDDO
621!            DO j=2,jjm
622!               ig0=1+(j-2)*iim
623!               DO i=1,iim
624!                  pdqfi(i,j,l,iq) = zdqfi(ig0+i,l,iq)
625!               ENDDO
626!               pdqfi(iip1,j,l,iq) = pdqfi(1,j,l,iq)
627!            ENDDO
628!         ENDDO
629!      ENDDO
630
631c   63. traceurs (tous en intensifs)
632c   ------------
633C     initialisation des tendances
634      pdqfi(:,:,:,:)=0.
635C
636       DO iq=1,nqtot
637         iiq=niadv(iq)
638         DO l=1,llm
639            DO i=1,iip1
640               pdqfi(i,1,l,iiq)    = zdqfi(1,l,iq)
641               pdqfi(i,jjp1,l,iiq) = zdqfi(ngridmx,l,iq)
642            ENDDO
643            DO j=2,jjm
644               ig0=1+(j-2)*iim
645               DO i=1,iim
646                  pdqfi(i,j,l,iiq) = zdqfi(ig0+i,l,iq)
647               ENDDO
648               pdqfi(iip1,j,l,iiq) = pdqfi(1,j,l,iq)
649            ENDDO
650         ENDDO
651       ENDDO
652
653c   65. champ u:
654c   ------------
655
656      DO l=1,llm
657
658         DO i=1,iip1
659            pdufi(i,1,l)    = 0.
660            pdufi(i,jjp1,l) = 0.
661         ENDDO
662
663         DO j=2,jjm
664            ig0=1+(j-2)*iim
665            DO i=1,iim-1
666               pdufi(i,j,l)=
667     $         0.5*(zdufi(ig0+i,l)+zdufi(ig0+i+1,l))*cu(i,j)
668            ENDDO
669            pdufi(iim,j,l)=
670     $      0.5*(zdufi(ig0+1,l)+zdufi(ig0+iim,l))*cu(iim,j)
671            pdufi(iip1,j,l)=pdufi(1,j,l)
672         ENDDO
673
674      ENDDO
675
676
677c   67. champ v:
678c   ------------
679
680      DO l=1,llm
681
682         DO j=2,jjm-1
683            ig0=1+(j-2)*iim
684            DO i=1,iim
685               pdvfi(i,j,l)=
686     $         0.5*(zdvfi(ig0+i,l)+zdvfi(ig0+i+iim,l))*cv(i,j)
687            ENDDO
688            pdvfi(iip1,j,l) = pdvfi(1,j,l)
689         ENDDO
690      ENDDO
691
692
693c   68. champ v pres des poles:
694c   ---------------------------
695c      v = U * cos(long) + V * SIN(long)
696
697      DO l=1,llm
698
699         DO i=1,iim
700            pdvfi(i,1,l)=
701     $      zdufi(1,l)*COS(rlonv(i))+zdvfi(1,l)*SIN(rlonv(i))
702            pdvfi(i,jjm,l)=zdufi(ngridmx,l)*COS(rlonv(i))
703     $      +zdvfi(ngridmx,l)*SIN(rlonv(i))
704            pdvfi(i,1,l)=
705     $      0.5*(pdvfi(i,1,l)+zdvfi(i+1,l))*cv(i,1)
706            pdvfi(i,jjm,l)=
707     $      0.5*(pdvfi(i,jjm,l)+zdvfi(ngridmx-iip1+i,l))*cv(i,jjm)
708          ENDDO
709
710         pdvfi(iip1,1,l)  = pdvfi(1,1,l)
711         pdvfi(iip1,jjm,l)= pdvfi(1,jjm,l)
712
713      ENDDO
714
715c-----------------------------------------------------------------------
716
717700   CONTINUE
718 
719      firstcal = .FALSE.
720
721      RETURN
722      END
Note: See TracBrowser for help on using the repository browser.