source: LMDZ6/branches/contrails/libf/phylmd/Dust/neutral.f90 @ 5463

Last change on this file since 5463 was 5337, checked in by Laurent Fairhead, 2 months ago

Getting rid of dependance to dynamics

File size: 2.7 KB
Line 
1!***********************************************************************
2  subroutine neutral(u10_mps,ustar_mps,obklen_m, &
3          u10n_mps )
4  !-----------------------------------------------------------------------     
5  ! subroutine to compute u10 neutral wind speed
6  ! inputs
7  ! u10_mps - wind speed at 10 m (m/s)
8  ! ustar_mps - friction velocity (m/s)
9  ! obklen_m - monin-obukhov length scale (m)
10  ! outputs
11  ! u10n_mps - wind speed at 10 m under neutral conditions (m/s)
12  ! following code assumes reference height Z is 10m, consistent with use
13  ! of u10 and u10_neutral.  If not, code
14  ! should be changed so that constants of 50. and 160. in equations
15  ! below are changed to -5 * Z and -16 * Z respectively.
16  ! Reference:  G. L. Geernaert.  'Bulk parameterizations for the
17  ! wind stress and heat fluxes,' in Surface Waves and Fluxes, Vol. I,
18  ! Current Theory, Geernaert and W.J. Plant, editors, Kluwer Academic
19  ! Publishers, Boston, MA, 1990.
20  ! subroutine written Feb 2001 by eg chapman
21  ! adapted to LMD-ZT by E. Cosme 310801
22  ! Following Will Shaw (PNL, Seattle) the theory applied for flux
23  ! calculation with the scheme of Nightingale et al. (2000) does not
24  ! hold anymore when -1<obklen<20. In this case, u10n is set to 0,
25  ! so that the transfer velocity  computed in nightingale.F will also
26  ! be 0. The flux is then set to 0.
27  !----------------------------------------------------------------------               
28  !
29  USE dimphy
30  !
31    real :: u10_mps(klon),ustar_mps(klon),obklen_m(klon)
32    real :: u10n_mps(klon)
33    real :: pi,von_karman
34    ! parameter (pi = 3.141592653589793, von_karman = 0.4)     
35  ! pour etre coherent avec vk de bl_for_dms.F
36    parameter (pi = 3.141592653589793, von_karman = 0.35)
37  !
38    real :: phi, phi_inv, phi_inv_sq, f1, f2, f3, dum1, psi
39    integer :: i
40
41
42    psi = 0.
43    do i=1,klon
44
45    if (u10_mps(i) .lt. 0.) u10_mps(i) = 0.0
46
47    if  (obklen_m(i) .lt. 0.) then
48            phi = (1. - 160./obklen_m(i))**(-0.25)
49            phi_inv = 1./phi
50            phi_inv_sq = 1./phi * 1./phi
51            f1 = (1. + phi_inv) / 2.
52            f2 = (1. + phi_inv_sq)/2.
53  ! following to avoid numerical overruns. recall tan(90deg)=infinity
54            dum1 = min (1.e24, phi_inv)
55            f3 = atan(dum1)
56            psi = 2.*log(f1) + log(f2) - 2.*f3 + pi/2.
57    else if (obklen_m(i) .gt. 0.) then
58            psi = -50. / obklen_m(i)
59    end if
60
61    u10n_mps(i) = u10_mps(i) + (ustar_mps(i) * psi /von_karman )
62  ! u10n set to 0. if -1 < obklen < 20
63    if ((obklen_m(i).gt.-1.).and.(obklen_m(i).lt.20.)) then
64        u10n_mps(i) = 0.
65    endif
66    if (u10n_mps(i) .lt. 0.) u10n_mps(i) = 0.0
67
68    enddo
69    return
70end subroutine neutral
71!***********************************************************************
Note: See TracBrowser for help on using the repository browser.