source: LMDZ6/branches/Amaury_dev/libf/phylmd/Dust/lmdz_seasalt.f90 @ 5185

Last change on this file since 5185 was 5160, checked in by abarral, 5 months ago

Put .h into modules

File size: 1.8 KB
Line 
1MODULE lmdz_seasalt
2  IMPLICIT NONE; PRIVATE
3  PUBLIC seasalt
4CONTAINS
5  ! This SUBROUTINE estimates Sea Salt emission fluxes over Oceanic surfaces.
6  SUBROUTINE seasalt(v_10m, u_10m, pct_ocean, lmt_sea_salt)
7    USE dimphy
8    USE lmdz_YOECUMF
9    USE lmdz_yomcst
10    USE lmdz_chem_spla, ONLY: ss_bins
11
12    IMPLICIT NONE
13
14    INTEGER :: i, bin                 !local variables
15    REAL :: pct_ocean(klon)           !hfraction of Ocean in each grid
16    REAL :: v_10m(klon), u_10m(klon)  !V&H components of wind @10 m
17    REAL :: w_speed_10m(klon)         !wind speed at 10m from surface
18    REAL :: lmt_sea_salt(klon, ss_bins)!sea salt emission flux - mg/m2/s
19    REAL :: sea_salt_flux(ss_bins)    !sea salt emission flux per unit wind speed
20
21    REAL :: wind, ocean
22
23    !------Sea salt emission fluxes for each size bin calculated
24    !------based on on parameterisation of Gong et al. (1997).
25    !------Fluxes of sea salt for each size bin are given in mg/m^2/sec
26    !------at wind speed of 1 m/s at 10m height (at 80% RH).
27    !------Fluxes at various wind speeds (@10 m from sea
28    !------surfaces are estimated using relationship: F=flux*U_10^3.14
29
30    !nhl for size bin of 0.03-0.5 and 0.5-20
31    DATA sea_salt_flux/4.5E-09, 8.7E-7/
32
33    DO i = 1, klon
34      w_speed_10m(i) = (v_10m(i)**2.0 + u_10m(i)**2.0)**0.5
35    ENDDO
36
37    DO bin = 1, ss_bins
38      wind = 0.0
39      ocean = 0.0
40      DO i = 1, klon
41        lmt_sea_salt(i, bin) = sea_salt_flux(bin) * (w_speed_10m(i)**3.41) &
42                * pct_ocean(i) * 1.e-4 * 1.e-3                       !g/cm2/s
43        wind = wind + w_speed_10m(i)
44        ocean = ocean + pct_ocean(i)
45      ENDDO
46      ! PRINT *,'Sea Salt flux = ',sea_salt_flux(bin)
47    ENDDO
48    ! PRINT *,'SUM OF WIND = ',wind
49    ! PRINT *,'SUM OF OCEAN SURFACE = ',ocean
50
51  END SUBROUTINE seasalt
52END MODULE lmdz_seasalt
Note: See TracBrowser for help on using the repository browser.