2007-03-20 19:25:22 +05:30
!##############################################################
2007-03-21 21:48:33 +05:30
MODULE mesh
2007-03-20 19:25:22 +05:30
!##############################################################
2007-03-21 21:48:33 +05:30
use prec , only : pReal , pInt
implicit none
! ---------------------------
2007-03-22 20:18:58 +05:30
! _Nelems : total number of elements in mesh
2007-04-25 13:03:24 +05:30
! _NcpElems : total number of CP elements in mesh
2007-03-22 20:18:58 +05:30
! _Nnodes : total number of nodes in mesh
2007-04-04 14:17:34 +05:30
! _maxNnodes : max number of nodes in any CP element
2007-04-25 13:03:24 +05:30
! _maxNips : max number of IPs in any CP element
! _maxNipNeighbors : max number of IP neighbors in any CP element
2007-04-04 14:17:34 +05:30
! _maxNsharedElems : max number of CP elements sharing a node
2007-03-22 20:18:58 +05:30
!
2008-03-25 18:22:27 +05:30
! _element : FEid, type(internal representation), material, texture, node indices
2007-03-26 14:20:57 +05:30
! _node : x,y,z coordinates (initially!)
! _sharedElem : entryCount and list of elements containing node
2007-03-22 20:18:58 +05:30
!
2007-03-27 18:23:31 +05:30
! _mapFEtoCPelem : [sorted FEid, corresponding CPid]
! _mapFEtoCPnode : [sorted FEid, corresponding CPid]
2007-03-22 20:18:58 +05:30
!
! MISSING: these definitions should actually reside in the
! FE-solver specific part (different for MARC/ABAQUS)..!
! Hence, I suggest to prefix with "FE_"
!
2007-10-24 14:30:42 +05:30
! _mapElementtype : map MARC/ABAQUS elemtype to 1...maxN
2007-03-22 20:18:58 +05:30
!
2007-03-26 14:20:57 +05:30
! _Nnodes : # nodes in a specific type of element
! _Nips : # IPs in a specific type of element
! _NipNeighbors : # IP neighbors in a specific type of element
! _ipNeighbor : +x,-x,+y,-y,+z,-z list of intra-element IPs and
2007-03-22 20:18:58 +05:30
! (negative) neighbor faces per own IP in a specific type of element
2009-01-16 23:06:37 +05:30
! _NfaceNodes : # nodes per face in a specific type of element
2007-03-26 14:20:57 +05:30
! _nodeOnFace : list of node indices on each face of a specific type of element
2009-03-30 20:20:19 +05:30
! _nodesAtIP : map IP index to two node indices in a specific type of element
2007-03-26 14:20:57 +05:30
! _ipNeighborhood : 6 or less neighboring IPs as [element_num, IP_index]
2009-01-16 23:06:37 +05:30
! _NsubNodes : # subnodes required to fully define all IP volumes
2007-03-22 20:18:58 +05:30
! order is +x,-x,+y,-y,+z,-z but meaning strongly depends on Elemtype
2007-03-21 21:48:33 +05:30
! ---------------------------
2007-10-23 18:39:46 +05:30
integer ( pInt ) mesh_Nelems , mesh_NcpElems , mesh_NelemSets , mesh_maxNelemInSet
2009-01-16 20:59:57 +05:30
integer ( pInt ) mesh_Nnodes , mesh_maxNnodes , mesh_maxNips , mesh_maxNipNeighbors , mesh_maxNsharedElems , mesh_maxNsubNodes
2007-10-24 14:30:42 +05:30
integer ( pInt ) , dimension ( 2 ) :: mesh_maxValStateVar = 0_pInt
2009-01-16 20:59:57 +05:30
character ( len = 64 ) , dimension ( : ) , allocatable :: mesh_nameElemSet
integer ( pInt ) , dimension ( : , : ) , allocatable :: mesh_mapElemSet
integer ( pInt ) , dimension ( : , : ) , allocatable , target :: mesh_mapFEtoCPelem , mesh_mapFEtoCPnode
integer ( pInt ) , dimension ( : , : ) , allocatable :: mesh_element , mesh_sharedElem
2009-01-16 23:06:37 +05:30
integer ( pInt ) , dimension ( : , : , : , : ) , allocatable :: mesh_ipNeighborhood
2009-01-20 00:12:31 +05:30
2009-01-16 23:06:37 +05:30
real ( pReal ) , dimension ( : , : , : ) , allocatable :: mesh_subNodeCoord ! coordinates of subnodes per element
real ( pReal ) , dimension ( : , : ) , allocatable :: mesh_ipVolume ! volume associated with IP
real ( pReal ) , dimension ( : , : , : ) , allocatable :: mesh_ipArea ! area of interface to neighboring IP
real ( pReal ) , dimension ( : , : , : , : ) , allocatable :: mesh_ipAreaNormal ! area normal of interface to neighboring IP
2009-01-16 20:59:57 +05:30
real ( pReal ) , allocatable :: mesh_node ( : , : )
2007-03-21 21:48:33 +05:30
2007-09-28 20:26:26 +05:30
integer ( pInt ) :: hypoelasticTableStyle = 0
2007-10-23 18:39:46 +05:30
integer ( pInt ) :: initialcondTableStyle = 0
2008-06-17 14:41:54 +05:30
integer ( pInt ) , parameter :: FE_Nelemtypes = 6
2007-03-22 20:18:58 +05:30
integer ( pInt ) , parameter :: FE_maxNnodes = 8
2009-01-16 23:06:37 +05:30
integer ( pInt ) , parameter :: FE_maxNsubNodes = 19
2007-10-12 19:18:29 +05:30
integer ( pInt ) , parameter :: FE_maxNips = 9
2009-01-16 23:06:37 +05:30
integer ( pInt ) , parameter :: FE_maxNipNeighbors = 6
2009-01-16 20:59:57 +05:30
integer ( pInt ) , parameter :: FE_NipFaceNodes = 4
2007-03-26 14:20:57 +05:30
integer ( pInt ) , dimension ( FE_Nelemtypes ) , parameter :: FE_Nnodes = &
2007-04-25 13:03:24 +05:30
( / 8 , & ! element 7
2007-10-12 19:18:29 +05:30
4 , & ! element 134
4 , & ! element 11
2008-06-17 14:41:54 +05:30
8 , & ! element 27
4 , & ! element 157
6 & ! element 136
2007-03-28 18:28:51 +05:30
/ )
2007-03-26 14:20:57 +05:30
integer ( pInt ) , dimension ( FE_Nelemtypes ) , parameter :: FE_Nips = &
2007-04-25 13:03:24 +05:30
( / 8 , & ! element 7
2007-10-12 19:18:29 +05:30
1 , & ! element 134
4 , & ! element 11
2008-06-17 14:41:54 +05:30
9 , & ! element 27
4 , & ! element 157
6 & ! element 136
2007-04-25 13:03:24 +05:30
/ )
2009-01-16 23:06:37 +05:30
integer ( pInt ) , dimension ( FE_Nelemtypes ) , parameter :: FE_NipNeighbors = &
( / 6 , & ! element 7
4 , & ! element 134
4 , & ! element 11
4 , & ! element 27
6 , & ! element 157
6 & ! element 136
/ )
integer ( pInt ) , dimension ( FE_Nelemtypes ) , parameter :: FE_NsubNodes = &
( / 19 , & ! element 7
2009-01-20 00:12:31 +05:30
0 , & ! element 134
0 , & ! element 11
0 , & ! element 27
0 , & ! element 157
0 & ! element 136
2009-01-16 23:06:37 +05:30
/ )
2009-01-16 20:59:57 +05:30
integer ( pInt ) , dimension ( FE_maxNipNeighbors , FE_Nelemtypes ) , parameter :: FE_NfaceNodes = &
2007-03-22 20:18:58 +05:30
reshape ( ( / &
2007-04-25 13:03:24 +05:30
4 , 4 , 4 , 4 , 4 , 4 , & ! element 7
2007-10-12 19:18:29 +05:30
3 , 3 , 3 , 3 , 0 , 0 , & ! element 134
2 , 2 , 2 , 2 , 0 , 0 , & ! element 11
2008-06-17 14:41:54 +05:30
3 , 3 , 3 , 3 , 0 , 0 , & ! element 27
3 , 3 , 3 , 3 , 0 , 0 , & ! element 157
3 , 4 , 4 , 4 , 3 , 0 & ! element 136
2009-01-16 20:59:57 +05:30
/ ) , ( / FE_maxNipNeighbors , FE_Nelemtypes / ) )
2009-03-30 20:20:19 +05:30
integer ( pInt ) , dimension ( 2 , FE_maxNips , FE_Nelemtypes ) , parameter :: FE_nodesAtIP = &
2007-03-22 20:18:58 +05:30
reshape ( ( / &
2009-03-30 20:20:19 +05:30
1 , 1 , 2 , 2 , 4 , 4 , 3 , 3 , 5 , 5 , 6 , 6 , 8 , 8 , 7 , 7 , 0 , 0 , & ! element 7
1 , 1 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 134
1 , 1 , 2 , 2 , 4 , 4 , 3 , 3 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 11
1 , 1 , 5 , 5 , 2 , 2 , 8 , 8 , 0 , 0 , 6 , 6 , 4 , 4 , 7 , 7 , 3 , 3 , & ! element 27
1 , 1 , 2 , 2 , 3 , 3 , 4 , 4 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 157
1 , 1 , 2 , 2 , 3 , 3 , 4 , 4 , 5 , 5 , 6 , 6 , 0 , 0 , 0 , 0 , 0 , 0 & ! element 136
/ ) , ( / 2 , FE_maxNips , FE_Nelemtypes / ) )
2009-01-16 20:59:57 +05:30
integer ( pInt ) , dimension ( FE_NipFaceNodes , FE_maxNipNeighbors , FE_Nelemtypes ) , parameter :: FE_nodeOnFace = &
2007-03-22 20:18:58 +05:30
reshape ( ( / &
2007-04-25 13:03:24 +05:30
1 , 2 , 3 , 4 , & ! element 7
2 , 1 , 5 , 6 , &
3 , 2 , 6 , 7 , &
2008-06-17 14:41:54 +05:30
4 , 3 , 7 , 8 , &
2007-04-25 13:03:24 +05:30
4 , 1 , 5 , 8 , &
8 , 7 , 6 , 5 , &
1 , 2 , 3 , 0 , & ! element 134
1 , 4 , 2 , 0 , &
2 , 3 , 4 , 0 , &
1 , 3 , 4 , 0 , &
0 , 0 , 0 , 0 , &
2007-10-12 19:18:29 +05:30
0 , 0 , 0 , 0 , &
1 , 2 , 0 , 0 , & ! element 11
2 , 3 , 0 , 0 , &
3 , 4 , 0 , 0 , &
4 , 1 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
1 , 5 , 2 , 0 , & ! element 27
2 , 6 , 3 , 0 , &
3 , 7 , 4 , 0 , &
4 , 8 , 1 , 0 , &
0 , 0 , 0 , 0 , &
2008-06-17 14:41:54 +05:30
0 , 0 , 0 , 0 , &
1 , 2 , 3 , 0 , & ! element 157
1 , 4 , 2 , 0 , &
2 , 3 , 4 , 0 , &
1 , 3 , 4 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
1 , 2 , 3 , 0 , & ! element 136
1 , 4 , 5 , 2 , &
2 , 5 , 6 , 3 , &
1 , 3 , 6 , 4 , &
4 , 6 , 5 , 0 , &
2007-04-25 13:03:24 +05:30
0 , 0 , 0 , 0 &
2009-01-16 20:59:57 +05:30
/ ) , ( / FE_NipFaceNodes , FE_maxNipNeighbors , FE_Nelemtypes / ) )
integer ( pInt ) , dimension ( FE_maxNipNeighbors , FE_maxNips , FE_Nelemtypes ) , parameter :: FE_ipNeighbor = &
2007-03-26 14:20:57 +05:30
reshape ( ( / &
2007-04-25 13:03:24 +05:30
2 , - 5 , 3 , - 2 , 5 , - 1 , & ! element 7
- 3 , 1 , 4 , - 2 , 6 , - 1 , &
4 , - 5 , - 4 , 1 , 7 , - 1 , &
- 3 , 3 , - 4 , 2 , 8 , - 1 , &
6 , - 5 , 7 , - 2 , - 6 , 1 , &
- 3 , 5 , 8 , - 2 , - 6 , 2 , &
8 , - 5 , - 4 , 5 , - 6 , 3 , &
- 3 , 7 , - 4 , 6 , - 6 , 4 , &
2007-10-12 19:18:29 +05:30
0 , 0 , 0 , 0 , 0 , 0 , &
2007-04-25 13:03:24 +05:30
- 1 , - 2 , - 3 , - 4 , 0 , 0 , & ! element 134
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
2007-10-12 19:18:29 +05:30
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
2 , - 4 , 3 , - 1 , 0 , 0 , & ! element 11
- 2 , 1 , 4 , - 1 , 0 , 0 , &
4 , - 4 , - 3 , 1 , 0 , 0 , &
- 2 , 3 , - 3 , 2 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
2 , - 4 , 4 , - 1 , 0 , 0 , & ! element 27
3 , 1 , 5 , - 1 , 0 , 0 , &
- 2 , 2 , 6 , - 1 , 0 , 0 , &
5 , - 4 , 7 , 1 , 0 , 0 , &
6 , 4 , 8 , 2 , 0 , 0 , &
- 2 , 5 , 9 , 3 , 0 , 0 , &
8 , - 4 , - 3 , 4 , 0 , 0 , &
9 , 7 , - 3 , 5 , 0 , 0 , &
2008-06-17 14:41:54 +05:30
- 2 , 8 , - 3 , 6 , 0 , 0 , &
2 , - 4 , 3 , - 2 , 4 , - 1 , & ! element 157
3 , - 2 , 1 , - 3 , 4 , - 1 , &
1 , - 3 , 2 , - 4 , 4 , - 1 , &
1 , - 3 , 2 , - 4 , 3 , - 2 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
2 , - 4 , 3 , - 2 , 4 , - 1 , & ! element 136
- 3 , 1 , 3 , - 2 , 5 , - 1 , &
2 , - 4 , - 3 , 1 , 6 , - 1 , &
5 , - 4 , 6 , - 2 , - 5 , 1 , &
- 3 , 4 , 6 , - 2 , - 5 , 2 , &
5 , - 4 , - 3 , 4 , - 5 , 3 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 &
2009-01-16 20:59:57 +05:30
/ ) , ( / FE_maxNipNeighbors , FE_maxNips , FE_Nelemtypes / ) )
2009-01-16 23:06:37 +05:30
integer ( pInt ) , dimension ( FE_maxNnodes , FE_maxNsubNodes , FE_Nelemtypes ) , parameter :: FE_subNodeParent = &
reshape ( ( / &
1 , 2 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 7
2 , 3 , 0 , 0 , 0 , 0 , 0 , 0 , &
3 , 4 , 0 , 0 , 0 , 0 , 0 , 0 , &
2009-01-20 00:12:31 +05:30
4 , 1 , 0 , 0 , 0 , 0 , 0 , 0 , &
2009-01-16 23:06:37 +05:30
1 , 5 , 0 , 0 , 0 , 0 , 0 , 0 , &
2 , 6 , 0 , 0 , 0 , 0 , 0 , 0 , &
3 , 7 , 0 , 0 , 0 , 0 , 0 , 0 , &
4 , 8 , 0 , 0 , 0 , 0 , 0 , 0 , &
5 , 6 , 0 , 0 , 0 , 0 , 0 , 0 , &
6 , 7 , 0 , 0 , 0 , 0 , 0 , 0 , &
7 , 8 , 0 , 0 , 0 , 0 , 0 , 0 , &
8 , 5 , 0 , 0 , 0 , 0 , 0 , 0 , &
1 , 2 , 3 , 4 , 0 , 0 , 0 , 0 , &
1 , 2 , 6 , 5 , 0 , 0 , 0 , 0 , &
2 , 3 , 7 , 6 , 0 , 0 , 0 , 0 , &
3 , 4 , 8 , 7 , 0 , 0 , 0 , 0 , &
1 , 4 , 8 , 5 , 0 , 0 , 0 , 0 , &
5 , 6 , 7 , 8 , 0 , 0 , 0 , 0 , &
1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 134
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 11
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 27
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 157
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & ! element 136
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 &
/ ) , ( / FE_maxNnodes , FE_maxNsubNodes , FE_Nelemtypes / ) )
integer ( pInt ) , dimension ( FE_NipFaceNodes , FE_maxNipNeighbors , FE_maxNips , FE_Nelemtypes ) , parameter :: FE_subNodeOnIPFace = &
reshape ( ( / &
9 , 21 , 27 , 22 , & ! element 7
1 , 13 , 25 , 12 , &
12 , 25 , 27 , 21 , &
1 , 9 , 22 , 13 , &
2009-01-20 00:12:31 +05:30
13 , 22 , 27 , 25 , &
2009-01-16 23:06:37 +05:30
1 , 12 , 21 , 9 , &
2 , 10 , 23 , 14 , & !
9 , 22 , 27 , 21 , &
10 , 21 , 27 , 23 , &
2 , 14 , 22 , 9 , &
14 , 23 , 27 , 22 , &
2 , 9 , 21 , 10 , &
11 , 24 , 27 , 21 , & !
4 , 12 , 25 , 16 , &
4 , 16 , 24 , 11 , &
12 , 21 , 27 , 25 , &
16 , 25 , 27 , 24 , &
4 , 11 , 21 , 12 , &
3 , 15 , 23 , 10 , & !
11 , 21 , 27 , 24 , &
3 , 11 , 24 , 15 , &
10 , 23 , 27 , 21 , &
15 , 24 , 27 , 23 , &
3 , 10 , 21 , 11 , &
17 , 22 , 27 , 26 , & !
5 , 20 , 25 , 13 , &
20 , 26 , 27 , 25 , &
5 , 13 , 22 , 17 , &
5 , 17 , 26 , 20 , &
13 , 25 , 27 , 22 , &
6 , 14 , 23 , 18 , & !
2009-01-20 00:12:31 +05:30
17 , 26 , 27 , 22 , &
2009-01-16 23:06:37 +05:30
18 , 23 , 27 , 26 , &
6 , 17 , 22 , 14 , &
6 , 18 , 26 , 17 , &
14 , 22 , 27 , 23 , &
19 , 26 , 27 , 24 , & !
8 , 16 , 25 , 20 , &
8 , 19 , 24 , 16 , &
20 , 25 , 27 , 26 , &
8 , 20 , 26 , 19 , &
16 , 24 , 27 , 25 , &
7 , 18 , 23 , 15 , & !
19 , 24 , 27 , 26 , &
7 , 15 , 24 , 19 , &
18 , 26 , 27 , 23 , &
7 , 19 , 26 , 18 , &
15 , 23 , 27 , 24 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
2009-01-20 00:12:31 +05:30
1 , 1 , 3 , 2 , & ! element 134
1 , 1 , 2 , 4 , &
2 , 2 , 3 , 4 , &
1 , 1 , 4 , 3 , &
2009-01-16 23:06:37 +05:30
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & ! element 11
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & ! element 27
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & ! element 157
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & ! element 136
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , & !
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 , &
0 , 0 , 0 , 0 &
/ ) , ( / FE_NipFaceNodes , FE_maxNipNeighbors , FE_maxNips , FE_Nelemtypes / ) )
2007-03-22 20:18:58 +05:30
2007-03-21 21:48:33 +05:30
CONTAINS
! ---------------------------
! subroutine mesh_init()
! function mesh_FEtoCPelement(FEid)
2007-03-26 14:20:57 +05:30
! function mesh_build_ipNeighorhood()
2007-03-21 21:48:33 +05:30
! ---------------------------
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
!***********************************************************
! initialization
!***********************************************************
2007-04-10 16:52:53 +05:30
SUBROUTINE mesh_init ( )
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
use prec , only : pInt
2009-01-16 23:06:37 +05:30
use IO , only : IO_error , IO_open_InputFile
2009-03-04 17:18:54 +05:30
use FEsolving , only : parallelExecution
2007-04-10 16:52:53 +05:30
implicit none
integer ( pInt ) , parameter :: fileUnit = 222
2009-01-20 00:12:31 +05:30
2009-01-16 20:59:57 +05:30
mesh_Nelems = 0_pInt
mesh_NcpElems = 0_pInt
mesh_Nnodes = 0_pInt
mesh_maxNips = 0_pInt
2009-01-16 23:06:37 +05:30
mesh_maxNnodes = 0_pInt
mesh_maxNipNeighbors = 0_pInt
mesh_maxNsharedElems = 0_pInt
mesh_maxNsubNodes = 0_pInt
2009-01-16 20:59:57 +05:30
mesh_NelemSets = 0_pInt
mesh_maxNelemInSet = 0_pInt
2007-04-25 13:03:24 +05:30
2009-01-20 00:12:31 +05:30
2007-10-24 14:30:42 +05:30
! call to various subroutines to parse the stuff from the input file...
2009-01-16 23:06:37 +05:30
if ( IO_open_inputFile ( fileUnit ) ) then
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
call mesh_get_meshDimensions ( fileUnit )
2007-04-25 13:03:24 +05:30
call mesh_build_nodeMapping ( fileUnit )
call mesh_build_elemMapping ( fileUnit )
2007-10-23 18:39:46 +05:30
call mesh_build_elemSetMapping ( fileUnit )
2007-04-10 16:52:53 +05:30
call mesh_get_nodeElemDimensions ( fileUnit )
call mesh_build_nodes ( fileUnit )
call mesh_build_elements ( fileUnit )
call mesh_build_sharedElems ( fileUnit )
2009-01-16 23:06:37 +05:30
call mesh_build_ipNeighborhood ( )
call mesh_build_subNodeCoords ( )
call mesh_build_ipVolumes ( )
call mesh_build_ipAreas ( )
2007-10-24 14:30:42 +05:30
call mesh_tell_statistics ( )
2007-04-10 16:52:53 +05:30
close ( fileUnit )
2009-03-04 17:18:54 +05:30
parallelExecution = ( mesh_Nelems == mesh_NcpElems ) ! plus potential killer from non-local constitutive
2007-04-10 16:52:53 +05:30
else
2007-12-11 19:53:21 +05:30
call IO_error ( 100 ) ! cannot open input file
2007-04-10 16:52:53 +05:30
endif
2007-04-25 13:03:24 +05:30
END SUBROUTINE
2007-03-26 14:20:57 +05:30
2007-04-10 16:52:53 +05:30
2009-01-20 00:12:31 +05:30
2008-06-17 02:19:48 +05:30
!***********************************************************
! mapping of FE element types to internal representation
!***********************************************************
FUNCTION FE_mapElemtype ( what )
2009-01-20 00:12:31 +05:30
2008-06-17 02:19:48 +05:30
implicit none
character ( len = * ) , intent ( in ) :: what
integer ( pInt ) FE_mapElemtype
select case ( what )
2008-06-17 14:41:54 +05:30
case ( '7' , 'C3D8' )
FE_mapElemtype = 1 ! Three-dimensional Arbitrarily Distorted Brick
2008-06-17 02:19:48 +05:30
case ( '134' )
2008-06-17 14:41:54 +05:30
FE_mapElemtype = 2 ! Three-dimensional Four-node Tetrahedron
2008-06-17 02:19:48 +05:30
case ( '11' )
2008-06-17 14:41:54 +05:30
FE_mapElemtype = 3 ! Arbitrary Quadrilateral Plane-strain
2008-06-17 02:19:48 +05:30
case ( '27' )
2008-06-17 14:41:54 +05:30
FE_mapElemtype = 4 ! Plane Strain, Eight-node Distorted Quadrilateral
case ( '157' )
FE_mapElemtype = 5 ! Three-dimensional, Low-order, Tetrahedron, Herrmann Formulations
case ( '136' )
FE_mapElemtype = 6 ! Three-dimensional Arbitrarily Distorted Pentahedral
case default
FE_mapElemtype = 0 ! unknown element --> should raise an error upstream..!
2008-06-17 02:19:48 +05:30
end select
2009-01-20 00:12:31 +05:30
2008-06-17 02:19:48 +05:30
END FUNCTION
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
!***********************************************************
2007-04-10 16:52:53 +05:30
! FE to CP id mapping by binary search thru lookup array
2007-03-26 14:20:57 +05:30
!
2007-04-10 16:52:53 +05:30
! valid questions are 'elem', 'node'
!***********************************************************
FUNCTION mesh_FEasCP ( what , id )
use prec , only : pInt
use IO , only : IO_lc
implicit none
character ( len = * ) , intent ( in ) :: what
integer ( pInt ) , intent ( in ) :: id
integer ( pInt ) , dimension ( : , : ) , pointer :: lookupMap
integer ( pInt ) mesh_FEasCP , lower , upper , center
mesh_FEasCP = 0_pInt
select case ( IO_lc ( what ( 1 : 4 ) ) )
case ( 'elem' )
lookupMap = > mesh_mapFEtoCPelem
case ( 'node' )
lookupMap = > mesh_mapFEtoCPnode
case default
return
end select
lower = 1_pInt
upper = size ( lookupMap , 2 )
! check at bounds QUESTION is it valid to extend bounds by 1 and just do binary search w/o init check at bounds?
if ( lookupMap ( 1 , lower ) == id ) then
mesh_FEasCP = lookupMap ( 2 , lower )
return
elseif ( lookupMap ( 1 , upper ) == id ) then
mesh_FEasCP = lookupMap ( 2 , upper )
return
endif
! binary search in between bounds
do while ( upper - lower > 1 )
center = ( lower + upper ) / 2
if ( lookupMap ( 1 , center ) < id ) then
lower = center
elseif ( lookupMap ( 1 , center ) > id ) then
upper = center
else
mesh_FEasCP = lookupMap ( 2 , center )
exit
end if
end do
return
END FUNCTION
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
!***********************************************************
2007-04-10 16:52:53 +05:30
! find face-matching element of same type
!!***********************************************************
2007-03-26 14:20:57 +05:30
FUNCTION mesh_faceMatch ( face , elem )
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
use prec , only : pInt
implicit none
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
integer ( pInt ) face , elem
integer ( pInt ) mesh_faceMatch
2008-03-25 18:22:27 +05:30
integer ( pInt ) , dimension ( FE_NfaceNodes ( face , mesh_element ( 2 , elem ) ) ) :: nodeMap
2007-04-24 12:19:13 +05:30
integer ( pInt ) minN , NsharedElems , lonelyNode , faceNode , i , n , t
2007-04-25 13:03:24 +05:30
2007-04-04 14:17:34 +05:30
minN = mesh_maxNsharedElems + 1 ! init to worst case
2007-04-25 13:03:24 +05:30
mesh_faceMatch = 0_pInt ! intialize to "no match found"
2008-03-25 18:22:27 +05:30
t = mesh_element ( 2 , elem ) ! figure elemType
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
do faceNode = 1 , FE_NfaceNodes ( face , t ) ! loop over nodes on face
2007-04-04 14:17:34 +05:30
nodeMap ( faceNode ) = mesh_FEasCP ( 'node' , mesh_element ( 4 + FE_nodeOnFace ( faceNode , face , t ) , elem ) ) ! CP id of face node
2007-04-25 13:03:24 +05:30
NsharedElems = mesh_sharedElem ( 1 , nodeMap ( faceNode ) ) ! figure # shared elements for this node
2007-03-26 14:20:57 +05:30
if ( NsharedElems < minN ) then
minN = NsharedElems ! remember min # shared elems
lonelyNode = faceNode ! remember most lonely node
endif
2007-04-25 13:03:24 +05:30
end do
2007-03-26 14:20:57 +05:30
candidate : do i = 1 , minN ! iterate over lonelyNode's shared elements
2007-04-25 13:03:24 +05:30
mesh_faceMatch = mesh_sharedElem ( 1 + i , nodeMap ( lonelyNode ) ) ! present candidate elem
2007-03-26 14:20:57 +05:30
if ( mesh_faceMatch == elem ) then ! my own element ?
mesh_faceMatch = 0_pInt ! disregard
cycle candidate
endif
2007-04-25 13:03:24 +05:30
do faceNode = 1 , FE_NfaceNodes ( face , t ) ! check remaining face nodes to match
if ( faceNode == lonelyNode ) cycle ! disregard lonely node (matches anyway)
2007-04-04 14:17:34 +05:30
n = nodeMap ( faceNode )
if ( all ( mesh_sharedElem ( 2 : 1 + mesh_sharedElem ( 1 , n ) , n ) / = mesh_faceMatch ) ) then ! no ref to candidate elem?
2007-04-25 13:03:24 +05:30
mesh_faceMatch = 0_pInt ! set to "no match" (so far)
2007-04-04 14:17:34 +05:30
cycle candidate ! next candidate elem
endif
2007-04-25 13:03:24 +05:30
end do
2007-04-04 14:17:34 +05:30
exit ! surviving candidate
2007-03-26 14:20:57 +05:30
end do candidate
2007-04-25 13:03:24 +05:30
2007-03-26 14:20:57 +05:30
return
2007-04-25 13:03:24 +05:30
2007-03-26 14:20:57 +05:30
END FUNCTION
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
!********************************************************************
! get count of elements, nodes, and cp elements in mesh
! for subsequent array allocations
!
! assign globals:
! _Nelems, _Nnodes, _NcpElems
!********************************************************************
SUBROUTINE mesh_get_meshDimensions ( unit )
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
use prec , only : pInt
2007-04-10 16:52:53 +05:30
use IO
2007-03-26 14:20:57 +05:30
implicit none
2009-01-20 00:12:31 +05:30
2007-10-24 20:54:49 +05:30
integer ( pInt ) unit , i , pos ( 41 )
2007-04-10 16:52:53 +05:30
character * 300 line
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 20 )
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
select case ( IO_lc ( IO_StringValue ( line , pos , 1 ) ) )
2007-09-28 19:46:03 +05:30
case ( 'table' )
2007-10-23 18:39:46 +05:30
if ( pos ( 1 ) == 6 ) then
initialcondTableStyle = IO_IntValue ( line , pos , 4 )
hypoelasticTableStyle = IO_IntValue ( line , pos , 5 )
endif
2007-04-10 16:52:53 +05:30
case ( 'sizing' )
mesh_Nelems = IO_IntValue ( line , pos , 3 )
mesh_Nnodes = IO_IntValue ( line , pos , 4 )
2007-10-23 18:39:46 +05:30
case ( 'define' )
select case ( IO_lc ( IO_StringValue ( line , pos , 2 ) ) )
case ( 'element' ) ! Count the number of encountered element sets
mesh_NelemSets = mesh_NelemSets + 1
mesh_maxNelemInSet = max ( mesh_maxNelemInSet , IO_countContinousIntValues ( unit ) )
end select
2007-04-10 16:52:53 +05:30
case ( 'hypoelastic' )
2007-10-23 18:39:46 +05:30
do i = 1 , 3 + hypoelasticTableStyle ! Skip 3 or 4 lines
2007-04-10 16:52:53 +05:30
read ( unit , 610 , END = 620 ) line
end do
2007-10-23 18:39:46 +05:30
mesh_NcpElems = mesh_NcpElems + IO_countContinousIntValues ( unit )
2007-04-10 16:52:53 +05:30
end select
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
end do
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
620 return
2007-03-26 14:20:57 +05:30
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-03-26 14:20:57 +05:30
2008-01-10 22:42:33 +05:30
!!********************************************************************
2007-04-10 16:52:53 +05:30
! get maximum count of nodes, IPs, IP neighbors, and shared elements
! for subsequent array allocations
2007-03-27 18:23:31 +05:30
!
2007-04-10 16:52:53 +05:30
! assign globals:
! _maxNnodes, _maxNips, _maxNipNeighbors, _maxNsharedElems
!********************************************************************
SUBROUTINE mesh_get_nodeElemDimensions ( unit )
2008-01-10 22:42:33 +05:30
2007-03-21 21:48:33 +05:30
use prec , only : pInt
2007-04-10 16:52:53 +05:30
use IO
2007-03-21 21:48:33 +05:30
implicit none
2008-01-10 22:42:33 +05:30
2007-04-10 16:52:53 +05:30
integer ( pInt ) , dimension ( mesh_Nnodes ) :: node_count
2008-01-10 22:42:33 +05:30
integer ( pInt ) , dimension ( : ) , allocatable :: node_seen
2007-04-10 16:52:53 +05:30
integer ( pInt ) unit , i , j , n , t , e
integer ( pInt ) , dimension ( 133 ) :: pos
character * 300 line
2008-01-10 22:42:33 +05:30
2007-04-10 16:52:53 +05:30
610 FORMAT ( A300 )
2008-01-10 22:42:33 +05:30
2007-04-10 16:52:53 +05:30
node_count = 0_pInt
2008-01-10 22:42:33 +05:30
allocate ( node_seen ( maxval ( FE_Nnodes ) ) )
2007-04-10 16:52:53 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 630 ) line
pos = IO_stringPos ( line , 1 )
if ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'connectivity' ) then
read ( unit , 610 , END = 630 ) line ! Garbage line
2007-09-28 20:26:26 +05:30
do i = 1 , mesh_Nelems ! read all elements
read ( unit , 610 , END = 630 ) line
pos = IO_stringPos ( line , 66 ) ! limit to 64 nodes max (plus ID, type)
e = mesh_FEasCP ( 'elem' , IO_intValue ( line , pos , 1 ) )
if ( e / = 0 ) then
2008-03-25 18:22:27 +05:30
t = FE_mapElemtype ( IO_StringValue ( line , pos , 2 ) )
2007-09-28 20:26:26 +05:30
mesh_maxNnodes = max ( mesh_maxNnodes , FE_Nnodes ( t ) )
mesh_maxNips = max ( mesh_maxNips , FE_Nips ( t ) )
2009-01-16 23:06:37 +05:30
mesh_maxNipNeighbors = max ( mesh_maxNipNeighbors , FE_NipNeighbors ( t ) )
2009-01-20 00:12:31 +05:30
2009-01-16 23:06:37 +05:30
mesh_maxNsubNodes = max ( mesh_maxNsubNodes , FE_NsubNodes ( t ) )
2009-01-20 00:12:31 +05:30
2008-01-10 22:42:33 +05:30
node_seen = 0_pInt
2007-09-28 20:26:26 +05:30
do j = 1 , FE_Nnodes ( t )
n = mesh_FEasCP ( 'node' , IO_IntValue ( line , pos , j + 2 ) )
2008-01-10 22:42:33 +05:30
if ( all ( node_seen / = n ) ) then
node_count ( n ) = node_count ( n ) + 1
2008-06-17 14:41:54 +05:30
end if
2008-01-10 22:42:33 +05:30
node_seen ( j ) = n
2007-09-28 20:26:26 +05:30
end do
2007-04-10 16:52:53 +05:30
end if
end do
2007-09-28 20:26:26 +05:30
exit
2007-03-21 21:48:33 +05:30
end if
end do
2008-01-10 22:42:33 +05:30
2007-04-10 16:52:53 +05:30
630 mesh_maxNsharedElems = maxval ( node_count )
2008-01-10 22:42:33 +05:30
2007-03-21 21:48:33 +05:30
return
2007-04-10 16:52:53 +05:30
END SUBROUTINE
2007-03-21 21:48:33 +05:30
2007-10-23 18:39:46 +05:30
!********************************************************************
! Build element set mapping
!
2008-03-25 18:22:27 +05:30
! allocate globals: mesh_nameElemSet, mesh_mapElemSet
2007-10-23 18:39:46 +05:30
!********************************************************************
SUBROUTINE mesh_build_elemSetMapping ( unit )
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
use prec , only : pInt
use IO
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
implicit none
2009-01-20 00:12:31 +05:30
2007-10-24 20:54:49 +05:30
integer unit , elem_set
2007-10-23 18:39:46 +05:30
character * 300 line
integer ( pInt ) , dimension ( 9 ) :: pos ! count plus 4 entities on a line
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
allocate ( mesh_nameElemSet ( mesh_NelemSets ) )
allocate ( mesh_mapElemSet ( 1 + mesh_maxNelemInSet , mesh_NelemSets ) ) ; mesh_mapElemSet = 0_pInt
elem_set = 0_pInt
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 4 )
if ( ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'define' ) . and . &
( IO_lc ( IO_stringValue ( line , pos , 2 ) ) == 'element' ) ) then
elem_set = elem_set + 1
mesh_nameElemSet ( elem_set ) = IO_stringValue ( line , pos , 4 )
mesh_mapElemSet ( : , elem_set ) = IO_continousIntValues ( unit , mesh_maxNelemInSet , mesh_nameElemSet , mesh_mapElemSet , mesh_NelemSets )
end if
end do
2009-01-20 00:12:31 +05:30
2007-10-23 18:39:46 +05:30
620 return
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
!********************************************************************
! Build node mapping from FEM to CP
!
2007-04-10 16:52:53 +05:30
! allocate globals:
! _mapFEtoCPnode
2007-04-25 13:03:24 +05:30
!********************************************************************
SUBROUTINE mesh_build_nodeMapping ( unit )
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
use prec , only : pInt
use math , only : qsort
use IO
implicit none
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
integer ( pInt ) , dimension ( mesh_Nnodes ) :: node_count
integer ( pInt ) unit , i
integer ( pInt ) , dimension ( 133 ) :: pos
character * 300 line
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
allocate ( mesh_mapFEtoCPnode ( 2 , mesh_Nnodes ) ) ; mesh_mapFEtoCPnode = 0_pInt
node_count ( : ) = 0_pInt
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 1 )
if ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'coordinates' ) then
read ( unit , 610 , END = 620 ) line ! skip crap line
do i = 1 , mesh_Nnodes
read ( unit , 610 , END = 620 ) line
mesh_mapFEtoCPnode ( 1 , i ) = IO_fixedIntValue ( line , ( / 0 , 10 / ) , 1 )
mesh_mapFEtoCPnode ( 2 , i ) = i
end do
exit
end if
end do
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
620 call qsort ( mesh_mapFEtoCPnode , 1 , size ( mesh_mapFEtoCPnode , 2 ) )
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
return
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
!********************************************************************
! Build element mapping from FEM to CP
!
! allocate globals:
! _mapFEtoCPelem
!********************************************************************
SUBROUTINE mesh_build_elemMapping ( unit )
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
use prec , only : pInt
use math , only : qsort
use IO
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
implicit none
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
integer unit , i , CP_elem
character * 300 line
integer ( pInt ) , dimension ( 3 ) :: pos
integer ( pInt ) , dimension ( 1 + mesh_NcpElems ) :: contInts
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
allocate ( mesh_mapFEtoCPelem ( 2 , mesh_NcpElems ) ) ; mesh_mapFEtoCPelem = 0_pInt
CP_elem = 0_pInt
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 1 )
if ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'hypoelastic' ) then
2007-09-28 19:46:03 +05:30
do i = 1 , 3 + hypoelasticTableStyle ! skip three (or four if new table style!) lines
2007-04-10 16:52:53 +05:30
read ( unit , 610 , END = 620 ) line
end do
2007-10-23 18:39:46 +05:30
contInts = IO_continousIntValues ( unit , mesh_NcpElems , mesh_nameElemSet , mesh_mapElemSet , mesh_NelemSets )
do i = 1 , contInts ( 1 )
CP_elem = CP_elem + 1
2007-04-10 16:52:53 +05:30
mesh_mapFEtoCPelem ( 1 , CP_elem ) = contInts ( 1 + i )
mesh_mapFEtoCPelem ( 2 , CP_elem ) = CP_elem
2007-10-23 18:39:46 +05:30
enddo
2007-04-10 16:52:53 +05:30
end if
end do
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
620 call qsort ( mesh_mapFEtoCPelem , 1 , size ( mesh_mapFEtoCPelem , 2 ) ) ! should be mesh_NcpElems
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
return
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
!********************************************************************
2007-04-10 16:52:53 +05:30
! store x,y,z coordinates of all nodes in mesh
!
! allocate globals:
! _node
2007-04-25 13:03:24 +05:30
!********************************************************************
SUBROUTINE mesh_build_nodes ( unit )
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
use prec , only : pInt
use IO
implicit none
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
integer unit , i , j , m
integer ( pInt ) , dimension ( 3 ) :: pos
integer ( pInt ) , dimension ( 5 ) , parameter :: node_ends = ( / 0 , 10 , 30 , 50 , 70 / )
character * 300 line
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
allocate ( mesh_node ( 3 , mesh_Nnodes ) )
mesh_node ( : , : ) = 0_pInt
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 1 )
if ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'coordinates' ) then
read ( unit , 610 , END = 620 ) line ! skip crap line
do i = 1 , mesh_Nnodes
read ( unit , 610 , END = 620 ) line
2007-10-23 18:39:46 +05:30
m = mesh_FEasCP ( 'node' , IO_fixedIntValue ( line , node_ends , 1 ) )
2007-04-25 13:03:24 +05:30
do j = 1 , 3
mesh_node ( j , m ) = IO_fixedNoEFloatValue ( line , node_ends , j + 1 )
end do
end do
exit
end if
end do
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
620 return
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
!********************************************************************
! store FEid, type, mat, tex, and node list per element
2007-04-10 16:52:53 +05:30
!
2007-04-25 13:03:24 +05:30
! allocate globals:
! _element
!********************************************************************
SUBROUTINE mesh_build_elements ( unit )
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
use prec , only : pInt
use IO
implicit none
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
integer unit , i , j , sv , val , CP_elem
integer ( pInt ) , dimension ( 133 ) :: pos
integer ( pInt ) , dimension ( 1 + mesh_NcpElems ) :: contInts
character * 300 line
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
allocate ( mesh_element ( 4 + mesh_maxNnodes , mesh_NcpElems ) ) ; mesh_element = 0_pInt
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
rewind ( unit )
2007-04-25 13:03:24 +05:30
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 2 )
if ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'connectivity' ) then
read ( unit , 610 , END = 620 ) line ! Garbage line
do i = 1 , mesh_Nelems
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 66 ) ! limit to 64 nodes max (plus ID, type)
CP_elem = mesh_FEasCP ( 'elem' , IO_intValue ( line , pos , 1 ) )
if ( CP_elem / = 0 ) then ! disregard non CP elems
2008-03-25 18:22:27 +05:30
mesh_element ( 1 , CP_elem ) = IO_IntValue ( line , pos , 1 ) ! FE id
mesh_element ( 2 , CP_elem ) = FE_mapElemtype ( IO_StringValue ( line , pos , 2 ) ) ! elem type
do j = 1 , FE_Nnodes ( mesh_element ( 2 , CP_elem ) )
2007-04-25 13:03:24 +05:30
mesh_element ( j + 4 , CP_elem ) = IO_IntValue ( line , pos , j + 2 ) ! copy FE ids of nodes
end do
end if
end do
exit
endif
enddo
rewind ( unit ) ! just in case "initial state" apears before "connectivity"
2007-10-23 18:39:46 +05:30
read ( unit , 610 , END = 620 ) line
do
2007-04-25 13:03:24 +05:30
pos = IO_stringPos ( line , 2 )
if ( ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'initial' ) . and . &
( IO_lc ( IO_stringValue ( line , pos , 2 ) ) == 'state' ) ) then
2007-10-23 18:39:46 +05:30
if ( initialcondTableStyle == 2 ) read ( unit , 610 , END = 620 ) line ! read extra line for new style
read ( unit , 610 , END = 620 ) line ! read line with index of state var
pos = IO_stringPos ( line , 1 )
sv = IO_IntValue ( line , pos , 1 ) ! figure state variable index
if ( ( sv == 2 ) . or . ( sv == 3 ) ) then ! only state vars 2 and 3 of interest
read ( unit , 610 , END = 620 ) line ! read line with value of state var
2007-04-25 13:03:24 +05:30
pos = IO_stringPos ( line , 1 )
2007-10-23 18:39:46 +05:30
do while ( scan ( IO_stringValue ( line , pos , 1 ) , '+-' , back = . true . ) > 1 ) ! is noEfloat value?
val = NINT ( IO_fixedNoEFloatValue ( line , ( / 0 , 20 / ) , 1 ) ) ! state var's value
2007-10-24 14:30:42 +05:30
mesh_maxValStateVar ( sv - 1 ) = max ( val , mesh_maxValStateVar ( sv - 1 ) ) ! remember max val of material and texture index
2007-10-23 18:39:46 +05:30
if ( initialcondTableStyle == 2 ) then
read ( unit , 610 , END = 620 ) line ! read extra line
read ( unit , 610 , END = 620 ) line ! read extra line
endif
contInts = IO_continousIntValues ( unit , mesh_Nelems , mesh_nameElemSet , mesh_mapElemSet , mesh_NelemSets ) ! get affected elements
do i = 1 , contInts ( 1 )
CP_elem = mesh_FEasCP ( 'elem' , contInts ( 1 + i ) )
mesh_element ( 1 + sv , CP_elem ) = val
enddo
if ( initialcondTableStyle == 0 ) read ( unit , 610 , END = 620 ) line ! ignore IP range for old table style
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 1 )
enddo
endif
else
read ( unit , 610 , END = 620 ) line
2007-04-25 13:03:24 +05:30
endif
enddo
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
620 return
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-04-25 13:03:24 +05:30
2007-04-10 16:52:53 +05:30
!********************************************************************
! build list of elements shared by each node in mesh
!
! allocate globals:
! _sharedElem
!********************************************************************
SUBROUTINE mesh_build_sharedElems ( unit )
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
use prec , only : pInt
use IO
implicit none
2009-01-20 00:12:31 +05:30
2008-06-17 14:41:54 +05:30
integer ( pint ) unit , i , j , n , e
2007-04-10 16:52:53 +05:30
integer ( pInt ) , dimension ( 133 ) :: pos
2008-06-17 02:19:48 +05:30
integer ( pInt ) , dimension ( : ) , allocatable :: node_seen
2007-04-10 16:52:53 +05:30
character * 300 line
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
610 FORMAT ( A300 )
2009-01-20 00:12:31 +05:30
2008-06-17 02:19:48 +05:30
allocate ( node_seen ( maxval ( FE_Nnodes ) ) )
2007-04-10 16:52:53 +05:30
allocate ( mesh_sharedElem ( 1 + mesh_maxNsharedElems , mesh_Nnodes ) )
mesh_sharedElem ( : , : ) = 0_pInt
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
rewind ( unit )
do
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 1 )
if ( IO_lc ( IO_stringValue ( line , pos , 1 ) ) == 'connectivity' ) then
read ( unit , 610 , END = 620 ) line ! Garbage line
do i = 1 , mesh_Nelems
read ( unit , 610 , END = 620 ) line
pos = IO_stringPos ( line , 66 ) ! limit to 64 nodes max (plus ID, type)
2008-06-17 14:41:54 +05:30
e = mesh_FEasCP ( 'elem' , IO_IntValue ( line , pos , 1 ) )
if ( e / = 0 ) then ! disregard non CP elems
2008-06-17 02:19:48 +05:30
node_seen = 0_pInt
2008-03-25 18:22:27 +05:30
do j = 1 , FE_Nnodes ( FE_mapElemtype ( IO_StringValue ( line , pos , 2 ) ) )
2008-06-17 14:41:54 +05:30
n = mesh_FEasCP ( 'node' , IO_IntValue ( line , pos , j + 2 ) )
if ( all ( node_seen / = n ) ) then
2008-06-17 17:24:34 +05:30
mesh_sharedElem ( 1 , n ) = mesh_sharedElem ( 1 , n ) + 1
2008-06-17 14:41:54 +05:30
mesh_sharedElem ( 1 + mesh_sharedElem ( 1 , n ) , n ) = e
2008-06-17 02:19:48 +05:30
end if
2008-06-17 14:41:54 +05:30
node_seen ( j ) = n
2007-04-10 16:52:53 +05:30
enddo
end if
end do
exit
end if
end do
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
620 return
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
!***********************************************************
! build up of IP neighborhood
!
! allocate globals
! _ipNeighborhood
!***********************************************************
SUBROUTINE mesh_build_ipNeighborhood ( )
use prec , only : pInt
implicit none
integer ( pInt ) e , t , i , j , k , n
2009-03-30 20:20:19 +05:30
integer ( pInt ) neighbor , neighboringElem , neighboringIP , matchingElem
integer ( pInt ) , dimension ( 2 ) :: linkedNode
2009-01-20 00:12:31 +05:30
2007-04-10 16:52:53 +05:30
allocate ( mesh_ipNeighborhood ( 2 , mesh_maxNipNeighbors , mesh_maxNips , mesh_NcpElems ) ) ; mesh_ipNeighborhood = 0_pInt
do e = 1 , mesh_NcpElems ! loop over cpElems
2008-03-25 18:22:27 +05:30
t = mesh_element ( 2 , e ) ! get elemType
2007-04-10 16:52:53 +05:30
do i = 1 , FE_Nips ( t ) ! loop over IPs of elem
do n = 1 , FE_NipNeighbors ( t ) ! loop over neighbors of IP
neighbor = FE_ipNeighbor ( n , i , t )
2009-03-30 20:20:19 +05:30
if ( neighbor > 0 ) then ! intra-element IP
2007-04-10 16:52:53 +05:30
neighboringElem = e
neighboringIP = neighbor
else ! neighboring element's IP
neighboringElem = 0_pInt
neighboringIP = 0_pInt
matchingElem = mesh_faceMatch ( - neighbor , e ) ! get CP elem id of face match
if ( matchingElem > 0 . and . &
2009-03-30 20:20:19 +05:30
mesh_element ( 2 , matchingElem ) == t ) then ! found match of same type?
do j = 1 , FE_Nnodes ( t ) ! check against all neighbor's nodes
if ( mesh_element ( 4 + FE_nodesAtIP ( 1 , i , t ) , e ) == mesh_element ( 4 + j , matchingElem ) ) linkedNode ( 1 ) = j ! which neighboring node matches my first nodeAtIP (indexed globally)
if ( mesh_element ( 4 + FE_nodesAtIP ( 2 , i , t ) , e ) == mesh_element ( 4 + j , matchingElem ) ) linkedNode ( 2 ) = j ! which neighboring node matches my second nodeAtIP (indexed globally)
enddo
matchFace : do j = 1 , FE_Nips ( t )
if ( ( linkedNode ( 1 ) == FE_nodesAtIP ( 1 , j , t ) . and . linkedNode ( 2 ) == FE_nodesAtIP ( 2 , j , t ) ) . or . &
( linkedNode ( 1 ) == FE_nodesAtIP ( 2 , j , t ) . and . linkedNode ( 2 ) == FE_nodesAtIP ( 1 , j , t ) ) ) then
neighboringElem = matchingElem
neighboringIP = j
exit matchFace
2007-04-10 16:52:53 +05:30
endif
2009-03-30 20:20:19 +05:30
enddo matchFace
2007-04-10 16:52:53 +05:30
endif
endif
mesh_ipNeighborhood ( 1 , n , i , e ) = neighboringElem
mesh_ipNeighborhood ( 2 , n , i , e ) = neighboringIP
2009-03-30 20:20:19 +05:30
enddo
enddo
enddo
2007-04-10 16:52:53 +05:30
2009-01-16 23:06:37 +05:30
return
2009-01-20 00:12:31 +05:30
2009-01-16 23:06:37 +05:30
END SUBROUTINE
2009-01-20 00:12:31 +05:30
2009-01-16 23:06:37 +05:30
!***********************************************************
! assignment of coordinates for subnodes in each cp element
!
! allocate globals
! _subNodeCoord
!***********************************************************
SUBROUTINE mesh_build_subNodeCoords ( )
use prec , only : pInt , pReal
implicit none
integer ( pInt ) e , t , n , p
allocate ( mesh_subNodeCoord ( 3 , mesh_maxNnodes + mesh_maxNsubNodes , mesh_NcpElems ) ) ; mesh_subNodeCoord = 0.0_pReal
do e = 1 , mesh_NcpElems ! loop over cpElems
t = mesh_element ( 2 , e ) ! get elemType
do n = 1 , FE_Nnodes ( t )
mesh_subNodeCoord ( : , n , e ) = mesh_node ( : , mesh_FEasCP ( 'node' , mesh_element ( 4 + n , e ) ) ) ! loop over nodes of this element type
enddo
2009-01-20 00:12:31 +05:30
do n = 1 , FE_NsubNodes ( t ) ! now for the true subnodes
do p = 1 , FE_Nnodes ( t ) ! loop through parents
2009-01-16 23:06:37 +05:30
if ( FE_subNodeParent ( p , n , t ) > 0 ) & ! valid parent node
mesh_subNodeCoord ( : , n + FE_Nnodes ( t ) , e ) = &
mesh_subNodeCoord ( : , n + FE_Nnodes ( t ) , e ) + &
mesh_node ( : , mesh_FEasCP ( 'node' , mesh_element ( 4 + FE_subNodeParent ( p , n , t ) , e ) ) ) ! add up parents
enddo
mesh_subNodeCoord ( : , n + FE_Nnodes ( t ) , e ) = mesh_subNodeCoord ( : , n + FE_Nnodes ( t ) , e ) / count ( FE_subNodeParent ( : , n , t ) > 0 )
2009-01-20 00:12:31 +05:30
enddo
2009-01-16 23:06:37 +05:30
enddo
return
END SUBROUTINE
!***********************************************************
! calculation of IP volume
!
! allocate globals
! _ipVolume
!***********************************************************
SUBROUTINE mesh_build_ipVolumes ( )
use prec , only : pInt
use math , only : math_volTetrahedron
implicit none
integer ( pInt ) e , f , t , i , j , k , n
2009-01-20 00:12:31 +05:30
integer ( pInt ) , parameter :: Ntriangles = FE_NipFaceNodes - 2 ! each interface is made up of this many triangles
2009-01-16 23:06:37 +05:30
integer ( pInt ) , dimension ( mesh_maxNnodes + mesh_maxNsubNodes ) :: gravityNode ! flagList to find subnodes determining center of grav
real ( pReal ) , dimension ( 3 , mesh_maxNnodes + mesh_maxNsubNodes ) :: gravityNodePos ! coordinates of subnodes determining center of grav
real ( pReal ) , dimension ( 3 , FE_NipFaceNodes ) :: nPos ! coordinates of nodes on IP face
2009-01-20 00:12:31 +05:30
real ( pReal ) , dimension ( Ntriangles , FE_NipFaceNodes ) :: volume ! volumes of possible tetrahedra
2009-01-16 23:06:37 +05:30
real ( pReal ) , dimension ( 3 ) :: centerOfGravity
allocate ( mesh_ipVolume ( mesh_maxNips , mesh_NcpElems ) ) ; mesh_ipVolume = 0.0_pReal
do e = 1 , mesh_NcpElems ! loop over cpElems
t = mesh_element ( 2 , e ) ! get elemType
do i = 1 , FE_Nips ( t ) ! loop over IPs of elem
gravityNode = 0_pInt ! reset flagList
gravityNodePos = 0.0_pReal ! reset coordinates
2009-01-20 00:12:31 +05:30
do f = 1 , FE_NipNeighbors ( t ) ! loop over interfaces of IP
2009-01-16 23:06:37 +05:30
do n = 1 , FE_NipFaceNodes ! loop over nodes on interface
gravityNode ( FE_subNodeOnIPFace ( n , f , i , t ) ) = 1
gravityNodePos ( : , FE_subNodeOnIPFace ( n , f , i , t ) ) = mesh_subNodeCoord ( : , FE_subNodeOnIPFace ( n , f , i , t ) , e )
enddo
enddo
2009-01-20 00:12:31 +05:30
do j = 1 , mesh_maxNnodes + mesh_maxNsubNodes - 1 ! walk through entire flagList except last
if ( gravityNode ( j ) > 0_pInt ) then ! valid node index
do k = j + 1 , mesh_maxNnodes + mesh_maxNsubNodes ! walk through remainder of list
if ( all ( ( gravityNodePos ( : , j ) - gravityNodePos ( : , k ) ) == 0.0_pReal ) ) then ! found match
gravityNode ( j ) = 0_pInt ! delete first instance
2009-01-16 23:06:37 +05:30
gravityNodePos ( : , j ) = 0.0_pReal
2009-01-20 00:12:31 +05:30
exit ! continue with next suspect
2009-01-16 23:06:37 +05:30
endif
enddo
endif
enddo
centerOfGravity = sum ( gravityNodePos , 2 ) / count ( gravityNode > 0 )
2009-01-20 00:12:31 +05:30
do f = 1 , FE_NipNeighbors ( t ) ! loop over interfaces of IP and add tetrahedra which connect to CoG
forall ( n = 1 : FE_NipFaceNodes ) nPos ( : , n ) = mesh_subNodeCoord ( : , FE_subNodeOnIPFace ( n , f , i , t ) , e )
forall ( n = 1 : FE_NipFaceNodes , j = 1 : Ntriangles ) & ! start at each interface node and build valid triangles to cover interface
volume ( j , n ) = math_volTetrahedron ( nPos ( : , n ) , & ! calc volume of respective tetrahedron to CoG
nPos ( : , 1 + mod ( n + j - 1 , FE_NipFaceNodes ) ) , &
nPos ( : , 1 + mod ( n + j - 0 , FE_NipFaceNodes ) ) , &
centerOfGravity )
mesh_ipVolume ( i , e ) = mesh_ipVolume ( i , e ) + sum ( volume ) ! add contribution from this interface
2009-01-16 23:06:37 +05:30
enddo
2009-01-20 00:12:31 +05:30
mesh_ipVolume ( i , e ) = mesh_ipVolume ( i , e ) / FE_NipFaceNodes ! renormalize with interfaceNodeNum due to loop over them
2009-01-16 23:06:37 +05:30
enddo
enddo
return
END SUBROUTINE
!***********************************************************
2009-03-04 17:18:54 +05:30
! calculation of IP interface areas
2009-01-16 23:06:37 +05:30
!
! allocate globals
2009-03-04 17:18:54 +05:30
! _ipArea, _ipAreaNormal
2009-01-16 23:06:37 +05:30
!***********************************************************
SUBROUTINE mesh_build_ipAreas ( )
use prec , only : pInt , pReal
use math
implicit none
2009-03-05 19:48:50 +05:30
integer ( pInt ) e , f , t , i , j , n
2009-01-20 00:12:31 +05:30
integer ( pInt ) , parameter :: Ntriangles = FE_NipFaceNodes - 2 ! each interface is made up of this many triangles
real ( pReal ) , dimension ( 3 , FE_NipFaceNodes ) :: nPos ! coordinates of nodes on IP face
real ( pReal ) , dimension ( 3 , Ntriangles , FE_NipFaceNodes ) :: normal
real ( pReal ) , dimension ( Ntriangles , FE_NipFaceNodes ) :: area
2009-01-16 23:06:37 +05:30
2009-01-20 00:12:31 +05:30
allocate ( mesh_ipArea ( mesh_maxNipNeighbors , mesh_maxNips , mesh_NcpElems ) ) ; mesh_ipArea = 0.0_pReal
2009-01-16 23:06:37 +05:30
allocate ( mesh_ipAreaNormal ( 3 , mesh_maxNipNeighbors , mesh_maxNips , mesh_NcpElems ) ) ; mesh_ipAreaNormal = 0.0_pReal
do e = 1 , mesh_NcpElems ! loop over cpElems
t = mesh_element ( 2 , e ) ! get elemType
do i = 1 , FE_Nips ( t ) ! loop over IPs of elem
2009-01-20 00:12:31 +05:30
do f = 1 , FE_NipNeighbors ( t ) ! loop over interfaces of IP
forall ( n = 1 : FE_NipFaceNodes ) nPos ( : , n ) = mesh_subNodeCoord ( : , FE_subNodeOnIPFace ( n , f , i , t ) , e )
forall ( n = 1 : FE_NipFaceNodes , j = 1 : Ntriangles ) ! start at each interface node and build valid triangles to cover interface
normal ( : , j , n ) = math_vectorproduct ( nPos ( : , 1 + mod ( n + j - 1 , FE_NipFaceNodes ) ) - nPos ( : , n ) , & ! calc their normal vectors
nPos ( : , 1 + mod ( n + j - 0 , FE_NipFaceNodes ) ) - nPos ( : , n ) )
area ( j , n ) = dsqrt ( sum ( normal ( : , j , n ) * normal ( : , j , n ) ) ) ! and area
end forall
forall ( n = 1 : FE_NipFaceNodes , j = 1 : Ntriangles , area ( j , n ) > 0.0_pReal ) &
normal ( : , j , n ) = normal ( : , j , n ) / area ( j , n ) ! make unit normal
mesh_ipArea ( f , i , e ) = sum ( area ) / ( FE_NipFaceNodes * 2.0_pReal ) ! area of parallelograms instead of triangles
mesh_ipAreaNormal ( : , f , i , e ) = sum ( sum ( normal , 3 ) , 2 ) / count ( area > 0.0_pReal ) ! average of all valid normals
2009-01-16 23:06:37 +05:30
enddo
enddo
enddo
return
2007-04-10 16:52:53 +05:30
2009-01-16 23:06:37 +05:30
END SUBROUTINE
2007-10-24 14:30:42 +05:30
!***********************************************************
! write statistics regarding input file parsing
! to the output file
!
!***********************************************************
SUBROUTINE mesh_tell_statistics ( )
2009-01-20 00:12:31 +05:30
2009-03-04 17:18:54 +05:30
use prec , only : pInt
use math , only : math_range
2008-06-17 02:19:48 +05:30
use IO , only : IO_error
2009-01-20 00:12:31 +05:30
2007-10-24 14:30:42 +05:30
implicit none
2009-01-20 00:12:31 +05:30
2009-03-30 20:20:19 +05:30
integer ( pInt ) , dimension ( : , : ) , allocatable :: mesh_HomogMicro
2008-06-17 02:19:48 +05:30
character ( len = 64 ) fmt
2009-01-20 00:12:31 +05:30
2009-03-30 20:20:19 +05:30
integer ( pInt ) i , e , n , f , t
2008-06-17 02:19:48 +05:30
if ( mesh_maxValStateVar ( 1 ) == 0 ) call IO_error ( 110 ) ! no materials specified
if ( mesh_maxValStateVar ( 2 ) == 0 ) call IO_error ( 120 ) ! no textures specified
2009-03-30 20:20:19 +05:30
allocate ( mesh_HomogMicro ( mesh_maxValStateVar ( 1 ) , mesh_maxValStateVar ( 2 ) ) ) ; mesh_HomogMicro = 0_pInt
2007-10-24 14:30:42 +05:30
do i = 1 , mesh_NcpElems
2009-03-30 20:20:19 +05:30
mesh_HomogMicro ( mesh_element ( 3 , i ) , mesh_element ( 4 , i ) ) = &
mesh_HomogMicro ( mesh_element ( 3 , i ) , mesh_element ( 4 , i ) ) + 1 ! count combinations of homogenization and microstructure
2007-10-24 14:30:42 +05:30
enddo
2008-06-17 02:19:48 +05:30
!$OMP CRITICAL (write2out)
2009-01-20 00:12:31 +05:30
write ( 6 , * )
write ( 6 , * ) "Input Parser: IP NEIGHBORHOOD"
write ( 6 , * )
2009-03-30 20:20:19 +05:30
write ( 6 , "(a10,x,a10,x,a10,x,a3,x,a13,x,a13)" ) "elem" , "IP" , "neighbor" , "" , "elemNeighbor" , "ipNeighbor"
do e = 1 , mesh_NcpElems ! loop over cpElems
t = mesh_element ( 2 , e ) ! get elemType
do i = 1 , FE_Nips ( t ) ! loop over IPs of elem
do n = 1 , FE_NipNeighbors ( t ) ! loop over neighbors of IP
write ( 6 , "(i10,x,i10,x,i10,x,a3,x,i13,x,i13)" ) e , i , n , '-->' , mesh_ipNeighborhood ( 1 , n , i , e ) , mesh_ipNeighborhood ( 2 , n , i , e )
enddo
enddo
enddo
write ( 6 , * )
2009-01-20 00:12:31 +05:30
write ( 6 , "(a13,x,e15.8)" ) "total volume" , sum ( mesh_ipVolume )
write ( 6 , * )
write ( 6 , "(a5,x,a5,x,a15,x,a5,x,a15,x,a16)" ) "elem" , "IP" , "volume" , "face" , "area" , "-- normal --"
do e = 1 , mesh_NcpElems
do i = 1 , FE_Nips ( mesh_element ( 2 , e ) )
write ( 6 , "(i5,x,i5,x,e15.8)" ) e , i , mesh_IPvolume ( i , e )
do f = 1 , FE_NipNeighbors ( mesh_element ( 2 , e ) )
! write (6,"(i33,x,e15.8,x,3(f6.3,x))") f,mesh_ipArea(f,i,e),mesh_ipAreaNormal(:,f,i,e)
enddo
enddo
enddo
2007-10-24 14:30:42 +05:30
write ( 6 , * )
write ( 6 , * ) "Input Parser: STATISTICS"
write ( 6 , * )
2009-01-16 20:59:57 +05:30
write ( 6 , * ) mesh_Nelems , " : total number of elements in mesh"
write ( 6 , * ) mesh_NcpElems , " : total number of CP elements in mesh"
write ( 6 , * ) mesh_Nnodes , " : total number of nodes in mesh"
write ( 6 , * ) mesh_maxNnodes , " : max number of nodes in any CP element"
write ( 6 , * ) mesh_maxNips , " : max number of IPs in any CP element"
2009-01-16 23:06:37 +05:30
write ( 6 , * ) mesh_maxNipNeighbors , " : max number of IP neighbors in any CP element"
write ( 6 , * ) mesh_maxNsubNodes , " : max number of (additional) subnodes in any CP element"
2009-01-16 20:59:57 +05:30
write ( 6 , * ) mesh_maxNsharedElems , " : max number of CP elements sharing a node"
2007-10-24 14:30:42 +05:30
write ( 6 , * )
2009-03-04 17:18:54 +05:30
write ( 6 , * ) "Input Parser: HOMOGENIZATION/MICROSTRUCTURE"
2007-10-24 14:30:42 +05:30
write ( 6 , * )
2009-03-04 17:18:54 +05:30
write ( 6 , * ) mesh_maxValStateVar ( 1 ) , " : maximum homogenization index"
write ( 6 , * ) mesh_maxValStateVar ( 2 ) , " : maximum microstructure index"
2007-10-24 16:55:58 +05:30
write ( 6 , * )
2009-03-31 14:19:23 +05:30
write ( fmt , "(a,i5,a)" ) "(9(x),a1,x," , mesh_maxValStateVar ( 2 ) , "(i8))"
2009-03-04 17:18:54 +05:30
write ( 6 , fmt ) "+" , math_range ( mesh_maxValStateVar ( 2 ) )
2009-03-31 14:19:23 +05:30
write ( fmt , "(a,i5,a)" ) "(i8,x,a1,x," , mesh_maxValStateVar ( 2 ) , "(i8))"
2009-03-30 20:20:19 +05:30
do i = 1 , mesh_maxValStateVar ( 1 ) ! loop over all (possibly assigned) homogenizations
write ( 6 , fmt ) i , "|" , mesh_HomogMicro ( i , : ) ! loop over all (possibly assigned) microstrcutures
2007-10-24 14:30:42 +05:30
enddo
write ( 6 , * )
2008-06-17 02:19:48 +05:30
!$OMP END CRITICAL (write2out)
2009-01-20 00:12:31 +05:30
2007-10-24 14:30:42 +05:30
return
END SUBROUTINE
2007-03-21 21:48:33 +05:30
END MODULE mesh
2007-10-23 18:39:46 +05:30