2012-10-02 18:23:25 +05:30
!--------------------------------------------------------------------------------------------------
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
2013-03-06 20:11:15 +05:30
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
2012-10-02 18:23:25 +05:30
!> @brief elasticity, plasticity, internal microstructure state
!--------------------------------------------------------------------------------------------------
module constitutive
2019-12-03 01:13:02 +05:30
use prec
2019-06-15 19:10:22 +05:30
use math
2019-12-05 01:20:46 +05:30
use rotations
2019-06-15 19:10:22 +05:30
use debug
use numerics
use IO
use config
use material
use results
use lattice
use discretization
use geometry_plastic_nonlocal
use source_thermal_dissipation
use source_thermal_externalheat
use source_damage_isoBrittle
use source_damage_isoDuctile
use source_damage_anisoBrittle
use source_damage_anisoDuctile
use kinematics_cleavage_opening
use kinematics_slipplane_opening
use kinematics_thermal_expansion
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
implicit none
private
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
integer , public , protected :: &
constitutive_plasticity_maxSizeDotState , &
constitutive_source_maxSizeDotState
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
interface
module subroutine plastic_none_init
end subroutine plastic_none_init
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
module subroutine plastic_isotropic_init
end subroutine plastic_isotropic_init
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
module subroutine plastic_phenopowerlaw_init
end subroutine plastic_phenopowerlaw_init
2020-02-07 16:53:22 +05:30
2019-12-03 02:08:41 +05:30
module subroutine plastic_kinehardening_init
end subroutine plastic_kinehardening_init
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
module subroutine plastic_dislotwin_init
end subroutine plastic_dislotwin_init
2019-12-03 01:13:02 +05:30
2019-12-03 02:21:25 +05:30
module subroutine plastic_disloUCLA_init
end subroutine plastic_disloUCLA_init
2020-02-07 16:53:22 +05:30
2019-12-05 01:20:46 +05:30
module subroutine plastic_nonlocal_init
end subroutine plastic_nonlocal_init
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +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
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
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
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_phenopowerlaw_LpAndItsTangent
2020-02-07 16:53:22 +05:30
2019-12-03 02:08:41 +05:30
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
2020-02-07 16:53:22 +05:30
2019-12-03 02:08:41 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_kinehardening_LpAndItsTangent
2019-12-03 01:13:02 +05:30
2019-12-03 02:21:25 +05:30
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
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
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-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
pure module subroutine plastic_disloUCLA_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
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
T
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_disloUCLA_LpAndItsTangent
2020-02-07 16:53:22 +05:30
2020-03-16 21:59:47 +05:30
module subroutine plastic_nonlocal_LpAndItsTangent ( Lp , dLp_dMp , &
Mp , Temperature , instance , of , ip , el )
2019-12-05 01:20:46 +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
2020-02-07 16:53:22 +05:30
2019-12-05 01:20:46 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< Mandel stress
real ( pReal ) , intent ( in ) :: &
2020-03-16 21:59:47 +05:30
Temperature
integer , intent ( in ) :: &
instance , &
of , &
2019-12-05 01:20:46 +05:30
ip , & !< current integration point
el !< current element number
end subroutine plastic_nonlocal_LpAndItsTangent
2019-12-03 02:21:25 +05:30
2019-12-03 01:13:02 +05:30
module subroutine plastic_isotropic_LiAndItsTangent ( Li , dLi_dMi , Mi , instance , of )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( out ) :: &
Li !< inleastic velocity gradient
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) , intent ( out ) :: &
dLi_dMi !< derivative of Li with respect to Mandel stress
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
2020-02-07 16:53:22 +05:30
Mi !< Mandel stress
2019-12-03 01:13:02 +05:30
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_isotropic_LiAndItsTangent
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +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
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
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
2020-02-07 16:53:22 +05:30
2019-12-03 02:08:41 +05:30
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
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
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_disloUCLA_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_disloUCLA_dotState
2020-02-07 16:53:22 +05:30
2020-03-16 14:19:59 +05:30
module subroutine plastic_nonlocal_dotState ( Mp , F , Fp , Temperature , timestep , &
instance , of , ip , el )
2019-12-05 01:20:46 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp !< MandelStress
real ( pReal ) , dimension ( 3 , 3 , homogenization_maxNgrains , discretization_nIP , discretization_nElem ) , intent ( in ) :: &
2020-02-07 16:53:22 +05:30
F , & !< deformation gradient
2019-12-05 01:20:46 +05:30
Fp !< plastic deformation gradient
2020-03-16 14:19:59 +05:30
real ( pReal ) , intent ( in ) :: &
Temperature , & !< temperature
timestep !< substepped crystallite time increment
integer , intent ( in ) :: &
instance , &
of , &
ip , & !< current integration point
el !< current element number
2019-12-05 01:20:46 +05:30
end subroutine plastic_nonlocal_dotState
2019-12-03 02:21:25 +05:30
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +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-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
module subroutine plastic_disloUCLA_dependentState ( instance , of )
integer , intent ( in ) :: &
instance , &
of
end subroutine plastic_disloUCLA_dependentState
2020-02-07 16:53:22 +05:30
2020-03-16 21:59:47 +05:30
module subroutine plastic_nonlocal_dependentState ( F , Fp , instance , of , ip , el )
2019-12-05 01:20:46 +05:30
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
2020-02-07 17:11:01 +05:30
F , &
2019-12-05 01:20:46 +05:30
Fp
2020-03-16 21:59:47 +05:30
integer , intent ( in ) :: &
instance , &
of , &
ip , &
el
2019-12-05 01:20:46 +05:30
end subroutine plastic_nonlocal_dependentState
2019-12-03 02:08:41 +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
2020-02-07 16:53:22 +05:30
2020-03-16 21:59:47 +05:30
module subroutine plastic_nonlocal_deltaState ( Mp , instance , of , ip , el )
real ( pReal ) , dimension ( 3 , 3 ) , intent ( in ) :: &
Mp
2019-12-05 01:20:46 +05:30
integer , intent ( in ) :: &
2020-03-16 21:59:47 +05:30
instance , &
of , &
2019-12-05 01:20:46 +05:30
ip , &
el
end subroutine plastic_nonlocal_deltaState
2019-12-03 02:21:25 +05:30
module function plastic_dislotwin_homogenizedC ( ipc , ip , el ) result ( homogenizedC )
real ( pReal ) , dimension ( 6 , 6 ) :: &
homogenizedC
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
end function plastic_dislotwin_homogenizedC
2020-02-07 16:53:22 +05:30
2020-03-16 14:19:59 +05:30
module subroutine plastic_nonlocal_updateCompatibility ( orientation , instance , i , e )
2019-12-05 01:20:46 +05:30
integer , intent ( in ) :: &
2020-03-16 14:19:59 +05:30
instance , &
2019-12-05 01:20:46 +05:30
i , &
e
type ( rotation ) , dimension ( 1 , discretization_nIP , discretization_nElem ) , intent ( in ) :: &
orientation !< crystal orientation
end subroutine plastic_nonlocal_updateCompatibility
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
module subroutine plastic_isotropic_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_isotropic_results
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
module subroutine plastic_phenopowerlaw_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
2019-12-03 02:08:41 +05:30
end subroutine plastic_phenopowerlaw_results
2020-02-07 16:53:22 +05:30
2019-12-03 02:08:41 +05:30
module subroutine plastic_kinehardening_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_kinehardening_results
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
module subroutine plastic_dislotwin_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_dislotwin_results
2020-02-07 16:53:22 +05:30
2019-12-03 02:21:25 +05:30
module subroutine plastic_disloUCLA_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_disloUCLA_results
2020-02-07 16:53:22 +05:30
2019-12-05 01:20:46 +05:30
module subroutine plastic_nonlocal_results ( instance , group )
integer , intent ( in ) :: instance
character ( len = * ) , intent ( in ) :: group
end subroutine plastic_nonlocal_results
2020-02-07 16:53:22 +05:30
2019-12-03 01:13:02 +05:30
end interface
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
public :: &
2019-12-05 01:20:46 +05:30
plastic_nonlocal_updateCompatibility , &
2019-06-15 19:10:22 +05:30
constitutive_init , &
constitutive_homogenizedC , &
2020-02-11 22:06:43 +05:30
constitutive_dependentState , &
2019-06-15 19:10:22 +05:30
constitutive_LpAndItsTangents , &
constitutive_LiAndItsTangents , &
constitutive_initialFi , &
constitutive_SandItsTangents , &
constitutive_collectDotState , &
2020-04-01 11:32:08 +05:30
constitutive_deltaState , &
2019-06-15 19:10:22 +05:30
constitutive_results
2020-02-07 16:53:22 +05:30
2012-03-09 01:55:28 +05:30
contains
2012-10-02 18:23:25 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief allocates arrays pointing to array of the various constitutive modules
!--------------------------------------------------------------------------------------------------
2019-04-06 01:56:23 +05:30
subroutine constitutive_init
2014-10-11 02:25:09 +05:30
2019-06-15 19:10:22 +05:30
integer :: &
ph , & !< counter in phase loop
2019-12-09 10:28:27 +05:30
s !< counter in source loop
2015-10-14 00:22:01 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2019-02-26 12:24:03 +05:30
! initialized plasticity
2019-06-15 19:10:22 +05:30
if ( any ( phase_plasticity == PLASTICITY_NONE_ID ) ) call plastic_none_init
if ( any ( phase_plasticity == PLASTICITY_ISOTROPIC_ID ) ) call plastic_isotropic_init
if ( any ( phase_plasticity == PLASTICITY_PHENOPOWERLAW_ID ) ) call plastic_phenopowerlaw_init
if ( any ( phase_plasticity == PLASTICITY_KINEHARDENING_ID ) ) call plastic_kinehardening_init
if ( any ( phase_plasticity == PLASTICITY_DISLOTWIN_ID ) ) call plastic_dislotwin_init
if ( any ( phase_plasticity == PLASTICITY_DISLOUCLA_ID ) ) call plastic_disloucla_init
if ( any ( phase_plasticity == PLASTICITY_NONLOCAL_ID ) ) then
call plastic_nonlocal_init
else
call geometry_plastic_nonlocal_disable
endif
2014-09-23 16:08:20 +05:30
!--------------------------------------------------------------------------------------------------
2019-02-26 12:24:03 +05:30
! initialize source mechanisms
2019-06-15 19:10:22 +05:30
if ( any ( phase_source == SOURCE_thermal_dissipation_ID ) ) call source_thermal_dissipation_init
if ( any ( phase_source == SOURCE_thermal_externalheat_ID ) ) call source_thermal_externalheat_init
if ( any ( phase_source == SOURCE_damage_isoBrittle_ID ) ) call source_damage_isoBrittle_init
if ( any ( phase_source == SOURCE_damage_isoDuctile_ID ) ) call source_damage_isoDuctile_init
if ( any ( phase_source == SOURCE_damage_anisoBrittle_ID ) ) call source_damage_anisoBrittle_init
if ( any ( phase_source == SOURCE_damage_anisoDuctile_ID ) ) call source_damage_anisoDuctile_init
2020-02-07 16:53:22 +05:30
2014-09-23 16:08:20 +05:30
!--------------------------------------------------------------------------------------------------
2019-02-26 12:24:03 +05:30
! initialize kinematic mechanisms
2019-06-15 19:10:22 +05:30
if ( any ( phase_kinematics == KINEMATICS_cleavage_opening_ID ) ) call kinematics_cleavage_opening_init
if ( any ( phase_kinematics == KINEMATICS_slipplane_opening_ID ) ) call kinematics_slipplane_opening_init
if ( any ( phase_kinematics == KINEMATICS_thermal_expansion_ID ) ) call kinematics_thermal_expansion_init
2020-02-07 16:53:22 +05:30
2019-12-09 10:08:15 +05:30
write ( 6 , '(/,a)' ) ' <<<+- constitutive init -+>>>' ; flush ( 6 )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
constitutive_source_maxSizeDotState = 0
PhaseLoop2 : do ph = 1 , material_Nphase
2016-01-16 22:57:19 +05:30
!--------------------------------------------------------------------------------------------------
! partition and inititalize state
2019-06-15 19:10:22 +05:30
plasticState ( ph ) % partionedState0 = plasticState ( ph ) % state0
plasticState ( ph ) % state = plasticState ( ph ) % partionedState0
forall ( s = 1 : phase_Nsources ( ph ) )
sourceState ( ph ) % p ( s ) % partionedState0 = sourceState ( ph ) % p ( s ) % state0
sourceState ( ph ) % p ( s ) % state = sourceState ( ph ) % p ( s ) % partionedState0
end forall
2016-01-16 22:57:19 +05:30
!--------------------------------------------------------------------------------------------------
2020-03-16 23:58:50 +05:30
! determine max size of source state
constitutive_source_maxSizeDotState = max ( constitutive_source_maxSizeDotState , &
maxval ( sourceState ( ph ) % p % sizeDotState ) )
2019-06-15 19:10:22 +05:30
enddo PhaseLoop2
2020-03-16 23:58:50 +05:30
constitutive_plasticity_maxSizeDotState = maxval ( plasticState % sizeDotState )
2014-06-24 14:54:59 +05:30
2012-10-02 18:23:25 +05:30
end subroutine constitutive_init
2009-03-06 15:32:36 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief returns the homogenize elasticity matrix
2018-08-25 17:25:39 +05:30
!> ToDo: homogenizedC66 would be more consistent
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2014-07-02 17:57:39 +05:30
function constitutive_homogenizedC ( ipc , ip , el )
2014-03-09 02:20:31 +05:30
2019-06-15 19:10:22 +05:30
real ( pReal ) , dimension ( 6 , 6 ) :: constitutive_homogenizedC
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
plasticityType : select case ( phase_plasticity ( material_phaseAt ( ipc , el ) ) )
case ( PLASTICITY_DISLOTWIN_ID ) plasticityType
constitutive_homogenizedC = plastic_dislotwin_homogenizedC ( ipc , ip , el )
case default plasticityType
constitutive_homogenizedC = lattice_C66 ( 1 : 6 , 1 : 6 , material_phaseAt ( ipc , el ) )
end select plasticityType
2009-03-06 15:32:36 +05:30
2012-10-02 18:23:25 +05:30
end function constitutive_homogenizedC
2019-06-15 19:10:22 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief calls microstructure function of the different constitutive models
!--------------------------------------------------------------------------------------------------
2020-02-11 22:06:43 +05:30
subroutine constitutive_dependentState ( F , Fp , ipc , ip , el )
2014-06-03 19:16:42 +05:30
2019-06-15 19:10:22 +05:30
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
2020-02-07 17:11:01 +05:30
F , & !< elastic deformation gradient
2019-06-15 19:10:22 +05:30
Fp !< plastic deformation gradient
integer :: &
ho , & !< homogenization
tme , & !< thermal member position
instance , of
2020-02-07 16:53:22 +05:30
2020-03-16 21:59:47 +05:30
ho = material_homogenizationAt ( el )
2019-06-15 19:10:22 +05:30
tme = thermalMapping ( ho ) % p ( ip , el )
2020-03-16 21:59:47 +05:30
of = material_phasememberAt ( ipc , ip , el )
instance = phase_plasticityInstance ( material_phaseAt ( ipc , el ) )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
plasticityType : select case ( phase_plasticity ( material_phaseAt ( ipc , el ) ) )
case ( PLASTICITY_DISLOTWIN_ID ) plasticityType
call plastic_dislotwin_dependentState ( temperature ( ho ) % p ( tme ) , instance , of )
case ( PLASTICITY_DISLOUCLA_ID ) plasticityType
call plastic_disloUCLA_dependentState ( instance , of )
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_nonlocal_dependentState ( F , Fp , instance , of , ip , el )
2019-06-15 19:10:22 +05:30
end select plasticityType
2015-10-14 00:22:01 +05:30
2020-02-11 22:06:43 +05:30
end subroutine constitutive_dependentState
openmp parallelization working again (at least for j2 and nonlocal constitutive model).
In order to keep it like that, please follow these simple rules:
DON'T use implicit array subscripts:
example: real, dimension(3,3) :: A,B
A(:,2) = B(:,1) <--- DON'T USE
A(1:3,2) = B(1:3,1) <--- BETTER USE
In many cases the use of explicit array subscripts is inevitable for parallelization. Additionally, it is an easy means to prevent memory leaks.
Enclose all write statements with the following:
!$OMP CRITICAL (write2out)
<your write statement>
!$OMP END CRITICAL (write2out)
Whenever you change something in the code and are not sure if it affects parallelization and leads to nonconforming behavior, please ask me and/or Franz to check this.
2011-03-17 16:16:17 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2015-10-14 00:22:01 +05:30
!> @brief contains the constitutive equation for calculating the velocity gradient
2019-02-17 16:45:46 +05:30
! ToDo: Discuss wheter it makes sense if crystallite handles the configuration conversion, i.e.
! Mp in, dLp_dMp out
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2019-02-17 16:45:46 +05:30
subroutine constitutive_LpAndItsTangents ( Lp , dLp_dS , dLp_dFi , &
2020-02-07 16:53:22 +05:30
S , Fi , ipc , ip , el )
2019-06-15 19:10:22 +05:30
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
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
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
ho = material_homogenizationAt ( el )
tme = thermalMapping ( ho ) % p ( ip , el )
2020-02-07 16:53:22 +05:30
2020-03-16 21:59:47 +05:30
Mp = matmul ( matmul ( transpose ( Fi ) , Fi ) , S )
of = material_phasememberAt ( ipc , ip , el )
instance = phase_plasticityInstance ( material_phaseAt ( ipc , el ) )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
plasticityType : select case ( phase_plasticity ( material_phaseAt ( ipc , el ) ) )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_NONE_ID ) plasticityType
Lp = 0.0_pReal
dLp_dMp = 0.0_pReal
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_ISOTROPIC_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_isotropic_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_PHENOPOWERLAW_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_phenopowerlaw_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_KINEHARDENING_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_kinehardening_LpAndItsTangent ( Lp , dLp_dMp , Mp , instance , of )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_nonlocal_LpAndItsTangent ( Lp , dLp_dMp , Mp , temperature ( ho ) % p ( tme ) , instance , of , ip , el )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_DISLOTWIN_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_dislotwin_LpAndItsTangent ( Lp , dLp_dMp , Mp , temperature ( ho ) % p ( tme ) , instance , of )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_DISLOUCLA_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_disloucla_LpAndItsTangent ( Lp , dLp_dMp , Mp , temperature ( ho ) % p ( tme ) , instance , of )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
end select plasticityType
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
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
2015-10-14 00:22:01 +05:30
2018-08-28 18:37:39 +05:30
end subroutine constitutive_LpAndItsTangents
2009-03-06 15:32:36 +05:30
2014-11-01 00:33:08 +05:30
!--------------------------------------------------------------------------------------------------
2015-10-14 00:22:01 +05:30
!> @brief contains the constitutive equation for calculating the velocity gradient
2018-12-30 17:05:26 +05:30
! ToDo: MD: S is Mi?
2014-11-01 00:33:08 +05:30
!--------------------------------------------------------------------------------------------------
2019-02-18 11:54:56 +05:30
subroutine constitutive_LiAndItsTangents ( Li , dLi_dS , dLi_dFi , &
S , Fi , ipc , ip , el )
2015-10-14 00:22:01 +05:30
2019-06-15 19:10:22 +05:30
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
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
Fi !< intermediate deformation gradient
real ( pReal ) , intent ( out ) , dimension ( 3 , 3 ) :: &
Li !< intermediate velocity gradient
real ( pReal ) , intent ( out ) , dimension ( 3 , 3 , 3 , 3 ) :: &
dLi_dS , & !< derivative of Li with respect to S
dLi_dFi
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
real ( pReal ) , dimension ( 3 , 3 ) :: &
my_Li , & !< intermediate velocity gradient
FiInv , &
temp_33
real ( pReal ) , dimension ( 3 , 3 , 3 , 3 ) :: &
my_dLi_dS
real ( pReal ) :: &
detFi
integer :: &
k , i , j , &
instance , of
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
Li = 0.0_pReal
dLi_dS = 0.0_pReal
dLi_dFi = 0.0_pReal
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
plasticityType : select case ( phase_plasticity ( material_phaseAt ( ipc , el ) ) )
case ( PLASTICITY_isotropic_ID ) plasticityType
of = material_phasememberAt ( ipc , ip , el )
instance = phase_plasticityInstance ( material_phaseAt ( ipc , el ) )
call plastic_isotropic_LiAndItsTangent ( my_Li , my_dLi_dS , S , instance , of )
case default plasticityType
my_Li = 0.0_pReal
my_dLi_dS = 0.0_pReal
end select plasticityType
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
Li = Li + my_Li
dLi_dS = dLi_dS + my_dLi_dS
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
KinematicsLoop : do k = 1 , phase_Nkinematics ( material_phaseAt ( ipc , el ) )
kinematicsType : select case ( phase_kinematics ( k , material_phaseAt ( ipc , el ) ) )
case ( KINEMATICS_cleavage_opening_ID ) kinematicsType
call kinematics_cleavage_opening_LiAndItsTangent ( my_Li , my_dLi_dS , S , ipc , ip , el )
case ( KINEMATICS_slipplane_opening_ID ) kinematicsType
call kinematics_slipplane_opening_LiAndItsTangent ( my_Li , my_dLi_dS , S , ipc , ip , el )
case ( KINEMATICS_thermal_expansion_ID ) kinematicsType
call kinematics_thermal_expansion_LiAndItsTangent ( my_Li , my_dLi_dS , ipc , ip , el )
case default kinematicsType
my_Li = 0.0_pReal
my_dLi_dS = 0.0_pReal
end select kinematicsType
Li = Li + my_Li
dLi_dS = dLi_dS + my_dLi_dS
enddo KinematicsLoop
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
FiInv = math_inv33 ( Fi )
detFi = math_det33 ( Fi )
Li = matmul ( matmul ( Fi , Li ) , FiInv ) * detFi !< push forward to intermediate configuration
temp_33 = matmul ( FiInv , Li )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
do i = 1 , 3 ; do j = 1 , 3
dLi_dS ( 1 : 3 , 1 : 3 , i , j ) = matmul ( matmul ( Fi , dLi_dS ( 1 : 3 , 1 : 3 , i , j ) ) , FiInv ) * detFi
dLi_dFi ( 1 : 3 , 1 : 3 , i , j ) = dLi_dFi ( 1 : 3 , 1 : 3 , i , j ) + Li * FiInv ( j , i )
dLi_dFi ( 1 : 3 , i , 1 : 3 , j ) = dLi_dFi ( 1 : 3 , i , 1 : 3 , j ) + math_I3 * temp_33 ( j , i ) + Li * FiInv ( j , i )
2019-07-01 10:39:51 +05:30
enddo ; enddo
2015-10-14 00:22:01 +05:30
2018-08-28 18:37:39 +05:30
end subroutine constitutive_LiAndItsTangents
2014-11-01 00:33:08 +05:30
openmp parallelization working again (at least for j2 and nonlocal constitutive model).
In order to keep it like that, please follow these simple rules:
DON'T use implicit array subscripts:
example: real, dimension(3,3) :: A,B
A(:,2) = B(:,1) <--- DON'T USE
A(1:3,2) = B(1:3,1) <--- BETTER USE
In many cases the use of explicit array subscripts is inevitable for parallelization. Additionally, it is an easy means to prevent memory leaks.
Enclose all write statements with the following:
!$OMP CRITICAL (write2out)
<your write statement>
!$OMP END CRITICAL (write2out)
Whenever you change something in the code and are not sure if it affects parallelization and leads to nonconforming behavior, please ask me and/or Franz to check this.
2011-03-17 16:16:17 +05:30
2015-07-24 20:17:18 +05:30
!--------------------------------------------------------------------------------------------------
2015-10-14 00:22:01 +05:30
!> @brief collects initial intermediate deformation gradient
2015-07-24 20:17:18 +05:30
!--------------------------------------------------------------------------------------------------
pure function constitutive_initialFi ( ipc , ip , el )
2015-10-14 00:22:01 +05:30
2019-06-15 19:10:22 +05:30
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
el !< element
real ( pReal ) , dimension ( 3 , 3 ) :: &
constitutive_initialFi !< composite initial intermediate deformation gradient
integer :: &
k !< counter in kinematics loop
integer :: &
phase , &
homog , offset
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
constitutive_initialFi = math_I3
phase = material_phaseAt ( ipc , el )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
KinematicsLoop : do k = 1 , phase_Nkinematics ( phase ) !< Warning: small initial strain assumption
kinematicsType : select case ( phase_kinematics ( k , phase ) )
case ( KINEMATICS_thermal_expansion_ID ) kinematicsType
homog = material_homogenizationAt ( el )
offset = thermalMapping ( homog ) % p ( ip , el )
constitutive_initialFi = &
constitutive_initialFi + kinematics_thermal_expansion_initialStrain ( homog , phase , offset )
end select kinematicsType
enddo KinematicsLoop
2015-10-14 00:22:01 +05:30
2015-07-24 20:17:18 +05:30
end function constitutive_initialFi
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2015-10-14 00:22:01 +05:30
!> @brief returns the 2nd Piola-Kirchhoff stress tensor and its tangent with respect to
2020-02-07 16:53:22 +05:30
!> the elastic/intermediate deformation gradients depending on the selected elastic law
2018-08-28 18:24:36 +05:30
!! (so far no case switch because only Hooke is implemented)
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2018-08-28 18:24:36 +05:30
subroutine constitutive_SandItsTangents ( S , dS_dFe , dS_dFi , Fe , Fi , ipc , ip , el )
2014-07-02 17:57:39 +05:30
2019-06-15 19:10:22 +05:30
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
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
2015-10-14 00:22:01 +05:30
2019-06-15 19:10:22 +05:30
call constitutive_hooke_SandItsTangents ( S , dS_dFe , dS_dFi , Fe , Fi , ipc , ip , el )
2013-10-14 16:24:45 +05:30
2015-10-14 00:22:01 +05:30
2018-08-28 18:24:36 +05:30
end subroutine constitutive_SandItsTangents
2012-03-15 15:21:33 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2015-10-14 00:22:01 +05:30
!> @brief returns the 2nd Piola-Kirchhoff stress tensor and its tangent with respect to
2018-08-28 18:24:36 +05:30
!> the elastic and intermeidate deformation gradients using Hookes law
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2019-02-18 11:54:56 +05:30
subroutine constitutive_hooke_SandItsTangents ( S , dS_dFe , dS_dFi , &
Fe , Fi , ipc , ip , el )
2012-11-07 21:13:29 +05:30
2019-06-15 19:10:22 +05:30
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
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
ho = material_homogenizationAt ( el )
C = math_66toSym3333 ( constitutive_homogenizedC ( ipc , ip , el ) )
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
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
C = C * damage ( ho ) % p ( damageMapping ( ho ) % p ( ip , el ) ) ** 2
end select degradationType
enddo DegradationLoop
2020-02-07 16:53:22 +05:30
2019-06-15 19:10:22 +05:30
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
2020-01-04 07:48:51 +05:30
do i = 1 , 3 ; do j = 1 , 3
2019-06-15 19:10:22 +05:30
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
2020-01-04 07:48:51 +05:30
enddo ; enddo
2015-10-14 00:22:01 +05:30
2018-08-28 18:24:36 +05:30
end subroutine constitutive_hooke_SandItsTangents
2012-03-15 15:21:33 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2015-10-14 00:22:01 +05:30
!> @brief contains the constitutive equation for calculating the rate of change of microstructure
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2020-04-01 16:25:49 +05:30
function constitutive_collectDotState ( S , FArray , Fi , FpArray , subdt , ipc , ip , el , phase , of ) result ( broken )
2014-06-14 02:23:17 +05:30
2019-06-15 19:10:22 +05:30
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
2020-04-01 16:25:49 +05:30
el , & !< element
phase , &
of
2019-06-15 19:10:22 +05:30
real ( pReal ) , intent ( in ) :: &
subdt !< timestep
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 , homogenization_maxNgrains , discretization_nIP , discretization_nElem ) :: &
2020-03-15 17:39:27 +05:30
FArray , & !< elastic deformation gradient
2019-06-15 19:10:22 +05:30
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
2020-04-01 16:25:49 +05:30
instance
2020-04-01 11:11:55 +05:30
logical :: broken
2019-06-15 19:10:22 +05:30
ho = material_homogenizationAt ( el )
tme = thermalMapping ( ho ) % p ( ip , el )
2020-04-01 11:11:55 +05:30
instance = phase_plasticityInstance ( phase )
2019-06-15 19:10:22 +05:30
2020-03-16 14:19:59 +05:30
Mp = matmul ( matmul ( transpose ( Fi ) , Fi ) , S )
2019-06-15 19:10:22 +05:30
2020-04-01 11:11:55 +05:30
plasticityType : select case ( phase_plasticity ( phase ) )
2019-06-15 19:10:22 +05:30
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_DISLOUCLA_ID ) plasticityType
call plastic_disloucla_dotState ( Mp , temperature ( ho ) % p ( tme ) , instance , of )
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
2020-03-16 14:19:59 +05:30
call plastic_nonlocal_dotState ( Mp , FArray , FpArray , temperature ( ho ) % p ( tme ) , subdt , &
instance , of , ip , el )
2019-06-15 19:10:22 +05:30
end select plasticityType
2020-04-01 11:11:55 +05:30
broken = any ( IEEE_is_NaN ( plasticState ( phase ) % dotState ( : , of ) ) )
2019-06-15 19:10:22 +05:30
2020-04-01 11:11:55 +05:30
SourceLoop : do i = 1 , phase_Nsources ( phase )
2019-06-15 19:10:22 +05:30
2020-04-01 11:11:55 +05:30
sourceType : select case ( phase_source ( i , phase ) )
2019-06-15 19:10:22 +05:30
case ( SOURCE_damage_anisoBrittle_ID ) sourceType
call source_damage_anisoBrittle_dotState ( S , ipc , ip , el ) !< correct stress?
case ( SOURCE_damage_isoDuctile_ID ) sourceType
2020-03-16 14:19:59 +05:30
call source_damage_isoDuctile_dotState ( ipc , ip , el )
2019-06-15 19:10:22 +05:30
case ( SOURCE_damage_anisoDuctile_ID ) sourceType
2020-03-16 14:19:59 +05:30
call source_damage_anisoDuctile_dotState ( ipc , ip , el )
2019-06-15 19:10:22 +05:30
case ( SOURCE_thermal_externalheat_ID ) sourceType
2020-04-01 11:11:55 +05:30
call source_thermal_externalheat_dotState ( phase , of )
2019-06-15 19:10:22 +05:30
end select sourceType
2020-04-01 11:11:55 +05:30
broken = broken . or . any ( IEEE_is_NaN ( sourceState ( phase ) % p ( i ) % dotState ( : , of ) ) )
2019-06-15 19:10:22 +05:30
enddo SourceLoop
2014-09-23 16:08:20 +05:30
2020-04-01 11:11:55 +05:30
end function constitutive_collectDotState
2009-03-06 15:32:36 +05:30
2019-06-15 19:10:22 +05:30
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2016-01-16 22:57:19 +05:30
!> @brief for constitutive models having an instantaneous change of state
2014-06-17 12:24:49 +05:30
!> will return false if delta state is not needed/supported by the constitutive model
2013-01-16 15:44:57 +05:30
!--------------------------------------------------------------------------------------------------
2020-04-01 16:25:49 +05:30
function constitutive_deltaState ( S , Fe , Fi , ipc , ip , el , phase , of ) result ( broken )
2015-10-14 00:22:01 +05:30
2019-06-15 19:10:22 +05:30
integer , intent ( in ) :: &
ipc , & !< component-ID of integration point
ip , & !< integration point
2020-04-01 16:25:49 +05:30
el , & !< element
phase , &
of
2019-06-15 19:10:22 +05:30
real ( pReal ) , intent ( in ) , dimension ( 3 , 3 ) :: &
S , & !< 2nd Piola Kirchhoff stress
Fe , & !< elastic deformation gradient
Fi !< intermediate deformation gradient
real ( pReal ) , dimension ( 3 , 3 ) :: &
Mp
integer :: &
i , &
2020-04-01 18:12:38 +05:30
instance , &
myOffset , &
mySize
2020-04-01 11:32:08 +05:30
logical :: &
broken
2019-06-15 19:10:22 +05:30
Mp = matmul ( matmul ( transpose ( Fi ) , Fi ) , S )
2020-04-01 16:25:49 +05:30
instance = phase_plasticityInstance ( phase )
2018-08-25 19:29:34 +05:30
2020-04-01 11:32:08 +05:30
plasticityType : select case ( phase_plasticity ( phase ) )
2018-08-25 19:29:34 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_KINEHARDENING_ID ) plasticityType
call plastic_kinehardening_deltaState ( Mp , instance , of )
2020-04-01 16:25:49 +05:30
broken = any ( IEEE_is_NaN ( plasticState ( phase ) % deltaState ( : , of ) ) )
2018-08-25 19:29:34 +05:30
2019-06-15 19:10:22 +05:30
case ( PLASTICITY_NONLOCAL_ID ) plasticityType
2020-03-16 21:59:47 +05:30
call plastic_nonlocal_deltaState ( Mp , instance , of , ip , el )
2020-04-01 16:25:49 +05:30
broken = any ( IEEE_is_NaN ( plasticState ( phase ) % deltaState ( : , of ) ) )
case default
broken = . false .
2018-08-25 19:29:34 +05:30
2019-06-15 19:10:22 +05:30
end select plasticityType
2020-04-01 16:25:49 +05:30
2020-04-01 18:12:38 +05:30
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
2012-05-16 20:13:26 +05:30
2020-04-01 11:32:08 +05:30
sourceLoop : do i = 1 , phase_Nsources ( phase )
2018-08-25 19:29:34 +05:30
2020-04-01 11:32:08 +05:30
sourceType : select case ( phase_source ( i , phase ) )
2018-08-25 19:29:34 +05:30
2019-06-15 19:10:22 +05:30
case ( SOURCE_damage_isoBrittle_ID ) sourceType
call source_damage_isoBrittle_deltaState ( constitutive_homogenizedC ( ipc , ip , el ) , Fe , &
ipc , ip , el )
2020-04-01 16:25:49 +05:30
broken = broken . or . any ( IEEE_is_NaN ( sourceState ( phase ) % p ( i ) % deltaState ( : , of ) ) )
2020-04-01 18:12:38 +05:30
if ( . not . broken ) then
myOffset = sourceState ( phase ) % p ( i ) % offsetDeltaState
mySize = sourceState ( phase ) % p ( i ) % sizeDeltaState
sourceState ( phase ) % p ( i ) % state ( myOffset + 1 : myOffset + mySize , of ) = &
sourceState ( phase ) % p ( i ) % state ( myOffset + 1 : myOffset + mySize , of ) + sourceState ( phase ) % p ( i ) % deltaState ( 1 : mySize , of )
endif
2018-08-25 19:29:34 +05:30
2019-06-15 19:10:22 +05:30
end select sourceType
2018-08-25 19:29:34 +05:30
2019-06-15 19:10:22 +05:30
enddo SourceLoop
2015-05-28 22:32:23 +05:30
2020-04-01 11:32:08 +05:30
end function constitutive_deltaState
2014-09-10 23:56:12 +05:30
2014-09-22 23:45:19 +05:30
2018-12-05 04:25:39 +05:30
!--------------------------------------------------------------------------------------------------
2018-12-12 11:10:57 +05:30
!> @brief writes constitutive results to HDF5 output file
2018-12-05 04:25:39 +05:30
!--------------------------------------------------------------------------------------------------
2019-04-06 10:01:02 +05:30
subroutine constitutive_results
2019-12-19 00:35:51 +05:30
2019-04-04 13:34:44 +05:30
integer :: p
2019-12-21 12:08:17 +05:30
character ( len = pStringLen ) :: group
2019-06-15 17:56:32 +05:30
do p = 1 , size ( config_name_phase )
group = trim ( 'current/constituent' ) / / '/' / / trim ( config_name_phase ( p ) )
2020-01-03 01:48:56 +05:30
call results_closeGroup ( results_addGroup ( group ) )
2020-02-07 16:53:22 +05:30
2019-04-18 15:25:50 +05:30
group = trim ( group ) / / '/plastic'
2020-02-07 16:53:22 +05:30
call results_closeGroup ( results_addGroup ( group ) )
2019-06-06 14:11:56 +05:30
select case ( phase_plasticity ( p ) )
2020-02-07 16:53:22 +05:30
2019-03-10 01:13:31 +05:30
case ( PLASTICITY_ISOTROPIC_ID )
2020-02-07 16:53:22 +05:30
call plastic_isotropic_results ( phase_plasticityInstance ( p ) , group )
2019-03-10 01:13:31 +05:30
case ( PLASTICITY_PHENOPOWERLAW_ID )
2020-02-07 16:53:22 +05:30
call plastic_phenopowerlaw_results ( phase_plasticityInstance ( p ) , group )
2019-04-04 13:34:44 +05:30
case ( PLASTICITY_KINEHARDENING_ID )
2020-02-07 16:53:22 +05:30
call plastic_kinehardening_results ( phase_plasticityInstance ( p ) , group )
2019-03-10 01:13:31 +05:30
2019-04-04 13:34:44 +05:30
case ( PLASTICITY_DISLOTWIN_ID )
2020-02-07 16:53:22 +05:30
call plastic_dislotwin_results ( phase_plasticityInstance ( p ) , group )
2019-04-04 13:34:44 +05:30
case ( PLASTICITY_DISLOUCLA_ID )
2020-02-07 16:53:22 +05:30
call plastic_disloUCLA_results ( phase_plasticityInstance ( p ) , group )
2019-04-04 13:34:44 +05:30
case ( PLASTICITY_NONLOCAL_ID )
2020-02-07 16:53:22 +05:30
call plastic_nonlocal_results ( phase_plasticityInstance ( p ) , group )
2019-03-10 01:13:31 +05:30
end select
2020-02-07 16:53:22 +05:30
enddo
2019-12-19 00:35:51 +05:30
2018-12-05 04:25:39 +05:30
end subroutine constitutive_results
2013-02-11 16:13:45 +05:30
end module constitutive