Neko 1.99.3
A portable framework for high-order spectral element flow simulations
Loading...
Searching...
No Matches
fluid_stats_simcomp.f90
Go to the documentation of this file.
1! Copyright (c) 2024-2026, 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 num_types, only : rp, dp, sp
37 use json_module, only : json_file
39 use registry, only : neko_registry
40 use time_state, only : time_state_t
41 use field, only : field_t
42 use fluid_stats, only : fluid_stats_t
44 use case, only : case_t
45 use coefs, only : coef_t
48 use logger, only : log_size, neko_log
51 use comm, only : neko_comm
52 use mpi_f08, only : mpi_wtime, mpi_barrier
53 implicit none
54 private
55
70 type(fluid_stats_output_t) :: stats_output
72 real(kind=rp) :: start_time
73 real(kind=rp) :: time
74 logical :: default_fname = .true.
75
76 contains
78 procedure, pass(this) :: init => fluid_stats_simcomp_init_from_json
80 procedure, pass(this) :: init_from_components => &
83 procedure, pass(this) :: free => fluid_stats_simcomp_free
85 procedure, pass(this) :: compute_ => fluid_stats_simcomp_compute
87 procedure, pass(this) :: output_ => fluid_stats_simcomp_compute
89 procedure, pass(this) :: restart_ => fluid_stats_simcomp_restart
91
92contains
93
97 subroutine fluid_stats_simcomp_init_from_json(this, json, case)
98 class(fluid_stats_simcomp_t), target, intent(inout) :: this
99 type(json_file), intent(inout) :: json
100 class(case_t), intent(inout), target :: case
101 character(len=:), allocatable :: filename
102 character(len=NEKO_VARNAME_LEN), allocatable :: fields(:)
103 character(len=:), allocatable :: hom_dir
104 character(len=:), allocatable :: stat_set
105 character(len=:), allocatable :: name
106 real(kind=rp) :: start_time
107 type(field_t), pointer :: u, v, w, p
108 type(coef_t), pointer :: coef
109
110 call json_get_or_default(json, "name", name, "fluid_stats")
111 call this%init_base(json, case)
112 call json_get_or_default(json, 'avg_direction', &
113 hom_dir, 'none')
114 call json_get_or_lookup_or_default(json, 'start_time', &
115 start_time, 0.0_rp)
116 call json_get_or_default(json, 'set_of_stats', &
117 stat_set, 'full')
118
119
120 u => neko_registry%get_field("u")
121 v => neko_registry%get_field("v")
122 w => neko_registry%get_field("w")
123 p => neko_registry%get_field("p")
124 coef => case%fluid%c_Xh
125 this%name = name
126
127 if (json%valid_path("output_filename")) then
128 call json_get(json, "output_filename", filename)
129 call fluid_stats_simcomp_init_from_components(this, name, u, v, w, p, &
130 coef, start_time, hom_dir, stat_set, filename)
131 else
132 call fluid_stats_simcomp_init_from_components(this, name, u, v, w, p, &
133 coef, start_time, hom_dir, stat_set)
134 end if
135
137
148 subroutine fluid_stats_simcomp_init_from_components(this, name, u, v, w, p, &
149 coef, start_time, hom_dir, stat_set, fname)
150 class(fluid_stats_simcomp_t), target, intent(inout) :: this
151 character(len=*), intent(in) :: name
152 character(len=*), intent(in) :: hom_dir
153 character(len=*), intent(in) :: stat_set
154 real(kind=rp), intent(in) :: start_time
155 type(field_t), intent(in), target :: u, v, w, p
156 type(coef_t), intent(in), target :: coef
157 character(len=*), intent(in), optional :: fname
158 character(len=NEKO_FNAME_LEN) :: stats_fname
159 character(len=LOG_SIZE) :: log_buf
160 character(len=5) :: prefix
161
162 call neko_log%section('Fluid stats')
163 write(log_buf, '(A,E15.7)') 'Start time: ', start_time
164 call neko_log%message(log_buf)
165 write(log_buf, '(A,A)') 'Set of statistics: ', trim(stat_set)
166 call neko_log%message(log_buf)
167 write(log_buf, '(A,A)') 'Averaging in direction: ', trim(hom_dir)
168 call neko_log%message(log_buf)
169
170 call this%stats%init(coef, u, v, w, p, stat_set, name)
171
172 this%name = name
173 this%start_time = start_time
174 this%time = start_time
175 if (present(fname)) then
176 this%default_fname = .false.
177 stats_fname = fname
178 else
179 stats_fname = "fluid_stats0"
180 this%default_fname = .true.
181 end if
182
183 call this%stats_output%init(this%stats, this%start_time, &
184 hom_dir = hom_dir, name = stats_fname, &
185 path = this%case%output_directory)
186
187 call this%case%output_controller%add(this%stats_output, &
188 this%output_controller%control_value, &
189 this%output_controller%control_mode)
190
191 call neko_log%end_section()
192
194
197 class(fluid_stats_simcomp_t), intent(inout) :: this
198 call this%free_base()
199 call this%stats%free()
200 call this%stats_output%free()
201 end subroutine fluid_stats_simcomp_free
202
203 subroutine fluid_stats_simcomp_restart(this, time)
204 class(fluid_stats_simcomp_t), intent(inout) :: this
205 type(time_state_t), intent(in) :: time
206 character(len=NEKO_FNAME_LEN) :: fname
207 character(len=5) :: prefix, suffix
208 integer :: last_slash_pos
209 real(kind=rp) :: t
210 t = time%t
211 if (t .gt. this%time) this%time = t
212 if (this%default_fname) then
213 fname = this%stats_output%file_%get_base_fname()
214 write (prefix, '(I5)') this%stats_output%file_%get_counter()
215 call filename_suffix(fname, suffix)
216 last_slash_pos = &
218 if (last_slash_pos .ne. 0) then
219 fname = &
220 trim(fname(1:last_slash_pos))// &
221 "fluid_stats"//trim(adjustl(prefix))//"."//suffix
222 else
223 fname = "fluid_stats"// &
224 trim(adjustl(prefix))//"."//suffix
225 end if
226 call this%stats_output%init_base(fname)
227 end if
228 end subroutine fluid_stats_simcomp_restart
229
232 subroutine fluid_stats_simcomp_compute(this, time)
233 class(fluid_stats_simcomp_t), intent(inout) :: this
234 type(time_state_t), intent(in) :: time
235 real(kind=rp) :: delta_t, t
236 real(kind=rp) :: sample_start_time, sample_time
237 character(len=LOG_SIZE) :: log_buf
238 integer :: ierr
239
240 if (time%start_time .gt. this%start_time) then
241 write(log_buf, '(A)') 'Simulation start time is later than the ' &
242 // 'fluid stats start time.'
243 call neko_log%warning(log_buf)
244 write(log_buf, '(A,E15.7)') 'Simulation start time:', time%start_time
245 call neko_log%warning(log_buf)
246 write(log_buf, '(A,E15.7)') 'Fluid stats start time:', this%start_time
247 call neko_log%warning(log_buf)
248 write(log_buf, '(A)') 'Assigning the statistics start time to ' &
249 // 'the simulation start time.'
250 call neko_log%warning(log_buf)
251 this%start_time = time%start_time
252 this%time = time%start_time
253 end if
254
255 t = time%t
256
257 if (t .ge. this%start_time) then
258 delta_t = t - this%time !This is only a real number
259
260 call mpi_barrier(neko_comm, ierr)
261
262 sample_start_time = mpi_wtime()
263
264 call this%stats%update(delta_t)
265 call mpi_barrier(neko_comm, ierr)
266 this%time = t
267
268 sample_time = mpi_wtime() - sample_start_time
269
270 call neko_log%section('Fluid stats')
271 write(log_buf, '(A,E15.7)') 'Sampling at time:', t
272 call neko_log%message(log_buf)
273 write(log_buf, '(A33,E15.7)') 'Simulationtime since last sample:', &
274 delta_t
275 call neko_log%message(log_buf)
276 write(log_buf, '(A,E15.7)') 'Sampling time (s):', sample_time
277 call neko_log%message(log_buf)
278 call neko_log%end_section()
279 end if
280
281 end subroutine fluid_stats_simcomp_compute
282
283end module fluid_stats_simcomp
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.
Definition case.f90:34
Coefficients.
Definition coef.f90:34
Definition comm.F90:1
type(mpi_comm), public neko_comm
MPI communicator.
Definition comm.F90:43
Defines a field.
Definition field.f90:34
Implements fluid_stats_ouput_t.
Implements the fluid_stats_simcomp_t type.
subroutine fluid_stats_simcomp_free(this)
Destructor.
subroutine fluid_stats_simcomp_restart(this, time)
subroutine fluid_stats_simcomp_init_from_json(this, json, case)
Constructor from json.
subroutine fluid_stats_simcomp_compute(this, time)
fluid_stats, called depending on compute_control and compute_value
subroutine fluid_stats_simcomp_init_from_components(this, name, u, v, w, p, coef, start_time, hom_dir, stat_set, fname)
Actual constructor.
Computes various statistics for the fluid fields. We use the Reynolds decomposition for a field u = ...
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
integer, parameter, public dp
Definition num_types.f90:9
integer, parameter, public sp
Definition num_types.f90:8
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
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.
Utilities.
Definition utils.f90:35
integer, parameter, public neko_fname_len
Definition utils.f90:41
subroutine, public filename_suffix(fname, suffix)
Extract a filename's suffix.
Definition utils.f90:118
integer, parameter, public neko_varname_len
Definition utils.f90:42
pure integer function, public filename_tslash_pos(fname)
Find position (in the string) of a filename's trailing slash.
Definition utils.f90:75
Coefficients defined on a given (mesh, ) tuple. Arrays use indices (i,j,k,e): element e,...
Definition coef.f90:63
Defines an output for the fluid statistics computed using the fluid_stats_t object.
A simulation component that computes the velocity and pressure statistics up to 4th order....
Base abstract class for simulation components.
A struct that contains all info about the time, expand as needed.