Neko 1.99.3
A portable framework for high-order spectral element flow simulations
Loading...
Searching...
No Matches
rough_log_law.f90
Go to the documentation of this file.
1! Copyright (c) 2024, The Neko Authors
2! All rights reserved.
3!
4! Redistribution and use in source and binary forms, with or without
5! modification, are permitted provided that the following conditions
6! are met:
7!
8! * Redistributions of source code must retain the above copyright
9! notice, this list of conditions and the following disclaimer.
10!
11! * Redistributions in binary form must reproduce the above
12! copyright notice, this list of conditions and the following
13! disclaimer in the documentation and/or other materials provided
14! with the distribution.
15!
16! * Neither the name of the authors nor the names of its
17! contributors may be used to endorse or promote products derived
18! from this software without specific prior written permission.
19!
20! THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21! "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22! LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23! FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24! COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25! INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26! BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27! LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
28! CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29! LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
30! ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31! POSSIBILITY OF SUCH DAMAGE.
32!
33!
36 use field, only: field_t
37 use num_types, only : rp
38 use json_module, only : json_file
39 use coefs, only : coef_t
41 use vector, only : vector_t
42 use wall_model, only : wall_model_t
43 use utils, only : neko_error
44 use registry, only : neko_registry
45 use json_utils, only : json_get_or_lookup, &
50 use math, only: masked_gather_copy_0
52 use logger, only : log_size, neko_log
53 implicit none
54 private
55
60 type, public, extends(wall_model_t) :: rough_log_law_t
61
63 real(kind=rp) :: kappa
65 real(kind=rp) :: b
67 real(kind=rp) :: z0
68 ! The fluid density at the boundary
69 type(vector_t) :: rho_w
70 contains
72 procedure, pass(this) :: init => rough_log_law_init
75 procedure, pass(this) :: partial_init => rough_log_law_partial_init
77 procedure, pass(this) :: finalize => rough_log_law_finalize
79 procedure, pass(this) :: init_from_components => &
82 procedure, pass(this) :: free => rough_log_law_free
84 procedure, pass(this) :: compute => rough_log_law_compute
85 ! Extract fluid properties at the wall (rho)
86 procedure, pass(this) :: extract_properties => rough_log_law_extract_properties
87 end type rough_log_law_t
88
89contains
97 subroutine rough_log_law_init(this, scheme_name, coef, msk, facet, &
98 h_index, json)
99 class(rough_log_law_t), intent(inout) :: this
100 character(len=*), intent(in) :: scheme_name
101 type(coef_t), intent(in) :: coef
102 integer, intent(in) :: msk(:)
103 integer, intent(in) :: facet(:)
104 integer, intent(in) :: h_index
105 type(json_file), intent(inout) :: json
106 real(kind=rp) :: kappa, b, z0
107
108 call json_get_or_lookup_or_default(json, "kappa", kappa, 0.4_rp)
109 call json_get_or_lookup_or_default(json, "B", b, 0.0_rp)
110 call json_get_or_lookup(json, "z0", z0)
111
112 call this%init_from_components(scheme_name, coef, msk, facet, h_index, &
113 kappa, b, z0)
114 end subroutine rough_log_law_init
115
119 subroutine rough_log_law_partial_init(this, coef, json)
120 class(rough_log_law_t), intent(inout) :: this
121 type(coef_t), intent(in) :: coef
122 type(json_file), intent(inout) :: json
123 character(len=LOG_SIZE) :: log_buf
124
125 call this%partial_init_base(coef, json)
126 call json_get_or_lookup_or_default(json, "kappa", this%kappa, 0.4_rp)
127 call json_get_or_lookup_or_default(json, "B", this%B, 0.0_rp)
128 call json_get_or_lookup(json, "z0", this%z0)
129
130 call neko_log%section('Wall model')
131 write(log_buf, '(A)') 'Model : Rough log law'
132 call neko_log%message(log_buf)
133 write(log_buf, '(A, E15.7)') 'kappa : ', this%kappa
134 call neko_log%message(log_buf)
135 write(log_buf, '(A, E15.7)') 'B : ', this%B
136 call neko_log%message(log_buf)
137 write(log_buf, '(A, E15.7)') 'z0 : ', this%z0
138 call neko_log%message(log_buf)
139 call neko_log%end_section()
140
141 end subroutine rough_log_law_partial_init
142
146 subroutine rough_log_law_finalize(this, msk, facet)
147 class(rough_log_law_t), intent(inout) :: this
148 integer, intent(in) :: msk(:)
149 integer, intent(in) :: facet(:)
150
151 call this%finalize_base(msk, facet)
152
153 call this%rho_w%init(this%n_nodes)
154
155 end subroutine rough_log_law_finalize
156
159 class(rough_log_law_t), intent(inout) :: this
160
161 if (neko_bcknd_device .eq. 1) then
162 call device_masked_gather_copy_0(this%rho_w%x_d, this%rho%x_d, this%msk_d, &
163 this%rho%size(), this%rho_w%size())
164 else
165 call masked_gather_copy_0(this%rho_w%x, this%rho%x, this%msk, &
166 this%rho%size(), this%rho_w%size())
167 end if
169
179 subroutine rough_log_law_init_from_components(this, scheme_name, coef, msk, &
180 facet, h_index, kappa, B, z0)
181 class(rough_log_law_t), intent(inout) :: this
182 character(len=*), intent(in) :: scheme_name
183 type(coef_t), intent(in) :: coef
184 integer, intent(in) :: msk(:)
185 integer, intent(in) :: facet(:)
186 integer, intent(in) :: h_index
187 real(kind=rp), intent(in) :: kappa, b, z0
188
189 call this%free()
190 call this%init_base(scheme_name, coef, msk, facet, h_index)
191
192 this%kappa = kappa
193 this%B = b
194 this%z0 = z0
195
196 call this%rho_w%init(this%n_nodes)
197
198 ! Check that the sampling height is above the roughness length
199 if (any(this%h%x(1:this%n_nodes) .le. this%z0)) then
200 call neko_error("Roughlog WM: Sampling height h must be greater than roughness z0. " // &
201 "Increase h_index or decrease z0.")
202 else if (this%z0 .eq. 0.0_rp) then
203 call neko_error("Roughlog WM: Roughness z0 must be greater than 0.")
204 end if
205
207
209 subroutine rough_log_law_free(this)
210 class(rough_log_law_t), intent(inout) :: this
211
212 call this%rho_w%free()
213 call this%free_base()
214
215 end subroutine rough_log_law_free
216
220 subroutine rough_log_law_compute(this, t, tstep)
221 class(rough_log_law_t), intent(inout) :: this
222 real(kind=rp), intent(in) :: t
223 integer, intent(in) :: tstep
224 type(field_t), pointer :: u
225 type(field_t), pointer :: v
226 type(field_t), pointer :: w
227
228 ! Extract boundary values for rho
229 call this%extract_properties()
230
231 u => neko_registry%get_field("u")
232 v => neko_registry%get_field("v")
233 w => neko_registry%get_field("w")
234
235 if (neko_bcknd_device .eq. 1) then
236 call rough_log_law_compute_device(u%x_d, v%x_d, w%x_d, this%ind_r_d, &
237 this%ind_s_d, this%ind_t_d, this%ind_e_d, &
238 this%n_x%x_d, this%n_y%x_d, this%n_z%x_d, &
239 this%h%x_d, this%tau_x%x_d, this%tau_y%x_d, &
240 this%tau_z%x_d, this%n_nodes, u%Xh%lx, this%kappa, &
241 this%rho_w%x_d, this%B, this%z0, tstep)
242 else
243 call rough_log_law_compute_cpu(u%x, v%x, w%x, this%ind_r, this%ind_s, &
244 this%ind_t, this%ind_e, this%n_x%x, this%n_y%x, this%n_z%x, &
245 this%h%x, this%tau_x%x, this%tau_y%x, this%tau_z%x, &
246 this%n_nodes, u%Xh%lx, u%msh%nelv, this%kappa, &
247 this%rho_w%x, this%B, this%z0, tstep)
248 end if
249
250 end subroutine rough_log_law_compute
251
252
253end module rough_log_law
__global__ void rough_log_law_compute(const T *__restrict__ u_d, const T *__restrict__ v_d, const T *__restrict__ w_d, const int *__restrict__ ind_r_d, const int *__restrict__ ind_s_d, const int *__restrict__ ind_t_d, const int *__restrict__ ind_e_d, const T *__restrict__ n_x_d, const T *__restrict__ n_y_d, const T *__restrict__ n_z_d, const T *__restrict__ h_d, T *__restrict__ tau_x_d, T *__restrict__ tau_y_d, T *__restrict__ tau_z_d, const int n_nodes, const int lx, const T kappa, const T *__restrict__ rho_w_d, const T B, const T z0)
Coefficients.
Definition coef.f90:34
subroutine, public device_masked_gather_copy_0(a_d, b_d, mask_d, n, n_mask, strm)
Gather a masked vector .
Defines a field.
Definition field.f90:34
Utilities for retrieving parameters from the case files.
Logging routines.
Definition log.f90:34
type(log_t), public neko_log
Global log stream.
Definition log.f90:79
integer, parameter, public log_size
Definition log.f90:45
Definition math.f90:60
subroutine, public masked_gather_copy_0(a, b, mask, n, n_mask)
Gather a masked vector to reduced contigous vector .
Definition math.f90:315
Build configurations.
integer, parameter neko_bcknd_device
integer, parameter, public rp
Global precision used in computations.
Definition num_types.f90:12
Defines a registry for storing solution fields.
Definition registry.f90:34
type(registry_t), target, public neko_registry
Global field registry.
Definition registry.f90:144
Implements the CPU kernel for the rough_log_law_t type.
subroutine, public rough_log_law_compute_cpu(u, v, w, ind_r, ind_s, ind_t, ind_e, n_x, n_y, n_z, h, tau_x, tau_y, tau_z, n_nodes, lx, nelv, kappa, rho_w, b, z0, tstep)
Compute the wall shear stress on CPU using the rough log-law model.
Implements the device kernel for the rough_log_law_t type.
subroutine, public rough_log_law_compute_device(u_d, v_d, w_d, ind_r_d, ind_s_d, ind_t_d, ind_e_d, n_x_d, n_y_d, n_z_d, h_d, tau_x_d, tau_y_d, tau_z_d, n_nodes, lx, kappa, rho_w_d, b, z0, tstep)
Compute the wall shear stress on device using the rough log-law model.
Implements rough_log_law_t.
subroutine rough_log_law_init_from_components(this, scheme_name, coef, msk, facet, h_index, kappa, b, z0)
Constructor from components.
subroutine rough_log_law_finalize(this, msk, facet)
Finalize the construction using the mask and facet arrays of the bc.
subroutine rough_log_law_extract_properties(this)
Extract the values of rho at the boundary.
subroutine rough_log_law_init(this, scheme_name, coef, msk, facet, h_index, json)
Constructor from JSON.
subroutine rough_log_law_partial_init(this, coef, json)
Constructor from JSON.
subroutine rough_log_law_free(this)
Destructor for the rough_log_law_t (base) class.
Defines a registry for storing and requesting temporary objects This can be used when you have a func...
type(scratch_registry_t), target, public neko_scratch_registry
Global scratch registry.
Utilities.
Definition utils.f90:35
Defines a vector.
Definition vector.f90:34
Implements wall_model_t.
Coefficients defined on a given (mesh, ) tuple. Arrays use indices (i,j,k,e): element e,...
Definition coef.f90:63
Wall model based on the log-law for a rough wall. The formula defining the law is ....
Base abstract type for wall-stress models for wall-modelled LES.