source: LMDZ4/trunk/libf/phylmd/phytrac.F @ 1091

Last change on this file since 1091 was 1067, checked in by Laurent Fairhead, 16 years ago
  • Modifications lie au premier niveau du modele pour la diffusion turbulent

du vent.

  • Preparation pour un couplage des courrant oceaniques.

JG

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 27.1 KB
Line 
1!
2c
3c
4      SUBROUTINE phytrac (rnpb,
5     I                    nstep,
6     I                    julien,
7     I                    gmtime,
8     I                    debutphy,
9     I                    lafin,
10     I                    nqmax,
11     I                    nlon,
12     I                    nlev,
13     I                    pdtphys,
14     I                    u,
15     I                    v,
16     I                    t_seri,
17     I                    paprs,
18     I                    pplay,
19     I                    pmfu,
20     I                    pmfd,
21     I                    pen_u,
22     I                    pde_u,
23     I                    pen_d,
24     I                    pde_d,
25     I                    cdragh,
26     I                    coefh,
27     I                    fm_therm,
28     I                    entr_therm,
29     I                    yu1,
30     I                    yv1,
31     I                    ftsol,
32     I                    pctsrf,
33     I                    xlat,
34     I                    frac_impa,
35     I                    frac_nucl,
36     I                    xlon,
37     I                    presnivs,
38     I                    pphis,
39     I                    pphi,
40     I                    albsol,
41     I                    sh,
42     I                    rh,
43     I                    cldfra,
44     I                    rneb,
45     I                    diafra,
46     I                    cldliq,
47     I                    itop_con,
48     I                    ibas_con,
49     I                    pmflxr,
50     I                    pmflxs,
51     I                    prfl,
52     I                    psfl,
53     I                    da,
54     I                    phi,
55     I                    mp,
56     I                    upwd,
57     I                    dnwd,
58     I                    aerosol_couple,
59     I                    flxmass_w,
60     I                    tau_inca,
61     I                    piz_inca,
62     I                    cg_inca,
63     I                    ccm,
64     I                    rfname,
65     O                    tr_seri)
66
67      USE ioipsl
68      USE dimphy
69      USE mod_grid_phy_lmdz
70      USE mod_phys_lmdz_para
71      USE comgeomphy
72      USE iophy
73      USE vampir
74
75      IMPLICIT none
76c======================================================================
77c Auteur(s) FH
78c Objet: Moniteur general des tendances traceurs
79c
80cAA Remarques en vrac:
81cAA--------------------
82cAA 1/ le call phytrac se fait avec nqmax-2 donc nous avons bien
83cAA les vrais traceurs (nbtr) dans phytrac (pas la vapeur ni eau liquide)
84cAA 2/ Le choix du radon et du pb se fait juste avec un data
85cAA    (peu propre). Peut-etre pourrait-on prevoir dans l'avenir
86cAA    une variable "type de traceur"
87c======================================================================
88#include "YOMCST.h"
89#include "dimensions.h"
90#include "indicesol.h"
91#include "clesphys.h"
92#include "temps.h"
93#include "paramet.h"
94#include "control.h"
95#include "advtrac.h"
96#include "thermcell.h"
97c======================================================================
98
99c Arguments:
100c
101c   EN ENTREE:
102c   ==========
103c
104c   divers:
105c   -------
106c
107      integer nlon  ! nombre de points horizontaux
108      integer nlev  ! nombre de couches verticales
109      integer nqmax ! nombre de traceurs auxquels on applique la physique
110      integer nstep  ! appel physique
111      integer julien !jour julien
112      integer itop_con(nlon)
113      integer ibas_con(nlon)
114      real gmtime
115      real pdtphys  ! pas d'integration pour la physique (seconde)
116      real t_seri(nlon,nlev) ! temperature
117      real tr_seri(nlon,nlev,nbtr) ! traceur 
118      real u(klon,klev)
119      real v(klon,klev)
120      real sh(nlon,nlev)     ! humidite specifique
121      real rh(nlon,nlev)     ! humidite relative
122      real cldliq(nlon,nlev) ! eau liquide nuageuse
123      real cldfra(nlon,nlev) ! fraction nuageuse (tous les nuages)
124      real diafra(nlon,nlev) ! fraction nuageuse (convection ou stratus artificiels)
125      real rneb(nlon,nlev)   ! fraction nuageuse (grande echelle)
126      real albsol(nlon)  ! albedo surface
127      real paprs(nlon,nlev+1)  ! pression pour chaque inter-couche (en Pa)
128      real ps(nlon)  ! pression surface
129      real pplay(nlon,nlev)  ! pression pour le mileu de chaque couche (en Pa)
130      real pphi(nlon,klev) ! geopotentiel
131      real pphis(klon)
132      REAL presnivs(klev)
133      logical debutphy       ! le flag de l'initialisation de la physique
134      logical lafin          ! le flag de la fin de la physique
135c Olivia     
136      integer nsplit
137      REAL pmflxr(klon,klev+1), pmflxs(klon,klev+1)   !--lessivage convection
138      REAL prfl(klon,klev+1),   psfl(klon,klev+1)     !--lessivage large-scale
139      LOGICAL aerosol_couple
140
141      REAL flxmass_w(klon,klev)
142      CHARACTER(len=8) :: solsym(nqmax)
143      integer la
144      REAL              ::    tau_inca(klon,klev,9,2)
145      REAL              ::    piz_inca(klon,klev,9,2)
146      REAL              ::    cg_inca(klon,klev,9,2)
147      character*4       ::    rfname(9)
148      REAL              ::    ccm(klon,klev,2)
149c
150c   convection:
151c   -----------
152c
153      REAL pmfu(nlon,nlev)  ! flux de masse dans le panache montant
154      REAL pmfd(nlon,nlev)  ! flux de masse dans le panache descendant
155      REAL pen_u(nlon,nlev) ! flux entraine dans le panache montant
156
157c
158c   thermiques:
159c   -----------
160c
161      real fm_therm(klon,klev+1),entr_therm(klon,klev)
162        real fm_therm1(klon,klev)
163c
164      REAL pde_u(nlon,nlev) ! flux detraine dans le panache montant
165      REAL pen_d(nlon,nlev) ! flux entraine dans le panache descendant
166      REAL pde_d(nlon,nlev) ! flux detraine dans le panache descendant
167c KE
168      real da(nlon,nlev),phi(nlon,nlev,nlev),mp(nlon,nlev)
169      REAL upwd(nlon,nlev)      ! saturated updraft mass flux
170      REAL dnwd(nlon,nlev)      ! saturated downdraft mass flux
171
172c
173c   Couche limite:
174c   --------------
175c
176      REAL cdragh(nlon,nlev)! coeff drag pour T et Q
177      REAL coefh(nlon,nlev) ! coeff melange CL
178      REAL yu1(nlon)        ! vents au premier niveau
179      REAL yv1(nlon)        ! vents au premier niveau
180      REAL xlat(nlon)       ! latitudes pour chaque point
181      REAL xlon(nlon)       ! longitudes pour chaque point
182
183c
184c   Lessivage:
185c   ----------
186c
187c pour le ON-LINE
188c
189      REAL frac_impa(nlon,nlev)  ! fraction d'aerosols impactes
190      REAL frac_nucl(nlon,nlev)  ! fraction d'aerosols nuclees
191c
192cAA
193cAA Arguments necessaires pour les sources et puits de traceur:
194cAA ----------------
195cAA
196      real ftsol(nlon,nbsrf)  ! Temperature du sol (surf)(Kelvin)
197      real pctsrf(nlon,nbsrf) ! Pourcentage de sol f(nature du sol)
198c abder
199      real pftsol1(nlon),pftsol2(nlon),pftsol3(nlon),pftsol4(nlon)
200      real ppsrf1(nlon),ppsrf2(nlon),ppsrf3(nlon),ppsrf4(nlon)
201c fin
202cAA ----------------------------
203cAA  VARIABLES LOCALES TRACEURS
204cAA ----------------------------
205cAA
206cAA Sources et puits des traceurs:
207cAA ------------------------------
208cAA
209cAA Pour l'instant seuls les cas du rn et du pb ont ete envisages.
210
211      REAL source(klon,nqmax)       ! a voir lorsque le flux est prescrit
212cAA
213cAA Pour la source de radon et son reservoir de sol
214cAA ................................................
215 
216      REAL,save,allocatable :: trs(:,:)    ! Conc. radon ds le sol
217c$OMP THREADPRIVATE(trs)
218cym      SAVE trs
219      REAL :: trs_tmp(klon_glo)
220     
221      REAL,save,allocatable :: masktr(:,:) ! Masque reservoir de sol traceur
222c                            Masque de l'echange avec la surface
223c                           (1 = reservoir) ou (possible => 1 )
224c$OMP THREADPRIVATE(masktr)
225cym      SAVE masktr
226      REAL,save,allocatable :: fshtr(:,:)  ! Flux surfacique dans le reservoir de sol
227c$OMP THREADPRIVATE(fshtr)
228cym      SAVE fshtr
229      REAL,save,allocatable :: hsoltr(:)      ! Epaisseur equivalente du reservoir de sol
230c$OMP THREADPRIVATE(hsoltr)
231cym      SAVE hsoltr
232      REAL,save,allocatable :: tautr(:)       ! Constante de decroissance radioactive
233c$OMP THREADPRIVATE(tautr)
234cym      SAVE tautr
235      REAL,save,allocatable :: vdeptr(:)      ! Vitesse de depot sec dans la couche Brownienne
236c$OMP THREADPRIVATE(vdeptr)
237cym      SAVE vdeptr
238      REAL,save,allocatable :: scavtr(:)      ! Coefficient de lessivage
239c$OMP THREADPRIVATE(scavtr)
240cym      SAVE scavtr
241cAA
242      CHARACTER*2 itn
243C maf ioipsl
244      CHARACTER*2 str2
245      INTEGER nhori, nvert
246      REAL zsto, zout, zjulian
247      INTEGER, SAVE :: nid_tra
248c$OMP THREADPRIVATE(nid_tra)
249      INTEGER, SAVE :: nid_tra2,nid_tra3
250c$OMP THREADPRIVATE(nid_tra2,nid_tra3)
251      INTEGER ndex(1)
252      INTEGER ndex2d(iim*(jjm+1)),ndex3d(iim*(jjm+1)*klev)
253      REAL zx_tmp_fi2d(klon)      ! variable temporaire grille physique
254      REAL zx_tmp_fi3d(klon,klev) ! variable temporaire pour champs 3D
255      REAL zx_tmp_2d(iim,jjm+1), zx_tmp_3d(iim,jjm+1,klev)
256      REAL zx_lon(iim,jjm+1), zx_lat(iim,jjm+1)
257c
258      integer itau_w   ! pas de temps ecriture = nstep + itau_phy
259c
260      logical ok_sync
261      parameter (ok_sync = .true.)
262C
263C nature du traceur
264c
265      logical,save,allocatable :: aerosol(:)  ! Nature du traceur
266c                            ! aerosol(it) = true  => aerosol
267c                            ! aerosol(it) = false => gaz
268c                            ! nat_trac(it) = 1. aerosol
269      logical,save,allocatable :: clsol(:)    ! clsol(it) = true => CL sol calculee
270      logical,save,allocatable :: radio(:)    ! radio(it)=true => decroisssance radioactive
271c$OMP THREADPRIVATE(aerosol,clsol,radio) 
272cym      save aerosol,clsol,radio
273C
274c======================================================================
275c
276c Declaration des procedures appelees
277c
278c--modif convection tiedtke
279      INTEGER i, k, it
280      INTEGER iq, iiq
281      REAL delp(klon,klev)
282c--end modif
283c
284c Variables liees a l'ecriture de la bande histoire physique
285c
286c Variables locales pour effectuer les appels en serie
287c----------------------------------------------------
288c
289      REAL d_tr(klon,klev), d_trs(klon) ! tendances de traceurs
290      REAL d_tr_cl(klon,klev,nbtr) ! tendance de traceurs  couche limite
291      REAL d_tr_cv(klon,klev,nbtr) ! tendance de traceurs  conv pour chq traceur
292      REAL d_tr_th(klon,klev,nbtr) ! la tendance des thermiques
293      REAL d_tr_dec(klon,klev,nbtr) ! la tendance de la decroissance
294c                                   ! radioactive du rn - > pb
295      REAL d_tr_lessi_impa(klon,klev,nbtr) ! la tendance du lessivage
296c                                          ! par impaction
297      REAL d_tr_lessi_nucl(klon,klev,nbtr) ! la tendance du lessivage
298c                                          ! par nucleation
299      REAL fluxrn(klon,klev)
300      REAL fluxpb(klon,klev)
301      REAL pbimpa(klon,klev)
302      REAL pbnucl(klon,klev)
303      REAL rn(klon,klev)
304      REAL pb(klon,klev)
305      REAL flestottr(klon,klev,nbtr) ! flux de lessivage
306c                                    ! dans chaque couche
307      real zmasse(klon,klev)
308      real ztra_th(klon,klev)
309
310C
311      character*20 modname
312      character*80 abort_message
313c
314c   Controles
315c-------------
316      logical first,couchelimite,convection,lessivage,sorties,
317     s        rnpb,inirnpb
318      save first,couchelimite,convection,lessivage,
319     s        sorties,inirnpb
320c$OMP THREADPRIVATE(first,couchelimite,convection,lessivage,
321c$OMP+              sorties,inirnpb)
322c      data first,couchelimite,convection,lessivage,sorties
323c     s     /.true.,.true.,.false.,.true.,.true./
324c Olivia
325       data first,couchelimite,convection,lessivage,
326     s      sorties
327     s     /.true.,.true.,.true.,.true.,.true./
328
329! Variables needed for configuration with INCA
330      INTEGER           :: lastgas
331      INTEGER           :: ncsec
332
333      REAL, PARAMETER   :: dry_mass = 28.966
334      REAL, POINTER     :: hbuf(:)
335      REAL, ALLOCATABLE :: obuf(:)
336      REAL              :: calday
337      REAL              :: pdel(klon,klev)
338c
339c======================================================================
340
341         modname='phytrac'
342
343         ps(:)=paprs(:,1)
344
345         if (debutphy) then
346           allocate( trs(klon,nbtr) )
347           allocate( masktr(klon,nbtr))
348           allocate( fshtr(klon,nbtr) )
349           allocate( hsoltr(nbtr))
350           allocate( tautr(nbtr))
351           allocate( vdeptr(nbtr))
352           allocate( scavtr(nbtr))
353           allocate( aerosol(nbtr))
354           allocate( clsol(nbtr))
355           allocate( radio(nbtr))
356
357
358! FH 2008/05/09 correction de la frequence d'ecriture des traceurs
359!         ecrit_tra = FLOAT(NINT(86400./pdtphys *ecritphy))
360          print*,'dans phytrac ',pdtphys,ecrit_tra
361
362         if(nbtr.lt.nqmax) then
363c           print*,'NQMAX=',nqmax
364c           print*,'NBTR=',nbtr
365           abort_message='See above'
366           call abort_gcm(modname,abort_message,1)
367         endif
368
369         inirnpb=rnpb
370         PRINT*, 'La frequence de sortie traceurs est  ', ecrit_tra
371C         
372c=============================================================
373c   Initialisation des sorties
374c=============================================================
375
376#ifdef CPP_IOIPSL
377#include "ini_histrac.h"
378#endif
379
380c======================================================================
381c   Initialisation de certaines variables pour le Rn et le Pb
382c======================================================================
383
384c Initialisation du traceur dans le sol (couche limite radonique)
385c
386c        print*,'valeur de debut dans phytrac :',debutphy
387         trs(:,:) = 0.
388c$OMP MASTER         
389       if (is_mpi_root) then
390         trs_tmp(:)=0.
391         open (99,file='starttrac',status='old',
392     .         err=999,form='formatted')
393         read(99,*) (trs_tmp(i),i=1,klon_glo)
394999      close(99)
395       endif
396c$OMP END MASTER
397       call Scatter(trs_tmp,trs(:,1))
398
399c         print*, 'apres starttrac'
400
401c Initialisation de la fraction d'aerosols lessivee
402c
403         d_tr_lessi_impa(:,:,:) = 0.
404         d_tr_lessi_nucl(:,:,:) = 0.
405c
406c Initialisation de la nature des traceurs
407c
408         DO it = 1, nqmax
409            aerosol(it) = .FALSE.  ! Tous les traceurs sont des gaz par defaut
410            radio(it) = .FALSE.    ! Par defaut pas de passage par radiornpb
411            clsol(it) = .FALSE.  ! Par defaut couche limite avec flux prescrit
412         ENDDO
413c
414      ENDIF  ! fin debutphy
415c Initialisation du traceur dans le sol (couche limite radonique)
416      if(inirnpb) THEN
417c
418         radio(1)= .true.
419         radio(2)= .true.
420         clsol(1)= .true.
421         clsol(2)= .true.
422         aerosol(2) = .TRUE. ! le Pb est un aerosol
423c
424         call initrrnpb (ftsol,pctsrf,masktr,fshtr,hsoltr,tautr
425     .                   ,vdeptr,scavtr)
426         inirnpb=.false.
427      endif
428
429
430      IF (config_inca == 'none') THEN
431       DO i=1,nlon
432          pftsol1(i) = ftsol(i,1)
433          pftsol2(i) = ftsol(i,2)
434          pftsol3(i) = ftsol(i,3)
435          pftsol4(i) = ftsol(i,4)
436
437          ppsrf1(i) = pctsrf(i,1)
438          ppsrf2(i) = pctsrf(i,2)
439          ppsrf3(i) = pctsrf(i,3)
440          ppsrf4(i) = pctsrf(i,4)
441
442       ENDDO
443
444      ELSE ! config_inca /=none
445#ifdef INCA
446      call VTe(VTphysiq)
447      call VTb(VTinca)
448
449!======================================================================
450!     Chimie
451!======================================================================
452
453        calday = FLOAT(julien) + gmtime
454        ncsec  = NINT (86400.*gmtime)
455
456        DO k = 1, nlev
457        pdel(:,k) = paprs(:,k) - paprs (:,k+1)
458        END DO
459
460        IF (config_inca == 'aero') THEN
461           CALL aerosolmain (aerosol_couple,
462     $                 tr_seri,
463     $                 pdtphys,
464     $                 pplay,
465     $                 pdel,
466     $                 prfl,
467     $                 pmflxr,
468     $                 psfl,
469     $                 pmflxs,
470     $                 pmfu,
471     $                 itop_con,
472     $                 ibas_con,
473     $                 pphi,
474     $                 airephy, ! paire,
475     $                 nstep,
476     $                 rneb,         ! for chimiaq
477     $                 t_seri,       ! for chimiaq
478     $                 rh,
479     $                 tau_inca,
480     $                 piz_inca,
481     $                 cg_inca,
482     $                 rfname,
483     $                 ccm,
484     $                 lafin)
485        END IF
486
487        CALL chemmain (tr_seri,    !mmr
488     $                 nstep,      !nstep
489     $                 calday,     !calday
490     $                 julien,     !ncdate
491     $                 ncsec,      !ncsec
492     $                 1,          !lat
493     $                 pdtphys,    !delt
494     $                 paprs(1,1), !ps
495     $                 pplay,      !pmid
496     $                 pdel,       !pdel
497     $                 airephy,
498     $                 pctsrf(1,1),!oro
499     $                 ftsol,      !tsurf
500     $                 albsol,     !albs
501     $                 pphi,       !zma
502     $                 pphis,      !phis
503     $                 cldfra,     !cldfr
504     $                 rneb,       !cldfr_st
505     $                 diafra,     !cldfr_cv
506     $                 itop_con,   !cldtop
507     $                 ibas_con,   !cldbot
508     $                 cldliq,     !cwat
509     $                 prfl,       !flxrst
510     $                 pmflxr,     !flxrcv
511     $                 psfl,       !flxsst
512     $                 pmflxs,     !flxscv
513     $                 pmfu,       !flxupd
514     $                 flxmass_w,  !flxmass_w
515     $                 t_seri,     !tfld
516     $                 sh,         !sh
517     $                 rh,         !rh
518     $                 .false.,    !wrhstts
519     $                 hbuf,       !hbuf
520     $                 obuf,       !obuf
521     $                 iip1,       !nx
522     $                 jjp1,       !ny
523     $                 source,
524     $                 solsym)
525
526
527      call VTe(VTinca)
528      call VTb(VTphysiq)
529#endif
530      END IF ! config_inca
531c======================================================================
532c   Calcul de l'effet de la convection
533c======================================================================
534c     print*,'Avant convection'
535       do it=1,nqmax
536          WRITE(itn,'(i2)') it
537c        call diagtracphy(tr_seri(:,:,it),paprs,'Avant conv'//itn)
538       enddo
539
540      if (convection) then
541
542c      print*,'Pas de temps dans phytrac : ',pdtphys
543      DO it=1, nqmax
544
545      IF ( config_inca/='none' .AND. conv_flg(it) == 0 ) CYCLE
546
547      if (iflag_con.lt.2) then
548       d_tr_cv=0.
549      else if (iflag_con.eq.2) then
550c tiedke
551      CALL nflxtr(pdtphys, pmfu, pmfd, pen_u, pde_u, pen_d, pde_d,
552     .            pplay, paprs, tr_seri(1,1,it), d_tr_cv(1,1,it))
553      else
554c KE
555      call cvltr(pdtphys, da, phi, mp, paprs,pplay, tr_seri(1,1,it),
556     .           upwd,dnwd,d_tr_cv(1,1,it))
557      endif
558
559       DO k = 1, nlev
560       DO i = 1, klon
561         tr_seri(i,k,it) = tr_seri(i,k,it) + d_tr_cv(i,k,it)
562       ENDDO
563       ENDDO
564
565       IF (config_inca == 'none') THEN
566        CALL minmaxqfi(tr_seri(1,1,it),0.,1.e33,'convection it = '//itn)
567       ELSE
568        CALL minmaxqfi(tr_seri(1,1,it),0.,1.e33,'convection it = '
569     .         //solsym(it))
570       END IF   
571     
572      ENDDO
573
574      endif ! convection
575c        print*,'Apres convection'
576c      do it=1,nqmax
577c         WRITE(itn,'(i1)') it
578c        call diagtracphy(tr_seri(:,:,it),paprs,'Avant conv'//itn)
579c      enddo
580
581
582c======================================================================
583c   Calcul de l'effet des thermiques
584c======================================================================
585
586      do k=1,klev
587         do i=1,klon
588            zmasse(i,k)=(paprs(i,k)-paprs(i,k+1))/rg
589         enddo
590      enddo
591
592c      print*,'masse dans ph ',zmasse
593      do it=1,nqmax
594         do k=1,klev
595            do i=1,klon
596               d_tr_th(i,k,it)=0.
597               tr_seri(i,k,it)=max(tr_seri(i,k,it),0.)
598               tr_seri(i,k,it)=min(tr_seri(i,k,it),1.e10)
599            enddo
600         enddo
601      enddo
602
603      if (iflag_thermals.gt.0) then
604c        print*,'calcul de leffet des thermiques'
605        nsplit=10
606        DO it=1, nqmax
607c        WRITE(itn,'(i1)') it
608c        CALL minmaxqfi(tr_seri(1,1,it),1.e10,-1.e33,'conv it='//itn)
609c            print*,'avant dqthermiquesretro'
610c             call dump2d(iim,jjm-1,tr_seri(2,1,1),'TR_SERI      ')
611
612         do isplit=1,nsplit
613c  Abderr 25 11 02
614C Thermiques
615c       print*,'Avant dans phytrac'
616            call dqthermcell(klon,klev,pdtphys/nsplit
617     .       ,fm_therm,entr_therm,zmasse
618     .       ,tr_seri(1:klon,1:klev,it),d_tr,ztra_th)
619
620            do k=1,klev
621               do i=1,klon
622                  d_tr(i,k)=pdtphys*d_tr(i,k)/nsplit
623                  d_tr_th(i,k,it)=d_tr_th(i,k,it)+d_tr(i,k)
624                  tr_seri(i,k,it)=max(tr_seri(i,k,it)+d_tr(i,k),0.)
625               enddo
626            enddo
627          enddo ! nsplit
628c          print*,'apres thermiques'
629c             call dump2d(iim,jjm-1,d_tr_th(1,1,1),'d_tr_th      ')
630c            do k=1,klev
631c       print*,'d_tr_th(',k,')=',tr_seri(280,k,1)
632c          enddo
633
634c        WRITE(itn,'(i1)') it
635c        CALL minmaxqfi(tr_seri(1,1,it),1.e10,-1.e33,'therm it='//itn)
636       ENDDO ! it
637       endif ! Thermiques
638c       print*,'ATTENTION: sdans thermniques'
639     
640c======================================================================
641c   Calcul de l'effet de la couche limite
642c======================================================================
643c       print *,'Avant couchelimite'
644c      do it=1,nqmax
645c         WRITE(itn,'(i1)') it
646c        call diagtracphy(tr_seri(:,:,it),paprs,'Avant CL  '//itn)
647c      enddo
648
649      if (couchelimite) then
650
651      DO k = 1, nlev
652      DO i = 1, klon
653         delp(i,k) = paprs(i,k)-paprs(i,k+1)
654      ENDDO
655      ENDDO
656
657C maf modif pour tenir compte du cas rnpb + traceur
658      DO it=1, nqmax
659
660      IF ( config_inca/='none' .AND. pbl_flg(it) == 0 ) CYCLE
661
662c     print *,'it',it,clsol(it)
663      if (clsol(it)) then  ! couche limite avec quantite dans le sol calculee
664          CALL cltracrn(it, pdtphys, yu1, yv1,
665     e                    cdragh, coefh,t_seri,ftsol,pctsrf,
666     e                    tr_seri(1,1,it),trs(1,it),
667     e                    paprs, pplay, delp,
668     e                    masktr(1,it),fshtr(1,it),hsoltr(it),
669     e                    tautr(it),vdeptr(it),
670     e                    xlat,
671     s                    d_tr_cl(1,1,it),d_trs)
672          DO k = 1, nlev
673            DO i = 1, klon
674              tr_seri(i,k,it) = tr_seri(i,k,it) + d_tr_cl(i,k,it)
675            ENDDO
676          ENDDO
677c
678c Traceur ds sol
679c
680          DO i = 1, klon
681            trs(i,it) = trs(i,it) + d_trs(i)
682          END DO
683C
684C maf provisoire suppression des prints
685C         WRITE(itn,'(i1)') it
686C         CALL minmaxqfi(tr_seri(1,1,it),0.,1.e33,'cltracrn it='//itn)
687      else ! couche limite avec flux prescrit
688#ifndef INCA
689
690Cmaf provisoire source / traceur a creer
691        DO i=1, klon
692          source(i,it) = 0.0 ! pas de source, pour l'instant
693        ENDDO
694C
695#endif
696          CALL cltrac(pdtphys, coefh,t_seri,
697     s               tr_seri(1,1,it), source(:,it),
698     e               paprs, pplay, delp,
699     s               d_tr_cl(1,1,it))
700            DO k = 1, nlev
701               DO i = 1, klon
702                  tr_seri(i,k,it) = tr_seri(i,k,it) + d_tr_cl(i,k,it)
703               ENDDO
704            ENDDO
705Cmaf          WRITE(itn,'(i1)') it
706cmaf          CALL minmaxqfi(tr_seri(1,1,it),0.,1.e33,'cltracn it='//itn)
707      endif
708      ENDDO
709c
710      endif ! couche limite
711
712c      print*,'Apres couchelimite'
713c      do it=1,nqmax
714c         WRITE(itn,'(i1)') it
715c        call diagtracphy(tr_seri(:,:,it),paprs,'Avant CL  '//itn)
716c      enddo
717
718c======================================================================
719c   Calcul de l'effet du puits radioactif
720c======================================================================
721
722C MAF il faudrait faire une modification pour passer dans radiornpb
723c si radio=true mais pour l'instant radiornpb propre au cas rnpb
724      if(rnpb) then
725c       print *, 'decroissance radiactive activee'
726        call radiornpb (tr_seri,pdtphys,tautr,d_tr_dec)
727C
728        DO it=1,nqmax
729            if(radio(it)) then
730            DO k = 1, nlev
731               DO i = 1, klon
732                  tr_seri(i,k,it) = tr_seri(i,k,it) + d_tr_dec(i,k,it)
733               ENDDO
734            ENDDO
735            WRITE(itn,'(i1)') it
736            CALL minmaxqfi(tr_seri(1,1,it),0.,1.e33,'puits rn it='//itn)
737            endif
738        ENDDO
739c
740      endif ! rnpb decroissance  radioactive
741C
742c======================================================================
743c   Calcul de l'effet de la precipitation
744c======================================================================
745
746c      print*,'LESSIVAGE =',lessivage
747      IF (lessivage) THEN
748
749c     print*,'avant lessivage'
750
751          d_tr_lessi_nucl(:,:,:) = 0.
752          d_tr_lessi_impa(:,:,:) = 0.
753          flestottr(:,:,:) = 0.
754c
755c tendance des aerosols nuclees et impactes
756c
757       DO it = 1, nqmax
758         IF (aerosol(it)) THEN
759           DO k = 1, nlev
760              DO i = 1, klon
761               d_tr_lessi_nucl(i,k,it) = d_tr_lessi_nucl(i,k,it) +
762     s                  ( 1 - frac_nucl(i,k) )*tr_seri(i,k,it)
763               d_tr_lessi_impa(i,k,it) = d_tr_lessi_impa(i,k,it) +
764     s                  ( 1 - frac_impa(i,k) )*tr_seri(i,k,it)
765              ENDDO
766           ENDDO
767         ENDIF
768       ENDDO
769c
770c Mises a jour des traceurs + calcul des flux de lessivage
771c Mise a jour due a l'impaction et a la nucleation
772c
773c      call dump2d(iim,jjm-1,frac_impa(2:klon-1,10),'FRACIMPA')
774c      call dump2d(iim,jjm-1,frac_nucl(2:klon-1,10),'FRACNUCL')
775c      call dump2d(iim,jjm-1,tr_seri(2:klon-1,10,3),'TRACEUR3')
776       DO it = 1, nqmax
777c         print*,'IT=',it,aerosol(it)
778         IF (aerosol(it)) THEN
779c           print*,'IT=',it,' On lessive'
780           DO k = 1, nlev
781              DO i = 1, klon
782               tr_seri(i,k,it)=tr_seri(i,k,it)
783     s         *frac_impa(i,k)*frac_nucl(i,k)
784              ENDDO
785           ENDDO
786         ENDIF
787       ENDDO
788c      call dump2d(iim,jjm-1,tr_seri(2:klon-1,10,3),'TRACEUR3B')
789c
790c Flux lessivage total
791c
792      DO it = 1, nqmax
793           DO k = 1, nlev
794            DO i = 1, klon
795               flestottr(i,k,it) = flestottr(i,k,it) -
796     s                   ( d_tr_lessi_nucl(i,k,it)   +
797     s                     d_tr_lessi_impa(i,k,it) ) *
798     s                   ( paprs(i,k)-paprs(i,k+1) ) /
799     s                   (RG * pdtphys)
800            ENDDO
801           ENDDO
802c
803Cmaf        WRITE(itn,'(i1)') it
804Cmaf    CALL minmaxqfi(tr_seri(1,1,it),0.,1.e33,'tr(lessi) it='//itn)
805      ENDDO
806c
807c     print*,'apres lessivage'
808      ENDIF
809Cc
810      DO k = 1, nlev
811         DO i = 1, klon
812            fluxrn(i,k) = flestottr(i,k,1)
813            fluxpb(i,k) = flestottr(i,k,2)
814            rn(i,k) = tr_seri(i,k,1)
815            pb(i,k) = tr_seri(i,k,2)
816            pbnucl(i,k)=d_tr_lessi_nucl(i,k,2)
817            pbimpa(i,k)=d_tr_lessi_impa(i,k,2)
818         ENDDO
819      ENDDO
820
821c=============================================================
822c   Ecriture des sorties
823c=============================================================
824
825#ifdef CPP_IOIPSL
826#include "write_histrac.h"
827#endif
828
829c=============================================================
830
831      if (lafin) then
832         print*, 'c est la fin de la physique'
833         call Gather(trs(:,1),trs_tmp)
834c$OMP MASTER     
835         if (is_mpi_root) then
836         
837           open (99,file='restarttrac',  form='formatted')
838           do i=1,klon_glo
839               write(99,*) trs_tmp(i)
840           enddo
841           PRINT*, 'Ecriture du fichier restarttrac'
842           close(99)
843         endif
844c$OMP END MASTER
845      else
846c         print*, 'physique pas fini'
847      endif
848
849
850      RETURN
851      END
Note: See TracBrowser for help on using the repository browser.