RootClass Module



Contents


Derived Types

type, public :: Root_

Components

TypeVisibility AttributesNameInitial
type(FEMDomain_), public :: FEMDomain
real(kind=real64), public :: Thickness
real(kind=real64), public :: length
real(kind=real64), public :: width
real(kind=real64), public :: MaxThickness
real(kind=real64), public :: Maxlength
real(kind=real64), public :: Maxwidth
real(kind=real64), public :: center_bottom(3)
real(kind=real64), public :: center_top(3)
real(kind=real64), public :: radius_bottom(3)
real(kind=real64), public :: radius_top(3)
real(kind=real64), public :: outer_normal_bottom(3)
real(kind=real64), public :: outer_normal_top(3)
real(kind=real64), public :: rot_x =0.0d0
real(kind=real64), public :: rot_y =0.0d0
real(kind=real64), public :: rot_z =0.0d0
real(kind=real64), public :: disp_x =0.0d0
real(kind=real64), public :: disp_y =0.0d0
real(kind=real64), public :: disp_z =0.0d0
integer(kind=int32), public :: EdgeNodeID(4)
integer(kind=int32), public :: EdgeElemID(4)
real(kind=real64), public :: maxdiameter
real(kind=real64), public :: mindiameter
real(kind=real64), public :: minlength
integer(kind=int32), public, allocatable:: I_planeNodeID(:)
integer(kind=int32), public, allocatable:: I_planeElementID(:)
integer(kind=int32), public, allocatable:: II_planeNodeID(:)
integer(kind=int32), public, allocatable:: II_planeElementID(:)
integer(kind=int32), public :: A_PointNodeID
integer(kind=int32), public :: B_PointNodeID
integer(kind=int32), public :: A_PointElementID
integer(kind=int32), public :: B_PointElementID
integer(kind=int32), public :: xnum =10
integer(kind=int32), public :: ynum =10
integer(kind=int32), public :: znum =10
real(kind=real64), public, allocatable:: DryDensity(:)
real(kind=real64), public, allocatable:: WaterContent(:)
integer(kind=int32), public :: Division
type(Root_), public, pointer:: pRoot

Type-Bound Procedures

procedure, public :: Init => initRoot
procedure, public :: rotate => rotateRoot
procedure, public :: move => moveRoot
procedure, public, pass :: connectRootRoot
procedure, public, pass :: connectRootStem
generic, public :: connect => connectRootRoot, connectRootStem
procedure, public :: rescale => rescaleRoot
procedure, public :: resize => resizeRoot
procedure, public :: fix => fixRoot
procedure, public :: getCoordinate => getCoordinateRoot
procedure, public :: getVolume => getVolumeRoot
procedure, public :: getBiomass => getBiomassRoot
procedure, public :: gmsh => gmshRoot
procedure, public :: vtk => vtkRoot
procedure, public :: msh => mshRoot
procedure, public :: stl => stlRoot
procedure, public :: export => exportRoot

Functions

public function getCoordinateRoot(obj, nodetype) result(ret)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=*), intent(in) :: nodetype

Return Value real(kind=real64), allocatable, (:)

public function getVolumeRoot(obj) result(ret)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(in) :: obj

Return Value real(kind=real64)

public function getBiomassRoot(obj) result(ret)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(in) :: obj

Return Value real(kind=real64)


Subroutines

public subroutine initRoot(obj, config, regacy, Thickness, length, width, MaxThickness, Maxlength, MaxWidth, rotx, roty, rotz, location)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=*), intent(in), optional :: config
logical, intent(in), optional :: regacy
real(kind=real64), intent(in), optional :: Thickness
real(kind=real64), intent(in), optional :: length
real(kind=real64), intent(in), optional :: width
real(kind=real64), intent(in), optional :: MaxThickness
real(kind=real64), intent(in), optional :: Maxlength
real(kind=real64), intent(in), optional :: MaxWidth
real(kind=real64), intent(in), optional :: rotx
real(kind=real64), intent(in), optional :: roty
real(kind=real64), intent(in), optional :: rotz
real(kind=real64), intent(in), optional :: location(3)

public subroutine exportRoot(obj, FileName, RootID)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(in) :: obj
character(len=*), intent(in) :: FileName
integer(kind=int32), intent(inout), optional :: RootID

public recursive subroutine rotateRoot(obj, x, y, z, reset)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
real(kind=real64), intent(in), optional :: x
real(kind=real64), intent(in), optional :: y
real(kind=real64), intent(in), optional :: z
logical, intent(in), optional :: reset

public recursive subroutine moveRoot(obj, x, y, z, reset)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
real(kind=real64), intent(in), optional :: x
real(kind=real64), intent(in), optional :: y
real(kind=real64), intent(in), optional :: z
logical, intent(in), optional :: reset

public subroutine connectRootRoot(obj, direct, Root)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=2), intent(in) :: direct
class(Root_), intent(inout) :: Root

public subroutine connectRootStem(obj, direct, Stem)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=2), intent(in) :: direct
class(Stem_), intent(inout) :: Stem

public subroutine gmshRoot(obj, name)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=*), intent(in) :: name

public subroutine mshRoot(obj, name)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=*), intent(in) :: name

public subroutine vtkRoot(obj, name)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=*), intent(in) :: name

public subroutine stlRoot(obj, name)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout) :: obj
character(len=*), intent(in) :: name

public subroutine resizeRoot(obj, x, y, z)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout), optional :: obj
real(kind=real64), intent(in), optional :: x
real(kind=real64), intent(in), optional :: y
real(kind=real64), intent(in), optional :: z

public subroutine rescaleRoot(obj, x, y, z)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout), optional :: obj
real(kind=real64), intent(in), optional :: x
real(kind=real64), intent(in), optional :: y
real(kind=real64), intent(in), optional :: z

public subroutine fixRoot(obj, x, y, z)

Arguments

Type IntentOptional AttributesName
class(Root_), intent(inout), optional :: obj
real(kind=real64), intent(in), optional :: x
real(kind=real64), intent(in), optional :: y
real(kind=real64), intent(in), optional :: z