1 | MODULE dustemission_mod |
---|
2 | |
---|
3 | IMPLICIT NONE |
---|
4 | !Parameters |
---|
5 | ! INTEGER, PARAMETER :: nbins=12 ! number of aerosol bins: original |
---|
6 | ! INTEGER, PARAMETER :: nbins=800 ! number of aerosol bins: for spla |
---|
7 | ! INTEGER, PARAMETER :: nbins=8000 ! number of aerosol bins: for spla |
---|
8 | |
---|
9 | INTEGER, PARAMETER :: flag_feff=1 ! 0: deactivate feff (drag partition scheme) |
---|
10 | INTEGER, PARAMETER :: nbins=800 ! number of aerosol bins: for spla |
---|
11 | INTEGER, PARAMETER :: nmode=3 ! number of soil-dust modes |
---|
12 | INTEGER, PARAMETER :: ntyp=5 ! number of soil types |
---|
13 | INTEGER, PARAMETER :: nwb=12 ! number of points for the 10m wind |
---|
14 | ! speed weibull distribution (>=2) |
---|
15 | real ,parameter :: z10m=1000. !10m in cm |
---|
16 | REAL,PARAMETER :: kref=3. !weibull parameter |
---|
17 | INTEGER, PARAMETER :: nats=14 !number of mineral types (14 here for sand, |
---|
18 | ! silt, clay etc.) |
---|
19 | integer, parameter :: nclass=200000 |
---|
20 | |
---|
21 | |
---|
22 | real , parameter :: dmin=0.0001 |
---|
23 | real , parameter :: dmax=0.2 |
---|
24 | integer, parameter :: nspe=nmode*3+1 |
---|
25 | real ,parameter :: vkarm=0.41 |
---|
26 | !JE20150202 : updating scheme to chimere13b <<< |
---|
27 | ! original values |
---|
28 | ! integer, parameter :: div1=3. |
---|
29 | ! integer, parameter :: div2=3. |
---|
30 | ! integer, parameter :: div3=3. |
---|
31 | ! real , parameter :: e1=3.61/div1 |
---|
32 | ! real , parameter :: e2=3.52/div2 |
---|
33 | ! real , parameter :: e3=3.46/div3 |
---|
34 | ! real , parameter :: rop=2.65 ! particle density g/m3 |
---|
35 | ! real , parameter :: roa=0.001227 ! air density g/m3 |
---|
36 | ! real , parameter :: pi=3.14159 !! |
---|
37 | ! real , parameter :: gravity=981. !! cm!! |
---|
38 | ! real , parameter :: cd=1.*roa/gravity |
---|
39 | ! new values |
---|
40 | ! logical, parameter :: ok_splatunning=.true. |
---|
41 | ! Div=3 from S. Alfaro (Sow et al ACPD 2011) |
---|
42 | !JE 20150206 |
---|
43 | integer, parameter :: div1=3. |
---|
44 | integer, parameter :: div2=3. |
---|
45 | integer, parameter :: div3=3. |
---|
46 | real , parameter :: e1=3.61/div1 |
---|
47 | real , parameter :: e2=3.52/div2 |
---|
48 | real , parameter :: e3=3.46/div3 |
---|
49 | real , parameter :: rop=2.65 ! particle density g/m3 |
---|
50 | real , parameter :: roa=0.001227 ! air density g/m3 |
---|
51 | real , parameter :: pi=3.14159 !! |
---|
52 | real , parameter :: gravity=981. !! cm!! |
---|
53 | ! C=2.61 from Marticorena and Bergametti 1995 instead of Gillete and Chen 2001 |
---|
54 | ! (recommended C=1.1 in supply-limited dust source area.. ) |
---|
55 | real , parameter :: cd=2.61*roa/gravity |
---|
56 | ! real , parameter :: cd=1.0*roa/gravity |
---|
57 | !JE20150202>>>> |
---|
58 | real,parameter :: beta=16300. |
---|
59 | real, parameter, dimension(3) :: diam=(/1.5,6.7,14.2/) |
---|
60 | INTEGER, PARAMETER :: ndistb=3 |
---|
61 | real, parameter, dimension(3) :: sig=(/1.7,1.6,1.5/) |
---|
62 | |
---|
63 | ! INTEGER, PARAMETER :: nbinsHR=3000 !original |
---|
64 | INTEGER, PARAMETER :: nbinsHR=30000 |
---|
65 | !min and max dust size in um |
---|
66 | REAL, PARAMETER :: sizedustmin=0.0599 ! for spla |
---|
67 | REAL, PARAMETER :: sizedustmax=63. |
---|
68 | ! REAL, PARAMETER :: sizedustmin=0.09 ! original |
---|
69 | ! REAL, PARAMETER :: sizedustmax=63. |
---|
70 | |
---|
71 | |
---|
72 | ! Calc variables |
---|
73 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: massfrac |
---|
74 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: binsHR |
---|
75 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: binsHRcm |
---|
76 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: itv |
---|
77 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: sizedust !size dust bin (in um) |
---|
78 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: szdcm !the same but (in cm) |
---|
79 | |
---|
80 | !soil inputs from file donnees_lisa.nc . Should be in the same grid as the |
---|
81 | !model (regridded with nearest neighborhood from surfnew.nc) |
---|
82 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: sol |
---|
83 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: P |
---|
84 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: zos |
---|
85 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: z01 |
---|
86 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: z02 |
---|
87 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: D |
---|
88 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: A |
---|
89 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: solspe |
---|
90 | INTEGER,DIMENSION(:,:),ALLOCATABLE,SAVE :: masklisa |
---|
91 | !!! INTEGER,DIMENSION(:),ALLOCATABLE,SAVE :: maskdust |
---|
92 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: feff |
---|
93 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: feffdbg |
---|
94 | |
---|
95 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: sizeclass |
---|
96 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: sizeclass2 |
---|
97 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: uth |
---|
98 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: uth2 |
---|
99 | REAL,DIMENSION(:,:),ALLOCATABLE,SAVE :: srel |
---|
100 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: srel2 |
---|
101 | |
---|
102 | INTEGER :: nat ! SOL data inside the loop (use as soil type index?) |
---|
103 | REAL :: ustarsalt |
---|
104 | REAL :: var3a,var3b |
---|
105 | INTEGER :: ns,nd,nsi,npi,ni ! counters |
---|
106 | INTEGER :: ncl |
---|
107 | |
---|
108 | ! outputs |
---|
109 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: m1dflux !fluxes for each soil mode |
---|
110 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: m2dflux |
---|
111 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: m3dflux |
---|
112 | |
---|
113 | |
---|
114 | |
---|
115 | !$OMP THREADPRIVATE(m1dflux) |
---|
116 | !$OMP THREADPRIVATE(m2dflux) |
---|
117 | !$OMP THREADPRIVATE(m3dflux) |
---|
118 | !$OMP THREADPRIVATE(massfrac) |
---|
119 | !$OMP THREADPRIVATE(binsHR) |
---|
120 | !$OMP THREADPRIVATE(binsHRcm) |
---|
121 | !$OMP THREADPRIVATE(itv) |
---|
122 | !$OMP THREADPRIVATE(sizedust) |
---|
123 | !$OMP THREADPRIVATE(szdcm) |
---|
124 | !$OMP THREADPRIVATE(sol) |
---|
125 | !$OMP THREADPRIVATE(P) |
---|
126 | !$OMP THREADPRIVATE(zos) |
---|
127 | !$OMP THREADPRIVATE(z01) |
---|
128 | !$OMP THREADPRIVATE(z02) |
---|
129 | !$OMP THREADPRIVATE(D) |
---|
130 | !$OMP THREADPRIVATE(A) |
---|
131 | !$OMP THREADPRIVATE(solspe) |
---|
132 | !$OMP THREADPRIVATE(masklisa) |
---|
133 | !!!!$OMP THREADPRIVATE(maskdust) |
---|
134 | !$OMP THREADPRIVATE(feff) |
---|
135 | !$OMP THREADPRIVATE(feffdbg) |
---|
136 | !$OMP THREADPRIVATE(sizeclass) |
---|
137 | !$OMP THREADPRIVATE(sizeclass2) |
---|
138 | !$OMP THREADPRIVATE(uth) |
---|
139 | !$OMP THREADPRIVATE(uth2) |
---|
140 | !$OMP THREADPRIVATE(srel) |
---|
141 | !$OMP THREADPRIVATE(srel2) |
---|
142 | |
---|
143 | |
---|
144 | |
---|
145 | CONTAINS |
---|
146 | |
---|
147 | !-------------------------------------------------------------------------------------- |
---|
148 | !====================================================================================== |
---|
149 | !************************************************************************************** |
---|
150 | !====================================================================================== |
---|
151 | !-------------------------------------------------------------------------------------- |
---|
152 | |
---|
153 | SUBROUTINE dustemission( debutphy, xlat, xlon, & !Input |
---|
154 | pctsrf,zu10m,zv10m,wstar, & !Input |
---|
155 | ale_bl,ale_wake, & !Input |
---|
156 | param_wstarBL, param_wstarWAKE, & !Input |
---|
157 | emdustacc,emdustcoa,emdustsco,maskdust) !Output |
---|
158 | USE dimphy |
---|
159 | USE infotrac |
---|
160 | USE write_field_phy |
---|
161 | USE mod_grid_phy_lmdz |
---|
162 | USE mod_phys_lmdz_para |
---|
163 | |
---|
164 | IMPLICIT NONE |
---|
165 | ! input : |
---|
166 | ! output: flux_sparam_ddfine,flux_sparam_ddcoa, |
---|
167 | ! first: |
---|
168 | ! Model grid parameters |
---|
169 | REAL,DIMENSION(klon), INTENT(IN) :: xlat |
---|
170 | REAL,DIMENSION(klon), INTENT(IN) :: xlon |
---|
171 | REAL,DIMENSION(klon), INTENT(IN) :: pctsrf |
---|
172 | REAL,DIMENSION(klon),INTENT(IN) :: zu10m ! 10m zonal wind |
---|
173 | REAL,DIMENSION(klon),INTENT(IN) :: zv10m ! meridional 10m wind |
---|
174 | REAL,DIMENSION(klon),INTENT(IN) :: wstar |
---|
175 | REAL,DIMENSION(klon),INTENT(IN) :: ale_bl |
---|
176 | REAL,DIMENSION(klon),INTENT(IN) :: ale_wake |
---|
177 | REAL,DIMENSION(klon), INTENT(IN) :: param_wstarWAKE |
---|
178 | REAL,DIMENSION(klon), INTENT(IN) :: param_wstarBL |
---|
179 | |
---|
180 | |
---|
181 | LOGICAL :: debutphy ! First physiqs run or not |
---|
182 | ! Intermediate variable: 12 bins emissions |
---|
183 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: emisbinloc ! vertical emission fluxes |
---|
184 | |
---|
185 | !OUT variables |
---|
186 | REAL,DIMENSION(klon) :: emdustacc,emdustcoa,emdustsco ! emission in spla dust bins: |
---|
187 | ! old radio : acc=0.03-0.5 micrometers, ccoa:0.5-10 micrometers |
---|
188 | ! new acc=0.03-0.5 micrometers, coa:0.5-3 micrometers ,sco:3-15 um |
---|
189 | INTEGER,DIMENSION(klon) :: maskdust ! where the emissions were calculated |
---|
190 | ! INTEGER,DIMENSION(klon_glo) :: maskdust_glo ! auxiliar |
---|
191 | ! REAL,DIMENSION(klon_glo) :: raux_klon_glo ! auxiliar |
---|
192 | |
---|
193 | !$OMP THREADPRIVATE(emisbinloc) |
---|
194 | !!!!!!$OMP THREADPRIVATE(maskdust) |
---|
195 | IF (debutphy) THEN |
---|
196 | ALLOCATE( emisbinloc(klon,nbins) ) |
---|
197 | ENDIF |
---|
198 | |
---|
199 | IF( debutphy ) THEN |
---|
200 | CALL initdust(xlat,xlon,pctsrf) |
---|
201 | ENDIF |
---|
202 | |
---|
203 | !JE20141124 CALL calcdustemission(debutphy,zu10m,zv10m,wstar,ale_bl,ale_wake,emisbinloc) |
---|
204 | CALL calcdustemission(debutphy,zu10m,zv10m,wstar,ale_bl,ale_wake,param_wstarBL,param_wstarWAKE, & !I |
---|
205 | emisbinloc) !O |
---|
206 | |
---|
207 | CALL makemask(maskdust) |
---|
208 | |
---|
209 | IF( debutphy ) THEN |
---|
210 | ! call gather(maskdust,maskdust_glo) |
---|
211 | ! !$OMP MASTER |
---|
212 | ! IF (is_mpi_root .AND. is_omp_root) THEN |
---|
213 | ! CALL writefield_phy("maskdust",float(maskdust_glo),1) |
---|
214 | CALL writefield_phy("maskdust",float(maskdust),1) |
---|
215 | ! ENDIF |
---|
216 | ! !$OMP END MASTER |
---|
217 | ! !$OMP BARRIER |
---|
218 | ENDIF |
---|
219 | |
---|
220 | CALL adaptdustemission(debutphy,emisbinloc,emdustacc,emdustcoa,emdustsco) |
---|
221 | ! output in kg/m2/s |
---|
222 | |
---|
223 | |
---|
224 | END SUBROUTINE dustemission |
---|
225 | |
---|
226 | !-------------------------------------------------------------------------------------- |
---|
227 | !====================================================================================== |
---|
228 | !************************************************************************************** |
---|
229 | !====================================================================================== |
---|
230 | !-------------------------------------------------------------------------------------- |
---|
231 | |
---|
232 | SUBROUTINE makemask(maskdustloc) |
---|
233 | USE dimphy |
---|
234 | USE infotrac |
---|
235 | IMPLICIT NONE |
---|
236 | !Input |
---|
237 | INTEGER,DIMENSION(klon) :: maskdustloc |
---|
238 | INTEGER :: i,j,k |
---|
239 | integer :: iaux |
---|
240 | |
---|
241 | |
---|
242 | do k=1,klon |
---|
243 | maskdustloc(k)=0 |
---|
244 | do i=1,ntyp |
---|
245 | if (masklisa(k,i)>0) then |
---|
246 | maskdustloc(k)=1 |
---|
247 | endif |
---|
248 | enddo |
---|
249 | enddo |
---|
250 | |
---|
251 | END SUBROUTINE makemask |
---|
252 | |
---|
253 | !-------------------------------------------------------------------------------------- |
---|
254 | !====================================================================================== |
---|
255 | !************************************************************************************** |
---|
256 | !====================================================================================== |
---|
257 | !-------------------------------------------------------------------------------------- |
---|
258 | |
---|
259 | SUBROUTINE adaptdustemission(debutphy,emisbinlocal, & |
---|
260 | emdustacc,emdustcoa,emdustsco) |
---|
261 | |
---|
262 | USE dimphy |
---|
263 | USE infotrac |
---|
264 | USE write_field_phy |
---|
265 | USE mod_grid_phy_lmdz |
---|
266 | USE mod_phys_lmdz_para |
---|
267 | |
---|
268 | IMPLICIT NONE |
---|
269 | !Input |
---|
270 | REAL,DIMENSION(klon) :: emdustacc,emdustcoa,emdustsco |
---|
271 | REAL, DIMENSION(klon,nbins) :: emisbinlocal |
---|
272 | ! Local |
---|
273 | INTEGER :: i,j,k |
---|
274 | !!! INTEGER,DIMENSION(2) :: iminacclow,iminacchigh,imincoalow,imincoahigh ! in |
---|
275 | !case of small nbins.... not ready |
---|
276 | INTEGER,SAVE ::iminacclow,iminacchigh,imincoalow |
---|
277 | INTEGER,SAVE ::imincoahigh,iminscohigh,iminscolow |
---|
278 | ! real,parameter :: sizeacclow=0.03 |
---|
279 | ! real,parameter :: sizeacchigh=0.5 |
---|
280 | ! real,parameter :: sizecoalow=0.5 |
---|
281 | ! real,parameter :: sizecoahigh=10. ! in micrometers |
---|
282 | real,parameter :: sizeacclow=0.06 |
---|
283 | real,parameter :: sizeacchigh=1.0 |
---|
284 | real,parameter :: sizecoalow=1.0 |
---|
285 | real,parameter :: sizecoahigh=6. !20 ! diameter in micrometers |
---|
286 | real,parameter :: sizescolow=6. |
---|
287 | real,parameter :: sizescohigh=30. ! in micrometers |
---|
288 | |
---|
289 | real,parameter :: tunningfactor=4.5 ! factor for fine bins!!! important!! |
---|
290 | !JE20140915 real,parameter :: sizeacclow=0.06 |
---|
291 | !JE20140915 real,parameter :: sizeacchigh=1.0 |
---|
292 | !JE20140915 real,parameter :: sizecoalow=1.0 |
---|
293 | !JE20140915 real,parameter :: sizecoahigh=10. !20 ! diameter in micrometers |
---|
294 | !JE20140915 real,parameter :: sizescolow=10. |
---|
295 | !JE20140915 real,parameter :: sizescohigh=30. ! in micrometers |
---|
296 | |
---|
297 | |
---|
298 | |
---|
299 | logical :: debutphy |
---|
300 | real :: diff, auxr1,auxr2,auxr3,auxr4 |
---|
301 | real,dimension(klon,nbins) :: itvmean |
---|
302 | real,dimension(klon,nbins+1) :: itv2 |
---|
303 | ! real,dimension(klon_glo,nbins) :: itvmean_glo |
---|
304 | ! real,dimension(:,:) , allocatable :: itvmean_glo |
---|
305 | ! real,dimension(:,:), allocatable :: itv2_glo |
---|
306 | |
---|
307 | integer, save :: counter,counter1 !dbg |
---|
308 | REAL, DIMENSION(:,:),ALLOCATABLE,SAVE :: emisbinlocalmean,emisbinlocalmean2 !dbg |
---|
309 | REAL, DIMENSION(:,:),ALLOCATABLE :: emisbinlocalmean2_glo |
---|
310 | logical :: writeaerosoldistrib |
---|
311 | !$OMP THREADPRIVATE(iminacclow,iminacchigh,imincoalow,imincoahigh) |
---|
312 | |
---|
313 | writeaerosoldistrib=.false. |
---|
314 | if (debutphy) then |
---|
315 | |
---|
316 | if (sizedustmin>sizeacclow .or. sizedustmax<sizescohigh) then |
---|
317 | call abort_gcm('adaptdustemission', 'Dust range problem',1) |
---|
318 | endif |
---|
319 | print *,'ALL DUST BIN: tunning EMISSION factor= ',tunningfactor |
---|
320 | auxr1=9999. |
---|
321 | auxr2=9999. |
---|
322 | auxr3=9999. |
---|
323 | auxr4=9999. |
---|
324 | do i=1,nbins+1 |
---|
325 | if (abs(sizeacclow-itv(i))<auxr1) then |
---|
326 | auxr1=abs( sizeacclow-itv(i)) |
---|
327 | iminacclow=i |
---|
328 | endif |
---|
329 | if (abs(sizeacchigh-itv(i))<auxr2) then |
---|
330 | auxr2=abs( sizeacchigh-itv(i)) |
---|
331 | iminacchigh=i |
---|
332 | imincoalow=i |
---|
333 | endif |
---|
334 | if (abs(sizecoahigh-itv(i))<auxr3) then |
---|
335 | auxr3=abs( sizecoahigh-itv(i)) |
---|
336 | imincoahigh=i |
---|
337 | iminscolow=i |
---|
338 | endif |
---|
339 | if (abs(sizescohigh-itv(i))<auxr4) then |
---|
340 | auxr4=abs( sizescohigh-itv(i)) |
---|
341 | iminscohigh=i |
---|
342 | endif |
---|
343 | enddo |
---|
344 | if (writeaerosoldistrib) then |
---|
345 | !JEdbg<< |
---|
346 | do j=1,klon |
---|
347 | do i=1,nbins |
---|
348 | itvmean(j,i)=(itv(i)+itv(i+1))/2. |
---|
349 | itv2(j,i)=itv(i) |
---|
350 | !print*, itv(i),itvmean(i),itv(i+1) |
---|
351 | !print*, sizedust(i) |
---|
352 | enddo |
---|
353 | itv2(j,nbins+1)=itv(nbins+1) |
---|
354 | enddo |
---|
355 | ! allocate(itv2_glo(klon_glo,nbins+1)) |
---|
356 | ! allocate(itvmean_glo(klon_glo,nbins)) |
---|
357 | ! ALLOCATE(emisbinlocalmean2_glo(klon_glo,nbins)) |
---|
358 | ! call gather(itv2,itv2_glo) |
---|
359 | ! call gather(itvmean,itvmean_glo) |
---|
360 | !!$OMP MASTER |
---|
361 | ! IF (is_mpi_root .AND. is_omp_root) THEN |
---|
362 | ! CALL writefield_phy("itv2",itv2_glo,nbins+1) |
---|
363 | ! CALL writefield_phy("itvmean",itvmean_glo,nbins) |
---|
364 | CALL writefield_phy("itv2",itv2,nbins+1) |
---|
365 | CALL writefield_phy("itvmean",itvmean,nbins) |
---|
366 | ! ENDIF |
---|
367 | !!$OMP END MASTER |
---|
368 | !!$OMP BARRIER |
---|
369 | ALLOCATE(emisbinlocalmean(klon,nbins)) |
---|
370 | ALLOCATE(emisbinlocalmean2(klon,nbins)) |
---|
371 | do i=1,nbins |
---|
372 | do j=1,klon |
---|
373 | emisbinlocalmean(j,i)=0.0 |
---|
374 | emisbinlocalmean2(j,i)=0.0 |
---|
375 | enddo |
---|
376 | enddo |
---|
377 | counter=1 |
---|
378 | counter1=0 |
---|
379 | !JEdbg>> |
---|
380 | endif |
---|
381 | endif |
---|
382 | |
---|
383 | |
---|
384 | !print *,'JE' |
---|
385 | !print *,iminacclow,iminacchigh,imincoalow,imincoahigh |
---|
386 | |
---|
387 | ! estimate and integrate bins into only accumulation and coarse |
---|
388 | |
---|
389 | |
---|
390 | do k=1,klon |
---|
391 | auxr1=0.0 |
---|
392 | auxr2=0.0 |
---|
393 | auxr3=0.0 |
---|
394 | do i=iminacclow,iminacchigh-1 |
---|
395 | auxr1=auxr1+emisbinlocal(k,i) |
---|
396 | enddo |
---|
397 | emdustacc(k)= auxr1*tunningfactor |
---|
398 | do i=imincoalow,imincoahigh-1 |
---|
399 | auxr2=auxr2+emisbinlocal(k,i) |
---|
400 | enddo |
---|
401 | emdustcoa(k)=auxr2*tunningfactor |
---|
402 | do i=iminscolow,iminscohigh-1 |
---|
403 | auxr3=auxr3+emisbinlocal(k,i) |
---|
404 | enddo |
---|
405 | emdustsco(k)=auxr3*tunningfactor |
---|
406 | enddo |
---|
407 | |
---|
408 | !JEdbg<< |
---|
409 | if (writeaerosoldistrib) then |
---|
410 | do i=1,nbins |
---|
411 | do j=1,klon |
---|
412 | emisbinlocalmean(j,i)=emisbinlocalmean(j,i)+emisbinlocal(j,i) |
---|
413 | enddo |
---|
414 | enddo |
---|
415 | counter1=counter1+1 |
---|
416 | ! 4 timesteps of physics=4*15min=1hour.. |
---|
417 | ! 1440 = 15 days |
---|
418 | ! 480 = 5 days |
---|
419 | if (MOD(counter,1440).eq. 0) THEN |
---|
420 | !if (MOD(counter,480).eq. 0) THEN |
---|
421 | do k = 1,klon |
---|
422 | do i=1,nbins |
---|
423 | emisbinlocalmean2(k,i)=emisbinlocalmean(k,i)/float(counter1) |
---|
424 | enddo |
---|
425 | enddo |
---|
426 | counter1=0 |
---|
427 | ! call gather(emisbinlocalmean2,emisbinlocalmean2_glo) |
---|
428 | !!$OMP MASTER |
---|
429 | ! IF (is_mpi_root .AND. is_omp_root) THEN |
---|
430 | ! CALL writefield_phy("emisbinlocalmean2",emisbinlocalmean2_glo,nbins) |
---|
431 | CALL writefield_phy("emisbinlocalmean2",emisbinlocalmean2,nbins) |
---|
432 | ! ENDIF |
---|
433 | !!$OMP END MASTER |
---|
434 | !!$OMP BARRIER |
---|
435 | do i=1,nbins |
---|
436 | do j=1,klon |
---|
437 | emisbinlocalmean(j,i)=0.0 |
---|
438 | enddo |
---|
439 | enddo |
---|
440 | endif |
---|
441 | counter=counter+1 |
---|
442 | endif |
---|
443 | !JEdbg>> |
---|
444 | |
---|
445 | !CALL abort_gcm('calcdustemission', 'OK1',1) |
---|
446 | |
---|
447 | END SUBROUTINE adaptdustemission |
---|
448 | |
---|
449 | |
---|
450 | !-------------------------------------------------------------------------------------- |
---|
451 | !====================================================================================== |
---|
452 | !************************************************************************************** |
---|
453 | !====================================================================================== |
---|
454 | !-------------------------------------------------------------------------------------- |
---|
455 | |
---|
456 | |
---|
457 | !-------------------------------------------------------- |
---|
458 | SUBROUTINE initdust(xlat,xlon,pctsrf) |
---|
459 | USE dimphy |
---|
460 | USE infotrac |
---|
461 | USE write_field_phy |
---|
462 | USE mod_grid_phy_lmdz |
---|
463 | USE mod_phys_lmdz_para |
---|
464 | |
---|
465 | IMPLICIT NONE |
---|
466 | !Inputs |
---|
467 | REAL,DIMENSION(klon), INTENT(IN) :: xlat |
---|
468 | REAL,DIMENSION(klon), INTENT(IN) :: xlon |
---|
469 | REAL,DIMENSION(klon), INTENT(IN) :: pctsrf |
---|
470 | |
---|
471 | !Local |
---|
472 | REAL,DIMENSION(klon,ntyp) :: solini |
---|
473 | REAL,DIMENSION(klon,ntyp) :: Pini |
---|
474 | REAL,DIMENSION(klon,ntyp) :: zosini |
---|
475 | REAL,DIMENSION(klon,ntyp) :: z01ini |
---|
476 | REAL,DIMENSION(klon,ntyp) :: z02ini |
---|
477 | REAL,DIMENSION(klon,ntyp) :: Dini |
---|
478 | REAL,DIMENSION(klon,ntyp) :: Aini |
---|
479 | |
---|
480 | REAL,DIMENSION(nclass) :: newstep |
---|
481 | |
---|
482 | !TEMPORAL/ MAKE MASK!!! |
---|
483 | REAL, PARAMETER :: longmin=-20. |
---|
484 | REAL, PARAMETER :: longmax=77. !35. |
---|
485 | REAL, PARAMETER :: latmin=10. |
---|
486 | REAL, PARAMETER :: latmax=40. |
---|
487 | !TEMPORAL/ MAKE MASK!!! |
---|
488 | !Local |
---|
489 | REAL, PARAMETER :: eps=1.e-5 |
---|
490 | REAL, PARAMETER :: aeff=0.35 |
---|
491 | REAL, PARAMETER :: xeff=10. |
---|
492 | REAL, PARAMETER :: trctunt=0.310723 |
---|
493 | |
---|
494 | INTEGER :: i,j,k,nts |
---|
495 | REAL :: dp,dstep |
---|
496 | ! Parametres pour le calcul de la repartition de l energie feff(klon,ntyp) |
---|
497 | REAL :: aa,bb,cc,dd,ee,ff |
---|
498 | REAL,DIMENSION(klon,ntyp) :: tmp1 |
---|
499 | REAL :: p3t,var1,var2,et |
---|
500 | |
---|
501 | ! Parametres pour le calcul de la surface couverte par les particule de diametre |
---|
502 | ! dp srel(nats,nclass) |
---|
503 | REAL :: stotale,su,su_loc,xk,xl,xm,xn |
---|
504 | REAL,DIMENSION(nclass) :: subsoildist |
---|
505 | |
---|
506 | ! isolog and massfrac calcs |
---|
507 | INTEGER :: nbinsout,nb,miniso,nbins1,nbins2,istart,no |
---|
508 | REAL :: b1,b2,stepbin,minisograd,exden,d2min,d2max,numin,numax |
---|
509 | REAL :: delta1,delta2,ldmd |
---|
510 | ! REAL, PARAMETER :: sizedustmin=0.09 |
---|
511 | REAL,DIMENSION(nbinsHR):: binsISOGRAD |
---|
512 | REAL,DIMENSION(nbinsHR):: vdISOGRAD |
---|
513 | REAL,DIMENSION(nbinsHR):: logvdISOGRAD |
---|
514 | REAL :: curvd |
---|
515 | REAL :: avdhr |
---|
516 | REAL :: bvdhr |
---|
517 | REAL,DIMENSION(nbins) :: dmn1 |
---|
518 | REAL,DIMENSION(nbins) :: dmn2 |
---|
519 | REAL,DIMENSION(nbins) :: dmn3 |
---|
520 | REAL,DIMENSION(nbinsHR) :: vdHR |
---|
521 | REAL,DIMENSION(nbinsHR) :: vdout |
---|
522 | |
---|
523 | |
---|
524 | |
---|
525 | ! Parametres pour le calcul de la vitesse de friction seuil uth(nclass) |
---|
526 | ! calcul de la vitesse seuil selon la parametrisation de Shao and Lu |
---|
527 | ! 2000(icuth=1). |
---|
528 | ! INTEGER :: ich1 |
---|
529 | REAL :: an |
---|
530 | REAL :: gam |
---|
531 | REAL :: sigshao |
---|
532 | REAL :: x1 |
---|
533 | REAL :: x2 |
---|
534 | ! Cas de Iversen and White 1982 (icuth=0) si necessaire. |
---|
535 | REAL, PARAMETER :: adust=1331.647 |
---|
536 | REAL, PARAMETER :: bdust=0.38194 |
---|
537 | REAL, PARAMETER :: xdust=1.561228 |
---|
538 | REAL, PARAMETER :: ddust=0.006/(rop*gravity) |
---|
539 | |
---|
540 | CHARACTER(LEN=10) :: varname |
---|
541 | CHARACTER(LEN=80) :: fnsolspe |
---|
542 | CHARACTER(LEN=200) :: line |
---|
543 | |
---|
544 | |
---|
545 | ! nats: number of mineral types (14 here for sand, silt, clay etc.) |
---|
546 | ALLOCATE( binsHR(nbinsHR) ) |
---|
547 | ALLOCATE( binsHRcm(nbinsHR) ) |
---|
548 | ALLOCATE( itv(nbins+1) ) |
---|
549 | ALLOCATE( sizedust(nbins) ) |
---|
550 | ALLOCATE( szdcm(nbins) ) |
---|
551 | ALLOCATE( massfrac(ndistb,nbins) ) |
---|
552 | ALLOCATE( sol(klon,ntyp) ) |
---|
553 | ALLOCATE( P(klon,ntyp) ) |
---|
554 | ALLOCATE( zos(klon,ntyp) ) |
---|
555 | ALLOCATE( z01(klon,ntyp) ) |
---|
556 | ALLOCATE( z02(klon,ntyp) ) |
---|
557 | ALLOCATE( D(klon,ntyp) ) |
---|
558 | ALLOCATE( A(klon,ntyp) ) |
---|
559 | ALLOCATE( masklisa(klon,ntyp) ) |
---|
560 | ALLOCATE( solspe(nats,nspe) ) |
---|
561 | ALLOCATE( feff(klon,ntyp) ) |
---|
562 | ALLOCATE( feffdbg(klon,ntyp) ) |
---|
563 | ALLOCATE( sizeclass(nclass) ) |
---|
564 | ALLOCATE( sizeclass2(nclass) ) |
---|
565 | ALLOCATE( uth(nclass) ) |
---|
566 | ALLOCATE( uth2(nclass) ) |
---|
567 | ALLOCATE( srel(nats,nclass) ) |
---|
568 | ALLOCATE( srel2(nats,nclass) ) |
---|
569 | ALLOCATE( m1dflux(klon) ) |
---|
570 | ALLOCATE( m2dflux(klon) ) |
---|
571 | ALLOCATE( m3dflux(klon) ) |
---|
572 | |
---|
573 | |
---|
574 | |
---|
575 | ! read input data from donnees_lisa.nc |
---|
576 | varname='SOL' |
---|
577 | CALL read_surface(varname,solini) |
---|
578 | varname='P' |
---|
579 | CALL read_surface(varname,Pini) |
---|
580 | varname='ZOS_' |
---|
581 | CALL read_surface(varname,zosini) |
---|
582 | varname='ZO1_' |
---|
583 | CALL read_surface(varname,z01ini) |
---|
584 | varname='ZO2_' |
---|
585 | CALL read_surface(varname,z02ini) |
---|
586 | varname='D' |
---|
587 | CALL read_surface(varname,Dini) |
---|
588 | varname='A' |
---|
589 | CALL read_surface(varname,Aini) |
---|
590 | print *,'beforewritephy',mpi_rank,omp_rank |
---|
591 | CALL writefield_phy("SOLinit",solini,5) |
---|
592 | CALL writefield_phy("Pinit",Pini,5) |
---|
593 | CALL writefield_phy("ZOSinit",zosini,5) |
---|
594 | CALL writefield_phy("ZO1init",z01ini,5) |
---|
595 | CALL writefield_phy("ZO2init",z02ini,5) |
---|
596 | CALL writefield_phy("Dinit",Dini,5) |
---|
597 | CALL writefield_phy("Ainit",Aini,5) |
---|
598 | print *,'afterwritephy',mpi_rank,omp_rank |
---|
599 | |
---|
600 | DO i=1,klon |
---|
601 | DO nts=1,ntyp |
---|
602 | masklisa(i,nts)=0 |
---|
603 | IF(Pini(i,nts)>=0.) THEN |
---|
604 | masklisa(i,nts)=1 |
---|
605 | ENDIF |
---|
606 | ENDDO |
---|
607 | ENDDO |
---|
608 | !print *,'JEOK1',mpi_rank,omp_rank |
---|
609 | DO i=1,klon |
---|
610 | !print *,Pini(i,1),Pini(i,2),Pini(i,3),Pini(i,4),Pini(i,5) |
---|
611 | DO nts=1,ntyp |
---|
612 | !IF(xlon(i).ge.longmin.and.xlon(i).le.longmax.and. & |
---|
613 | !& xlat(i).ge.latmin.and.xlat(i).le.latmax & |
---|
614 | !& .and.pctsrf(i)>0.5.and.Pini(i,nts)>0.)THEN |
---|
615 | IF(pctsrf(i)>0.5.and.Pini(i,nts)>0.)THEN |
---|
616 | |
---|
617 | sol(i,nts) = solini(i,nts) |
---|
618 | P(i,nts) = Pini(i,nts) |
---|
619 | zos(i,nts) = zosini(i,nts) |
---|
620 | z01(i,nts) = z01ini(i,nts) |
---|
621 | z02(i,nts) = z02ini(i,nts) |
---|
622 | D(i,nts) = Dini(i,nts) |
---|
623 | A(i,nts) = Aini(i,nts) |
---|
624 | ! masklisa(i,nts)=1 |
---|
625 | ELSE |
---|
626 | sol(i,nts) =0.0 |
---|
627 | P(i,nts) =0.0 |
---|
628 | zos(i,nts) =0.0 |
---|
629 | z01(i,nts) =0.0 |
---|
630 | z02(i,nts) =0.0 |
---|
631 | D(i,nts) =0.0 |
---|
632 | A(i,nts) =0.0 |
---|
633 | ! masklisa(i,nts)=0 |
---|
634 | ENDIF |
---|
635 | ENDDO |
---|
636 | ENDDO |
---|
637 | |
---|
638 | ! print *,'JEOK2',mpi_rank,omp_rank |
---|
639 | if ( 1==1 ) then |
---|
640 | |
---|
641 | ! print *,'JEOK4',mpi_rank,omp_rank |
---|
642 | CALL writefield_phy("SOL",sol,5) |
---|
643 | CALL writefield_phy("P" ,P ,5) |
---|
644 | CALL writefield_phy("ZOS",zos,5) |
---|
645 | CALL writefield_phy("ZO1",z01,5) |
---|
646 | CALL writefield_phy("ZO2",z02,5) |
---|
647 | CALL writefield_phy("D" ,D ,5) |
---|
648 | CALL writefield_phy("A" ,A ,5) |
---|
649 | CALL writefield_phy("masklisa",float(masklisa),5) |
---|
650 | CALL writefield_phy("pctsrf",pctsrf,1) |
---|
651 | CALL writefield_phy("xlon",xlon,1) |
---|
652 | CALL writefield_phy("xlat",xlat,1) |
---|
653 | !print *,'JEOK5',mpi_rank,omp_rank |
---|
654 | !print *,'JEOK6',mpi_rank,omp_rank |
---|
655 | |
---|
656 | endif |
---|
657 | |
---|
658 | !CALL abort_gcm('initdustemission', 'OK1',1) |
---|
659 | |
---|
660 | ! Lecture des donnees du LISA indiquant le type de sol utilise. |
---|
661 | ! in lines: landuse |
---|
662 | ! nats: number of mineral types (14 here for sand, silt, clay etc.) |
---|
663 | ! data format in columns |
---|
664 | ! mmd1 sigma1 p1 mmd2 sigma2 p2 mmd3 ... alpha |
---|
665 | !print *,'JEOK7',mpi_rank,omp_rank |
---|
666 | !$OMP MASTER |
---|
667 | IF (is_mpi_root .AND. is_omp_root) THEN |
---|
668 | !print *,'JEOK9',mpi_rank,omp_rank |
---|
669 | fnsolspe='SOILSPEC.data' |
---|
670 | PRINT*,' o Reading ',fnsolspe(1:40) |
---|
671 | OPEN(10,file=fnsolspe) |
---|
672 | READ(10,*)line |
---|
673 | DO i=1,nats |
---|
674 | READ(10,*)line |
---|
675 | READ(10,*)(solspe(i,j),j=1,nspe) |
---|
676 | !JE alfa(i)=solspe(i,10) |
---|
677 | ! PRINT*,'i,alfa(i)',i,alfa(i) |
---|
678 | ! WRITE(18,*)i,alfa(i) |
---|
679 | END DO |
---|
680 | ! print*,'solspe(14,10)= ',solspe(14,10) |
---|
681 | CLOSE(10) |
---|
682 | ENDIF |
---|
683 | !$OMP END MASTER |
---|
684 | !$OMP BARRIER |
---|
685 | !print *,'JEOK10',mpi_rank,omp_rank |
---|
686 | call bcast(solspe) |
---|
687 | ! Calcul de la distribution en taille des particules de Dust |
---|
688 | ! Elle depend du nombre de classe des particules nclass. |
---|
689 | !c making full resolution soil diameter table |
---|
690 | dstep=0.0005 |
---|
691 | dp=dmin |
---|
692 | do i=1,nclass |
---|
693 | dp=dp*exp(dstep) |
---|
694 | sizeclass(i)=dp |
---|
695 | if(dp.ge.dmax+eps)goto 30 |
---|
696 | newstep(i)=dstep |
---|
697 | ! WRITE(18,*)i,sizeclass(i) |
---|
698 | enddo |
---|
699 | 30 continue |
---|
700 | print*,'IK5' |
---|
701 | ncl=i-1 |
---|
702 | print*,' soil size classes used ',ncl,' / ',nclass |
---|
703 | print*,' soil size min: ',sizeclass(1),' soil size max: ',sizeclass(ncl) |
---|
704 | if(ncl.gt.nclass)stop |
---|
705 | |
---|
706 | ! Threshold velocity: |
---|
707 | if (.false.) then |
---|
708 | !if (.true.) then |
---|
709 | !c 0: Iversen and White 1982 |
---|
710 | print *,'Using Iversen and White 1982 Uth' |
---|
711 | do i=1,ncl |
---|
712 | bb=adust*(sizeclass(i)**xdust)+bdust |
---|
713 | cc=sqrt(1+ddust*(sizeclass(i)**(-2.5))) |
---|
714 | xk=sqrt(abs(rop*gravity*sizeclass(i)/roa)) |
---|
715 | if (bb.lt.10.) then |
---|
716 | dd=sqrt(1.928*(bb**0.092)-1.) |
---|
717 | uth(i)=0.129*xk*cc/dd |
---|
718 | else |
---|
719 | ee=-0.0617*(bb-10.) |
---|
720 | ff=1.-0.0858*exp(ee) |
---|
721 | uth(i)=0.12*xk*cc*ff |
---|
722 | endif |
---|
723 | enddo |
---|
724 | endif |
---|
725 | if(.true.) then |
---|
726 | ! 1: Shao and Lu 2000 |
---|
727 | print *,'Using Shao and Lu 2000 Uth' |
---|
728 | an=0.0123 |
---|
729 | gam=0.3 |
---|
730 | do i=1,ncl |
---|
731 | sigshao=rop/roa |
---|
732 | x1=sigshao*gravity*sizeclass(i) |
---|
733 | x2=gam/(roa*sizeclass(i)) |
---|
734 | uth(i)=sqrt(an*(x1+x2)) |
---|
735 | enddo |
---|
736 | endif |
---|
737 | |
---|
738 | |
---|
739 | |
---|
740 | !Calcul de la surface couverte par les particules de diametre dp |
---|
741 | !srel(nats,nclass) |
---|
742 | |
---|
743 | ! OPEN(18,file='srel.dat',form='formatted',access='sequential') |
---|
744 | DO ns=1,nats |
---|
745 | stotale=0. |
---|
746 | DO i=1,ncl |
---|
747 | su=0. |
---|
748 | DO j=1,nmode |
---|
749 | nd=((j-1)*3)+1 |
---|
750 | nsi=((j-1)*3)+2 |
---|
751 | npi=((j-1)*3)+3 |
---|
752 | IF (solspe(ns,nd).EQ.0.)THEN |
---|
753 | su_loc=0. |
---|
754 | ELSE |
---|
755 | xk=solspe(ns,npi)/(sqrt(2.*pi)*log(solspe(ns,nsi))) |
---|
756 | xl=((log(sizeclass(i))-log(solspe(ns,nd)))**2) & |
---|
757 | & /(2.*(log(solspe(ns,nsi)))**2) |
---|
758 | xm=xk*exp(-xl) |
---|
759 | xn=rop*(2./3.)*(sizeclass(i)/2.) |
---|
760 | su_loc=xm*newstep(i)/xn |
---|
761 | END IF |
---|
762 | su=su+su_loc |
---|
763 | END DO |
---|
764 | subsoildist(i)=su |
---|
765 | stotale=stotale+su |
---|
766 | END DO |
---|
767 | DO i=1,ncl |
---|
768 | IF (subsoildist(i).gt.0..and.stotale.gt.0.)THEN |
---|
769 | srel(ns,i)=subsoildist(i)/stotale |
---|
770 | |
---|
771 | ELSE |
---|
772 | srel(ns,i)=0. |
---|
773 | END IF |
---|
774 | ! WRITE(18,*)i,srel(1,i) |
---|
775 | END DO |
---|
776 | ! PRINT*,'ns , srel(10000) ',ns,srel(ns,10000) |
---|
777 | END DO |
---|
778 | |
---|
779 | |
---|
780 | ! Calcul de la repartition de l energie feff(klon,ntyp) |
---|
781 | |
---|
782 | !efficient fraction for the friction velocities as a function |
---|
783 | !of z0s, Zo1 et Zo2 to retrieve the apparent threshold |
---|
784 | !wind friction velocity. |
---|
785 | ! feff(:,:)=0. |
---|
786 | do i=1,klon |
---|
787 | do k=1,ntyp |
---|
788 | ! print*,'IKKK ',i,klon,k,ntyp |
---|
789 | if (zos(i,k).eq.0..or.z01(i,k).eq.0.) then |
---|
790 | ! if (zos(i,k)<=0..or.z01(i,k)<=0.) then |
---|
791 | ! if (zos(i,k)<0..or.z01(i,k)<0.) then |
---|
792 | ! print*,'INI DUST WARNING zos ou z01<0',zos(i,k),z01(i,k) |
---|
793 | ! endif |
---|
794 | feff(i,k)=0. |
---|
795 | feffdbg(i,k)=0. |
---|
796 | ! print*,'IKKK A ',i,klon,k,ntyp |
---|
797 | else |
---|
798 | ! drag partition betzeen the erodable surface and zo1 |
---|
799 | ! print*,'IKKK B0 ',i,klon,k,ntyp,z01(i,k),zos(i,k),xeff,aeff |
---|
800 | aa=log(z01(i,k)/zos(i,k)) |
---|
801 | tmp1(i,k)=aa |
---|
802 | bb=log(aeff*(xeff/zos(i,k))**0.8) |
---|
803 | cc=1.-aa/bb |
---|
804 | feffdbg(i,k)=cc |
---|
805 | ! print*,'IKKK B1 ',i,klon,k,ntyp |
---|
806 | ! drag partition between zo1 and zo2 |
---|
807 | ! feff: total efficient fraction |
---|
808 | if(D(i,k).eq.0.)then |
---|
809 | feff(i,k)=cc |
---|
810 | ! print*,'IKKK C ',i,klon,k,ntyp |
---|
811 | else |
---|
812 | dd=log(z02(i,k)/z01(i,k)) |
---|
813 | ee=log(aeff*(D(i,k)/z01(i,k))**0.8) |
---|
814 | feff(i,k)=(1.-dd/ee)*cc |
---|
815 | ! print*,'IKKK D ',i,klon,k,ntyp |
---|
816 | endif |
---|
817 | if (feff(i,k).lt.0.)feff(i,k)=0. |
---|
818 | if (feffdbg(i,k).lt.0.)feffdbg(i,k)=0. |
---|
819 | if (feff(i,k).gt.1.)feff(i,k)=1. |
---|
820 | if (feffdbg(i,k).gt.1.)feffdbg(i,k)=1. |
---|
821 | ! print*,'IKKK E ',i,klon,k,ntyp |
---|
822 | endif |
---|
823 | enddo |
---|
824 | enddo |
---|
825 | ! JE20150120<< |
---|
826 | if (flag_feff .eq. 0) then |
---|
827 | print *,'JE_dbg FORCED deactivated feff' |
---|
828 | do i=1,klon |
---|
829 | do k=1,ntyp |
---|
830 | feff(i,k)=1. |
---|
831 | enddo |
---|
832 | enddo |
---|
833 | endif |
---|
834 | ! JE20150120>> |
---|
835 | |
---|
836 | |
---|
837 | if (1==1) then |
---|
838 | ! ! CALL writefield_phy("AA",tmp1(1:klon,1:5),5) |
---|
839 | ! |
---|
840 | CALL writefield_phy("REPART5",feff(1:klon,1:5),5) |
---|
841 | CALL writefield_phy("REPART5dbg",feffdbg(1:klon,1:5),5) |
---|
842 | endif |
---|
843 | |
---|
844 | |
---|
845 | !c---------------FOR def_prepag01modif(var3a,var3b)----------------------- |
---|
846 | p3t=0.0001 |
---|
847 | var1=e3**(1./3.) |
---|
848 | var2=(rop*pi)**(1./3.) |
---|
849 | var3a=trctunt*var1/var2 |
---|
850 | et=e1+(sqrt(p3t*(e3*e3+e1*e2-e2*e3-e1*e3))/p3t) |
---|
851 | var1=et**(1./3.) |
---|
852 | var2=(rop*pi)**(1./3.) |
---|
853 | var3b=trctunt*var1/var2 |
---|
854 | |
---|
855 | ! JE20140902: comment all isograd distributions and make own massfrac: |
---|
856 | |
---|
857 | |
---|
858 | ! if (.false.) then |
---|
859 | !!**************L718 |
---|
860 | ! |
---|
861 | !!c------------------------------------------------------------------------ |
---|
862 | !! isolog distrib and massfrac calculations. |
---|
863 | ! |
---|
864 | ! nbinsout=nbins+1 |
---|
865 | ! b1=log(sizedustmin) |
---|
866 | ! b2=log(sizedustmax) |
---|
867 | !! restricted ISOLOG bins distributions |
---|
868 | ! |
---|
869 | !! step=(b2-b1)/(nbinsout-1) |
---|
870 | !! DO ni=1,nbinsout |
---|
871 | !! itv(ni)=exp(b1+(ni-1)*step) |
---|
872 | !! ENDDO |
---|
873 | !!OPEN(18,file='vdepothrsizbin.dat',form='formatted',access='sequential') |
---|
874 | !! Restricted ISOGRADIENT bins distributions |
---|
875 | !!!!!!!Making HIGH RESOLUTION dust size distribution (in um)!!!!!! |
---|
876 | ! stepbin=(b2-b1)/(nbinsHR-1) |
---|
877 | ! DO nb=1,nbinsHR |
---|
878 | ! binsHR(nb)=exp(b1+(nb-1)*stepbin) |
---|
879 | ! END DO |
---|
880 | ! |
---|
881 | ! DO nb=1,nbinsHR |
---|
882 | ! binsHRcm(nb)=binsHR(nb)*1.e-4 |
---|
883 | ! END DO |
---|
884 | !! Making HIGH RESOLUTION dry deposition velocity |
---|
885 | ! CALL calcvd(vdout) |
---|
886 | ! |
---|
887 | ! |
---|
888 | ! DO nb=1,nbinsHR |
---|
889 | ! vdHR(nb)=vdout(nb) |
---|
890 | !! WRITE(18,*),binsHR(nb),vdHR(nb) |
---|
891 | ! END DO |
---|
892 | ! |
---|
893 | ! !searching for minimum value of dry deposition velocity |
---|
894 | ! minisograd=1.e20 |
---|
895 | ! DO nb=1,nbinsHR |
---|
896 | ! IF(vdHR(nb).le.minisograd)THEN |
---|
897 | ! minisograd=vdHR(nb) |
---|
898 | ! miniso=nb |
---|
899 | ! END IF |
---|
900 | ! END DO |
---|
901 | ! |
---|
902 | !! searching for optimal number of bins in positive slope Vd part |
---|
903 | ! |
---|
904 | ! nbins1=1 |
---|
905 | ! nbins2=nbinsout-1 |
---|
906 | ! DO k=1,1000 |
---|
907 | ! delta1=abs(log(vdHR(1))-log(vdHR(miniso)) )/nbins1 |
---|
908 | ! delta2=abs(log(vdHR(nbinsHR))-log(vdHR(miniso)))/(nbins2-1) |
---|
909 | ! IF(delta2.GE.delta1)THEN |
---|
910 | ! GOTO 50 |
---|
911 | ! |
---|
912 | ! ELSE |
---|
913 | ! nbins2=nbins2-1 |
---|
914 | ! nbins1=nbins1+1 |
---|
915 | ! END IF |
---|
916 | ! IF(nbins2.EQ.1)THEN |
---|
917 | ! PRINT*,'!! warning: lower limit was found: STOP' |
---|
918 | ! STOP |
---|
919 | ! END IF |
---|
920 | ! END DO |
---|
921 | ! 50 CONTINUE |
---|
922 | !print*,'IK10' |
---|
923 | !! building the optimized distribution |
---|
924 | ! logvdISOGRAD(1)=log(vdHR(1)) |
---|
925 | ! binsISOGRAD(1)=binsHR(1) |
---|
926 | ! DO k=2,nbins1 |
---|
927 | ! logvdISOGRAD(k)=logvdISOGRAD(1)-(k-1)*delta1 |
---|
928 | ! END DO |
---|
929 | ! |
---|
930 | ! logvdISOGRAD(nbins1+1)=log(minisograd) |
---|
931 | ! |
---|
932 | ! DO k=1,nbins2 |
---|
933 | ! logvdISOGRAD(nbins1+1+k)=logvdISOGRAD(nbins1+1)+k*delta2 |
---|
934 | ! END DO |
---|
935 | ! |
---|
936 | ! DO k=1,nbinsout |
---|
937 | ! vdISOGRAD(k)=exp(logvdISOGRAD(k)) |
---|
938 | ! END DO |
---|
939 | !! sequential search of the correspondig particle diameter |
---|
940 | ! istart=1 |
---|
941 | ! DO k=2,nbinsout-1 |
---|
942 | ! curvd=vdISOGRAD(k) |
---|
943 | ! DO nb=istart,nbinsHR |
---|
944 | ! avdhr=vdHR(nb) |
---|
945 | ! bvdhr=vdHR(nb+1) |
---|
946 | ! IF(nb.LT.(miniso-1).AND.curvd.LT.avdhr.AND. & |
---|
947 | ! curvd.GT.bvdhr)THEN |
---|
948 | ! binsISOGRAD(k)=binsHR(nb) |
---|
949 | ! istart=nb |
---|
950 | ! GOTO 60 |
---|
951 | ! END IF |
---|
952 | ! IF(nb.eq.miniso)THEN |
---|
953 | ! binsISOGRAD(k)=binsHR(nb) |
---|
954 | ! istart=nb+1 |
---|
955 | ! GOTO 60 |
---|
956 | ! END IF |
---|
957 | ! IF(nb.GT.miniso.AND.curvd.GT.avdhr.AND. & |
---|
958 | ! curvd.LT.bvdhr)THEN |
---|
959 | ! binsISOGRAD(k)=binsHR(nb) |
---|
960 | ! istart=nb |
---|
961 | ! GOTO 60 |
---|
962 | ! END IF |
---|
963 | ! END DO |
---|
964 | ! 60 CONTINUE |
---|
965 | ! END DO |
---|
966 | !print*,'IK11' |
---|
967 | ! binsISOGRAD(nbinsout)=binsHR(nbinsHR) |
---|
968 | ! vdISOGRAD(nbinsout)=vdHR(nbinsHR) |
---|
969 | ! DO nb=1,nbinsout |
---|
970 | ! itv(nb)=binsISOGRAD(nb) |
---|
971 | ! END DO |
---|
972 | ! end ! JE20140902 if false |
---|
973 | |
---|
974 | ! Making dust size distribution (in um) |
---|
975 | ! |
---|
976 | nbinsout=nbins+1 |
---|
977 | b1=log(sizedustmin) |
---|
978 | b2=log(sizedustmax) |
---|
979 | stepbin=(b2-b1)/(nbinsout-1) |
---|
980 | DO ni=1,nbinsout |
---|
981 | itv(ni)=exp(b1+(ni-1)*stepbin) |
---|
982 | ENDDO |
---|
983 | |
---|
984 | ! stepbin=(b2-b1)/(nbinsHR-1) |
---|
985 | ! DO nb=1,nbinsHR |
---|
986 | ! binsHR(nb)=exp(b1+(nb-1)*stepbin) |
---|
987 | ! END DO |
---|
988 | ! |
---|
989 | ! DO nb=1,nbinsHR |
---|
990 | ! binsHRcm(nb)=binsHR(nb)*1.e-4 |
---|
991 | ! END DO |
---|
992 | |
---|
993 | |
---|
994 | |
---|
995 | DO nb=1,nbins |
---|
996 | ldmd=(log(itv(nb+1))-log(itv(nb)))/2. |
---|
997 | sizedust(nb)=exp(log(itv(nb))+ldmd) |
---|
998 | PRINT*,nb, itv(nb),' < ',sizedust(nb),' < ',itv(nb+1) |
---|
999 | ENDDO |
---|
1000 | ! Making dust size distribution (in cm) ??? |
---|
1001 | DO nb=1,nbins |
---|
1002 | szdcm(nb)=sizedust(nb)*1.e-4 |
---|
1003 | ENDDO |
---|
1004 | !c preparation of emissions reaffectation. |
---|
1005 | DO k=1,ndistb |
---|
1006 | exden=sqrt(2.)*log(sig(k)) |
---|
1007 | DO nb=1,nbins |
---|
1008 | d2min=itv(nb) |
---|
1009 | d2max=itv(nb+1) |
---|
1010 | numin=log(d2min/diam(k)) |
---|
1011 | numax=log(d2max/diam(k)) |
---|
1012 | massfrac(k,nb)=0.5*(erf(numax/exden)-erf(numin/exden)) |
---|
1013 | !print *,k,nb,massfrac(k,nb) |
---|
1014 | ENDDO |
---|
1015 | ENDDO |
---|
1016 | |
---|
1017 | !$OMP MASTER |
---|
1018 | IF (is_mpi_root .AND. is_omp_root) THEN |
---|
1019 | OPEN (unit=15001, file='massfrac') |
---|
1020 | DO k=1,ndistb |
---|
1021 | DO nb=1,nbins |
---|
1022 | write(15001,*),k,nb,massfrac(k,nb) |
---|
1023 | ENDDO |
---|
1024 | ENDDO |
---|
1025 | ENDIF |
---|
1026 | !$OMP END MASTER |
---|
1027 | !$OMP BARRIER |
---|
1028 | |
---|
1029 | !CALL abort_gcm('calcdustemission', 'OK1',1) |
---|
1030 | |
---|
1031 | !------------ |
---|
1032 | |
---|
1033 | |
---|
1034 | END SUBROUTINE initdust |
---|
1035 | |
---|
1036 | !-------------------------------------------------------------------------------------- |
---|
1037 | !====================================================================================== |
---|
1038 | !************************************************************************************** |
---|
1039 | !====================================================================================== |
---|
1040 | !-------------------------------------------------------------------------------------- |
---|
1041 | |
---|
1042 | SUBROUTINE calcdustemission(debutphy,zu10m,zv10m,wstar, & |
---|
1043 | ale_bl,ale_wake,param_wstarBL,param_wstarWAKE, & |
---|
1044 | emisbin) |
---|
1045 | ! emisions over 12 dust bin |
---|
1046 | USE dimphy |
---|
1047 | USE infotrac |
---|
1048 | |
---|
1049 | IMPLICIT NONE |
---|
1050 | ! Input |
---|
1051 | LOGICAL, INTENT(IN) :: debutphy ! First physiqs run or not |
---|
1052 | REAL,DIMENSION(klon),INTENT(IN) :: zu10m ! 10m zonal wind |
---|
1053 | REAL,DIMENSION(klon),INTENT(IN) :: zv10m ! meridional 10m wind |
---|
1054 | REAL,DIMENSION(klon),INTENT(IN) :: wstar |
---|
1055 | REAL,DIMENSION(klon),INTENT(IN) :: ale_bl |
---|
1056 | REAL,DIMENSION(klon),INTENT(IN) :: ale_wake |
---|
1057 | |
---|
1058 | ! Local variables |
---|
1059 | ! INTEGER, PARAMETER :: flag_wstar=150 |
---|
1060 | ! INTEGER, PARAMETER :: flag_wstar=120 |
---|
1061 | ! INTEGER, PARAMETER :: flag_wstar=125 |
---|
1062 | REAL,DIMENSION(klon), INTENT(IN) :: param_wstarWAKE |
---|
1063 | REAL,DIMENSION(klon), INTENT(IN) :: param_wstarBL |
---|
1064 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: fluxdust ! horizonal emission fluxes in UNITS for the nmod soil aerosol modes |
---|
1065 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: wind10ms ! 10m wind distribution in m/s |
---|
1066 | REAL,DIMENSION(:), ALLOCATABLE,SAVE :: wind10cm ! 10m wind distribution in cm/s |
---|
1067 | REAL,DIMENSION(klon) :: zwstar |
---|
1068 | REAL,DIMENSION(nwb) :: probu |
---|
1069 | ! REAL, DIMENSION(nmode) :: fluxN,ftN,adN,fdpN,pN,eN ! in the original code N=1,2,3 |
---|
1070 | REAL :: flux1,flux2,flux3,ft1,ft2,ft3 |
---|
1071 | |
---|
1072 | |
---|
1073 | REAL, PARAMETER :: umin=21. |
---|
1074 | REAL, PARAMETER :: woff=0.5 ! min value of 10m wind speed accepted for emissions |
---|
1075 | REAL :: pdfcum,U10mMOD,pdfu,weilambda |
---|
1076 | REAL :: z0salt,ceff,cerod,cpcent |
---|
1077 | REAL :: cdnms,ustarns,modwm,utmin |
---|
1078 | !JE20150202 REAL :: cdnms,ustarns,modwm |
---|
1079 | REAL :: fdp1,fdp2,ad1,ad2,ad3,flux_diam |
---|
1080 | REAL :: dfec1,dfec2,dfec3,t1,t2,t3,p1,p2,p3,dec,ec |
---|
1081 | ! auxiliar counters |
---|
1082 | INTEGER :: kwb |
---|
1083 | INTEGER :: i,j,k,l,n |
---|
1084 | INTEGER :: kfin,ideb,ifin,kfin2,istep |
---|
1085 | REAL :: auxreal |
---|
1086 | |
---|
1087 | ! Output |
---|
1088 | !REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: emisbin ! vertical emission fluxes in UNITS for the 12 bins |
---|
1089 | REAL,DIMENSION(klon,nbins) :: emisbin ! vertical emission fluxes in UNITS for the 12 bins |
---|
1090 | !$OMP THREADPRIVATE(fluxdust) |
---|
1091 | !$OMP THREADPRIVATE(wind10ms) |
---|
1092 | !$OMP THREADPRIVATE(wind10cm) |
---|
1093 | |
---|
1094 | !---------------------------------------------------- |
---|
1095 | ! initialization |
---|
1096 | !---------------------------------------------------- |
---|
1097 | IF (debutphy) THEN |
---|
1098 | ! ALLOCATE( emisbin(klon,nbins) ) |
---|
1099 | ALLOCATE( fluxdust(klon,nmode) ) |
---|
1100 | ALLOCATE( wind10ms(nwb) ) |
---|
1101 | ALLOCATE( wind10cm(nwb) ) |
---|
1102 | ENDIF !debutphy |
---|
1103 | |
---|
1104 | |
---|
1105 | DO i=1,klon |
---|
1106 | DO j=1,nbins |
---|
1107 | emisbin(i,j) = 0.0 |
---|
1108 | ENDDO !j,nbind |
---|
1109 | DO j=1,nmode |
---|
1110 | fluxdust(i,j) = 0.0 |
---|
1111 | ENDDO !j,nmode |
---|
1112 | zwstar(i) = 0.0 |
---|
1113 | ENDDO !i,klon |
---|
1114 | !---------------------------------------------------- |
---|
1115 | ! calculations |
---|
1116 | !---------------------------------------------------- |
---|
1117 | |
---|
1118 | ! including BL processes.. |
---|
1119 | !JE201041120 zwstar=sqrt(2.*(ale_bl+0.01*(flag_wstar-100)*ale_wake)) |
---|
1120 | !JE20141124 zwstar=sqrt(2.*(flag_wstarBL*ale_bl+0.01*(flag_wstar-100)*ale_wake)) |
---|
1121 | ! print |
---|
1122 | !*,'zwstar=sqrt(2.*(',flag_wstarBL,'ale_bl+0.01*(',flag_wstar,'-100)*ale_wake))' |
---|
1123 | ! |
---|
1124 | DO i=1,klon ! main loop |
---|
1125 | zwstar(i)=sqrt(2.*(param_wstarBL(i)*ale_bl(i)+param_wstarWAKE(i)*ale_wake(i))) |
---|
1126 | U10mMOD=MAX(woff,sqrt(zu10m(i)*zu10m(i)+zv10m(i)*zv10m(i))) |
---|
1127 | pdfcum=0. |
---|
1128 | ! Wind weibull distribution: |
---|
1129 | |
---|
1130 | DO kwb=1,nwb |
---|
1131 | flux1=0. |
---|
1132 | flux2=0. |
---|
1133 | flux3=0. |
---|
1134 | !JE20141205<< differences in weibull distribution: expectance of the distribution is |
---|
1135 | !0.89*U10mMODD instead of U10mMOD |
---|
1136 | ! now: lambda parameter of weibull ditribution is estimated as |
---|
1137 | ! lambda=U10mMOD/gamma(1+1/kref) |
---|
1138 | ! gamma function estimated with stirling formula |
---|
1139 | auxreal=1.+1./kref |
---|
1140 | weilambda = U10mMOD/exp(auxreal*log(auxreal)-auxreal & |
---|
1141 | - 0.5*log(auxreal/(2.*pi))+1./(12.*auxreal) & |
---|
1142 | -1./(360.*(auxreal**3.))+1./(1260.*(auxreal**5.))) |
---|
1143 | IF(nwb.gt.1)THEN |
---|
1144 | wind10ms(kwb)=kwb*2.*U10mMOD/nwb |
---|
1145 | !original |
---|
1146 | ! pdfu=(kref/U10mMOD)*(wind10ms(kwb)/U10mMOD)**(kref-1) & |
---|
1147 | ! *exp(-(wind10ms(kwb)/U10mMOD)**kref) |
---|
1148 | pdfu=(kref/weilambda)*(wind10ms(kwb)/weilambda)**(kref-1) & |
---|
1149 | *exp(-(wind10ms(kwb)/weilambda)**kref) |
---|
1150 | ! !print *,'JEdbg U10mMOD weilambda ',U10mMOD,weilambda |
---|
1151 | !JE20141205>> |
---|
1152 | |
---|
1153 | probu(kwb)=pdfu*2.*U10mMOD/nwb |
---|
1154 | pdfcum=pdfcum+probu(kwb) |
---|
1155 | IF(probu(kwb).le.1.e-2)GOTO 70 |
---|
1156 | ELSE |
---|
1157 | wind10ms(kwb)=U10mMOD |
---|
1158 | probu(kwb)=1. |
---|
1159 | ENDIF |
---|
1160 | wind10cm(kwb)=wind10ms(kwb)*100. |
---|
1161 | DO n=1,ntyp |
---|
1162 | ft1=0. |
---|
1163 | ft2=0. |
---|
1164 | ft3=0. |
---|
1165 | !JE20150129<<<< |
---|
1166 | |
---|
1167 | IF(.FALSE.) THEN |
---|
1168 | ! nat=int(sol(i,n)) |
---|
1169 | ! print *,i,n |
---|
1170 | IF(sol(i,n).gt.1..and.sol(i,n).lt.15.) nat=int(sol(i,n)) |
---|
1171 | !JE20140526<< |
---|
1172 | ! print *,'JE: WARNING: nat=0 forced to nat=99!! and doing nothing' |
---|
1173 | IF(sol(i,n).lt.0.5) THEN |
---|
1174 | nat=99 |
---|
1175 | GOTO 80 |
---|
1176 | ENDIF |
---|
1177 | !JE20140526>> |
---|
1178 | |
---|
1179 | |
---|
1180 | !IF(n.eq.1.and.nat.eq.99)GOTO 80 |
---|
1181 | ! if(n.eq.1) print*,'nat1=',nat,'sol1=',sol(i,n) |
---|
1182 | IF(n.eq.1.and.nat.eq.99)GOTO 80 |
---|
1183 | |
---|
1184 | ENDIF |
---|
1185 | IF(.TRUE.) THEN |
---|
1186 | nat=int(sol(i,n)) |
---|
1187 | if(n == 1 .and. nat >= 14 .or. nat < 1 .or. nat > 19) GOTO 80 |
---|
1188 | ENDIF |
---|
1189 | !JE20150129>>>> |
---|
1190 | |
---|
1191 | z0salt=z02(i,n) |
---|
1192 | ceff=feff(i,n) |
---|
1193 | cerod=A(i,n) |
---|
1194 | cpcent=P(i,n) |
---|
1195 | ustarsalt=0. |
---|
1196 | IF(ceff.le.0..or.z0salt.eq.0.)GOTO 80 |
---|
1197 | IF(cerod.eq.0.or.cpcent.eq.0.)GOTO 80 |
---|
1198 | ! in cm: utmin, umin, z10m, z0salt, ustarns |
---|
1199 | ! in meters: modwm |
---|
1200 | ! no dimension for: cdnms |
---|
1201 | ! Cas ou wsta=0. |
---|
1202 | cdnms=vkarm/(log(z10m/z0salt)) |
---|
1203 | modwm=sqrt((wind10ms(kwb)**2)+(1.2*zwstar(i))**2) |
---|
1204 | ustarns=cdnms*modwm*100. |
---|
1205 | !JE20150202 << |
---|
1206 | ! Do not have too much sense.. and is not anymore in the chimere14b version. |
---|
1207 | ! |
---|
1208 | ! utmin=umin/(cdnms*ceff) |
---|
1209 | ! IF(wind10cm(kwb).ge.utmin)THEN |
---|
1210 | ! ustarsalt=ustarns+ & |
---|
1211 | ! (0.3*(wind10cm(kwb)/100.-utmin/100.)**2.) |
---|
1212 | ! ELSE |
---|
1213 | ! ustarsalt=ustarns |
---|
1214 | ! ENDIF |
---|
1215 | ! ustarsalt should be : |
---|
1216 | ustarsalt=ustarns |
---|
1217 | !JE20150202 >> |
---|
1218 | |
---|
1219 | |
---|
1220 | IF(ustarsalt.lt.umin/ceff)GOTO 80 |
---|
1221 | ! print*,'ustarsalt = ',ustarsalt |
---|
1222 | !---------------------------------------- |
---|
1223 | CALL def_copyncl(kfin) |
---|
1224 | |
---|
1225 | ! CALL def_ag01(kfin,ft1,ft2,ft3) |
---|
1226 | do ni=1,kfin |
---|
1227 | fdp1=1.-(uth2(ni)/(ceff*ustarsalt)) |
---|
1228 | if (fdp1.le.0..or.srel2(nat,ni).eq.0.) then |
---|
1229 | ad1=0. |
---|
1230 | ad2=0. |
---|
1231 | ad3=0. |
---|
1232 | else |
---|
1233 | |
---|
1234 | fdp2=(1.+(uth2(ni)/(ceff*ustarsalt)))**2. |
---|
1235 | flux_diam=cd*srel2(nat,ni)*fdp1*fdp2*(ustarsalt**3) |
---|
1236 | dec=flux_diam*beta |
---|
1237 | ec=(pi/3.)*1.e+2*rop* (sizeclass2(ni)**3) *(ustarsalt**2) |
---|
1238 | dfec1=(ec-e1) |
---|
1239 | dfec2=(ec-e2) |
---|
1240 | dfec3=(ec-e3) |
---|
1241 | t1=0. |
---|
1242 | t2=0. |
---|
1243 | t3=0. |
---|
1244 | if(ec.ge.e1)t1=1. |
---|
1245 | if(ec.ge.e2)t2=1. |
---|
1246 | if(ec.ge.e3)t3=1. |
---|
1247 | if(dfec3.ne.0.)then |
---|
1248 | p1=t1*dfec1/dfec3 |
---|
1249 | p2=t2*(1.-p1)*dfec2/dfec3 |
---|
1250 | else |
---|
1251 | p1=0. |
---|
1252 | p2=0. |
---|
1253 | endif |
---|
1254 | p3=t3*(1.-p1-p2) |
---|
1255 | ad1=(pi/6.)*dec*rop*p1*((diam(1)*1.e-4)**3.)/e1 |
---|
1256 | ad2=(pi/6.)*dec*rop*p2*((diam(2)*1.e-4)**3.)/e2 |
---|
1257 | ad3=(pi/6.)*dec*rop*p3*((diam(3)*1.e-4)**3.)/e3 |
---|
1258 | |
---|
1259 | endif |
---|
1260 | ft1=ft1+ad1 |
---|
1261 | ft2=ft2+ad2 |
---|
1262 | ft3=ft3+ad3 |
---|
1263 | enddo ! of loop over nc |
---|
1264 | |
---|
1265 | !.... |
---|
1266 | |
---|
1267 | flux1=flux1+ft1*cpcent*cerod |
---|
1268 | flux2=flux2+ft2*cpcent*cerod |
---|
1269 | flux3=flux3+ft3*cpcent*cerod |
---|
1270 | ! print *,'JEflux :',kwb,n,flux1,flux2,flux3 |
---|
1271 | 80 CONTINUE |
---|
1272 | ENDDO !n=1,ntyp |
---|
1273 | 70 CONTINUE |
---|
1274 | fluxdust(i,1)=fluxdust(i,1)+flux1*probu(kwb) |
---|
1275 | fluxdust(i,2)=fluxdust(i,2)+flux2*probu(kwb) |
---|
1276 | fluxdust(i,3)=fluxdust(i,3)+flux3*probu(kwb) |
---|
1277 | ENDDO !kwb=1,nwb |
---|
1278 | m1dflux(i)=10.*fluxdust(i,1) |
---|
1279 | m2dflux(i)=10.*fluxdust(i,2) ! tous en Kg/m2/s |
---|
1280 | m3dflux(i)=10.*fluxdust(i,3) |
---|
1281 | |
---|
1282 | |
---|
1283 | |
---|
1284 | ENDDO ! i, klon |
---|
1285 | |
---|
1286 | |
---|
1287 | |
---|
1288 | |
---|
1289 | !from horizontal to vertical fluxes for each bin |
---|
1290 | DO k=1,klon |
---|
1291 | DO i=1,ndistb |
---|
1292 | DO j=1,nbins |
---|
1293 | !JE20150202 << |
---|
1294 | emisbin(k,j) = emisbin(k,j)+10*fluxdust(k,i)*massfrac(i,j) |
---|
1295 | !JE20150202 >> |
---|
1296 | ENDDO !j, nbind |
---|
1297 | ENDDO !i, nmode |
---|
1298 | ENDDO !k,klon |
---|
1299 | |
---|
1300 | |
---|
1301 | !print *,' JE fluxdust in calcdust' |
---|
1302 | ! DO k=1,klon |
---|
1303 | ! DO i=1,ndistb |
---|
1304 | !!print *,k,i,fluxdust(k,i) |
---|
1305 | !enddo |
---|
1306 | !enddo |
---|
1307 | !print *,' JE emisbin in calcdust' |
---|
1308 | !do k=1,klon |
---|
1309 | !do j=1,nbins |
---|
1310 | !!print *,k,j,emisbin(k,j) |
---|
1311 | !enddo |
---|
1312 | !enddo |
---|
1313 | ! CALL abort_gcm('calcdustemission', 'OK1',1) |
---|
1314 | |
---|
1315 | END SUBROUTINE calcdustemission |
---|
1316 | !-------------------------------------------------------------------------------------- |
---|
1317 | !====================================================================================== |
---|
1318 | !************************************************************************************** |
---|
1319 | !====================================================================================== |
---|
1320 | !-------------------------------------------------------------------------------------- |
---|
1321 | |
---|
1322 | |
---|
1323 | |
---|
1324 | SUBROUTINE def_copyncl(kfin) |
---|
1325 | implicit none |
---|
1326 | |
---|
1327 | integer i,n,kfin,ideb,ifin,istep,kfin2 |
---|
1328 | real dsmin,dsmax |
---|
1329 | |
---|
1330 | ! estimation of the reduced soil size distribution |
---|
1331 | dsmin=var3a*(ustarsalt**(-2./3.)) |
---|
1332 | dsmax=var3b*(ustarsalt**(-2./3.)) |
---|
1333 | ! print*,'ustarsalt = ',ustarsalt,'dsmin=',dsmin,'dsmax=',dsmax |
---|
1334 | ! dichotomy |
---|
1335 | call def_dichotomy(sizeclass,nclass,1,ncl,dsmin,ideb) |
---|
1336 | ! print*,'ideb = ',ideb |
---|
1337 | call def_dichotomy(sizeclass,nclass,ideb,ncl,dsmax,ifin) |
---|
1338 | ! print*,'ifin = ',ifin |
---|
1339 | ! readaptation of large sizes particles |
---|
1340 | kfin=0 |
---|
1341 | do i=ideb,ifin |
---|
1342 | kfin=kfin+1 |
---|
1343 | sizeclass2(kfin)=sizeclass(i) |
---|
1344 | uth2(kfin)=uth(i) |
---|
1345 | srel2(nat,kfin)=srel(nat,i) |
---|
1346 | enddo |
---|
1347 | ! print*,'je suis la' |
---|
1348 | kfin2=kfin |
---|
1349 | istep=50 |
---|
1350 | do i=ifin,ncl,istep |
---|
1351 | kfin=kfin+1 |
---|
1352 | sizeclass2(kfin)=sizeclass(i) |
---|
1353 | uth2(kfin)=uth(i) |
---|
1354 | srel2(nat,kfin)=srel(nat,i)*istep |
---|
1355 | enddo |
---|
1356 | if(kfin.ge.nclass)then |
---|
1357 | print*,'$$$$ Tables dimension problem:',kfin,'>',nclass |
---|
1358 | endif |
---|
1359 | !--------------- |
---|
1360 | |
---|
1361 | return |
---|
1362 | END SUBROUTINE def_copyncl |
---|
1363 | |
---|
1364 | !-------------------------------------------------------------------------------------- |
---|
1365 | !====================================================================================== |
---|
1366 | !************************************************************************************** |
---|
1367 | !====================================================================================== |
---|
1368 | !-------------------------------------------------------------------------------------- |
---|
1369 | |
---|
1370 | subroutine def_dichotomy(siz,nclass,i1,i2,ds,iout) |
---|
1371 | !c--------------------------------------------------------------- |
---|
1372 | !c 'size' is the table to scan |
---|
1373 | !c of dimension 'nclass', and reduced size of interest [i1:i2] |
---|
1374 | !c 'ds' is the value to find in 'size' |
---|
1375 | !c 'iout' is the number in the table 'size' correspondig to 'ds' |
---|
1376 | !c--------------------------------------------------------------- |
---|
1377 | |
---|
1378 | implicit none |
---|
1379 | integer i1,i2,nclass,iout,ismin,ismax,k2,ihalf,idiff |
---|
1380 | real siz(nclass),ds |
---|
1381 | !c----------------------------- |
---|
1382 | iout=0 |
---|
1383 | ismin=i1 |
---|
1384 | ismax=i2 |
---|
1385 | ihalf=int((ismax+ismin)/2.) |
---|
1386 | do k2=1,1000000 |
---|
1387 | if(ds.gt.siz(ihalf))then |
---|
1388 | ismin=ihalf |
---|
1389 | else |
---|
1390 | ismax=ihalf |
---|
1391 | endif |
---|
1392 | ihalf=int((ismax+ismin)/2.) |
---|
1393 | idiff=ismax-ismin |
---|
1394 | if(idiff.le.1)then |
---|
1395 | iout=ismin |
---|
1396 | goto 52 |
---|
1397 | endif |
---|
1398 | enddo |
---|
1399 | 52 continue |
---|
1400 | if(iout.eq.0)then |
---|
1401 | print*,'$$$$ Tables dimension problem: ',iout |
---|
1402 | endif |
---|
1403 | |
---|
1404 | end subroutine def_dichotomy |
---|
1405 | |
---|
1406 | !-------------------------------------------------------------------------------------- |
---|
1407 | !====================================================================================== |
---|
1408 | !************************************************************************************** |
---|
1409 | !====================================================================================== |
---|
1410 | !-------------------------------------------------------------------------------------- |
---|
1411 | |
---|
1412 | |
---|
1413 | SUBROUTINE calcvd(vdout) |
---|
1414 | IMPLICIT NONE |
---|
1415 | INTEGER :: nb |
---|
1416 | !JE already def in module INTEGER,PARAMETER :: nbinsHR=3000 |
---|
1417 | INTEGER,PARAMETER :: idiffusi=1 |
---|
1418 | INTEGER,PARAMETER :: idrydep=2 |
---|
1419 | REAL :: dmn1,dmn2,dmn3,ra,rb |
---|
1420 | REAL :: rhod,muair,nuair,R,airmolw |
---|
1421 | REAL :: bolz,rhoair,gravity,karman,zed,z0m |
---|
1422 | REAL :: ustarbin,temp,pres,rac,lambda,ccexp |
---|
1423 | REAL :: Cc,rexp,pi,St |
---|
1424 | REAL,DIMENSION(nbinsHR) :: setvel |
---|
1425 | REAL,DIMENSION(nbinsHR) :: diffmol1 |
---|
1426 | REAL,DIMENSION(nbinsHR) :: diffmol2 |
---|
1427 | REAL,DIMENSION(nbinsHR) :: schmidtnumb |
---|
1428 | REAL,DIMENSION(nbinsHR) :: diffmole |
---|
1429 | |
---|
1430 | REAL,DIMENSION(nbinsHR), INTENT(OUT) :: vdout |
---|
1431 | ! users physical parameters |
---|
1432 | temp=273.15+25. ! in Kelvin degrees |
---|
1433 | pres=1013. ! in hPa |
---|
1434 | ! calculation of Ra |
---|
1435 | zed=10. |
---|
1436 | z0m=0.05 |
---|
1437 | karman=0.41 |
---|
1438 | ustarbin=30. ! cm/s |
---|
1439 | ra=log(zed/z0m)/(karman*ustarbin) |
---|
1440 | !c physical constants (all must in units g / cm / s) |
---|
1441 | rhod=2.65 ! g.cm-3 |
---|
1442 | muair=1.72e-4 ! g.cm-1.s-1 |
---|
1443 | nuair=0.1461 ! air kinematic viscosity [cm2.s-1] |
---|
1444 | R=8.314 ! molar gas constant J.mol-1.K-1 |
---|
1445 | airmolw=28.8 ! molar weight of air |
---|
1446 | bolz=1.38e-16 ! g.cm2.s-2 |
---|
1447 | rhoair=1.225e-3 ! g.cm-3 |
---|
1448 | gravity=981. ! gravity [cm.s-2] |
---|
1449 | pi=3.14159 |
---|
1450 | rac=sqrt(8.0*airmolw/(pi*R*temp)) |
---|
1451 | lambda=(2.*muair)/(pres*rac) |
---|
1452 | ! c Cc and Vs |
---|
1453 | ! binsHRcm=binsize*1.e-4 |
---|
1454 | DO nb=1,nbinsHR |
---|
1455 | ccexp=exp((-0.55*binsHRcm(nb))/lambda) |
---|
1456 | Cc=1.+(2.*lambda)/binsHRcm(nb)*(1.257+0.4*ccexp) |
---|
1457 | setvel(nb)=(1./18.)*((binsHRcm(nb))**2*rhod*gravity*Cc)/muair |
---|
1458 | !c Molecular diffusivity (s/cm2) and Schmidt number |
---|
1459 | !c Note that the molecular diffusivity uses diameter in micro-m |
---|
1460 | !c to give a result directly in s/cm2 |
---|
1461 | dmn1=2.38e-7/binsHR(nb) |
---|
1462 | dmn2=0.163/binsHR(nb) |
---|
1463 | dmn3=0.0548*exp(-6.66*binsHR(nb))/binsHR(nb) |
---|
1464 | diffmol1(nb)=dmn1*(1.+dmn2+dmn3) |
---|
1465 | diffmol2(nb)=bolz*temp*Cc/(3.*pi*muair*binsHRcm(nb)) |
---|
1466 | IF(idiffusi.EQ.1)diffmole(nb)=diffmol1(nb) |
---|
1467 | IF(idiffusi.EQ.2)diffmole(nb)=diffmol2(nb) |
---|
1468 | schmidtnumb(nb)=nuair/diffmole(nb) |
---|
1469 | St=setvel(nb)*ustarbin*ustarbin/(gravity*nuair) |
---|
1470 | rb=1./(ustarbin*((schmidtnumb(nb))**(-2./3.)+10.**(-3./St))) |
---|
1471 | !c wesely (primarily designed for gases) |
---|
1472 | IF(idrydep.EQ.1)THEN |
---|
1473 | vdout(nb)=1./(ra+rb+ra*rb*setvel(nb))+setvel(nb) |
---|
1474 | END IF |
---|
1475 | !c venkatram and pleim (more adaptated to particles but numerically unstable) |
---|
1476 | IF(idrydep.EQ.2)THEN |
---|
1477 | rexp=exp(-(ra+rb)*setvel(nb)) |
---|
1478 | vdout(nb)=setvel(nb)/(1.-rexp) |
---|
1479 | END IF |
---|
1480 | END DO |
---|
1481 | !c----------------- |
---|
1482 | RETURN |
---|
1483 | END SUBROUTINE calcvd |
---|
1484 | |
---|
1485 | |
---|
1486 | |
---|
1487 | END MODULE dustemission_mod |
---|
1488 | |
---|