source: LMDZ6/branches/Amaury_dev/libf/phylmd/tracinca_mod.F90 @ 5501

Last change on this file since 5501 was 5117, checked in by abarral, 6 months ago

rename modules properly lmdz_*
move some unused files to obsolete/
(lint) uppercase fortran keywords

  • 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: 7.7 KB
Line 
1!$Id $
2
3MODULE tracinca_mod
4
5  ! This module prepares and calls the INCA main subroutines.
6
7  IMPLICIT NONE
8
9  CHARACTER(len = 4), SAVE :: config_inca
10  !$OMP THREADPRIVATE(config_inca)
11  ! config_inca='none' => without INCA
12  ! config_inca='chem' => INCA with chemistry
13  ! config_inca='aero' => INCA with aerosols
14  ! config_inca='aeNP' => INCA with aerosols NP (?)
15CONTAINS
16
17  SUBROUTINE tracinca_init(aerosol, lessivage)
18    ! This SUBROUTINE initialize some control varaibles.
19
20    USE infotrac_phy, ONLY: nbtr, type_trac
21    USE lmdz_abort_physic, ONLY: abort_physic
22    IMPLICIT NONE
23
24    ! Output variables
25    LOGICAL, DIMENSION(nbtr), INTENT(OUT) :: aerosol
26    LOGICAL, INTENT(OUT) :: lessivage
27
28    ! Initialization
29    lessivage = .FALSE.
30    aerosol(:) = .FALSE.
31
32    !--- COHERENCE TEST BETWEEN "type_trac" AND "config_inca"
33    IF(ANY(type_trac == ['inca', 'inco']) .AND. ALL(config_inca /= ['aero', 'aeNP', 'chem'])) CALL abort_physic('tracinca_init', &
34            'INCA enabled, but unknown config_inca = "' // TRIM(config_inca) // '". Please modify "run.def"', 1)
35
36    !--- PROBLEM IF "config_inca" DIFFERS FROM "none" AND INCA HAS NOT BEEN ACTIVATED
37    IF(ALL(type_trac /= ['inca', 'inco'])  .AND.    config_inca /= 'none')                  CALL abort_physic('tracinca_init', &
38            'INCA disabled, but config_inca = "' // TRIM(config_inca) // '" should be "none". Please modify "run.def"', 1)
39
40  END SUBROUTINE tracinca_init
41
42  SUBROUTINE tracinca(&
43          nstep, julien, gmtime, lafin, &
44          pdtphys, t_seri, paprs, pplay, &
45          pmfu, upwd, ftsol, pctsrf, pphis, &
46          pphi, albsol, sh, ch, rh, &
47          cldfra, rneb, diafra, cldliq, &
48          itop_con, ibas_con, pmflxr, pmflxs, &
49          prfl, psfl, aerosol_couple, flxmass_w, &
50          tau_aero, piz_aero, cg_aero, ccm, &
51          rfname, &
52          tr_seri, source)
53
54    !========================================================
55    !    -- CHIMIE INCA --
56    !========================================================
57
58    USE dimphy
59    USE infotrac_phy, ONLY: nbtr
60    USE lmdz_vampir
61    USE indice_sol_mod
62    USE lmdz_geometry, ONLY: cell_area
63    USE lmdz_grid_phy, ONLY: nbp_lon, nbp_lat
64    USE aero_mod, ONLY: naero_grp
65    USE lmdz_cppkeys_wrapper, ONLY: CPPKEY_INCA
66    IMPLICIT NONE
67
68    !==========================================================================
69    !                   -- DESCRIPTION DES ARGUMENTS --
70    !==========================================================================
71
72
73    ! EN ENTREE ...
74
75    !Configuration grille,temps:
76    INTEGER, INTENT(IN) :: nstep      ! Appel physique
77    INTEGER, INTENT(IN) :: julien     ! Jour julien
78    REAL, INTENT(IN) :: gmtime
79    REAL, INTENT(IN) :: pdtphys    ! Pas d'integration pour la physique (seconde)
80    LOGICAL, INTENT(IN) :: lafin      ! le flag de la fin de la physique
81
82
83    !Physique:
84    !--------
85    REAL, DIMENSION(klon, klev), INTENT(IN) :: t_seri  ! Temperature
86    REAL, DIMENSION(klon, klev), INTENT(IN) :: sh      ! humidite specifique
87    REAL, DIMENSION(klon, klev), INTENT(IN) :: ch      ! eau liquide
88    REAL, DIMENSION(klon, klev), INTENT(IN) :: rh      ! humidite relative
89    REAL, DIMENSION(klon, klev + 1), INTENT(IN) :: paprs   ! pression pour chaque inter-couche (en Pa)
90    REAL, DIMENSION(klon, klev), INTENT(IN) :: pplay   ! pression pour le mileu de chaque couche (en Pa)
91    REAL, DIMENSION(klon, klev), INTENT(IN) :: pphi    ! geopotentiel
92    REAL, DIMENSION(klon), INTENT(IN) :: pphis
93    REAL, DIMENSION(klon, klev), INTENT(IN) :: cldliq  ! eau condensee pour le radiatif
94    REAL, DIMENSION(klon, klev), INTENT(IN) :: cldfra  ! fraction nuageuse (tous les nuages)
95    REAL, DIMENSION(klon, klev), INTENT(IN) :: diafra  ! fraction nuageuse (convection ou stratus artificiels)
96    REAL, DIMENSION(klon, klev), INTENT(IN) :: rneb    ! fraction nuageuse (grande echelle)
97    INTEGER, DIMENSION(klon), INTENT(IN) :: itop_con
98    INTEGER, DIMENSION(klon), INTENT(IN) :: ibas_con
99    REAL, DIMENSION(klon), INTENT(IN) :: albsol  ! albedo surface
100
101    !Convection:
102    !----------
103    REAL, DIMENSION(klon, klev), INTENT(IN) :: pmfu  ! flux de masse dans le panache montant - Tiedtke
104    REAL, DIMENSION(klon, klev), INTENT(IN) :: upwd  ! flux de masse dans le panache montant - Emanuel
105
106    !...Tiedke
107    REAL, DIMENSION(klon, klev + 1), INTENT(IN) :: pmflxr, pmflxs ! Flux precipitant de pluie, neige aux interfaces [convection]
108    REAL, DIMENSION(klon, klev + 1), INTENT(IN) :: prfl, psfl ! Flux precipitant de pluie, neige aux interfaces [large-scale]
109
110    LOGICAL, INTENT(IN) :: aerosol_couple
111    REAL, DIMENSION(klon, klev), INTENT(IN) :: flxmass_w
112    REAL, DIMENSION(klon, klev, naero_grp, 2), INTENT(IN) :: tau_aero
113    REAL, DIMENSION(klon, klev, naero_grp, 2), INTENT(IN) :: piz_aero
114    REAL, DIMENSION(klon, klev, naero_grp, 2), INTENT(IN) :: cg_aero
115    CHARACTER(len = 4), DIMENSION(naero_grp), INTENT(IN) :: rfname
116    REAL, DIMENSION(klon, klev, 2), INTENT(IN) :: ccm
117
118    ! Arguments necessaires pour les sources et puits de traceur:
119    REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: ftsol  ! Temperature du sol (surf)(Kelvin)
120    REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: pctsrf ! Pourcentage de sol f(nature du sol)
121
122
123    ! InOutput argument
124    REAL, DIMENSION(klon, klev, nbtr), INTENT(INOUT) :: tr_seri ! Concentration Traceur [U/KgA]
125
126    ! Output arguments
127    REAL, DIMENSION(klon, nbtr), INTENT(OUT) :: source  ! a voir lorsque le flux de surface est prescrit
128
129    !=======================================================================================
130    !                        -- VARIABLES LOCALES TRACEURS --
131    !=======================================================================================
132
133    INTEGER :: k
134    REAL, DIMENSION(klon, klev) :: pdel
135    REAL, DIMENSION(klon, klev) :: zpmfu  ! flux de masse dans le panache montant
136    REAL :: calday
137    INTEGER :: ncsec
138
139    CALL VTe(VTphysiq)
140    CALL VTb(VTinca)
141
142    calday = REAL(julien) + gmtime
143    ncsec = NINT (86400. * gmtime)
144
145    DO k = 1, klev
146      pdel(:, k) = paprs(:, k) - paprs (:, k + 1)
147    END DO
148
149    IF (CPPKEY_INCA) THEN
150      IF (config_inca == 'aero' .OR. config_inca == 'chem') THEN
151        zpmfu(:, :) = pmfu(:, :)
152      ELSE IF (config_inca == 'aeNP') THEN
153        zpmfu(:, :) = upwd(:, :)
154      ENDIF
155
156      CALL aerosolmain(&
157              aerosol_couple, tr_seri, pdtphys, &
158              pplay, pdel, prfl, pmflxr, psfl, &
159              pmflxs, zpmfu, itop_con, ibas_con, &
160              pphi, cell_area, nstep, rneb, t_seri, &
161              rh, tau_aero, piz_aero, cg_aero, &
162              rfname, ccm, lafin)
163
164      CALL chemmain (tr_seri, &   !mmr
165              nstep, & !nstep
166              calday, & !calday
167              julien, & !ncdate
168              ncsec, & !ncsec
169              1, & !lat
170              pdtphys, & !delt
171              paprs(1, 1), & !ps
172              pplay, & !pmid
173              pdel, & !pdel
174              cell_area, &
175              pctsrf(1, 1), & !oro
176              ftsol, & !tsurf
177              albsol, & !albs
178              pphi, & !zma
179              pphis, & !phis
180              cldfra, & !cldfr
181              rneb, & !cldfr_st
182              diafra, & !cldfr_cv
183              itop_con, & !cldtop
184              ibas_con, & !cldbot
185              cldliq, & !cwat
186              prfl, & !flxrst
187              pmflxr, & !flxrcv
188              psfl, & !flxsst
189              pmflxs, & !flxscv
190              zpmfu, & !flxupd   !--now depends on whether AP or NP
191              flxmass_w, & !flxmass_w
192              t_seri, & !tfld
193              sh, & !sh
194              ch, & !ql
195              rh, & !rh
196              nbp_lon, & !nx
197              nbp_lat, & !ny
198              source)
199    END IF
200
201    CALL VTe(VTinca)
202    CALL VTb(VTphysiq)
203
204  END SUBROUTINE tracinca
205
206
207END MODULE tracinca_mod
Note: See TracBrowser for help on using the repository browser.