37 use json_module,
only : json_file
58 real(kind=
rp) :: kappa = 0.41_rp
60 real(kind=
rp) :: b = 5.2_rp
62 real(kind=
rp) :: p = 1.138_rp
64 real(kind=
rp) :: s = 217.8_rp
77 procedure, pass(this) :: init_from_components => &
82 procedure, pass(this) :: compute_nu_and_rho => &
99 character(len=*),
intent(in) :: scheme_name
100 type(
coef_t),
intent(in) :: coef
101 integer,
intent(in) :: msk(:)
102 integer,
intent(in) :: facet(:)
103 integer,
intent(in) :: h_index
104 type(json_file),
intent(inout) :: json
105 real(kind=
rp) :: kappa, b, p, s
112 call this%init_from_components(scheme_name, coef, msk, facet, h_index, &
121 type(
coef_t),
intent(in) :: coef
122 type(json_file),
intent(inout) :: json
123 call this%partial_init_base(coef, json)
135 integer,
intent(in) :: msk(:)
136 integer,
intent(in) :: facet(:)
138 call this%finalize_base(msk, facet)
139 call this%nu%init(this%n_nodes)
140 call this%rho_w%init(this%n_nodes)
154 msk, facet, h_index, kappa, B, p, s)
156 character(len=*),
intent(in) :: scheme_name
157 type(
coef_t),
intent(in) :: coef
158 integer,
intent(in) :: msk(:)
159 integer,
intent(in) :: facet(:)
160 integer,
intent(in) :: h_index
161 real(kind=
rp),
intent(in) :: kappa, b, p, s
164 call this%init_base(scheme_name, coef, msk, facet, h_index)
171 call this%nu%init(this%n_nodes)
172 call this%rho_w%init(this%n_nodes)
186 temp%size(), this%nu%size())
188 this%msk_d, this%rho%size(), this%rho_w%size())
193 this%rho%size(), this%rho_w%size())
203 call this%rho_w%free()
205 call this%free_base()
213 real(kind=
rp),
intent(in) :: t
214 integer,
intent(in) :: tstep
219 call this%compute_nu_and_rho()
227 this%ind_r_d, this%ind_s_d, this%ind_t_d, this%ind_e_d, &
228 this%n_x%x_d, this%n_y%x_d, this%n_z%x_d, this%nu%x_d, &
229 this%rho_w%x_d, this%h%x_d, this%tau_x%x_d, this%tau_y%x_d, &
230 this%tau_z%x_d, this%n_nodes, u%Xh%lx, this%kappa, this%B, &
234 this%ind_s, this%ind_t, this%ind_e, this%n_x%x, this%n_y%x, &
235 this%n_z%x, this%nu%x, this%rho_w%x, this%h%x, this%tau_x%x, &
236 this%tau_y%x, this%tau_z%x, this%n_nodes, u%Xh%lx, u%msh%nelv, &
237 this%kappa, this%B, this%p, this%s)
__global__ void cai_sagaut_model_ii_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__ nu_d, const T *__restrict__ rho_w_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 B, const T p, const T s)
CPU backend for cai_sagaut_model_ii_t.
subroutine, public cai_sagaut_model_ii_compute_cpu(u, v, w, ind_r, ind_s, ind_t, ind_e, n_x, n_y, n_z, nu, rho_w, h, tau_x, tau_y, tau_z, n_nodes, lx, nelv, kappa, b, p, s)
Evaluate wall shear stresses with the CPU Model-II kernel.
Device dispatch for cai_sagaut_model_ii_t.
subroutine, public cai_sagaut_model_ii_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, nu_d, rho_w_d, h_d, tau_x_d, tau_y_d, tau_z_d, n_nodes, lx, kappa, b, p, s)
Evaluate the device wall-model kernel for Model-II.
Implements cai_sagaut_model_ii_t.
subroutine cai_sagaut_model_ii_init(this, scheme_name, coef, msk, facet, h_index, json)
Initialise the wall model from the case file.
subroutine cai_sagaut_model_ii_compute_nu_and_rho(this)
Gather viscosity and density values at the wall-model points.
subroutine cai_sagaut_model_ii_partial_init(this, coef, json)
Partially initialise the wall model from the case file.
subroutine cai_sagaut_model_ii_init_from_components(this, scheme_name, coef, msk, facet, h_index, kappa, b, p, s)
Initialise the wall model from explicit components.
subroutine cai_sagaut_model_ii_free(this)
Destructor.
subroutine cai_sagaut_model_ii_finalize(this, msk, facet)
Finalise allocation of derived data structures.
subroutine, public device_masked_gather_copy_0(a_d, b_d, mask_d, n, n_mask, strm)
Gather a masked vector .
subroutine, public field_invcol3(a, b, c, n)
Invert a vector .
Utilities for retrieving parameters from the case files.
subroutine, public masked_gather_copy_0(a, b, mask, n, n_mask)
Gather a masked vector to reduced contigous vector .
integer, parameter neko_bcknd_device
integer, parameter, public rp
Global precision used in computations.
Defines a registry for storing solution fields.
type(registry_t), target, public neko_registry
Global field registry.
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.
Explicit wall model based on Model-II from Cai and Sagaut (2021).
Coefficients defined on a given (mesh, ) tuple. Arrays use indices (i,j,k,e): element e,...
Base abstract type for wall-stress models for wall-modelled LES.