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

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

Add missing klon on strataer_emiss_mod.F90
Correct various missing explicit declarations
Replace tabs by spaces (tabs are not part of the fortran charset)
Continue cleaning modules
Removed unused arguments and variables

  • Property svn:executable set to *
File size: 7.0 KB
RevLine 
[5158]1MODULE lmdz_screenp
[5099]2
[5158]3  ! This module contains some procedures for calculation of the first
4  ! guess of temperature, specific humidity and wind at a reference level
5  ! coefficients for turbulent diffusion at surface
[5099]6
[5158]7  IMPLICIT NONE; PRIVATE
8  PUBLIC screenp, screenpn
[5099]9
[3817]10CONTAINS
[5099]11
[5158]12  !****************************************************************************************
[5099]13
[5158]14  !r original routine
[5099]15
[5158]16  SUBROUTINE screenp(klon, knon, &
17          speed, tair, qair, &
18          ts, qsurf, rugos, lmon, &
19          ustar, testar, qstar, zref, &
20          delu, delte, delq)
21    IMPLICIT NONE
22    !-------------------------------------------------------------------------
[5099]23
[5158]24    ! Objet : calcul "predicteur" des anomalies du vent, de la temperature
25    !         potentielle et de l'humidite relative au niveau de reference zref et
26    !         par rapport au 1er niveau (pour u) ou a la surface (pour theta et q)
27    !         a partir des relations de Dyer-Businger.
[5099]28
[5158]29    ! Reference : Hess, Colman et McAvaney (1995)
[5099]30
[5158]31    ! I. Musat, 01.07.2002
32    !-------------------------------------------------------------------------
[5099]33
[5158]34    ! klon----input-I- dimension de la grille physique (= nb_pts_latitude X nb_pts_longitude)
35    ! knon----input-I- nombre de points pour un type de surface
36    ! speed---input-R- module du vent au 1er niveau du modele
37    ! tair----input-R- temperature de l'air au 1er niveau du modele
38    ! qair----input-R- humidite relative au 1er niveau du modele
39    ! ts------input-R- temperature de l'air a la surface
40    ! qsurf---input-R- humidite relative a la surface
41    ! rugos---input-R- rugosite
42    ! lmon----input-R- longueur de Monin-Obukov
43    ! ustar---input-R- facteur d'echelle pour le vent
44    ! testar--input-R- facteur d'echelle pour la temperature potentielle
45    ! qstar---input-R- facteur d'echelle pour l'humidite relative
46    ! zref----input-R- altitude de reference
[5099]47
[5158]48    ! delu----input-R- anomalie du vent par rapport au 1er niveau
49    ! delte---input-R- anomalie de la temperature potentielle par rapport a la surface
50    ! delq----input-R- anomalie de l'humidite relative par rapport a la surface
[5099]51
[5158]52    INTEGER, INTENT(IN) :: klon, knon
53    REAL, DIMENSION(klon), INTENT(IN) :: speed, tair, qair
54    REAL, DIMENSION(klon), INTENT(IN) :: ts, qsurf, rugos
55    DOUBLE PRECISION, DIMENSION(klon), INTENT(IN) :: lmon
56    REAL, DIMENSION(klon), INTENT(IN) :: ustar, testar, qstar
57    REAL, INTENT(IN) :: zref
[5099]58
[5158]59    REAL, DIMENSION(klon), INTENT(OUT) :: delu, delte, delq
[5099]60
[5158]61    !-------------------------------------------------------------------------
62    ! Variables locales et constantes :
63    REAL, PARAMETER :: RKAR = 0.40
64    INTEGER :: i
65    REAL :: xtmp, xtmp0
66    !-------------------------------------------------------------------------
67    DO i = 1, knon
[5099]68
[5158]69      IF (lmon(i)>=0.) THEN
[5099]70
[5158]71        ! STABLE CASE
[5099]72
[5158]73        IF (speed(i)>1.5.AND.lmon(i)<=1.0                        &
74                .AND. rugos(i)<=1.0) THEN
75          delu(i) = (ustar(i) / RKAR) * &
76                  (log(zref / (rugos(i)) + 1.) + &
77                          min(5.d0, 5.0 * (zref - rugos(i)) / lmon(i)))
78          delte(i) = (testar(i) / RKAR) * &
79                  (log(zref / (rugos(i)) + 1.) + &
80                          min(5.d0, 5.0 * (zref - rugos(i)) / lmon(i)))
81          delq(i) = (qstar(i) / RKAR) * &
82                  (log(zref / (rugos(i)) + 1.) + &
83                          min(5.d0, 5.0 * (zref - rugos(i)) / lmon(i)))
84        ELSE
85          delu(i) = 0.1 * speed(i)
86          delte(i) = 0.1 * (tair(i) - ts(i))
87          delq(i) = 0.1 * (max(qair(i), 0.0) - max(qsurf(i), 0.0))
88        ENDIF
89      ELSE
[5099]90
[5158]91        ! UNSTABLE CASE
[5099]92
[5158]93        IF (speed(i)>5.0.AND.abs(lmon(i))<=50.0) THEN
94          xtmp = (1. - 16. * (zref / lmon(i)))**(1. / 4.)
95          xtmp0 = (1. - 16. * (rugos(i) / lmon(i)))**(1. / 4.)
96          delu(i) = (ustar(i) / RKAR) * &
97                  (log(zref / (rugos(i)) + 1.) &
98                          - 2. * log(0.5 * (1. + xtmp)) &
99                          + 2. * log(0.5 * (1. + xtmp0)) &
100                          - log(0.5 * (1. + xtmp * xtmp)) &
101                          + log(0.5 * (1. + xtmp0 * xtmp0)) &
102                          + 2. * atan(xtmp) - 2. * atan(xtmp0))
103          delte(i) = (testar(i) / RKAR) * &
104                  (log(zref / (rugos(i)) + 1.) &
105                          - 2.0 * log(0.5 * (1. + xtmp * xtmp)) &
106                          + 2.0 * log(0.5 * (1. + xtmp0 * xtmp0)))
107          delq(i) = (qstar(i) / RKAR) * &
108                  (log(zref / (rugos(i)) + 1.) &
109                          - 2.0 * log(0.5 * (1. + xtmp * xtmp)) &
110                          + 2.0 * log(0.5 * (1. + xtmp0 * xtmp0)))
111        ELSE
112          delu(i) = 0.5 * speed(i)
113          delte(i) = 0.5 * (tair(i) - ts(i))
114          delq(i) = 0.5 * (max(qair(i), 0.0) - max(qsurf(i), 0.0))
[3817]115        ENDIF
[5158]116      ENDIF
[5099]117
[5158]118    ENDDO
[5105]119
[5158]120  END SUBROUTINE screenp
[5099]121
[5158]122  SUBROUTINE screenpn(klon, knon, speed, tair, qair, ts, qsurf, zri1, delu, delte, delq)
123    IMPLICIT NONE
124    !-------------------------------------------------------------------------
[5099]125
[5158]126    ! Objet : calcul "predicteur" des anomalies du vent, de la temperature
127    !         potentielle et de l'humidite relative au niveau de reference zref et
128    !         par rapport au 1er niveau (pour u) ou a la surface (pour theta et q)
129    !         a partir des relations de Dyer-Businger.
[5099]130
[5158]131    ! Reference : Hess, Colman et McAvaney (1995)
[5099]132
[5158]133    ! I. Musat, 01.07.2002
134    !-------------------------------------------------------------------------
[5099]135
[5158]136    ! klon----input-I- dimension de la grille physique (= nb_pts_latitude X nb_pts_longitude)
137    ! knon----input-I- nombre de points pour un type de surface
138    ! speed---input-R- module du vent au 1er niveau du modele
139    ! tair----input-R- temperature de l'air au 1er niveau du modele
140    ! qair----input-R- humidite relative au 1er niveau du modele
141    ! ts------input-R- temperature de l'air a la surface
142    ! qsurf---input-R- humidite relative a la surface
[5099]143
[5158]144    ! delu----input-R- anomalie du vent par rapport au 1er niveau
145    ! delte---input-R- anomalie de la temperature potentielle par rapport a la surface
146    ! delq----input-R- anomalie de l'humidite relative par rapport a la surface
[5099]147
[5158]148    INTEGER, INTENT(IN) :: klon, knon
149    REAL, DIMENSION(klon), INTENT(IN) :: speed, tair, qair
150    REAL, DIMENSION(klon), INTENT(IN) :: ts, qsurf
151    REAL, DIMENSION(klon), INTENT(IN) :: zri1
[5099]152
[5158]153    REAL, DIMENSION(klon), INTENT(OUT) :: delu, delte, delq
[5099]154
[5158]155    !-------------------------------------------------------------------------
156    ! Variables locales et constantes :
157    REAL, PARAMETER :: RKAR = 0.40
158    INTEGER :: i
159    !-------------------------------------------------------------------------
160    DO i = 1, knon
[5099]161
[5158]162      IF (zri1(i)>=0.) THEN
163        delu(i) = 0.1 * speed(i)
164        delte(i) = 0.1 * (tair(i) - ts(i))
165        delq(i) = 0.1 * (max(qair(i), 0.0) - max(qsurf(i), 0.0))
166      ELSE
167        delu(i) = 0.5 * speed(i)
168        delte(i) = 0.5 * (tair(i) - ts(i))
169        delq(i) = 0.5 * (max(qair(i), 0.0) - max(qsurf(i), 0.0))
170      ENDIF
[5099]171
[5158]172    ENDDO
[5105]173
[5158]174  END SUBROUTINE screenpn
175END MODULE lmdz_screenp
Note: See TracBrowser for help on using the repository browser.