source: LMDZ6/trunk/libf/phylmd/Dust/finemission.f90 @ 5327

Last change on this file since 5327 was 5292, checked in by abarral, 3 weeks ago

Move academic.h chem.h chem_spla.h to module

File size: 5.6 KB
RevLine 
[5246]1! This subroutine calculates the emissions of BLACK CARBON and ORGANIC
2! MATTER
3SUBROUTINE finemission(zdz,pdtphys,zalt,kminbc,kmaxbc, &
4        scale_param_bb,scale_param_ff, &
5        iregion_ind,iregion_bb, &
6        nbreg_ind,nbreg_bb, &
7        lmt_bcff,lmt_bcnff,lmt_bcbb_l,lmt_bcbb_h, &
8        lmt_bcba,lmt_omff,lmt_omnff,lmt_ombb_l, &
9        lmt_ombb_h,lmt_omnat,lmt_omba,id_fine, &
10        flux_sparam_bb,flux_sparam_ff, &
11        source_tr,flux_tr,tr_seri)
[2630]12
[5292]13USE chem_mod_h
14    USE dimphy
[5246]15  USE indice_sol_mod
16  USE infotrac
17   ! USE phytracr_spl_mod, ONLY : nbreg_dust, nbreg_ind, nbreg_bb
[5271]18  USE dimensions_mod, ONLY: iim, jjm, llm, ndm
[5285]19USE paramet_mod_h
20USE yomcst_mod_h
[5271]21IMPLICIT NONE
[2630]22
[5271]23
[2630]24
[5272]25
[5274]26
[5246]27  INTEGER :: i, k, kminbc, kmaxbc
28  !============================= INPUT ===================================
29  REAL :: pdtphys  ! pas d'integration pour la physique (seconde)
30  REAL :: zalt(klon,klev)
31  REAL :: zdz(klon,klev)
32  !
33  !------------------------- Scaling Parameters --------------------------
34  !
35  INTEGER :: nbreg_ind,nbreg_bb
36  INTEGER :: iregion_ind(klon)  !Defines regions for SO2, BC & OM
37  INTEGER :: iregion_bb(klon)   !Defines regions for SO2, BC & OM
38  REAL :: scale_param_bb(nbreg_bb) !Scaling parameter for biomas burning
39  REAL :: scale_param_ff(nbreg_ind) !Scaling parameter for industrial emissions (fossil fuel)
40  INTEGER :: id_fine
41  !============================= OUTPUT ==================================
42  REAL :: source_tr(klon,nbtr)
43  REAL :: flux_tr(klon,nbtr)
44  REAL :: tr_seri(klon,klev,nbtr) ! traceur
45  REAL :: flux_sparam_bb(klon), flux_sparam_ff(klon)
46  !========================= LOCAL VARIABLES =============================
47  REAL :: zzdz
48  !------------------------- BLACK CARBON emissions ----------------------
49  REAL :: lmt_bcff(klon)       ! emissions de BC fossil fuels
50  REAL :: lmt_bcnff(klon)      ! emissions de BC non-fossil fuels
51  REAL :: lmt_bcbb_l(klon)     ! emissions de BC biomass basses
52  REAL :: lmt_bcbb_h(klon)     ! emissions de BC biomass hautes
53  REAL :: lmt_bcba(klon)       ! emissions de BC bateau
54  !------------------------ ORGANIC MATTER emissions ---------------------
55  REAL :: lmt_omff(klon)     ! emissions de OM fossil fuels
56  REAL :: lmt_omnff(klon)    ! emissions de OM non-fossil fuels
57  REAL :: lmt_ombb_l(klon)   ! emissions de OM biomass basses
58  REAL :: lmt_ombb_h(klon)   ! emissions de OM biomass hautes
59  REAL :: lmt_omnat(klon)    ! emissions de OM Natural
60  REAL :: lmt_omba(klon)     ! emissions de OM bateau
[2630]61
[5246]62  EXTERNAL condsurfc
63  !========================================================================
64                     ! LOW LEVEL EMISSIONS
65  !========================================================================
[2630]66
[5246]67  ! corresponds to bc_source.EQ.3
[2630]68
[5246]69  DO i=1,klon
70     IF (iregion_ind(i).GT.0) THEN
71   IF(id_fine>0)    source_tr(i,id_fine)=source_tr(i,id_fine)+ &
72         (scale_param_ff(iregion_ind(i))*lmt_bcff(i)+ & !g/m2/s
73         scale_param_ff(iregion_ind(i))*lmt_omff(i) &
74         )     * 1.e4                        !g/m2/s
75  !
76  IF(id_fine>0)     flux_tr(i,id_fine)=flux_tr(i,id_fine)+ &
77        (scale_param_ff(iregion_ind(i))*lmt_bcff(i)+ & !mg/m2/s
78        scale_param_ff(iregion_ind(i))*lmt_omff(i) &
79        )     * 1.e4 *1.e3                  !mg/m2/s
80  !
81       flux_sparam_ff(i)= flux_sparam_ff(i) + &
82             scale_param_ff(iregion_ind(i))* &
83             ( lmt_bcff(i)+lmt_omff(i)) &
84             *1.e4*1.e3
85     ENDIF
86     IF (iregion_bb(i).GT.0) THEN
87   IF(id_fine>0)    source_tr(i,id_fine)=source_tr(i,id_fine)+ &
88         (scale_param_bb(iregion_bb(i))*lmt_bcbb_l(i)+ & !g/m2/s
89         scale_param_bb(iregion_bb(i))*lmt_ombb_l(i) & !g/m2/s
90         )     * 1.e4                        !g/m2/s
91  !
92   IF(id_fine>0)    flux_tr(i,id_fine)=flux_tr(i,id_fine)+ &
93         (scale_param_bb(iregion_bb(i))*lmt_bcbb_l(i)+ & !mg/m2/s
94         scale_param_bb(iregion_bb(i))*lmt_ombb_l(i)+ & !mg/m2/s
95         scale_param_bb(iregion_bb(i))*lmt_bcbb_h(i)+ & !mg/m2/s
96         scale_param_bb(iregion_bb(i))*lmt_ombb_h(i) & !mg/m2/s
97         )     * 1.e4 *1.e3                  !mg/m2/s
98  !
99       flux_sparam_bb(i)=flux_sparam_bb(i) + &
100             scale_param_bb(iregion_bb(i))*(lmt_bcbb_l(i) + &
101             lmt_bcbb_h(i) + lmt_ombb_l(i) + lmt_ombb_h(i)) &
102             *1.e4*1.e3
103     ENDIF
104   IF(id_fine>0)  source_tr(i,id_fine)=source_tr(i,id_fine)+ &
105         (lmt_bcnff(i)+lmt_bcba(i)+lmt_omnff(i)+ &
106         lmt_omnat(i)+lmt_omba(i))     * 1.e4           !g/m2/s
107  !
108   IF(id_fine>0)  flux_tr(i,id_fine)=flux_tr(i,id_fine)+ &
109         (lmt_bcnff(i)+lmt_omnff(i)+lmt_omnat(i)+ &
110         lmt_omba(i)+lmt_bcba(i))     * 1.e4 *1.e3      !mg/m2/s
111  !
112     flux_sparam_ff(i)= flux_sparam_ff(i) + &
113           (lmt_omba(i)+lmt_bcba(i))*1.e4*1.e3
114  ENDDO
[2630]115
[5246]116  !========================================================================
117                     ! HIGH LEVEL EMISSIONS
118  !========================================================================
119
120  !  Sources hautes de BC/OM
121
122  !
123  ! HIGH LEVEL EMISSIONS OF SO2 ARE IN PRECUREMISSION.F
124  !
125  k=2                             !introducing emissions in level 2
126  !nhl      DO i = 1, klon
127  !
128  !nhl      tr_seri(i,k,id_fine)=tr_seri(i,k,id_fine)+scale_param_ff(iregion_ind(i))*
129  !nhl     .               (lmt_bcff_h(i)+lmt_omff_h(i))/zdz(i,k)/100.*pdtphys
130  !
131  !nhl      ENDDO
132
133  DO k=kminbc, kmaxbc
134  DO i = 1, klon
135      zzdz=zalt(i,kmaxbc+1)-zalt(i,kminbc)
136  !
137     IF (iregion_bb(i) .GT.0) THEN
138    IF(id_fine>0)   tr_seri(i,k,id_fine)=tr_seri(i,k,id_fine)+ &
139          (scale_param_bb(iregion_bb(i))*lmt_bcbb_h(i)+ &
140          scale_param_bb(iregion_bb(i))*lmt_ombb_h(i)) &
141          /zzdz/100.*pdtphys
142     ENDIF
143  !
144  ENDDO
145  ENDDO
146  !
147END SUBROUTINE finemission
Note: See TracBrowser for help on using the repository browser.