2020-07-15 18:05:21 +05:30
!----------------------------------------------------------------------------------------------------
2020-09-14 00:30:34 +05:30
!> @brief internal microstructure state for all plasticity constitutive models
2020-07-15 18:05:21 +05:30
!----------------------------------------------------------------------------------------------------
2020-11-03 05:19:17 +05:30
submodule ( constitutive ) constitutive_mech
2020-07-09 04:31:08 +05:30
2020-12-15 22:15:11 +05:30
integer ( kind ( ELASTICITY_undefined_ID ) ) , dimension ( : ) , allocatable :: &
phase_elasticity !< elasticity of each phase
integer ( kind ( SOURCE_undefined_ID ) ) , dimension ( : , : ) , allocatable :: &
phase_stiffnessDegradation !< active stiffness degradation mechanisms of each phase
2020-07-09 04:31:08 +05:30
interface
2020-08-15 19:32:10 +05:30
module function plastic_none_init ( ) result ( myPlasticity )
logical , dimension ( : ) , allocatable :: &
myPlasticity
end function plastic_none_init
module function plastic_isotropic_init ( ) result ( myPlasticity )
logical , dimension ( : ) , allocatable :: &
myPlasticity
end function plastic_isotropic_init
module function plastic_phenopowerlaw_init ( ) result ( myPlasticity )
logical , dimension ( : ) , allocatable :: &
myPlasticity
end function plastic_phenopowerlaw_init
module function plastic_kinehardening_init ( ) result ( myPlasticity )
logical , dimension ( : ) , allocatable :: &
myPlasticity
end function plastic_kinehardening_init
module function plastic_dislotwin_init ( ) result ( myPlasticity )
logical , dimension ( : ) , allocatable :: &
myPlasticity
end function plastic_dislotwin_init
2020-11-29 16:28:39 +05:30
module function plastic_dislotungsten_init ( ) result ( myPlasticity )
2020-08-15 19:32:10 +05:30
logical , dimension ( : ) , allocatable :: &
myPlasticity
2020-11-29 16:28:39 +05:30
end function plastic_dislotungsten_init
2020-08-15 19:32:10 +05:30
module function plastic_nonlocal_init ( ) result ( myPlasticity )
logical , dimension ( : ) , allocatable :: &
myPlasticity
end function plastic_nonlocal_init
2020-07-09 04:31:08 +05:30
module subroutine plastic_isotropic_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLp_dMp !< derivative of Lp with respect to the Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_isotropic_LpAndItsTangent
pure module subroutine plastic_phenopowerlaw_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLp_dMp !< derivative of Lp with respect to the Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_phenopowerlaw_LpAndItsTangent
pure module subroutine plastic_kinehardening_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLp_dMp !< derivative of Lp with respect to the Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_kinehardening_LpAndItsTangent
module subroutine plastic_dislotwin_LpAndItsTangent ( Lp , dLp_dMp , Mp , T , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLp_dMp !< derivative of Lp with respect to the Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
T
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_dislotwin_LpAndItsTangent
2020-11-29 16:28:39 +05:30
pure module subroutine plastic_dislotungsten_LpAndItsTangent ( Lp , dLp_dMp , Mp , T , instance , of )
2020-07-09 04:31:08 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLp_dMp !< derivative of Lp with respect to the Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
T
integer , intent ( in ) :: &
instance , &
of
2020-11-29 16:28:39 +05:30
end subroutine plastic_dislotungsten_LpAndItsTangent
2020-07-09 04:31:08 +05:30
module subroutine plastic_nonlocal_LpAndItsTangent ( Lp , dLp_dMp , &
Mp , Temperature , instance , of , ip , el )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLp_dMp !< derivative of Lp with respect to the Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
Temperature
integer , intent ( in ) :: &
instance , &
of , &
ip , & !< current integration point
el !< current element number
end subroutine plastic_nonlocal_LpAndItsTangent
2020-12-20 21:02:33 +05:30
module subroutine plastic_isotropic_dotState ( Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_isotropic_dotState
module subroutine plastic_phenopowerlaw_dotState ( Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_phenopowerlaw_dotState
module subroutine plastic_kinehardening_dotState ( Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_kinehardening_dotState
module subroutine plastic_dislotwin_dotState ( Mp , T , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
T
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_dislotwin_dotState
module subroutine plastic_disloTungsten_dotState ( Mp , T , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
T
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_disloTungsten_dotState
module subroutine plastic_nonlocal_dotState ( Mp , F , Fp , Temperature , timestep , &
instance , of , ip , el )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< MandelStress
real ( pReal ) , dimension ( 3 , 3 , homogenization_maxNconstituents , discretization_nIPs , discretization_Nelems ) , intent ( in ) :: &
F , & !< deformation gradient
Fp !< plastic deformation gradient
real ( pReal ) , intent ( in ) :: &
Temperature , & !< temperature
timestep !< substepped crystallite time increment
integer , intent ( in ) :: &
instance , &
of , &
ip , & !< current integration point
el !< current element number
end subroutine plastic_nonlocal_dotState
2020-07-09 04:31:08 +05:30
module subroutine plastic_dislotwin_dependentState ( T , instance , of )
integer , intent ( in ) :: &
instance , &
of
real ( pReal ) , intent ( in ) :: &
T
end subroutine plastic_dislotwin_dependentState
2020-11-29 16:28:39 +05:30
module subroutine plastic_dislotungsten_dependentState ( instance , of )
2020-07-09 04:31:08 +05:30
integer , intent ( in ) :: &
instance , &
of
2020-11-29 16:28:39 +05:30
end subroutine plastic_dislotungsten_dependentState
2020-07-09 04:31:08 +05:30
module subroutine plastic_nonlocal_dependentState ( F , Fp , instance , of , ip , el )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
2020-07-15 18:05:21 +05:30
F , & !< deformation gradient
Fp !< plastic deformation gradient
2020-07-09 04:31:08 +05:30
integer , intent ( in ) :: &
instance , &
of , &
2020-07-15 18:05:21 +05:30
ip , & !< current integration point
el !< current element number
2020-07-09 04:31:08 +05:30
end subroutine plastic_nonlocal_dependentState
2020-12-20 21:41:43 +05:30
module subroutine plastic_kinehardening_deltaState ( Mp , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_kinehardening_deltaState
module subroutine plastic_nonlocal_deltaState ( Mp , instance , of , ip , el )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp
integer , intent ( in ) :: &
instance , &
of , &
ip , &
el
end subroutine plastic_nonlocal_deltaState
2020-07-12 18:52:40 +05:30
module subroutine plastic_isotropic_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_isotropic_results
module subroutine plastic_phenopowerlaw_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_phenopowerlaw_results
module subroutine plastic_kinehardening_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_kinehardening_results
module subroutine plastic_dislotwin_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_dislotwin_results
2020-11-29 16:28:39 +05:30
module subroutine plastic_dislotungsten_results ( instance , group )
2020-07-12 18:52:40 +05:30
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
2020-11-29 16:28:39 +05:30
end subroutine plastic_dislotungsten_results
2020-07-12 18:52:40 +05:30
module subroutine plastic_nonlocal_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_nonlocal_results
2020-07-09 04:31:08 +05:30
end interface
contains
!--------------------------------------------------------------------------------------------------
2020-11-05 21:19:59 +05:30
!> @brief Initialize mechanical field related constitutive models
!> @details Initialize elasticity, plasticity and stiffness degradation models.
2020-07-09 04:31:08 +05:30
!--------------------------------------------------------------------------------------------------
2020-11-03 02:09:33 +05:30
module subroutine mech_init
2020-07-09 04:31:08 +05:30
2020-11-03 02:09:33 +05:30
integer :: &
p , &
stiffDegradationCtr
class ( tNode ) , pointer :: &
phases , &
phase , &
2020-11-03 03:16:46 +05:30
mech , &
2020-11-03 02:09:33 +05:30
elastic , &
stiffDegradation
2020-08-15 19:32:10 +05:30
2020-11-03 05:19:17 +05:30
print '(/,a)' , ' <<<+- constitutive_mech init -+>>>'
2020-09-14 00:30:34 +05:30
2020-11-03 02:09:33 +05:30
!-------------------------------------------------------------------------------------------------
! initialize elasticity (hooke) !ToDO: Maybe move to elastic submodule along with function homogenizedC?
2020-09-13 14:09:17 +05:30
phases = > config_material % get ( 'phase' )
2020-11-03 02:09:33 +05:30
allocate ( phase_elasticity ( phases % length ) , source = ELASTICITY_undefined_ID )
allocate ( phase_elasticityInstance ( phases % length ) , source = 0 )
allocate ( phase_NstiffnessDegradations ( phases % length ) , source = 0 )
do p = 1 , phases % length
phase = > phases % get ( p )
2020-11-18 01:54:40 +05:30
mech = > phase % get ( 'mechanics' )
2020-11-03 03:16:46 +05:30
elastic = > mech % get ( 'elasticity' )
2020-11-03 02:09:33 +05:30
if ( elastic % get_asString ( 'type' ) == 'hooke' ) then
phase_elasticity ( p ) = ELASTICITY_HOOKE_ID
else
call IO_error ( 200 , ext_msg = elastic % get_asString ( 'type' ) )
endif
2020-11-05 21:19:59 +05:30
stiffDegradation = > mech % get ( 'stiffness_degradation' , defaultVal = emptyList ) ! check for stiffness degradation mechanisms
2020-11-03 02:09:33 +05:30
phase_NstiffnessDegradations ( p ) = stiffDegradation % length
enddo
allocate ( phase_stiffnessDegradation ( maxval ( phase_NstiffnessDegradations ) , phases % length ) , &
source = STIFFNESS_DEGRADATION_undefined_ID )
if ( maxVal ( phase_NstiffnessDegradations ) / = 0 ) then
do p = 1 , phases % length
phase = > phases % get ( p )
2020-11-18 01:54:40 +05:30
mech = > phase % get ( 'mechanics' )
2020-11-03 03:16:46 +05:30
stiffDegradation = > mech % get ( 'stiffness_degradation' , defaultVal = emptyList )
2020-11-03 02:09:33 +05:30
do stiffDegradationCtr = 1 , stiffDegradation % length
if ( stiffDegradation % get_asString ( stiffDegradationCtr ) == 'damage' ) &
phase_stiffnessDegradation ( stiffDegradationCtr , p ) = STIFFNESS_DEGRADATION_damage_ID
enddo
enddo
endif
2020-08-15 19:32:10 +05:30
2020-11-03 05:19:17 +05:30
! initialize plasticity
2020-08-15 19:32:10 +05:30
allocate ( plasticState ( phases % length ) )
allocate ( phase_plasticity ( phases % length ) , source = PLASTICITY_undefined_ID )
allocate ( phase_plasticityInstance ( phases % length ) , source = 0 )
allocate ( phase_localPlasticity ( phases % length ) , source = . true . )
where ( plastic_none_init ( ) ) phase_plasticity = PLASTICITY_NONE_ID
where ( plastic_isotropic_init ( ) ) phase_plasticity = PLASTICITY_ISOTROPIC_ID
where ( plastic_phenopowerlaw_init ( ) ) phase_plasticity = PLASTICITY_PHENOPOWERLAW_ID
where ( plastic_kinehardening_init ( ) ) phase_plasticity = PLASTICITY_KINEHARDENING_ID
where ( plastic_dislotwin_init ( ) ) phase_plasticity = PLASTICITY_DISLOTWIN_ID
2020-11-29 16:28:39 +05:30
where ( plastic_dislotungsten_init ( ) ) phase_plasticity = PLASTICITY_DISLOTUNGSTEN_ID
2020-08-15 19:32:10 +05:30
where ( plastic_nonlocal_init ( ) ) phase_plasticity = PLASTICITY_NONLOCAL_ID
do p = 1 , phases % length
2020-11-03 03:16:46 +05:30
phase_elasticityInstance ( p ) = count ( phase_elasticity ( 1 : p ) == phase_elasticity ( p ) )
2020-08-15 19:32:10 +05:30
phase_plasticityInstance ( p ) = count ( phase_plasticity ( 1 : p ) == phase_plasticity ( p ) )
2020-09-14 00:30:34 +05:30
enddo
2020-08-15 19:32:10 +05:30
2020-11-03 02:09:33 +05:30
end subroutine mech_init
2020-07-09 04:31:08 +05:30
2020-07-10 18:29:07 +05:30
2020-08-15 19:32:10 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief checks if a plastic module is active or not
!--------------------------------------------------------------------------------------------------
module function plastic_active ( plastic_label ) result ( active_plastic )
character ( len = * ) , intent ( in ) :: plastic_label !< type of plasticity model
logical , dimension ( : ) , allocatable :: active_plastic
class ( tNode ) , pointer :: &
phases , &
phase , &
2020-11-03 03:16:46 +05:30
mech , &
2020-08-15 19:32:10 +05:30
pl
integer :: p
2020-09-13 14:09:17 +05:30
phases = > config_material % get ( 'phase' )
2020-08-15 19:32:10 +05:30
allocate ( active_plastic ( phases % length ) , source = . false . )
do p = 1 , phases % length
phase = > phases % get ( p )
2020-11-18 01:54:40 +05:30
mech = > phase % get ( 'mechanics' )
2020-11-03 03:16:46 +05:30
pl = > mech % get ( 'plasticity' )
2020-08-15 19:32:10 +05:30
if ( pl % get_asString ( 'type' ) == plastic_label ) active_plastic ( p ) = . true .
enddo
end function plastic_active
2020-11-03 02:09:33 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief returns the 2nd Piola-Kirchhoff stress tensor and its tangent with respect to
!> the elastic and intermediate deformation gradients using Hooke's law
!--------------------------------------------------------------------------------------------------
2020-11-04 17:13:52 +05:30
module subroutine constitutive_hooke_SandItsTangents ( S , dS_dFe , dS_dFi , &
2020-11-03 02:09:33 +05:30
Fe , Fi , ipc , ip , el )
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
Fe , & !< elastic deformation gradient
Fi !< intermediate deformation gradient
real ( pReal ) , intent ( out ) , dimension ( 3 , 3 ) :: &
S !< 2nd Piola-Kirchhoff stress tensor in lattice configuration
real ( pReal ) , intent ( out ) , dimension ( 3 , 3 , 3 , 3 ) :: &
dS_dFe , & !< derivative of 2nd P-K stress with respect to elastic deformation gradient
dS_dFi !< derivative of 2nd P-K stress with respect to intermediate deformation gradient
real ( pReal ) , dimension ( 3 , 3 ) :: E
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) :: C
integer :: &
ho , & !< homogenization
d !< counter in degradation loop
integer :: &
i , j
ho = material_homogenizationAt ( el )
C = math_66toSym3333 ( constitutive_homogenizedC ( ipc , ip , el ) )
DegradationLoop : do d = 1 , phase_NstiffnessDegradations ( material_phaseAt ( ipc , el ) )
degradationType : select case ( phase_stiffnessDegradation ( d , material_phaseAt ( ipc , el ) ) )
case ( STIFFNESS_DEGRADATION_damage_ID ) degradationType
2020-12-16 00:25:55 +05:30
C = C * damage ( ho ) % p ( material_homogenizationMemberAt ( ip , el ) ) ** 2
2020-11-03 02:09:33 +05:30
end select degradationType
enddo DegradationLoop
E = 0.5_pReal * ( matmul ( transpose ( Fe ) , Fe ) - math_I3 ) !< Green-Lagrange strain in unloaded configuration
S = math_mul3333xx33 ( C , matmul ( matmul ( transpose ( Fi ) , E ) , Fi ) ) !< 2PK stress in lattice configuration in work conjugate with GL strain pulled back to lattice configuration
do i = 1 , 3 ; do j = 1 , 3
dS_dFe ( i , j , 1 : 3 , 1 : 3 ) = matmul ( Fe , matmul ( matmul ( Fi , C ( i , j , 1 : 3 , 1 : 3 ) ) , transpose ( Fi ) ) ) !< dS_ij/dFe_kl = C_ijmn * Fi_lm * Fi_on * Fe_ko
dS_dFi ( i , j , 1 : 3 , 1 : 3 ) = 2.0_pReal * matmul ( matmul ( E , Fi ) , C ( i , j , 1 : 3 , 1 : 3 ) ) !< dS_ij/dFi_kl = C_ijln * E_km * Fe_mn
enddo ; enddo
end subroutine constitutive_hooke_SandItsTangents
2020-07-09 04:31:08 +05:30
!--------------------------------------------------------------------------------------------------
2020-07-12 20:14:26 +05:30
!> @brief calls microstructure function of the different plasticity constitutive models
2020-07-09 04:31:08 +05:30
!--------------------------------------------------------------------------------------------------
2020-07-12 20:14:26 +05:30
module subroutine constitutive_plastic_dependentState ( F , Fp , ipc , ip , el )
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
F , & !< elastic deformation gradient
Fp !< plastic deformation gradient
2020-07-10 18:43:56 +05:30
2020-07-09 04:31:08 +05:30
integer :: &
ho , & !< homogenization
tme , & !< thermal member position
instance , of
ho = material_homogenizationAt ( el )
2020-12-15 22:15:11 +05:30
tme = material_homogenizationMemberAt ( ip , el )
2020-07-09 04:31:08 +05:30
of = material_phasememberAt ( ipc , ip , el )
instance = phase_plasticityInstance ( material_phaseAt ( ipc , el ) )
plasticityType : select case ( phase_plasticity ( material_phaseAt ( ipc , el ) ) )
case ( PLASTICITY_DISLOTWIN_ID ) plasticityType
call plastic_dislotwin_dependentState ( temperature ( ho ) % p ( tme ) , instance , of )
2020-08-15 19:32:10 +05:30
case ( PLASTICITY_DISLOTUNGSTEN_ID ) plasticityType
2020-11-29 16:28:39 +05:30
call plastic_dislotungsten_dependentState ( instance , of )
2020-07-09 04:31:08 +05:30
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
call plastic_nonlocal_dependentState ( F , Fp , instance , of , ip , el )
end select plasticityType
2020-07-12 20:14:26 +05:30
end subroutine constitutive_plastic_dependentState
2020-07-09 04:31:08 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief contains the constitutive equation for calculating the velocity gradient
! ToDo: Discuss whether it makes sense if crystallite handles the configuration conversion, i.e.
! Mp in, dLp_dMp out
!--------------------------------------------------------------------------------------------------
2020-07-12 20:14:26 +05:30
module subroutine constitutive_plastic_LpAndItsTangents ( Lp , dLp_dS , dLp_dFi , &
S , Fi , ipc , ip , el )
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
S , & !< 2nd Piola-Kirchhoff stress
Fi !< intermediate deformation gradient
real ( pReal ) , intent ( out ) , dimension ( 3 , 3 ) :: &
Lp !< plastic velocity gradient
real ( pReal ) , intent ( out ) , dimension ( 3 , 3 , 3 , 3 ) :: &
dLp_dS , &
dLp_dFi !< derivative of Lp with respect to Fi
2020-07-10 18:43:56 +05:30
2020-07-09 04:31:08 +05:30
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) :: &
dLp_dMp !< derivative of Lp with respect to Mandel stress
real ( pReal ) , dimension ( 3 , 3 ) :: &
Mp !< Mandel stress work conjugate with Lp
integer :: &
ho , & !< homogenization
tme !< thermal member position
integer :: &
i , j , instance , of
ho = material_homogenizationAt ( el )
2020-12-15 22:15:11 +05:30
tme = material_homogenizationMemberAt ( ip , el )
2020-07-09 04:31:08 +05:30
Mp = matmul ( matmul ( transpose ( Fi ) , Fi ) , S )
of = material_phasememberAt ( ipc , ip , el )
instance = phase_plasticityInstance ( material_phaseAt ( ipc , el ) )
plasticityType : select case ( phase_plasticity ( material_phaseAt ( ipc , el ) ) )
case ( PLASTICITY_NONE_ID ) plasticityType
Lp = 0.0_pReal
dLp_dMp = 0.0_pReal
case ( PLASTICITY_ISOTROPIC_ID ) plasticityType
2020-08-15 19:32:10 +05:30
call plastic_isotropic_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
2020-07-09 04:31:08 +05:30
case ( PLASTICITY_PHENOPOWERLAW_ID ) plasticityType
call plastic_phenopowerlaw_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
case ( PLASTICITY_KINEHARDENING_ID ) plasticityType
call plastic_kinehardening_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
2020-08-15 19:32:10 +05:30
call plastic_nonlocal_LpAndItsTangent ( Lp , dLp_dMp , Mp , temperature ( ho ) % p ( tme ) , instance , of , ip , el )
2020-07-09 04:31:08 +05:30
case ( PLASTICITY_DISLOTWIN_ID ) plasticityType
2020-08-15 19:32:10 +05:30
call plastic_dislotwin_LpAndItsTangent ( Lp , dLp_dMp , Mp , temperature ( ho ) % p ( tme ) , instance , of )
2020-07-09 04:31:08 +05:30
2020-08-15 19:32:10 +05:30
case ( PLASTICITY_DISLOTUNGSTEN_ID ) plasticityType
2020-11-29 16:28:39 +05:30
call plastic_dislotungsten_LpAndItsTangent ( Lp , dLp_dMp , Mp , temperature ( ho ) % p ( tme ) , instance , of )
2020-07-09 04:31:08 +05:30
end select plasticityType
do i = 1 , 3 ; do j = 1 , 3
dLp_dFi ( i , j , 1 : 3 , 1 : 3 ) = matmul ( matmul ( Fi , S ) , transpose ( dLp_dMp ( i , j , 1 : 3 , 1 : 3 ) ) ) + &
matmul ( matmul ( Fi , dLp_dMp ( i , j , 1 : 3 , 1 : 3 ) ) , S )
dLp_dS ( i , j , 1 : 3 , 1 : 3 ) = matmul ( matmul ( transpose ( Fi ) , Fi ) , dLp_dMp ( i , j , 1 : 3 , 1 : 3 ) ) ! ToDo: @PS: why not: dLp_dMp:(FiT Fi)
enddo ; enddo
2020-07-12 20:14:26 +05:30
end subroutine constitutive_plastic_LpAndItsTangents
2020-07-09 04:31:08 +05:30
2020-12-20 21:02:33 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief contains the constitutive equation for calculating the rate of change of microstructure
!--------------------------------------------------------------------------------------------------
function constitutive_collectDotState ( S , FArray , Fi , FpArray , subdt , ipc , ip , el , phase , of ) result ( broken )
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el , & !< element
phase , &
of
real ( pReal ) , intent ( in ) :: &
subdt !< timestep
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 , homogenization_maxNconstituents , discretization_nIPs , discretization_Nelems ) :: &
FArray , & !< elastic deformation gradient
FpArray !< plastic deformation gradient
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
Fi !< intermediate deformation gradient
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
S !< 2nd Piola Kirchhoff stress (vector notation)
real ( pReal ) , dimension ( 3 , 3 ) :: &
Mp
integer :: &
ho , & !< homogenization
tme , & !< thermal member position
i , & !< counter in source loop
instance
logical :: broken
ho = material_homogenizationAt ( el )
tme = material_homogenizationMemberAt ( ip , el )
instance = phase_plasticityInstance ( phase )
Mp = matmul ( matmul ( transpose ( Fi ) , Fi ) , S )
plasticityType : select case ( phase_plasticity ( phase ) )
case ( PLASTICITY_ISOTROPIC_ID ) plasticityType
call plastic_isotropic_dotState ( Mp , instance , of )
case ( PLASTICITY_PHENOPOWERLAW_ID ) plasticityType
call plastic_phenopowerlaw_dotState ( Mp , instance , of )
case ( PLASTICITY_KINEHARDENING_ID ) plasticityType
call plastic_kinehardening_dotState ( Mp , instance , of )
case ( PLASTICITY_DISLOTWIN_ID ) plasticityType
call plastic_dislotwin_dotState ( Mp , temperature ( ho ) % p ( tme ) , instance , of )
case ( PLASTICITY_DISLOTUNGSTEN_ID ) plasticityType
call plastic_disloTungsten_dotState ( Mp , temperature ( ho ) % p ( tme ) , instance , of )
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
call plastic_nonlocal_dotState ( Mp , FArray , FpArray , temperature ( ho ) % p ( tme ) , subdt , &
instance , of , ip , el )
end select plasticityType
broken = any ( IEEE_is_NaN ( plasticState ( phase ) % dotState ( : , of ) ) )
end function constitutive_collectDotState
2020-12-20 21:41:43 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief for constitutive models having an instantaneous change of state
!> will return false if delta state is not needed/supported by the constitutive model
!--------------------------------------------------------------------------------------------------
function constitutive_deltaState ( S , Fi , ipc , ip , el , phase , of ) result ( broken )
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el , & !< element
phase , &
of
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
S , & !< 2nd Piola Kirchhoff stress
Fi !< intermediate deformation gradient
real ( pReal ) , dimension ( 3 , 3 ) :: &
Mp
integer :: &
instance , &
myOffset , &
mySize
logical :: &
broken
Mp = matmul ( matmul ( transpose ( Fi ) , Fi ) , S )
instance = phase_plasticityInstance ( phase )
plasticityType : select case ( phase_plasticity ( phase ) )
case ( PLASTICITY_KINEHARDENING_ID ) plasticityType
call plastic_kinehardening_deltaState ( Mp , instance , of )
broken = any ( IEEE_is_NaN ( plasticState ( phase ) % deltaState ( : , of ) ) )
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
call plastic_nonlocal_deltaState ( Mp , instance , of , ip , el )
broken = any ( IEEE_is_NaN ( plasticState ( phase ) % deltaState ( : , of ) ) )
case default
broken = . false .
end select plasticityType
if ( . not . broken ) then
select case ( phase_plasticity ( phase ) )
case ( PLASTICITY_NONLOCAL_ID , PLASTICITY_KINEHARDENING_ID )
myOffset = plasticState ( phase ) % offsetDeltaState
mySize = plasticState ( phase ) % sizeDeltaState
plasticState ( phase ) % state ( myOffset + 1 : myOffset + mySize , of ) = &
plasticState ( phase ) % state ( myOffset + 1 : myOffset + mySize , of ) + plasticState ( phase ) % deltaState ( 1 : mySize , of )
end select
endif
end function constitutive_deltaState
2020-07-12 20:14:26 +05:30
!--------------------------------------------------------------------------------------------
!> @brief writes plasticity constitutive results to HDF5 output file
2020-09-14 00:30:34 +05:30
!--------------------------------------------------------------------------------------------
2020-07-12 18:52:40 +05:30
module subroutine plastic_results
integer :: p
2020-12-06 18:02:20 +05:30
character ( len = : ) , allocatable :: group
2020-07-12 18:52:40 +05:30
2020-08-15 19:32:10 +05:30
plasticityLoop : do p = 1 , size ( material_name_phase )
2020-12-06 18:02:20 +05:30
group = '/current/phase/' / / trim ( material_name_phase ( p ) )
2020-07-12 18:52:40 +05:30
call results_closeGroup ( results_addGroup ( group ) )
group = trim ( group ) / / '/plastic'
call results_closeGroup ( results_addGroup ( group ) )
select case ( phase_plasticity ( p ) )
case ( PLASTICITY_ISOTROPIC_ID )
call plastic_isotropic_results ( phase_plasticityInstance ( p ) , group )
case ( PLASTICITY_PHENOPOWERLAW_ID )
call plastic_phenopowerlaw_results ( phase_plasticityInstance ( p ) , group )
case ( PLASTICITY_KINEHARDENING_ID )
call plastic_kinehardening_results ( phase_plasticityInstance ( p ) , group )
case ( PLASTICITY_DISLOTWIN_ID )
call plastic_dislotwin_results ( phase_plasticityInstance ( p ) , group )
2020-08-15 19:32:10 +05:30
case ( PLASTICITY_DISLOTUNGSTEN_ID )
2020-11-29 16:28:39 +05:30
call plastic_dislotungsten_results ( phase_plasticityInstance ( p ) , group )
2020-07-12 18:52:40 +05:30
case ( PLASTICITY_NONLOCAL_ID )
call plastic_nonlocal_results ( phase_plasticityInstance ( p ) , group )
end select
enddo plasticityLoop
end subroutine plastic_results
2020-11-03 05:19:17 +05:30
end submodule constitutive_mech
2020-07-09 04:31:08 +05:30