123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 |
- #include "tm5.inc"
- SUBROUTINE m7_equimix(kproma, kbdim, klev, &
- papp1, pttn, ptp1, &
- prelhum, pm6rp, pm6dry, &
- prhop, pww, paernl )
- !
- ! *m7_equimix* calculates the ambient radii of the particles with
- ! sulphate, b/o carbon and dust.
- !
- ! Authors:
- ! --------
- ! J. Wilson and E. Vignati, JRC (original source) 05/2000
- ! P. Stier, MPI (f90-version, changes, comments) 2001
- !
- ! Purpose:
- ! --------
- ! This routine calculates the ambient radii for mixed particles without
- ! sea salt with mass of ttn molecules, converts them to count mean radii and
- ! stores them in the array with address pm6rp.
- ! It additionally calculates the ambient particle density.
- !
- ! Method:
- ! -------
- ! The calculations of the ambient particle properties are based on
- ! parameterisations of the mass of sulfate and density derived
- ! by Julian Wilson from a regression analysis of results of solving
- ! the generalised Kelvin equation using (F. J. Zeleznik, J. Phys. Chem.
- ! Ref. Data 20, 1157, 1991), for an H2SO4-H2O mixture, in the
- ! following parameter ranges:
- ! 1e2 < pttn < 1E11 [molecules]
- ! 0.2 < prelhum < 0.9 [1]
- ! 240 < ptp1 < 330 [K]
- ! 10000 < papp1 < 100000 [Pa]
- !
- ! Due to the limitations of the parametrisation, the ambient temperature
- ! is restricted to a minimum of 240 K within this subroutine.
- !
- ! For this application to mixed aerosols with an insoluble core we
- ! assume the H2O uptake by the particle to be that of a pure
- ! H2SO4 / H2O particle containing the H2SO4 mass of the mixed aerosol.
- !
- ! Interface:
- ! ----------
- ! *m7_equimix* is called from *m7*
- !
- ! Externals:
- ! ----------
- ! none
- !
- USE mo_aero_m7, ONLY: naermod, nmod, nsol, isoans, &
- ibcks, iocks, isoaks, issas, &
- ibcas, iocas, isoaas, iduas, &
- isscs, ibccs, ioccs, isoacs,&
- iducs, &
- wvb, gmb, avo, wh2so4,&
- pi, ram2cmr, &
- dbc, doc, ddust, dh2so4,&
- dh2o, isoans
-
- IMPLICIT NONE
- !
- ! pttn = average mass for single compound in each mode
- ! [in molec. for sulphate and in ug for bc, oc, soa, ss, and dust]
- ! pm6rp = count mean radius under ambient conditions
- ! pm6dry = count mean radius under dry conditions
- ! paernl = aerosol number for each mode [cm-3]
- ! pww = aerosol water content for each mode [kg(water) m-3(air)]
- ! zwso4 = percentage by mass of sulfate in a H2O-H2SO4 particle
- ! containing pttn molecules of sulfate under ambient conditions
- ! zvso4 = volume of pttn molecules of sulfate [cm3]
- ! zmso4 = mass of pttn molecules of sulfate [g]
- ! zdso4h2o = density of sulfate-h2o fraction of a particle with average
- ! mass [g.cm-3]
- ! zmso4h2o = mass of sulfate-h2o fraction of a particle with average mass [g]
- ! zvso4h2o = volume of sulfate-h2o fraction of a particle with average
- ! mass [cm3]
- ! zinsvol = total volume of insoluble compounds in a single particle of
- ! average mass [cm3]
- ! zinsmass = total mass of insoluble compounds in a single
- ! particle of average mass [cm3]
- INTEGER :: kproma, kbdim, klev
- REAL :: papp1(kbdim,klev), ptp1(kbdim,klev), &
- prelhum(kbdim,klev)
- REAL :: pttn(kbdim,klev,naermod), prhop(kbdim,klev,nmod), &
- pm6dry(kbdim,klev,nsol), pm6rp(kbdim,klev,nmod), &
- pww(kbdim,klev,nmod), paernl(kbdim,klev,nmod)
- !
- ! Local variables:
- !
- INTEGER :: jk, jl, jmod
-
- REAL :: zseasalt, zinsvol, zinsmas, &
- zwso4, zvso4, zmso4, &
- zvso4h2o, zmso4h2o, zdso4h2o, &
- zapp1, zrh, ztk
-
- REAL :: zlnm2, zln3, zln32, ztk2, &
- zlnm, zss2
- !
- !
- !CDIR unroll=5
- DO 100 jmod=1,nsol
- DO 90 jk=1,klev
- DO 80 jl=1,kproma
- !--- 1) Split particle quantities into soluble (sea salt) and --------------
- ! non soluble (organic carbon + black carbon + dust) parts:
- ! (N.B. densities are assumed independent of temperature & pressure)
- SELECT CASE (jmod)
- CASE (1)
- zseasalt=0.
- zinsvol=1.e-6*(pttn(jl,jk,isoans)/doc)
- zinsmas=1.e-6*(pttn(jl,jk,isoans))
- CASE (2)
- zseasalt=0.
-
- zinsvol=1.e-6*(pttn(jl,jk,ibcks)/dbc+(pttn(jl,jk,iocks)+pttn(jl,jk,isoaks))/doc)
- zinsmas=1.e-6*(pttn(jl,jk,ibcks)+pttn(jl,jk,iocks)+pttn(jl,jk,isoaks))
- CASE (3)
- zseasalt=pttn(jl,jk,issas)
- zinsvol=1.e-6*(pttn(jl,jk,ibcas)/dbc+(pttn(jl,jk,iocas)+pttn(jl,jk,isoaas))/doc+ &
- pttn(jl,jk,iduas)/ddust)
- zinsmas=1.e-6*(pttn(jl,jk,ibcas)+pttn(jl,jk,iocas)+ &
- pttn(jl,jk,isoaas)+pttn(jl,jk,iduas))
- CASE (4)
- zseasalt=pttn(jl,jk,isscs)
- zinsvol=1.e-6*(pttn(jl,jk,ibccs)/dbc+(pttn(jl,jk,ioccs)+pttn(jl,jk,isoacs))/doc+ &
- pttn(jl,jk,iducs)/ddust)
- zinsmas=1.e-6*(pttn(jl,jk,ibccs)+pttn(jl,jk,ioccs)+ &
- pttn(jl,jk,isoacs)+pttn(jl,jk,iducs))
- END SELECT
- !--- 2) Calculation of the particle properties in the absense of sea salt: --
- !
- IF (pttn(jl,jk,jmod) > 0.0 .AND. zinsvol > 0.0 .AND. zseasalt < 1.E-15 ) THEN
- !--- 2.1) Calculation of the ambient particle properties: ----------------
- !
- !--- Constrain ambient temperature and relative humidity to
- ! conditions for which the parametrisation of the liquid
- ! water content works:
- !
- ! Temperature:
- ztk = ptp1(jl,jk)
- ztk = MAX(ztk , 240.)
- ! Relative Humidity:
- zrh = prelhum(jl,jk)
- zrh = MAX(zrh , 0.05)
- zrh = MIN(zrh , 0.90)
-
- !--- Assign auxiliary variables:
- zapp1=papp1(jl,jk)
- zlnm = LOG(pttn(jl,jk,jmod))
- zlnm2 = zlnm*zlnm
- zss2 = zrh**2
- ztk2 = ztk*ztk
- zln3 = zlnm/3.0
- zln32 = zln3*zln3
- !--- Percentage by weight of sulfate in the particle [%]:
- ! (Here we ignore any insoluble mass.)
- zwso4 = wvb(1) + wvb(2)*zlnm + wvb(3)*zrh*zlnm + wvb(4)*ztk*zlnm + &
- wvb(5)*zrh/ztk + wvb(6)*zlnm2*zrh + wvb(7)*zlnm2*ztk + &
- wvb(8)*zlnm*zss2 + wvb(9)*zlnm*ztk2 + wvb(10)*zlnm2*zss2 + &
- wvb(11)*zlnm2*ztk2 + wvb(12)*zss2/ztk2 + wvb(13)*zlnm2 + &
- wvb(14)*zlnm2*zlnm + wvb(15)*zlnm2*zlnm2 + &
- wvb(16)*zss2*zrh/(ztk2*ztk) + wvb(17)*LOG(zrh*ztk/zapp1)
- !--- Dry mass of sulfate in an average particle [g]:
- zmso4 = pttn(jl,jk,jmod)*wh2so4/avo
- !--- Dry volume of sulfate in an average particle [cm3]:
- ! Any temperature or pressure dependency of the
- ! sulfate density is ingored.
- zvso4 = zmso4/dh2so4
- !--- Mass of sulfate + water in an average particle [g]:
- zmso4h2o = zmso4/(zwso4/100.0)
- !--- Density of the sulfate-water fraction of an average particle [g cm-3]:
- !@@@ Check: changed zwvso4 into zwso4 (now the mass!)
- zdso4h2o = gmb(1) + gmb(2)*zwso4 + gmb(3)*zln3 + gmb(4)*zrh + &
- gmb(5)*ztk + gmb(6)*zln32 + gmb(7)*zln3/zrh + &
- gmb(8)*zln3/ztk + gmb(9)*ztk2
-
- !--- Limits for zdso4h2o: H2O(0.99) and pure H2SO4 (1.841):
- !
- zdso4h2o=MAX(zdso4h2o,dh2o)
- zdso4h2o=MIN(zdso4h2o,dh2so4)
-
- !--- Volume of sulfate-water fraction of an average particle [cm3]:
- zvso4h2o = zmso4h2o/zdso4h2o
- !--- 2.2) Calculatiion of the particle radii: ----------------------------
- !--- 2.2.1) Dry count mean radius [cm]:
-
- pm6dry(jl,jk,jmod)=((zvso4+zinsvol)*0.75/pi)**(1./3.)*ram2cmr(jmod)
- !--- 2.2.2) Equilibrium wet count mean radius [cm]:
-
- pm6rp(jl,jk,jmod) =((zvso4h2o+zinsvol)*0.75/pi)**(1./3.)*ram2cmr(jmod)
-
- !--- 2.3) Calculation of the particle density [g cm-3]:-------------------
-
- prhop(jl,jk,jmod)=(zmso4h2o+zinsmas)/ &
- (zvso4h2o+zinsvol)
- !--- 2.4) Store aerosol water for each mode [kg(water) m-3(air)]:
- pww(jl,jk,jmod)=(zmso4h2o-zmso4)*paernl(jl,jk,jmod)*1.E3
- END IF
- 80 END DO
- 90 END DO
- 100 END DO
- !write(2121,*)pm6rp(:,1,1)
- END SUBROUTINE m7_equimix
|