source: palm/trunk/SOURCE/init_cloud_physics.f90 @ 2000

Last change on this file since 2000 was 2000, checked in by knoop, 8 years ago

Forced header and separation lines into 80 columns

  • Property svn:keywords set to Id
File size: 4.8 KB
Line 
1!> @file init_cloud_physics.f90
2!------------------------------------------------------------------------------!
3! This file is part of PALM.
4!
5! PALM is free software: you can redistribute it and/or modify it under the
6! terms of the GNU General Public License as published by the Free Software
7! Foundation, either version 3 of the License, or (at your option) any later
8! version.
9!
10! PALM is distributed in the hope that it will be useful, but WITHOUT ANY
11! WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12! A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
13!
14! You should have received a copy of the GNU General Public License along with
15! PALM. If not, see <http://www.gnu.org/licenses/>.
16!
17! Copyright 1997-2016 Leibniz Universitaet Hannover
18!------------------------------------------------------------------------------!
19!
20! Current revisions:
21! -----------------
22! Forced header and separation lines into 80 columns
23!
24! Former revisions:
25! ------------------
26! $Id: init_cloud_physics.f90 2000 2016-08-20 18:09:15Z knoop $
27!
28! 1849 2016-04-08 11:33:18Z hoffmann
29! bfactor removed and microphysics constants moved microphysics_mod
30!
31! 1822 2016-04-07 07:49:42Z hoffmann
32! icloud_scheme replaced by microphysics_*
33!
34! 1691 2015-10-26 16:17:44Z maronga
35! Removed typo
36!
37! 1682 2015-10-07 23:56:08Z knoop
38! Code annotations made doxygen readable
39!
40! 1361 2014-04-16 15:17:48Z hoffmann
41! sed_qc_const is now calculated here (2-moment microphysics)
42!
43! 1353 2014-04-08 15:21:23Z heinze
44! REAL constants provided with KIND-attribute
45!
46! 1334 2014-03-25 12:21:40Z heinze
47! Bugfix: REAL constants provided with KIND-attribute
48!
49! 1322 2014-03-20 16:38:49Z raasch
50! REAL constants defined as wp-kind
51!
52! 1320 2014-03-20 08:40:49Z raasch
53! ONLY-attribute added to USE-statements,
54! kind-parameters added to all INTEGER and REAL declaration statements,
55! kinds are defined in new module mod_kinds,
56! revision history before 2012 removed,
57! comment fields (!:) to be used for variable explanations added to
58! all variable declaration statements
59!
60! 1065 2012-11-22 17:42:36Z hoffmann
61! The Courant number of sedimentation can be controlled with c_sedimentation.
62!
63! 1053 2012-11-13 17:11:03Z hoffmann
64! calculation of the maximum timestep according to the terminal velocity of rain
65! drops in the two moment cloud scheme
66!
67! calculation of frequently used constants (pirho_l, dpirho_l, schmidt_p_1d3,
68! hyrho)
69!
70! 1036 2012-10-22 13:43:42Z raasch
71! code put under GPL (PALM 3.9)
72!
73! 824 2012-02-17 09:09:57Z raasch
74! calculation of b_cond replaced by calculation of bfactor
75!
76! Revision 1.1  2000/04/13 14:37:22  schroeter
77! Initial revision
78!
79!
80! Description:
81! ------------
82!> Initialization of parameters for handling cloud-physics
83!------------------------------------------------------------------------------!
84 SUBROUTINE init_cloud_physics
85 
86
87    USE arrays_3d,                                                             &
88        ONLY:  dzu, hyp, pt_init, zu
89       
90    USE cloud_parameters,                                                      &
91        ONLY:  cp, hyrho, l_d_cp, l_d_r, l_d_rv, l_v, pt_d_t, rho_l, r_d, r_v, &
92               t_d_pt
93               
94    USE control_parameters,                                                    &
95        ONLY:  g, message_string, pt_surface, rho_surface, surface_pressure
96   
97    USE indices,                                                               &
98        ONLY:  nzb, nzt
99   
100    USE kinds
101
102    IMPLICIT NONE
103
104    INTEGER(iwp) ::  k      !<
105   
106    REAL(wp) ::  t_surface  !<
107
108    ALLOCATE( hyp(nzb:nzt+1), pt_d_t(nzb:nzt+1), t_d_pt(nzb:nzt+1),            &
109              hyrho(nzb:nzt+1) )
110
111!
112!-- Calculate frequently used parameters
113    l_d_cp = l_v / cp
114    l_d_r  = l_v / r_d
115    l_d_rv = l_v / r_v
116
117!
118!-- Calculate:
119!-- pt / t : ratio of potential and actual temperature (pt_d_t)
120!-- t / pt : ratio of actual and potential temperature (t_d_pt)
121!-- p_0(z) : vertical profile of the hydrostatic pressure (hyp)
122    t_surface = pt_surface * ( surface_pressure / 1000.0_wp )**0.286_wp
123    DO  k = nzb, nzt+1
124!
125!--    Check temperature in case of too large domain height
126       IF ( ( t_surface - g/cp * zu(k) ) < 0.0_wp )  THEN
127          WRITE( message_string, * )  'absolute temperature < 0.0 at zu(', k, &
128                                      ') = ', zu(k)
129          CALL message( 'init_cloud_physics', 'PA0142', 1, 2, 0, 6, 0 )
130       ENDIF
131       hyp(k)    = surface_pressure * 100.0_wp * &
132                   ( (t_surface - g/cp * zu(k)) / t_surface )**(1.0_wp/0.286_wp)
133       pt_d_t(k) = ( 100000.0_wp / hyp(k) )**0.286_wp
134       t_d_pt(k) = 1.0_wp / pt_d_t(k)
135       hyrho(k)  = hyp(k) / ( r_d * t_d_pt(k) * pt_init(k) )       
136    ENDDO
137
138!
139!-- Compute reference density
140    rho_surface = surface_pressure * 100.0_wp / ( r_d * t_surface )
141
142
143 END SUBROUTINE init_cloud_physics
Note: See TracBrowser for help on using the repository browser.