introduced output of initial geometry (vtk file) to mesh
This commit is contained in:
parent
aa07656a90
commit
6b46a9c338
|
@ -92,6 +92,7 @@ end function getSolverJobName
|
||||||
end module DAMASK_interface
|
end module DAMASK_interface
|
||||||
|
|
||||||
#include "IO.f90"
|
#include "IO.f90"
|
||||||
|
#include "libs.f90"
|
||||||
#include "numerics.f90"
|
#include "numerics.f90"
|
||||||
#include "debug.f90"
|
#include "debug.f90"
|
||||||
#include "math.f90"
|
#include "math.f90"
|
||||||
|
|
|
@ -92,6 +92,7 @@ end function getSolverJobName
|
||||||
end module DAMASK_interface
|
end module DAMASK_interface
|
||||||
|
|
||||||
#include "IO.f90"
|
#include "IO.f90"
|
||||||
|
#include "libs.f90"
|
||||||
#include "numerics.f90"
|
#include "numerics.f90"
|
||||||
#include "debug.f90"
|
#include "debug.f90"
|
||||||
#include "math.f90"
|
#include "math.f90"
|
||||||
|
|
|
@ -124,6 +124,7 @@ end function getSolverJobName
|
||||||
end module DAMASK_interface
|
end module DAMASK_interface
|
||||||
|
|
||||||
#include "IO.f90"
|
#include "IO.f90"
|
||||||
|
#include "libs.f90"
|
||||||
#include "numerics.f90"
|
#include "numerics.f90"
|
||||||
#include "debug.f90"
|
#include "debug.f90"
|
||||||
#include "math.f90"
|
#include "math.f90"
|
||||||
|
|
|
@ -484,7 +484,7 @@ subroutine utilities_fourierConvolution(fieldAim)
|
||||||
flush(6)
|
flush(6)
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! to the actual spectral method calculation (mechanical equilibrium)
|
! do the actual spectral method calculation (mechanical equilibrium)
|
||||||
if(memory_efficient) then ! memory saving version, on-the-fly calculation of gamma_hat
|
if(memory_efficient) then ! memory saving version, on-the-fly calculation of gamma_hat
|
||||||
do k = 1_pInt, res(3); do j = 1_pInt, res(2) ;do i = 1_pInt, res1_red
|
do k = 1_pInt, res(3); do j = 1_pInt, res(2) ;do i = 1_pInt, res1_red
|
||||||
if(any([i,j,k] /= 1_pInt)) then ! singular point at xi=(0.0,0.0,0.0) i.e. i=j=k=1
|
if(any([i,j,k] /= 1_pInt)) then ! singular point at xi=(0.0,0.0,0.0) i.e. i=j=k=1
|
||||||
|
@ -645,7 +645,7 @@ end function utilities_curlRMS
|
||||||
|
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief calculates mask compliance tensor
|
!> @brief calculates mask compliance tensor used to adjust F to fullfill stress BC
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
function utilities_maskedCompliance(rot_BC,mask_stress,C)
|
function utilities_maskedCompliance(rot_BC,mask_stress,C)
|
||||||
use IO, only: &
|
use IO, only: &
|
||||||
|
@ -684,7 +684,7 @@ function utilities_maskedCompliance(rot_BC,mask_stress,C)
|
||||||
|
|
||||||
if(debugGeneral) then
|
if(debugGeneral) then
|
||||||
write(6,'(/,a)') ' ... updating masked compliance ............................................'
|
write(6,'(/,a)') ' ... updating masked compliance ............................................'
|
||||||
write(6,'(/,a,/,9(9(2x,f12.7,1x)/))',advance='no') ' Stiffness C rotated / GPa =',&
|
write(6,'(/,a,/,9(9(2x,f12.7,1x)/))',advance='no') ' Stiffness C (load) / GPa =',&
|
||||||
transpose(temp99_Real)/1.e9_pReal
|
transpose(temp99_Real)/1.e9_pReal
|
||||||
flush(6)
|
flush(6)
|
||||||
endif
|
endif
|
||||||
|
@ -724,8 +724,9 @@ function utilities_maskedCompliance(rot_BC,mask_stress,C)
|
||||||
if(debugGeneral .or. errmatinv) then ! report
|
if(debugGeneral .or. errmatinv) then ! report
|
||||||
write(formatString, '(I16.16)') size_reduced
|
write(formatString, '(I16.16)') size_reduced
|
||||||
formatString = '(/,a,/,'//trim(formatString)//'('//trim(formatString)//'(2x,es9.2,1x)/))'
|
formatString = '(/,a,/,'//trim(formatString)//'('//trim(formatString)//'(2x,es9.2,1x)/))'
|
||||||
write(6,trim(formatString),advance='no') ' C * S', transpose(matmul(c_reduced,s_reduced))
|
write(6,trim(formatString),advance='no') ' C * S (load) ', &
|
||||||
write(6,trim(formatString),advance='no') ' S', transpose(s_reduced)
|
transpose(matmul(c_reduced,s_reduced))
|
||||||
|
write(6,trim(formatString),advance='no') ' S (load) ', transpose(s_reduced)
|
||||||
endif
|
endif
|
||||||
if(errmatinv) call IO_error(error_ID=400_pInt,ext_msg='utilities_maskedCompliance')
|
if(errmatinv) call IO_error(error_ID=400_pInt,ext_msg='utilities_maskedCompliance')
|
||||||
deallocate(c_reduced)
|
deallocate(c_reduced)
|
||||||
|
@ -735,7 +736,7 @@ function utilities_maskedCompliance(rot_BC,mask_stress,C)
|
||||||
temp99_real = 0.0_pReal
|
temp99_real = 0.0_pReal
|
||||||
endif
|
endif
|
||||||
if(debugGeneral) & ! report
|
if(debugGeneral) & ! report
|
||||||
write(6,'(/,a,/,9(9(2x,f12.7,1x)/),/)',advance='no') ' Masked Compliance * GPa =', &
|
write(6,'(/,a,/,9(9(2x,f12.7,1x)/),/)',advance='no') ' Masked Compliance (load) * GPa =', &
|
||||||
transpose(temp99_Real*1.e9_pReal)
|
transpose(temp99_Real*1.e9_pReal)
|
||||||
flush(6)
|
flush(6)
|
||||||
utilities_maskedCompliance = math_Plain99to3333(temp99_Real)
|
utilities_maskedCompliance = math_Plain99to3333(temp99_Real)
|
||||||
|
|
|
@ -24,10 +24,10 @@
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
#ifdef Spectral
|
#ifdef Spectral
|
||||||
#include "kdtree2.f90"
|
#include "../lib/kdtree2.f90"
|
||||||
#include "IR_Precision.f90"
|
|
||||||
#include "Lib_VTK_IO.f90"
|
|
||||||
#endif
|
#endif
|
||||||
|
#include "../lib/IR_Precision.f90"
|
||||||
|
#include "../lib/Lib_VTK_IO.f90"
|
||||||
|
|
||||||
module libs
|
module libs
|
||||||
end module libs
|
end module libs
|
||||||
|
|
187
code/mesh.f90
187
code/mesh.f90
|
@ -1,7 +1,7 @@
|
||||||
! Copyright 2011-13 Max-Planck-Institut für Eisenforschung GmbH
|
! Copyright 2011-13 Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!
|
!
|
||||||
! This file is part of DAMASK,
|
! This file is part of DAMASK,
|
||||||
! the Düsseldorf Advanced Material Simulation Kit.
|
! the Düsseldorf Advanced Material Simulation Kit.
|
||||||
!
|
!
|
||||||
! DAMASK is free software: you can redistribute it and/or modify
|
! DAMASK is free software: you can redistribute it and/or modify
|
||||||
! it under the terms of the GNU General Public License as published by
|
! it under the terms of the GNU General Public License as published by
|
||||||
|
@ -19,11 +19,11 @@
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!* $Id$
|
!* $Id$
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!! Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!! Christoph Koords, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Christoph Koords, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!! Martin Diehl, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Martin Diehl, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!! Krishna Komerla, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Krishna Komerla, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!> @brief Sets up the mesh for the solvers MSC.Marc, Abaqus and the spectral solver
|
!> @brief Sets up the mesh for the solvers MSC.Marc, Abaqus and the spectral solver
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ module mesh
|
||||||
mesh_Nmaterials, &
|
mesh_Nmaterials, &
|
||||||
mesh_Nnodes, & !< total number of nodes in mesh
|
mesh_Nnodes, & !< total number of nodes in mesh
|
||||||
mesh_Ncellnodes, & !< total number of cell nodes in mesh (including duplicates)
|
mesh_Ncellnodes, & !< total number of cell nodes in mesh (including duplicates)
|
||||||
|
mesh_Ncells, & !< total number of cells in mesh
|
||||||
mesh_maxNnodes, & !< max number of nodes in any CP element
|
mesh_maxNnodes, & !< max number of nodes in any CP element
|
||||||
mesh_maxNips, & !< max number of IPs in any CP element
|
mesh_maxNips, & !< max number of IPs in any CP element
|
||||||
mesh_maxNipNeighbors, & !< max number of IP neighbors in any CP element
|
mesh_maxNipNeighbors, & !< max number of IP neighbors in any CP element
|
||||||
|
@ -82,9 +82,9 @@ module mesh
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
type, private :: tCellnode !< set of parameters defining a cellnode
|
type, private :: tCellnode !< set of parameters defining a cellnode
|
||||||
real(pReal), dimension(3) :: coords = 0.0_pReal
|
real(pReal), dimension(3) :: coords = 0.0_pReal !< coordinates of cell node
|
||||||
integer(pInt) :: elemParent = 0_pInt
|
integer(pInt) :: elemParent = 0_pInt !< number of parent element
|
||||||
integer(pInt) :: intraElemID = 0_pInt
|
integer(pInt) :: intraElemID = 0_pInt !< internal number of cell node in element
|
||||||
end type tCellnode
|
end type tCellnode
|
||||||
|
|
||||||
integer(pInt), dimension(2), private :: &
|
integer(pInt), dimension(2), private :: &
|
||||||
|
@ -393,14 +393,16 @@ module mesh
|
||||||
],pInt)
|
],pInt)
|
||||||
|
|
||||||
|
|
||||||
public :: mesh_init, &
|
public :: &
|
||||||
|
mesh_init, &
|
||||||
mesh_FEasCP, &
|
mesh_FEasCP, &
|
||||||
mesh_build_cells, &
|
mesh_build_cells, &
|
||||||
mesh_build_ipVolumes, &
|
mesh_build_ipVolumes, &
|
||||||
mesh_build_ipCoordinates, &
|
mesh_build_ipCoordinates, &
|
||||||
mesh_cellCenterCoordinates
|
mesh_cellCenterCoordinates
|
||||||
#ifdef Spectral
|
#ifdef Spectral
|
||||||
public :: mesh_regrid, &
|
public :: &
|
||||||
|
mesh_regrid, &
|
||||||
mesh_nodesAroundCentres, &
|
mesh_nodesAroundCentres, &
|
||||||
mesh_deformedCoordsFFT, &
|
mesh_deformedCoordsFFT, &
|
||||||
mesh_deformedCoordsLinear, &
|
mesh_deformedCoordsLinear, &
|
||||||
|
@ -454,7 +456,9 @@ module mesh
|
||||||
mesh_tell_statistics, &
|
mesh_tell_statistics, &
|
||||||
FE_mapElemtype, &
|
FE_mapElemtype, &
|
||||||
mesh_faceMatch, &
|
mesh_faceMatch, &
|
||||||
mesh_build_FEdata
|
mesh_build_FEdata, &
|
||||||
|
mesh_writeGeom
|
||||||
|
|
||||||
contains
|
contains
|
||||||
|
|
||||||
|
|
||||||
|
@ -591,7 +595,9 @@ subroutine mesh_init(ip,el)
|
||||||
call mesh_build_ipNeighborhood
|
call mesh_build_ipNeighborhood
|
||||||
call mesh_tell_statistics
|
call mesh_tell_statistics
|
||||||
|
|
||||||
if (usePingPong .and. (mesh_Nelems /= mesh_NcpElems)) call IO_error(600_pInt) ! ping-pong must be disabled when havin non-DAMASK-elements
|
call mesh_writeGeom
|
||||||
|
|
||||||
|
if (usePingPong .and. (mesh_Nelems /= mesh_NcpElems)) call IO_error(600_pInt) ! ping-pong must be disabled when havin non-DAMASK-elements
|
||||||
|
|
||||||
FEsolving_execElem = [ 1_pInt,mesh_NcpElems ]
|
FEsolving_execElem = [ 1_pInt,mesh_NcpElems ]
|
||||||
if (allocated(FEsolving_execIP)) deallocate(FEsolving_execIP)
|
if (allocated(FEsolving_execIP)) deallocate(FEsolving_execIP)
|
||||||
|
@ -688,12 +694,14 @@ subroutine mesh_build_cells
|
||||||
allocate(cellnodeParent(2_pInt,mesh_maxNcellnodes*mesh_NcpElems)) ; cellnodeParent = 0_pInt
|
allocate(cellnodeParent(2_pInt,mesh_maxNcellnodes*mesh_NcpElems)) ; cellnodeParent = 0_pInt
|
||||||
|
|
||||||
mesh_Ncellnodes = 0_pInt
|
mesh_Ncellnodes = 0_pInt
|
||||||
|
mesh_Ncells = 0_pInt
|
||||||
do e = 1_pInt,mesh_NcpElems ! loop over cpElems
|
do e = 1_pInt,mesh_NcpElems ! loop over cpElems
|
||||||
t = mesh_element(2_pInt,e) ! get element type
|
t = mesh_element(2_pInt,e) ! get element type
|
||||||
g = FE_geomtype(t) ! get geometry type
|
g = FE_geomtype(t) ! get geometry type
|
||||||
c = FE_celltype(g) ! get cell type
|
c = FE_celltype(g) ! get cell type
|
||||||
localCellnode2globalCellnode = 0_pInt
|
localCellnode2globalCellnode = 0_pInt
|
||||||
do i = 1_pInt,FE_Nips(g) ! loop over ips=cells in this element
|
do i = 1_pInt,FE_Nips(g) ! loop over ips=cells in this element
|
||||||
|
mesh_Ncells = mesh_Ncells + FE_Nips(g)
|
||||||
do n = 1_pInt,FE_NcellnodesPerCell(c) ! loop over cell nodes in this cell
|
do n = 1_pInt,FE_NcellnodesPerCell(c) ! loop over cell nodes in this cell
|
||||||
localCellnodeID = FE_cell(n,i,g)
|
localCellnodeID = FE_cell(n,i,g)
|
||||||
if (localCellnodeID <= FE_NmatchingNodes(g)) then ! this cell node is a matching node
|
if (localCellnodeID <= FE_NmatchingNodes(g)) then ! this cell node is a matching node
|
||||||
|
@ -1211,7 +1219,7 @@ subroutine mesh_spectral_build_nodes()
|
||||||
/ real(res(3),pReal)
|
/ real(res(3),pReal)
|
||||||
end forall
|
end forall
|
||||||
|
|
||||||
mesh_node = mesh_node0 ! why?
|
mesh_node = mesh_node0
|
||||||
|
|
||||||
end subroutine mesh_spectral_build_nodes
|
end subroutine mesh_spectral_build_nodes
|
||||||
|
|
||||||
|
@ -1326,6 +1334,8 @@ function mesh_regrid(adaptive,resNewInput,minRes)
|
||||||
use math, only: &
|
use math, only: &
|
||||||
math_periodicNearestNeighbor, &
|
math_periodicNearestNeighbor, &
|
||||||
math_mul33x3
|
math_mul33x3
|
||||||
|
|
||||||
|
implicit none
|
||||||
character(len=1024):: formatString, N_Digits
|
character(len=1024):: formatString, N_Digits
|
||||||
logical, intent(in) :: adaptive ! if true, choose adaptive grid based on resNewInput, otherwise keep it constant
|
logical, intent(in) :: adaptive ! if true, choose adaptive grid based on resNewInput, otherwise keep it constant
|
||||||
integer(pInt), dimension(3), optional, intent(in) :: resNewInput ! f2py cannot handle optional arguments correctly (they are always present)
|
integer(pInt), dimension(3), optional, intent(in) :: resNewInput ! f2py cannot handle optional arguments correctly (they are always present)
|
||||||
|
@ -2883,11 +2893,10 @@ subroutine mesh_abaqus_count_nodesAndElements(myUnit)
|
||||||
end subroutine mesh_abaqus_count_nodesAndElements
|
end subroutine mesh_abaqus_count_nodesAndElements
|
||||||
|
|
||||||
|
|
||||||
!********************************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! count overall number of element sets in mesh
|
!> @brief count overall number of element sets in mesh and write 'mesh_NelemSets' and
|
||||||
!
|
!! 'mesh_maxNelemInSet'
|
||||||
! mesh_NelemSets, mesh_maxNelemInSet
|
!--------------------------------------------------------------------------------------------------
|
||||||
!********************************************************************
|
|
||||||
subroutine mesh_abaqus_count_elementSets(myUnit)
|
subroutine mesh_abaqus_count_elementSets(myUnit)
|
||||||
|
|
||||||
use IO, only: IO_lc, &
|
use IO, only: IO_lc, &
|
||||||
|
@ -2927,11 +2936,13 @@ subroutine mesh_abaqus_count_elementSets(myUnit)
|
||||||
end subroutine mesh_abaqus_count_elementSets
|
end subroutine mesh_abaqus_count_elementSets
|
||||||
|
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
! count overall number of solid sections sets in mesh (Abaqus only)
|
! count overall number of solid sections sets in mesh (Abaqus only)
|
||||||
!
|
!
|
||||||
! mesh_Nmaterials
|
! mesh_Nmaterials
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine mesh_abaqus_count_materials(myUnit)
|
subroutine mesh_abaqus_count_materials(myUnit)
|
||||||
|
|
||||||
use IO, only: IO_lc, &
|
use IO, only: IO_lc, &
|
||||||
|
@ -2971,11 +2982,13 @@ subroutine mesh_abaqus_count_materials(myUnit)
|
||||||
end subroutine mesh_abaqus_count_materials
|
end subroutine mesh_abaqus_count_materials
|
||||||
|
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
! Build element set mapping
|
! Build element set mapping
|
||||||
!
|
!
|
||||||
! allocate globals: mesh_nameElemSet, mesh_mapElemSet
|
! allocate globals: mesh_nameElemSet, mesh_mapElemSet
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine mesh_abaqus_map_elementSets(myUnit)
|
subroutine mesh_abaqus_map_elementSets(myUnit)
|
||||||
|
|
||||||
use IO, only: IO_lc, &
|
use IO, only: IO_lc, &
|
||||||
|
@ -3023,11 +3036,13 @@ subroutine mesh_abaqus_map_elementSets(myUnit)
|
||||||
end subroutine mesh_abaqus_map_elementSets
|
end subroutine mesh_abaqus_map_elementSets
|
||||||
|
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
! map solid section (Abaqus only)
|
! map solid section (Abaqus only)
|
||||||
!
|
!
|
||||||
! allocate globals: mesh_nameMaterial, mesh_mapMaterial
|
! allocate globals: mesh_nameMaterial, mesh_mapMaterial
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine mesh_abaqus_map_materials(myUnit)
|
subroutine mesh_abaqus_map_materials(myUnit)
|
||||||
|
|
||||||
use IO, only: IO_lc, &
|
use IO, only: IO_lc, &
|
||||||
|
@ -3418,7 +3433,7 @@ subroutine mesh_abaqus_build_elements(myUnit)
|
||||||
integer(pInt), parameter :: maxNchunks = 65_pInt
|
integer(pInt), parameter :: maxNchunks = 65_pInt
|
||||||
integer(pInt), dimension (1_pInt+2_pInt*maxNchunks) :: myPos
|
integer(pInt), dimension (1_pInt+2_pInt*maxNchunks) :: myPos
|
||||||
|
|
||||||
integer(pInt) :: i,j,k,c,e,t,homog,micro
|
integer(pInt) :: i,j,k,c,e,t,homog,micro, nNodesAlreadyRead
|
||||||
logical inPart,materialFound
|
logical inPart,materialFound
|
||||||
character (len=64) :: materialName,elemSetName
|
character (len=64) :: materialName,elemSetName
|
||||||
character(len=300) :: line
|
character(len=300) :: line
|
||||||
|
@ -3515,11 +3530,9 @@ subroutine mesh_abaqus_build_elements(myUnit)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
!********************************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! get any additional damask options from input file
|
!> @brief get any additional damask options from input file, sets mesh_periodicSurface
|
||||||
!
|
!--------------------------------------------------------------------------------------------------
|
||||||
! mesh_periodicSurface
|
|
||||||
!********************************************************************
|
|
||||||
subroutine mesh_get_damaskOptions(myUnit)
|
subroutine mesh_get_damaskOptions(myUnit)
|
||||||
|
|
||||||
use IO, only: &
|
use IO, only: &
|
||||||
|
@ -3583,12 +3596,9 @@ use IO, only: &
|
||||||
620 end subroutine mesh_get_damaskOptions
|
620 end subroutine mesh_get_damaskOptions
|
||||||
|
|
||||||
|
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! calculation of IP interface areas
|
!> @brief calculation of IP interface areas, allocate globals '_ipArea', and '_ipAreaNormal'
|
||||||
!
|
!--------------------------------------------------------------------------------------------------
|
||||||
! allocate globals
|
|
||||||
! _ipArea, _ipAreaNormal
|
|
||||||
!***********************************************************
|
|
||||||
subroutine mesh_build_ipAreas
|
subroutine mesh_build_ipAreas
|
||||||
|
|
||||||
use math, only: &
|
use math, only: &
|
||||||
|
@ -3663,12 +3673,9 @@ subroutine mesh_build_ipAreas
|
||||||
end subroutine mesh_build_ipAreas
|
end subroutine mesh_build_ipAreas
|
||||||
|
|
||||||
|
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! assignment of twin nodes for each cp node
|
!> @brief assignment of twin nodes for each cp node, allocate globals '_nodeTwins'
|
||||||
!
|
!--------------------------------------------------------------------------------------------------
|
||||||
! allocate globals
|
|
||||||
! _nodeTwins
|
|
||||||
!***********************************************************
|
|
||||||
subroutine mesh_build_nodeTwins
|
subroutine mesh_build_nodeTwins
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
|
@ -3736,14 +3743,10 @@ enddo
|
||||||
end subroutine mesh_build_nodeTwins
|
end subroutine mesh_build_nodeTwins
|
||||||
|
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
!********************************************************************
|
!> @brief get maximum count of shared elements among cpElements and build list of elements shared
|
||||||
! get maximum count of shared elements among cpElements and
|
!! by each node in mesh. Allocate globals '_maxNsharedElems' and '_sharedElem'
|
||||||
! build list of elements shared by each node in mesh
|
!--------------------------------------------------------------------------------------------------
|
||||||
!
|
|
||||||
! _maxNsharedElems
|
|
||||||
! _sharedElem
|
|
||||||
!********************************************************************
|
|
||||||
subroutine mesh_build_sharedElems
|
subroutine mesh_build_sharedElems
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
|
@ -3808,12 +3811,9 @@ deallocate(node_seen)
|
||||||
end subroutine mesh_build_sharedElems
|
end subroutine mesh_build_sharedElems
|
||||||
|
|
||||||
|
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! build up of IP neighborhood
|
!> @brief build up of IP neighborhood, allocate globals '_ipNeighborhood'
|
||||||
!
|
!--------------------------------------------------------------------------------------------------
|
||||||
! allocate globals
|
|
||||||
! _ipNeighborhood
|
|
||||||
!***********************************************************
|
|
||||||
subroutine mesh_build_ipNeighborhood
|
subroutine mesh_build_ipNeighborhood
|
||||||
|
|
||||||
use math, only: math_mul3x3
|
use math, only: math_mul3x3
|
||||||
|
@ -3982,11 +3982,9 @@ enddo
|
||||||
end subroutine mesh_build_ipNeighborhood
|
end subroutine mesh_build_ipNeighborhood
|
||||||
|
|
||||||
|
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! write statistics regarding input file parsing
|
!> @brief write statistics regarding input file parsing to the output file
|
||||||
! to the output file
|
!--------------------------------------------------------------------------------------------------
|
||||||
!
|
|
||||||
!***********************************************************
|
|
||||||
subroutine mesh_tell_statistics
|
subroutine mesh_tell_statistics
|
||||||
|
|
||||||
use math, only: math_range
|
use math, only: math_range
|
||||||
|
@ -4133,9 +4131,9 @@ enddo
|
||||||
end subroutine mesh_tell_statistics
|
end subroutine mesh_tell_statistics
|
||||||
|
|
||||||
|
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! mapping of FE element types to internal representation
|
!> @brief mapping of FE element types to internal representation
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
integer(pInt) function FE_mapElemtype(what)
|
integer(pInt) function FE_mapElemtype(what)
|
||||||
|
|
||||||
use IO, only: IO_lc, IO_error
|
use IO, only: IO_lc, IO_error
|
||||||
|
@ -4188,9 +4186,9 @@ integer(pInt) function FE_mapElemtype(what)
|
||||||
end function FE_mapElemtype
|
end function FE_mapElemtype
|
||||||
|
|
||||||
|
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
! find face-matching element of same type
|
!> @brief find face-matching element of same type
|
||||||
!***********************************************************
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine mesh_faceMatch(elem, face ,matchingElem, matchingFace)
|
subroutine mesh_faceMatch(elem, face ,matchingElem, matchingFace)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
|
@ -4292,11 +4290,11 @@ subroutine mesh_build_FEdata
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
integer(pInt) :: me
|
integer(pInt) :: me
|
||||||
allocate(FE_nodesAtIP(FE_maxmaxNnodesAtIP,FE_maxNips,FE_Ngeomtypes)) ; FE_nodesAtIP = 0_pInt
|
allocate(FE_nodesAtIP(FE_maxmaxNnodesAtIP,FE_maxNips,FE_Ngeomtypes)); FE_nodesAtIP = 0_pInt
|
||||||
allocate(FE_ipNeighbor(FE_maxNipNeighbors,FE_maxNips,FE_Ngeomtypes)) ; FE_ipNeighbor = 0_pInt
|
allocate(FE_ipNeighbor(FE_maxNipNeighbors,FE_maxNips,FE_Ngeomtypes)); FE_ipNeighbor = 0_pInt
|
||||||
allocate(FE_cell(FE_maxNcellnodesPerCell,FE_maxNips,FE_Ngeomtypes)) ; FE_cell = 0_pInt
|
allocate(FE_cell(FE_maxNcellnodesPerCell,FE_maxNips,FE_Ngeomtypes)); FE_cell = 0_pInt
|
||||||
allocate(FE_cellnodeParentnodeWeights(FE_maxNnodes,FE_maxNcellnodes,FE_Nelemtypes)) ; FE_cellnodeParentnodeWeights = 0.0_pReal
|
allocate(FE_cellnodeParentnodeWeights(FE_maxNnodes,FE_maxNcellnodes,FE_Nelemtypes)); FE_cellnodeParentnodeWeights = 0.0_pReal
|
||||||
allocate(FE_cellface(FE_maxNcellnodesPerCellface,FE_maxNcellfaces,FE_Ncelltypes)) ; FE_cellface = 0.0_pReal
|
allocate(FE_cellface(FE_maxNcellnodesPerCellface,FE_maxNcellfaces,FE_Ncelltypes)); FE_cellface = 0_pInt
|
||||||
|
|
||||||
|
|
||||||
!*** fill FE_nodesAtIP with data ***
|
!*** fill FE_nodesAtIP with data ***
|
||||||
|
@ -4962,7 +4960,7 @@ subroutine mesh_build_FEdata
|
||||||
me = 0_pInt
|
me = 0_pInt
|
||||||
|
|
||||||
me = me + 1_pInt
|
me = me + 1_pInt
|
||||||
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 2D 3node
|
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 2D 3node, VTK_TRIANGLE (5)
|
||||||
reshape(int([&
|
reshape(int([&
|
||||||
2,3, &
|
2,3, &
|
||||||
3,1, &
|
3,1, &
|
||||||
|
@ -4970,7 +4968,7 @@ subroutine mesh_build_FEdata
|
||||||
],pInt),[FE_NcellnodesPerCellface(me),FE_NipNeighbors(me)])
|
],pInt),[FE_NcellnodesPerCellface(me),FE_NipNeighbors(me)])
|
||||||
|
|
||||||
me = me + 1_pInt
|
me = me + 1_pInt
|
||||||
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 2D 4node
|
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 2D 4node, VTK_QUAD (9)
|
||||||
reshape(int([&
|
reshape(int([&
|
||||||
2,3, &
|
2,3, &
|
||||||
4,1, &
|
4,1, &
|
||||||
|
@ -4979,7 +4977,7 @@ subroutine mesh_build_FEdata
|
||||||
],pInt),[FE_NcellnodesPerCellface(me),FE_NipNeighbors(me)])
|
],pInt),[FE_NcellnodesPerCellface(me),FE_NipNeighbors(me)])
|
||||||
|
|
||||||
me = me + 1_pInt
|
me = me + 1_pInt
|
||||||
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 3D 4node
|
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 3D 4node, VTK_TETRA (10)
|
||||||
reshape(int([&
|
reshape(int([&
|
||||||
1,3,2, &
|
1,3,2, &
|
||||||
1,2,4, &
|
1,2,4, &
|
||||||
|
@ -4988,7 +4986,7 @@ subroutine mesh_build_FEdata
|
||||||
],pInt),[FE_NcellnodesPerCellface(me),FE_NipNeighbors(me)])
|
],pInt),[FE_NcellnodesPerCellface(me),FE_NipNeighbors(me)])
|
||||||
|
|
||||||
me = me + 1_pInt
|
me = me + 1_pInt
|
||||||
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 3D 8node
|
FE_cellface(1:FE_NcellnodesPerCellface(me),1:FE_NipNeighbors(me),me) = & ! 3D 8node, VTK_HEXAHEDRON (12)
|
||||||
reshape(int([&
|
reshape(int([&
|
||||||
2,3,7,6, &
|
2,3,7,6, &
|
||||||
4,1,5,8, &
|
4,1,5,8, &
|
||||||
|
@ -5001,5 +4999,48 @@ subroutine mesh_build_FEdata
|
||||||
|
|
||||||
end subroutine mesh_build_FEdata
|
end subroutine mesh_build_FEdata
|
||||||
|
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
!> @brief writes out initial geometry
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
subroutine mesh_writeGeom
|
||||||
|
use DAMASK_interface, only: &
|
||||||
|
getSolverJobName
|
||||||
|
use Lib_VTK_IO, only: &
|
||||||
|
VTK_INI, &
|
||||||
|
VTK_GEO, &
|
||||||
|
VTK_CON, &
|
||||||
|
VTK_END
|
||||||
|
|
||||||
|
implicit none
|
||||||
|
integer(pInt), dimension(1:mesh_Ncells) :: cell_type
|
||||||
|
integer(pInt), dimension(mesh_Ncells*(1_pInt+FE_maxNcellnodesPerCell)) :: connect
|
||||||
|
integer(pInt):: E_IO, g, c, e, CellID, i, NcellnodesSeen
|
||||||
|
integer(pInt), dimension(FE_Ncelltypes), parameter :: DAMASKTOVTK= [5,9,10,12]
|
||||||
|
|
||||||
|
cellID = 0_pInt
|
||||||
|
NcellnodesSeen = 0_pInt
|
||||||
|
do e = 1_pInt, mesh_NcpElems ! loop over cpElems
|
||||||
|
g = FE_geomtype(mesh_element(2_pInt,e)) ! get element type) ! get geometry type
|
||||||
|
c = FE_celltype(g) ! get cell type
|
||||||
|
do i = 1_pInt,FE_Nips(g) ! loop over ips=cells in this element
|
||||||
|
cellID = cellID + 1_pInt
|
||||||
|
cell_type(cellID) = DAMASKTOVTK(c)
|
||||||
|
connect(NcellnodesSeen+1_pInt:NcellnodesSeen+FE_NcellnodesPerCell(c)+1_pInt) &
|
||||||
|
= [FE_NcellnodesPerCell(c),mesh_cell(1:FE_NcellnodesPerCell(c),i,e)-1_pInt] ! number of nodes per element, global element number (counting starts at 0)
|
||||||
|
NcellnodesSeen = NcellnodesSeen + FE_NcellnodesPerCell(c)+1_pInt
|
||||||
|
enddo
|
||||||
|
enddo
|
||||||
|
|
||||||
|
E_IO = VTK_INI(output_format = 'ASCII', title=trim(getSolverJobName()), &
|
||||||
|
filename = trim(getSolverJobName())//'.vtk', mesh_topology = 'UNSTRUCTURED_GRID')
|
||||||
|
E_IO = VTK_GEO(NN = mesh_Ncellnodes, X = mesh_cellnode%coords(1), &
|
||||||
|
Y = mesh_cellnode%coords(2), Z = mesh_cellnode%coords(3))
|
||||||
|
E_IO = VTK_CON(NC = mesh_Ncells, connect = connect(1:NcellnodesSeen), cell_type = cell_type)
|
||||||
|
E_IO = VTK_END()
|
||||||
|
|
||||||
|
end subroutine mesh_writeGeom
|
||||||
|
|
||||||
|
|
||||||
end module mesh
|
end module mesh
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue