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

Last change on this file since 5452 was 5337, checked in by Laurent Fairhead, 6 weeks ago

Getting rid of dependance to dynamics

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