61 character(len=20) :: SIMCOMPS_KNOWN_TYPES(20) = [character(len=20) :: &
62 "boundary_operation", &
89 module subroutine simulation_component_factory(object, json,
case)
90 class(simulation_component_t),
allocatable,
intent(inout) :: object
91 type(json_file),
intent(inout) :: json
92 class(case_t),
intent(inout),
target :: case
93 character(len=:),
allocatable :: type_name
94 character(len=:),
allocatable :: type_string
98 call json_get_or_default(json,
"is_user", is_user, .false.)
102 call json_get(json,
"type", type_name)
105 call simulation_component_allocator(object, type_name)
108 call object%init(json,
case)
110 end subroutine simulation_component_factory
115 module subroutine simulation_component_allocator(object, type_name)
116 class(simulation_component_t),
allocatable,
intent(inout) :: object
117 character(len=*),
intent(in):: type_name
120 if (
allocated(object))
then
125 select case (trim(type_name))
126 case (
"boundary_operation")
128 case (
"boundary_flux")
136 case (
"field_writer")
148 case (
"force_torque")
152 case (
"fluid_sgs_stats")
154 case (
"scalar_stats")
156 case (
"scalar_sgs_stats")
160 case (
"spectral_error")
162 case (
"data_streamer")
164 case (
"field_subsampler")
167 do i = 1, simcomp_registry_size
168 if (trim(type_name) == &
169 trim(simcomp_registry(i)%type_name))
then
170 call simcomp_registry(i)%allocator(object)
175 simcomps_known_types)
178 end subroutine simulation_component_allocator
185 module subroutine register_simulation_component(type_name, allocator)
186 character(len=*),
intent(in) :: type_name
187 procedure(simulation_component_allocate),
pointer,
intent(in) :: allocator
188 type(allocator_entry),
allocatable :: temp(:)
191 do i = 1,
size(simcomps_known_types)
192 if (trim(type_name) .eq. trim(simcomps_known_types(i)))
then
198 do i = 1, simcomp_registry_size
199 if (trim(type_name) .eq. &
200 trim(simcomp_registry(i)%type_name))
then
207 if (simcomp_registry_size == 0)
then
208 allocate(simcomp_registry(1))
210 allocate(temp(simcomp_registry_size + 1))
211 temp(1:simcomp_registry_size) = simcomp_registry
212 call move_alloc(temp, simcomp_registry)
215 simcomp_registry_size = simcomp_registry_size + 1
216 simcomp_registry(simcomp_registry_size)%type_name = type_name
217 simcomp_registry(simcomp_registry_size)%allocator => allocator
218 end subroutine register_simulation_component
220end submodule simulation_component_fctry
Implements boundary_flux_t.
Implements boundary_operation_t.
Defines a simulation case.
Implements the curl_t type.
A simulation component that streams data using ADIOS2.
Implements the derivative_t type.
Implements the divergence_t type.
Implements type field_subsampler_t.
Implements the field_writer_t type.
Implements the fluid_sgs_stats_simcomp_t type.
Implements the fluid_stats_simcomp_t type.
Implements the force_torque_t type.
Implements the gradient_t type.
A simulation component that computes lambda2 The values are stored in the field registry under the na...
Implements the les_simcomp_t type.
Implements the scalar_sgs_stats_simcomp_t type.
Implements the scalar_stats_simcomp_t type.
Simulation components are objects that encapsulate functionality that can be fit to a particular comp...
Implements type spectral_error_t.
Implements the user_stats_t type.
character(:) function, allocatable, public concat_string_array(array, sep, prepend)
Concatenate an array of strings into one string with array items separated by spaces.
subroutine, public neko_type_registration_error(base_type, wrong_type, known)
subroutine, public neko_type_error(base_type, wrong_type, known_types)
Reports an error allocating a type for a particular base pointer class.
Implements the weak_gradient_t type.
A simulation component for total vector flux through labelled zones.
A simulation component for boundary reductions on labelled zones.
A simulation component that computes the curl of a vector field. Added to the field registry as curl_...
A simulation component that computes a derivative of a field. Wraps the duxyz operator.
A simulation component that computes the divergence of a vector field. Added to the field registry as...
Implements the field_subsampler_t simulation components, which allows for masking regions of the doma...
A simulation component that writes a 3d field to a file.
A simulation component that computes the subgrid-scale contributions to the Reynolds stresses in LES.
A simulation component that computes the velocity and pressure statistics up to 4th order....
A simulation component that computes the force and torque on a given boundary zone.
A simulation component that computes the gradient of a field. Wraps the gradient operator.
A simulation component that drives the computation of the SGS viscosity.
A simulation component that computes the subgrid-scale contributions to the Reynolds stresses in LES.
A simulation component that computes the scalar statistics for the skewness, kurtosis,...
Provides tools to calculate the spectral error indicator.
A simulation component that computes the averages of fields in the registry.
A simulation component that computes the weak gradient of a field. Wraps the opgradient operator.