[5] | 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
---|
| 2 | <html><head> |
---|
[62] | 3 | <meta http-equiv="content-type" content="text/html; charset=ISO-8859-1"><title>PALM chapter 4.1</title></head> |
---|
[61] | 4 | <body><h3><a name="chapter4.1"></a>4.1 |
---|
| 5 | Initialization parameters</h3> |
---|
| 6 | <br><table style="text-align: left; width: 100%;" border="1" cellpadding="2" cellspacing="2"> <tbody> |
---|
| 7 | <tr> <td style="vertical-align: top;"><font size="4"><b>Parameter name</b></font></td> |
---|
| 8 | <td style="vertical-align: top;"><font size="4"><b>Type</b></font></td> |
---|
| 9 | <td style="vertical-align: top;"> <p><b><font size="4">Default</font></b> <br> <b><font size="4">value</font></b></p> </td> |
---|
| 10 | <td style="vertical-align: top;"><font size="4"><b>Explanation</b></font></td> |
---|
| 11 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 12 | <p><a name="adjust_mixing_length"></a><b>adjust_mixing_length</b></p> |
---|
| 13 | </td> <td style="vertical-align: top;">L</td> |
---|
| 14 | <td style="vertical-align: top;"><span style="font-style: italic;">.F.</span></td> <td style="vertical-align: top;"> <p style="font-style: normal;">Near-surface adjustment of the |
---|
| 15 | mixing length to the Prandtl-layer law. </p> <p>Usually |
---|
| 16 | the mixing length in LES models l<sub>LES</sub> |
---|
[5] | 17 | depends (as in PALM) on the grid size and is possibly restricted |
---|
| 18 | further in case of stable stratification and near the lower wall (see |
---|
| 19 | parameter <a href="#wall_adjustment">wall_adjustment</a>). |
---|
| 20 | With <b>adjust_mixing_length</b> = <span style="font-style: italic;">.T.</span> |
---|
[61] | 21 | the Prandtl' mixing length l<sub>PR</sub> = kappa * z/phi |
---|
| 22 | is calculated |
---|
[5] | 23 | and the mixing length actually used in the model is set l = MIN (l<sub>LES</sub>, |
---|
[61] | 24 | l<sub>PR</sub>). This usually gives a decrease of the |
---|
| 25 | mixing length at |
---|
[5] | 26 | the bottom boundary and considers the fact that eddy sizes |
---|
[61] | 27 | decrease in the vicinity of the wall. </p> <p style="font-style: normal;"><b>Warning:</b> So |
---|
| 28 | far, there is |
---|
[5] | 29 | no good experience with <b>adjust_mixing_length</b> = <span style="font-style: italic;">.T.</span> ! </p> |
---|
[61] | 30 | <p>With <b>adjust_mixing_length</b> = <span style="font-style: italic;">.T.</span> and the |
---|
| 31 | Prandtl-layer being |
---|
| 32 | switched on (see <a href="#prandtl_layer">prandtl_layer</a>) |
---|
| 33 | <span style="font-style: italic;">'(u*)** 2+neumann'</span> |
---|
[5] | 34 | should always be set as the lower boundary condition for the TKE (see <a href="#bc_e_b">bc_e_b</a>), |
---|
| 35 | otherwise the near-surface value of the TKE is not in agreement with |
---|
| 36 | the Prandtl-layer law (Prandtl-layer law and Prandtl-Kolmogorov-Ansatz |
---|
[61] | 37 | should provide the same value for K<sub>m</sub>). A warning |
---|
| 38 | is given, |
---|
| 39 | if this is not the case.</p> </td> </tr> <tr> |
---|
| 40 | <td style="vertical-align: top;"> <p><a name="alpha_surface"></a><b>alpha_surface</b></p> |
---|
| 41 | </td> <td style="vertical-align: top;">R<br> </td> |
---|
| 42 | <td style="vertical-align: top;"><span style="font-style: italic;">0.0</span><br> </td> |
---|
| 43 | <td style="vertical-align: top;"> <p style="font-style: normal;">Inclination of the model domain |
---|
| 44 | with respect to the horizontal (in degrees). </p> <p style="font-style: normal;">By means of <b>alpha_surface</b> |
---|
[5] | 45 | the model domain can be inclined in x-direction with respect to the |
---|
| 46 | horizontal. In this way flows over inclined surfaces (e.g. drainage |
---|
[61] | 47 | flows, gravity flows) can be simulated. In case of <b>alpha_surface |
---|
| 48 | </b>/= <span style="font-style: italic;">0</span> |
---|
| 49 | the buoyancy term |
---|
[5] | 50 | appears both in |
---|
| 51 | the equation of motion of the u-component and of the w-component.<br> |
---|
[61] | 52 | </p> <p style="font-style: normal;">An inclination |
---|
| 53 | is only possible in |
---|
[5] | 54 | case of cyclic horizontal boundary conditions along x AND y (see <a href="#bc_lr">bc_lr</a> |
---|
| 55 | and <a href="#bc_ns">bc_ns</a>) and <a href="#topography">topography</a> = <span style="font-style: italic;">'flat'</span>. </p> |
---|
[61] | 56 | <p>Runs with inclined surface still require additional |
---|
[5] | 57 | user-defined code as well as modifications to the default code. Please |
---|
| 58 | ask the <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/PALM_group.html#0">PALM |
---|
[61] | 59 | developer group</a>.</p> </td> </tr> |
---|
| 60 | <tr> <td style="vertical-align: top;"> <p><a name="bc_e_b"></a><b>bc_e_b</b></p> </td> |
---|
| 61 | <td style="vertical-align: top;">C * 20</td> <td style="vertical-align: top;"><span style="font-style: italic;">'neumann'</span></td> |
---|
| 62 | <td style="vertical-align: top;"> <p style="font-style: normal;">Bottom boundary condition of the |
---|
| 63 | TKE. </p> <p><b>bc_e_b</b> may be |
---|
| 64 | set to <span style="font-style: italic;">'neumann'</span> |
---|
| 65 | or <span style="font-style: italic;">'(u*) ** 2+neumann'</span>. |
---|
| 66 | <b>bc_e_b</b> |
---|
| 67 | = <span style="font-style: italic;">'neumann'</span> |
---|
| 68 | yields to |
---|
[5] | 69 | e(k=0)=e(k=1) (Neumann boundary condition), where e(k=1) is calculated |
---|
[61] | 70 | via the prognostic TKE equation. Choice of <span style="font-style: italic;">'(u*)**2+neumann'</span> |
---|
| 71 | also yields to |
---|
[5] | 72 | e(k=0)=e(k=1), but the TKE at the Prandtl-layer top (k=1) is calculated |
---|
| 73 | diagnostically by e(k=1)=(us/0.1)**2. However, this is only allowed if |
---|
| 74 | a Prandtl-layer is used (<a href="#prandtl_layer">prandtl_layer</a>). |
---|
[61] | 75 | If this is not the case, a warning is given and <b>bc_e_b</b> |
---|
| 76 | is reset |
---|
| 77 | to <span style="font-style: italic;">'neumann'</span>. |
---|
| 78 | </p> <p style="font-style: normal;">At the top |
---|
| 79 | boundary a Neumann |
---|
| 80 | boundary condition is generally used: (e(nz+1) = e(nz)).</p> </td> |
---|
| 81 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 82 | <p><a name="bc_lr"></a><b>bc_lr</b></p> |
---|
| 83 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 84 | <td style="vertical-align: top;"><span style="font-style: italic;">'cyclic'</span></td> |
---|
| 85 | <td style="vertical-align: top;">Boundary |
---|
| 86 | condition along x (for all quantities).<br> <br> |
---|
| 87 | By default, a cyclic boundary condition is used along x.<br> <br> |
---|
| 88 | <span style="font-weight: bold;">bc_lr</span> may |
---|
| 89 | also be |
---|
[5] | 90 | assigned the values <span style="font-style: italic;">'dirichlet/neumann'</span> |
---|
[61] | 91 | (inflow from left, outflow to the right) or <span style="font-style: italic;">'neumann/dirichlet'</span> |
---|
| 92 | (inflow from |
---|
[5] | 93 | right, outflow to the left). This requires the multi-grid method to be |
---|
| 94 | used for solving the Poisson equation for perturbation pressure (see <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#psolver">psolver</a>) |
---|
[61] | 95 | and it also requires cyclic boundary conditions along y (see<br> <a href="#bc_ns">bc_ns</a>).<br> <br> |
---|
[5] | 96 | In case of these non-cyclic lateral boundaries, a Dirichlet condition |
---|
| 97 | is used at the inflow for all quantities (initial vertical profiles - |
---|
| 98 | see <a href="#initializing_actions">initializing_actions</a> |
---|
| 99 | - are fixed during the run) except u, to which a Neumann (zero |
---|
| 100 | gradient) condition is applied. At the outflow, a Neumann (zero |
---|
| 101 | gradient) condition is used for all quantities except v, which is set |
---|
| 102 | to its horizontal average along the outflow (e.g. v(k,:,nx+1) = |
---|
| 103 | average_along_y( v(k,:,nx)), and except w, which is set to zero |
---|
| 104 | (Dirichlet condition). These conditions ensure the velocity field to be |
---|
| 105 | free of divergence at the inflow and at the outflow. For perturbation |
---|
| 106 | pressure Neumann (zero gradient) conditions are assumed both at the |
---|
[61] | 107 | inflow and at the outflow.<br> <br> |
---|
[5] | 108 | When using non-cyclic lateral boundaries, a filter is applied to the |
---|
| 109 | velocity field in the vicinity of the outflow in order to suppress any |
---|
| 110 | reflections of outgoing disturbances (see <a href="#km_damp_max">km_damp_max</a> |
---|
| 111 | and <a href="#outflow_damping_width">outflow_damping_width</a>).<br> |
---|
[61] | 112 | <br> |
---|
[5] | 113 | In order to maintain a turbulent state of the flow, it may be |
---|
| 114 | neccessary to continuously impose perturbations on the horizontal |
---|
| 115 | velocity field in the vicinity of the inflow throughout the whole run. |
---|
| 116 | This can be switched on using <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#create_disturbances">create_disturbances</a>. |
---|
| 117 | The horizontal range to which these perturbations are applied is |
---|
| 118 | controlled by the parameters <a href="#inflow_disturbance_begin">inflow_disturbance_begin</a> |
---|
| 119 | and <a href="#inflow_disturbance_end">inflow_disturbance_end</a>. |
---|
| 120 | The vertical range and the perturbation amplitude are given by <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#psolver">disturbance_level_b</a>, |
---|
[61] | 121 | <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#psolver">disturbance_level_t</a>, |
---|
[5] | 122 | and <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#psolver">disturbance_amplitude</a>. |
---|
| 123 | The time interval at which perturbations are to be imposed is set by <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#dt_disturb">dt_disturb</a>.<br> |
---|
[61] | 124 | <br> |
---|
[5] | 125 | In case of non-cyclic horizontal boundaries <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#call_psolver_at_all_substeps">call_psolver |
---|
[61] | 126 | at_all_substeps</a> = .T. should be used.<br> <br> <span style="font-weight: bold;">Note:</span><br> |
---|
[5] | 127 | Using non-cyclic lateral boundaries requires very sensitive adjustments |
---|
| 128 | of the inflow (vertical profiles) and the bottom boundary conditions, |
---|
| 129 | e.g. a surface heating should not be applied near the inflow boundary |
---|
| 130 | because this may significantly disturb the inflow. Please check the |
---|
[61] | 131 | model results very carefully.</td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="bc_ns"></a><b>bc_ns</b></p> |
---|
| 132 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 133 | <td style="vertical-align: top;"><span style="font-style: italic;">'cyclic'</span></td> |
---|
| 134 | <td style="vertical-align: top;">Boundary |
---|
| 135 | condition along y (for all quantities).<br> <br> |
---|
| 136 | By default, a cyclic boundary condition is used along y.<br> <br> |
---|
| 137 | <span style="font-weight: bold;">bc_ns</span> may |
---|
| 138 | also be |
---|
[5] | 139 | assigned the values <span style="font-style: italic;">'dirichlet/neumann'</span> |
---|
| 140 | (inflow from rear ("north"), outflow to the front ("south")) or <span style="font-style: italic;">'neumann/dirichlet'</span> |
---|
| 141 | (inflow from front ("south"), outflow to the rear ("north")). This |
---|
| 142 | requires the multi-grid |
---|
| 143 | method to be used for solving the Poisson equation for perturbation |
---|
| 144 | pressure (see <a href="chapter_4.2.html#psolver">psolver</a>) |
---|
[61] | 145 | and it also requires cyclic boundary conditions along x (see<br> <a href="#bc_lr">bc_lr</a>).<br> <br> |
---|
[5] | 146 | In case of these non-cyclic lateral boundaries, a Dirichlet condition |
---|
| 147 | is used at the inflow for all quantities (initial vertical profiles - |
---|
| 148 | see <a href="#initializing_actions">initializing_actions</a> |
---|
| 149 | - are fixed during the run) except v, to which a Neumann (zero |
---|
| 150 | gradient) condition is applied. At the outflow, a Neumann (zero |
---|
| 151 | gradient) condition is used for all quantities except u, which is set |
---|
| 152 | to its horizontal average along the outflow (e.g. u(k,ny+1,:) = |
---|
| 153 | average_along_x( u(k,ny,:)), and except w, which is set to zero |
---|
| 154 | (Dirichlet condition). These conditions ensure the velocity field to be |
---|
| 155 | free of divergence at the inflow and at the outflow. For perturbation |
---|
| 156 | pressure Neumann (zero gradient) conditions are assumed both at the |
---|
[61] | 157 | inflow and at the outflow.<br> <br> |
---|
[5] | 158 | For further details regarding non-cyclic lateral boundary conditions |
---|
[61] | 159 | see <a href="#bc_lr">bc_lr</a>.</td> </tr> |
---|
| 160 | <tr> <td style="vertical-align: top;"> <p><a name="bc_p_b"></a><b>bc_p_b</b></p> </td> |
---|
| 161 | <td style="vertical-align: top;">C * 20</td> <td style="vertical-align: top;"><span style="font-style: italic;">'neumann'</span></td> |
---|
| 162 | <td style="vertical-align: top;"> <p style="font-style: normal;">Bottom boundary condition of the |
---|
| 163 | perturbation pressure. </p> <p>Allowed values |
---|
| 164 | are <span style="font-style: italic;">'dirichlet'</span>, |
---|
| 165 | <span style="font-style: italic;">'neumann'</span> |
---|
| 166 | and <span style="font-style: italic;">'neumann+inhomo'</span>. |
---|
| 167 | <span style="font-style: italic;">'dirichlet'</span> |
---|
| 168 | sets |
---|
[5] | 169 | p(k=0)=0.0, <span style="font-style: italic;">'neumann'</span> |
---|
| 170 | sets p(k=0)=p(k=1). <span style="font-style: italic;">'neumann+inhomo'</span> |
---|
| 171 | corresponds to an extended Neumann boundary condition where heat flux |
---|
| 172 | or temperature inhomogeneities near the |
---|
[61] | 173 | surface (pt(k=1)) are additionally regarded (see Shen and |
---|
| 174 | LeClerc |
---|
[5] | 175 | (1995, Q.J.R. Meteorol. Soc., |
---|
| 176 | 1209)). This condition is only permitted with the Prandtl-layer |
---|
| 177 | switched on (<a href="#prandtl_layer">prandtl_layer</a>), |
---|
[61] | 178 | otherwise the run is terminated. </p> <p>Since |
---|
| 179 | at the bottom boundary of the model the vertical |
---|
[5] | 180 | velocity |
---|
[61] | 181 | disappears (w(k=0) = 0.0), the consistent Neumann condition (<span style="font-style: italic;">'neumann'</span> or <span style="font-style: italic;">'neumann+inhomo'</span>) |
---|
| 182 | dp/dz = 0 should |
---|
[5] | 183 | be used, which leaves the vertical component w unchanged when the |
---|
| 184 | pressure solver is applied. Simultaneous use of the Neumann boundary |
---|
| 185 | conditions both at the bottom and at the top boundary (<a href="#bc_p_t">bc_p_t</a>) |
---|
| 186 | usually yields no consistent solution for the perturbation pressure and |
---|
[61] | 187 | should be avoided.</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="bc_p_t"></a><b>bc_p_t</b></p> |
---|
| 188 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 189 | <td style="vertical-align: top;"><span style="font-style: italic;">'dirichlet'</span></td> |
---|
| 190 | <td style="vertical-align: top;"> <p style="font-style: normal;">Top boundary condition of the |
---|
| 191 | perturbation pressure. </p> <p style="font-style: normal;">Allowed values are <span style="font-style: italic;">'dirichlet'</span> |
---|
| 192 | (p(k=nz+1)= 0.0) or <span style="font-style: italic;">'neumann'</span> |
---|
| 193 | (p(k=nz+1)=p(k=nz)). </p> <p>Simultaneous use |
---|
| 194 | of Neumann boundary conditions both at the |
---|
[5] | 195 | top and bottom boundary (<a href="#bc_p_b">bc_p_b</a>) |
---|
| 196 | usually yields no consistent solution for the perturbation pressure and |
---|
| 197 | should be avoided. Since at the bottom boundary the Neumann |
---|
| 198 | condition is a good choice (see <a href="#bc_p_b">bc_p_b</a>), |
---|
[61] | 199 | a Dirichlet condition should be set at the top boundary.</p> </td> |
---|
| 200 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 201 | <p><a name="bc_pt_b"></a><b>bc_pt_b</b></p> |
---|
| 202 | </td> <td style="vertical-align: top;">C*20</td> |
---|
| 203 | <td style="vertical-align: top;"><span style="font-style: italic;">'dirichlet'</span></td> |
---|
| 204 | <td style="vertical-align: top;"> <p style="font-style: normal;">Bottom boundary condition of the |
---|
| 205 | potential temperature. </p> <p>Allowed values |
---|
| 206 | are <span style="font-style: italic;">'dirichlet'</span> |
---|
[5] | 207 | (pt(k=0) = const. = <a href="#pt_surface">pt_surface</a> |
---|
| 208 | + <a href="#pt_surface_initial_change">pt_surface_initial_change</a>; |
---|
| 209 | the user may change this value during the run using user-defined code) |
---|
| 210 | and <span style="font-style: italic;">'neumann'</span> |
---|
| 211 | (pt(k=0)=pt(k=1)). <br> |
---|
[61] | 212 | When a constant surface sensible heat flux is used (<a href="#surface_heatflux">surface_heatflux</a>), <b>bc_pt_b</b> |
---|
| 213 | = <span style="font-style: italic;">'neumann'</span> |
---|
[5] | 214 | must be used, because otherwise the resolved scale may contribute to |
---|
| 215 | the surface flux so that a constant value cannot be guaranteed.</p> |
---|
[61] | 216 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="pc_pt_t"></a><b>bc_pt_t</b></p> |
---|
| 217 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 218 | <td style="vertical-align: top;"><span style="font-style: italic;">'initial gradient'</span></td> |
---|
| 219 | <td style="vertical-align: top;"> <p style="font-style: normal;">Top boundary condition of the |
---|
| 220 | potential temperature. </p> <p>Allowed are the |
---|
| 221 | values <span style="font-style: italic;">'dirichlet' </span>(pt(k=nz+1) |
---|
| 222 | does not change during the run), <span style="font-style: italic;">'neumann'</span> |
---|
| 223 | (pt(k=nz+1)=pt(k=nz)), and <span style="font-style: italic;">'initial_gradient'</span>. |
---|
| 224 | With the 'initial_gradient'-condition the value of the temperature |
---|
| 225 | gradient at the top is |
---|
[5] | 226 | calculated from the initial |
---|
[61] | 227 | temperature profile (see <a href="#pt_surface">pt_surface</a>, |
---|
| 228 | <a href="#pt_vertical_gradient">pt_vertical_gradient</a>) |
---|
[40] | 229 | by bc_pt_t_val = (pt_init(k=nz+1) - |
---|
| 230 | pt_init(k=nz)) / dzu(nz+1).<br> |
---|
[5] | 231 | Using this value (assumed constant during the |
---|
| 232 | run) the temperature boundary values are calculated as </p> |
---|
[61] | 233 | <ul> <p style="font-style: normal;">pt(k=nz+1) = |
---|
| 234 | pt(k=nz) + |
---|
| 235 | bc_pt_t_val * dzu(nz+1)</p> </ul> <p style="font-style: normal;">(up to k=nz the prognostic |
---|
[40] | 236 | equation for the temperature is solved).<br> |
---|
[61] | 237 | When a constant sensible heat flux is used at the top boundary (<a href="chapter_4.1.html#top_heatflux">top_heatflux</a>), |
---|
| 238 | <b>bc_pt_t</b> = <span style="font-style: italic;">'neumann'</span> |
---|
[40] | 239 | must be used, because otherwise the resolved scale may contribute to |
---|
[61] | 240 | the top flux so that a constant value cannot be guaranteed.</p> </td> |
---|
| 241 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 242 | <p><a name="bc_q_b"></a><b>bc_q_b</b></p> |
---|
| 243 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 244 | <td style="vertical-align: top;"><span style="font-style: italic;">'dirichlet'</span></td> |
---|
| 245 | <td style="vertical-align: top;"> <p style="font-style: normal;">Bottom boundary condition of the |
---|
| 246 | specific humidity / total water content. </p> <p>Allowed |
---|
| 247 | values are <span style="font-style: italic;">'dirichlet'</span> |
---|
[5] | 248 | (q(k=0) = const. = <a href="#q_surface">q_surface</a> |
---|
| 249 | + <a href="#q_surface_initial_change">q_surface_initial_change</a>; |
---|
| 250 | the user may change this value during the run using user-defined code) |
---|
| 251 | and <span style="font-style: italic;">'neumann'</span> |
---|
| 252 | (q(k=0)=q(k=1)). <br> |
---|
[61] | 253 | When a constant surface latent heat flux is used (<a href="#surface_waterflux">surface_waterflux</a>), <b>bc_q_b</b> |
---|
| 254 | = <span style="font-style: italic;">'neumann'</span> |
---|
[5] | 255 | must be used, because otherwise the resolved scale may contribute to |
---|
| 256 | the surface flux so that a constant value cannot be guaranteed.</p> |
---|
[61] | 257 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="bc_q_t"></a><b>bc_q_t</b></p> |
---|
| 258 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">C |
---|
| 259 | * 20</span></td> <td style="vertical-align: top;"><span style="font-style: italic;">'neumann'</span></td> |
---|
| 260 | <td style="vertical-align: top;"> <p style="font-style: normal;">Top boundary condition of the |
---|
| 261 | specific humidity / total water content. </p> <p>Allowed |
---|
| 262 | are the values <span style="font-style: italic;">'dirichlet'</span> |
---|
[5] | 263 | (q(k=nz) and q(k=nz+1) do |
---|
| 264 | not change during the run) and <span style="font-style: italic;">'neumann'</span>. |
---|
| 265 | With the Neumann boundary |
---|
| 266 | condition the value of the humidity gradient at the top is calculated |
---|
| 267 | from the |
---|
[61] | 268 | initial humidity profile (see <a href="#q_surface">q_surface</a>, |
---|
| 269 | <a href="#q_vertical_gradient">q_vertical_gradient</a>) |
---|
[5] | 270 | by: bc_q_t_val = ( q_init(k=nz) - q_init(k=nz-1)) / dzu(nz).<br> |
---|
| 271 | Using this value (assumed constant during the run) the humidity |
---|
| 272 | boundary values |
---|
[61] | 273 | are calculated as </p> <ul> <p style="font-style: normal;">q(k=nz+1) =q(k=nz) + |
---|
| 274 | bc_q_t_val * dzu(nz+1)</p> </ul> <p style="font-style: normal;">(up tp k=nz the prognostic |
---|
| 275 | equation for q is solved). </p> </td> </tr> <tr> |
---|
| 276 | <td style="vertical-align: top;"> <p><a name="bc_s_b"></a><b>bc_s_b</b></p> </td> |
---|
| 277 | <td style="vertical-align: top;">C * 20</td> <td style="vertical-align: top;"><span style="font-style: italic;">'dirichlet'</span></td> |
---|
| 278 | <td style="vertical-align: top;"> <p style="font-style: normal;">Bottom boundary condition of the |
---|
| 279 | scalar concentration. </p> <p>Allowed values |
---|
| 280 | are <span style="font-style: italic;">'dirichlet'</span> |
---|
[5] | 281 | (s(k=0) = const. = <a href="#s_surface">s_surface</a> |
---|
| 282 | + <a href="#s_surface_initial_change">s_surface_initial_change</a>; |
---|
| 283 | the user may change this value during the run using user-defined code) |
---|
[61] | 284 | and <span style="font-style: italic;">'neumann'</span> |
---|
| 285 | (s(k=0) = |
---|
[5] | 286 | s(k=1)). <br> |
---|
[61] | 287 | When a constant surface concentration flux is used (<a href="#surface_scalarflux">surface_scalarflux</a>), <b>bc_s_b</b> |
---|
| 288 | = <span style="font-style: italic;">'neumann'</span> |
---|
[5] | 289 | must be used, because otherwise the resolved scale may contribute to |
---|
| 290 | the surface flux so that a constant value cannot be guaranteed.</p> |
---|
[61] | 291 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="bc_s_t"></a><b>bc_s_t</b></p> |
---|
| 292 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 293 | <td style="vertical-align: top;"><span style="font-style: italic;">'neumann'</span></td> |
---|
| 294 | <td style="vertical-align: top;"> <p style="font-style: normal;">Top boundary condition of the |
---|
| 295 | scalar concentration. </p> <p>Allowed are the |
---|
| 296 | values <span style="font-style: italic;">'dirichlet'</span> |
---|
[5] | 297 | (s(k=nz) and s(k=nz+1) do |
---|
| 298 | not change during the run) and <span style="font-style: italic;">'neumann'</span>. |
---|
| 299 | With the Neumann boundary |
---|
| 300 | condition the value of the scalar concentration gradient at the top is |
---|
| 301 | calculated |
---|
[61] | 302 | from the initial scalar concentration profile (see <a href="#s_surface">s_surface</a>, <a href="#s_vertical_gradient">s_vertical_gradient</a>) |
---|
[5] | 303 | by: bc_s_t_val = (s_init(k=nz) - s_init(k=nz-1)) / dzu(nz).<br> |
---|
| 304 | Using this value (assumed constant during the run) the concentration |
---|
| 305 | boundary values |
---|
[61] | 306 | are calculated as </p> <ul> <p style="font-style: normal;">s(k=nz+1) = s(k=nz) + |
---|
| 307 | bc_s_t_val * dzu(nz+1)</p> </ul> <p style="font-style: normal;">(up to k=nz the prognostic |
---|
[5] | 308 | equation for the scalar concentration is |
---|
[61] | 309 | solved).</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="bc_uv_b"></a><b>bc_uv_b</b></p> |
---|
| 310 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 311 | <td style="vertical-align: top;"><span style="font-style: italic;">'dirichlet'</span></td> |
---|
| 312 | <td style="vertical-align: top;"> <p style="font-style: normal;">Bottom boundary condition of the |
---|
| 313 | horizontal velocity components u and v. </p> <p>Allowed |
---|
| 314 | values are <span style="font-style: italic;">'dirichlet' </span>and |
---|
| 315 | <span style="font-style: italic;">'neumann'</span>. <b>bc_uv_b</b> |
---|
| 316 | = <span style="font-style: italic;">'dirichlet'</span> |
---|
| 317 | yields the |
---|
[5] | 318 | no-slip condition with u=v=0 at the bottom. Due to the staggered grid |
---|
| 319 | u(k=0) and v(k=0) are located at z = - 0,5 * <a href="#dz">dz</a> |
---|
| 320 | (below the bottom), while u(k=1) and v(k=1) are located at z = +0,5 * |
---|
| 321 | dz. u=v=0 at the bottom is guaranteed using mirror boundary |
---|
[61] | 322 | condition: </p> <ul> <p style="font-style: normal;">u(k=0) = - u(k=1) and v(k=0) = - |
---|
| 323 | v(k=1)</p> </ul> <p style="font-style: normal;">The |
---|
| 324 | Neumann boundary condition |
---|
[5] | 325 | yields the free-slip condition with u(k=0) = u(k=1) and v(k=0) = |
---|
| 326 | v(k=1). |
---|
| 327 | With Prandtl - layer switched on, the free-slip condition is not |
---|
| 328 | allowed (otherwise the run will be terminated)<font color="#000000">.</font></p> |
---|
[61] | 329 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="bc_uv_t"></a><b>bc_uv_t</b></p> |
---|
| 330 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 331 | <td style="vertical-align: top;"><span style="font-style: italic;">'dirichlet'</span></td> |
---|
| 332 | <td style="vertical-align: top;"> <p style="font-style: normal;">Top boundary condition of the |
---|
| 333 | horizontal velocity components u and v. </p> <p>Allowed |
---|
| 334 | values are <span style="font-style: italic;">'dirichlet'</span> |
---|
| 335 | and <span style="font-style: italic;">'neumann'</span>. |
---|
| 336 | The |
---|
[5] | 337 | Dirichlet condition yields u(k=nz+1) = ug(nz+1) and v(k=nz+1) = |
---|
| 338 | vg(nz+1), |
---|
| 339 | Neumann condition yields the free-slip condition with u(k=nz+1) = |
---|
| 340 | u(k=nz) and v(k=nz+1) = v(k=nz) (up to k=nz the prognostic equations |
---|
[61] | 341 | for the velocities are solved).</p> </td> </tr> <tr> |
---|
| 342 | <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="building_height"></a>building_height</span></td> |
---|
| 343 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">50.0</span></td> <td>Height |
---|
| 344 | of a single building in m.<br> <br> <span style="font-weight: bold;">building_height</span> must |
---|
| 345 | be less than the height of the model domain. This parameter requires |
---|
| 346 | the use of <a href="#topography">topography</a> |
---|
| 347 | = <span style="font-style: italic;">'single_building'</span>.</td> |
---|
| 348 | </tr> <tr> <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="building_length_x"></a>building_length_x</span></td> |
---|
| 349 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">50.0</span></td> <td><span style="font-style: italic;"></span>Width of a single |
---|
| 350 | building in m.<br> <br> |
---|
| 351 | Currently, <span style="font-weight: bold;">building_length_x</span> |
---|
| 352 | must be at least <span style="font-style: italic;">3 |
---|
| 353 | * </span><a style="font-style: italic;" href="#dx">dx</a> and no more than <span style="font-style: italic;">( </span><a style="font-style: italic;" href="#nx">nx</a><span style="font-style: italic;"> - 1 ) </span><span style="font-style: italic;"> * <a href="#dx">dx</a> |
---|
| 354 | </span><span style="font-style: italic;">- <a href="#building_wall_left">building_wall_left</a></span>. |
---|
| 355 | This parameter requires the use of <a href="#topography">topography</a> |
---|
| 356 | = <span style="font-style: italic;">'single_building'</span>.</td> |
---|
| 357 | </tr> <tr> <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="building_length_y"></a>building_length_y</span></td> |
---|
| 358 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">50.0</span></td> <td>Depth |
---|
| 359 | of a single building in m.<br> <br> |
---|
| 360 | Currently, <span style="font-weight: bold;">building_length_y</span> |
---|
| 361 | must be at least <span style="font-style: italic;">3 |
---|
| 362 | * </span><a style="font-style: italic;" href="#dy">dy</a> and no more than <span style="font-style: italic;">( </span><a style="font-style: italic;" href="#ny">ny</a><span style="font-style: italic;"> - 1 ) </span><span style="font-style: italic;"> * <a href="#dy">dy</a></span><span style="font-style: italic;"> - <a href="#building_wall_south">building_wall_south</a></span>. This parameter requires |
---|
| 363 | the use of <a href="#topography">topography</a> |
---|
| 364 | = <span style="font-style: italic;">'single_building'</span>.</td> |
---|
| 365 | </tr> <tr> <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="building_wall_left"></a>building_wall_left</span></td> |
---|
| 366 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">building centered in x-direction</span></td> |
---|
| 367 | <td>x-coordinate of the left building wall (distance between the |
---|
| 368 | left building wall and the left border of the model domain) in m.<br> |
---|
| 369 | <br> |
---|
| 370 | Currently, <span style="font-weight: bold;">building_wall_left</span> |
---|
| 371 | must be at least <span style="font-style: italic;">1 |
---|
| 372 | * </span><a style="font-style: italic;" href="#dx">dx</a> and less than <span style="font-style: italic;">( <a href="#nx">nx</a> |
---|
| 373 | - 1 ) * <a href="#dx">dx</a> - <a href="#building_length_x">building_length_x</a></span>. |
---|
| 374 | This parameter requires the use of <a href="#topography">topography</a> |
---|
| 375 | = <span style="font-style: italic;">'single_building'</span>.<br> |
---|
| 376 | <br> |
---|
| 377 | The default value <span style="font-weight: bold;">building_wall_left</span> |
---|
| 378 | = <span style="font-style: italic;">( ( <a href="#nx">nx</a> + |
---|
| 379 | 1 ) * <a href="#dx">dx</a> - <a href="#building_length_x">building_length_x</a> ) / 2</span> |
---|
| 380 | centers the building in x-direction. </td> </tr> <tr> |
---|
| 381 | <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="building_wall_south"></a>building_wall_south</span></td> |
---|
| 382 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;"></span><span style="font-style: italic;">building centered in y-direction</span></td> |
---|
| 383 | <td>y-coordinate of the South building wall (distance between the |
---|
[5] | 384 | South building wall and the South border of the model domain) in m.<br> |
---|
[61] | 385 | <br> |
---|
| 386 | Currently, <span style="font-weight: bold;">building_wall_south</span> |
---|
| 387 | must be at least <span style="font-style: italic;">1 |
---|
| 388 | * </span><a style="font-style: italic;" href="#dy">dy</a> and less than <span style="font-style: italic;">( <a href="#ny">ny</a> |
---|
| 389 | - 1 ) * <a href="#dy">dy</a> - <a href="#building_length_y">building_length_y</a></span>. |
---|
| 390 | This parameter requires the use of <a href="#topography">topography</a> |
---|
| 391 | = <span style="font-style: italic;">'single_building'</span>.<br> |
---|
| 392 | <br> |
---|
| 393 | The default value <span style="font-weight: bold;">building_wall_south</span> |
---|
| 394 | = <span style="font-style: italic;">( ( <a href="#ny">ny</a> + |
---|
| 395 | 1 ) * <a href="#dy">dy</a> - <a href="#building_length_y">building_length_y</a> ) / 2</span> |
---|
| 396 | centers the building in y-direction. </td> </tr> <tr> |
---|
| 397 | <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="cloud_droplets"></a>cloud_droplets</span><br> |
---|
| 398 | </td> <td style="vertical-align: top;">L<br> </td> |
---|
| 399 | <td style="vertical-align: top;"><span style="font-style: italic;">.F.</span><br> </td> |
---|
| 400 | <td style="vertical-align: top;">Parameter to switch on |
---|
| 401 | usage of cloud droplets.<br> <br> |
---|
[5] | 402 | Cloud droplets require to use the particle package (<span style="font-weight: bold;">mrun</span>-option <span style="font-family: monospace;">-p particles</span>), |
---|
| 403 | so in this case a particle corresponds to a droplet. The droplet |
---|
| 404 | features (number of droplets, initial radius, etc.) can be steered with |
---|
| 405 | the respective particle parameters (see e.g. <a href="#chapter_4.2.html#radius">radius</a>). |
---|
| 406 | The real number of initial droplets in a grid cell is equal to the |
---|
| 407 | initial number of droplets (defined by the particle source parameters <span lang="en-GB"><font face="Thorndale, serif"> </font></span><a href="chapter_4.2.html#pst"><span lang="en-GB"><font face="Thorndale, serif">pst</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#psl"><span lang="en-GB"><font face="Thorndale, serif">psl</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#psr"><span lang="en-GB"><font face="Thorndale, serif">psr</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#pss"><span lang="en-GB"><font face="Thorndale, serif">pss</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#psn"><span lang="en-GB"><font face="Thorndale, serif">psn</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#psb"><span lang="en-GB"><font face="Thorndale, serif">psb</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#pdx"><span lang="en-GB"><font face="Thorndale, serif">pdx</font></span></a><span lang="en-GB"><font face="Thorndale, serif">, </font></span><a href="chapter_4.2.html#pdy"><span lang="en-GB"><font face="Thorndale, serif">pdy</font></span></a> |
---|
[61] | 408 | <span lang="en-GB"><font face="Thorndale, serif">and |
---|
| 409 | </font></span><a href="chapter_4.2.html#pdz"><span lang="en-GB"><font face="Thorndale, serif">pdz</font></span></a><span lang="en-GB"></span><span lang="en-GB"></span>) |
---|
| 410 | times the <a href="#initial_weighting_factor">initial_weighting_factor</a>.<br> |
---|
| 411 | <br> |
---|
| 412 | In case of using cloud droplets, the default condensation scheme in |
---|
| 413 | PALM cannot be used, i.e. <a href="#cloud_physics">cloud_physics</a> |
---|
| 414 | must be set <span style="font-style: italic;">.F.</span>.<br> |
---|
| 415 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="cloud_physics"></a><b>cloud_physics</b></p> |
---|
| 416 | </td> <td style="vertical-align: top;">L<br> </td> |
---|
| 417 | <td style="vertical-align: top;"><span style="font-style: italic;">.F.</span></td> <td style="vertical-align: top;"> <p>Parameter to switch |
---|
| 418 | on the condensation scheme. </p> |
---|
| 419 | For <b>cloud_physics =</b> <span style="font-style: italic;">.TRUE.</span>, equations |
---|
| 420 | for the |
---|
[5] | 421 | liquid water |
---|
| 422 | content and the liquid water potential temperature are solved instead |
---|
| 423 | of those for specific humidity and potential temperature. Note |
---|
| 424 | that a grid volume is assumed to be either completely saturated or |
---|
| 425 | completely |
---|
| 426 | unsaturated (0%-or-100%-scheme). A simple precipitation scheme can |
---|
| 427 | additionally be switched on with parameter <a href="#precipitation">precipitation</a>. |
---|
[61] | 428 | Also cloud-top cooling by longwave radiation can be utilized (see <a href="#radiation">radiation</a>)<br> <b><br> |
---|
| 429 | cloud_physics =</b> <span style="font-style: italic;">.TRUE. |
---|
| 430 | </span>requires <a href="#moisture">moisture</a> |
---|
| 431 | =<span style="font-style: italic;"> .TRUE.</span> .<br> |
---|
[5] | 432 | Detailed information about the condensation scheme is given in the |
---|
| 433 | description of the <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM-1/Dokumentationen/Cloud_physics/wolken.pdf">cloud |
---|
[61] | 434 | physics module</a> (pdf-file, only in German).<br> <br> |
---|
| 435 | This condensation scheme is not allowed if cloud droplets are simulated |
---|
| 436 | explicitly (see <a href="#cloud_droplets">cloud_droplets</a>).<br> |
---|
| 437 | </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="conserve_volume_flow"></a>conserve_volume_flow</span></td> |
---|
| 438 | <td style="vertical-align: top;">L</td> <td style="vertical-align: top;"><span style="font-style: italic;">.F.</span></td> <td>Conservation |
---|
| 439 | of volume flow in x- and y-direction.<br> <br> <span style="font-weight: bold;">conserve_volume_flow</span> |
---|
| 440 | = <span style="font-style: italic;">.TRUE.</span> |
---|
[5] | 441 | guarantees that the volume flow through the xz- or yz-cross-section of |
---|
| 442 | the total model domain remains constant (equal to the initial value at |
---|
| 443 | t=0) throughout the run.<br> |
---|
[61] | 444 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="cut_spline_overshoot"></a><b>cut_spline_overshoot</b></p> |
---|
| 445 | </td> <td style="vertical-align: top;">L</td> |
---|
| 446 | <td style="vertical-align: top;"><span style="font-style: italic;">.T.</span></td> <td style="vertical-align: top;"> <p>Cuts off of |
---|
| 447 | so-called overshoots, which can occur with the |
---|
| 448 | upstream-spline scheme. </p> <p><font color="#000000">The cubic splines tend to overshoot in |
---|
[5] | 449 | case of discontinuous changes of variables between neighbouring grid |
---|
| 450 | points.</font><font color="#ff0000"> </font><font color="#000000">This |
---|
[61] | 451 | may lead to errors in calculating the advection tendency.</font> |
---|
| 452 | Choice |
---|
| 453 | of <b>cut_spline_overshoot</b> = <i>.TRUE.</i> |
---|
| 454 | (switched on by |
---|
[5] | 455 | default) |
---|
| 456 | allows variable values not to exceed an interval defined by the |
---|
| 457 | respective adjacent grid points. This interval can be adjusted |
---|
| 458 | seperately for every prognostic variable (see initialization parameters |
---|
[61] | 459 | <a href="#overshoot_limit_e">overshoot_limit_e</a>, <a href="#overshoot_limit_pt">overshoot_limit_pt</a>, <a href="#overshoot_limit_u">overshoot_limit_u</a>, |
---|
[5] | 460 | etc.). This might be necessary in case that the |
---|
| 461 | default interval has a non-tolerable effect on the model |
---|
[61] | 462 | results. </p> <p>Overshoots may also be removed |
---|
| 463 | using the parameters <a href="#ups_limit_e">ups_limit_e</a>, |
---|
| 464 | <a href="#ups_limit_pt">ups_limit_pt</a>, |
---|
[5] | 465 | etc. as well as by applying a long-filter (see <a href="#long_filter_factor">long_filter_factor</a>).</p> |
---|
[61] | 466 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="damp_level_1d"></a><b>damp_level_1d</b></p> |
---|
| 467 | </td> <td style="vertical-align: top;">R</td> |
---|
| 468 | <td style="vertical-align: top;"><span style="font-style: italic;">zu(nz+1)</span></td> |
---|
| 469 | <td style="vertical-align: top;"> <p>Height where |
---|
| 470 | the damping layer begins in the 1d-model |
---|
| 471 | (in m). </p> <p>This parameter is used to |
---|
| 472 | switch on a damping layer for the |
---|
[5] | 473 | 1d-model, which is generally needed for the damping of inertia |
---|
| 474 | oscillations. Damping is done by gradually increasing the value |
---|
| 475 | of the eddy diffusivities about 10% per vertical grid level |
---|
| 476 | (starting with the value at the height given by <b>damp_level_1d</b>, |
---|
[61] | 477 | or possibly from the next grid pint above), i.e. K<sub>m</sub>(k+1) |
---|
| 478 | = |
---|
[5] | 479 | 1.1 * K<sub>m</sub>(k). |
---|
[61] | 480 | The values of K<sub>m</sub> are limited to 10 m**2/s at |
---|
| 481 | maximum. <br> |
---|
[5] | 482 | This parameter only comes into effect if the 1d-model is switched on |
---|
| 483 | for |
---|
| 484 | the initialization of the 3d-model using <a href="#initializing_actions">initializing_actions</a> |
---|
[61] | 485 | = <span style="font-style: italic;">'set_1d-model_profiles'</span>. |
---|
| 486 | <br> </p> </td> </tr> <tr> <td style="vertical-align: top;"><a name="dissipation_1d"></a><span style="font-weight: bold;">dissipation_1d</span><br> |
---|
| 487 | </td> <td style="vertical-align: top;">C*20<br> |
---|
| 488 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">'as_in_3d_</span><br style="font-style: italic;"> <span style="font-style: italic;">model'</span><br> </td> |
---|
| 489 | <td style="vertical-align: top;">Calculation method for |
---|
| 490 | the energy dissipation term in the TKE equation of the 1d-model.<br> |
---|
| 491 | <br> |
---|
| 492 | By default the dissipation is calculated as in the 3d-model using diss |
---|
| 493 | = (0.19 + 0.74 * l / l_grid) * e**1.5 / l.<br> <br> |
---|
| 494 | Setting <span style="font-weight: bold;">dissipation_1d</span> |
---|
| 495 | = <span style="font-style: italic;">'detering'</span> |
---|
| 496 | forces the dissipation to be calculated as diss = 0.064 * e**1.5 / l.<br> |
---|
| 497 | </td> </tr> |
---|
| 498 | <tr> <td style="vertical-align: top;"> <p><a name="dt"></a><b>dt</b></p> </td> |
---|
| 499 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">variable</span></td> |
---|
| 500 | <td style="vertical-align: top;"> <p>Time step for |
---|
| 501 | the 3d-model (in s). </p> <p>By default, (i.e. |
---|
| 502 | if a Runge-Kutta scheme is used, see <a href="#timestep_scheme">timestep_scheme</a>) |
---|
[5] | 503 | the value of the time step is calculating after each time step |
---|
| 504 | (following the time step criteria) and |
---|
[61] | 505 | used for the next step.</p> <p>If the user assigns <b>dt</b> |
---|
| 506 | a value, then the time step is |
---|
[5] | 507 | fixed to this value throughout the whole run (whether it fulfills the |
---|
| 508 | time step |
---|
| 509 | criteria or not). However, changes are allowed for restart runs, |
---|
| 510 | because <b>dt</b> can also be used as a <a href="chapter_4.2.html#dt_laufparameter">run |
---|
[61] | 511 | parameter</a>. </p> <p>In case that the |
---|
| 512 | calculated time step meets the condition<br> </p> <ul> |
---|
| 513 | <p><b>dt</b> < 0.00001 * <a href="chapter_4.2.html#dt_max">dt_max</a> (with dt_max |
---|
| 514 | = 20.0)</p> </ul> <p>the simulation will be |
---|
| 515 | aborted. Such situations usually arise |
---|
[5] | 516 | in case of any numerical problem / instability which causes a |
---|
[61] | 517 | non-realistic increase of the wind speed. </p> <p>A |
---|
| 518 | small time step due to a large mean horizontal windspeed |
---|
[5] | 519 | speed may be enlarged by using a coordinate transformation (see <a href="#galilei_transformation">galilei_transformation</a>), |
---|
[61] | 520 | in order to spare CPU time.<br> </p> <p>If the |
---|
| 521 | leapfrog timestep scheme is used (see <a href="#timestep_scheme">timestep_scheme</a>) |
---|
[5] | 522 | a temporary time step value dt_new is calculated first, with dt_new = <a href="chapter_4.2.html#fcl_factor">cfl_factor</a> |
---|
| 523 | * dt_crit where dt_crit is the maximum timestep allowed by the CFL and |
---|
| 524 | diffusion condition. Next it is examined whether dt_new exceeds or |
---|
| 525 | falls below the |
---|
| 526 | value of the previous timestep by at |
---|
| 527 | least +5 % / -2%. If it is smaller, <span style="font-weight: bold;">dt</span> |
---|
| 528 | = dt_new is immediately used for the next timestep. If it is larger, |
---|
[61] | 529 | then <span style="font-weight: bold;">dt </span>= |
---|
| 530 | 1.02 * dt_prev |
---|
[5] | 531 | (previous timestep) is used as the new timestep, however the time |
---|
| 532 | step is only increased if the last change of the time step is dated |
---|
| 533 | back at |
---|
| 534 | least 30 iterations. If dt_new is located in the interval mentioned |
---|
| 535 | above, then dt |
---|
| 536 | does not change at all. By doing so, permanent time step changes as |
---|
| 537 | well as large |
---|
[61] | 538 | sudden changes (increases) in the time step are avoided.</p> </td> |
---|
| 539 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 540 | <p><a name="dt_pr_1d"></a><b>dt_pr_1d</b></p> |
---|
| 541 | </td> <td style="vertical-align: top;">R</td> |
---|
| 542 | <td style="vertical-align: top;"><span style="font-style: italic;">9999999.9</span></td> |
---|
| 543 | <td style="vertical-align: top;"> <p>Temporal |
---|
| 544 | interval of vertical profile output of the 1D-model |
---|
| 545 | (in s). </p> <p>Data are written in ASCII |
---|
| 546 | format to file <a href="chapter_3.4.html#LIST_PROFIL_1D">LIST_PROFIL_1D</a>. |
---|
[5] | 547 | This parameter is only in effect if the 1d-model has been switched on |
---|
| 548 | for the |
---|
| 549 | initialization of the 3d-model with <a href="#initializing_actions">initializing_actions</a> |
---|
| 550 | = <span style="font-style: italic;">'set_1d-model_profiles'</span>.</p> |
---|
[61] | 551 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="dt_run_control_1d"></a><b>dt_run_control_1d</b></p> |
---|
| 552 | </td> <td style="vertical-align: top;">R</td> |
---|
| 553 | <td style="vertical-align: top;"><span style="font-style: italic;">60.0</span></td> <td style="vertical-align: top;"> <p>Temporal interval of |
---|
| 554 | runtime control output of the 1d-model |
---|
| 555 | (in s). </p> <p>Data are written in ASCII |
---|
| 556 | format to file <a href="chapter_3.4.html#RUN_CONTROL">RUN_CONTROL</a>. |
---|
[5] | 557 | This parameter is only in effect if the 1d-model is switched on for the |
---|
| 558 | initialization of the 3d-model with <a href="#initializing_actions">initializing_actions</a> |
---|
| 559 | = <span style="font-style: italic;">'set_1d-model_profiles'</span>.</p> |
---|
[61] | 560 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="dx"></a><b>dx</b></p> |
---|
| 561 | </td> <td style="vertical-align: top;">R</td> |
---|
| 562 | <td style="vertical-align: top;"><span style="font-style: italic;">1.0</span></td> <td style="vertical-align: top;"> <p>Horizontal grid |
---|
| 563 | spacing along the x-direction (in m). </p> <p>Along |
---|
| 564 | x-direction only a constant grid spacing is allowed.</p> </td> |
---|
| 565 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 566 | <p><a name="dy"></a><b>dy</b></p> |
---|
| 567 | </td> <td style="vertical-align: top;">R</td> |
---|
| 568 | <td style="vertical-align: top;"><span style="font-style: italic;">1.0</span></td> <td style="vertical-align: top;"> <p>Horizontal grid |
---|
| 569 | spacing along the x-direction (in m). </p> <p>Along |
---|
| 570 | x-direction only a constant grid spacing is allowed.</p> </td> |
---|
| 571 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 572 | <p><a name="dz"></a><b>dz</b></p> |
---|
| 573 | </td> <td style="vertical-align: top;">R</td> |
---|
| 574 | <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p>Vertical grid |
---|
| 575 | spacing (in m). </p> <p>This parameter must be |
---|
| 576 | assigned by the user, because no |
---|
| 577 | default value is given.<br> </p> <p>By default, the |
---|
[5] | 578 | model uses constant grid spacing along z-direction, but it can be |
---|
| 579 | stretched using the parameters <a href="#dz_stretch_level">dz_stretch_level</a> |
---|
[61] | 580 | and <a href="#dz_stretch_factor">dz_stretch_factor</a>. |
---|
| 581 | In case of stretching, a maximum allowed grid spacing can be given by <a href="#dz_max">dz_max</a>.<br> </p> <p>Assuming |
---|
| 582 | a constant <span style="font-weight: bold;">dz</span>, |
---|
[5] | 583 | the scalar levels (zu) are calculated directly by: </p> |
---|
[61] | 584 | <ul> <p>zu(0) = - dz * 0.5 <br> |
---|
| 585 | zu(1) = dz * 0.5</p> </ul> <p>The w-levels lie |
---|
| 586 | half between them: </p> <ul> <p>zw(k) = |
---|
| 587 | ( zu(k) + zu(k+1) ) * 0.5</p> </ul> </td> </tr> |
---|
| 588 | <tr><td style="vertical-align: top;"><a name="dz_max"></a><span style="font-weight: bold;">dz_max</span></td><td style="vertical-align: top;">R</td><td style="vertical-align: top;"><span style="font-style: italic;">9999999.9</span></td><td style="vertical-align: top;">Allowed maximum vertical grid |
---|
| 589 | spacing (in m).<br><br>If the vertical grid is stretched |
---|
| 590 | (see <a href="#dz_stretch_factor">dz_stretch_factor</a> |
---|
| 591 | and <a href="#dz_stretch_level">dz_stretch_level</a>), |
---|
| 592 | <span style="font-weight: bold;">dz_max</span> can |
---|
| 593 | be used to limit the vertical grid spacing.</td></tr><tr> |
---|
| 594 | <td style="vertical-align: top;"> <p><a name="dz_stretch_factor"></a><b>dz_stretch_factor</b></p> |
---|
| 595 | </td> <td style="vertical-align: top;">R</td> |
---|
| 596 | <td style="vertical-align: top;"><span style="font-style: italic;">1.08</span></td> <td style="vertical-align: top;"> <p>Stretch factor for a |
---|
| 597 | vertically stretched grid (see <a href="#dz_stretch_level">dz_stretch_level</a>). |
---|
| 598 | </p> <p>The stretch factor should not exceed a value of |
---|
| 599 | approx. 1.10 - |
---|
[5] | 600 | 1.12, otherwise the discretization errors due to the stretched grid not |
---|
[61] | 601 | negligible any more. (refer Kalnay de Rivas)</p> </td> </tr> |
---|
| 602 | <tr> <td style="vertical-align: top;"> <p><a name="dz_stretch_level"></a><b>dz_stretch_level</b></p> |
---|
| 603 | </td> <td style="vertical-align: top;">R</td> |
---|
| 604 | <td style="vertical-align: top;"><span style="font-style: italic;">100000.0</span><br> </td> |
---|
| 605 | <td style="vertical-align: top;"> <p>Height level |
---|
| 606 | above which the grid is to be stretched |
---|
| 607 | vertically (in m). </p> <p>The vertical grid |
---|
| 608 | spacings <a href="#dz">dz</a> |
---|
| 609 | above this level are calculated as </p> <ul> <p><b>dz</b>(k+1) |
---|
| 610 | = <b>dz</b>(k) * <a href="#dz_stretch_factor">dz_stretch_factor</a></p> |
---|
| 611 | </ul> <p>and used as spacings for the scalar levels (zu). |
---|
| 612 | The |
---|
| 613 | w-levels are then defined as: </p> <ul> <p>zw(k) |
---|
| 614 | = ( zu(k) + zu(k+1) ) * 0.5</p> </ul> </td> </tr> |
---|
| 615 | <tr> <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="e_min"></a>e_min</span></td> |
---|
| 616 | <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">0.0</span></td> <td>Minimum |
---|
| 617 | subgrid-scale TKE in m<sup>2</sup>s<sup>-2</sup>.<br> |
---|
| 618 | <br>This |
---|
| 619 | option adds artificial viscosity to the flow by ensuring that |
---|
| 620 | the |
---|
| 621 | subgrid-scale TKE does not fall below the minimum threshold <span style="font-weight: bold;">e_min</span>.</td> </tr> |
---|
| 622 | <tr> <td style="vertical-align: top;"> <p><a name="end_time_1d"></a><b>end_time_1d</b></p> |
---|
| 623 | </td> <td style="vertical-align: top;">R</td> |
---|
| 624 | <td style="vertical-align: top;"><span style="font-style: italic;">864000.0</span><br> </td> |
---|
| 625 | <td style="vertical-align: top;"> <p>Time to be |
---|
| 626 | simulated for the 1d-model (in s). </p> <p>The |
---|
| 627 | default value corresponds to a simulated time of 10 days. |
---|
[5] | 628 | Usually, after such a period the inertia oscillations have completely |
---|
| 629 | decayed and the solution of the 1d-model can be regarded as stationary |
---|
| 630 | (see <a href="#damp_level_1d">damp_level_1d</a>). |
---|
| 631 | This parameter is only in effect if the 1d-model is switched on for the |
---|
| 632 | initialization of the 3d-model with <a href="#initializing_actions">initializing_actions</a> |
---|
| 633 | = <span style="font-style: italic;">'set_1d-model_profiles'</span>.</p> |
---|
[61] | 634 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="fft_method"></a><b>fft_method</b></p> |
---|
| 635 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 636 | <td style="vertical-align: top;"><span style="font-style: italic;">'system-</span><br style="font-style: italic;"> <span style="font-style: italic;">specific'</span></td> |
---|
| 637 | <td style="vertical-align: top;"> <p>FFT-method to |
---|
| 638 | be used.<br> </p> <p><br> |
---|
[5] | 639 | The fast fourier transformation (FFT) is used for solving the |
---|
| 640 | perturbation pressure equation with a direct method (see <a href="chapter_4.2.html#psolver">psolver</a>) |
---|
| 641 | and for calculating power spectra (see optional software packages, |
---|
| 642 | section <a href="chapter_4.2.html#spectra_package">4.2</a>).</p> |
---|
[61] | 643 | <p><br> |
---|
[5] | 644 | By default, system-specific, optimized routines from external |
---|
| 645 | vendor libraries are used. However, these are available only on certain |
---|
| 646 | computers and there are more or less severe restrictions concerning the |
---|
[61] | 647 | number of gridpoints to be used with them.<br> </p> <p>There |
---|
| 648 | are two other PALM internal methods available on every |
---|
[5] | 649 | machine (their respective source code is part of the PALM source code):</p> |
---|
[61] | 650 | <p>1.: The <span style="font-weight: bold;">Temperton</span>-method |
---|
[5] | 651 | from Clive Temperton (ECWMF) which is computationally very fast and |
---|
| 652 | switched on with <b>fft_method</b> = <span style="font-style: italic;">'temperton-algorithm'</span>. |
---|
| 653 | The number of horizontal gridpoints (nx+1, ny+1) to be used with this |
---|
[61] | 654 | method must be composed of prime factors 2, 3 and 5.<br> </p> |
---|
[5] | 655 | 2.: The <span style="font-weight: bold;">Singleton</span>-method |
---|
| 656 | which is very slow but has no restrictions concerning the number of |
---|
[61] | 657 | gridpoints to be used with, switched on with <b>fft_method</b> |
---|
| 658 | = <span style="font-style: italic;">'singleton-algorithm'</span>. |
---|
| 659 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="galilei_transformation"></a><b>galilei_transformation</b></p> |
---|
| 660 | </td> <td style="vertical-align: top;">L</td> |
---|
| 661 | <td style="vertical-align: top;"><i>.F.</i></td> |
---|
| 662 | <td style="vertical-align: top;">Application of a |
---|
| 663 | Galilei-transformation to the |
---|
[5] | 664 | coordinate |
---|
[61] | 665 | system of the model.<br><p>With <b>galilei_transformation</b> |
---|
| 666 | = <i>.T.,</i> a so-called |
---|
[5] | 667 | Galilei-transformation is switched on which ensures that the coordinate |
---|
| 668 | system of the model is moved along with the geostrophical wind. |
---|
| 669 | Alternatively, the model domain can be moved along with the averaged |
---|
| 670 | horizontal wind (see <a href="#use_ug_for_galilei_tr">use_ug_for_galilei_tr</a>, |
---|
| 671 | this can and will naturally change in time). With this method, |
---|
| 672 | numerical inaccuracies of the Piascek - Williams - scheme (concerns in |
---|
| 673 | particular the momentum advection) are minimized. Beyond that, in the |
---|
| 674 | majority of cases the lower relative velocities in the moved system |
---|
| 675 | permit a larger time step (<a href="#dt">dt</a>). |
---|
| 676 | Switching the transformation on is only worthwhile if the geostrophical |
---|
| 677 | wind (ug, vg) |
---|
| 678 | and the averaged horizontal wind clearly deviate from the value 0. In |
---|
| 679 | each case, the distance the coordinate system has been moved is written |
---|
| 680 | to the file <a href="chapter_3.4.html#RUN_CONTROL">RUN_CONTROL</a>. |
---|
[61] | 681 | </p> <p>Non-cyclic lateral boundary conditions (see <a href="#bc_lr">bc_lr</a> |
---|
| 682 | and <a href="#bc_ns">bc_ns</a>), the specification |
---|
| 683 | of a gestrophic |
---|
[5] | 684 | wind that is not constant with height |
---|
| 685 | as well as e.g. stationary inhomogeneities at the bottom boundary do |
---|
[61] | 686 | not allow the use of this transformation.</p> </td> </tr> |
---|
| 687 | <tr> <td style="vertical-align: top;"> <p><a name="grid_matching"></a><b>grid_matching</b></p> |
---|
| 688 | </td> <td style="vertical-align: top;">C * 6</td> |
---|
| 689 | <td style="vertical-align: top;"><span style="font-style: italic;">'match'</span></td> <td style="vertical-align: top;">Variable to adjust the |
---|
| 690 | subdomain |
---|
| 691 | sizes in parallel runs.<br> <br> |
---|
[5] | 692 | For <b>grid_matching</b> = <span style="font-style: italic;">'strict'</span>, |
---|
| 693 | the subdomains are forced to have an identical |
---|
| 694 | size on all processors. In this case the processor numbers in the |
---|
| 695 | respective directions of the virtual processor net must fulfill certain |
---|
| 696 | divisor conditions concerning the grid point numbers in the three |
---|
[61] | 697 | directions (see <a href="#nx">nx</a>, <a href="#ny">ny</a> |
---|
[5] | 698 | and <a href="#nz">nz</a>). |
---|
| 699 | Advantage of this method is that all PEs bear the same computational |
---|
[61] | 700 | load.<br> <br> |
---|
[5] | 701 | There is no such restriction by default, because then smaller |
---|
| 702 | subdomains are allowed on those processors which |
---|
| 703 | form the right and/or north boundary of the virtual processor grid. On |
---|
| 704 | all other processors the subdomains are of same size. Whether smaller |
---|
| 705 | subdomains are actually used, depends on the number of processors and |
---|
| 706 | the grid point numbers used. Information about the respective settings |
---|
| 707 | are given in file <a href="file:///home/raasch/public_html/PALM_group/home/raasch/public_html/PALM_group/doc/app/chapter_3.4.html#RUN_CONTROL">RUN_CONTROL</a>.<br> |
---|
[61] | 708 | <br> |
---|
[5] | 709 | When using a multi-grid method for solving the Poisson equation (see <a href="http://www.muk.uni-hannover.de/%7Eraasch/PALM_group/doc/app/chapter_4.2.html#psolver">psolver</a>) |
---|
| 710 | only <b>grid_matching</b> = <span style="font-style: italic;">'strict'</span> |
---|
[61] | 711 | is allowed.<br> <br> <b>Note:</b><br> |
---|
[5] | 712 | In some cases for small processor numbers there may be a very bad load |
---|
| 713 | balancing among the |
---|
[61] | 714 | processors which may reduce the performance of the code.</td> </tr> |
---|
| 715 | <tr> <td style="vertical-align: top;"><a name="inflow_disturbance_begin"></a><b>inflow_disturbance_<br> |
---|
| 716 | begin</b></td> <td style="vertical-align: top;">I</td> |
---|
| 717 | <td style="vertical-align: top;"><span style="font-style: italic;">MIN(10,</span><br style="font-style: italic;"> <span style="font-style: italic;">nx/2 or ny/2)</span></td> |
---|
| 718 | <td style="vertical-align: top;">Lower |
---|
[5] | 719 | limit of the horizontal range for which random perturbations are to be |
---|
[61] | 720 | imposed on the horizontal velocity field (gridpoints).<br> <br> |
---|
[5] | 721 | If non-cyclic lateral boundary conditions are used (see <a href="#bc_lr">bc_lr</a> |
---|
| 722 | or <a href="#bc_ns">bc_ns</a>), |
---|
| 723 | this parameter gives the gridpoint number (counted horizontally from |
---|
| 724 | the inflow) from which on perturbations are imposed on the |
---|
| 725 | horizontal velocity field. Perturbations must be switched on with |
---|
| 726 | parameter <a href="chapter_4.2.html#create_disturbances">create_disturbances</a>.</td> |
---|
[61] | 727 | </tr> <tr> <td style="vertical-align: top;"><a name="inflow_disturbance_end"></a><b>inflow_disturbance_<br> |
---|
| 728 | end</b></td> <td style="vertical-align: top;">I</td> |
---|
| 729 | <td style="vertical-align: top;"><span style="font-style: italic;">MIN(100,</span><br style="font-style: italic;"> <span style="font-style: italic;">3/4*nx or</span><br style="font-style: italic;"> <span style="font-style: italic;">3/4*ny)</span></td> <td style="vertical-align: top;">Upper |
---|
[5] | 730 | limit of the horizontal range for which random perturbations are |
---|
[61] | 731 | to be imposed on the horizontal velocity field (gridpoints).<br> <br> |
---|
[5] | 732 | If non-cyclic lateral boundary conditions are used (see <a href="#bc_lr">bc_lr</a> |
---|
| 733 | or <a href="#bc_ns">bc_ns</a>), |
---|
| 734 | this parameter gives the gridpoint number (counted horizontally from |
---|
| 735 | the inflow) unto which perturbations are imposed on the |
---|
| 736 | horizontal |
---|
| 737 | velocity field. Perturbations must be switched on with parameter <a href="chapter_4.2.html#create_disturbances">create_disturbances</a>.</td> |
---|
[61] | 738 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 739 | <p><a name="initializing_actions"></a><b>initializing_actions</b></p> |
---|
| 740 | </td> <td style="vertical-align: top;">C * 100</td> |
---|
| 741 | <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p style="font-style: normal;">Initialization actions |
---|
| 742 | to be carried out. </p> <p style="font-style: normal;">This parameter does not have a |
---|
[5] | 743 | default value and therefore must be assigned with each model run. For |
---|
| 744 | restart runs <b>initializing_actions</b> = <span style="font-style: italic;">'read_restart_data'</span> |
---|
| 745 | must be set. For the initial run of a job chain the following values |
---|
[61] | 746 | are allowed: </p> <p style="font-style: normal;"><span style="font-style: italic;">'set_constant_profiles'</span> |
---|
| 747 | </p> <ul> <p>A horizontal wind profile consisting |
---|
| 748 | of linear sections (see <a href="#ug_surface">ug_surface</a>, |
---|
| 749 | <a href="#ug_vertical_gradient">ug_vertical_gradient</a>, |
---|
| 750 | <a href="#ug_vertical_gradient_level">ug_vertical_gradient_level</a> |
---|
| 751 | and <a href="#vg_surface">vg_surface</a>, <a href="#vg_vertical_gradient">vg_vertical_gradient</a>, |
---|
| 752 | <a href="#vg_vertical_gradient_level">vg_vertical_gradient_level</a>, |
---|
[5] | 753 | respectively) as well as a vertical temperature (humidity) profile |
---|
| 754 | consisting of |
---|
[61] | 755 | linear sections (see <a href="#pt_surface">pt_surface</a>, |
---|
| 756 | <a href="#pt_vertical_gradient">pt_vertical_gradient</a>, |
---|
| 757 | <a href="#q_surface">q_surface</a> |
---|
[5] | 758 | and <a href="#q_vertical_gradient">q_vertical_gradient</a>) |
---|
| 759 | are assumed as initial profiles. The subgrid-scale TKE is set to 0 but K<sub>m</sub> |
---|
[61] | 760 | and K<sub>h</sub> are set to very small values because |
---|
| 761 | otherwise no TKE |
---|
| 762 | would be generated.</p> </ul> <p style="font-style: italic;">'set_1d-model_profiles' </p> |
---|
| 763 | <ul> <p>The arrays of the 3d-model are initialized with |
---|
| 764 | the |
---|
[5] | 765 | (stationary) solution of the 1d-model. These are the variables e, kh, |
---|
| 766 | km, u, v and with Prandtl layer switched on rif, us, usws, vsws. The |
---|
| 767 | temperature (humidity) profile consisting of linear sections is set as |
---|
| 768 | for 'set_constant_profiles' and assumed as constant in time within the |
---|
| 769 | 1d-model. For steering of the 1d-model a set of parameters with suffix |
---|
[61] | 770 | "_1d" (e.g. <a href="#end_time_1d">end_time_1d</a>, |
---|
| 771 | <a href="#damp_level_1d">damp_level_1d</a>) |
---|
| 772 | is available.</p> </ul> <p><span style="font-style: italic;">'by_user'</span></p><p style="margin-left: 40px;">The initialization of the arrays |
---|
| 773 | of the 3d-model is under complete control of the user and has to be |
---|
| 774 | done in routine <a href="chapter_3.5.1.html#user_init_3d_model">user_init_3d_model</a> |
---|
| 775 | of the user-interface.<span style="font-style: italic;"></span></p><p><span style="font-style: italic;">'initialize_vortex'</span> |
---|
| 776 | </p> <div style="margin-left: 40px;">The initial |
---|
| 777 | velocity field of the |
---|
[5] | 778 | 3d-model corresponds to a |
---|
| 779 | Rankine-vortex with vertical axis. This setting may be used to test |
---|
| 780 | advection schemes. Free-slip boundary conditions for u and v (see <a href="#bc_uv_b">bc_uv_b</a>, <a href="#bc_uv_t">bc_uv_t</a>) |
---|
| 781 | are necessary. In order not to distort the vortex, an initial |
---|
| 782 | horizontal wind profile constant |
---|
| 783 | with height is necessary (to be set by <b>initializing_actions</b> |
---|
| 784 | = <span style="font-style: italic;">'set_constant_profiles'</span>) |
---|
| 785 | and some other conditions have to be met (neutral stratification, |
---|
| 786 | diffusion must be |
---|
| 787 | switched off, see <a href="#km_constant">km_constant</a>). |
---|
| 788 | The center of the vortex is located at jc = (nx+1)/2. It |
---|
| 789 | extends from k = 0 to k = nz+1. Its radius is 8 * <a href="#dx">dx</a> |
---|
| 790 | and the exponentially decaying part ranges to 32 * <a href="#dx">dx</a> |
---|
[61] | 791 | (see init_rankine.f90). </div> <p><span style="font-style: italic;">'initialize_ptanom'</span> |
---|
| 792 | </p> <ul> <p>A 2d-Gauss-like shape disturbance |
---|
| 793 | (x,y) is added to the |
---|
[5] | 794 | initial temperature field with radius 10.0 * <a href="#dx">dx</a> |
---|
| 795 | and center at jc = (nx+1)/2. This may be used for tests of scalar |
---|
| 796 | advection schemes |
---|
| 797 | (see <a href="#scalar_advec">scalar_advec</a>). |
---|
| 798 | Such tests require a horizontal wind profile constant with hight and |
---|
| 799 | diffusion |
---|
| 800 | switched off (see <span style="font-style: italic;">'initialize_vortex'</span>). |
---|
| 801 | Additionally, the buoyancy term |
---|
| 802 | must be switched of in the equation of motion for w (this |
---|
[61] | 803 | requires the user to comment out the call of <span style="font-family: monospace;">buoyancy</span> in the |
---|
| 804 | source code of <span style="font-family: monospace;">prognostic_equations.f90</span>).</p> |
---|
| 805 | </ul> <p style="font-style: normal;">Values may be |
---|
[5] | 806 | combined, e.g. <b>initializing_actions</b> = <span style="font-style: italic;">'set_constant_profiles |
---|
[61] | 807 | initialize_vortex'</span>, but the values of <span style="font-style: italic;">'set_constant_profiles'</span>, |
---|
| 808 | <span style="font-style: italic;">'set_1d-model_profiles'</span> |
---|
| 809 | , and <span style="font-style: italic;">'by_user'</span> |
---|
| 810 | must not be given at the same time.</p> <p style="font-style: italic;"> </p> </td> </tr> |
---|
| 811 | <tr> <td style="vertical-align: top;"> <p><a name="km_constant"></a><b>km_constant</b></p> |
---|
| 812 | </td> <td style="vertical-align: top;">R</td> |
---|
| 813 | <td style="vertical-align: top;"><i>variable<br> |
---|
| 814 | (computed from TKE)</i></td> <td style="vertical-align: top;"> <p>Constant eddy |
---|
| 815 | diffusivities are used (laminar |
---|
| 816 | simulations). </p> <p>If this parameter is |
---|
| 817 | specified, both in the 1d and in the |
---|
[5] | 818 | 3d-model constant values for the eddy diffusivities are used in |
---|
| 819 | space and time with K<sub>m</sub> = <b>km_constant</b> |
---|
| 820 | and K<sub>h</sub> = K<sub>m</sub> / <a href="chapter_4.2.html#prandtl_number">prandtl_number</a>. |
---|
| 821 | The prognostic equation for the subgrid-scale TKE is switched off. |
---|
| 822 | Constant eddy diffusivities are only allowed with the Prandtl layer (<a href="#prandtl_layer">prandtl_layer</a>) |
---|
[61] | 823 | switched off.</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="km_damp_max"></a><b>km_damp_max</b></p> |
---|
| 824 | </td> <td style="vertical-align: top;">R</td> |
---|
| 825 | <td style="vertical-align: top;"><span style="font-style: italic;">0.5*(dx |
---|
| 826 | or dy)</span></td> <td style="vertical-align: top;">Maximum |
---|
[5] | 827 | diffusivity used for filtering the velocity field in the vicinity of |
---|
[61] | 828 | the outflow (in m<sup>2</sup>/s).<br> <br> |
---|
[5] | 829 | When using non-cyclic lateral boundaries (see <a href="#bc_lr">bc_lr</a> |
---|
| 830 | or <a href="#bc_ns">bc_ns</a>), |
---|
| 831 | a smoothing has to be applied to the |
---|
| 832 | velocity field in the vicinity of the outflow in order to suppress any |
---|
| 833 | reflections of outgoing disturbances. Smoothing is done by increasing |
---|
| 834 | the eddy diffusivity along the horizontal direction which is |
---|
| 835 | perpendicular to the outflow boundary. Only velocity components |
---|
| 836 | parallel to the outflow boundary are filtered (e.g. v and w, if the |
---|
| 837 | outflow is along x). Damping is applied from the bottom to the top of |
---|
[61] | 838 | the domain.<br> <br> |
---|
[5] | 839 | The horizontal range of the smoothing is controlled by <a href="#outflow_damping_width">outflow_damping_width</a> |
---|
| 840 | which defines the number of gridpoints (counted from the outflow |
---|
| 841 | boundary) from where on the smoothing is applied. Starting from that |
---|
| 842 | point, the eddy diffusivity is linearly increased (from zero to its |
---|
| 843 | maximum value given by <span style="font-weight: bold;">km_damp_max</span>) |
---|
| 844 | until half of the damping range width, from where it remains constant |
---|
| 845 | up to the outflow boundary. If at a certain grid point the eddy |
---|
| 846 | diffusivity calculated from the flow field is larger than as described |
---|
[61] | 847 | above, it is used instead.<br> <br> |
---|
[5] | 848 | The default value of <span style="font-weight: bold;">km_damp_max</span> |
---|
[61] | 849 | has been empirically proven to be sufficient.</td> </tr> <tr> |
---|
| 850 | <td style="vertical-align: top;"> <p><a name="long_filter_factor"></a><b>long_filter_factor</b></p> |
---|
| 851 | </td> <td style="vertical-align: top;">R</td> |
---|
| 852 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 853 | <td style="vertical-align: top;"> <p>Filter factor |
---|
| 854 | for the so-called Long-filter.<br> </p> <p><br> |
---|
[5] | 855 | This filter very efficiently |
---|
| 856 | eliminates 2-delta-waves sometimes cauesed by the upstream-spline |
---|
| 857 | scheme (see Mahrer and |
---|
| 858 | Pielke, 1978: Mon. Wea. Rev., 106, 818-830). It works in all three |
---|
[61] | 859 | directions in space. A value of <b>long_filter_factor</b> |
---|
| 860 | = <i>0.01</i> |
---|
[5] | 861 | sufficiently removes the small-scale waves without affecting the |
---|
[61] | 862 | longer waves.<br> </p> <p>By default, the filter is |
---|
| 863 | switched off (= <i>0.0</i>). |
---|
[5] | 864 | It is exclusively applied to the tendencies calculated by the |
---|
| 865 | upstream-spline scheme (see <a href="#momentum_advec">momentum_advec</a> |
---|
| 866 | and <a href="#scalar_advec">scalar_advec</a>), |
---|
| 867 | not to the prognostic variables themselves. At the bottom and top |
---|
| 868 | boundary of the model domain the filter effect for vertical |
---|
| 869 | 2-delta-waves is reduced. There, the amplitude of these waves is only |
---|
| 870 | reduced by approx. 50%, otherwise by nearly 100%. <br> |
---|
[61] | 871 | Filter factors with values > <i>0.01</i> also |
---|
| 872 | reduce the amplitudes |
---|
[5] | 873 | of waves with wavelengths longer than 2-delta (see the paper by Mahrer |
---|
| 874 | and |
---|
[62] | 875 | Pielke, quoted above). </p> </td> </tr> <tr><td style="vertical-align: top;"><a name="loop_optimization"></a><span style="font-weight: bold;">loop_optimization</span></td><td style="vertical-align: top;">C*16</td><td style="vertical-align: top;"><span style="font-style: italic;">see right</span></td><td>Method used to optimize loops for solving the prognostic equations .<br><br>By |
---|
| 876 | default, the optimization method depends on the host on which PALM is |
---|
| 877 | running. On machines with vector-type CPUs, single 3d-loops are used to |
---|
| 878 | calculate each tendency term of each prognostic equation, while on all |
---|
| 879 | other machines, all prognostic equations are solved within one big loop |
---|
| 880 | over the two horizontal indices<span style="font-family: Courier New,Courier,monospace;"> i </span>and<span style="font-family: Courier New,Courier,monospace;"> j </span>(giving a good cache uitilization).<br><br>The default behaviour can be changed by setting either <span style="font-weight: bold;">loop_optimization</span> = <span style="font-style: italic;">'vector'</span> or <span style="font-weight: bold;">loop_optimization</span> = <span style="font-style: italic;">'cache'</span>.</td></tr><tr> |
---|
[61] | 881 | <td style="vertical-align: top;"><a name="mixing_length_1d"></a><span style="font-weight: bold;">mixing_length_1d</span><br> |
---|
| 882 | </td> <td style="vertical-align: top;">C*20<br> |
---|
| 883 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">'as_in_3d_</span><br style="font-style: italic;"> <span style="font-style: italic;">model'</span><br> </td> |
---|
| 884 | <td style="vertical-align: top;">Mixing length used in the |
---|
| 885 | 1d-model.<br> <br> |
---|
| 886 | By default the mixing length is calculated as in the 3d-model (i.e. it |
---|
| 887 | depends on the grid spacing).<br> <br> |
---|
| 888 | By setting <span style="font-weight: bold;">mixing_length_1d</span> |
---|
| 889 | = <span style="font-style: italic;">'blackadar'</span>, |
---|
[5] | 890 | the so-called Blackadar mixing length is used (l = kappa * z / ( 1 + |
---|
| 891 | kappa * z / lambda ) with the limiting value lambda = 2.7E-4 * u_g / f).<br> |
---|
[61] | 892 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="moisture"></a><b>moisture</b></p> |
---|
| 893 | </td> <td style="vertical-align: top;">L</td> |
---|
| 894 | <td style="vertical-align: top;"><i>.F.</i></td> |
---|
| 895 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 896 | switch on the prognostic equation for specific |
---|
| 897 | humidity q.<br> </p> <p>The initial vertical |
---|
| 898 | profile of q can be set via parameters <a href="chapter_4.1.html#q_surface">q_surface</a>, <a href="chapter_4.1.html#q_vertical_gradient">q_vertical_gradient</a> |
---|
[5] | 899 | and <a href="chapter_4.1.html#q_vertical_gradient_level">q_vertical_gradient_level</a>. |
---|
| 900 | Boundary conditions can be set via <a href="chapter_4.1.html#q_surface_initial_change">q_surface_initial_change</a> |
---|
| 901 | and <a href="chapter_4.1.html#surface_waterflux">surface_waterflux</a>.<br> |
---|
[61] | 902 | </p> |
---|
[5] | 903 | If the condensation scheme is switched on (<a href="chapter_4.1.html#cloud_physics">cloud_physics</a> |
---|
| 904 | = .TRUE.), q becomes the total liquid water content (sum of specific |
---|
[61] | 905 | humidity and liquid water content).</td> </tr> |
---|
| 906 | <tr> <td style="vertical-align: top;"> <p><a name="momentum_advec"></a><b>momentum_advec</b></p> |
---|
| 907 | </td> <td style="vertical-align: top;">C * 10</td> |
---|
| 908 | <td style="vertical-align: top;"><i>'pw-scheme'</i></td> |
---|
| 909 | <td style="vertical-align: top;"> <p>Advection |
---|
| 910 | scheme to be used for the momentum equations.<br> <br> |
---|
[5] | 911 | The user can choose between the following schemes:<br> |
---|
[61] | 912 | <br> <br> <span style="font-style: italic;">'pw-scheme'</span><br> |
---|
| 913 | </p> <div style="margin-left: 40px;">The scheme of |
---|
| 914 | Piascek and |
---|
[5] | 915 | Williams (1970, J. Comp. Phys., 6, |
---|
| 916 | 392-405) with central differences in the form C3 is used.<br> |
---|
| 917 | If intermediate Euler-timesteps are carried out in case of <a href="#timestep_scheme">timestep_scheme</a> |
---|
[61] | 918 | = <span style="font-style: italic;">'leapfrog+euler'</span> |
---|
| 919 | the |
---|
[5] | 920 | advection scheme is - for the Euler-timestep - automatically switched |
---|
[61] | 921 | to an upstream-scheme.<br> </div> <p> </p> <p><span style="font-style: italic;">'ups-scheme'</span><br> |
---|
| 922 | </p> <div style="margin-left: 40px;">The |
---|
| 923 | upstream-spline scheme is |
---|
[5] | 924 | used |
---|
| 925 | (see Mahrer and Pielke, |
---|
| 926 | 1978: Mon. Wea. Rev., 106, 818-830). In opposite to the |
---|
| 927 | Piascek-Williams scheme, this is characterized by much better numerical |
---|
| 928 | features (less numerical diffusion, better preservation of flow |
---|
| 929 | structures, e.g. vortices), but computationally it is much more |
---|
| 930 | expensive. In |
---|
| 931 | addition, the use of the Euler-timestep scheme is mandatory (<a href="#timestep_scheme">timestep_scheme</a> |
---|
[61] | 932 | = <span style="font-style: italic;">'</span><i>euler'</i>), |
---|
| 933 | i.e. the |
---|
[5] | 934 | timestep accuracy is only of first order. |
---|
| 935 | For this reason the advection of scalar variables (see <a href="#scalar_advec">scalar_advec</a>) |
---|
| 936 | should then also be carried out with the upstream-spline scheme, |
---|
| 937 | because otherwise the scalar variables would |
---|
| 938 | be subject to large numerical diffusion due to the upstream |
---|
[61] | 939 | scheme. </div> <p style="margin-left: 40px;">Since |
---|
| 940 | the cubic splines used tend |
---|
[5] | 941 | to overshoot under |
---|
| 942 | certain circumstances, this effect must be adjusted by suitable |
---|
| 943 | filtering and smoothing (see <a href="#cut_spline_overshoot">cut_spline_overshoot</a>, |
---|
[61] | 944 | <a href="#long_filter_factor">long_filter_factor</a>, |
---|
| 945 | <a href="#ups_limit_pt">ups_limit_pt</a>, <a href="#ups_limit_u">ups_limit_u</a>, <a href="#ups_limit_v">ups_limit_v</a>, <a href="#ups_limit_w">ups_limit_w</a>). |
---|
[5] | 946 | This is always neccessary for runs with stable stratification, |
---|
| 947 | even if this stratification appears only in parts of the model domain.<br> |
---|
[61] | 948 | </p> <div style="margin-left: 40px;">With stable |
---|
| 949 | stratification the |
---|
[5] | 950 | upstream-spline scheme also |
---|
| 951 | produces gravity waves with large amplitude, which must be |
---|
| 952 | suitably damped (see <a href="chapter_4.2.html#rayleigh_damping_factor">rayleigh_damping_factor</a>).<br> |
---|
[61] | 953 | <br> <span style="font-weight: bold;">Important: </span>The |
---|
[5] | 954 | upstream-spline scheme is not implemented for humidity and passive |
---|
| 955 | scalars (see <a href="#moisture">moisture</a> |
---|
| 956 | and <a href="#passive_scalar">passive_scalar</a>) |
---|
| 957 | and requires the use of a 2d-domain-decomposition. The last conditions |
---|
| 958 | severely restricts code optimization on several machines leading to |
---|
| 959 | very long execution times! The scheme is also not allowed for |
---|
| 960 | non-cyclic lateral boundary conditions (see <a href="#bc_lr">bc_lr</a> |
---|
[61] | 961 | and <a href="#bc_ns">bc_ns</a>).</div> </td> |
---|
| 962 | </tr> <tr> <td style="vertical-align: top;"><a name="netcdf_precision"></a><span style="font-weight: bold;">netcdf_precision</span><br> |
---|
| 963 | </td> <td style="vertical-align: top;">C*20<br> |
---|
| 964 | (10)<br> </td> <td style="vertical-align: top;"><span style="font-style: italic;">single preci-</span><br style="font-style: italic;"> <span style="font-style: italic;">sion for all</span><br style="font-style: italic;"> <span style="font-style: italic;">output quan-</span><br style="font-style: italic;"> <span style="font-style: italic;">tities</span><br> </td> |
---|
| 965 | <td style="vertical-align: top;">Defines the accuracy of |
---|
| 966 | the NetCDF output.<br> <br> |
---|
| 967 | By default, all NetCDF output data (see <a href="chapter_4.2.html#data_output_format">data_output_format</a>) |
---|
| 968 | have single precision (4 byte) accuracy. Double precision (8 |
---|
| 969 | byte) can be choosen alternatively.<br> |
---|
| 970 | Accuracy for the different output data (cross sections, 3d-volume data, |
---|
| 971 | spectra, etc.) can be set independently.<br> <span style="font-style: italic;">'<out>_NF90_REAL4'</span> |
---|
| 972 | (single precision) or <span style="font-style: italic;">'<out>_NF90_REAL8'</span> |
---|
| 973 | (double precision) are the two principally allowed values for <span style="font-weight: bold;">netcdf_precision</span>, |
---|
| 974 | where the string <span style="font-style: italic;">'<out>' |
---|
| 975 | </span>can be chosen out of the following list:<br> <br> |
---|
| 976 | <table style="text-align: left; width: 284px; height: 234px;" border="1" cellpadding="2" cellspacing="2"> <tbody> |
---|
| 977 | <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'xy'</span><br> </td> |
---|
| 978 | <td style="vertical-align: top;">horizontal cross section<br> |
---|
| 979 | </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'xz'</span><br> </td> |
---|
| 980 | <td style="vertical-align: top;">vertical (xz) cross |
---|
| 981 | section<br> </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'yz'</span><br> </td> |
---|
| 982 | <td style="vertical-align: top;">vertical (yz) cross |
---|
| 983 | section<br> </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'2d'</span><br> </td> |
---|
| 984 | <td style="vertical-align: top;">all cross sections<br> |
---|
| 985 | </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'3d'</span><br> </td> |
---|
| 986 | <td style="vertical-align: top;">volume data<br> </td> |
---|
| 987 | </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'pr'</span><br> </td> |
---|
| 988 | <td style="vertical-align: top;">vertical profiles<br> |
---|
| 989 | </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'ts'</span><br> </td> |
---|
| 990 | <td style="vertical-align: top;">time series, particle |
---|
| 991 | time series<br> </td> </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'sp'</span><br> </td> |
---|
| 992 | <td style="vertical-align: top;">spectra<br> </td> |
---|
| 993 | </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'prt'</span><br> </td> |
---|
| 994 | <td style="vertical-align: top;">particles<br> </td> |
---|
| 995 | </tr> <tr> <td style="vertical-align: top;"><span style="font-style: italic;">'all'</span><br> </td> |
---|
| 996 | <td style="vertical-align: top;">all output quantities<br> |
---|
| 997 | </td> </tr> </tbody> </table> <br> <span style="font-weight: bold;">Example:</span><br> |
---|
[5] | 998 | If all cross section data and the particle data shall be output in |
---|
[61] | 999 | double precision and all other quantities in single precision, then <span style="font-weight: bold;">netcdf_precision</span> = <span style="font-style: italic;">'2d_NF90_REAL8'</span>, <span style="font-style: italic;">'prt_NF90_REAL8'</span> |
---|
| 1000 | has to be assigned.<br> </td> </tr> |
---|
| 1001 | <tr> <td style="vertical-align: top;"> <p><a name="npex"></a><b>npex</b></p> </td> |
---|
| 1002 | <td style="vertical-align: top;">I</td> <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p>Number of processors |
---|
| 1003 | along x-direction of the virtual |
---|
[5] | 1004 | processor |
---|
[61] | 1005 | net. </p> <p>For parallel runs, the total |
---|
| 1006 | number of processors to be used |
---|
[5] | 1007 | is given by |
---|
[61] | 1008 | the <span style="font-weight: bold;">mrun</span> |
---|
| 1009 | option <a href="http://www.muk.uni-hannover.de/software/mrun_beschreibung.html#Opt-X">-X</a>. |
---|
[5] | 1010 | By default, depending on the type of the parallel computer, PALM |
---|
| 1011 | generates a 1d processor |
---|
| 1012 | net (domain decomposition along x, <span style="font-weight: bold;">npey</span> |
---|
[61] | 1013 | = <span style="font-style: italic;">1</span>) or a |
---|
| 1014 | 2d-net (this is |
---|
[5] | 1015 | favored on machines with fast communication network). In case of a |
---|
| 1016 | 2d-net, it is tried to make it more or less square-shaped. If, for |
---|
| 1017 | example, 16 processors are assigned (-X 16), a 4 * 4 processor net is |
---|
[61] | 1018 | generated (<span style="font-weight: bold;">npex</span> |
---|
| 1019 | = <span style="font-style: italic;">4</span>, <span style="font-weight: bold;">npey</span> |
---|
[5] | 1020 | = <span style="font-style: italic;">4</span>). |
---|
| 1021 | This choice is optimal for square total domains (<a href="#nx">nx</a> |
---|
| 1022 | = <a href="#ny">ny</a>), |
---|
| 1023 | since then the number of ghost points at the lateral boundarys of |
---|
| 1024 | the subdomains is minimal. If <span style="font-weight: bold;">nx</span> |
---|
[61] | 1025 | nd <span style="font-weight: bold;">ny</span> |
---|
| 1026 | differ extremely, the |
---|
[5] | 1027 | processor net should be manually adjusted using adequate values for <span style="font-weight: bold;">npex</span> and <span style="font-weight: bold;">npey</span>. </p> |
---|
[61] | 1028 | <p><b>Important:</b> The value of <span style="font-weight: bold;">npex</span> * <span style="font-weight: bold;">npey</span> must exactly |
---|
| 1029 | correspond to the |
---|
[5] | 1030 | value assigned by the <span style="font-weight: bold;">mrun</span>-option |
---|
[61] | 1031 | <tt>-X</tt>. |
---|
[5] | 1032 | Otherwise the model run will abort with a corresponding error |
---|
| 1033 | message. <br> |
---|
| 1034 | Additionally, the specification of <span style="font-weight: bold;">npex</span> |
---|
[61] | 1035 | and <span style="font-weight: bold;">npey</span> |
---|
| 1036 | may of course |
---|
[5] | 1037 | override the default setting for the domain decomposition (1d or 2d) |
---|
| 1038 | which may have a significant (negative) effect on the code performance. |
---|
[61] | 1039 | </p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="npey"></a><b>npey</b></p> |
---|
| 1040 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1041 | <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p>Number of processors |
---|
| 1042 | along y-direction of the virtual |
---|
[5] | 1043 | processor |
---|
[61] | 1044 | net. </p> <p>For further information see <a href="#npex">npex</a>.</p> </td> </tr> |
---|
| 1045 | <tr> <td style="vertical-align: top;"> <p><a name="nsor_ini"></a><b>nsor_ini</b></p> |
---|
| 1046 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1047 | <td style="vertical-align: top;"><i>100</i></td> |
---|
| 1048 | <td style="vertical-align: top;"> <p>Initial number |
---|
| 1049 | of iterations with the SOR algorithm. </p> <p>This |
---|
| 1050 | parameter is only effective if the SOR algorithm was |
---|
[5] | 1051 | selected as the pressure solver scheme (<a href="chapter_4.2.html#psolver">psolver</a> |
---|
[61] | 1052 | = <span style="font-style: italic;">'sor'</span>) |
---|
| 1053 | and specifies the |
---|
[5] | 1054 | number of initial iterations of the SOR |
---|
| 1055 | scheme (at t = 0). The number of subsequent iterations at the following |
---|
| 1056 | timesteps is determined |
---|
| 1057 | with the parameter <a href="#nsor">nsor</a>. |
---|
[61] | 1058 | Usually <b>nsor</b> < <b>nsor_ini</b>, |
---|
| 1059 | since in each case |
---|
[5] | 1060 | subsequent calls to <a href="chapter_4.2.html#psolver">psolver</a> |
---|
| 1061 | use the solution of the previous call as initial value. Suitable |
---|
| 1062 | test runs should determine whether sufficient convergence of the |
---|
| 1063 | solution is obtained with the default value and if necessary the value |
---|
[61] | 1064 | of <b>nsor_ini</b> should be changed.</p> </td> |
---|
| 1065 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 1066 | <p><a name="nx"></a><b>nx</b></p> |
---|
| 1067 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1068 | <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p>Number of grid |
---|
| 1069 | points in x-direction. </p> <p>A value for this |
---|
| 1070 | parameter must be assigned. Since the lower |
---|
[5] | 1071 | array bound in PALM |
---|
| 1072 | starts with i = 0, the actual number of grid points is equal to <b>nx+1</b>. |
---|
| 1073 | In case of cyclic boundary conditions along x, the domain size is (<b>nx+1</b>)* |
---|
[61] | 1074 | <a href="#dx">dx</a>.</p> <p>For |
---|
| 1075 | parallel runs, in case of <a href="#grid_matching">grid_matching</a> |
---|
| 1076 | = <span style="font-style: italic;">'strict'</span>, |
---|
| 1077 | <b>nx+1</b> must |
---|
[5] | 1078 | be an integral multiple |
---|
| 1079 | of the processor numbers (see <a href="#npex">npex</a> |
---|
| 1080 | and <a href="#npey">npey</a>) |
---|
| 1081 | along x- as well as along y-direction (due to data |
---|
[61] | 1082 | transposition restrictions).</p> </td> </tr> <tr> |
---|
| 1083 | <td style="vertical-align: top;"> <p><a name="ny"></a><b>ny</b></p> |
---|
| 1084 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1085 | <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p>Number of grid |
---|
| 1086 | points in y-direction. </p> <p>A value for this |
---|
| 1087 | parameter must be assigned. Since the lower |
---|
[5] | 1088 | array bound in PALM starts with i = 0, the actual number of grid points |
---|
[61] | 1089 | is equal to <b>ny+1</b>. In case of cyclic boundary |
---|
| 1090 | conditions along |
---|
[5] | 1091 | y, the domain size is (<b>ny+1</b>) * <a href="#dy">dy</a>.</p> |
---|
[61] | 1092 | <p>For parallel runs, in case of <a href="#grid_matching">grid_matching</a> |
---|
| 1093 | = <span style="font-style: italic;">'strict'</span>, |
---|
| 1094 | <b>ny+1</b> must |
---|
[5] | 1095 | be an integral multiple |
---|
| 1096 | of the processor numbers (see <a href="#npex">npex</a> |
---|
| 1097 | and <a href="#npey">npey</a>) |
---|
| 1098 | along y- as well as along x-direction (due to data |
---|
[61] | 1099 | transposition restrictions).</p> </td> </tr> <tr> |
---|
| 1100 | <td style="vertical-align: top;"> <p><a name="nz"></a><b>nz</b></p> |
---|
| 1101 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1102 | <td style="vertical-align: top;"><br> </td> <td style="vertical-align: top;"> <p>Number of grid |
---|
| 1103 | points in z-direction. </p> <p>A value for this |
---|
| 1104 | parameter must be assigned. Since the lower |
---|
[5] | 1105 | array bound in PALM |
---|
| 1106 | starts with k = 0 and since one additional grid point is added at the |
---|
[61] | 1107 | top boundary (k = <b>nz+1</b>), the actual number of grid |
---|
| 1108 | points is <b>nz+2</b>. |
---|
| 1109 | However, the prognostic equations are only solved up to <b>nz</b> |
---|
| 1110 | (u, |
---|
[5] | 1111 | v) |
---|
[61] | 1112 | or up to <b>nz-1</b> (w, scalar quantities). The top |
---|
| 1113 | boundary for u |
---|
| 1114 | and v is at k = <b>nz+1</b> (u, v) while at k = <b>nz</b> |
---|
| 1115 | for all |
---|
| 1116 | other quantities. </p> <p>For parallel |
---|
| 1117 | runs, in case of <a href="#grid_matching">grid_matching</a> |
---|
| 1118 | = <span style="font-style: italic;">'strict'</span>, |
---|
| 1119 | <b>nz</b> must |
---|
[5] | 1120 | be an integral multiple of |
---|
| 1121 | the number of processors in x-direction (due to data transposition |
---|
[61] | 1122 | restrictions).</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="omega"></a><b>omega</b></p> |
---|
| 1123 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1124 | <td style="vertical-align: top;"><i>7.29212E-5</i></td> |
---|
| 1125 | <td style="vertical-align: top;"> <p>Angular |
---|
| 1126 | velocity of the rotating system (in rad s<sup>-1</sup>). |
---|
| 1127 | </p> <p>The angular velocity of the earth is set by |
---|
| 1128 | default. The |
---|
[5] | 1129 | values |
---|
[61] | 1130 | of the Coriolis parameters are calculated as: </p> <ul> |
---|
| 1131 | <p>f = 2.0 * <b>omega</b> * sin(<a href="#phi">phi</a>) |
---|
| 1132 | <br>f* = 2.0 * <b>omega</b> * cos(<a href="#phi">phi</a>)</p> |
---|
| 1133 | </ul> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="outflow_damping_width"></a><b>outflow_damping_width</b></p> |
---|
| 1134 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1135 | <td style="vertical-align: top;"><span style="font-style: italic;">MIN(20, |
---|
[5] | 1136 | nx/2</span> or <span style="font-style: italic;">ny/2)</span></td> |
---|
[61] | 1137 | <td style="vertical-align: top;">Width of |
---|
[5] | 1138 | the damping range in the vicinity of the outflow (gridpoints).<br> |
---|
[61] | 1139 | <br> |
---|
[5] | 1140 | When using non-cyclic lateral boundaries (see <a href="chapter_4.1.html#bc_lr">bc_lr</a> |
---|
| 1141 | or <a href="chapter_4.1.html#bc_ns">bc_ns</a>), |
---|
| 1142 | a smoothing has to be applied to the |
---|
| 1143 | velocity field in the vicinity of the outflow in order to suppress any |
---|
| 1144 | reflections of outgoing disturbances. This parameter controlls the |
---|
| 1145 | horizontal range to which the smoothing is applied. The range is given |
---|
| 1146 | in gridpoints counted from the respective outflow boundary. For further |
---|
| 1147 | details about the smoothing see parameter <a href="chapter_4.1.html#km_damp_max">km_damp_max</a>, |
---|
[61] | 1148 | which defines the magnitude of the damping.</td> </tr> |
---|
| 1149 | <tr> <td style="vertical-align: top;"> <p><a name="overshoot_limit_e"></a><b>overshoot_limit_e</b></p> |
---|
| 1150 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1151 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1152 | <td style="vertical-align: top;"> <p>Allowed limit |
---|
| 1153 | for the overshooting of subgrid-scale TKE in |
---|
[5] | 1154 | case that the upstream-spline scheme is switched on (in m<sup>2</sup>/s<sup>2</sup>). |
---|
[61] | 1155 | </p> <p>By deafult, if cut-off of overshoots is switched |
---|
| 1156 | on for the |
---|
[5] | 1157 | upstream-spline scheme (see <a href="#cut_spline_overshoot">cut_spline_overshoot</a>), |
---|
| 1158 | no overshoots are permitted at all. If <b>overshoot_limit_e</b> |
---|
| 1159 | is given a non-zero value, overshoots with the respective |
---|
| 1160 | amplitude (both upward and downward) are allowed. </p> |
---|
[61] | 1161 | <p>Only positive values are allowed for <b>overshoot_limit_e</b>.</p> |
---|
| 1162 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="overshoot_limit_pt"></a><b>overshoot_limit_pt</b></p> |
---|
| 1163 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1164 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1165 | <td style="vertical-align: top;"> <p>Allowed limit |
---|
| 1166 | for the overshooting of potential temperature in |
---|
[5] | 1167 | case that the upstream-spline scheme is switched on (in K). </p> |
---|
[61] | 1168 | <p>For further information see <a href="#overshoot_limit_e">overshoot_limit_e</a>. |
---|
| 1169 | </p> <p>Only positive values are allowed for <b>overshoot_limit_pt</b>.</p> |
---|
| 1170 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="overshoot_limit_u"></a><b>overshoot_limit_u</b></p> |
---|
| 1171 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1172 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1173 | <td style="vertical-align: top;">Allowed limit for the |
---|
[5] | 1174 | overshooting of |
---|
| 1175 | the u-component of velocity in case that the upstream-spline scheme is |
---|
[61] | 1176 | switched on (in m/s). <p>For further information see <a href="#overshoot_limit_e">overshoot_limit_e</a>. |
---|
| 1177 | </p> <p>Only positive values are allowed for <b>overshoot_limit_u</b>.</p> |
---|
| 1178 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="overshoot_limit_v"></a><b>overshoot_limit_v</b></p> |
---|
| 1179 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1180 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1181 | <td style="vertical-align: top;"> <p>Allowed limit |
---|
| 1182 | for the overshooting of the v-component of |
---|
[5] | 1183 | velocity in case that the upstream-spline scheme is switched on |
---|
[61] | 1184 | (in m/s). </p> <p>For further information see <a href="#overshoot_limit_e">overshoot_limit_e</a>. |
---|
| 1185 | </p> <p>Only positive values are allowed for <b>overshoot_limit_v</b>.</p> |
---|
| 1186 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="overshoot_limit_w"></a><b>overshoot_limit_w</b></p> |
---|
| 1187 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1188 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1189 | <td style="vertical-align: top;"> <p>Allowed limit |
---|
| 1190 | for the overshooting of the w-component of |
---|
[5] | 1191 | velocity in case that the upstream-spline scheme is switched on |
---|
[61] | 1192 | (in m/s). </p> <p>For further information see <a href="#overshoot_limit_e">overshoot_limit_e</a>. |
---|
| 1193 | </p> <p>Only positive values are permitted for <b>overshoot_limit_w</b>.</p> |
---|
| 1194 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="passive_scalar"></a><b>passive_scalar</b></p> |
---|
| 1195 | </td> <td style="vertical-align: top;">L</td> |
---|
| 1196 | <td style="vertical-align: top;"><i>.F.</i></td> |
---|
| 1197 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 1198 | switch on the prognostic equation for a passive |
---|
| 1199 | scalar. <br> </p> <p>The initial vertical profile |
---|
| 1200 | of s can be set via parameters <a href="#s_surface">s_surface</a>, |
---|
| 1201 | <a href="#s_vertical_gradient">s_vertical_gradient</a> |
---|
[5] | 1202 | and <a href="#s_vertical_gradient_level">s_vertical_gradient_level</a>. |
---|
| 1203 | Boundary conditions can be set via <a href="#s_surface_initial_change">s_surface_initial_change</a> |
---|
[61] | 1204 | and <a href="#surface_scalarflux">surface_scalarflux</a>. |
---|
| 1205 | </p> <p><b>Note:</b> <br> |
---|
| 1206 | With <span style="font-weight: bold;">passive_scalar</span> |
---|
| 1207 | switched |
---|
[5] | 1208 | on, the simultaneous use of humidity (see <a href="#moisture">moisture</a>) |
---|
[61] | 1209 | is impossible.</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="phi"></a><b>phi</b></p> |
---|
| 1210 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1211 | <td style="vertical-align: top;"><i>55.0</i></td> |
---|
| 1212 | <td style="vertical-align: top;"> <p>Geographical |
---|
| 1213 | latitude (in degrees). </p> <p>The value of |
---|
| 1214 | this parameter determines the value of the |
---|
[5] | 1215 | Coriolis parameters f and f*, provided that the angular velocity (see <a href="#omega">omega</a>) |
---|
[61] | 1216 | is non-zero.</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="prandtl_layer"></a><b>prandtl_layer</b></p> |
---|
| 1217 | </td> <td style="vertical-align: top;">L</td> |
---|
| 1218 | <td style="vertical-align: top;"><i>.T.</i></td> |
---|
| 1219 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 1220 | switch on a Prandtl layer. </p> <p>By default, |
---|
| 1221 | a Prandtl layer is switched on at the bottom |
---|
[5] | 1222 | boundary between z = 0 and z = 0.5 * <a href="#dz">dz</a> |
---|
| 1223 | (the first computational grid point above ground for u, v and the |
---|
| 1224 | scalar quantities). |
---|
| 1225 | In this case, at the bottom boundary, free-slip conditions for u and v |
---|
| 1226 | (see <a href="#bc_uv_b">bc_uv_b</a>) |
---|
| 1227 | are not allowed. Likewise, laminar |
---|
| 1228 | simulations with constant eddy diffusivities (<a href="#km_constant">km_constant</a>) |
---|
[61] | 1229 | are forbidden. </p> <p>With Prandtl-layer |
---|
| 1230 | switched off, the TKE boundary condition <a href="#bc_e_b">bc_e_b</a> |
---|
| 1231 | = '<i>(u*)**2+neumann'</i> must not be used and is |
---|
| 1232 | automatically |
---|
| 1233 | changed to <i>'neumann'</i> if necessary. Also, |
---|
| 1234 | the pressure |
---|
[5] | 1235 | boundary condition <a href="#bc_p_b">bc_p_b</a> |
---|
| 1236 | = <i>'neumann+inhomo'</i> is not allowed. </p> |
---|
[61] | 1237 | <p>The roughness length is declared via the parameter <a href="#roughness_length">roughness_length</a>.</p> |
---|
| 1238 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="precipitation"></a><b>precipitation</b></p> |
---|
| 1239 | </td> <td style="vertical-align: top;">L</td> |
---|
| 1240 | <td style="vertical-align: top;"><span style="font-style: italic;">.F.</span></td> <td style="vertical-align: top;"> <p>Parameter to switch |
---|
| 1241 | on the precipitation scheme.<br> </p> <p>For |
---|
| 1242 | precipitation processes PALM uses a simplified Kessler |
---|
[5] | 1243 | scheme. This scheme only considers the |
---|
| 1244 | so-called autoconversion, that means the generation of rain water by |
---|
| 1245 | coagulation of cloud drops among themselves. Precipitation begins and |
---|
| 1246 | is immediately removed from the flow as soon as the liquid water |
---|
[61] | 1247 | content exceeds the critical value of 0.5 g/kg.</p> </td> </tr> |
---|
| 1248 | <tr><td style="vertical-align: top;"><a name="pt_reference"></a><span style="font-weight: bold;">pt_reference</span></td><td style="vertical-align: top;">R</td><td style="vertical-align: top;"><span style="font-style: italic;">use horizontal average as |
---|
| 1249 | refrence</span></td><td style="vertical-align: top;">Reference |
---|
| 1250 | temperature to be used in all buoyancy terms (in K).<br><br>By |
---|
| 1251 | default, the instantaneous horizontal average over the total model |
---|
| 1252 | domain is used.</td></tr><tr> <td style="vertical-align: top;"> <p><a name="pt_surface"></a><b>pt_surface</b></p> |
---|
| 1253 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1254 | <td style="vertical-align: top;"><i>300.0</i></td> |
---|
| 1255 | <td style="vertical-align: top;"> <p>Surface |
---|
| 1256 | potential temperature (in K). </p> <p>This |
---|
| 1257 | parameter assigns the value of the potential temperature |
---|
| 1258 | pt at the surface (k=0)<b>.</b> Starting from this value, |
---|
| 1259 | the |
---|
[5] | 1260 | initial vertical temperature profile is constructed with <a href="#pt_vertical_gradient">pt_vertical_gradient</a> |
---|
[61] | 1261 | and <a href="#pt_vertical_gradient_level">pt_vertical_gradient_level |
---|
| 1262 | </a>. |
---|
[5] | 1263 | This profile is also used for the 1d-model as a stationary profile.</p> |
---|
[61] | 1264 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="pt_surface_initial_change"></a><b>pt_surface_initial</b> |
---|
| 1265 | <br> <b>_change</b></p> </td> <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><span style="font-style: italic;">0.0</span><br> </td> |
---|
| 1266 | <td style="vertical-align: top;"> <p>Change in |
---|
| 1267 | surface temperature to be made at the beginning of |
---|
[5] | 1268 | the 3d run |
---|
[61] | 1269 | (in K). </p> <p>If <b>pt_surface_initial_change</b> |
---|
| 1270 | is set to a non-zero |
---|
[5] | 1271 | value, the near surface sensible heat flux is not allowed to be given |
---|
| 1272 | simultaneously (see <a href="#surface_heatflux">surface_heatflux</a>).</p> |
---|
[61] | 1273 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="pt_vertical_gradient"></a><b>pt_vertical_gradient</b></p> |
---|
| 1274 | </td> <td style="vertical-align: top;">R (10)</td> |
---|
| 1275 | <td style="vertical-align: top;"><i>10 * 0.0</i></td> |
---|
| 1276 | <td style="vertical-align: top;"> <p>Temperature |
---|
| 1277 | gradient(s) of the initial temperature profile (in |
---|
[5] | 1278 | K |
---|
[61] | 1279 | / 100 m). </p> <p>This temperature gradient |
---|
| 1280 | holds starting from the height |
---|
[5] | 1281 | level defined by <a href="#pt_vertical_gradient_level">pt_vertical_gradient_level</a> |
---|
| 1282 | (precisely: for all uv levels k where zu(k) > |
---|
| 1283 | pt_vertical_gradient_level, |
---|
| 1284 | pt_init(k) is set: pt_init(k) = pt_init(k-1) + dzu(k) * <b>pt_vertical_gradient</b>) |
---|
| 1285 | up to the top boundary or up to the next height level defined |
---|
| 1286 | by <a href="#pt_vertical_gradient_level">pt_vertical_gradient_level</a>. |
---|
| 1287 | A total of 10 different gradients for 11 height intervals (10 intervals |
---|
| 1288 | if <a href="#pt_vertical_gradient_level">pt_vertical_gradient_level</a>(1) |
---|
[61] | 1289 | = <i>0.0</i>) can be assigned. The surface temperature is |
---|
| 1290 | assigned via <a href="#pt_surface">pt_surface</a>. |
---|
| 1291 | </p> <p>Example: </p> <ul> <p><b>pt_vertical_gradient</b> |
---|
| 1292 | = <i>1.0</i>, <i>0.5</i>, <br> |
---|
| 1293 | <b>pt_vertical_gradient_level</b> = <i>500.0</i>, |
---|
| 1294 | <i>1000.0</i>,</p> </ul> <p>That |
---|
| 1295 | defines the temperature profile to be neutrally |
---|
[5] | 1296 | stratified |
---|
| 1297 | up to z = 500.0 m with a temperature given by <a href="#pt_surface">pt_surface</a>. |
---|
[61] | 1298 | For 500.0 m < z <= 1000.0 m the temperature gradient is |
---|
| 1299 | 1.0 K / |
---|
[5] | 1300 | 100 m and for z > 1000.0 m up to the top boundary it is |
---|
| 1301 | 0.5 K / 100 m (it is assumed that the assigned height levels correspond |
---|
[61] | 1302 | with uv levels). </p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="pt_vertical_gradient_level"></a><b>pt_vertical_gradient</b> |
---|
| 1303 | <br> <b>_level</b></p> </td> <td style="vertical-align: top;">R (10)</td> <td style="vertical-align: top;"> <p><i>10 *</i> |
---|
| 1304 | <span style="font-style: italic;">0.0</span><br> |
---|
| 1305 | </p> </td> <td style="vertical-align: top;"> |
---|
| 1306 | <p>Height level from which on the temperature gradient defined by |
---|
| 1307 | <a href="#pt_vertical_gradient">pt_vertical_gradient</a> |
---|
| 1308 | is effective (in m). </p> <p>The height levels |
---|
| 1309 | are to be assigned in ascending order. The |
---|
[5] | 1310 | default values result in a neutral stratification regardless of the |
---|
| 1311 | values of <a href="#pt_vertical_gradient">pt_vertical_gradient</a> |
---|
| 1312 | (unless the top boundary of the model is higher than 100000.0 m). |
---|
| 1313 | For the piecewise construction of temperature profiles see <a href="#pt_vertical_gradient">pt_vertical_gradient</a>.</p> |
---|
[61] | 1314 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="q_surface"></a><b>q_surface</b></p> |
---|
| 1315 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1316 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1317 | <td style="vertical-align: top;"> <p>Surface |
---|
| 1318 | specific humidity / total water content (kg/kg). </p> <p>This |
---|
| 1319 | parameter assigns the value of the specific humidity q at |
---|
| 1320 | the surface (k=0). Starting from this value, the initial |
---|
| 1321 | humidity |
---|
[5] | 1322 | profile is constructed with <a href="#q_vertical_gradient">q_vertical_gradient</a> |
---|
| 1323 | and <a href="#q_vertical_gradient_level">q_vertical_gradient_level</a>. |
---|
| 1324 | This profile is also used for the 1d-model as a stationary profile.</p> |
---|
[61] | 1325 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="q_surface_initial_change"></a><b>q_surface_initial</b> |
---|
| 1326 | <br> <b>_change</b></p> </td> <td style="vertical-align: top;">R<br> </td> <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1327 | <td style="vertical-align: top;"> <p>Change in |
---|
| 1328 | surface specific humidity / total water content to |
---|
[5] | 1329 | be made at the beginning |
---|
[61] | 1330 | of the 3d run (kg/kg). </p> <p>If <b>q_surface_initial_change</b><i> |
---|
| 1331 | </i>is set to a |
---|
[5] | 1332 | non-zero value the |
---|
| 1333 | near surface latent heat flux (water flux) is not allowed to be given |
---|
| 1334 | simultaneously (see <a href="#surface_waterflux">surface_waterflux</a>).</p> |
---|
[61] | 1335 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="q_vertical_gradient"></a><b>q_vertical_gradient</b></p> |
---|
| 1336 | </td> <td style="vertical-align: top;">R (10)</td> |
---|
| 1337 | <td style="vertical-align: top;"><i>10 * 0.0</i></td> |
---|
| 1338 | <td style="vertical-align: top;"> <p>Humidity |
---|
| 1339 | gradient(s) of the initial humidity profile |
---|
| 1340 | (in 1/100 m). </p> <p>This humidity gradient |
---|
| 1341 | holds starting from the height |
---|
[5] | 1342 | level defined by <a href="#q_vertical_gradient_level">q_vertical_gradient_level</a> |
---|
| 1343 | (precisely: for all uv levels k, where zu(k) > |
---|
| 1344 | q_vertical_gradient_level, |
---|
| 1345 | q_init(k) is set: q_init(k) = q_init(k-1) + dzu(k) * <b>q_vertical_gradient</b>) |
---|
| 1346 | up to the top boundary or up to the next height level defined |
---|
| 1347 | by <a href="#q_vertical_gradient_level">q_vertical_gradient_level</a>. |
---|
| 1348 | A total of 10 different gradients for 11 height intervals (10 intervals |
---|
| 1349 | if <a href="#q_vertical_gradient_level">q_vertical_gradient_level</a>(1) |
---|
[61] | 1350 | = <i>0.0</i>) can be asigned. The surface humidity is |
---|
| 1351 | assigned |
---|
[5] | 1352 | via <a href="#q_surface">q_surface</a>. </p> |
---|
[61] | 1353 | <p>Example: </p> <ul> <p><b>q_vertical_gradient</b> |
---|
| 1354 | = <i>0.001</i>, <i>0.0005</i>, <br> |
---|
| 1355 | <b>q_vertical_gradient_level</b> = <i>500.0</i>, |
---|
| 1356 | <i>1000.0</i>,</p> </ul> |
---|
[5] | 1357 | That defines the humidity to be constant with height up to z = |
---|
| 1358 | 500.0 |
---|
| 1359 | m with a |
---|
| 1360 | value given by <a href="#q_surface">q_surface</a>. |
---|
[61] | 1361 | For 500.0 m < z <= 1000.0 m the humidity gradient is |
---|
| 1362 | 0.001 / 100 |
---|
[5] | 1363 | m and for z > 1000.0 m up to the top boundary it is |
---|
| 1364 | 0.0005 / 100 m (it is assumed that the assigned height levels |
---|
| 1365 | correspond with uv |
---|
[61] | 1366 | levels). </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="q_vertical_gradient_level"></a><b>q_vertical_gradient</b> |
---|
| 1367 | <br> <b>_level</b></p> </td> <td style="vertical-align: top;">R (10)</td> <td style="vertical-align: top;"> <p><i>10 *</i> |
---|
| 1368 | <i>0.0</i></p> </td> <td style="vertical-align: top;"> <p>Height level from |
---|
| 1369 | which on the moisture gradient defined by <a href="#q_vertical_gradient">q_vertical_gradient</a> |
---|
| 1370 | is effective (in m). </p> <p>The height levels |
---|
| 1371 | are to be assigned in ascending order. The |
---|
[5] | 1372 | default values result in a humidity constant with height regardless of |
---|
| 1373 | the values of <a href="#q_vertical_gradient">q_vertical_gradient</a> |
---|
| 1374 | (unless the top boundary of the model is higher than 100000.0 m). For |
---|
| 1375 | the piecewise construction of humidity profiles see <a href="#q_vertical_gradient">q_vertical_gradient</a>.</p> |
---|
[61] | 1376 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="radiation"></a><b>radiation</b></p> |
---|
| 1377 | </td> <td style="vertical-align: top;">L</td> |
---|
| 1378 | <td style="vertical-align: top;"><i>.F.</i></td> |
---|
| 1379 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 1380 | switch on longwave radiation cooling at |
---|
| 1381 | cloud-tops. </p> <p>Long-wave radiation |
---|
| 1382 | processes are parameterized by the |
---|
[5] | 1383 | effective emissivity, which considers only the absorption and emission |
---|
| 1384 | of long-wave radiation at cloud droplets. The radiation scheme can be |
---|
| 1385 | used only with <a href="#cloud_physics">cloud_physics</a> |
---|
[61] | 1386 | = .TRUE. .</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="random_generator"></a><b>random_generator</b></p> |
---|
| 1387 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 1388 | <td style="vertical-align: top;"> <p><i>'numerical</i><br> |
---|
| 1389 | <i>recipes'</i></p> </td> <td style="vertical-align: top;"> <p>Random number |
---|
| 1390 | generator to be used for creating uniformly |
---|
| 1391 | distributed random numbers. <br> </p> <p>It is |
---|
| 1392 | used if random perturbations are to be imposed on the |
---|
[5] | 1393 | velocity field or on the surface heat flux field (see <a href="chapter_4.2.html#create_disturbances">create_disturbances</a> |
---|
| 1394 | and <a href="chapter_4.2.html#random_heatflux">random_heatflux</a>). |
---|
| 1395 | By default, the "Numerical Recipes" random number generator is used. |
---|
| 1396 | This one provides exactly the same order of random numbers on all |
---|
| 1397 | different machines and should be used in particular for comparison runs.<br> |
---|
[61] | 1398 | <br> |
---|
[5] | 1399 | Besides, a system-specific generator is available ( <b>random_generator</b> |
---|
[61] | 1400 | = <i>'system-specific')</i> which should particularly be |
---|
| 1401 | used for runs |
---|
[5] | 1402 | on vector parallel computers (NEC), because the default generator |
---|
| 1403 | cannot be vectorized and therefore significantly drops down the code |
---|
[61] | 1404 | performance on these machines.<br> </p> <span style="font-weight: bold;">Note:</span><br> |
---|
[5] | 1405 | Results from two otherwise identical model runs will not be comparable |
---|
[61] | 1406 | one-to-one if they used different random number generators.</td> </tr> |
---|
| 1407 | <tr> <td style="vertical-align: top;"> <p><a name="random_heatflux"></a><b>random_heatflux</b></p> |
---|
| 1408 | </td> <td style="vertical-align: top;">L</td> |
---|
| 1409 | <td style="vertical-align: top;"><i>.F.</i></td> |
---|
| 1410 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 1411 | impose random perturbations on the internal two-dimensional near |
---|
| 1412 | surface heat flux field <span style="font-style: italic;">shf</span>. |
---|
| 1413 | <br> </p>If a near surface heat flux is used as bottom |
---|
| 1414 | boundary |
---|
[5] | 1415 | condition (see <a href="#surface_heatflux">surface_heatflux</a>), |
---|
| 1416 | it is by default assumed to be horizontally homogeneous. Random |
---|
[61] | 1417 | perturbations can be imposed on the internal |
---|
| 1418 | two-dimensional heat flux field <span style="font-style: italic;">shf</span> by assigning <b>random_heatflux</b> |
---|
| 1419 | = <i>.T.</i>. The disturbed heat flux field is calculated |
---|
| 1420 | by |
---|
[5] | 1421 | multiplying the |
---|
| 1422 | values at each mesh point with a normally distributed random number |
---|
| 1423 | with a mean value and standard deviation of 1. This is repeated after |
---|
[61] | 1424 | every timestep.<br> <br> |
---|
| 1425 | In case of a non-flat <a href="#topography">topography</a>, assigning |
---|
| 1426 | <b>random_heatflux</b> |
---|
| 1427 | = <i>.T.</i> imposes random perturbations on the |
---|
| 1428 | combined heat |
---|
| 1429 | flux field <span style="font-style: italic;">shf</span> |
---|
| 1430 | composed of <a href="#surface_heatflux">surface_heatflux</a> |
---|
| 1431 | at the bottom surface and <a href="#wall_heatflux">wall_heatflux(0)</a> |
---|
| 1432 | at the topography top face.</td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="rif_max"></a><b>rif_max</b></p> |
---|
| 1433 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1434 | <td style="vertical-align: top;"><i>1.0</i></td> |
---|
| 1435 | <td style="vertical-align: top;"> <p>Upper limit of |
---|
| 1436 | the flux-Richardson number. </p> <p>With the |
---|
| 1437 | Prandtl layer switched on (see <a href="#prandtl_layer">prandtl_layer</a>), |
---|
| 1438 | flux-Richardson numbers (rif) are calculated for z=z<sub>p</sub> |
---|
| 1439 | (k=1) |
---|
[5] | 1440 | in the 3d-model (in the 1d model for all heights). Their values in |
---|
| 1441 | particular determine the |
---|
| 1442 | values of the friction velocity (1d- and 3d-model) and the values of |
---|
| 1443 | the eddy diffusivity (1d-model). With small wind velocities at the |
---|
| 1444 | Prandtl layer top or small vertical wind shears in the 1d-model, rif |
---|
[61] | 1445 | can take up unrealistic large values. They are limited by an upper (<span style="font-weight: bold;">rif_max</span>) and lower |
---|
| 1446 | limit (see <a href="#rif_min">rif_min</a>) |
---|
| 1447 | for the flux-Richardson number. The condition <b>rif_max</b> |
---|
| 1448 | > <b>rif_min</b> |
---|
| 1449 | must be met.</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="rif_min"></a><b>rif_min</b></p> |
---|
| 1450 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1451 | <td style="vertical-align: top;"><i>- 5.0</i></td> |
---|
| 1452 | <td style="vertical-align: top;"> <p>Lower limit of |
---|
| 1453 | the flux-Richardson number. </p> <p>For further |
---|
| 1454 | explanations see <a href="#rif_max">rif_max</a>. |
---|
| 1455 | The condition <b>rif_max</b> > <b>rif_min </b>must |
---|
| 1456 | be met.</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="roughness_length"></a><b>roughness_length</b></p> |
---|
| 1457 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1458 | <td style="vertical-align: top;"><i>0.1</i></td> |
---|
| 1459 | <td style="vertical-align: top;"> <p>Roughness |
---|
| 1460 | length (in m). </p> <p>This parameter is |
---|
| 1461 | effective only in case that a Prandtl layer |
---|
[5] | 1462 | is switched |
---|
| 1463 | on (see <a href="#prandtl_layer">prandtl_layer</a>).</p> |
---|
[61] | 1464 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="scalar_advec"></a><b>scalar_advec</b></p> |
---|
| 1465 | </td> <td style="vertical-align: top;">C * 10</td> |
---|
| 1466 | <td style="vertical-align: top;"><i>'pw-scheme'</i></td> |
---|
| 1467 | <td style="vertical-align: top;"> <p>Advection |
---|
| 1468 | scheme to be used for the scalar quantities. </p> <p>The |
---|
| 1469 | user can choose between the following schemes:<br> </p> <p><span style="font-style: italic;">'pw-scheme'</span><br> |
---|
| 1470 | </p> <div style="margin-left: 40px;">The scheme of |
---|
| 1471 | Piascek and |
---|
[5] | 1472 | Williams (1970, J. Comp. Phys., 6, |
---|
| 1473 | 392-405) with central differences in the form C3 is used.<br> |
---|
| 1474 | If intermediate Euler-timesteps are carried out in case of <a href="#timestep_scheme">timestep_scheme</a> |
---|
[61] | 1475 | = <span style="font-style: italic;">'leapfrog+euler'</span> |
---|
| 1476 | the |
---|
[5] | 1477 | advection scheme is - for the Euler-timestep - automatically switched |
---|
[61] | 1478 | to an upstream-scheme. <br> </div> <br> <p><span style="font-style: italic;">'bc-scheme'</span><br> |
---|
| 1479 | </p> <div style="margin-left: 40px;">The Bott |
---|
| 1480 | scheme modified by |
---|
[5] | 1481 | Chlond (1994, Mon. |
---|
| 1482 | Wea. Rev., 122, 111-125). This is a conservative monotonous scheme with |
---|
| 1483 | very small numerical diffusion and therefore very good conservation of |
---|
| 1484 | scalar flow features. The scheme however, is computationally very |
---|
| 1485 | expensive both because it is expensive itself and because it does (so |
---|
| 1486 | far) not allow specific code optimizations (e.g. cache optimization). |
---|
| 1487 | Choice of this |
---|
| 1488 | scheme forces the Euler timestep scheme to be used for the scalar |
---|
| 1489 | quantities. For output of horizontally averaged |
---|
| 1490 | profiles of the resolved / total heat flux, <a href="chapter_4.2.html#data_output_pr">data_output_pr</a> |
---|
[61] | 1491 | = <i>'w*pt*BC'</i> / <i>'wptBC' </i>should |
---|
| 1492 | be used, instead of the |
---|
[5] | 1493 | standard profiles (<span style="font-style: italic;">'w*pt*'</span> |
---|
[61] | 1494 | and <span style="font-style: italic;">'wpt'</span>) |
---|
| 1495 | because these are |
---|
[5] | 1496 | too inaccurate with this scheme. However, for subdomain analysis (see <a href="#statistic_regions">statistic_regions</a>) |
---|
| 1497 | exactly the reverse holds: here <i>'w*pt*BC'</i> and <i>'wptBC'</i> |
---|
[61] | 1498 | show very large errors and should not be used.<br> <br> |
---|
[5] | 1499 | This scheme is not allowed for non-cyclic lateral boundary conditions |
---|
| 1500 | (see <a href="#bc_lr">bc_lr</a> |
---|
[61] | 1501 | and <a href="#bc_ns">bc_ns</a>).<br> <br> |
---|
| 1502 | </div> <span style="font-style: italic;">'ups-scheme'</span><br> |
---|
| 1503 | <p style="margin-left: 40px;">The upstream-spline-scheme |
---|
| 1504 | is used |
---|
[5] | 1505 | (see Mahrer and Pielke, |
---|
| 1506 | 1978: Mon. Wea. Rev., 106, 818-830). In opposite to the Piascek |
---|
| 1507 | Williams scheme, this is characterized by much better numerical |
---|
| 1508 | features (less numerical diffusion, better preservation of flux |
---|
| 1509 | structures, e.g. vortices), but computationally it is much more |
---|
| 1510 | expensive. In |
---|
| 1511 | addition, the use of the Euler-timestep scheme is mandatory (<a href="#timestep_scheme">timestep_scheme</a> |
---|
[61] | 1512 | = <span style="font-style: italic;">'</span><i>euler'</i>), |
---|
| 1513 | i.e. the |
---|
[5] | 1514 | timestep accuracy is only first order. For this reason the advection of |
---|
| 1515 | momentum (see <a href="#momentum_advec">momentum_advec</a>) |
---|
| 1516 | should then also be carried out with the upstream-spline scheme, |
---|
| 1517 | because otherwise the momentum would |
---|
| 1518 | be subject to large numerical diffusion due to the upstream |
---|
[61] | 1519 | scheme. </p> <p style="margin-left: 40px;">Since |
---|
| 1520 | the cubic splines used tend |
---|
[5] | 1521 | to overshoot under |
---|
| 1522 | certain circumstances, this effect must be adjusted by suitable |
---|
| 1523 | filtering and smoothing (see <a href="#cut_spline_overshoot">cut_spline_overshoot</a>, |
---|
[61] | 1524 | <a href="#long_filter_factor">long_filter_factor</a>, |
---|
| 1525 | <a href="#ups_limit_pt">ups_limit_pt</a>, <a href="#ups_limit_u">ups_limit_u</a>, <a href="#ups_limit_v">ups_limit_v</a>, <a href="#ups_limit_w">ups_limit_w</a>). |
---|
[5] | 1526 | This is always neccesssary for runs with stable stratification, |
---|
| 1527 | even if this stratification appears only in parts of the model |
---|
[61] | 1528 | domain. </p> <p style="margin-left: 40px;">With |
---|
| 1529 | stable stratification the |
---|
[5] | 1530 | upstream-upline scheme also produces gravity waves with large |
---|
| 1531 | amplitude, which must be |
---|
| 1532 | suitably damped (see <a href="chapter_4.2.html#rayleigh_damping_factor">rayleigh_damping_factor</a>).<br> |
---|
[61] | 1533 | </p> <p style="margin-left: 40px;"><span style="font-weight: bold;">Important: </span>The |
---|
[5] | 1534 | upstream-spline scheme is not implemented for humidity and passive |
---|
| 1535 | scalars (see <a href="#moisture">moisture</a> |
---|
| 1536 | and <a href="#passive_scalar">passive_scalar</a>) |
---|
| 1537 | and requires the use of a 2d-domain-decomposition. The last conditions |
---|
| 1538 | severely restricts code optimization on several machines leading to |
---|
| 1539 | very long execution times! This scheme is also not allowed for |
---|
| 1540 | non-cyclic lateral boundary conditions (see <a href="#bc_lr">bc_lr</a> |
---|
[61] | 1541 | and <a href="#bc_ns">bc_ns</a>).</p><br>A |
---|
| 1542 | differing advection scheme can be choosed for the subgrid-scale TKE |
---|
| 1543 | using parameter <a href="chapter_4.1.html#use_upstream_for_tke">use_upstream_for_tke</a>.</td> |
---|
| 1544 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 1545 | <p><a name="statistic_regions"></a><b>statistic_regions</b></p> |
---|
| 1546 | </td> <td style="vertical-align: top;">I</td> |
---|
| 1547 | <td style="vertical-align: top;"><i>0</i></td> |
---|
| 1548 | <td style="vertical-align: top;"> <p>Number of |
---|
| 1549 | additional user-defined subdomains for which |
---|
[5] | 1550 | statistical analysis |
---|
[61] | 1551 | and corresponding output (profiles, time series) shall be |
---|
| 1552 | made. </p> <p>By default, vertical profiles and |
---|
| 1553 | other statistical quantities |
---|
[5] | 1554 | are calculated as horizontal and/or volume average of the total model |
---|
| 1555 | domain. Beyond that, these calculations can also be carried out for |
---|
[61] | 1556 | subdomains which can be defined using the field <a href="chapter_3.5.3.html">rmask </a>within the |
---|
| 1557 | user-defined software |
---|
[5] | 1558 | (see <a href="chapter_3.5.3.html">chapter |
---|
| 1559 | 3.5.3</a>). The number of these subdomains is determined with the |
---|
[61] | 1560 | parameter <b>statistic_regions</b>. Maximum 9 additional |
---|
| 1561 | subdomains |
---|
[5] | 1562 | are allowed. The parameter <a href="chapter_4.3.html#region">region</a> |
---|
| 1563 | can be used to assigned names (identifier) to these subdomains which |
---|
| 1564 | are then used in the headers |
---|
[61] | 1565 | of the output files and plots.</p><p>If the default NetCDF |
---|
| 1566 | output format is selected (see parameter <a href="chapter_4.2.html#data_output_format">data_output_format</a>), |
---|
| 1567 | data for the total domain and all defined subdomains are output to the |
---|
| 1568 | same file(s) (<a href="chapter_3.4.html#DATA_1D_PR_NETCDF">DATA_1D_PR_NETCDF</a>, |
---|
| 1569 | <a href="chapter_3.4.html#DATA_1D_TS_NETCDF">DATA_1D_TS_NETCDF</a>). |
---|
| 1570 | In case of <span style="font-weight: bold;">statistic_regions</span> |
---|
| 1571 | > <span style="font-style: italic;">0</span>, |
---|
[5] | 1572 | data on the file for the different domains can be distinguished by a |
---|
| 1573 | suffix which is appended to the quantity names. Suffix 0 means data for |
---|
[61] | 1574 | the total domain, suffix 1 means data for subdomain 1, etc.</p><p>In |
---|
| 1575 | case of <span style="font-weight: bold;">data_output_format</span> |
---|
| 1576 | = <span style="font-style: italic;">'profil'</span>, |
---|
| 1577 | individual local files for profiles (<a href="chapter_3.4.html#PLOT1D_DATA">PLOT1D_DATA</a>) are |
---|
| 1578 | created for each subdomain. The individual subdomain files differ by |
---|
| 1579 | their name (the |
---|
[5] | 1580 | number of the respective subdomain is attached, e.g. |
---|
[48] | 1581 | PLOT1D_DATA_1). In this case the name of the file with the data of |
---|
| 1582 | the total domain is PLOT1D_DATA_0. If no subdomains |
---|
[61] | 1583 | are declared (<b>statistic_regions</b> = <i>0</i>), |
---|
| 1584 | the name |
---|
[48] | 1585 | PLOT1D_DATA is used (this must be considered in the |
---|
[61] | 1586 | respective file connection statements of the <span style="font-weight: bold;">mrun</span> configuration |
---|
| 1587 | file).</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="surface_heatflux"></a><b>surface_heatflux</b></p> |
---|
| 1588 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1589 | <td style="vertical-align: top;"><span style="font-style: italic;">no prescribed<br> |
---|
| 1590 | heatflux<br> </span></td> <td style="vertical-align: top;"> <p>Kinematic sensible |
---|
| 1591 | heat flux at the bottom surface (in K m/s). </p> <p>If |
---|
| 1592 | a value is assigned to this parameter, the internal two-dimensional |
---|
| 1593 | surface heat flux field <span style="font-style: italic;">shf</span> |
---|
| 1594 | is initialized with the value of <span style="font-weight: bold;">surface_heatflux</span> as |
---|
| 1595 | bottom (horizontally homogeneous) boundary condition for the |
---|
[5] | 1596 | temperature equation. This additionally requires that a Neumann |
---|
| 1597 | condition must be used for the potential temperature (see <a href="#bc_pt_b">bc_pt_b</a>), |
---|
| 1598 | because otherwise the resolved scale may contribute to |
---|
| 1599 | the surface flux so that a constant value cannot be guaranteed. Also, |
---|
| 1600 | changes of the |
---|
| 1601 | surface temperature (see <a href="#pt_surface_initial_change">pt_surface_initial_change</a>) |
---|
| 1602 | are not allowed. The parameter <a href="#random_heatflux">random_heatflux</a> |
---|
[61] | 1603 | can be used to impose random perturbations on the (homogeneous) surface |
---|
| 1604 | heat |
---|
[5] | 1605 | flux field <span style="font-style: italic;">shf</span>. </p> |
---|
[61] | 1606 | <p> |
---|
| 1607 | In case of a non-flat <a href="#topography">topography</a>, the |
---|
| 1608 | internal two-dimensional surface heat |
---|
| 1609 | flux field <span style="font-style: italic;">shf</span> |
---|
| 1610 | is initialized with the value of <span style="font-weight: bold;">surface_heatflux</span> |
---|
| 1611 | at the bottom surface and <a href="#wall_heatflux">wall_heatflux(0)</a> |
---|
| 1612 | at the topography top face. The parameter<a href="#random_heatflux"> random_heatflux</a> |
---|
| 1613 | can be used to impose random perturbations on this combined surface |
---|
| 1614 | heat |
---|
| 1615 | flux field <span style="font-style: italic;">shf</span>. |
---|
| 1616 | </p> <p>If no surface heat flux is assigned, <span style="font-style: italic;">shf</span> is calculated |
---|
| 1617 | at each timestep by u<sub>*</sub> * theta<sub>*</sub> |
---|
| 1618 | (of course only with <a href="#prandtl_layer">prandtl_layer</a> |
---|
| 1619 | switched on). Here, u<sub>*</sub> |
---|
| 1620 | and theta<sub>*</sub> are calculated from the Prandtl law |
---|
| 1621 | assuming |
---|
[5] | 1622 | logarithmic wind and temperature |
---|
| 1623 | profiles between k=0 and k=1. In this case a Dirichlet condition (see <a href="#bc_pt_b">bc_pt_b</a>) |
---|
[61] | 1624 | must be used as bottom boundary condition for the potential temperature.</p><p>See |
---|
| 1625 | also <a href="#top_heatflux">top_heatflux</a>.</p> |
---|
| 1626 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="surface_pressure"></a><b>surface_pressure</b></p> |
---|
| 1627 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1628 | <td style="vertical-align: top;"><i>1013.25</i></td> |
---|
| 1629 | <td style="vertical-align: top;"> <p>Atmospheric |
---|
| 1630 | pressure at the surface (in hPa). </p> |
---|
[5] | 1631 | Starting from this surface value, the vertical pressure |
---|
| 1632 | profile is calculated once at the beginning of the run assuming a |
---|
| 1633 | neutrally stratified |
---|
| 1634 | atmosphere. This is needed for |
---|
| 1635 | converting between the liquid water potential temperature and the |
---|
| 1636 | potential temperature (see <a href="#cloud_physics">cloud_physics</a><span style="text-decoration: underline;"></span>).</td> |
---|
[61] | 1637 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 1638 | <p><a name="surface_scalarflux"></a><b>surface_scalarflux</b></p> |
---|
| 1639 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1640 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1641 | <td style="vertical-align: top;"> <p>Scalar flux at |
---|
| 1642 | the surface (in kg/(m<sup>2</sup> s)). </p> |
---|
| 1643 | <p>If a non-zero value is assigned to this parameter, the |
---|
[5] | 1644 | respective scalar flux value is used |
---|
| 1645 | as bottom (horizontally homogeneous) boundary condition for the scalar |
---|
[61] | 1646 | concentration equation. This additionally requires that a |
---|
| 1647 | Neumann |
---|
[5] | 1648 | condition must be used for the scalar concentration (see <a href="#bc_s_b">bc_s_b</a>), |
---|
| 1649 | because otherwise the resolved scale may contribute to |
---|
| 1650 | the surface flux so that a constant value cannot be guaranteed. Also, |
---|
| 1651 | changes of the |
---|
| 1652 | surface scalar concentration (see <a href="#s_surface_initial_change">s_surface_initial_change</a>) |
---|
[61] | 1653 | are not allowed. <br> </p> <p>If no surface scalar |
---|
| 1654 | flux is assigned (<b>surface_scalarflux</b> |
---|
[5] | 1655 | = <i>0.0</i>), |
---|
| 1656 | it is calculated at each timestep by u<sub>*</sub> * s<sub>*</sub> |
---|
| 1657 | (of course only with Prandtl layer switched on). Here, s<sub>*</sub> |
---|
| 1658 | is calculated from the Prandtl law assuming a logarithmic scalar |
---|
| 1659 | concentration |
---|
| 1660 | profile between k=0 and k=1. In this case a Dirichlet condition (see <a href="#bc_s_b">bc_s_b</a>) |
---|
| 1661 | must be used as bottom boundary condition for the scalar concentration.</p> |
---|
[61] | 1662 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="surface_waterflux"></a><b>surface_waterflux</b></p> |
---|
| 1663 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1664 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1665 | <td style="vertical-align: top;"> <p>Kinematic |
---|
| 1666 | water flux near the surface (in m/s). </p> <p>If |
---|
| 1667 | a non-zero value is assigned to this parameter, the |
---|
[5] | 1668 | respective water flux value is used |
---|
| 1669 | as bottom (horizontally homogeneous) boundary condition for the |
---|
| 1670 | humidity equation. This additionally requires that a Neumann |
---|
| 1671 | condition must be used for the specific humidity / total water content |
---|
| 1672 | (see <a href="#bc_q_b">bc_q_b</a>), |
---|
| 1673 | because otherwise the resolved scale may contribute to |
---|
| 1674 | the surface flux so that a constant value cannot be guaranteed. Also, |
---|
| 1675 | changes of the |
---|
| 1676 | surface humidity (see <a href="#q_surface_initial_change">q_surface_initial_change</a>) |
---|
[61] | 1677 | are not allowed.<br> </p> <p>If no surface water |
---|
| 1678 | flux is assigned (<b>surface_waterflux</b> |
---|
[5] | 1679 | = <i>0.0</i>), |
---|
| 1680 | it is calculated at each timestep by u<sub>*</sub> * q<sub>*</sub> |
---|
| 1681 | (of course only with Prandtl layer switched on). Here, q<sub>*</sub> |
---|
| 1682 | is calculated from the Prandtl law assuming a logarithmic temperature |
---|
| 1683 | profile between k=0 and k=1. In this case a Dirichlet condition (see <a href="#bc_q_b">bc_q_b</a>) |
---|
| 1684 | must be used as the bottom boundary condition for the humidity.</p> |
---|
[61] | 1685 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="s_surface"></a><b>s_surface</b></p> |
---|
| 1686 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1687 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1688 | <td style="vertical-align: top;"> <p>Surface value |
---|
| 1689 | of the passive scalar (in kg/m<sup>3</sup>). <br> |
---|
| 1690 | </p> |
---|
[5] | 1691 | This parameter assigns the value of the passive scalar s at |
---|
| 1692 | the surface (k=0)<b>.</b> Starting from this value, the |
---|
| 1693 | initial vertical scalar concentration profile is constructed with<a href="#s_vertical_gradient"> |
---|
| 1694 | s_vertical_gradient</a> and <a href="#s_vertical_gradient_level">s_vertical_gradient_level</a>.</td> |
---|
[61] | 1695 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 1696 | <p><a name="s_surface_initial_change"></a><b>s_surface_initial</b> |
---|
| 1697 | <br> <b>_change</b></p> </td> <td style="vertical-align: top;">R</td> <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1698 | <td style="vertical-align: top;"> <p>Change in |
---|
| 1699 | surface scalar concentration to be made at the |
---|
[5] | 1700 | beginning of the 3d run (in kg/m<sup>3</sup>). </p> |
---|
[61] | 1701 | <p>If <b>s_surface_initial_change</b><i> </i>is |
---|
| 1702 | set to a |
---|
[5] | 1703 | non-zero |
---|
| 1704 | value, the near surface scalar flux is not allowed to be given |
---|
| 1705 | simultaneously (see <a href="#surface_scalarflux">surface_scalarflux</a>).</p> |
---|
[61] | 1706 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="s_vertical_gradient"></a><b>s_vertical_gradient</b></p> |
---|
| 1707 | </td> <td style="vertical-align: top;">R (10)</td> |
---|
| 1708 | <td style="vertical-align: top;"><i>10 * 0</i><i>.0</i></td> |
---|
| 1709 | <td style="vertical-align: top;"> <p>Scalar |
---|
| 1710 | concentration gradient(s) of the initial scalar |
---|
[5] | 1711 | concentration profile (in kg/m<sup>3 </sup>/ |
---|
[61] | 1712 | 100 m). </p> <p>The scalar gradient holds |
---|
| 1713 | starting from the height level |
---|
[5] | 1714 | defined by <a href="#s_vertical_gradient_level">s_vertical_gradient_level |
---|
[61] | 1715 | </a>(precisely: for all uv levels k, where zu(k) > |
---|
[5] | 1716 | s_vertical_gradient_level, s_init(k) is set: s_init(k) = s_init(k-1) + |
---|
[61] | 1717 | dzu(k) * <b>s_vertical_gradient</b>) up to the top |
---|
| 1718 | boundary or up to |
---|
[5] | 1719 | the next height level defined by <a href="#s_vertical_gradient_level">s_vertical_gradient_level</a>. |
---|
| 1720 | A total of 10 different gradients for 11 height intervals (10 intervals |
---|
| 1721 | if <a href="#s_vertical_gradient_level">s_vertical_gradient_level</a>(1) |
---|
[61] | 1722 | = <i>0.0</i>) can be assigned. The surface scalar value is |
---|
| 1723 | assigned |
---|
| 1724 | via <a href="#s_surface">s_surface</a>.<br> </p> |
---|
| 1725 | <p>Example: </p> <ul> <p><b>s_vertical_gradient</b> |
---|
| 1726 | = <i>0.1</i>, <i>0.05</i>, <br> |
---|
| 1727 | <b>s_vertical_gradient_level</b> = <i>500.0</i>, |
---|
| 1728 | <i>1000.0</i>,</p> </ul> <p>That |
---|
| 1729 | defines the scalar concentration to be constant with |
---|
[5] | 1730 | height up to z = 500.0 m with a value given by <a href="#s_surface">s_surface</a>. |
---|
| 1731 | For 500.0 m < z <= 1000.0 m the scalar gradient is 0.1 |
---|
[61] | 1732 | kg/m<sup>3 </sup>/ 100 m and for z > 1000.0 m up to |
---|
| 1733 | the top |
---|
| 1734 | boundary it is 0.05 kg/m<sup>3 </sup>/ 100 m (it is |
---|
| 1735 | assumed that the |
---|
[5] | 1736 | assigned height levels |
---|
| 1737 | correspond with uv |
---|
[61] | 1738 | levels).</p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="s_vertical_gradient_level"></a><b>s_vertical_gradient_</b> |
---|
| 1739 | <br> <b>level</b></p> </td> <td style="vertical-align: top;">R (10)</td> <td style="vertical-align: top;"> <p><i>10 *</i> |
---|
| 1740 | <i>0.0</i></p> </td> <td style="vertical-align: top;"> <p>Height level from |
---|
| 1741 | which on the scalar gradient defined by <a href="#s_vertical_gradient">s_vertical_gradient</a> |
---|
| 1742 | is effective (in m). </p> <p>The height levels |
---|
| 1743 | are to be assigned in ascending order. The |
---|
[5] | 1744 | default values result in a scalar concentration constant with height |
---|
| 1745 | regardless of the values of <a href="#s_vertical_gradient">s_vertical_gradient</a> |
---|
| 1746 | (unless the top boundary of the model is higher than 100000.0 m). For |
---|
| 1747 | the |
---|
| 1748 | piecewise construction of scalar concentration profiles see <a href="#s_vertical_gradient">s_vertical_gradient</a>.</p> |
---|
[61] | 1749 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="timestep_scheme"></a><b>timestep_scheme</b></p> |
---|
| 1750 | </td> <td style="vertical-align: top;">C * 20</td> |
---|
| 1751 | <td style="vertical-align: top;"> <p><i>'runge</i><br> |
---|
| 1752 | <i>kutta-3'</i></p> </td> <td style="vertical-align: top;"> <p>Time step scheme to |
---|
| 1753 | be used for the integration of the prognostic |
---|
| 1754 | variables. </p> <p>The user can choose between |
---|
| 1755 | the following schemes:<br> </p> <p><span style="font-style: italic;">'runge-kutta-3'</span><br> |
---|
| 1756 | </p> <div style="margin-left: 40px;">Third order |
---|
| 1757 | Runge-Kutta scheme.<br> |
---|
[5] | 1758 | This scheme requires the use of <a href="#momentum_advec">momentum_advec</a> |
---|
| 1759 | = <a href="#scalar_advec">scalar_advec</a> |
---|
[61] | 1760 | = '<i>pw-scheme'</i>. Please refer to the <a href="../tec/numerik.heiko/zeitschrittverfahren.pdf">documentation |
---|
| 1761 | on PALM's time integration schemes (28p., in German)</a> |
---|
| 1762 | fur further details.<br> </div> <p><span style="font-style: italic;">'runge-kutta-2'</span><br> |
---|
| 1763 | </p> <div style="margin-left: 40px;">Second order |
---|
| 1764 | Runge-Kutta scheme.<br> |
---|
[5] | 1765 | For special features see <b>timestep_scheme</b> = '<i>runge-kutta-3'</i>.<br> |
---|
[61] | 1766 | </div> <br> <span style="font-style: italic;"><span style="font-style: italic;">'leapfrog'</span><br> |
---|
| 1767 | <br> </span> <div style="margin-left: 40px;">Second |
---|
| 1768 | order leapfrog scheme.<br> |
---|
[5] | 1769 | Although this scheme requires a constant timestep (because it is |
---|
| 1770 | centered in time), is even applied in case of changes in |
---|
| 1771 | timestep. Therefore, only small |
---|
| 1772 | changes of the timestep are allowed (see <a href="#dt">dt</a>). |
---|
| 1773 | However, an Euler timestep is always used as the first timestep of an |
---|
| 1774 | initiali run. When using the Bott-Chlond scheme for scalar advection |
---|
| 1775 | (see <a href="#scalar_advec">scalar_advec</a>), |
---|
| 1776 | the prognostic equation for potential temperature will be calculated |
---|
| 1777 | with the Euler scheme, although the leapfrog scheme is switched |
---|
| 1778 | on. <br> |
---|
| 1779 | The leapfrog scheme must not be used together with the upstream-spline |
---|
| 1780 | scheme for calculating the advection (see <a href="#scalar_advec">scalar_advec</a> |
---|
| 1781 | = '<i>ups-scheme'</i> and <a href="#momentum_advec">momentum_advec</a> |
---|
[61] | 1782 | = '<i>ups-scheme'</i>).<br> </div> <br> |
---|
| 1783 | <span style="font-style: italic;">'</span><span style="font-style: italic;"><span style="font-style: italic;">leapfrog+euler'</span><br> |
---|
| 1784 | <br> </span> <div style="margin-left: 40px;">The |
---|
| 1785 | leapfrog scheme is used, but |
---|
[5] | 1786 | after each change of a timestep an Euler timestep is carried out. |
---|
| 1787 | Although this method is theoretically correct (because the pure |
---|
| 1788 | leapfrog method does not allow timestep changes), the divergence of the |
---|
| 1789 | velocity field (after applying the pressure solver) may be |
---|
| 1790 | significantly larger than with <span style="font-style: italic;">'leapfrog'</span>.<br> |
---|
[61] | 1791 | </div> <br> <span style="font-style: italic;">'euler'</span><br> |
---|
| 1792 | <br> <div style="margin-left: 40px;">First order |
---|
| 1793 | Euler scheme. <br> |
---|
[5] | 1794 | The Euler scheme must be used when treating the advection terms with |
---|
| 1795 | the upstream-spline scheme (see <a href="#scalar_advec">scalar_advec</a> |
---|
[61] | 1796 | = <span style="font-style: italic;">'ups-scheme'</span> |
---|
| 1797 | and <a href="#momentum_advec">momentum_advec</a> |
---|
[5] | 1798 | = <span style="font-style: italic;">'ups-scheme'</span>).</div> |
---|
[61] | 1799 | <br><br>A differing timestep scheme can be choosed for the |
---|
| 1800 | subgrid-scale TKE using parameter <a href="#use_upstream_for_tke">use_upstream_for_tke</a>.<br> |
---|
| 1801 | </td> </tr> <tr> <td style="text-align: left; vertical-align: top;"><span style="font-weight: bold;"><a name="topography"></a></span><span style="font-weight: bold;">topography</span></td> |
---|
| 1802 | <td style="vertical-align: top;">C * 40</td> <td style="vertical-align: top;"><span style="font-style: italic;">'flat'</span></td> <td> |
---|
| 1803 | <p>Topography mode. </p> <p>The user can |
---|
| 1804 | choose between the following modes:<br> </p> <p><span style="font-style: italic;">'flat'</span><br> </p> |
---|
| 1805 | <div style="margin-left: 40px;">Flat surface.</div> <p><span style="font-style: italic;">'single_building'</span><br> |
---|
| 1806 | </p> <div style="margin-left: 40px;">Flow |
---|
| 1807 | around a single rectangular building mounted on a flat surface.<br> |
---|
[5] | 1808 | The building size and location can be specified with the parameters <a href="#building_height">building_height</a>, <a href="#building_length_x">building_length_x</a>, <a href="#building_length_y">building_length_y</a>, <a href="#building_wall_left">building_wall_left</a> and <a href="#building_wall_south">building_wall_south</a>.</div> |
---|
[61] | 1809 | <span style="font-style: italic;"></span> <p><span style="font-style: italic;">'read_from_file'</span><br> |
---|
| 1810 | </p> <div style="margin-left: 40px;">Flow around |
---|
| 1811 | arbitrary topography.<br> |
---|
| 1812 | This mode requires the input file <a href="chapter_3.4.html#TOPOGRAPHY_DATA">TOPOGRAPHY_DATA</a><font color="#000000">. This file contains </font><font color="#000000"><font color="#000000">the </font></font><font color="#000000">arbitrary topography </font><font color="#000000"><font color="#000000">height |
---|
| 1813 | information</font></font><font color="#000000"> |
---|
| 1814 | in m. These data <span style="font-style: italic;"></span>must |
---|
| 1815 | exactly match the horizontal grid.</font> </div> <span style="font-style: italic;"><br> </span><font color="#000000"> |
---|
| 1816 | Alternatively, the user may add code to the user interface subroutine <a href="chapter_3.5.1.html#user_init_grid">user_init_grid</a> |
---|
| 1817 | to allow further topography modes.<br> <br> |
---|
| 1818 | All non-flat <span style="font-weight: bold;">topography</span> |
---|
| 1819 | modes </font>require the use of <a href="#momentum_advec">momentum_advec</a> |
---|
[5] | 1820 | = <a href="#scalar_advec">scalar_advec</a> |
---|
[61] | 1821 | = '<i>pw-scheme'</i>, <a href="chapter_4.2.html#psolver">psolver</a> |
---|
| 1822 | = <i>'poisfft'</i> or '<i>poisfft_hybrid'</i>, |
---|
| 1823 | <i> </i><a href="#alpha_surface">alpha_surface</a> |
---|
| 1824 | = 0.0, <a href="#bc_lr">bc_lr</a> = <a href="#bc_ns">bc_ns</a> = <span style="font-style: italic;">'cyclic'</span>, <a style="" href="#galilei_transformation">galilei_transformation</a> |
---|
| 1825 | = <span style="font-style: italic;">.F.</span>, <a href="#cloud_physics">cloud_physics </a> = <span style="font-style: italic;">.F.</span>, <a href="#cloud_droplets">cloud_droplets</a> = <span style="font-style: italic;">.F.</span>, <a href="#moisture">moisture</a> = <span style="font-style: italic;">.F.</span>, and <a href="#prandtl_layer">prandtl_layer</a> = .T..<br> |
---|
| 1826 | <font color="#000000"><br> |
---|
| 1827 | Note that an inclined model domain requires the use of <span style="font-weight: bold;">topography</span> = <span style="font-style: italic;">'flat'</span> and a |
---|
| 1828 | nonzero </font><a href="#alpha_surface">alpha_surface</a>.</td> |
---|
| 1829 | </tr> <tr><td style="vertical-align: top;"><a name="top_heatflux"></a><span style="font-weight: bold;">top_heatflux</span></td><td style="vertical-align: top;">R</td><td style="vertical-align: top;"><span style="font-style: italic;">no prescribed<br> |
---|
| 1830 | heatflux</span></td><td style="vertical-align: top;"><p>Kinematic |
---|
| 1831 | sensible heat flux at the top boundary (in K m/s). </p> |
---|
| 1832 | <p>If a value is assigned to this parameter, the internal |
---|
| 1833 | two-dimensional surface heat flux field <span style="font-family: monospace;">tswst</span> is |
---|
| 1834 | initialized with the value of <span style="font-weight: bold;">top_heatflux</span> as |
---|
| 1835 | top (horizontally homogeneous) boundary condition for the |
---|
[40] | 1836 | temperature equation. This additionally requires that a Neumann |
---|
| 1837 | condition must be used for the potential temperature (see <a href="chapter_4.1.html#bc_pt_t">bc_pt_t</a>), |
---|
| 1838 | because otherwise the resolved scale may contribute to |
---|
| 1839 | the top flux so that a constant value cannot be guaranteed.<span style="font-style: italic;"></span> </p> |
---|
[61] | 1840 | <p><span style="font-weight: bold;">Note:</span><br>The |
---|
| 1841 | application of a top heat flux additionally requires the setting of |
---|
| 1842 | initial parameter <a href="#use_top_fluxes">use_top_fluxes</a> |
---|
| 1843 | = .T..<span style="font-style: italic;"></span><span style="font-weight: bold;"></span> </p><p>No |
---|
| 1844 | Prandtl-layer is available at the top boundary so far.</p><p>See |
---|
| 1845 | also <a href="#surface_heatflux">surface_heatflux</a>.</p> |
---|
| 1846 | </td></tr><tr> <td style="vertical-align: top;"> |
---|
| 1847 | <p><a name="ug_surface"></a><span style="font-weight: bold;">ug_surface</span></p> |
---|
| 1848 | </td> <td style="vertical-align: top;">R<br> </td> |
---|
| 1849 | <td style="vertical-align: top;"><span style="font-style: italic;">0.0</span><br> </td> |
---|
| 1850 | <td style="vertical-align: top;">u-component of the |
---|
| 1851 | geostrophic |
---|
| 1852 | wind at the surface (in m/s).<br> <br> |
---|
[5] | 1853 | This parameter assigns the value of the u-component of the geostrophic |
---|
| 1854 | wind (ug) at the surface (k=0). Starting from this value, the initial |
---|
| 1855 | vertical profile of the <br> |
---|
[61] | 1856 | u-component of the geostrophic wind is constructed with <a href="#ug_vertical_gradient">ug_vertical_gradient</a> |
---|
| 1857 | and <a href="#ug_vertical_gradient_level">ug_vertical_gradient_level</a>. |
---|
| 1858 | The |
---|
[5] | 1859 | profile constructed in that way is used for creating the initial |
---|
| 1860 | vertical velocity profile of the 3d-model. Either it is applied, as it |
---|
| 1861 | has been specified by the user (<a href="#initializing_actions">initializing_actions</a> |
---|
| 1862 | = 'set_constant_profiles') or it is used for calculating a stationary |
---|
| 1863 | boundary layer wind profile (<a href="#initializing_actions">initializing_actions</a> |
---|
[61] | 1864 | = 'set_1d-model_profiles'). If ug is constant with height (i.e. ug(k)=<span style="font-weight: bold;">ug_surface</span>) |
---|
| 1865 | and has a large |
---|
[5] | 1866 | value, it is recommended to use a Galilei-transformation of the |
---|
| 1867 | coordinate system, if possible (see <a href="#galilei_transformation">galilei_transformation</a>), |
---|
[61] | 1868 | in order to obtain larger time steps.<br> </td> </tr> |
---|
| 1869 | <tr> <td style="vertical-align: top;"> <p><a name="ug_vertical_gradient"></a><span style="font-weight: bold;">ug_vertical_gradient</span></p> |
---|
| 1870 | </td> <td style="vertical-align: top;">R(10)<br> |
---|
| 1871 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">10 |
---|
| 1872 | * 0.0</span><br> </td> <td style="vertical-align: top;">Gradient(s) of the initial |
---|
| 1873 | profile of the u-component of the geostrophic wind (in |
---|
| 1874 | 1/100s).<br> <br> |
---|
[5] | 1875 | The gradient holds starting from the height level defined by <a href="#ug_vertical_gradient_level">ug_vertical_gradient_level</a> |
---|
| 1876 | (precisely: for all uv levels k where zu(k) > <a href="#ug_vertical_gradient_level">ug_vertical_gradient_level</a>, |
---|
[61] | 1877 | ug(k) is set: ug(k) = ug(k-1) + dzu(k) * <span style="font-weight: bold;">ug_vertical_gradient</span>) |
---|
| 1878 | up to the top |
---|
| 1879 | boundary or up to the next height level defined by <a href="#ug_vertical_gradient_level">ug_vertical_gradient_level</a>. |
---|
| 1880 | A |
---|
[5] | 1881 | total of 10 different gradients for 11 height intervals (10 |
---|
| 1882 | intervals if <a href="#ug_vertical_gradient_level">ug_vertical_gradient_level</a>(1) |
---|
[61] | 1883 | = 0.0) can be assigned. The surface geostrophic wind is assigned by <a href="#ug_surface">ug_surface</a>. <br> </td> |
---|
| 1884 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 1885 | <p><a name="ug_vertical_gradient_level"></a><span style="font-weight: bold;">ug_vertical_gradient_level</span></p> |
---|
| 1886 | </td> <td style="vertical-align: top;">R(10)<br> |
---|
| 1887 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">10 |
---|
| 1888 | * 0.0</span><br> </td> <td style="vertical-align: top;">Height level from which on the |
---|
[5] | 1889 | gradient defined by <a href="#ug_vertical_gradient">ug_vertical_gradient</a> |
---|
[61] | 1890 | is effective (in m).<br> <br> |
---|
[5] | 1891 | The height levels are to be assigned in ascending order. For the |
---|
| 1892 | piecewise construction of a profile of the u-component of the |
---|
| 1893 | geostrophic wind component (ug) see <a href="#ug_vertical_gradient">ug_vertical_gradient</a>.<br> |
---|
[61] | 1894 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="ups_limit_e"></a><b>ups_limit_e</b></p> |
---|
| 1895 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1896 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1897 | <td style="vertical-align: top;"> <p>Subgrid-scale |
---|
| 1898 | turbulent kinetic energy difference used as |
---|
[5] | 1899 | criterion for applying the upstream scheme when upstream-spline |
---|
| 1900 | advection is switched on (in m<sup>2</sup>/s<sup>2</sup>). |
---|
[61] | 1901 | </p> <p>This variable steers the appropriate |
---|
| 1902 | treatment of the |
---|
[5] | 1903 | advection of the subgrid-scale turbulent kinetic energy in case that |
---|
| 1904 | the uptream-spline scheme is used . For further information see <a href="#ups_limit_pt">ups_limit_pt</a>. </p> |
---|
[61] | 1905 | <p>Only positive values are allowed for <b>ups_limit_e</b>. |
---|
| 1906 | </p> </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="ups_limit_pt"></a><b>ups_limit_pt</b></p> |
---|
| 1907 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1908 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1909 | <td style="vertical-align: top;"> <p>Temperature |
---|
| 1910 | difference used as criterion for applying |
---|
| 1911 | the upstream scheme when upstream-spline advection is |
---|
| 1912 | switched on |
---|
| 1913 | (in K). </p> <p>This criterion is used if the |
---|
| 1914 | upstream-spline scheme is |
---|
[5] | 1915 | switched on (see <a href="#scalar_advec">scalar_advec</a>).<br> |
---|
| 1916 | If, for a given gridpoint, the absolute temperature difference with |
---|
| 1917 | respect to the upstream |
---|
| 1918 | grid point is smaller than the value given for <b>ups_limit_pt</b>, |
---|
| 1919 | the upstream scheme is used for this gridpoint (by default, the |
---|
| 1920 | upstream-spline scheme is always used). Reason: in case of a very small |
---|
| 1921 | upstream gradient, the advection should cause only a very small |
---|
| 1922 | tendency. However, in such situations the upstream-spline scheme may |
---|
| 1923 | give wrong tendencies at a |
---|
| 1924 | grid point due to spline overshooting, if simultaneously the downstream |
---|
| 1925 | gradient is very large. In such cases it may be more reasonable to use |
---|
| 1926 | the upstream scheme. The numerical diffusion caused by the upstream |
---|
| 1927 | schme remains small as long as the upstream gradients are small.<br> |
---|
[61] | 1928 | </p> <p>The percentage of grid points for which the |
---|
| 1929 | upstream |
---|
[5] | 1930 | scheme is actually used, can be output as a time series with respect to |
---|
| 1931 | the |
---|
[61] | 1932 | three directions in space with run parameter (see <a href="chapter_4.2.html#dt_dots">dt_dots</a>, the |
---|
| 1933 | timeseries names in the NetCDF file are <i>'splptx'</i>, <i>'splpty'</i>, |
---|
| 1934 | <i>'splptz'</i>). The percentage |
---|
| 1935 | of gridpoints should stay below a certain limit, however, it |
---|
| 1936 | is |
---|
[5] | 1937 | not possible to give |
---|
| 1938 | a general limit, since it depends on the respective flow. </p> |
---|
[61] | 1939 | <p>Only positive values are permitted for <b>ups_limit_pt</b>.<br> |
---|
| 1940 | </p> |
---|
[5] | 1941 | A more effective control of |
---|
[61] | 1942 | the “overshoots” can be achieved with parameter <a href="#cut_spline_overshoot">cut_spline_overshoot</a>. |
---|
| 1943 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="ups_limit_u"></a><b>ups_limit_u</b></p> |
---|
| 1944 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1945 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1946 | <td style="vertical-align: top;"> <p>Velocity |
---|
| 1947 | difference (u-component) used as criterion for |
---|
[5] | 1948 | applying the upstream scheme |
---|
| 1949 | when upstream-spline advection is switched on (in m/s). </p> |
---|
[61] | 1950 | <p>This variable steers the appropriate treatment of the |
---|
[5] | 1951 | advection of the u-velocity-component in case that the upstream-spline |
---|
| 1952 | scheme is used. For further |
---|
[61] | 1953 | information see <a href="#ups_limit_pt">ups_limit_pt</a>. |
---|
| 1954 | </p> <p>Only positive values are permitted for <b>ups_limit_u</b>.</p> |
---|
| 1955 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="ups_limit_v"></a><b>ups_limit_v</b></p> |
---|
| 1956 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1957 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1958 | <td style="vertical-align: top;"> <p>Velocity |
---|
| 1959 | difference (v-component) used as criterion for |
---|
[5] | 1960 | applying the upstream scheme |
---|
| 1961 | when upstream-spline advection is switched on (in m/s). </p> |
---|
[61] | 1962 | <p>This variable steers the appropriate treatment of the |
---|
[5] | 1963 | advection of the v-velocity-component in case that the upstream-spline |
---|
| 1964 | scheme is used. For further |
---|
[61] | 1965 | information see <a href="#ups_limit_pt">ups_limit_pt</a>. |
---|
| 1966 | </p> <p>Only positive values are permitted for <b>ups_limit_v</b>.</p> |
---|
| 1967 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="ups_limit_w"></a><b>ups_limit_w</b></p> |
---|
| 1968 | </td> <td style="vertical-align: top;">R</td> |
---|
| 1969 | <td style="vertical-align: top;"><i>0.0</i></td> |
---|
| 1970 | <td style="vertical-align: top;"> <p>Velocity |
---|
| 1971 | difference (w-component) used as criterion for |
---|
[5] | 1972 | applying the upstream scheme |
---|
| 1973 | when upstream-spline advection is switched on (in m/s). </p> |
---|
[61] | 1974 | <p>This variable steers the appropriate treatment of the |
---|
[5] | 1975 | advection of the w-velocity-component in case that the upstream-spline |
---|
| 1976 | scheme is used. For further |
---|
[61] | 1977 | information see <a href="#ups_limit_pt">ups_limit_pt</a>. |
---|
| 1978 | </p> <p>Only positive values are permitted for <b>ups_limit_w</b>.</p> |
---|
| 1979 | </td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="use_surface_fluxes"></a><b>use_surface_fluxes</b></p> |
---|
| 1980 | </td> <td style="vertical-align: top;">L</td> |
---|
| 1981 | <td style="vertical-align: top;"><i>.F.</i></td> |
---|
| 1982 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 1983 | steer the treatment of the subgrid-scale vertical |
---|
| 1984 | fluxes within the diffusion terms at k=1 (bottom boundary).<br> </p> |
---|
| 1985 | <p>By default, the near-surface subgrid-scale fluxes are |
---|
[5] | 1986 | parameterized (like in the remaining model domain) using the gradient |
---|
| 1987 | approach. If <b>use_surface_fluxes</b> |
---|
[61] | 1988 | = <i>.TRUE.</i>, the user-assigned surface fluxes are used |
---|
| 1989 | instead |
---|
| 1990 | (see <a href="#surface_heatflux">surface_heatflux</a>, |
---|
| 1991 | <a href="#surface_waterflux">surface_waterflux</a> |
---|
| 1992 | and <a href="#surface_scalarflux">surface_scalarflux</a>) |
---|
| 1993 | <span style="font-weight: bold;">or</span> the |
---|
| 1994 | surface fluxes are |
---|
[5] | 1995 | calculated via the Prandtl layer relation (depends on the bottom |
---|
[61] | 1996 | boundary conditions, see <a href="#bc_pt_b">bc_pt_b</a>, |
---|
| 1997 | <a href="#bc_q_b">bc_q_b</a> |
---|
| 1998 | and <a href="#bc_s_b">bc_s_b</a>).<br> </p> |
---|
| 1999 | <p><b>use_surface_fluxes</b> |
---|
| 2000 | is automatically set <i>.TRUE.</i>, if a Prandtl layer is |
---|
| 2001 | used (see <a href="#prandtl_layer">prandtl_layer</a>). |
---|
| 2002 | </p> <p>The user may prescribe the surface fluxes at the |
---|
| 2003 | bottom |
---|
| 2004 | boundary without using a Prandtl layer by setting <span style="font-weight: bold;">use_surface_fluxes</span> = |
---|
| 2005 | <span style="font-style: italic;">.T.</span> and <span style="font-weight: bold;">prandtl_layer</span> = <span style="font-style: italic;">.F.</span>. If , in this |
---|
| 2006 | case, the |
---|
| 2007 | momentum flux (u<sub>*</sub><sup>2</sup>) |
---|
| 2008 | should also be prescribed, |
---|
[5] | 2009 | the user must assign an appropriate value within the user-defined code.</p> |
---|
[61] | 2010 | </td> </tr> <tr><td style="vertical-align: top;"><a name="use_top_fluxes"></a><span style="font-weight: bold;">use_top_fluxes</span></td><td style="vertical-align: top;">L</td><td style="vertical-align: top;"><span style="font-style: italic;">.F.</span></td><td style="vertical-align: top;"> <p>Parameter to steer |
---|
| 2011 | the treatment of the subgrid-scale vertical |
---|
| 2012 | fluxes within the diffusion terms at k=nz (top boundary).</p><p>By |
---|
| 2013 | default, the fluxes at nz are calculated using the gradient approach. |
---|
| 2014 | If <b>use_top_fluxes</b> |
---|
| 2015 | = <i>.TRUE.</i>, the user-assigned top fluxes are used |
---|
| 2016 | instead |
---|
| 2017 | (see <a href="chapter_4.1.html#top_heatflux">top_heatflux</a>).</p><p>Currently, |
---|
| 2018 | only a value for the sensible heatflux can be assigned. In case of <span style="font-weight: bold;">use_top_fluxes</span> = <span style="font-style: italic;">.TRUE.</span>, the latent |
---|
| 2019 | heat flux at the top will be automatically set to zero.</p></td></tr><tr> |
---|
| 2020 | <td style="vertical-align: top;"> <p><a name="use_ug_for_galilei_tr"></a><b>use_ug_for_galilei_tr</b></p> |
---|
| 2021 | </td> <td style="vertical-align: top;">L</td> |
---|
| 2022 | <td style="vertical-align: top;"><i>.T.</i></td> |
---|
| 2023 | <td style="vertical-align: top;"> <p>Switch to |
---|
| 2024 | determine the translation velocity in case that a |
---|
| 2025 | Galilean transformation is used.<br> </p> <p>In |
---|
| 2026 | case of a Galilean transformation (see <a href="#galilei_transformation">galilei_transformation</a>), |
---|
| 2027 | <b>use_ug_for_galilei_tr</b> |
---|
[5] | 2028 | = <i>.T.</i> ensures |
---|
| 2029 | that the coordinate system is translated with the geostrophic windspeed.<br> |
---|
[61] | 2030 | </p> <p>Alternatively, with <b>use_ug_for_galilei_tr</b> |
---|
| 2031 | = <i>.F</i>., |
---|
[5] | 2032 | the |
---|
| 2033 | geostrophic wind can be replaced as translation speed by the (volume) |
---|
| 2034 | averaged velocity. However, in this case the user must be aware of fast |
---|
| 2035 | growing gravity waves, so this |
---|
[61] | 2036 | choice is usually not recommended!</p> </td> </tr> <tr><td align="left" valign="top"><a name="use_upstream_for_tke"></a><span style="font-weight: bold;">use_upstream_for_tke</span></td><td align="left" valign="top">L</td><td align="left" valign="top"><span style="font-style: italic;">.F.</span></td><td align="left" valign="top">Parameter to choose the |
---|
| 2037 | advection/timestep scheme to be used for the subgrid-scale TKE.<br><br>By |
---|
[5] | 2038 | default, the advection scheme and the timestep scheme to be used for |
---|
[61] | 2039 | the subgrid-scale TKE are set by the initialization parameters <a href="#scalar_advec">scalar_advec</a> and <a href="#timestep_scheme">timestep_scheme</a>, |
---|
| 2040 | respectively. <span style="font-weight: bold;">use_upstream_for_tke</span> |
---|
| 2041 | = <span style="font-style: italic;">.T.</span> |
---|
[5] | 2042 | forces the Euler-scheme and the upstream-scheme to be used as timestep |
---|
| 2043 | scheme and advection scheme, respectively. By these methods, the strong |
---|
| 2044 | (artificial) near-surface vertical gradients of the subgrid-scale TKE |
---|
| 2045 | are significantly reduced. This is required when subgrid-scale |
---|
| 2046 | velocities are used for advection of particles (see particle package |
---|
| 2047 | parameter <a href="chapter_4.2.html#use_sgs_for_particles">use_sgs_for_particles</a>).</td></tr><tr> |
---|
[61] | 2048 | <td style="vertical-align: top;"> <p><a name="vg_surface"></a><span style="font-weight: bold;">vg_surface</span></p> |
---|
| 2049 | </td> <td style="vertical-align: top;">R<br> </td> |
---|
| 2050 | <td style="vertical-align: top;"><span style="font-style: italic;">0.0</span><br> </td> |
---|
| 2051 | <td style="vertical-align: top;">v-component of the |
---|
| 2052 | geostrophic |
---|
| 2053 | wind at the surface (in m/s).<br> <br> |
---|
[5] | 2054 | This parameter assigns the value of the v-component of the geostrophic |
---|
| 2055 | wind (vg) at the surface (k=0). Starting from this value, the initial |
---|
| 2056 | vertical profile of the <br> |
---|
[61] | 2057 | v-component of the geostrophic wind is constructed with <a href="#vg_vertical_gradient">vg_vertical_gradient</a> |
---|
| 2058 | and <a href="#vg_vertical_gradient_level">vg_vertical_gradient_level</a>. |
---|
| 2059 | The |
---|
[5] | 2060 | profile |
---|
| 2061 | constructed in that way is used for creating the initial vertical |
---|
| 2062 | velocity profile of the 3d-model. Either it is applied, as it has been |
---|
| 2063 | specified by the user (<a href="#initializing_actions">initializing_actions</a> |
---|
| 2064 | = 'set_constant_profiles') |
---|
| 2065 | or it is used for calculating a stationary boundary layer wind profile |
---|
[61] | 2066 | (<a href="#initializing_actions">initializing_actions</a> |
---|
| 2067 | = |
---|
[5] | 2068 | 'set_1d-model_profiles'). If vg is constant |
---|
| 2069 | with height (i.e. vg(k)=<span style="font-weight: bold;">vg_surface</span>) |
---|
| 2070 | and has a large value, it is |
---|
| 2071 | recommended to use a Galilei-transformation of the coordinate system, |
---|
| 2072 | if possible (see <a href="#galilei_transformation">galilei_transformation</a>), |
---|
| 2073 | in order to obtain larger |
---|
[61] | 2074 | time steps.</td> </tr> <tr> <td style="vertical-align: top;"> <p><a name="vg_vertical_gradient"></a><span style="font-weight: bold;">vg_vertical_gradient</span></p> |
---|
| 2075 | </td> <td style="vertical-align: top;">R(10)<br> |
---|
| 2076 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">10 |
---|
| 2077 | * 0.0</span><br> </td> <td style="vertical-align: top;">Gradient(s) of the initial |
---|
| 2078 | profile of the v-component of the geostrophic wind (in |
---|
| 2079 | 1/100s).<br> <br> |
---|
[5] | 2080 | The gradient holds starting from the height level defined by <a href="#vg_vertical_gradient_level">vg_vertical_gradient_level</a> |
---|
| 2081 | (precisely: for all uv levels k where zu(k) |
---|
| 2082 | > <a href="#vg_vertical_gradient_level">vg_vertical_gradient_level</a>, |
---|
| 2083 | vg(k) is set: vg(k) = vg(k-1) + dzu(k) |
---|
[61] | 2084 | * <span style="font-weight: bold;">vg_vertical_gradient</span>) |
---|
| 2085 | up to |
---|
[5] | 2086 | the top boundary or up to the next height |
---|
| 2087 | level defined by <a href="#vg_vertical_gradient_level">vg_vertical_gradient_level</a>. |
---|
| 2088 | A total of 10 different |
---|
[61] | 2089 | gradients for 11 height intervals (10 intervals if <a href="#vg_vertical_gradient_level">vg_vertical_gradient_level</a>(1) |
---|
| 2090 | = |
---|
[5] | 2091 | 0.0) can be assigned. The surface |
---|
| 2092 | geostrophic wind is assigned by <a href="#vg_surface">vg_surface</a>.</td> |
---|
[61] | 2093 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 2094 | <p><a name="vg_vertical_gradient_level"></a><span style="font-weight: bold;">vg_vertical_gradient_level</span></p> |
---|
| 2095 | </td> <td style="vertical-align: top;">R(10)<br> |
---|
| 2096 | </td> <td style="vertical-align: top;"><span style="font-style: italic;">10 |
---|
| 2097 | * 0.0</span><br> </td> <td style="vertical-align: top;">Height level from which on the |
---|
[5] | 2098 | gradient defined by <a href="#vg_vertical_gradient">vg_vertical_gradient</a> |
---|
[61] | 2099 | is effective (in m).<br> <br> |
---|
[5] | 2100 | The height levels are to be assigned in ascending order. For the |
---|
| 2101 | piecewise construction of a profile of the v-component of the |
---|
| 2102 | geostrophic wind component (vg) see <a href="#vg_vertical_gradient">vg_vertical_gradient</a>.</td> |
---|
[61] | 2103 | </tr> <tr> <td style="vertical-align: top;"> |
---|
| 2104 | <p><a name="wall_adjustment"></a><b>wall_adjustment</b></p> |
---|
| 2105 | </td> <td style="vertical-align: top;">L</td> |
---|
| 2106 | <td style="vertical-align: top;"><i>.T.</i></td> |
---|
| 2107 | <td style="vertical-align: top;"> <p>Parameter to |
---|
| 2108 | restrict the mixing length in the vicinity of the |
---|
[5] | 2109 | bottom |
---|
[61] | 2110 | boundary. </p> <p>With <b>wall_adjustment</b> |
---|
| 2111 | = <i>.TRUE., </i>the mixing |
---|
[5] | 2112 | length is limited to a maximum of 1.8 * z. This condition |
---|
| 2113 | typically affects only the |
---|
[61] | 2114 | first grid points above the bottom boundary.</p> </td> </tr> |
---|
| 2115 | <tr> <td style="vertical-align: top;"><span style="font-weight: bold;"><a name="wall_heatflux"></a>wall_heatflux</span></td> |
---|
| 2116 | <td style="vertical-align: top;">R(5)</td> <td style="vertical-align: top;"><span style="font-style: italic;">5 * 0.0</span></td> <td>Prescribed |
---|
| 2117 | kinematic sensible heat flux in W m<sup>-2</sup> |
---|
| 2118 | at the five topography faces:<br> <br> <div style="margin-left: 40px;"><span style="font-weight: bold;">wall_heatflux(0) |
---|
| 2119 | </span>top face<br> <span style="font-weight: bold;">wall_heatflux(1) |
---|
| 2120 | </span>left face<br> <span style="font-weight: bold;">wall_heatflux(2) |
---|
| 2121 | </span>right face<br> <span style="font-weight: bold;">wall_heatflux(3) |
---|
| 2122 | </span>south face<br> <span style="font-weight: bold;">wall_heatflux(4) |
---|
| 2123 | </span>north face</div> <br> |
---|
| 2124 | This parameter applies only in case of a non-flat <a href="#topography">topography</a>. The |
---|
| 2125 | parameter <a href="#random_heatflux">random_heatflux</a> |
---|
| 2126 | can be used to impose random perturbations on the internal |
---|
| 2127 | two-dimensional surface heat |
---|
| 2128 | flux field <span style="font-style: italic;">shf</span> |
---|
| 2129 | that is composed of <a href="#surface_heatflux">surface_heatflux</a> |
---|
| 2130 | at the bottom surface and <span style="font-weight: bold;">wall_heatflux(0)</span> |
---|
| 2131 | at the topography top face. </td> </tr> </tbody> |
---|
| 2132 | </table><br> |
---|
| 2133 | <p style="line-height: 100%;"><br><font color="#000080"><font color="#000080"><a href="chapter_4.0.html"><font color="#000080"><img name="Grafik1" src="left.gif" align="bottom" border="2" height="32" width="32"></font></a><a href="index.html"><font color="#000080"><img name="Grafik2" src="up.gif" align="bottom" border="2" height="32" width="32"></font></a><a href="chapter_4.2.html"><font color="#000080"><img name="Grafik3" src="right.gif" align="bottom" border="2" height="32" width="32"></font></a></font></font></p> |
---|
| 2134 | <p style="line-height: 100%;"><i>Last |
---|
| 2135 | change: </i> $Id: chapter_4.1.html 62 2007-03-13 02:52:40Z raasch $ </p> |
---|
| 2136 | <br><br> |
---|
[5] | 2137 | </body></html> |
---|