SELF_DomainDecomposition_t Module


Uses

  • module~~self_domaindecomposition_t~~UsesGraph module~self_domaindecomposition_t SELF_DomainDecomposition_t module~self_lagrange~3 SELF_Lagrange module~self_domaindecomposition_t->module~self_lagrange~3 module~self_supportroutines SELF_SupportRoutines module~self_domaindecomposition_t->module~self_supportroutines iso_c_binding iso_c_binding module~self_domaindecomposition_t->iso_c_binding module~self_constants SELF_Constants module~self_domaindecomposition_t->module~self_constants mpi mpi module~self_domaindecomposition_t->mpi module~self_lagrange~3->iso_c_binding module~self_lagrange~3->module~self_constants iso_fortran_env iso_fortran_env module~self_lagrange~3->iso_fortran_env module~self_lagrange_t SELF_Lagrange_t module~self_lagrange~3->module~self_lagrange_t module~self_supportroutines->module~self_constants module~self_supportroutines->iso_fortran_env module~self_constants->iso_c_binding module~self_constants->iso_fortran_env module~self_lagrange_t->module~self_supportroutines module~self_lagrange_t->iso_c_binding module~self_lagrange_t->module~self_constants module~self_lagrange_t->iso_fortran_env module~self_quadrature SELF_Quadrature module~self_lagrange_t->module~self_quadrature module~self_hdf5 SELF_HDF5 module~self_lagrange_t->module~self_hdf5 HDF5 HDF5 module~self_lagrange_t->HDF5 module~self_quadrature->module~self_constants module~self_quadrature->iso_fortran_env module~self_hdf5->module~self_constants module~self_hdf5->mpi module~self_hdf5->iso_fortran_env module~self_hdf5->HDF5

Used by

  • module~~self_domaindecomposition_t~~UsedByGraph module~self_domaindecomposition_t SELF_DomainDecomposition_t module~self_domaindecomposition SELF_DomainDecomposition module~self_domaindecomposition->module~self_domaindecomposition_t module~self_domaindecomposition~2 SELF_DomainDecomposition module~self_domaindecomposition~2->module~self_domaindecomposition_t module~self_mesh SELF_Mesh module~self_mesh->module~self_domaindecomposition module~self_mappedvector_3d_t SELF_MappedVector_3D_t module~self_mappedvector_3d_t->module~self_domaindecomposition module~self_mesh_3d~2 SELF_Mesh_3D module~self_mappedvector_3d_t->module~self_mesh_3d~2 module~self_geometry_3d SELF_Geometry_3D module~self_mappedvector_3d_t->module~self_geometry_3d module~self_mappedvector_2d_t SELF_MappedVector_2D_t module~self_mappedvector_2d_t->module~self_domaindecomposition module~self_mesh_2d SELF_Mesh_2D module~self_mappedvector_2d_t->module~self_mesh_2d module~self_geometry_2d SELF_Geometry_2D module~self_mappedvector_2d_t->module~self_geometry_2d module~self_mesh_3d_t SELF_Mesh_3D_t module~self_mesh_3d_t->module~self_domaindecomposition module~self_mesh_3d_t->module~self_mesh module~self_mappedscalar_2d_t SELF_MappedScalar_2D_t module~self_mappedscalar_2d_t->module~self_domaindecomposition module~self_mappedscalar_2d_t->module~self_mesh_2d module~self_mappedscalar_2d_t->module~self_geometry_2d module~self_mesh_2d_t SELF_Mesh_2D_t module~self_mesh_2d_t->module~self_domaindecomposition module~self_mesh_2d_t->module~self_mesh module~self_mappedscalar_3d_t SELF_MappedScalar_3D_t module~self_mappedscalar_3d_t->module~self_domaindecomposition module~self_mappedscalar_3d_t->module~self_mesh_3d~2 module~self_mappedscalar_3d_t->module~self_geometry_3d module~self_nulldgmodel3d_t self_NullDGModel3D_t module~self_nulldgmodel3d_t->module~self_mesh module~self_dgmodel3d SELF_DGModel3D module~self_nulldgmodel3d_t->module~self_dgmodel3d module~self_burgers1d_t self_Burgers1D_t module~self_burgers1d_t->module~self_mesh module~self_dgmodel1d~2 SELF_DGModel1D module~self_burgers1d_t->module~self_dgmodel1d~2 module~self_mappedscalar_3d SELF_MappedScalar_3D module~self_mappedscalar_3d->module~self_mappedscalar_3d_t module~self_mappedvector_3d~2 SELF_MappedVector_3D module~self_mappedvector_3d~2->module~self_mappedvector_3d_t module~self_mappedvector_2d~2 SELF_MappedVector_2D module~self_mappedvector_2d~2->module~self_mappedvector_2d_t module~self_linearshallowwater2d_t self_LinearShallowWater2D_t module~self_linearshallowwater2d_t->module~self_mesh module~self_dgmodel2d SELF_DGModel2D module~self_linearshallowwater2d_t->module~self_dgmodel2d module~self_mappedscalar_2d SELF_MappedScalar_2D module~self_mappedscalar_2d->module~self_mappedscalar_2d_t module~self_mesh_3d SELF_Mesh_3D module~self_mesh_3d->module~self_mesh_3d_t module~self_nulldgmodel2d_t self_NullDGModel2D_t module~self_nulldgmodel2d_t->module~self_mesh module~self_nulldgmodel2d_t->module~self_dgmodel2d module~self_mappedvector_2d SELF_MappedVector_2D module~self_mappedvector_2d->module~self_mappedvector_2d_t module~self_mesh_2d->module~self_mesh_2d_t module~self_mappedscalar_3d~2 SELF_MappedScalar_3D module~self_mappedscalar_3d~2->module~self_mappedscalar_3d_t module~self_lineareuler2d_t self_LinearEuler2D_t module~self_lineareuler2d_t->module~self_mesh module~self_lineareuler2d_t->module~self_dgmodel2d module~self_advection_diffusion_3d_t self_advection_diffusion_3d_t module~self_advection_diffusion_3d_t->module~self_mesh module~self_advection_diffusion_3d_t->module~self_dgmodel3d module~self_mesh_3d~2->module~self_mesh_3d_t module~self_advection_diffusion_1d_t self_advection_diffusion_1d_t module~self_advection_diffusion_1d_t->module~self_mesh module~self_advection_diffusion_1d_t->module~self_dgmodel1d~2 module~self_mappedvector_3d SELF_MappedVector_3D module~self_mappedvector_3d->module~self_mappedvector_3d_t module~self_mappedscalar_2d~2 SELF_MappedScalar_2D module~self_mappedscalar_2d~2->module~self_mappedscalar_2d_t module~self_nulldgmodel1d_t self_NullDGModel1D_t module~self_nulldgmodel1d_t->module~self_mesh module~self_nulldgmodel1d_t->module~self_dgmodel1d~2 module~self_advection_diffusion_2d_t self_advection_diffusion_2d_t module~self_advection_diffusion_2d_t->module~self_mesh module~self_advection_diffusion_2d_t->module~self_dgmodel2d module~self_mesh_1d SELF_Mesh_1D module~self_mesh_1d->module~self_mesh module~self_mesh_2d~2 SELF_Mesh_2D module~self_mesh_2d~2->module~self_mesh_2d_t module~self_nulldgmodel2d~2 self_NullDGModel2D module~self_nulldgmodel2d~2->module~self_nulldgmodel2d_t module~self_advection_diffusion_2d~2 self_advection_diffusion_2d module~self_advection_diffusion_2d~2->module~self_advection_diffusion_2d_t module~self_burgers1d self_Burgers1D module~self_burgers1d->module~self_burgers1d_t module~self_advection_diffusion_2d self_advection_diffusion_2d module~self_advection_diffusion_2d->module~self_advection_diffusion_2d_t module~self_dgmodel1d SELF_DGModel1D module~self_dgmodel1d->module~self_mesh_1d module~self_dgmodel1d_t SELF_DGModel1D_t module~self_dgmodel1d->module~self_dgmodel1d_t module~self_mappedscalar_1d SELF_MappedScalar_1D module~self_dgmodel1d->module~self_mappedscalar_1d module~self_nulldgmodel3d self_NullDGModel3D module~self_nulldgmodel3d->module~self_nulldgmodel3d_t module~self_linearshallowwater2d self_LinearShallowWater2D module~self_linearshallowwater2d->module~self_linearshallowwater2d_t module~self_nulldgmodel1d~2 self_NullDGModel1D module~self_nulldgmodel1d~2->module~self_nulldgmodel1d_t module~self_burgers1d~2 self_Burgers1D module~self_burgers1d~2->module~self_burgers1d_t module~self_lineareuler2d~2 self_LinearEuler2D module~self_lineareuler2d~2->module~self_lineareuler2d_t module~self_geometry_3d->module~self_mesh_3d~2 module~self_advection_diffusion_1d self_advection_diffusion_1d module~self_advection_diffusion_1d->module~self_advection_diffusion_1d_t module~self_advection_diffusion_1d->module~self_dgmodel1d~2 module~self_mappedscalar_1d_t SELF_MappedScalar_1D_t module~self_mappedscalar_1d_t->module~self_mesh_1d module~self_geometry_1d SELF_Geometry_1D module~self_mappedscalar_1d_t->module~self_geometry_1d module~self_nulldgmodel1d self_NullDGModel1D module~self_nulldgmodel1d->module~self_nulldgmodel1d_t module~self_linearshallowwater2d~2 self_LinearShallowWater2D module~self_linearshallowwater2d~2->module~self_linearshallowwater2d_t module~self_nulldgmodel2d self_NullDGModel2D module~self_nulldgmodel2d->module~self_nulldgmodel2d_t module~self_dgmodel2d_t SELF_DGModel2D_t module~self_dgmodel2d_t->module~self_mappedvector_2d module~self_dgmodel2d_t->module~self_mesh_2d module~self_dgmodel2d_t->module~self_mappedscalar_2d~2 module~self_dgmodel2d_t->module~self_geometry_2d module~self_advection_diffusion_3d~2 self_advection_diffusion_3d module~self_advection_diffusion_3d~2->module~self_advection_diffusion_3d_t module~self_dgmodel1d_t->module~self_mesh_1d module~self_dgmodel1d_t->module~self_mappedscalar_1d module~self_dgmodel3d_t SELF_DGModel3D_t module~self_dgmodel3d_t->module~self_mappedvector_3d~2 module~self_dgmodel3d_t->module~self_mappedscalar_3d~2 module~self_dgmodel3d_t->module~self_mesh_3d~2 module~self_dgmodel3d_t->module~self_geometry_3d module~self_nulldgmodel3d~2 self_NullDGModel3D module~self_nulldgmodel3d~2->module~self_nulldgmodel3d_t module~self_advection_diffusion_3d self_advection_diffusion_3d module~self_advection_diffusion_3d->module~self_advection_diffusion_3d_t module~self_geometry_1d->module~self_mesh_1d module~self_geometry_2d->module~self_mesh_2d module~self_lineareuler2d self_LinearEuler2D module~self_lineareuler2d->module~self_lineareuler2d_t module~self_advection_diffusion_1d~2 self_advection_diffusion_1d module~self_advection_diffusion_1d~2->module~self_advection_diffusion_1d_t module~self_mappedscalar_1d->module~self_mappedscalar_1d_t module~self_dgmodel2d~2 SELF_DGModel2D module~self_dgmodel2d~2->module~self_dgmodel2d_t module~self_mappedscalar_1d~2 SELF_MappedScalar_1D module~self_mappedscalar_1d~2->module~self_mappedscalar_1d_t module~self_dgmodel2d->module~self_dgmodel2d_t module~self_dgmodel1d~2->module~self_dgmodel1d_t module~self_dgmodel3d~2 SELF_DGModel3D module~self_dgmodel3d~2->module~self_dgmodel3d_t module~self_dgmodel3d->module~self_dgmodel3d_t

Contents


Derived Types

type, public :: DomainDecomposition_t

Components

TypeVisibilityAttributesNameInitial
integer, public, pointer, dimension(:):: elemToRank
logical, public :: initialized =.false.
integer, public :: maxMsg
integer, public :: mpiComm
logical, public :: mpiEnabled =.false.
integer, public :: mpiPrec
integer, public :: msgCount
integer, public :: nElem
integer, public :: nRanks
integer, public, pointer, dimension(:):: offSetElem
integer, public :: rankId
integer, public, allocatable:: requests(:)
integer, public, allocatable:: stats(:,:)

Type-Bound Procedures

procedure, public :: FinalizeMPIExchangeAsync
procedure, public :: Free => Free_DomainDecomposition_t
procedure, public :: GenerateDecomposition => GenerateDecomposition_DomainDecomposition_t
procedure, public :: Init => Init_DomainDecomposition_t
procedure, public :: SetElemToRank => SetElemToRank_DomainDecomposition_t

Subroutines

public subroutine DomainDecomp(nElems, nDomains, offsetElem)

Arguments

TypeIntentOptionalAttributesName
integer, intent(in) :: nElems
integer, intent(in) :: nDomains
integer, intent(out) :: offsetElem(0:nDomains)

public subroutine ElemToRank(nDomains, offsetElem, elemID, domain)

Arguments

TypeIntentOptionalAttributesName
integer, intent(in) :: nDomains
integer, intent(in) :: offsetElem(0:nDomains)
integer, intent(in) :: elemID
integer, intent(out) :: domain

public subroutine FinalizeMPIExchangeAsync(mpiHandler)

Arguments

TypeIntentOptionalAttributesName
class(DomainDecomposition_t), intent(inout) :: mpiHandler

public subroutine Free_DomainDecomposition_t(this)

Arguments

TypeIntentOptionalAttributesName
class(DomainDecomposition_t), intent(inout) :: this

public subroutine GenerateDecomposition_DomainDecomposition_t(this, nGlobalElem, maxMsg)

Arguments

TypeIntentOptionalAttributesName
class(DomainDecomposition_t), intent(inout) :: this
integer, intent(in) :: nGlobalElem
integer, intent(in) :: maxMsg

public subroutine Init_DomainDecomposition_t(this)

Arguments

TypeIntentOptionalAttributesName
class(DomainDecomposition_t), intent(inout) :: this

public subroutine SetElemToRank_DomainDecomposition_t(this, nElem)

Arguments

TypeIntentOptionalAttributesName
class(DomainDecomposition_t), intent(inout) :: this
integer, intent(in) :: nElem