use of kinetics avoids different calculation of shearrates
This commit is contained in:
parent
3526c0a757
commit
ed570f0fe8
|
@ -887,17 +887,18 @@ function plastic_dislotwin_homogenizedC(ipc,ip,el)
|
||||||
|
|
||||||
integer(pInt) :: i, &
|
integer(pInt) :: i, &
|
||||||
of
|
of
|
||||||
real(pReal) :: sumf_twin, sumf_trans
|
real(pReal) :: f_unrotated
|
||||||
|
|
||||||
of = phasememberAt(ipc,ip,el)
|
of = phasememberAt(ipc,ip,el)
|
||||||
associate(prm => param(phase_plasticityInstance(material_phase(ipc,ip,el))),&
|
associate(prm => param(phase_plasticityInstance(material_phase(ipc,ip,el))),&
|
||||||
stt => state(phase_plasticityInstance(material_phase(ipc,ip,el))))
|
stt => state(phase_plasticityInstance(material_phase(ipc,ip,el))))
|
||||||
|
|
||||||
sumf_twin = sum(stt%twinFraction(1_pInt:prm%totalNtwin,of))
|
f_unrotated = 1.0_pReal &
|
||||||
sumf_trans = sum(stt%stressTransFraction(1_pInt:prm%totalNtrans,of)) + &
|
- sum(stt%twinFraction(1_pInt:prm%totalNtwin,of)) &
|
||||||
sum(stt%strainTransFraction(1_pInt:prm%totalNtrans,of))
|
- sum(stt%stressTransFraction(1_pInt:prm%totalNtrans,of)) &
|
||||||
|
- sum(stt%strainTransFraction(1_pInt:prm%totalNtrans,of))
|
||||||
|
|
||||||
plastic_dislotwin_homogenizedC = (1.0_pReal-sumf_twin-sumf_trans)*prm%C66
|
plastic_dislotwin_homogenizedC = f_unrotated * prm%C66
|
||||||
do i=1_pInt,prm%totalNtwin
|
do i=1_pInt,prm%totalNtwin
|
||||||
plastic_dislotwin_homogenizedC = plastic_dislotwin_homogenizedC &
|
plastic_dislotwin_homogenizedC = plastic_dislotwin_homogenizedC &
|
||||||
+ stt%twinFraction(i,of)*prm%C66_twin(1:6,1:6,i)
|
+ stt%twinFraction(i,of)*prm%C66_twin(1:6,1:6,i)
|
||||||
|
@ -934,7 +935,7 @@ subroutine plastic_dislotwin_microstructure(temperature,ipc,ip,el)
|
||||||
i, &
|
i, &
|
||||||
of
|
of
|
||||||
real(pReal) :: &
|
real(pReal) :: &
|
||||||
sumf_twin,sfe,sumf_trans
|
sumf_twin,SFE,sumf_trans
|
||||||
real(pReal), dimension(:), allocatable :: &
|
real(pReal), dimension(:), allocatable :: &
|
||||||
x0, &
|
x0, &
|
||||||
fOverStacksize, &
|
fOverStacksize, &
|
||||||
|
@ -1067,7 +1068,7 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
real(pReal), dimension(9,9), intent(out) :: dLp_dTstar99
|
real(pReal), dimension(9,9), intent(out) :: dLp_dTstar99
|
||||||
|
|
||||||
integer(pInt) :: of,i,k,l,m,n,s1,s2
|
integer(pInt) :: of,i,k,l,m,n,s1,s2
|
||||||
real(pReal) :: sumf_twin,sumf_trans,StressRatio_p,StressRatio_pminus1,&
|
real(pReal) :: f_unrotated,StressRatio_p,&
|
||||||
StressRatio_r,BoltzmannRatio,Ndot0_twin,stressRatio, &
|
StressRatio_r,BoltzmannRatio,Ndot0_twin,stressRatio, &
|
||||||
Ndot0_trans,StressRatio_s, &
|
Ndot0_trans,StressRatio_s, &
|
||||||
dgdot_dtau, &
|
dgdot_dtau, &
|
||||||
|
@ -1075,7 +1076,9 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
real(pReal), dimension(3,3,3,3) :: dLp_dS
|
real(pReal), dimension(3,3,3,3) :: dLp_dS
|
||||||
real(pReal), dimension(param(phase_plasticityInstance(material_phase(ipc,ip,el)))%totalNslip) :: &
|
real(pReal), dimension(param(phase_plasticityInstance(material_phase(ipc,ip,el)))%totalNslip) :: &
|
||||||
gdot_slip,dgdot_dtau_slip
|
gdot_slip,dgdot_dtau_slip
|
||||||
real(pReal):: gdot_sb,gdot_twin,gdot_trans
|
real(pReal), dimension(param(phase_plasticityInstance(material_phase(ipc,ip,el)))%totalNtwin) :: &
|
||||||
|
gdot_twin,dgdot_dtau_twin
|
||||||
|
real(pReal):: gdot_sb,gdot_trans
|
||||||
real(pReal), dimension(3,3) :: eigVectors, Schmid_shearBand
|
real(pReal), dimension(3,3) :: eigVectors, Schmid_shearBand
|
||||||
real(pReal), dimension(3) :: eigValues, sb_s, sb_m
|
real(pReal), dimension(3) :: eigValues, sb_s, sb_m
|
||||||
logical :: error
|
logical :: error
|
||||||
|
@ -1110,9 +1113,10 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
stt => state(phase_plasticityInstance(material_phase(ipc,ip,el))), &
|
stt => state(phase_plasticityInstance(material_phase(ipc,ip,el))), &
|
||||||
mse => microstructure(phase_plasticityInstance(material_phase(ipc,ip,el))))
|
mse => microstructure(phase_plasticityInstance(material_phase(ipc,ip,el))))
|
||||||
|
|
||||||
sumf_twin = sum(stt%twinFraction(1:prm%totalNtwin,of))
|
f_unrotated = 1.0_pReal &
|
||||||
sumf_trans = sum(stt%stressTransFraction(1:prm%totalNtrans,of)) &
|
- sum(stt%twinFraction(1_pInt:prm%totalNtwin,of)) &
|
||||||
+ sum(stt%strainTransFraction(1:prm%totalNtrans,of))
|
- sum(stt%stressTransFraction(1_pInt:prm%totalNtrans,of)) &
|
||||||
|
- sum(stt%strainTransFraction(1_pInt:prm%totalNtrans,of))
|
||||||
|
|
||||||
Lp = 0.0_pReal
|
Lp = 0.0_pReal
|
||||||
dLp_dS = 0.0_pReal
|
dLp_dS = 0.0_pReal
|
||||||
|
@ -1127,8 +1131,8 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
enddo slipContribution
|
enddo slipContribution
|
||||||
|
|
||||||
!ToDo: Why do this before shear banding?
|
!ToDo: Why do this before shear banding?
|
||||||
Lp = Lp * (1.0_pReal - sumf_twin - sumf_trans)
|
Lp = Lp * f_unrotated
|
||||||
dLp_dS = dLp_dS * (1.0_pReal - sumf_twin - sumf_trans)
|
dLp_dS = dLp_dS * f_unrotated
|
||||||
|
|
||||||
shearBandingContribution: if(dNeq0(prm%sbVelocity)) then
|
shearBandingContribution: if(dNeq0(prm%sbVelocity)) then
|
||||||
|
|
||||||
|
@ -1143,10 +1147,10 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
|
|
||||||
significantShearBandStress: if (abs(tau) > tol_math_check) then
|
significantShearBandStress: if (abs(tau) > tol_math_check) then
|
||||||
StressRatio_p = (abs(tau)/prm%sbResistance)**prm%pShearBand
|
StressRatio_p = (abs(tau)/prm%sbResistance)**prm%pShearBand
|
||||||
StressRatio_pminus1 = (abs(tau)/prm%sbResistance)**(prm%pShearBand-1.0_pReal)
|
|
||||||
gdot_sb = sign(prm%sbVelocity*exp(-BoltzmannRatio*(1_pInt-StressRatio_p)**prm%qShearBand), tau)
|
gdot_sb = sign(prm%sbVelocity*exp(-BoltzmannRatio*(1_pInt-StressRatio_p)**prm%qShearBand), tau)
|
||||||
dgdot_dtau = ((abs(gdot_sb)*BoltzmannRatio* prm%pShearBand*prm%qShearBand)/ prm%sbResistance) &
|
dgdot_dtau = ((abs(gdot_sb)*BoltzmannRatio* prm%pShearBand*prm%qShearBand)/ prm%sbResistance) &
|
||||||
* StressRatio_pminus1*(1_pInt-StressRatio_p)**(prm%qShearBand-1.0_pReal)
|
* (abs(tau)/prm%sbResistance)**(prm%pShearBand-1.0_pReal) &
|
||||||
|
* (1.0_pReal-StressRatio_p)**(prm%qShearBand-1.0_pReal)
|
||||||
|
|
||||||
Lp = Lp + gdot_sb * Schmid_shearBand
|
Lp = Lp + gdot_sb * Schmid_shearBand
|
||||||
forall (k=1_pInt:3_pInt,l=1_pInt:3_pInt,m=1_pInt:3_pInt,n=1_pInt:3_pInt) &
|
forall (k=1_pInt:3_pInt,l=1_pInt:3_pInt,m=1_pInt:3_pInt,n=1_pInt:3_pInt) &
|
||||||
|
@ -1157,40 +1161,14 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
|
|
||||||
endif shearBandingContribution
|
endif shearBandingContribution
|
||||||
|
|
||||||
!call kinetics_twin(prm,stt,mse,of,S,temperature,gdot_slip,gdot_twin,dgdot_dtau_twin)
|
call kinetics_twin(prm,stt,mse,of,S,temperature,gdot_slip,gdot_twin,dgdot_dtau_twin)
|
||||||
|
gdot_twin = f_unrotated * gdot_twin
|
||||||
|
dgdot_dtau_twin = f_unrotated * dgdot_dtau_twin
|
||||||
twinContibution: do i = 1_pInt, prm%totalNtwin
|
twinContibution: do i = 1_pInt, prm%totalNtwin
|
||||||
|
Lp = Lp + gdot_twin(i)*prm%Schmid_twin(1:3,1:3,i)
|
||||||
tau = math_mul33xx33(S,prm%Schmid_twin(1:3,1:3,i))
|
forall (k=1_pInt:3_pInt,l=1_pInt:3_pInt,m=1_pInt:3_pInt,n=1_pInt:3_pInt) &
|
||||||
|
dLp_dS(k,l,m,n) = dLp_dS(k,l,m,n) &
|
||||||
significantTwinStress: if (tau > tol_math_check) then
|
+ dgdot_dtau_twin(i)* prm%Schmid_twin(k,l,i)*prm%Schmid_twin(m,n,i)
|
||||||
StressRatio_r = (mse%threshold_stress_twin(i,of)/tau)**prm%r(i)
|
|
||||||
|
|
||||||
isFCCtwin: if (prm%isFCC) then
|
|
||||||
s1=prm%fcc_twinNucleationSlipPair(1,i)
|
|
||||||
s2=prm%fcc_twinNucleationSlipPair(2,i)
|
|
||||||
if (tau < mse%tau_r_twin(i,of)) then
|
|
||||||
Ndot0_twin=(abs(gdot_slip(s1))*(stt%rhoEdge(s2,of)+stt%rhoEdgeDip(s2,of))+& !!!!! correct?
|
|
||||||
abs(gdot_slip(s2))*(stt%rhoEdge(s1,of)+stt%rhoEdgeDip(s1,of)))/&
|
|
||||||
(prm%L0_twin*prm%burgers_slip(i))*&
|
|
||||||
(1.0_pReal-exp(-prm%VcrossSlip/(kB*Temperature)*&
|
|
||||||
(mse%tau_r_twin(i,of)-tau)))
|
|
||||||
else
|
|
||||||
Ndot0_twin=0.0_pReal
|
|
||||||
end if
|
|
||||||
else isFCCtwin
|
|
||||||
Ndot0_twin=prm%Ndot0_twin(i)
|
|
||||||
endif isFCCtwin
|
|
||||||
|
|
||||||
gdot_twin = prm%shear_twin(i) * mse%twinVolume(i,of) * Ndot0_twin*exp(-StressRatio_r)
|
|
||||||
gdot_twin = (1.0_pReal-sumf_twin-sumf_trans) * gdot_twin
|
|
||||||
dgdot_dtau = ((gdot_twin*prm%r(i))/tau)*StressRatio_r
|
|
||||||
|
|
||||||
Lp = Lp + gdot_twin*prm%Schmid_twin(1:3,1:3,i)
|
|
||||||
forall (k=1_pInt:3_pInt,l=1_pInt:3_pInt,m=1_pInt:3_pInt,n=1_pInt:3_pInt) &
|
|
||||||
dLp_dS(k,l,m,n) = dLp_dS(k,l,m,n) &
|
|
||||||
+ dgdot_dtau* prm%Schmid_twin(k,l,i)*prm%Schmid_twin(m,n,i)
|
|
||||||
endif significantTwinStress
|
|
||||||
|
|
||||||
enddo twinContibution
|
enddo twinContibution
|
||||||
|
|
||||||
transConstribution: do i = 1_pInt, prm%totalNtrans
|
transConstribution: do i = 1_pInt, prm%totalNtrans
|
||||||
|
@ -1216,7 +1194,7 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
endif isFCCtrans
|
endif isFCCtrans
|
||||||
|
|
||||||
gdot_trans = mse%martensiteVolume(i,of) * Ndot0_trans*exp(-StressRatio_s)
|
gdot_trans = mse%martensiteVolume(i,of) * Ndot0_trans*exp(-StressRatio_s)
|
||||||
gdot_trans = (1.0_pReal-sumf_twin-sumf_trans)* gdot_trans
|
gdot_trans = f_unrotated * gdot_trans
|
||||||
dgdot_dtau = ((gdot_trans*prm%s(i))/tau)*StressRatio_s
|
dgdot_dtau = ((gdot_trans*prm%s(i))/tau)*StressRatio_s
|
||||||
Lp = Lp + gdot_trans*prm%Schmid_trans(1:3,1:3,i)
|
Lp = Lp + gdot_trans*prm%Schmid_trans(1:3,1:3,i)
|
||||||
|
|
||||||
|
@ -1263,7 +1241,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
|
|
||||||
integer(pInt) :: i,s1,s2, &
|
integer(pInt) :: i,s1,s2, &
|
||||||
of
|
of
|
||||||
real(pReal) :: sumf_twin,sumf_trans,StressRatio_p,BoltzmannRatio,&
|
real(pReal) :: f_unrotated,StressRatio_p,BoltzmannRatio,&
|
||||||
EdgeDipMinDistance,AtomicVolume,VacancyDiffusion,StressRatio_r,Ndot0_twin,stressRatio,&
|
EdgeDipMinDistance,AtomicVolume,VacancyDiffusion,StressRatio_r,Ndot0_twin,stressRatio,&
|
||||||
Ndot0_trans,StressRatio_s,EdgeDipDistance, ClimbVelocity,DotRhoEdgeDipClimb,DotRhoEdgeDipAnnihilation, &
|
Ndot0_trans,StressRatio_s,EdgeDipDistance, ClimbVelocity,DotRhoEdgeDipClimb,DotRhoEdgeDipAnnihilation, &
|
||||||
DotRhoDipFormation,DotRhoMultiplication,DotRhoEdgeEdgeAnnihilation, &
|
DotRhoDipFormation,DotRhoMultiplication,DotRhoEdgeEdgeAnnihilation, &
|
||||||
|
@ -1292,9 +1270,10 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
|
|
||||||
dot%whole(:,of) = 0.0_pReal
|
dot%whole(:,of) = 0.0_pReal
|
||||||
|
|
||||||
sumf_twin = sum(stt%twinFraction(1_pInt:prm%totalNtwin,of))
|
f_unrotated = 1.0_pReal &
|
||||||
sumf_trans = sum(stt%stressTransFraction(1_pInt:prm%totalNtrans,of)) + &
|
- sum(stt%twinFraction(1_pInt:prm%totalNtwin,of)) &
|
||||||
sum(stt%strainTransFraction(1_pInt:prm%totalNtrans,of))
|
- sum(stt%stressTransFraction(1_pInt:prm%totalNtrans,of)) &
|
||||||
|
- sum(stt%strainTransFraction(1_pInt:prm%totalNtrans,of))
|
||||||
|
|
||||||
slipState: do i = 1_pInt, prm%totalNslip
|
slipState: do i = 1_pInt, prm%totalNslip
|
||||||
|
|
||||||
|
@ -1373,8 +1352,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
else isFCCtwin
|
else isFCCtwin
|
||||||
Ndot0_twin=prm%Ndot0_twin(i)
|
Ndot0_twin=prm%Ndot0_twin(i)
|
||||||
endif isFCCtwin
|
endif isFCCtwin
|
||||||
dot%twinFraction(i,of) = (1.0_pReal-sumf_twin-sumf_trans)*&
|
dot%twinFraction(i,of) = f_unrotated * mse%twinVolume(i,of)*Ndot0_twin*exp(-StressRatio_r)
|
||||||
mse%twinVolume(i,of)*Ndot0_twin*exp(-StressRatio_r)
|
|
||||||
dot%accshear_twin(i,of) = dot%twinFraction(i,of) * prm%shear_twin(i)
|
dot%accshear_twin(i,of) = dot%twinFraction(i,of) * prm%shear_twin(i)
|
||||||
endif significantTwinStress
|
endif significantTwinStress
|
||||||
|
|
||||||
|
@ -1400,7 +1378,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
else isFCCtrans
|
else isFCCtrans
|
||||||
Ndot0_trans=prm%Ndot0_trans(i)
|
Ndot0_trans=prm%Ndot0_trans(i)
|
||||||
endif isFCCtrans
|
endif isFCCtrans
|
||||||
dot%strainTransFraction(i,of) = (1.0_pReal-sumf_twin-sumf_trans)*&
|
dot%strainTransFraction(i,of) = f_unrotated * &
|
||||||
mse%martensiteVolume(i,of)*Ndot0_trans*exp(-StressRatio_s)
|
mse%martensiteVolume(i,of)*Ndot0_trans*exp(-StressRatio_s)
|
||||||
!* Dotstate for accumulated shear due to transformation
|
!* Dotstate for accumulated shear due to transformation
|
||||||
!dot%accshear_trans(i,of) = dot%strainTransFraction(i,of) * &
|
!dot%accshear_trans(i,of) = dot%strainTransFraction(i,of) * &
|
||||||
|
@ -1545,6 +1523,88 @@ subroutine kinetics_twin(prm,stt,mse,of,S,temperature,gdot_slip,gdot_twin,dgdot_
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
|
||||||
|
!!--------------------------------------------------------------------------------------------------
|
||||||
|
!!> @brief calculates shear rates on transformation systems
|
||||||
|
!!--------------------------------------------------------------------------------------------------
|
||||||
|
!subroutine kinetics_trans(prm,stt,mse,of,S,temperature,gdot_slip,gdot_twin,dgdot_dtau_twin)
|
||||||
|
! use prec, only: &
|
||||||
|
! tol_math_check, &
|
||||||
|
! dNeq0
|
||||||
|
! use math, only: &
|
||||||
|
! math_mul33xx33
|
||||||
|
!
|
||||||
|
! implicit none
|
||||||
|
! type(tParameters), intent(in) :: &
|
||||||
|
! prm
|
||||||
|
! type(tDislotwinState), intent(in) :: &
|
||||||
|
! stt
|
||||||
|
! integer(pInt), intent(in) :: &
|
||||||
|
! of
|
||||||
|
! type(tDislotwinMicrostructure) :: &
|
||||||
|
! mse
|
||||||
|
! real(pReal), dimension(prm%totalNslip), intent(out) :: &
|
||||||
|
! gdot_slip
|
||||||
|
! real(pReal), dimension(prm%totalNtwin), intent(out) :: &
|
||||||
|
! gdot_twin
|
||||||
|
! real(pReal), dimension(prm%totalNtwin), optional, intent(out) :: &
|
||||||
|
! dgdot_dtau_twin
|
||||||
|
! real(pReal), dimension(3,3), intent(in) :: &
|
||||||
|
! S
|
||||||
|
! real(pReal), intent(in) :: &
|
||||||
|
! temperature
|
||||||
|
!
|
||||||
|
! real, dimension(prm%totalNtwin) :: &
|
||||||
|
! tau, &
|
||||||
|
! Ndot0_twin, &
|
||||||
|
! stressRatio_r, &
|
||||||
|
! dgdot_dtau
|
||||||
|
!
|
||||||
|
! integer(pInt) :: i,s1,s2
|
||||||
|
!
|
||||||
|
! do i = 1_pInt, prm%totalNtrans
|
||||||
|
! tau(i) = math_mul33xx33(S,prm%Schmid_trans(1:3,1:3,i))
|
||||||
|
! isFCC: if (prm%isFCC) then
|
||||||
|
! s1=prm%fcc_twinNucleationSlipPair(1,i)
|
||||||
|
! s2=prm%fcc_twinNucleationSlipPair(2,i)
|
||||||
|
! if (tau(i) < mse%tau_r_trans(i,of)) then
|
||||||
|
! Ndot0_trans=(abs(gdot_slip(s1))*(stt%rhoEdge(s2,of)+stt%rhoEdgeDip(s2,of))+& ! s1/s2 mixing correct?
|
||||||
|
! abs(gdot_slip(s2))*(stt%rhoEdge(s1,of)+stt%rhoEdgeDip(s1,of)))/&
|
||||||
|
! (prm%L0_trans*prm%burgers_slip(i))*& ! burgers_slip correct?
|
||||||
|
! (1.0_pReal-exp(-prm%VcrossSlip/(kB*Temperature)*&
|
||||||
|
! (mse%tau_r_trans(i,of)-tau)))
|
||||||
|
! else
|
||||||
|
! Ndot0_trans=0.0_pReal
|
||||||
|
! end if
|
||||||
|
! else isFCC
|
||||||
|
! Ndot0_trans=prm%Ndot0_trans(i)
|
||||||
|
! endif isFCC
|
||||||
|
! enddo
|
||||||
|
!
|
||||||
|
!
|
||||||
|
! endif isFCCtrans
|
||||||
|
! dot%strainTransFraction(i,of) = f_unrotated * &
|
||||||
|
! mse%martensiteVolume(i,of)*Ndot0_trans*exp(-StressRatio_s)
|
||||||
|
! !* Dotstate for accumulated shear due to transformation
|
||||||
|
! !dot%accshear_trans(i,of) = dot%strainTransFraction(i,of) * &
|
||||||
|
! ! lattice_sheartrans(index_myfamily+i,ph)
|
||||||
|
! endif significantTransStress
|
||||||
|
!
|
||||||
|
! enddo transState
|
||||||
|
!
|
||||||
|
!
|
||||||
|
! significantStress: where(tau > tol_math_check)
|
||||||
|
! StressRatio_r = (mse%threshold_stress_twin(:,of)/tau)**prm%r
|
||||||
|
! gdot_twin = prm%shear_twin * mse%twinVolume(:,of) * Ndot0_twin*exp(-StressRatio_r)
|
||||||
|
! dgdot_dtau = ((gdot_twin*prm%r)/tau)*StressRatio_r
|
||||||
|
! else where significantStress
|
||||||
|
! gdot_twin = 0.0_pReal
|
||||||
|
! dgdot_dtau = 0.0_pReal
|
||||||
|
! end where significantStress
|
||||||
|
!
|
||||||
|
! if(present(dgdot_dtau_twin)) dgdot_dtau_twin = dgdot_dtau
|
||||||
|
!
|
||||||
|
!end subroutine
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief return array of constitutive results
|
!> @brief return array of constitutive results
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
|
Loading…
Reference in New Issue