same structure as in phenopowerlaw
This commit is contained in:
parent
4b8f150731
commit
fb651e24ef
|
@ -678,7 +678,6 @@ end subroutine plastic_disloUCLA_dotState
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
function plastic_disloUCLA_postResults(Mp,Temperature,instance,of) result(postResults)
|
function plastic_disloUCLA_postResults(Mp,Temperature,instance,of) result(postResults)
|
||||||
use prec, only: &
|
use prec, only: &
|
||||||
tol_math_check, &
|
|
||||||
dEq, dNeq0
|
dEq, dNeq0
|
||||||
use math, only: &
|
use math, only: &
|
||||||
pi, &
|
pi, &
|
||||||
|
@ -686,86 +685,75 @@ math_mul33xx33
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
real(pReal), dimension(3,3), intent(in) :: &
|
real(pReal), dimension(3,3), intent(in) :: &
|
||||||
Mp !< 2nd Piola Kirchhoff stress tensor in Mandel notation
|
Mp !< Mandel stress
|
||||||
real(pReal), intent(in) :: &
|
real(pReal), intent(in) :: &
|
||||||
temperature !< temperature at integration point
|
Temperature !< Mandel stress
|
||||||
integer(pInt), intent(in) :: &
|
integer(pInt), intent(in) :: &
|
||||||
instance,of
|
instance, &
|
||||||
|
of
|
||||||
|
|
||||||
real(pReal), dimension(plastic_disloUCLA_sizePostResults(instance)) :: &
|
real(pReal), dimension(sum(plastic_disloUCLA_sizePostResult(:,instance))) :: &
|
||||||
postResults
|
postResults
|
||||||
|
|
||||||
integer(pInt) :: &
|
integer(pInt) :: &
|
||||||
ns,&
|
o,c,i
|
||||||
o,c,j
|
real(pReal), dimension(param(instance)%totalNslip) :: &
|
||||||
real(pReal), dimension(plastic_disloUCLA_totalNslip(instance)) :: &
|
gdot_slip_pos,dgdot_dtauslip_pos,tau_slip_pos, &
|
||||||
gdot_slip_pos,dgdot_dtauslip_pos,tau_slip_pos,gdot_slip_neg,dgdot_dtauslip_neg,tau_slip_neg
|
gdot_slip_neg,dgdot_dtauslip_neg,tau_slip_neg
|
||||||
|
|
||||||
ns = plastic_disloUCLA_totalNslip(instance)
|
|
||||||
|
|
||||||
c = 0_pInt
|
|
||||||
postResults = 0.0_pReal
|
|
||||||
associate( prm => param(instance), stt => state(instance), mse => microstructure(instance))
|
associate( prm => param(instance), stt => state(instance), mse => microstructure(instance))
|
||||||
do o = 1_pInt,plastic_disloUCLA_Noutput(instance)
|
|
||||||
select case(plastic_disloUCLA_outputID(o,instance))
|
postResults = 0.0_pReal
|
||||||
|
c = 0_pInt
|
||||||
|
|
||||||
|
outputsLoop: do o = 1_pInt,size(prm%outputID)
|
||||||
|
select case(prm%outputID(o))
|
||||||
|
|
||||||
case (rho_ID)
|
case (rho_ID)
|
||||||
postResults(c+1_pInt:c+ns) = stt%rhoEdge(1_pInt:ns,of)
|
postResults(c+1_pInt:c+prm%totalNslip) = stt%rhoEdge(1_pInt:prm%totalNslip,of)
|
||||||
c = c + ns
|
|
||||||
case (rhoDip_ID)
|
case (rhoDip_ID)
|
||||||
postResults(c+1_pInt:c+ns) = stt%rhoEdgeDip(1_pInt:ns,of)
|
postResults(c+1_pInt:c+prm%totalNslip) = stt%rhoEdgeDip(1_pInt:prm%totalNslip,of)
|
||||||
c = c + ns
|
|
||||||
case (shearrate_ID,stressexponent_ID)
|
case (shearrate_ID,stressexponent_ID)
|
||||||
call kinetics(Mp,Temperature,instance,of, &
|
call kinetics(Mp,Temperature,instance,of, &
|
||||||
gdot_slip_pos,dgdot_dtauslip_pos,tau_slip_pos,gdot_slip_neg,dgdot_dtauslip_neg,tau_slip_neg)
|
gdot_slip_pos,dgdot_dtauslip_pos,tau_slip_pos,gdot_slip_neg,dgdot_dtauslip_neg,tau_slip_neg)
|
||||||
|
|
||||||
if (plastic_disloUCLA_outputID(o,instance) == shearrate_ID) then
|
if (prm%outputID(o) == shearrate_ID) then
|
||||||
postResults(c+1:c+ns) = (gdot_slip_pos + gdot_slip_neg)*0.5_pReal
|
postResults(c+1:c+prm%totalNslip) = (gdot_slip_pos + gdot_slip_neg)*0.5_pReal
|
||||||
c = c + ns
|
elseif(prm%outputID(o) == stressexponent_ID) then
|
||||||
elseif(plastic_disloUCLA_outputID(o,instance) == stressexponent_ID) then
|
where (dNeq0(gdot_slip_pos+gdot_slip_neg))
|
||||||
do j = 1_pInt, ns
|
postResults(c+1_pInt:c + prm%totalNslip) = (tau_slip_pos+tau_slip_neg) * 0.5_pReal &
|
||||||
if (dEq(gdot_slip_pos(j)+gdot_slip_neg(j),0.0_pReal)) then
|
/ (gdot_slip_pos+gdot_slip_neg) &
|
||||||
postResults(c+j) = 0.0_pReal
|
* (dgdot_dtauslip_pos+dgdot_dtauslip_neg)
|
||||||
else
|
else where
|
||||||
postResults(c+j) = (tau_slip_pos(j)+tau_slip_neg(j))/&
|
postResults(c+1_pInt:c + prm%totalNslip) = 0.0_pReal
|
||||||
(gdot_slip_pos(j)+gdot_slip_neg(j))*&
|
end where
|
||||||
(dgdot_dtauslip_pos(j)+dgdot_dtauslip_neg(j))* 0.5_pReal
|
|
||||||
endif
|
endif
|
||||||
enddo
|
|
||||||
c = c + ns
|
|
||||||
endif
|
|
||||||
|
|
||||||
case (accumulatedshear_ID)
|
case (accumulatedshear_ID)
|
||||||
postResults(c+1_pInt:c+ns) = &
|
postResults(c+1_pInt:c+prm%totalNslip) = stt%accshear_slip(1_pInt:prm%totalNslip, of)
|
||||||
stt%accshear_slip(1_pInt:ns, of)
|
|
||||||
c = c + ns
|
|
||||||
case (mfp_ID)
|
case (mfp_ID)
|
||||||
postResults(c+1_pInt:c+ns) = mse%mfp(1_pInt:ns, of)
|
postResults(c+1_pInt:c+prm%totalNslip) = mse%mfp(1_pInt:prm%totalNslip, of)
|
||||||
c = c + ns
|
|
||||||
case (resolvedstress_ID)
|
case (resolvedstress_ID)
|
||||||
do j = 1_pInt, prm%totalNslip
|
do i = 1_pInt, prm%totalNslip
|
||||||
|
postResults(c+i) =math_mul33xx33(Mp,prm%nonSchmid_pos(1:3,1:3,i))
|
||||||
postResults(c+j) =math_mul33xx33(Mp,prm%nonSchmid_pos(1:3,1:3,j))
|
|
||||||
enddo
|
enddo
|
||||||
c = c + ns
|
|
||||||
case (thresholdstress_ID)
|
case (thresholdstress_ID)
|
||||||
postResults(c+1_pInt:c+ns) = mse%threshold_stress(1_pInt:ns,of)
|
postResults(c+1_pInt:c+prm%totalNslip) = mse%threshold_stress(1_pInt:prm%totalNslip,of)
|
||||||
c = c + ns
|
|
||||||
case (dipoleDistance_ID)
|
case (dipoleDistance_ID)
|
||||||
do j = 1_pInt, prm%totalNslip
|
do i = 1_pInt, prm%totalNslip
|
||||||
if (dNeq0(abs(math_mul33xx33(Mp,prm%nonSchmid_pos(1:3,1:3,j))))) then
|
if (dNeq0(abs(math_mul33xx33(Mp,prm%nonSchmid_pos(1:3,1:3,i))))) then
|
||||||
postResults(c+j) = &
|
postResults(c+i) = (3.0_pReal*prm%mu*prm%burgers(i)) &
|
||||||
(3.0_pReal*prm%mu*prm%burgers(j))/&
|
/ (16.0_pReal*pi*abs(math_mul33xx33(Mp,prm%nonSchmid_pos(1:3,1:3,i))))
|
||||||
(16.0_pReal*pi*abs(math_mul33xx33(Mp,prm%nonSchmid_pos(1:3,1:3,j))))
|
|
||||||
else
|
else
|
||||||
postResults(c+j) = huge(1.0_pReal)
|
postResults(c+i) = huge(1.0_pReal)
|
||||||
endif
|
endif
|
||||||
postResults(c+j)=min(postResults(c+j),mse%mfp(j,of))
|
postResults(c+i)=min(postResults(c+i),mse%mfp(i,of))
|
||||||
enddo
|
enddo
|
||||||
c = c + ns
|
|
||||||
end select
|
end select
|
||||||
enddo
|
|
||||||
|
c = c + prm%totalNslip
|
||||||
|
enddo outputsLoop
|
||||||
end associate
|
end associate
|
||||||
|
|
||||||
end function plastic_disloUCLA_postResults
|
end function plastic_disloUCLA_postResults
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue