New version of constitutive_dislo.f90, where some dangerous spots were reformulated.

PROBLEM: [001] in tension does not have a symmetrical change of shape, which is definitely not good at all. I checked my implementation and I really do not see any errors. Could someone check it out? Can it comes from the numerical integration?
This commit is contained in:
Luc Hantcherli 2008-11-07 16:34:29 +00:00
parent 6e13ed0566
commit 3ec8ec6b15
1 changed files with 31 additions and 14 deletions

View File

@ -670,7 +670,7 @@ use math, only: math_sampleGaussOri,math_sampleFiberOri,math_sampleRandomOri,mat
math_Mandel3333to66,math_Mandel66to3333 math_Mandel3333to66,math_Mandel66to3333
use mesh, only: mesh_NcpElems,FE_Nips,mesh_maxNips,mesh_element use mesh, only: mesh_NcpElems,FE_Nips,mesh_maxNips,mesh_element
use IO, only: IO_hybridIA use IO, only: IO_hybridIA
use lattice, only: lattice_SlipSlipIntType,lattice_sn,lattice_st,lattice_Qtwin,lattice_Sslip_v,lattice_Sslip use lattice, only: lattice_SlipIntType,lattice_sn,lattice_st,lattice_Qtwin,lattice_Sslip_v,lattice_Sslip
implicit none implicit none
!* Definition of variables !* Definition of variables
@ -876,9 +876,9 @@ do i=1,material_maxN
x=dot_product(lattice_sn(:,j,i),lattice_st(:,k,i)) x=dot_product(lattice_sn(:,j,i),lattice_st(:,k,i))
y=1.0_pReal-x**(2.0_pReal) y=1.0_pReal-x**(2.0_pReal)
!* Interaction matrix * !* Interaction matrix *
constitutive_Pforest(j,k,i)=abs(x)*material_SlipIntCoeff(lattice_SlipSlipIntType(j,k,i),i) constitutive_Pforest(j,k,i)=abs(x)*material_SlipIntCoeff(lattice_SlipIntType(j,k,i),i)
if (y>0.0_pReal) then if (y>0.0_pReal) then
constitutive_Pparallel(j,k,i)=sqrt(y)*material_SlipIntCoeff(lattice_SlipSlipIntType(j,k,i),i) constitutive_Pparallel(j,k,i)=sqrt(y)*material_SlipIntCoeff(lattice_SlipIntType(j,k,i),i)
else else
constitutive_Pparallel(j,k,i)=0.0_pReal constitutive_Pparallel(j,k,i)=0.0_pReal
endif endif
@ -886,7 +886,6 @@ do i=1,material_maxN
enddo enddo
enddo enddo
end subroutine end subroutine
@ -1004,7 +1003,7 @@ do i=1,material_Nslip(matID)
Sslip = lattice_Sslip(:,:,i,material_CrystalStructure(matID)) Sslip = lattice_Sslip(:,:,i,material_CrystalStructure(matID))
tau_slip(i) = dot_product(Tstar_v,lattice_Sslip_v(:,i,material_CrystalStructure(matID))) tau_slip(i) = dot_product(Tstar_v,lattice_Sslip_v(:,i,material_CrystalStructure(matID)))
if (abs(tau_slip(i)) > constitutive_passing_stress(i)) then if (abs(tau_slip(i)) > constitutive_passing_stress(i)) then
gdot_slip(i) = constitutive_g0_slip(i)*(tau_slip(i)/abs(tau_slip(i)))*& gdot_slip(i) = constitutive_g0_slip(i)*sign(1.d0,tau_slip(i))*&
sinh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp)) sinh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp))
dgdot_dtauslip(i) = (constitutive_g0_slip(i)*constitutive_activation_volume(i))/(Kb*Tp)*& dgdot_dtauslip(i) = (constitutive_g0_slip(i)*constitutive_activation_volume(i))/(Kb*Tp)*&
cosh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp)) cosh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp))
@ -1012,6 +1011,9 @@ do i=1,material_Nslip(matID)
Lp = Lp + gdot_slip(i) * Sslip Lp = Lp + gdot_slip(i) * Sslip
enddo enddo
write(6,*) 'constitutive_g0_slip'
write(6,*) constitutive_g0_slip
!* Calculation of the tangent of Lp !* Calculation of the tangent of Lp
do i=1,material_Nslip(matID) do i=1,material_Nslip(matID)
Sslip = lattice_Sslip(:,:,i,material_CrystalStructure(matID)) Sslip = lattice_Sslip(:,:,i,material_CrystalStructure(matID))
@ -1063,15 +1065,15 @@ gdot_slip = 0.0_pReal
do i=1,material_Nslip(matID) do i=1,material_Nslip(matID)
tau_slip(i) = dot_product(Tstar_v,lattice_Sslip_v(:,i,material_CrystalStructure(matID))) tau_slip(i) = dot_product(Tstar_v,lattice_Sslip_v(:,i,material_CrystalStructure(matID)))
if (abs(tau_slip(i)) > constitutive_passing_stress(i)) then if (abs(tau_slip(i)) > constitutive_passing_stress(i)) then
gdot_slip(i) = constitutive_g0_slip(i)*(tau_slip(i)/abs(tau_slip(i)))*& gdot_slip(i) = constitutive_g0_slip(i)*sign(1.d0,tau_slip(i))*&
sinh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp)) sinh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp))
endif
locks(i) = (sqrt(constitutive_rho_f(i))*abs(gdot_slip(i)))/(material_c4(matID)*material_bg(matID)) locks(i) = (sqrt(constitutive_rho_f(i))*abs(gdot_slip(i)))/(material_c4(matID)*material_bg(matID))
grainboundaries(i) = abs(gdot_slip(i))/(material_c5(matID)*material_bg(matID)*material_GrainSize(matID)) grainboundaries(i) = abs(gdot_slip(i))/(material_c5(matID)*material_bg(matID)*material_GrainSize(matID))
athermal_recovery(i) = material_c7(matID)*state(i)*abs(gdot_slip(i)) athermal_recovery(i) = material_c7(matID)*state(i)*abs(gdot_slip(i))
thermal_recovery(i) = material_c8(matID)*abs(tau_slip(i))*state(i)**2*((material_D0(matID)*material_bg(matID)**3)/& thermal_recovery(i) = material_c8(matID)*abs(tau_slip(i))*state(i)**2*((material_D0(matID)*material_bg(matID)**3)/&
(kB*Tp))*exp(-material_Qsd(matID)/(kB*Tp)) (kB*Tp))*exp(-material_Qsd(matID)/(kB*Tp))
constitutive_dotState(i) = locks(i)+grainboundaries(i)-athermal_recovery(i)-thermal_recovery(i) constitutive_dotState(i) = locks(i)+grainboundaries(i)-athermal_recovery(i) !-thermal_recovery(i)
endif
enddo enddo
return return
@ -1092,6 +1094,7 @@ function constitutive_post_results(Tstar_v,state,Tp,dt,ipc,ip,el)
!* constitutive_Nresults has to be set accordingly in _Assignment * !* constitutive_Nresults has to be set accordingly in _Assignment *
!********************************************************************* !*********************************************************************
use prec, only: pReal,pInt use prec, only: pReal,pInt
use lattice, only: lattice_Sslip_v
implicit none implicit none
!* Definition of variables !* Definition of variables
@ -1099,7 +1102,7 @@ integer(pInt) i,ipc,ip,el
integer(pInt) matID integer(pInt) matID
real(pReal) Tp,dt real(pReal) Tp,dt
real(pReal), dimension(6) :: Tstar_v real(pReal), dimension(6) :: Tstar_v
real(pReal), dimension(constitutive_Nstatevars(ipc,ip,el)) :: state real(pReal), dimension(constitutive_Nstatevars(ipc,ip,el)) :: state,tau_slip,gdot_slip
real(pReal), dimension(constitutive_Nresults(ipc,ip,el)) :: constitutive_post_results real(pReal), dimension(constitutive_Nresults(ipc,ip,el)) :: constitutive_post_results
!* Get the material-ID from the triplet(ipc,ip,el) !* Get the material-ID from the triplet(ipc,ip,el)
@ -1108,10 +1111,24 @@ constitutive_post_results=0.0_pReal
!* Output variables !* Output variables
if(constitutive_Nresults(ipc,ip,el)==0) return if(constitutive_Nresults(ipc,ip,el)==0) return
!* Dislocation density evolution
do i=1,material_Nslip(matID)
tau_slip(i) = dot_product(Tstar_v,lattice_Sslip_v(:,i,material_CrystalStructure(matID)))
if (abs(tau_slip(i)) > constitutive_passing_stress(i)) then
gdot_slip(i) = constitutive_g0_slip(i)*sign(1.d0,tau_slip(i))*&
sinh(((abs(tau_slip(i))-constitutive_passing_stress(i))*constitutive_activation_volume(i))/(Kb*Tp))
endif
enddo
!* Output variables
constitutive_post_results(1) = sum(state(1:material_Nslip(matID))) constitutive_post_results(1) = sum(state(1:material_Nslip(matID)))
do i=1,material_Nslip(matID) do i=1,material_Nslip(matID)
constitutive_post_results(2+i) = state(i) constitutive_post_results(2+i) = state(i)
enddo enddo
do i=1,material_Nslip(matID)
constitutive_post_results(2+material_Nslip(matID)+i) = constitutive_passing_stress(i)
enddo
return return
end function end function