32 integer,
intent(in) :: t_step
52 character(len=*),
intent(in) :: t_step_dir
53 character(len=1),
intent(in) :: direction
54 real(wp),
dimension(-1:),
intent(out) :: cb_array
55 real(wp),
dimension(0:),
intent(out) :: d_array
56 real(wp),
dimension(0:),
intent(out) :: cc_array
57 integer,
intent(in) :: size_dim
58 character(LEN=len_trim(t_step_dir) + 10) :: file_loc
61 file_loc = trim(t_step_dir) //
'/' // direction //
'_cb.dat'
62 inquire (file=trim(file_loc), exist=file_check)
65 open (1, file=trim(file_loc), form=
'unformatted', status=
'old', action=
'read')
66 read (1) cb_array(-1:size_dim)
69 call s_mpi_abort(
'File ' // direction //
'_cb.dat is missing in ' // trim(t_step_dir) //
'. Exiting.')
72 d_array(0:size_dim) = cb_array(0:size_dim) - cb_array(-1:size_dim - 1)
73 cc_array(0:size_dim) = cb_array(-1:size_dim - 1) + d_array(0:size_dim)/2._wp
81 integer,
intent(out) :: data_size
82 integer(KIND=MPI_OFFSET_KIND),
intent(out) :: m_mok, n_mok, p_mok
83 integer(KIND=MPI_OFFSET_KIND),
intent(out) :: wp_mok, mok, str_mok, nvars_mok
91 data_size = (
m + 1)*(
n + 1)*(
p + 1)
93 m_mok = int(
m_glb + 1, mpi_offset_kind)
94 n_mok = int(
n_glb + 1, mpi_offset_kind)
95 p_mok = int(
p_glb + 1, mpi_offset_kind)
96 wp_mok = int(storage_size(0._stp)/8, mpi_offset_kind)
97 mok = int(1._wp, mpi_offset_kind)
98 str_mok = int(name_len, mpi_offset_kind)
99 nvars_mok = int(
sys_size, mpi_offset_kind)
107 character(len=*),
intent(in) :: file_loc_base
108 integer,
intent(in),
optional :: t_step
109 character(LEN=len_trim(file_loc_base) + 20) :: file_loc
110 logical :: file_exist
111 integer :: ifile, ierr, data_size
114 integer,
dimension(MPI_STATUS_SIZE) :: status
115 integer(KIND=MPI_OFFSET_KIND) :: disp
116 integer(KIND=MPI_OFFSET_KIND) :: m_mok, n_mok, p_mok, mok, wp_mok, var_mok
117 integer :: save_index
123 write (file_loc,
'(A)') trim(file_loc_base) //
'ib.dat'
125 write (file_loc,
'(A)') trim(file_loc_base) //
'/ib_data.dat'
127 inquire (file=trim(file_loc), exist=file_exist)
132 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
134 m_mok = int(
m_glb + 1, mpi_offset_kind)
135 n_mok = int(
n_glb + 1, mpi_offset_kind)
136 p_mok = int(
p_glb + 1, mpi_offset_kind)
137 mok = int(1._wp, mpi_offset_kind)
138 wp_mok = int(storage_size(0._stp)/8, mpi_offset_kind)
141 data_size = (
m + 1)*(
n + 1)*(
p + 1)
142 var_mok = int(
sys_size + 1, mpi_offset_kind)
143 if (t_step == 0)
then
146 disp = m_mok*max(mok, n_mok)*max(mok, p_mok)*wp_mok*(var_mok - 1 + int(save_index, mpi_offset_kind))
150 call mpi_file_read(ifile,
mpi_io_ib_data%var%sf, data_size, mpi_integer, status, ierr)
152 call mpi_file_close(ifile, ierr)
155 open (2, file=trim(file_loc), form=
'unformatted', action=
'read', status=
'old')
160 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
168 integer,
intent(in) :: local_start_idx, end_x, end_y, end_z
172 allocate (
q_cons_vf(i)%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
173 allocate (
q_prim_vf(i)%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
177 allocate (
ib_markers%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
181 allocate (
q_t_sf%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
190 integer,
intent(in) :: t_step
191 character(LEN=len_trim(case_dir) + 2*name_len) :: t_step_dir
192 character(LEN=len_trim(case_dir) + 3*name_len) :: file_loc
193 character(len=int(floor(log10(real(
sys_size, wp)))) + 1) :: file_num
195 logical :: file_check
198 write (t_step_dir,
'(A,I0,A,I0)')
'/p_all/p',
proc_rank,
'/', t_step
199 t_step_dir = trim(
case_dir) // trim(t_step_dir)
201 file_loc = trim(t_step_dir) //
'/.'
204 if (dir_check .neqv. .true.)
then
205 call s_mpi_abort(
'Time-step folder ' // trim(t_step_dir) //
' is missing. Exiting.')
229 write (file_num,
'(I0)') i
230 file_loc = trim(t_step_dir) //
'/q_cons_vf' // trim(file_num) //
'.dat'
231 inquire (file=trim(file_loc), exist=file_check)
234 open (1, file=trim(file_loc), form=
'unformatted', status=
'old', action=
'read')
241 call s_mpi_abort(
'File q_cons_vf' // trim(file_num) //
'.dat is missing in ' // trim(t_step_dir) //
'. Exiting.')
253 integer,
intent(in) :: t_step
256 real(wp),
allocatable,
dimension(:) :: x_cb_glb, y_cb_glb, z_cb_glb
257 integer :: ifile, ierr, data_size, filetype, stride
258 integer,
dimension(MPI_STATUS_SIZE) :: status
259 integer(KIND=MPI_OFFSET_KIND) :: disp
260 integer(KIND=MPI_OFFSET_KIND) :: m_mok, n_mok, p_mok
261 integer(KIND=MPI_OFFSET_KIND) :: wp_mok, var_mok, str_mok
262 integer(KIND=MPI_OFFSET_KIND) :: nvars_mok
263 integer(KIND=MPI_OFFSET_KIND) :: mok
264 integer(kind=MPI_OFFSET_KIND) :: offset
265 character(LEN=path_len + 2*name_len) :: file_loc
266 logical :: file_exist
267 character(len=10) :: t_step_string
270 allocate (x_cb_glb(-1:
m_glb))
271 allocate (y_cb_glb(-1:
n_glb))
272 allocate (z_cb_glb(-1:
p_glb))
280 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'x_cb.dat'
281 inquire (file=trim(file_loc), exist=file_exist)
284 data_size =
m_glb + 2
285 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
287 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
288 call mpi_type_commit(filetype, ierr)
291 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
293 call mpi_file_read(ifile, x_cb_glb, data_size, mpi_p, status, ierr)
294 call mpi_file_close(ifile, ierr)
296 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
304 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'y_cb.dat'
305 inquire (file=trim(file_loc), exist=file_exist)
308 data_size =
n_glb + 2
309 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
311 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
312 call mpi_type_commit(filetype, ierr)
315 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
317 call mpi_file_read(ifile, y_cb_glb, data_size, mpi_p, status, ierr)
318 call mpi_file_close(ifile, ierr)
320 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
328 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'z_cb.dat'
329 inquire (file=trim(file_loc), exist=file_exist)
332 data_size =
p_glb + 2
333 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
335 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
336 call mpi_type_commit(filetype, ierr)
339 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
341 call mpi_file_read(ifile, z_cb_glb, data_size, mpi_p, status, ierr)
342 call mpi_file_close(ifile, ierr)
344 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
355 deallocate (x_cb_glb, y_cb_glb, z_cb_glb)
370 integer,
intent(in) :: t_step
371 integer(KIND=MPI_OFFSET_KIND),
intent(inout) :: m_mok, n_mok, p_mok
372 integer(KIND=MPI_OFFSET_KIND),
intent(inout) :: wp_mok, mok, str_mok, nvars_mok
373 integer :: ifile, ierr, data_size
374 integer,
dimension(MPI_STATUS_SIZE) :: status
375 integer(KIND=MPI_OFFSET_KIND) :: disp, var_mok
376 character(LEN=path_len + 2*name_len) :: file_loc
377 logical :: file_exist
378 character(len=10) :: t_step_string
383 write (file_loc,
'(I0,A1,I7.7,A)') t_step,
'_',
proc_rank,
'.dat'
384 file_loc = trim(
case_dir) //
'/restart_data/lustre_' // trim(t_step_string) // trim(
mpiiofs) // trim(file_loc)
385 inquire (file=trim(file_loc), exist=file_exist)
388 call mpi_file_open(mpi_comm_self, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
401 data_size = (
m + 3)*(
n + 3)*(
p + 3)
403 data_size = (
m + 1)*(
n + 1)*(
p + 1)
406 m_mok = int(
m_glb + 1, mpi_offset_kind)
407 n_mok = int(
n_glb + 1, mpi_offset_kind)
408 p_mok = int(
p_glb + 1, mpi_offset_kind)
409 wp_mok = int(storage_size(0._stp)/8, mpi_offset_kind)
410 mok = int(1._wp, mpi_offset_kind)
411 str_mok = int(name_len, mpi_offset_kind)
412 nvars_mok = int(
sys_size, mpi_offset_kind)
416 var_mok = int(i, mpi_offset_kind)
417 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
421 var_mok = int(i, mpi_offset_kind)
422 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
427 call mpi_file_close(ifile, ierr)
437 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
440 write (file_loc,
'(I0,A)') t_step,
'.dat'
441 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) // trim(file_loc)
442 inquire (file=trim(file_loc), exist=file_exist)
445 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
450 var_mok = int(i, mpi_offset_kind)
452 disp = m_mok*max(mok, n_mok)*max(mok, p_mok)*wp_mok*(var_mok - 1)
455 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
459 call mpi_file_close(ifile, ierr)
463 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
Noncharacteristic and processor boundary condition application for ghost cells and buffer regions.
subroutine, public s_read_parallel_boundary_condition_files(bc_type)
Read boundary condition type and buffer data from per-rank parallel files using MPI I/O.
subroutine, public s_read_serial_boundary_condition_files(step_dirpath, bc_type)
Read boundary condition type and buffer data from serial (unformatted) restart files.
subroutine, public s_assign_default_bc_type(bc_type)
Initialize the per-cell boundary condition type arrays with the global default BC values.
Platform-specific file and directory operations: create, delete, inquire, getcwd, and basename.
impure subroutine my_inquire(fileloc, dircheck)
Inquires on the existence of a directory.
Shared derived types for field data, patch geometry, bubble dynamics, and MPI I/O structures.
Global parameters for the post-process: domain geometry, equation of state, and output database setti...
logical, parameter chemistry
Chemistry modeling.
integer beta_idx
Index of lagrange bubbles beta.
real(wp), dimension(:), allocatable y_cc
integer proc_rank
Rank of the local processor.
type(mpi_io_ib_var), public mpi_io_ib_data
real(wp), dimension(:), allocatable y_cb
character(len=name_len) mpiiofs
integer, dimension(:), allocatable start_idx
Starting cell-center index of local processor in global grid.
integer sys_size
Number of unknowns in the system of equations.
real(wp), dimension(:), allocatable dz
integer buff_size
Number of ghost cells for boundary condition storage.
real(wp), dimension(:), allocatable z_cb
integer num_dims
Number of spatial dimensions.
real(wp), dimension(:), allocatable x_cc
real(wp), dimension(:), allocatable x_cb
real(wp), dimension(:), allocatable dy
integer t_step_save
Interval between consecutive time-step directory.
real(wp), dimension(:), allocatable z_cc
character(len=path_len) case_dir
Case folder location.
logical mhd
Magnetohydrodynamics.
logical parallel_io
Format of the data files.
logical down_sample
down sampling of the database file(s)
logical file_per_process
output format
logical elasticity
elasticity modeling, true for hyper or hypo
type(mpi_io_var), public mpi_io_data
real(wp), dimension(:), allocatable dx
Cell-width distributions in the x-, y- and z-coordinate directions.
Utility routines for bubble model setup, coordinate transforms, array sampling, and special functions...
elemental subroutine, public s_int_to_str(i, res)
Convert an integer to its trimmed string representation.
MPI communication layer: domain decomposition, halo exchange, reductions, and parallel I/O setup.
impure subroutine s_mpi_abort(prnt, code)
The subroutine terminates the MPI execution environment.
impure subroutine s_mpi_barrier
Halts all processes until all have reached barrier.
impure subroutine s_initialize_mpi_data(q_cons_vf, ib_markers, beta)
Set up MPI I/O data views and variable pointers for parallel file output.
subroutine s_initialize_mpi_data_ds(q_cons_vf)
Set up MPI I/O data views for downsampled (coarsened) parallel file output.
MPI gather and scatter operations for distributing post-process grid and flow-variable data.
Derived type annexing an integer scalar field (SF).
Derived type annexing a scalar field (SF).