2019-02-02 17:40:21 +05:30
|
|
|
|
2019-01-24 19:23:23 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
!> @author Christoph Koords, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
!> @author Martin Diehl, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
!> @brief Sets up the mesh for the solvers MSC.Marc,FEM, Abaqus and the spectral solver
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
module mesh_base
|
|
|
|
|
|
|
|
use, intrinsic :: iso_c_binding
|
|
|
|
use prec, only: &
|
|
|
|
pStringLen, &
|
|
|
|
pReal, &
|
|
|
|
pInt
|
|
|
|
use element, only: &
|
|
|
|
tElement
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
!---------------------------------------------------------------------------------------------------
|
|
|
|
!> Properties of a the whole mesh (consisting of one type of elements)
|
|
|
|
!---------------------------------------------------------------------------------------------------
|
|
|
|
type, public :: tMesh
|
|
|
|
type(tElement) :: &
|
|
|
|
elem
|
|
|
|
real(pReal), dimension(:,:), allocatable, public :: &
|
|
|
|
ipVolume, & !< volume associated with each IP (initially!)
|
|
|
|
node0, & !< node x,y,z coordinates (initially)
|
|
|
|
node !< node x,y,z coordinates (deformed)
|
|
|
|
integer(pInt), dimension(:,:), allocatable, public :: &
|
|
|
|
cellnodeParent !< cellnode's parent element ID, cellnode's intra-element ID
|
2019-02-01 16:54:23 +05:30
|
|
|
character(pStringLen) :: type = "n/a"
|
2019-01-24 19:23:23 +05:30
|
|
|
integer(pInt) :: &
|
|
|
|
Nnodes, & !< total number of nodes in mesh
|
|
|
|
Nelems = -1_pInt, &
|
|
|
|
elemType, &
|
|
|
|
Ncells, &
|
|
|
|
nIPneighbors, &
|
|
|
|
NcellNodes, &
|
|
|
|
maxElemsPerNode
|
|
|
|
integer(pInt), dimension(:), allocatable, public :: &
|
|
|
|
homogenizationAt, &
|
|
|
|
microstructureAt
|
|
|
|
integer(pInt), dimension(:,:), allocatable, public :: &
|
|
|
|
connectivity
|
2019-02-01 16:54:23 +05:30
|
|
|
contains
|
|
|
|
procedure, pass(self) :: tMesh_base_init
|
2019-02-02 16:16:38 +05:30
|
|
|
procedure :: setNelems => tMesh_base_setNelems ! not needed once we compute the cells from the connectivity
|
2019-02-01 16:54:23 +05:30
|
|
|
generic, public :: init => tMesh_base_init
|
2019-01-24 19:23:23 +05:30
|
|
|
end type tMesh
|
|
|
|
|
2019-02-01 16:54:23 +05:30
|
|
|
contains
|
|
|
|
subroutine tMesh_base_init(self,meshType,elemType,nodes)
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
class(tMesh) :: self
|
|
|
|
character(len=*), intent(in) :: meshType
|
|
|
|
integer(pInt), intent(in) :: elemType
|
|
|
|
real(pReal), dimension(:,:), intent(in) :: nodes
|
|
|
|
|
2019-02-01 17:13:14 +05:30
|
|
|
write(6,'(/,a)') ' <<<+- mesh_base_init -+>>>'
|
|
|
|
|
|
|
|
write(6,*)' mesh type ',meshType
|
|
|
|
write(6,*)' # node ',size(nodes,2)
|
|
|
|
|
2019-02-01 16:54:23 +05:30
|
|
|
self%type = meshType
|
|
|
|
call self%elem%init(elemType)
|
|
|
|
self%node0 = nodes
|
2019-02-02 17:40:21 +05:30
|
|
|
self%nNodes = size(nodes,2)
|
2019-02-01 17:13:14 +05:30
|
|
|
|
2019-02-01 16:54:23 +05:30
|
|
|
end subroutine tMesh_base_init
|
|
|
|
|
2019-02-02 16:16:38 +05:30
|
|
|
|
|
|
|
subroutine tMesh_base_setNelems(self,Nelems)
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
class(tMesh) :: self
|
|
|
|
integer(pInt), intent(in) :: Nelems
|
|
|
|
|
|
|
|
self%Nelems = Nelems
|
|
|
|
|
|
|
|
end subroutine tMesh_base_setNelems
|
|
|
|
|
2019-01-24 19:23:23 +05:30
|
|
|
end module mesh_base
|