marker_set_ReadH5HUT Subroutine

private impure subroutine marker_set_ReadH5HUT(this, iter, time, step)

Reads marker data from file in parallel using H5HUT.

Type Bound

marker_set

Arguments

Type IntentOptional Attributes Name
class(marker_set), intent(inout) :: this

A collection of tessellation elements

integer, intent(out) :: iter

Iteration at write

real(kind=wp), intent(out) :: time

Time at write

integer, intent(in), optional :: step

User supplied step to open


Calls

proc~~marker_set_readh5hut~~CallsGraph proc~marker_set_readh5hut marker_set%marker_set_ReadH5HUT c c proc~marker_set_readh5hut->c f f proc~marker_set_readh5hut->f markers markers proc~marker_set_readh5hut->markers n n proc~marker_set_readh5hut->n p p proc~marker_set_readh5hut->p proc~h5hut_obj_final h5hut_obj%h5hut_obj_Final proc~marker_set_readh5hut->proc~h5hut_obj_final proc~h5hut_obj_getnpoints h5hut_obj%h5hut_obj_GetNPoints proc~marker_set_readh5hut->proc~h5hut_obj_getnpoints proc~h5hut_obj_init h5hut_obj%h5hut_obj_Init proc~marker_set_readh5hut->proc~h5hut_obj_init proc~h5hut_obj_jumptostep h5hut_obj%h5hut_obj_JumpToStep proc~marker_set_readh5hut->proc~h5hut_obj_jumptostep proc~h5hut_obj_lasttimestep h5hut_obj%h5hut_obj_LastTimeStep proc~marker_set_readh5hut->proc~h5hut_obj_lasttimestep proc~lagrangian_set_communicate lagrangian_set%lagrangian_set_Communicate proc~marker_set_readh5hut->proc~lagrangian_set_communicate proc~lagrangian_set_localize lagrangian_set%lagrangian_set_Localize proc~marker_set_readh5hut->proc~lagrangian_set_localize proc~lagrangian_set_resize lagrangian_set%lagrangian_set_Resize proc~marker_set_readh5hut->proc~lagrangian_set_resize v v proc~marker_set_readh5hut->v proc~hdf5_obj_final hdf5_obj%hdf5_obj_Final proc~h5hut_obj_final->proc~hdf5_obj_final proc~hdf5_obj_getnpoints hdf5_obj%hdf5_obj_GetNPoints proc~h5hut_obj_getnpoints->proc~hdf5_obj_getnpoints proc~hdf5_obj_readdatasetnames hdf5_obj%hdf5_obj_ReadDatasetNames proc~h5hut_obj_getnpoints->proc~hdf5_obj_readdatasetnames proc~hdf5_obj_init hdf5_obj%hdf5_obj_Init proc~h5hut_obj_init->proc~hdf5_obj_init none~readattributes hdf5_obj%ReadAttributes proc~h5hut_obj_jumptostep->none~readattributes proc~h5hut_obj_setstep h5hut_obj%h5hut_obj_SetStep proc~h5hut_obj_jumptostep->proc~h5hut_obj_setstep proc~h5hut_obj_lasttimestep->none~readattributes proc~h5hut_obj_getnsteps h5hut_obj%h5hut_obj_GetNSteps proc~h5hut_obj_lasttimestep->proc~h5hut_obj_getnsteps proc~h5hut_obj_lasttimestep->proc~h5hut_obj_setstep proc~lagrangian_set_communicate->proc~lagrangian_set_resize mpi_gather mpi_gather proc~lagrangian_set_communicate->mpi_gather mpi_recv mpi_recv proc~lagrangian_set_communicate->mpi_recv mpi_send mpi_send proc~lagrangian_set_communicate->mpi_send proc~lagrangian_set_recycle lagrangian_set%lagrangian_set_Recycle proc~lagrangian_set_communicate->proc~lagrangian_set_recycle proc~block_obj_getowningcell block_obj%block_obj_GetOwningCell proc~lagrangian_set_localize->proc~block_obj_getowningcell proc~hdf5_obj_readattributes0d hdf5_obj%hdf5_obj_ReadAttributes0D none~readattributes->proc~hdf5_obj_readattributes0d proc~hdf5_obj_readattributes1d hdf5_obj%hdf5_obj_ReadAttributes1D none~readattributes->proc~hdf5_obj_readattributes1d proc~hdf5_obj_readgroupnames hdf5_obj%hdf5_obj_ReadGroupNames proc~h5hut_obj_getnsteps->proc~hdf5_obj_readgroupnames proc~hdf5_obj_creategroup hdf5_obj%hdf5_obj_CreateGroup proc~h5hut_obj_setstep->proc~hdf5_obj_creategroup h5garbage_collect_f h5garbage_collect_f proc~hdf5_obj_final->h5garbage_collect_f proc~hashtbl_obj_final hashtbl_obj%hashtbl_obj_Final proc~hdf5_obj_final->proc~hashtbl_obj_final h5dclose_f h5dclose_f proc~hdf5_obj_getnpoints->h5dclose_f h5dget_space_f h5dget_space_f proc~hdf5_obj_getnpoints->h5dget_space_f h5dopen_f h5dopen_f proc~hdf5_obj_getnpoints->h5dopen_f h5sclose_f h5sclose_f proc~hdf5_obj_getnpoints->h5sclose_f h5sget_simple_extent_npoints_f h5sget_simple_extent_npoints_f proc~hdf5_obj_getnpoints->h5sget_simple_extent_npoints_f proc~hdf5_obj_closegroup hdf5_obj%hdf5_obj_CloseGroup proc~hdf5_obj_getnpoints->proc~hdf5_obj_closegroup proc~hdf5_obj_getgroupobject hdf5_obj%hdf5_obj_GetGroupObject proc~hdf5_obj_getnpoints->proc~hdf5_obj_getgroupobject proc~hdf5_obj_opengroup hdf5_obj%hdf5_obj_OpenGroup proc~hdf5_obj_getnpoints->proc~hdf5_obj_opengroup h5open_f h5open_f proc~hdf5_obj_init->h5open_f proc~hashtbl_obj_init hashtbl_obj%hashtbl_obj_Init proc~hdf5_obj_init->proc~hashtbl_obj_init h5gn_members_f h5gn_members_f proc~hdf5_obj_readdatasetnames->h5gn_members_f h5iget_name_f h5iget_name_f proc~hdf5_obj_readdatasetnames->h5iget_name_f h5oclose_f h5oclose_f proc~hdf5_obj_readdatasetnames->h5oclose_f h5oget_info_f h5oget_info_f proc~hdf5_obj_readdatasetnames->h5oget_info_f h5oopen_by_idx_f h5oopen_by_idx_f proc~hdf5_obj_readdatasetnames->h5oopen_by_idx_f proc~hdf5_obj_fixgroupname hdf5_obj%hdf5_obj_FixGroupName proc~hdf5_obj_readdatasetnames->proc~hdf5_obj_fixgroupname proc~lagrangian_set_recycle->proc~lagrangian_set_resize proc~hdf5_obj_closegroup->proc~hdf5_obj_fixgroupname proc~hdf5_obj_closegroup->proc~hdf5_obj_getgroupobject h5gclose_f h5gclose_f proc~hdf5_obj_closegroup->h5gclose_f proc~hashtbl_obj_hashstring hashtbl_obj%hashtbl_obj_HashString proc~hdf5_obj_closegroup->proc~hashtbl_obj_hashstring proc~hashtbl_obj_remove hashtbl_obj%hashtbl_obj_Remove proc~hdf5_obj_closegroup->proc~hashtbl_obj_remove proc~hdf5_obj_creategroup->proc~hdf5_obj_closegroup proc~hdf5_obj_creategroup->proc~hdf5_obj_fixgroupname h5gcreate_f h5gcreate_f proc~hdf5_obj_creategroup->h5gcreate_f proc~hdf5_obj_creategroup->proc~hashtbl_obj_hashstring proc~hashtbl_obj_put hashtbl_obj%hashtbl_obj_Put proc~hdf5_obj_creategroup->proc~hashtbl_obj_put proc~hdf5_obj_getgroupobject->proc~hdf5_obj_fixgroupname none~get~3 hashtbl_obj%Get proc~hdf5_obj_getgroupobject->none~get~3 proc~hdf5_obj_getgroupobject->proc~hashtbl_obj_hashstring proc~hdf5_obj_opengroup->proc~hdf5_obj_fixgroupname proc~hdf5_obj_opengroup->proc~hdf5_obj_getgroupobject h5oopen_f h5oopen_f proc~hdf5_obj_opengroup->h5oopen_f proc~hdf5_obj_opengroup->proc~hashtbl_obj_hashstring proc~hdf5_obj_opengroup->proc~hashtbl_obj_put proc~hdf5_obj_readattributes0d->h5sclose_f proc~hdf5_obj_readattributes0d->proc~hdf5_obj_closegroup proc~hdf5_obj_readattributes0d->proc~hdf5_obj_getgroupobject proc~hdf5_obj_readattributes0d->proc~hdf5_obj_opengroup h5aclose_f h5aclose_f proc~hdf5_obj_readattributes0d->h5aclose_f h5aget_space_f h5aget_space_f proc~hdf5_obj_readattributes0d->h5aget_space_f h5aget_type_f h5aget_type_f proc~hdf5_obj_readattributes0d->h5aget_type_f h5aopen_f h5aopen_f proc~hdf5_obj_readattributes0d->h5aopen_f h5aread_f h5aread_f proc~hdf5_obj_readattributes0d->h5aread_f h5sget_simple_extent_dims_f h5sget_simple_extent_dims_f proc~hdf5_obj_readattributes0d->h5sget_simple_extent_dims_f proc~hdf5_obj_readattributes1d->h5sclose_f proc~hdf5_obj_readattributes1d->proc~hdf5_obj_closegroup proc~hdf5_obj_readattributes1d->proc~hdf5_obj_getgroupobject proc~hdf5_obj_readattributes1d->proc~hdf5_obj_opengroup proc~hdf5_obj_readattributes1d->h5aclose_f proc~hdf5_obj_readattributes1d->h5aget_space_f proc~hdf5_obj_readattributes1d->h5aget_type_f proc~hdf5_obj_readattributes1d->h5aopen_f proc~hdf5_obj_readattributes1d->h5aread_f proc~hdf5_obj_readattributes1d->h5sget_simple_extent_dims_f proc~hdf5_obj_readgroupnames->h5gn_members_f proc~hdf5_obj_readgroupnames->h5iget_name_f proc~hdf5_obj_readgroupnames->h5oclose_f proc~hdf5_obj_readgroupnames->h5oget_info_f proc~hdf5_obj_readgroupnames->h5oopen_by_idx_f proc~hdf5_obj_readgroupnames->proc~hdf5_obj_fixgroupname proc~hashtbl_obj_get_int4 hashtbl_obj%hashtbl_obj_Get_int4 none~get~3->proc~hashtbl_obj_get_int4 proc~hashtbl_obj_get_int8 hashtbl_obj%hashtbl_obj_Get_int8 none~get~3->proc~hashtbl_obj_get_int8 proc~hashtbl_obj_get_real_dp hashtbl_obj%hashtbl_obj_Get_real_dp none~get~3->proc~hashtbl_obj_get_real_dp proc~hashtbl_obj_get_real_sp hashtbl_obj%hashtbl_obj_Get_real_sp none~get~3->proc~hashtbl_obj_get_real_sp proc~sllist_obj_put sllist_obj%sllist_obj_Put proc~hashtbl_obj_put->proc~sllist_obj_put proc~sllist_obj_remove sllist_obj%sllist_obj_Remove proc~hashtbl_obj_remove->proc~sllist_obj_remove none~get~2 sllist_obj%Get proc~hashtbl_obj_get_int4->none~get~2 proc~hashtbl_obj_get_int8->none~get~2 proc~hashtbl_obj_get_real_dp->none~get~2 proc~hashtbl_obj_get_real_sp->none~get~2 proc~sllist_obj_put->proc~sllist_obj_put proc~sllist_obj_get_int4 sllist_obj%sllist_obj_Get_int4 none~get~2->proc~sllist_obj_get_int4 proc~sllist_obj_get_int8 sllist_obj%sllist_obj_Get_int8 none~get~2->proc~sllist_obj_get_int8 proc~sllist_obj_get_real_dp sllist_obj%sllist_obj_Get_real_dp none~get~2->proc~sllist_obj_get_real_dp proc~sllist_obj_get_real_sp sllist_obj%sllist_obj_Get_real_sp none~get~2->proc~sllist_obj_get_real_sp proc~sllist_obj_get_int4->proc~sllist_obj_get_int4 proc~sllist_obj_get_int8->proc~sllist_obj_get_int8 proc~sllist_obj_get_real_dp->proc~sllist_obj_get_real_dp proc~sllist_obj_get_real_sp->proc~sllist_obj_get_real_sp

Source Code

    impure subroutine marker_set_ReadH5HUT(this,iter,time,step)
      !> Reads marker data from file in parallel using H5HUT.
      implicit none
      class(marker_set), intent(inout) :: this                                 !! A collection of tessellation elements
      integer,           intent(out)   :: iter                                 !! Iteration at write
      real(wp),          intent(out)   :: time                                 !! Time at write
      integer,           intent(in),    &
                              optional :: step                                 !! User supplied step to open
      ! Work variables
      type(h5hut_obj)               :: h5                                      !! H5hut structure
      integer,          allocatable :: buffi(:)                                !! Integer buffer
      integer(leapI8),  allocatable :: buffi8(:)                               !! Integer (kind=8) buffer
      real(wp),         allocatable :: buffr(:)                                !! Real buffer
      integer,          allocatable :: size_per_rank(:)                        !! Number of markers per rank
      integer :: max_chunk                                                     !! Max number of chunks on any MPI rank
      integer :: chunk_size                                                    !! Number of markers in chunk
      integer :: goff                                                          !! Global offset
      integer :: loff                                                          !! Local offset
      integer :: n                                                             !! Iterator

      ! Open the file
      call h5%Initialize(trim(adjustl(this%read_file)),"R",this%parallel)

      if (.not.present(step)) then
        ! Jump to last step
        call h5%LastTimeStep(iter,time)
      else
        ! Jump to desired step
        call h5%JumpToStep(step,iter,time)
      end if

      ! Get total number of point objects
      call h5%GetNPoints(this%count)

      ! Distribute equally the data on each mpi rank
      associate(mpi=>this%parallel)
        allocate(size_per_rank(mpi%nproc))

        do n=1,mpi%nproc
          size_per_rank(n) = int(this%count/mpi%nproc)
          if (n.le.mod(this%count,mpi%nproc)) size_per_rank(n)=size_per_rank(n)+1
        end do
      end associate

      ! Allocate buffers
      call this%parallel%Max(ceiling(size_per_rank(this%parallel%rank%mine)/real(this%R_chunk_size,wp)),max_chunk)

      loff  = 0
      chunk_size = 0
      do n=1,max_chunk
        ! Local offset
        loff    = loff + chunk_size

        ! Determine next chunk size
        if (loff.lt.size_per_rank(this%parallel%rank%mine)) then
          chunk_size = min(size_per_rank(this%parallel%rank%mine) - loff,this%R_chunk_size)

          ! Resize the data array to contain read Lagrangian objects
          call this%Resize(this%count_+chunk_size)
        else
          chunk_size = 0
        end if

        ! Global offset
        goff = sum(size_per_rank(1:this%parallel%rank%mine-1)) + loff

        allocate(buffi8(chunk_size),buffi(chunk_size),buffr(chunk_size))

        ! Read the base Lagrangian object structure
        if (chunk_size.eq.0) then
          call h5%Read("id",buffi8,offset=goff)
          call h5%Read("x", buffr, offset=goff)
          call h5%Read("y", buffr, offset=goff)
          call h5%Read("z", buffr, offset=goff)
          call h5%Read("i", buffi, offset=goff)
          call h5%Read("j", buffi, offset=goff)
          call h5%Read("k", buffi, offset=goff)
          call h5%Read("s", buffi, offset=goff)
          call h5%Read("SA",buffr, offset=goff)
          call h5%Read("nx",buffr, offset=goff)
          call h5%Read("ny",buffr, offset=goff)
          call h5%Read("nz",buffr, offset=goff)
          call h5%Read("vx",buffr, offset=goff)
          call h5%Read("vy",buffr, offset=goff)
          call h5%Read("vz",buffr, offset=goff)
          call h5%Read("fx",buffr, offset=goff)
          call h5%Read("fy",buffr, offset=goff)
          call h5%Read("fz",buffr, offset=goff)
        else
          select type (markers=>this%p)
          type is (marker_obj)
            call h5%Read("id",buffi8,offset=goff); markers(this%count_-chunk_size+1:this%count_)%id   = buffi8
            call h5%Read("x", buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%p(1) = buffr
            call h5%Read("y", buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%p(2) = buffr
            call h5%Read("z", buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%p(3) = buffr
            call h5%Read("i", buffi, offset=goff); markers(this%count_-chunk_size+1:this%count_)%c(1) = buffi
            call h5%Read("j", buffi, offset=goff); markers(this%count_-chunk_size+1:this%count_)%c(2) = buffi
            call h5%Read("k", buffi, offset=goff); markers(this%count_-chunk_size+1:this%count_)%c(3) = buffi
            call h5%Read("s", buffi, offset=goff); markers(this%count_-chunk_size+1:this%count_)%s    = buffi
            call h5%Read("SA",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%SA   = buffr
            call h5%Read("nx",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%n(1) = buffr
            call h5%Read("ny",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%n(2) = buffr
            call h5%Read("nz",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%n(3) = buffr
            call h5%Read("vx",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%v(1) = buffr
            call h5%Read("vy",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%v(2) = buffr
            call h5%Read("vz",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%v(3) = buffr
            call h5%Read("fx",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%f(1) = buffr
            call h5%Read("fy",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%f(2) = buffr
            call h5%Read("fz",buffr, offset=goff); markers(this%count_-chunk_size+1:this%count_)%f(3) = buffr
          end select
        end if

        ! Deallocate buffers
        deallocate(buffi8,buffi,buffr)

        ! Send markers to their mpiranks
        call this%Communicate()
      end do

      ! Free data
      deallocate(size_per_rank)
      call h5%Finalize

      ! Set unread variables to zero
      select type (markers=>this%p)
      class is (marker_obj)
        do n=1,this%count_
          markers(n)%pold  = 0.0_wp
          markers(n)%vold  = 0.0_wp
        end do
      end select

      ! Localize markers on the grid
      call this%Localize()

      return
    end subroutine marker_set_ReadH5HUT