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, var_mok
114 integer,
dimension(MPI_STATUS_SIZE) :: status
115 integer(KIND=MPI_OFFSET_KIND) :: disp
116 integer :: m_mok, n_mok, p_mok, mok, wp_mok, save_index
122 write (file_loc,
'(A)') trim(file_loc_base) //
'ib.dat'
124 write (file_loc,
'(A)') trim(file_loc_base) //
'/ib_data.dat'
126 inquire (file=trim(file_loc), exist=file_exist)
131 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
133 m_mok = int(
m_glb + 1, mpi_offset_kind)
134 n_mok = int(
n_glb + 1, mpi_offset_kind)
135 p_mok = int(
p_glb + 1, mpi_offset_kind)
136 mok = int(1._wp, mpi_offset_kind)
137 wp_mok = int(storage_size(0._stp)/8, mpi_offset_kind)
140 data_size = (
m + 1)*(
n + 1)*(
p + 1)
141 var_mok = int(
sys_size + 1, mpi_offset_kind)
142 if (t_step == 0)
then
145 disp = m_mok*max(mok, n_mok)*max(mok, p_mok)*wp_mok*(var_mok - 1 + int(save_index, mpi_offset_kind))
149 call mpi_file_read(ifile,
mpi_io_ib_data%var%sf, data_size, mpi_integer, status, ierr)
151 call mpi_file_close(ifile, ierr)
154 open (2, file=trim(file_loc), form=
'unformatted', action=
'read', status=
'old')
159 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
167 integer,
intent(in) :: local_start_idx, end_x, end_y, end_z
171 allocate (
q_cons_vf(i)%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
172 allocate (
q_prim_vf(i)%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
176 allocate (
ib_markers%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
180 allocate (
q_t_sf%sf(local_start_idx:end_x,local_start_idx:end_y,local_start_idx:end_z))
189 integer,
intent(in) :: t_step
190 character(LEN=len_trim(case_dir) + 2*name_len) :: t_step_dir
191 character(LEN=len_trim(case_dir) + 3*name_len) :: file_loc
192 character(len=int(floor(log10(real(
sys_size, wp)))) + 1) :: file_num
193 character(LEN=len_trim(case_dir) + 2*name_len) :: t_step_ib_dir
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 real(wp) :: delx, dely, delz
262 character(LEN=path_len + 2*name_len) :: file_loc
263 logical :: file_exist
264 character(len=10) :: t_step_string
267 allocate (x_cb_glb(-1:
m_glb))
268 allocate (y_cb_glb(-1:
n_glb))
269 allocate (z_cb_glb(-1:
p_glb))
277 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'x_cb.dat'
278 inquire (file=trim(file_loc), exist=file_exist)
281 data_size =
m_glb + 2
282 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
284 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
285 call mpi_type_commit(filetype, ierr)
288 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
290 call mpi_file_read(ifile, x_cb_glb, data_size, mpi_p, status, ierr)
291 call mpi_file_close(ifile, ierr)
293 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
301 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'y_cb.dat'
302 inquire (file=trim(file_loc), exist=file_exist)
305 data_size =
n_glb + 2
306 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
308 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
309 call mpi_type_commit(filetype, ierr)
312 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
314 call mpi_file_read(ifile, y_cb_glb, data_size, mpi_p, status, ierr)
315 call mpi_file_close(ifile, ierr)
317 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
325 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) //
'z_cb.dat'
326 inquire (file=trim(file_loc), exist=file_exist)
329 data_size =
p_glb + 2
330 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
332 call mpi_type_vector(data_size, 1, stride, mpi_p, filetype, ierr)
333 call mpi_type_commit(filetype, ierr)
336 call mpi_file_set_view(ifile, offset, mpi_p, filetype,
'native',
mpi_info_int, ierr)
338 call mpi_file_read(ifile, z_cb_glb, data_size, mpi_p, status, ierr)
339 call mpi_file_close(ifile, ierr)
341 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
352 deallocate (x_cb_glb, y_cb_glb, z_cb_glb)
367 integer,
intent(in) :: t_step
368 integer(KIND=MPI_OFFSET_KIND),
intent(inout) :: m_mok, n_mok, p_mok
369 integer(KIND=MPI_OFFSET_KIND),
intent(inout) :: wp_mok, mok, str_mok, nvars_mok
370 integer :: ifile, ierr, data_size
371 integer,
dimension(MPI_STATUS_SIZE) :: status
372 integer(KIND=MPI_OFFSET_KIND) :: disp, var_mok
373 character(LEN=path_len + 2*name_len) :: file_loc
374 logical :: file_exist
375 character(len=10) :: t_step_string
380 write (file_loc,
'(I0,A1,I7.7,A)') t_step,
'_',
proc_rank,
'.dat'
381 file_loc = trim(
case_dir) //
'/restart_data/lustre_' // trim(t_step_string) // trim(
mpiiofs) // trim(file_loc)
382 inquire (file=trim(file_loc), exist=file_exist)
385 call mpi_file_open(mpi_comm_self, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
398 data_size = (
m + 3)*(
n + 3)*(
p + 3)
400 data_size = (
m + 1)*(
n + 1)*(
p + 1)
403 m_mok = int(
m_glb + 1, mpi_offset_kind)
404 n_mok = int(
n_glb + 1, mpi_offset_kind)
405 p_mok = int(
p_glb + 1, mpi_offset_kind)
406 wp_mok = int(storage_size(0._stp)/8, mpi_offset_kind)
407 mok = int(1._wp, mpi_offset_kind)
408 str_mok = int(name_len, mpi_offset_kind)
409 nvars_mok = int(
sys_size, mpi_offset_kind)
413 var_mok = int(i, mpi_offset_kind)
414 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
418 var_mok = int(i, mpi_offset_kind)
419 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
424 call mpi_file_close(ifile, ierr)
434 call s_mpi_abort(
'File ' // trim(file_loc) //
' is missing. Exiting.')
437 write (file_loc,
'(I0,A)') t_step,
'.dat'
438 file_loc = trim(
case_dir) //
'/restart_data' // trim(
mpiiofs) // trim(file_loc)
439 inquire (file=trim(file_loc), exist=file_exist)
442 call mpi_file_open(mpi_comm_world, file_loc, mpi_mode_rdonly,
mpi_info_int, ifile, ierr)
447 var_mok = int(i, mpi_offset_kind)
449 disp = m_mok*max(mok, n_mok)*max(mok, p_mok)*wp_mok*(var_mok - 1)
452 call mpi_file_read_all(ifile,
mpi_io_data%var(i)%sf, data_size*mpi_io_type, mpi_io_p, status, ierr)
456 call mpi_file_close(ifile, ierr)
460 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).