43 use,
intrinsic :: iso_fortran_env
44 use,
intrinsic :: iso_c_binding
46 use json_module,
only : json_file
56 real(kind=
rp),
dimension(3) :: uinf = [0d0, 0d0, 0d0]
57 real(kind=
rp) :: delta
59 type(c_ptr),
private :: blax_d = c_null_ptr
60 type(c_ptr),
private :: blay_d = c_null_ptr
61 type(c_ptr),
private :: blaz_d = c_null_ptr
71 procedure, pass(this) :: init_from_components => &
85 class(
blasius_t),
intent(inout),
target :: this
86 type(
coef_t),
target,
intent(in) :: coef
87 type(json_file),
intent(inout) :: json
88 real(kind=
rp) :: delta
89 real(kind=
rp),
allocatable :: uinf(:)
90 character(len=:),
allocatable :: approximation
92 call this%init_base(coef)
95 call json_get(json,
'approximation', approximation)
98 if (
size(uinf) .ne. 3)
then
99 call neko_error(
"The uinf keyword for the blasius profile should be an &
103 call this%init_from_components(coef, delta, uinf, approximation)
114 class(
blasius_t),
intent(inout),
target :: this
115 type(
coef_t),
target,
intent(in) :: coef
116 real(kind=
rp) :: delta
117 real(kind=
rp) :: uinf(3)
118 character(len=*) :: approximation
120 call this%init_base(coef)
125 select case (trim(approximation))
139 call neko_error(
'Invalid Blasius approximation')
144 class(
blasius_t),
target,
intent(inout) :: this
146 call this%free_base()
149 if (c_associated(this%blax_d))
then
153 if (c_associated(this%blay_d))
then
157 if (c_associated(this%blaz_d))
then
166 integer,
intent(in) :: n
167 real(kind=
rp),
intent(inout),
dimension(n) :: x
169 logical,
intent(in),
optional :: strong
174 class(
blasius_t),
intent(inout),
target :: this
175 type(c_ptr),
intent(inout) :: x_d
177 logical,
intent(in),
optional :: strong
178 type(c_ptr),
intent(inout) :: strm
184 integer,
intent(in) :: n
185 real(kind=
rp),
intent(inout),
dimension(n) :: x
186 real(kind=
rp),
intent(inout),
dimension(n) :: y
187 real(kind=
rp),
intent(inout),
dimension(n) :: z
189 logical,
intent(in),
optional :: strong
190 integer :: i, m, k, idx(4), facet
193 if (
present(strong))
then
199 associate(xc => this%coef%dof%x, yc => this%coef%dof%y, &
200 zc => this%coef%dof%z, nx => this%coef%nx, ny => this%coef%ny, &
201 nz => this%coef%nz, lx => this%coef%Xh%lx)
207 facet = this%facet(i)
211 x(k) = this%bla(zc(idx(1), idx(2), idx(3), idx(4)), &
212 this%delta, this%uinf(1))
217 y(k) = this%bla(xc(idx(1), idx(2), idx(3), idx(4)), &
218 this%delta, this%uinf(2))
223 z(k) = this%bla(yc(idx(1), idx(2), idx(3), idx(4)), &
224 this%delta, this%uinf(3))
234 class(
blasius_t),
intent(inout),
target :: this
235 type(c_ptr),
intent(inout) :: x_d
236 type(c_ptr),
intent(inout) :: y_d
237 type(c_ptr),
intent(inout) :: z_d
238 type(time_state_t),
intent(in),
optional :: time
239 logical,
intent(in),
optional :: strong
240 integer :: i, m, k, idx(4), facet
241 integer(c_size_t) :: s
242 real(kind=rp),
allocatable :: bla_x(:), bla_y(:), bla_z(:)
244 type(c_ptr),
intent(inout) :: strm
246 if (
present(strong))
then
252 associate(xc => this%coef%dof%x, yc => this%coef%dof%y, &
253 zc => this%coef%dof%z, nx => this%coef%nx, ny => this%coef%ny, &
254 nz => this%coef%nz, lx => this%coef%Xh%lx , &
255 blax_d => this%blax_d, blay_d => this%blay_d, &
256 blaz_d => this%blaz_d)
262 if (.not. c_associated(blax_d) .and. strong_ .and. m .gt. 0)
then
263 allocate(bla_x(m), bla_y(m), bla_z(m))
265 if (rp .eq. real32)
then
267 else if (rp .eq. real64)
then
271 call device_alloc(blax_d, s)
272 call device_alloc(blay_d, s)
273 call device_alloc(blaz_d, s)
277 facet = this%facet(i)
281 bla_x(i) = this%bla(zc(idx(1), idx(2), idx(3), idx(4)), &
282 this%delta, this%uinf(1))
287 bla_y(i) = this%bla(xc(idx(1), idx(2), idx(3), idx(4)), &
288 this%delta, this%uinf(2))
293 bla_z(i) = this%bla(yc(idx(1), idx(2), idx(3), idx(4)), &
294 this%delta, this%uinf(3))
299 call device_memcpy(bla_x, blax_d, m, host_to_device, sync = .false.)
300 call device_memcpy(bla_y, blay_d, m, host_to_device, sync = .false.)
301 call device_memcpy(bla_z, blaz_d, m, host_to_device, sync = .true.)
303 deallocate(bla_x, bla_y, bla_z)
306 if (strong_ .and. this%msk(0) .gt. 0)
then
307 call device_inhom_dirichlet_apply_vector(this%msk_d, x_d, y_d, z_d, &
308 blax_d, blay_d, blaz_d, m, strm)
318 real(kind=rp),
intent(in) :: uinf(3)
319 real(kind=rp),
intent(in) :: delta
320 character(len=*) :: type
324 select case (trim(type))
326 this%bla => blasius_linear
328 this%bla => blasius_quadratic
330 this%bla => blasius_cubic
332 this%bla => blasius_quartic
334 this%bla => blasius_sin
336 this%bla => blasius_tanh
338 call neko_error(
'Invalid Blasius approximation')
344 class(
blasius_t),
target,
intent(inout) :: this
345 logical,
optional,
intent(in) :: only_facets
346 logical :: only_facets_
348 if (
present(only_facets))
then
349 only_facets_ = only_facets
351 only_facets_ = .false.
354 call this%finalize_base(only_facets_)
__inline__ __device__ void nonlinear_index(const int idx, const int lx, int *index)
Copy data between host and device (or device and device)
Abstract interface for computing a Blasius flow profile.
Retrieves a parameter by name or throws an error.
Defines a boundary condition.
Defines a Blasius profile dirichlet condition.
subroutine blasius_finalize(this, only_facets)
Finalize.
subroutine blasius_apply_scalar_dev(this, x_d, time, strong, strm)
No-op scalar apply (device version)
subroutine blasius_init(this, coef, json)
Constructor.
subroutine blasius_init_from_components(this, coef, delta, uinf, approximation)
Constructor from components.
subroutine blasius_apply_vector(this, x, y, z, n, time, strong)
Apply blasius conditions (vector valued)
subroutine blasius_apply_scalar(this, x, n, time, strong)
No-op scalar apply.
subroutine blasius_apply_vector_dev(this, x_d, y_d, z_d, time, strong, strm)
Apply blasius conditions (vector valued) (device version)
subroutine blasius_free(this)
subroutine blasius_set_params(this, uinf, delta, type)
Set Blasius parameters.
subroutine device_inhom_dirichlet_apply_vector(msk, x, y, z, bla_x, bla_y, bla_z, m, strm)
Device abstraction, common interface for various accelerators.
integer, parameter, public host_to_device
subroutine, public device_free(x_d)
Deallocate memory on the device.
subroutine, public device_alloc(x_d, s)
Allocate memory on the device.
real(kind=rp) function, public blasius_quadratic(y, delta, u)
Quadratic approximate Blasius Profile .
real(kind=rp) function, public blasius_quartic(y, delta, u)
Quartic approximate Blasius Profile .
real(kind=rp) function, public blasius_sin(y, delta, u)
Sinusoidal approximate Blasius Profile .
real(kind=rp) function, public blasius_cubic(y, delta, u)
Cubic approximate Blasius Profile .
real(kind=rp) function, public blasius_tanh(y, delta, u)
Hyperbolic tangent approximate Blasius Profile from O. Savas (2012) where is the 99 percent thickne...
real(kind=rp) function, public blasius_linear(y, delta, u)
Linear approximate Blasius profile .
Utilities for retrieving parameters from the case files.
integer, parameter, public rp
Global precision used in computations.
Module with things related to the simulation time.
Base type for a boundary condition.
Blasius profile for inlet (vector valued).
Coefficients defined on a given (mesh, ) tuple. Arrays use indices (i,j,k,e): element e,...
A struct that contains all info about the time, expand as needed.