2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
|
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
|
!> @author Luc Hantcherli, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
|
!> @author W.A. Counts
|
|
|
|
|
!> @author Denny Tjahjanto, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
|
!> @author Christoph Kords, Max-Planck-Institut für Eisenforschung GmbH
|
2018-07-10 11:54:45 +05:30
|
|
|
|
!> @author Martin Diehl, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
|
!> @brief Interfaces DAMASK with MSC.Marc
|
2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2018-07-10 11:54:45 +05:30
|
|
|
|
#define QUOTE(x) #x
|
|
|
|
|
#define PASTE(x,y) x ## y
|
|
|
|
|
|
2021-07-04 20:31:24 +05:30
|
|
|
|
#ifdef Marc4DAMASK
|
|
|
|
|
#define MARC4DAMASK Marc4DAMASK
|
|
|
|
|
#endif
|
|
|
|
|
|
2022-04-24 22:20:23 +05:30
|
|
|
|
#include "../prec.f90"
|
2023-07-18 19:01:41 +05:30
|
|
|
|
#include "../parallelization.f90"
|
|
|
|
|
#include "../constants.f90"
|
|
|
|
|
#include "../misc.f90"
|
|
|
|
|
#include "../IO.f90"
|
|
|
|
|
#include "../YAML_types.f90"
|
|
|
|
|
#include "../YAML_parse.f90"
|
|
|
|
|
#include "../HDF5_utilities.f90"
|
2018-07-10 11:54:45 +05:30
|
|
|
|
|
2012-03-09 01:55:28 +05:30
|
|
|
|
module DAMASK_interface
|
2020-09-19 14:20:32 +05:30
|
|
|
|
use, intrinsic :: ISO_fortran_env, only: &
|
2020-01-25 13:42:09 +05:30
|
|
|
|
compiler_version, &
|
|
|
|
|
compiler_options
|
|
|
|
|
use ifport, only: &
|
|
|
|
|
CHDIR
|
2016-07-20 12:14:12 +05:30
|
|
|
|
|
2023-07-18 19:01:41 +05:30
|
|
|
|
use prec
|
|
|
|
|
use IO
|
|
|
|
|
|
2022-06-22 02:16:54 +05:30
|
|
|
|
implicit none(type,external)
|
2020-01-25 13:42:09 +05:30
|
|
|
|
private
|
|
|
|
|
|
2020-03-10 18:19:11 +05:30
|
|
|
|
logical, protected, public :: symmetricSolver
|
2020-01-25 13:42:09 +05:30
|
|
|
|
character(len=*), parameter, public :: INPUTFILEEXTENSION = '.dat'
|
2020-09-12 19:36:33 +05:30
|
|
|
|
|
2020-01-25 13:42:09 +05:30
|
|
|
|
public :: &
|
|
|
|
|
DAMASK_interface_init, &
|
|
|
|
|
getSolverJobName
|
2009-10-12 21:31:49 +05:30
|
|
|
|
|
2012-03-09 01:55:28 +05:30
|
|
|
|
contains
|
2009-08-31 20:51:15 +05:30
|
|
|
|
|
2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2018-07-10 11:54:45 +05:30
|
|
|
|
!> @brief reports and sets working directory
|
2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2012-03-09 01:55:28 +05:30
|
|
|
|
subroutine DAMASK_interface_init
|
2010-11-03 20:09:18 +05:30
|
|
|
|
|
2020-01-26 16:54:35 +05:30
|
|
|
|
integer, dimension(8) :: dateAndTime
|
|
|
|
|
integer :: ierr
|
|
|
|
|
character(len=pPathLen) :: wd
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2022-08-29 19:38:24 +05:30
|
|
|
|
external :: quit
|
|
|
|
|
|
2022-05-03 16:25:27 +05:30
|
|
|
|
print'(/,1x,a)', '<<<+- DAMASK_Marc init -+>>>'
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print*, 'Roters et al., Computational Materials Science 158:420–478, 2019'
|
|
|
|
|
print*, 'https://doi.org/10.1016/j.commatsci.2018.04.030'
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(/,a)', ' Version: '//DAMASKVERSION
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2021-02-02 13:33:41 +05:30
|
|
|
|
print'(/,a)', ' Compiled with: '//compiler_version()
|
|
|
|
|
print'(a)', ' Compiler options: '//compiler_options()
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(/,a)', ' Compiled on: '//__DATE__//' at '//__TIME__
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2020-01-25 13:42:09 +05:30
|
|
|
|
call date_and_time(values = dateAndTime)
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(/,a,2(i2.2,a),i4.4)', ' Date: ',dateAndTime(3),'/',dateAndTime(2),'/', dateAndTime(1)
|
|
|
|
|
print'(a,2(i2.2,a),i2.2)', ' Time: ',dateAndTime(5),':', dateAndTime(6),':', dateAndTime(7)
|
2020-02-25 14:10:38 +05:30
|
|
|
|
|
2020-01-25 13:42:09 +05:30
|
|
|
|
inquire(5, name=wd)
|
|
|
|
|
wd = wd(1:scan(wd,'/',back=.true.))
|
|
|
|
|
ierr = CHDIR(wd)
|
|
|
|
|
if (ierr /= 0) then
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print*, 'working directory "'//trim(wd)//'" does not exist'
|
2020-01-25 13:42:09 +05:30
|
|
|
|
call quit(1)
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-01-25 13:42:09 +05:30
|
|
|
|
symmetricSolver = solverIsSymmetric()
|
2012-03-09 01:55:28 +05:30
|
|
|
|
|
|
|
|
|
end subroutine DAMASK_interface_init
|
|
|
|
|
|
2009-08-31 20:39:15 +05:30
|
|
|
|
|
2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
!> @brief solver job name (no extension) as combination of geometry and load case name
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2020-01-25 13:26:39 +05:30
|
|
|
|
function getSolverJobName()
|
2010-05-10 20:32:59 +05:30
|
|
|
|
|
2020-01-25 13:42:09 +05:30
|
|
|
|
character(len=:), allocatable :: getSolverJobName
|
|
|
|
|
character(1024) :: inputName
|
|
|
|
|
character(len=*), parameter :: pathSep = achar(47)//achar(92) ! forward and backward slash
|
|
|
|
|
integer :: extPos
|
2010-05-10 20:32:59 +05:30
|
|
|
|
|
2020-01-25 13:42:09 +05:30
|
|
|
|
inquire(5, name=inputName) ! determine inputfile
|
|
|
|
|
extPos = len_trim(inputName)-4
|
|
|
|
|
getSolverJobName=inputName(scan(inputName,pathSep,back=.true.)+1:extPos)
|
2010-05-10 20:32:59 +05:30
|
|
|
|
|
2012-03-09 01:55:28 +05:30
|
|
|
|
end function getSolverJobName
|
|
|
|
|
|
2013-03-01 17:18:29 +05:30
|
|
|
|
|
2020-01-25 13:42:09 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
!> @brief determines whether a symmetric solver is used
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
logical function solverIsSymmetric()
|
|
|
|
|
|
2023-06-04 10:47:38 +05:30
|
|
|
|
character(len=pSTRLEN) :: line
|
2020-01-25 13:42:09 +05:30
|
|
|
|
integer :: myStat,fileUnit,s,e
|
|
|
|
|
|
|
|
|
|
open(newunit=fileUnit, file=getSolverJobName()//INPUTFILEEXTENSION, &
|
|
|
|
|
status='old', position='rewind', action='read',iostat=myStat)
|
|
|
|
|
do
|
|
|
|
|
read (fileUnit,'(A)',END=100) line
|
2023-07-18 19:01:41 +05:30
|
|
|
|
if (index(trim(IO_lc(line)),'solver') == 1) then
|
2020-01-25 13:42:09 +05:30
|
|
|
|
read (fileUnit,'(A)',END=100) line ! next line
|
|
|
|
|
s = verify(line, ' ') ! start of first chunk
|
|
|
|
|
s = s + verify(line(s+1:),' ') ! start of second chunk
|
|
|
|
|
e = s + scan (line(s+1:),' ') ! end of second chunk
|
|
|
|
|
solverIsSymmetric = line(s:e) /= '1'
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
|
|
|
|
end do
|
2020-01-25 13:42:09 +05:30
|
|
|
|
100 close(fileUnit)
|
|
|
|
|
|
|
|
|
|
end function solverIsSymmetric
|
|
|
|
|
|
2012-03-09 01:55:28 +05:30
|
|
|
|
end module DAMASK_interface
|
2009-08-31 20:51:15 +05:30
|
|
|
|
|
2023-01-19 22:07:45 +05:30
|
|
|
|
#include "../result.f90"
|
2022-04-24 22:20:23 +05:30
|
|
|
|
#include "../config.f90"
|
|
|
|
|
#include "../LAPACK_interface.f90"
|
|
|
|
|
#include "../math.f90"
|
|
|
|
|
#include "../rotations.f90"
|
|
|
|
|
#include "../polynomials.f90"
|
2022-12-08 02:13:05 +05:30
|
|
|
|
#include "../tables.f90"
|
2023-07-15 23:58:57 +05:30
|
|
|
|
#include "../crystal.f90"
|
2022-05-13 13:29:09 +05:30
|
|
|
|
#include "element.f90"
|
2022-04-24 22:20:23 +05:30
|
|
|
|
#include "../geometry_plastic_nonlocal.f90"
|
|
|
|
|
#include "../discretization.f90"
|
|
|
|
|
#include "discretization_Marc.f90"
|
|
|
|
|
#include "../material.f90"
|
|
|
|
|
#include "../phase.f90"
|
|
|
|
|
#include "../phase_mechanical.f90"
|
|
|
|
|
#include "../phase_mechanical_elastic.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_none.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_isotropic.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_phenopowerlaw.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_kinehardening.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_dislotwin.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_dislotungsten.f90"
|
|
|
|
|
#include "../phase_mechanical_plastic_nonlocal.f90"
|
|
|
|
|
#include "../phase_mechanical_eigen.f90"
|
|
|
|
|
#include "../phase_mechanical_eigen_thermalexpansion.f90"
|
|
|
|
|
#include "../phase_thermal.f90"
|
2023-07-18 07:42:57 +05:30
|
|
|
|
#include "../phase_thermal_source_dissipation.f90"
|
|
|
|
|
#include "../phase_thermal_source_externalheat.f90"
|
2022-04-24 22:20:23 +05:30
|
|
|
|
#include "../phase_damage.f90"
|
|
|
|
|
#include "../phase_damage_isobrittle.f90"
|
|
|
|
|
#include "../phase_damage_anisobrittle.f90"
|
|
|
|
|
#include "../homogenization.f90"
|
|
|
|
|
#include "../homogenization_mechanical.f90"
|
|
|
|
|
#include "../homogenization_mechanical_pass.f90"
|
|
|
|
|
#include "../homogenization_mechanical_isostrain.f90"
|
|
|
|
|
#include "../homogenization_mechanical_RGC.f90"
|
|
|
|
|
#include "../homogenization_thermal.f90"
|
|
|
|
|
#include "../homogenization_thermal_pass.f90"
|
|
|
|
|
#include "../homogenization_thermal_isotemperature.f90"
|
|
|
|
|
#include "../homogenization_damage.f90"
|
|
|
|
|
#include "../homogenization_damage_pass.f90"
|
2022-04-29 18:20:27 +05:30
|
|
|
|
#include "materialpoint_Marc.f90"
|
2009-03-04 17:18:54 +05:30
|
|
|
|
|
2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
!> @brief This is the MSC.Marc user subroutine for defining material behavior
|
|
|
|
|
!> @details (1) F,R,U are only available for continuum and membrane elements (not for
|
|
|
|
|
!> @details shells and beams).
|
|
|
|
|
!> @details
|
2013-04-09 15:38:00 +05:30
|
|
|
|
!> @details (2) Use the -> 'Plasticity,3' card(=update+finite+large disp+constant d)
|
|
|
|
|
!> @details in the parameter section of input deck (updated Lagrangian formulation).
|
2013-03-01 17:18:29 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2013-04-09 15:38:00 +05:30
|
|
|
|
subroutine hypela2(d,g,e,de,s,t,dt,ngens,m,nn,kcus,matus,ndi,nshear,disp, &
|
|
|
|
|
dispt,coord,ffn,frotn,strechn,eigvn,ffn1,frotn1, &
|
|
|
|
|
strechn1,eigvn1,ncrd,itel,ndeg,ndm,nnode, &
|
|
|
|
|
jtype,lclass,ifr,ifu)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
use prec
|
|
|
|
|
use DAMASK_interface
|
2020-08-15 19:32:10 +05:30
|
|
|
|
use config
|
2020-06-19 04:35:44 +05:30
|
|
|
|
use YAML_types
|
2022-05-02 13:21:10 +05:30
|
|
|
|
use discretization_Marc
|
2020-06-16 10:04:12 +05:30
|
|
|
|
use homogenization
|
2022-05-02 13:21:10 +05:30
|
|
|
|
use materialpoint_Marc
|
2022-05-13 12:13:24 +05:30
|
|
|
|
use OMP_LIB
|
2020-06-16 10:04:12 +05:30
|
|
|
|
|
2022-06-22 02:16:54 +05:30
|
|
|
|
implicit none(type,external)
|
2022-06-27 14:07:41 +05:30
|
|
|
|
integer(pI64), intent(in) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
ngens, & !< size of stress-strain law
|
|
|
|
|
nn, & !< integration point number
|
|
|
|
|
ndi, & !< number of direct components
|
|
|
|
|
nshear, & !< number of shear components
|
|
|
|
|
ncrd, & !< number of coordinates
|
|
|
|
|
itel, & !< dimension of F and R, either 2 or 3
|
|
|
|
|
ndeg, & !< number of degrees of freedom
|
|
|
|
|
ndm, & !< not specified in MSC.Marc 2012 Manual D
|
|
|
|
|
nnode, & !< number of nodes per element
|
|
|
|
|
jtype, & !< element type
|
|
|
|
|
ifr, & !< set to 1 if R has been calculated
|
|
|
|
|
ifu !< set to 1 if stretch has been calculated
|
2022-06-27 14:07:41 +05:30
|
|
|
|
integer(pI64), dimension(2), intent(in) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
m, & !< (1) user element number, (2) internal element number
|
|
|
|
|
matus, & !< (1) user material identification number, (2) internal material identification number
|
|
|
|
|
kcus, & !< (1) layer number, (2) internal layer number
|
|
|
|
|
lclass !< (1) element class, (2) 0: displacement, 1: low order Herrmann, 2: high order Herrmann
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(*), intent(in) :: & ! has dimension(1) according to MSC.Marc 2012 Manual D, but according to example hypela2.f dimension(*)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
e, & !< total elastic strain
|
|
|
|
|
de, & !< increment of strain
|
|
|
|
|
dt !< increment of state variables
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(itel), intent(in) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
strechn, & !< square of principal stretch ratios, lambda(i) at t=n
|
|
|
|
|
strechn1 !< square of principal stretch ratios, lambda(i) at t=n+1
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(3,3), intent(in) :: & ! has dimension(itel,*) according to MSC.Marc 2012 Manual D, but we alway assume dimension(3,3)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
ffn, & !< deformation gradient at t=n
|
|
|
|
|
ffn1 !< deformation gradient at t=n+1
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(itel,*), intent(in) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
frotn, & !< rotation tensor at t=n
|
|
|
|
|
eigvn, & !< i principal direction components for j eigenvalues at t=n
|
|
|
|
|
frotn1, & !< rotation tensor at t=n+1
|
|
|
|
|
eigvn1 !< i principal direction components for j eigenvalues at t=n+1
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(ndeg,*), intent(in) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
disp, & !< incremental displacements
|
|
|
|
|
dispt !< displacements at t=n (at assembly, lovl=4) and displacements at t=n+1 (at stress recovery, lovl=6)
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(ncrd,*), intent(in) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
coord !< coordinates
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(*), intent(inout) :: & ! according to MSC.Marc 2012 Manual D
|
2020-06-16 10:04:12 +05:30
|
|
|
|
t !< state variables (comes in at t=n, must be updated to have state variables at t=n+1)
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(ndi+nshear), intent(out) :: & ! has dimension(*) according to MSC.Marc 2012 Manual D, but we need to loop over it
|
2020-06-16 10:04:12 +05:30
|
|
|
|
s, & !< stress - should be updated by user
|
|
|
|
|
g !< change in stress due to temperature effects
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(ngens,ngens), intent(out) :: & ! according to MSC.Marc 2012 Manual D, but according to example hypela2.f dimension(ngens,*)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
d !< stress-strain law to be formed
|
2008-03-15 03:02:57 +05:30
|
|
|
|
|
2013-04-09 15:38:00 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2009-03-04 17:18:54 +05:30
|
|
|
|
! Marc common blocks are in fixed format so they have to be reformated to free format (f90)
|
|
|
|
|
! Beware of changes in newer Marc versions
|
2013-04-22 20:11:33 +05:30
|
|
|
|
|
2022-04-24 22:20:23 +05:30
|
|
|
|
#include QUOTE(PASTE(include/concom,MARC4DAMASK)) ! concom is needed for inc, lovl
|
|
|
|
|
#include QUOTE(PASTE(include/creeps,MARC4DAMASK)) ! creeps is needed for timinc (time increment)
|
2009-03-04 17:18:54 +05:30
|
|
|
|
|
2020-06-16 10:04:12 +05:30
|
|
|
|
logical :: cutBack
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(6) :: stress
|
|
|
|
|
real(pREAL), dimension(6,6) :: ddsdde
|
2021-04-11 13:16:11 +05:30
|
|
|
|
integer :: computationMode, i, node, CPnodeID
|
2021-02-02 13:33:41 +05:30
|
|
|
|
integer(pI32) :: defaultNumThreadsInt !< default value set by Marc
|
2020-06-16 10:32:29 +05:30
|
|
|
|
|
2022-01-13 12:07:38 +05:30
|
|
|
|
integer, save :: &
|
|
|
|
|
theInc = -1, & !< needs description
|
|
|
|
|
lastLovl = 0 !< lovl in previous call to marc hypela2
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), save :: &
|
|
|
|
|
theTime = 0.0_pREAL, & !< needs description
|
|
|
|
|
theDelta = 0.0_pREAL
|
2020-06-16 10:32:29 +05:30
|
|
|
|
logical, save :: &
|
|
|
|
|
lastIncConverged = .false., & !< needs description
|
|
|
|
|
outdatedByNewInc = .false., & !< needs description
|
2023-02-05 19:28:24 +05:30
|
|
|
|
materialpoint_init_done = .false. !< remember whether init has been done already
|
|
|
|
|
|
2020-06-16 10:04:12 +05:30
|
|
|
|
|
2020-07-03 20:15:11 +05:30
|
|
|
|
defaultNumThreadsInt = omp_get_num_threads() ! remember number of threads set by Marc
|
2021-02-02 13:33:41 +05:30
|
|
|
|
call omp_set_num_threads(1_pI32) ! no openMP
|
2020-07-03 20:15:11 +05:30
|
|
|
|
|
2022-04-24 21:05:59 +05:30
|
|
|
|
if (.not. materialpoint_init_done) then
|
|
|
|
|
materialpoint_init_done = .true.
|
2023-02-05 19:28:24 +05:30
|
|
|
|
call materialpoint_initAll()
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-06-16 10:04:12 +05:30
|
|
|
|
|
|
|
|
|
computationMode = 0 ! save initialization value, since it does not result in any calculation
|
|
|
|
|
if (lovl == 4 ) then ! jacobian requested by marc
|
|
|
|
|
if (timinc < theDelta .and. theInc == inc .and. lastLovl /= lovl) & ! first after cutback
|
2022-04-24 21:05:59 +05:30
|
|
|
|
computationMode = materialpoint_RESTOREJACOBIAN
|
2020-06-16 10:04:12 +05:30
|
|
|
|
elseif (lovl == 6) then ! stress requested by marc
|
2022-04-24 21:05:59 +05:30
|
|
|
|
computationMode = materialpoint_CALCRESULTS
|
2020-06-16 10:04:12 +05:30
|
|
|
|
if (cptim > theTime .or. inc /= theInc) then ! reached "convergence"
|
|
|
|
|
terminallyIll = .false.
|
|
|
|
|
cycleCounter = -1 ! first calc step increments this to cycle = 0
|
|
|
|
|
if (inc == 0) then ! >> start of analysis <<
|
|
|
|
|
lastIncConverged = .false.
|
|
|
|
|
outdatedByNewInc = .false.
|
|
|
|
|
lastLovl = lovl ! pretend that this is NOT the first after a lovl change
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(a,i6,1x,i2)', '<< HYPELA2 >> start of analysis..! ',m(1),nn
|
2020-06-16 10:04:12 +05:30
|
|
|
|
else if (inc - theInc > 1) then ! >> restart of broken analysis <<
|
|
|
|
|
lastIncConverged = .false.
|
|
|
|
|
outdatedByNewInc = .false.
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(a,i6,1x,i2)', '<< HYPELA2 >> restart of analysis..! ',m(1),nn
|
2020-06-16 10:04:12 +05:30
|
|
|
|
else ! >> just the next inc <<
|
|
|
|
|
lastIncConverged = .true.
|
|
|
|
|
outdatedByNewInc = .true.
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(a,i6,1x,i2)', '<< HYPELA2 >> new increment..! ',m(1),nn
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-06-16 10:04:12 +05:30
|
|
|
|
else if ( timinc < theDelta ) then ! >> cutBack <<
|
|
|
|
|
lastIncConverged = .false.
|
|
|
|
|
outdatedByNewInc = .false.
|
|
|
|
|
terminallyIll = .false.
|
|
|
|
|
cycleCounter = -1 ! first calc step increments this to cycle = 0
|
2020-09-17 22:58:41 +05:30
|
|
|
|
print'(a,i6,1x,i2)', '<< HYPELA2 >> cutback detected..! ',m(1),nn
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if ! convergence treatment end
|
2020-06-16 10:04:12 +05:30
|
|
|
|
flush(6)
|
|
|
|
|
|
|
|
|
|
if (lastLovl /= lovl) then
|
|
|
|
|
cycleCounter = cycleCounter + 1
|
|
|
|
|
!mesh_cellnode = mesh_build_cellnodes() ! update cell node coordinates
|
|
|
|
|
!call mesh_build_ipCoordinates() ! update ip coordinates
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-06-16 10:04:12 +05:30
|
|
|
|
if (outdatedByNewInc) then
|
2022-04-24 21:05:59 +05:30
|
|
|
|
computationMode = ior(computationMode,materialpoint_AGERESULTS)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
outdatedByNewInc = .false.
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-06-16 10:04:12 +05:30
|
|
|
|
if (lastIncConverged) then
|
2022-04-24 21:05:59 +05:30
|
|
|
|
computationMode = ior(computationMode,materialpoint_BACKUPJACOBIAN)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
lastIncConverged = .false.
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-06-16 10:04:12 +05:30
|
|
|
|
|
|
|
|
|
theTime = cptim
|
|
|
|
|
theDelta = timinc
|
|
|
|
|
theInc = inc
|
|
|
|
|
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2020-06-16 10:04:12 +05:30
|
|
|
|
lastLovl = lovl
|
|
|
|
|
|
2022-06-27 14:07:41 +05:30
|
|
|
|
call materialpoint_general(computationMode,ffn,ffn1,t(1),timinc,int(m(1)),int(nn),stress,ddsdde)
|
2020-06-16 10:04:12 +05:30
|
|
|
|
|
|
|
|
|
d = ddsdde(1:ngens,1:ngens)
|
|
|
|
|
s = stress(1:ndi+nshear)
|
2023-06-04 10:52:25 +05:30
|
|
|
|
g = 0.0_pREAL
|
|
|
|
|
if (symmetricSolver) d = 0.5_pREAL*(d+transpose(d))
|
2020-06-16 10:04:12 +05:30
|
|
|
|
|
|
|
|
|
call omp_set_num_threads(defaultNumThreadsInt) ! reset number of threads to stored default value
|
2010-11-19 23:15:27 +05:30
|
|
|
|
|
2012-03-09 01:55:28 +05:30
|
|
|
|
end subroutine hypela2
|
2009-05-07 21:57:36 +05:30
|
|
|
|
|
2008-04-07 20:24:29 +05:30
|
|
|
|
|
2016-05-03 20:36:55 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2017-02-08 14:32:56 +05:30
|
|
|
|
!> @brief calculate internal heat generated due to inelastic energy dissipation
|
2016-05-03 20:36:55 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
subroutine flux(f,ts,n,time)
|
2020-01-25 13:42:09 +05:30
|
|
|
|
use prec
|
2021-01-24 21:34:41 +05:30
|
|
|
|
use homogenization
|
2022-05-03 16:25:27 +05:30
|
|
|
|
use discretization_Marc
|
2016-07-20 12:14:12 +05:30
|
|
|
|
|
2022-06-22 02:16:54 +05:30
|
|
|
|
implicit none(type,external)
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(6), intent(in) :: &
|
2020-01-25 13:42:09 +05:30
|
|
|
|
ts
|
2022-06-27 14:07:41 +05:30
|
|
|
|
integer(pI64), dimension(10), intent(in) :: &
|
2020-01-25 13:42:09 +05:30
|
|
|
|
n
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), intent(in) :: &
|
2020-01-25 13:42:09 +05:30
|
|
|
|
time
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), dimension(2), intent(out) :: &
|
2020-01-25 13:42:09 +05:30
|
|
|
|
f
|
|
|
|
|
|
2022-06-27 14:07:41 +05:30
|
|
|
|
|
|
|
|
|
f(1) = homogenization_f_T(discretization_Marc_FEM2DAMASK_cell(int(n(3)),int(n(1))))
|
2023-06-04 10:52:25 +05:30
|
|
|
|
f(2) = 0.0_pREAL
|
2017-02-08 14:32:56 +05:30
|
|
|
|
|
|
|
|
|
end subroutine flux
|
2016-05-03 20:36:55 +05:30
|
|
|
|
|
|
|
|
|
|
2019-05-05 15:36:55 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2019-06-15 19:51:15 +05:30
|
|
|
|
!> @brief trigger writing of results
|
2020-01-12 05:25:00 +05:30
|
|
|
|
!> @details uedinc is called before each new increment, not at the end of a converged one.
|
|
|
|
|
!> Therefore, storing the last written inc with an 'save' variable is required to avoid writing the
|
|
|
|
|
! same increment multiple times.
|
2019-05-05 15:36:55 +05:30
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
|
subroutine uedinc(inc,incsub)
|
2019-05-15 02:14:38 +05:30
|
|
|
|
use prec
|
2022-05-02 13:21:10 +05:30
|
|
|
|
use materialpoint_Marc
|
|
|
|
|
use discretization_Marc
|
2019-05-05 15:36:55 +05:30
|
|
|
|
|
2022-06-22 02:16:54 +05:30
|
|
|
|
implicit none(type,external)
|
2022-11-17 12:42:27 +05:30
|
|
|
|
|
|
|
|
|
external :: nodvar
|
2022-06-27 14:07:41 +05:30
|
|
|
|
integer(pI64), intent(in) :: inc, incsub
|
|
|
|
|
|
2021-02-02 13:33:41 +05:30
|
|
|
|
integer :: n, nqncomp, nqdatatype
|
2020-01-12 05:25:00 +05:30
|
|
|
|
integer, save :: inc_written
|
2023-06-04 10:52:25 +05:30
|
|
|
|
real(pREAL), allocatable, dimension(:,:) :: d_n
|
2022-04-24 22:20:23 +05:30
|
|
|
|
#include QUOTE(PASTE(include/creeps,MARC4DAMASK)) ! creeps is needed for timinc (time increment)
|
2019-05-05 15:36:55 +05:30
|
|
|
|
|
2021-02-02 13:33:41 +05:30
|
|
|
|
|
2020-01-12 05:25:00 +05:30
|
|
|
|
if (inc > inc_written) then
|
2021-04-11 00:22:46 +05:30
|
|
|
|
allocate(d_n(3,count(discretization_Marc_FEM2DAMASK_node /= -1)))
|
|
|
|
|
do n = lbound(discretization_Marc_FEM2DAMASK_node,1), ubound(discretization_Marc_FEM2DAMASK_node,1)
|
|
|
|
|
if (discretization_Marc_FEM2DAMASK_node(n) /= -1) then
|
|
|
|
|
call nodvar(1,n,d_n(1:3,discretization_Marc_FEM2DAMASK_node(n)),nqncomp,nqdatatype)
|
2023-06-04 10:52:25 +05:30
|
|
|
|
if (nqncomp == 2) d_n(3,discretization_Marc_FEM2DAMASK_node(n)) = 0.0_pREAL
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
|
|
|
|
end do
|
2021-02-02 13:33:41 +05:30
|
|
|
|
|
2022-05-03 16:25:27 +05:30
|
|
|
|
call discretization_Marc_UpdateNodeAndIpCoords(d_n)
|
2023-01-19 22:07:45 +05:30
|
|
|
|
call materialpoint_result(int(inc),cptim)
|
2021-02-02 13:33:41 +05:30
|
|
|
|
|
2022-06-27 14:07:41 +05:30
|
|
|
|
inc_written = int(inc)
|
2022-12-02 00:14:53 +05:30
|
|
|
|
end if
|
2019-05-05 15:36:55 +05:30
|
|
|
|
|
|
|
|
|
end subroutine uedinc
|