SELF_Vector_3D_t Module



Contents


Derived Types

type, public, extends(SELF_DataObj) :: Vector3D_t

Components

TypeVisibilityAttributesNameInitial
integer, public :: M
integer, public :: N
real(kind=prec), public, pointer, contiguous, dimension(:,:,:,:,:,:):: avgBoundary
real(kind=prec), public, pointer, contiguous, dimension(:,:,:,:,:,:):: boundary
real(kind=prec), public, pointer, contiguous, dimension(:,:,:,:,:):: boundaryNormal
type(EquationParser), public, allocatable:: eqn(:)
real(kind=prec), public, pointer, contiguous, dimension(:,:,:,:,:,:):: extBoundary
real(kind=prec), public, pointer, contiguous, dimension(:,:,:,:,:,:):: interior
type(Lagrange), public, pointer:: interp
type(Metadata), public, allocatable:: meta(:)
integer, public :: nElem
integer, public :: nVar

Type-Bound Procedures

procedure, public :: AverageSides => AverageSides_Vector3D_t
procedure, public :: BoundaryInterp => BoundaryInterp_Vector3D_t
generic, public :: Curl => Curl_Vector3D_t
procedure, private :: Curl_Vector3D_t
generic, public :: Divergence => Divergence_Vector3D_t
procedure, private :: Divergence_Vector3D_t
procedure, public :: Free => Free_Vector3D_t
generic, public :: Gradient => Gradient_Vector3D_t
procedure, private :: Gradient_Vector3D_t
generic, public :: GridInterp => GridInterp_Vector3D_t
procedure, private :: GridInterp_Vector3D_t
procedure, public :: Init => Init_Vector3D_t
procedure, public :: SetDescription => SetDescription_DataObj
generic, public :: SetEquation => SetEquation_DataObj, SetEquation_Vector3D_t
procedure, private :: SetEquation_Vector3D_t
procedure, public :: SetName => SetName_DataObj
procedure, public :: SetUnits => SetUnits_DataObj
procedure, public :: UpdateDevice => UpdateDevice_Vector3D_t
procedure, public :: UpdateHost => UpdateHost_Vector3D_t
generic, public :: WriteHDF5 => WriteHDF5_MPI_Vector3D_t, WriteHDF5_Vector3D_t
procedure, private :: WriteHDF5_MPI_Vector3D_t
procedure, private :: WriteHDF5_Vector3D_t

Subroutines

public subroutine AverageSides_Vector3D_t(this)

Arguments

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

public subroutine BoundaryInterp_Vector3D_t(this)

Arguments

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

public subroutine Curl_Vector3D_t(this, curlf)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(in) :: this
real(kind=prec), intent(out) :: curlf(1:this%N+1,1:this%N+1,1:this%N+1,1:this%nelem,1:this%nvar,1:3)

public subroutine Divergence_Vector3D_t(this, df)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(in) :: this
real(kind=prec), intent(out) :: df(1:this%N+1,1:this%N+1,1:this%N+1,1:this%nelem,1:this%nvar)

public subroutine Free_Vector3D_t(this)

Arguments

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

public subroutine Gradient_Vector3D_t(this, df)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(in) :: this
real(kind=prec), intent(out) :: df(1:this%N+1,1:this%N+1,1:this%N+1,1:this%nelem,1:this%nvar,1:3,1:3)

public subroutine GridInterp_Vector3D_t(this, f)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(in) :: this
real(kind=prec), intent(out) :: f(1:this%M+1,1:this%M+1,1:this%M+1,1:this%nelem,1:this%nvar,1:3)

(Output) Array of function values, defined on the target grid

public subroutine Init_Vector3D_t(this, interp, nVar, nElem)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(out) :: this
type(Lagrange), intent(in), target:: interp
integer, intent(in) :: nVar
integer, intent(in) :: nElem

public subroutine SetEquation_Vector3D_t(this, idir, ivar, eqnChar)

Sets the equation parser for the idir direction and ivar-th variable

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(inout) :: this
integer, intent(in) :: idir
integer, intent(in) :: ivar
character, intent(in) :: eqnChar

public subroutine UpdateDevice_Vector3D_t(this)

Arguments

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

public subroutine UpdateHost_Vector3D_t(this)

Arguments

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

public subroutine WriteHDF5_MPI_Vector3D_t(this, fileId, group, elemoffset, nglobalelem)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(in) :: this
integer(kind=HID_T), intent(in) :: fileId
character, intent(in) :: group
integer, intent(in) :: elemoffset
integer, intent(in) :: nglobalelem

public subroutine WriteHDF5_Vector3D_t(this, fileId, group)

Arguments

TypeIntentOptionalAttributesName
class(Vector3D_t), intent(in) :: this
integer(kind=HID_T), intent(in) :: fileId
character, intent(in) :: group