37 use json_module,
only : json_file
51 use mpi_f08,
only : mpi_wtime, mpi_barrier
69 real(kind=
rp) :: start_time
71 logical :: default_fname = .true.
77 procedure, pass(this) :: init_from_components => &
96 type(json_file),
intent(inout) :: json
97 class(
case_t),
intent(inout),
target :: case
98 character(len=:),
allocatable :: filename
99 character(len=20),
allocatable :: fields(:)
100 character(len=:),
allocatable :: hom_dir
101 character(len=:),
allocatable :: stat_set
102 character(len=:),
allocatable :: sname
103 character(len=:),
allocatable :: name
104 real(kind=
rp) :: start_time
105 type(
field_t),
pointer :: s, u, v, w, p
106 type(
coef_t),
pointer :: coef
107 logical :: sname_provided
109 sname_provided = json%valid_path(
'field')
113 if (sname_provided)
then
115 name,
"scalar_stats_" // trim(sname))
118 name,
"scalar_stats")
120 call this%init_base(json,
case)
133 coef =>
case%fluid%c_Xh
136 if (json%valid_path(
"output_filename"))
then
137 call json_get(json,
"output_filename", filename)
139 p, coef, start_time, hom_dir, stat_set, filename)
140 else if (sname_provided)
then
142 p, coef, start_time, hom_dir, stat_set,
"scalar_stats_" // trim(sname) //
"0")
145 p, coef, start_time, hom_dir, stat_set)
162 p, coef, start_time, hom_dir, stat_set, fname)
164 character(len=*),
intent(in) :: name
165 character(len=*),
intent(in) :: hom_dir
166 character(len=*),
intent(in) :: stat_set
167 real(kind=
rp),
intent(in) :: start_time
168 type(
field_t),
intent(in),
target :: s, u, v, w, p
169 type(
coef_t),
intent(in),
target :: coef
170 character(len=*),
intent(in),
optional :: fname
171 character(len=NEKO_FNAME_LEN) :: stats_fname
172 character(len=LOG_SIZE) :: log_buf
173 character(len=5) :: prefix
176 call neko_log%section(
'Scalar stats')
177 write(log_buf,
'(A,A)')
'Scalar field: ', trim(s%name)
179 write(log_buf,
'(A,E15.7)')
'Start time: ', start_time
181 write(log_buf,
'(A,A)')
'Set of statistics: ', trim(stat_set)
183 write(log_buf,
'(A,A)')
'Averaging in direction: ', trim(hom_dir)
187 call this%stats%init(coef, s, u, v, w, p, stat_set, name)
189 this%start_time = start_time
190 this%time = start_time
191 if (
present(fname))
then
192 this%default_fname = .false.
195 stats_fname =
"scalar_stats0"
196 this%default_fname = .true.
199 call this%stats_output%init(this%stats, this%start_time, &
200 hom_dir = hom_dir, name = stats_fname, &
201 path = this%case%output_directory)
203 call this%case%output_controller%add(this%stats_output, &
204 this%output_controller%control_value, &
205 this%output_controller%control_mode)
214 call this%free_base()
215 call this%stats%free()
221 character(len=NEKO_FNAME_LEN) :: fname
222 character(len=5) :: prefix, suffix
223 integer :: last_slash_pos
226 if (t .gt. this%time) this%time = t
227 if (this%default_fname)
then
228 fname = this%stats_output%file_%get_base_fname()
229 write (prefix,
'(I5)') this%stats_output%file_%get_counter()
233 if (last_slash_pos .ne. 0)
then
235 trim(fname(1:last_slash_pos))// &
236 "scalar_stats"//trim(adjustl(prefix))//
"."//suffix
238 fname =
"scalar_stats"// &
239 trim(adjustl(prefix))//
"."//suffix
241 call this%stats_output%init_base(fname)
250 real(kind=
rp) :: delta_t, t
251 real(kind=
rp) :: sample_start_time, sample_time
252 character(len=LOG_SIZE) :: log_buf
255 if (time%start_time .gt. this%start_time)
then
256 write(log_buf,
'(A)')
'Simulation start time is later than the ' &
257 //
'scalar stats start time.'
259 write(log_buf,
'(A,E15.7)')
'Simulation start time:', time%start_time
261 write(log_buf,
'(A,E15.7)')
'Scalar stats start time:', this%start_time
263 write(log_buf,
'(A)')
'Assigning the statistics start time to ' &
264 //
'the simulation start time.'
266 this%start_time = time%start_time
267 this%time = time%start_time
272 if (t .ge. this%start_time)
then
273 delta_t = t - this%time
277 sample_start_time = mpi_wtime()
279 call this%stats%update(delta_t)
283 sample_time = mpi_wtime() - sample_start_time
285 call neko_log%section(
'Scalar stats')
286 write(log_buf,
'(A,E15.7)')
'Sampling at time:', t
288 write(log_buf,
'(A33,E15.7)')
'Simulationtime since last sample:', &
291 write(log_buf,
'(A,E15.7)')
'Sampling time (s):', sample_time
Retrieves a parameter by name or assigns a provided default value. In the latter case also adds the m...
Retrieves a parameter by name or throws an error.
Defines a simulation case.
type(mpi_comm), public neko_comm
MPI communicator.
Utilities for retrieving parameters from the case files.
type(log_t), public neko_log
Global log stream.
integer, parameter, public log_size
integer, parameter, public dp
integer, parameter, public sp
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.
Implements scalar_stats_ouput_t.
Implements the scalar_stats_simcomp_t type.
subroutine scalar_stats_simcomp_free(this)
Destructor.
subroutine scalar_stats_simcomp_init_from_json(this, json, case)
Constructor from json.
subroutine scalar_stats_simcomp_restart(this, time)
subroutine scalar_stats_simcomp_init_from_components(this, name, s, u, v, w, p, coef, start_time, hom_dir, stat_set, fname)
Actual constructor.
subroutine scalar_stats_simcomp_compute(this, time)
scalar_stats, called depending on compute_control and compute_value
Computes various statistics for the scalar fields. We use the Reynolds decomposition for a field u = ...
Simulation components are objects that encapsulate functionality that can be fit to a particular comp...
subroutine restart_(this, time)
Dummy restart function.
subroutine compute_(this, time)
Dummy compute function.
Defines a container for all statistics.
Module with things related to the simulation time.
integer, parameter, public neko_fname_len
subroutine, public filename_suffix(fname, suffix)
Extract a filename's suffix.
pure integer function, public filename_tslash_pos(fname)
Find position (in the string) of a filename's trailing slash.
Coefficients defined on a given (mesh, ) tuple. Arrays use indices (i,j,k,e): element e,...
Defines an output for the scalar statistics computed using the scalar_stats_t object.
A simulation component that computes the scalar statistics for the skewness, kurtosis,...
Base abstract class for simulation components.
A struct that contains all info about the time, expand as needed.