axis_obj_Init Subroutine

private pure subroutine axis_obj_Init(this, lo, hi, ngc)

Initialize axis.

Type Bound

axis_obj

Arguments

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

A axis object

integer, intent(in) :: lo

Array lower bound

integer, intent(in) :: hi

Array higher bound

integer, intent(in) :: ngc

Number of ghost cells


Called by

proc~~axis_obj_init~~CalledByGraph proc~axis_obj_init axis_obj%axis_obj_Init proc~block_obj_partition block_obj%block_obj_Partition proc~block_obj_partition->proc~axis_obj_init proc~block_obj_updategridghostcells block_obj%block_obj_UpdateGridGhostCells proc~block_obj_partition->proc~block_obj_updategridghostcells proc~block_obj_setupuniformgrid block_obj%block_obj_SetupUniformGrid proc~block_obj_setupuniformgrid->proc~axis_obj_init proc~block_obj_setupuniformgrid->proc~block_obj_updategridghostcells proc~block_obj_updateextents block_obj%block_obj_UpdateExtents proc~block_obj_updateextents->proc~axis_obj_init proc~block_obj_init2 block_obj%block_obj_Init2 proc~block_obj_init2->proc~block_obj_setupuniformgrid proc~block_obj_updategridghostcells->proc~block_obj_updateextents proc~cdifs_obj_preparesolverblock cdifs_obj_PrepareSolverBlock proc~cdifs_obj_preparesolverblock->proc~block_obj_partition none~initialize~10 block_obj%Initialize proc~cdifs_obj_preparesolverblock->none~initialize~10 proc~collision_obj_setupcollisionblock collision_obj%collision_obj_SetupCollisionBlock proc~collision_obj_setupcollisionblock->proc~block_obj_setupuniformgrid proc~collision_obj_setupcollisionblock->none~initialize~10 proc~collision_obj_setupcollisionblock2 collision_obj%collision_obj_SetupCollisionBlock2 proc~collision_obj_setupcollisionblock2->proc~block_obj_setupuniformgrid proc~collision_obj_setupcollisionblock2->proc~block_obj_updategridghostcells proc~collision_obj_setupcollisionblock2->none~initialize~10 proc~grans_obj_preparesolverblock grans_obj_PrepareSolverBlock proc~grans_obj_preparesolverblock->proc~block_obj_partition proc~grans_obj_preparesolverblock->none~initialize~10 proc~setupcaseblock SetUpCaseBlock proc~setupcaseblock->proc~block_obj_partition proc~setupcaseblock->proc~block_obj_setupuniformgrid proc~setupcaseblock->none~initialize~10 proc~setupcaseblock~10 SetUpCaseBlock proc~setupcaseblock~10->proc~block_obj_partition proc~setupcaseblock~10->proc~block_obj_setupuniformgrid proc~setupcaseblock~10->none~initialize~10 proc~setupcaseblock~11 SetUpCaseBlock proc~setupcaseblock~11->proc~block_obj_partition proc~setupcaseblock~11->none~initialize~10 proc~setupcaseblock~12 SetUpCaseBlock proc~setupcaseblock~12->proc~block_obj_partition proc~setupcaseblock~12->proc~block_obj_setupuniformgrid proc~setupcaseblock~12->none~initialize~10 proc~setupcaseblock~13 SetUpCaseBlock proc~setupcaseblock~13->proc~block_obj_partition proc~setupcaseblock~13->proc~block_obj_setupuniformgrid proc~setupcaseblock~13->none~initialize~10 proc~setupcaseblock~14 SetUpCaseBlock proc~setupcaseblock~14->proc~block_obj_partition proc~setupcaseblock~14->proc~block_obj_setupuniformgrid proc~setupcaseblock~14->none~initialize~10 proc~setupcaseblock~2 SetUpCaseBlock proc~setupcaseblock~2->proc~block_obj_partition proc~setupcaseblock~2->none~initialize~10 proc~setupcaseblock~3 SetUpCaseBlock proc~setupcaseblock~3->proc~block_obj_partition proc~setupcaseblock~3->none~initialize~10 proc~setupcaseblock~4 SetUpCaseBlock proc~setupcaseblock~4->proc~block_obj_partition proc~setupcaseblock~4->proc~block_obj_setupuniformgrid proc~setupcaseblock~4->none~initialize~10 proc~setupcaseblock~5 SetUpCaseBlock proc~setupcaseblock~5->proc~block_obj_partition proc~setupcaseblock~5->proc~block_obj_setupuniformgrid proc~setupcaseblock~5->none~initialize~10 proc~setupcaseblock~6 SetUpCaseBlock proc~setupcaseblock~6->proc~block_obj_partition proc~setupcaseblock~6->proc~block_obj_setupuniformgrid proc~setupcaseblock~6->none~initialize~10 proc~setupcaseblock~7 SetUpCaseBlock proc~setupcaseblock~7->proc~block_obj_partition proc~setupcaseblock~7->proc~block_obj_setupuniformgrid proc~setupcaseblock~7->none~initialize~10 proc~setupcaseblock~8 SetUpCaseBlock proc~setupcaseblock~8->proc~block_obj_partition proc~setupcaseblock~8->proc~block_obj_setupuniformgrid proc~setupcaseblock~8->none~initialize~10 proc~setupcaseblock~9 SetUpCaseBlock proc~setupcaseblock~9->proc~block_obj_partition proc~setupcaseblock~9->proc~block_obj_setupuniformgrid proc~setupcaseblock~9->none~initialize~10 none~initialize~10->proc~block_obj_init2 proc~block_obj_read block_obj%block_obj_Read proc~block_obj_read->proc~block_obj_updategridghostcells proc~cdifs_obj_preparesolver cdifs_obj_PrepareSolver proc~cdifs_obj_preparesolver->proc~cdifs_obj_preparesolverblock proc~cdifs_obj_preparesolver->proc~collision_obj_setupcollisionblock proc~grans_obj_preparesolver grans_obj_PrepareSolver proc~grans_obj_preparesolver->proc~grans_obj_preparesolverblock proc~grans_obj_preparesolvercollision grans_obj_PrepareSolverCollision proc~grans_obj_preparesolver->proc~grans_obj_preparesolvercollision proc~grans_obj_preparesolvercollision->proc~collision_obj_setupcollisionblock program~main main program~main->proc~setupcaseblock program~main~10 main program~main~10->proc~setupcaseblock~10 program~main~11 main program~main~11->proc~setupcaseblock~11 program~main~12 main program~main~12->proc~setupcaseblock~12 program~main~13 main program~main~13->proc~setupcaseblock~13 program~main~14 main program~main~14->proc~setupcaseblock~14 program~main~2 main program~main~2->proc~setupcaseblock~2 program~main~3 main program~main~3->proc~setupcaseblock~3 program~main~4 main program~main~4->proc~setupcaseblock~4 program~main~5 main program~main~5->proc~setupcaseblock~5 program~main~6 main program~main~6->proc~setupcaseblock~6 program~main~7 main program~main~7->proc~setupcaseblock~7 program~main~8 main program~main~8->proc~setupcaseblock~8 program~main~9 main program~main~9->proc~setupcaseblock~9 interface~cdifs_obj_preparesolver cdifs_obj%cdifs_obj_PrepareSolver interface~cdifs_obj_preparesolver->proc~cdifs_obj_preparesolver interface~grans_obj_preparesolver grans_obj%grans_obj_PrepareSolver interface~grans_obj_preparesolver->proc~grans_obj_preparesolver

Source Code

    pure subroutine axis_obj_Init(this,lo,hi,ngc)
      !> Initialize axis.
      class(axis_obj), intent(inout) :: this                                   !! A axis object
      integer,         intent(in)    :: lo                                     !! Array lower bound
      integer,         intent(in)    :: hi                                     !! Array higher bound
      integer,         intent(in)    :: ngc                                    !! Number of ghost cells

      this%lo  = lo
      this%hi  = hi
      this%ngc = ngc

      ! Allocate arrays
      if (associated(this%x  )) deallocate(this%x  )
      if (associated(this%xm )) deallocate(this%xm )
      if (associated(this%dxm)) deallocate(this%dxm)

      allocate(this%x  (lo-ngc:hi+1+ngc)); this%x   = 0.0_wp
      allocate(this%xm (lo-ngc:hi  +ngc)); this%xm  = 0.0_wp
      allocate(this%dxm(lo-ngc:hi  +ngc)); this%dxm = 0.0_wp

      return
    end subroutine axis_obj_Init