same structure as in phenopowerlaw

This commit is contained in:
Martin Diehl 2018-12-03 10:48:37 +01:00
parent 4b8f150731
commit fb651e24ef
1 changed files with 62 additions and 74 deletions

View File

@ -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