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.')
225 write (file_num,
'(I0)') i
226 file_loc = trim(t_step_dir) //
'/q_cons_vf' // trim(file_num) //
'.dat'
227 inquire (file=trim(file_loc), exist=file_check)
230 open (1, file=trim(file_loc), form=
'unformatted', status=
'old', action=
'read')
237 call s_mpi_abort(
'File q_cons_vf' // trim(file_num) //
'.dat is missing in ' // trim(t_step_dir) //
'. Exiting.')
249 integer,
intent(in) :: t_step
252 real(wp),
allocatable,
dimension(:) :: x_cb_glb, y_cb_glb, z_cb_glb
253 integer :: ifile, ierr, data_size, filetype, stride
254 integer,
dimension(MPI_STATUS_SIZE) :: status
255 integer(KIND=MPI_OFFSET_KIND) :: disp
256 integer(KIND=MPI_OFFSET_KIND) :: m_mok, n_mok, p_mok
257 integer(KIND=MPI_OFFSET_KIND) :: wp_mok, var_mok, str_mok
258 integer(KIND=MPI_OFFSET_KIND) :: nvars_mok
259 integer(KIND=MPI_OFFSET_KIND) :: mok
260 integer(kind=MPI_OFFSET_KIND) :: offset
261 character(LEN=path_len + 2*name_len) :: file_loc
262 logical :: file_exist
263 character(len=10) :: t_step_string
266 allocate (x_cb_glb(-1:
m_glb))
267 allocate (y_cb_glb(-1:
n_glb))
268 allocate (z_cb_glb(-1:
p_glb))
276 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'x_cb.dat'
277 inquire (file=trim(file_loc), exist=file_exist)
280 data_size =
m_glb + 2
281 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
283 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
284 call mpi_type_commit(filetype, ierr)
287 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
289 call mpi_file_read(ifile, x_cb_glb, data_size, mpi_p, status, ierr)
290 call mpi_file_close(ifile, ierr)
292 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
300 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'y_cb.dat'
301 inquire (file=trim(file_loc), exist=file_exist)
304 data_size =
n_glb + 2
305 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
307 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
308 call mpi_type_commit(filetype, ierr)
311 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
313 call mpi_file_read(ifile, y_cb_glb, data_size, mpi_p, status, ierr)
314 call mpi_file_close(ifile, ierr)
316 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
324 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'z_cb.dat'
325 inquire (file=trim(file_loc), exist=file_exist)
328 data_size =
p_glb + 2
329 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
331 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
332 call mpi_type_commit(filetype, ierr)
335 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
337 call mpi_file_read(ifile, z_cb_glb, data_size, mpi_p, status, ierr)
338 call mpi_file_close(ifile, ierr)
340 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
351 deallocate (x_cb_glb, y_cb_glb, z_cb_glb)
366 integer,
intent(in) :: t_step
367 integer(KIND=MPI_OFFSET_KIND),
intent(inout) :: m_mok, n_mok, p_mok
368 integer(KIND=MPI_OFFSET_KIND),
intent(inout) :: wp_mok, mok, str_mok, nvars_mok
369 integer :: ifile, ierr, data_size
370 integer,
dimension(MPI_STATUS_SIZE) :: status
371 integer(KIND=MPI_OFFSET_KIND) :: disp, var_mok
372 character(LEN=path_len + 2*name_len) :: file_loc
373 logical :: file_exist
374 character(len=10) :: t_step_string
379 write (file_loc,
'(I0,A1,I7.7,A)') t_step,
'_',
proc_rank,
'.dat'
380 file_loc = trim(
case_dir) //
'/restart_data/lustre_' // trim(t_step_string) // trim(
mpiiofs) // trim(file_loc)
381 inquire (file=trim(file_loc), exist=file_exist)
384 call mpi_file_open(mpi_comm_self, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
397 data_size = (
m + 3)*(
n + 3)*(
p + 3)
399 data_size = (
m + 1)*(
n + 1)*(
p + 1)
402 m_mok = int(
m_glb + 1, mpi_offset_kind)
403 n_mok = int(
n_glb + 1, mpi_offset_kind)
404 p_mok = int(
p_glb + 1, mpi_offset_kind)
405 wp_mok = int(storage_size(0._stp)/8, mpi_offset_kind)
406 mok = int(1._wp, mpi_offset_kind)
407 str_mok = int(name_len, mpi_offset_kind)
408 nvars_mok = int(
sys_size, mpi_offset_kind)
412 var_mok = int(i, mpi_offset_kind)
413 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
417 var_mok = int(i, mpi_offset_kind)
418 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
423 call mpi_file_close(ifile, ierr)
433 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
436 write (file_loc,
'(I0,A)') t_step,
'.dat'
437 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) // trim(file_loc)
438 inquire (file=trim(file_loc), exist=file_exist)
441 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
446 var_mok = int(i, mpi_offset_kind)
448 disp = m_mok*max(mok, n_mok)*max(mok, p_mok)*wp_mok*(var_mok - 1)
451 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
455 call mpi_file_close(ifile, ierr)
459 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).