no need to have as a separate state

This commit is contained in:
Martin Diehl 2018-12-13 07:06:12 +01:00
parent dfafddec57
commit 6b5131e0f3
1 changed files with 17 additions and 22 deletions

View File

@ -87,8 +87,6 @@ module plastic_kinehardening
gamma0, & !< accumulated shear at last switch of stress sense gamma0, & !< accumulated shear at last switch of stress sense
accshear !< accumulated (absolute) shear accshear !< accumulated (absolute) shear
real(pReal), pointer, dimension(:) :: & !< scalars along NipcMyInstance
sumGamma !< accumulated shear across all systems
end type end type
type(tParameters), dimension(:), allocatable, private :: & type(tParameters), dimension(:), allocatable, private :: &
@ -324,8 +322,7 @@ param(instance)%outputID = prm%outputID
! allocate state arrays ! allocate state arrays
sizeDotState = nSlip & !< crss sizeDotState = nSlip & !< crss
+ nSlip & !< crss_back + nSlip & !< crss_back
+ nSlip & !< accumulated (absolute) shear + nSlip !< accumulated (absolute) shear
+ 1_pInt !< sum(gamma)
sizeDeltaState = nSlip & !< sense of acting shear stress (-1 or +1) sizeDeltaState = nSlip & !< sense of acting shear stress (-1 or +1)
+ nSlip & !< backstress at last switch of stress sense + nSlip & !< backstress at last switch of stress sense
@ -362,13 +359,6 @@ param(instance)%outputID = prm%outputID
dot%accshear => plasticState(p)%dotState (startIndex-o:endIndex-o,1:NipcMyPhase) dot%accshear => plasticState(p)%dotState (startIndex-o:endIndex-o,1:NipcMyPhase)
plasticState(p)%aTolState(startIndex-o:endIndex-o) = prm%aTolShear plasticState(p)%aTolState(startIndex-o:endIndex-o) = prm%aTolShear
! .............................................
startIndex = endIndex + 1_pInt
endIndex = endIndex + 1_pInt
stt%sumGamma => plasticState(p)%state (startIndex ,1:NipcMyPhase)
dot%sumGamma => plasticState(p)%dotState (startIndex-o ,1:NipcMyPhase)
plasticState(p)%aTolState(startIndex-o:endIndex-o) =prm%aTolShear
!---------------------------------------------------------------------------------------------- !----------------------------------------------------------------------------------------------
!locally define deltaState alias !locally define deltaState alias
o = endIndex o = endIndex
@ -846,17 +836,23 @@ subroutine plastic_kinehardening_dotState(Mp,ipc,ip,el)
real(pReal), dimension(plastic_kinehardening_totalNslip(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: & real(pReal), dimension(plastic_kinehardening_totalNslip(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
gdot_pos,gdot_neg, & gdot_pos,gdot_neg, &
tau_pos,tau_neg tau_pos,tau_neg
real(pReal) :: &
sumGamma
of = phasememberAt(ipc,ip,el) of = phasememberAt(ipc,ip,el)
ph = phaseAt(ipc,ip,el) ph = phaseAt(ipc,ip,el)
instance = phase_plasticityInstance(ph) instance = phase_plasticityInstance(ph)
nSlip = plastic_kinehardening_totalNslip(instance) nSlip = plastic_kinehardening_totalNslip(instance)
dotState(instance)%sumGamma(of) = 0.0_pReal associate( prm => paramNew(instance), stt => state(instance), dot => dotState(instance))
call plastic_kinehardening_shearRates(gdot_pos,gdot_neg,tau_pos,tau_neg, & call plastic_kinehardening_shearRates(gdot_pos,gdot_neg,tau_pos,tau_neg, &
Mp,ph,instance,of) Mp,ph,instance,of)
dot%accshear(:,of) = abs(gdot_pos+gdot_neg)
sumGamma = sum(stt%accshear(:,of))
j = 0_pInt j = 0_pInt
slipFamilies: do f = 1_pInt,lattice_maxNslipFamily slipFamilies: do f = 1_pInt,lattice_maxNslipFamily
slipSystems: do i = 1_pInt,plastic_kinehardening_Nslip(f,instance) slipSystems: do i = 1_pInt,plastic_kinehardening_Nslip(f,instance)
@ -865,8 +861,8 @@ subroutine plastic_kinehardening_dotState(Mp,ipc,ip,el)
dot_product(param(instance)%hardeningMatrix_SlipSlip(j,1:nSlip),abs(gdot_pos+gdot_neg)) * & dot_product(param(instance)%hardeningMatrix_SlipSlip(j,1:nSlip),abs(gdot_pos+gdot_neg)) * &
( param(instance)%theta1(f) + & ( param(instance)%theta1(f) + &
(param(instance)%theta0(f) - param(instance)%theta1(f) & (param(instance)%theta0(f) - param(instance)%theta1(f) &
+ param(instance)%theta0(f)*param(instance)%theta1(f)*state(instance)%sumGamma(of)/param(instance)%tau1(f)) & + param(instance)%theta0(f)*param(instance)%theta1(f)*sumGamma/param(instance)%tau1(f)) &
*exp(-state(instance)%sumGamma(of)*param(instance)%theta0(f)/param(instance)%tau1(f)) & ! V term depending on the harding law *exp(-sumGamma*param(instance)%theta0(f)/param(instance)%tau1(f)) & ! V term depending on the harding law
) )
dotState(instance)%crss_back(j,of) = & ! evolution of back stress resistance j dotState(instance)%crss_back(j,of) = & ! evolution of back stress resistance j
state(instance)%sense(j,of)*abs(gdot_pos(j)+gdot_neg(j)) * & state(instance)%sense(j,of)*abs(gdot_pos(j)+gdot_neg(j)) * &
@ -878,10 +874,9 @@ subroutine plastic_kinehardening_dotState(Mp,ipc,ip,el)
*param(instance)%theta0_b(f)/(param(instance)%tau1_b(f)+state(instance)%chi0(j,of))) & *param(instance)%theta0_b(f)/(param(instance)%tau1_b(f)+state(instance)%chi0(j,of))) &
) ! V term depending on the harding law for back stress ) ! V term depending on the harding law for back stress
dotState(instance)%accshear(j,of) = abs(gdot_pos(j)+gdot_neg(j))
dotState(instance)%sumGamma(of) = dotState(instance)%sumGamma(of) + dotState(instance)%accshear(j,of)
enddo slipSystems enddo slipSystems
enddo slipFamilies enddo slipFamilies
end associate
end subroutine plastic_kinehardening_dotState end subroutine plastic_kinehardening_dotState