Introduce debug module, contains distributions of nCutback, nStressLoop, and nStateLoop
This commit is contained in:
parent
3a7ec38a3d
commit
b8b171c95b
|
@ -39,7 +39,7 @@
|
||||||
!*********************************************************
|
!*********************************************************
|
||||||
SUBROUTINE CPFEM_init()
|
SUBROUTINE CPFEM_init()
|
||||||
!
|
!
|
||||||
use prec, only: pReal,pInt
|
use prec
|
||||||
use math, only: math_EulertoR, math_I3, math_identity2nd
|
use math, only: math_EulertoR, math_I3, math_identity2nd
|
||||||
use mesh
|
use mesh
|
||||||
use constitutive
|
use constitutive
|
||||||
|
@ -106,6 +106,7 @@
|
||||||
CPFEM_en, CPFEM_in, CPFEM_stress, CPFEM_jaco, CPFEM_ngens)
|
CPFEM_en, CPFEM_in, CPFEM_stress, CPFEM_jaco, CPFEM_ngens)
|
||||||
!
|
!
|
||||||
use prec, only: pReal,pInt
|
use prec, only: pReal,pInt
|
||||||
|
use debug
|
||||||
use math, only: math_init, invnrmMandel
|
use math, only: math_init, invnrmMandel
|
||||||
use mesh, only: mesh_init,mesh_FEasCP, mesh_NcpElems, FE_Nips, FE_mapElemtype, mesh_element
|
use mesh, only: mesh_init,mesh_FEasCP, mesh_NcpElems, FE_Nips, FE_mapElemtype, mesh_element
|
||||||
use crystal, only: crystal_Init
|
use crystal, only: crystal_Init
|
||||||
|
@ -148,6 +149,9 @@ if(mod(CPFEM_cn,2)==0) then
|
||||||
endif
|
endif
|
||||||
CPFEM_cycle_old=CPFEM_cn
|
CPFEM_cycle_old=CPFEM_cn
|
||||||
! this shall be done in a parallel loop in the future
|
! this shall be done in a parallel loop in the future
|
||||||
|
debug_cutbackDistribution = 0_pInt
|
||||||
|
debug_stressLoopDistribution = 0_pInt
|
||||||
|
debug_stateLoopDistribution = 0_pInt
|
||||||
do e=1,mesh_NcpElems
|
do e=1,mesh_NcpElems
|
||||||
do i=1,FE_Nips(FE_mapElemtype(mesh_element(2,e)))
|
do i=1,FE_Nips(FE_mapElemtype(mesh_element(2,e)))
|
||||||
call CPFEM_stressIP(CPFEM_cn, CPFEM_dt, i, e)
|
call CPFEM_stressIP(CPFEM_cn, CPFEM_dt, i, e)
|
||||||
|
@ -185,6 +189,7 @@ if(mod(CPFEM_cn,2)==0) then
|
||||||
cp_en) ! Element number
|
cp_en) ! Element number
|
||||||
|
|
||||||
use prec, only: pReal,pInt,ijaco,nCutback
|
use prec, only: pReal,pInt,ijaco,nCutback
|
||||||
|
use debug
|
||||||
use math, only: math_pDecomposition,math_RtoEuler, inDeg
|
use math, only: math_pDecomposition,math_RtoEuler, inDeg
|
||||||
use IO, only: IO_error
|
use IO, only: IO_error
|
||||||
use mesh, only: mesh_element
|
use mesh, only: mesh_element
|
||||||
|
@ -240,7 +245,10 @@ if(mod(CPFEM_cn,2)==0) then
|
||||||
dt,cp_en,CPFEM_in,grain,updateJaco .and. t==CPFEM_dt,&
|
dt,cp_en,CPFEM_in,grain,updateJaco .and. t==CPFEM_dt,&
|
||||||
Fg(:,:,i_now),Fg(:,:,i_then),Fp(:,:,i_now),state(:,i_now))
|
Fg(:,:,i_now),Fg(:,:,i_then),Fp(:,:,i_now),state(:,i_now))
|
||||||
if (msg == 'ok') then ! solution converged
|
if (msg == 'ok') then ! solution converged
|
||||||
if (t == CPFEM_dt) exit ! reached final "then"
|
if (t == CPFEM_dt) then
|
||||||
|
debug_cutbackDistribution(i) = debug_cutbackDistribution(i)+1
|
||||||
|
exit ! reached final "then"
|
||||||
|
endif
|
||||||
else ! solution not found
|
else ! solution not found
|
||||||
i = i+1_pInt ! inc cutback counter
|
i = i+1_pInt ! inc cutback counter
|
||||||
! write(6,*) 'ncut:', i
|
! write(6,*) 'ncut:', i
|
||||||
|
@ -378,6 +386,7 @@ if(mod(CPFEM_cn,2)==0) then
|
||||||
state_old) ! former microstructure
|
state_old) ! former microstructure
|
||||||
|
|
||||||
use prec
|
use prec
|
||||||
|
use debug
|
||||||
use constitutive, only: constitutive_Nstatevars,&
|
use constitutive, only: constitutive_Nstatevars,&
|
||||||
constitutive_homogenizedC,constitutive_dotState,constitutive_LpAndItsTangent,&
|
constitutive_homogenizedC,constitutive_dotState,constitutive_LpAndItsTangent,&
|
||||||
constitutive_Microstructure
|
constitutive_Microstructure
|
||||||
|
@ -419,6 +428,7 @@ state: do ! outer iteration: state
|
||||||
iState = iState+1
|
iState = iState+1
|
||||||
if (iState > nState) then
|
if (iState > nState) then
|
||||||
msg = 'limit state iteration'
|
msg = 'limit state iteration'
|
||||||
|
debug_stateLoopDistribution(nState) = debug_stateLoopDistribution(nState)+1
|
||||||
return
|
return
|
||||||
endif
|
endif
|
||||||
call constitutive_Microstructure(state_new,CPFEM_Temperature(CPFEM_in,cp_en),grain,CPFEM_in,cp_en)
|
call constitutive_Microstructure(state_new,CPFEM_Temperature(CPFEM_in,cp_en),grain,CPFEM_in,cp_en)
|
||||||
|
@ -429,6 +439,7 @@ stress: do ! inner iteration: stress
|
||||||
iStress = iStress+1
|
iStress = iStress+1
|
||||||
if (iStress > nStress) then ! too many loops required
|
if (iStress > nStress) then ! too many loops required
|
||||||
msg = 'limit stress iteration'
|
msg = 'limit stress iteration'
|
||||||
|
debug_stressLoopDistribution(nStress) = debug_stateLoopDistribution(nStress)+1
|
||||||
return
|
return
|
||||||
endif
|
endif
|
||||||
p_hydro=(Tstar_v(1)+Tstar_v(2)+Tstar_v(3))/3.0_pReal
|
p_hydro=(Tstar_v(1)+Tstar_v(2)+Tstar_v(3))/3.0_pReal
|
||||||
|
@ -482,9 +493,10 @@ stress: do ! inner iteration: stress
|
||||||
|
|
||||||
|
|
||||||
enddo stress
|
enddo stress
|
||||||
|
debug_stressLoopDistribution(iStress) = debug_stressLoopDistribution(iStress)+1
|
||||||
Tstar_v = 0.5_pReal*matmul(C_66,math_Mandel33to6(matmul(transpose(B),AB)-math_I3))
|
Tstar_v = 0.5_pReal*matmul(C_66,math_Mandel33to6(matmul(transpose(B),AB)-math_I3))
|
||||||
!if ((printer==1_pInt).AND.(CPFEM_in==1_pInt).AND.(cp_en==1_pInt)) then
|
!if ((printer==1_pInt).AND.(CPFEM_in==1_pInt).AND.(cp_en==1_pInt)) then
|
||||||
!write(6,'(A10, 12ES12.3)') 'state_new', state_new
|
!write(6,'(A10, 24ES12.3)') 'state_new', state_new
|
||||||
!write(6,'(A10, 6ES12.3)') 'Tstar_v', Tstar_v
|
!write(6,'(A10, 6ES12.3)') 'Tstar_v', Tstar_v
|
||||||
!endif
|
!endif
|
||||||
dstate = dt*constitutive_dotState(Tstar_v,state_new,CPFEM_Temperature(CPFEM_in,cp_en),grain,CPFEM_in,cp_en) ! evolution of microstructure
|
dstate = dt*constitutive_dotState(Tstar_v,state_new,CPFEM_Temperature(CPFEM_in,cp_en),grain,CPFEM_in,cp_en) ! evolution of microstructure
|
||||||
|
@ -497,6 +509,7 @@ stress: do ! inner iteration: stress
|
||||||
if (maxval(abs(RstateS)) < reltol_State) exit state
|
if (maxval(abs(RstateS)) < reltol_State) exit state
|
||||||
|
|
||||||
enddo state
|
enddo state
|
||||||
|
debug_strateLoopDistribution(iState) = debug_stateLoopDistribution(iState)+1
|
||||||
|
|
||||||
invFp_new = matmul(invFp_old,B)
|
invFp_new = matmul(invFp_old,B)
|
||||||
call math_invert3x3(invFp_new,Fp_new,det,failed)
|
call math_invert3x3(invFp_new,Fp_new,det,failed)
|
||||||
|
@ -507,6 +520,7 @@ stress: do ! inner iteration: stress
|
||||||
Fp_new = Fp_new*det**(1.0_pReal/3.0_pReal) ! det = det(InvFp_new) !!
|
Fp_new = Fp_new*det**(1.0_pReal/3.0_pReal) ! det = det(InvFp_new) !!
|
||||||
Fe_new = matmul(Fg_new,invFp_new)
|
Fe_new = matmul(Fg_new,invFp_new)
|
||||||
return
|
return
|
||||||
|
|
||||||
END SUBROUTINE
|
END SUBROUTINE
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -559,6 +559,7 @@
|
||||||
SUBROUTINE IO_error(ID)
|
SUBROUTINE IO_error(ID)
|
||||||
|
|
||||||
use prec, only: pInt
|
use prec, only: pInt
|
||||||
|
use debug
|
||||||
implicit none
|
implicit none
|
||||||
|
|
||||||
integer(pInt) ID
|
integer(pInt) ID
|
||||||
|
@ -581,7 +582,7 @@
|
||||||
case (500)
|
case (500)
|
||||||
msg='Unknown lattice type specified'
|
msg='Unknown lattice type specified'
|
||||||
case (600)
|
case (600)
|
||||||
msg='Stress iteration did not converge'
|
msg='Convergence not reached'
|
||||||
case (700)
|
case (700)
|
||||||
msg='Singular matrix in stress iteration'
|
msg='Singular matrix in stress iteration'
|
||||||
case default
|
case default
|
||||||
|
@ -591,6 +592,9 @@
|
||||||
write(6,*) 'MPIE Material Routine Ver. 0.0 by the coding team'
|
write(6,*) 'MPIE Material Routine Ver. 0.0 by the coding team'
|
||||||
write(6,*)
|
write(6,*)
|
||||||
write(6,*) msg
|
write(6,*) msg
|
||||||
|
write(6,*)
|
||||||
|
call debug_info()
|
||||||
|
|
||||||
call flush(6)
|
call flush(6)
|
||||||
call quit(9000+ID)
|
call quit(9000+ID)
|
||||||
! ABAQUS returns in some cases
|
! ABAQUS returns in some cases
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
|
||||||
|
!##############################################################
|
||||||
|
MODULE debug
|
||||||
|
!##############################################################
|
||||||
|
use prec
|
||||||
|
|
||||||
|
implicit none
|
||||||
|
integer(pInt), dimension(nCutback) :: debug_cutbackDistribution
|
||||||
|
integer(pInt), dimension(nStress) :: debug_stressLoopDistribution
|
||||||
|
integer(pInt), dimension(nState) :: debug_stateLoopDistribution
|
||||||
|
|
||||||
|
CONTAINS
|
||||||
|
|
||||||
|
|
||||||
|
!********************************************************************
|
||||||
|
! write debug statements to standard out
|
||||||
|
!********************************************************************
|
||||||
|
SUBROUTINE debug_info()
|
||||||
|
|
||||||
|
use prec
|
||||||
|
implicit none
|
||||||
|
|
||||||
|
integer(pInt) i
|
||||||
|
|
||||||
|
write(6,*) 'DEBUG Info'
|
||||||
|
write(6,*) 'distribution_cutback :'
|
||||||
|
do i=1,nCutback
|
||||||
|
if (debug_cutbackDistribution(i) > 0) write(6,*) i,debug_cutbackDistribution(i)
|
||||||
|
enddo
|
||||||
|
write(6,*)
|
||||||
|
|
||||||
|
write(6,*) 'distribution_stressLoop :'
|
||||||
|
do i=1,nStress
|
||||||
|
if (debug_stressLoopDistribution(i) > 0) write(6,*) i,debug_stressLoopDistribution(i)
|
||||||
|
enddo
|
||||||
|
write(6,*)
|
||||||
|
|
||||||
|
write(6,*) 'distribution_stateLoop :'
|
||||||
|
do i=1,nState
|
||||||
|
if (debug_stateLoopDistribution(i) > 0) write(6,*) i,debug_stateLoopDistribution(i)
|
||||||
|
enddo
|
||||||
|
write(6,*)
|
||||||
|
|
||||||
|
END SUBROUTINE
|
||||||
|
|
||||||
|
END MODULE debug
|
|
@ -28,6 +28,7 @@
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
!
|
!
|
||||||
include "prec.f90"
|
include "prec.f90"
|
||||||
|
include "debug.f90"
|
||||||
include "math.f90"
|
include "math.f90"
|
||||||
include "IO.f90"
|
include "IO.f90"
|
||||||
include "mesh.f90"
|
include "mesh.f90"
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
!********************************************************************
|
!********************************************************************
|
||||||
!
|
!
|
||||||
include "prec.f90"
|
include "prec.f90"
|
||||||
|
include "debug.f90"
|
||||||
include "math.f90"
|
include "math.f90"
|
||||||
include "IO.f90"
|
include "IO.f90"
|
||||||
include "mesh.f90"
|
include "mesh.f90"
|
||||||
|
|
|
@ -17,11 +17,11 @@
|
||||||
! *** Perturbation of strain array for numerical calculation of FEM Jacobi matrix ***
|
! *** Perturbation of strain array for numerical calculation of FEM Jacobi matrix ***
|
||||||
real(pReal), parameter :: pert_e=1.0e-5_pReal
|
real(pReal), parameter :: pert_e=1.0e-5_pReal
|
||||||
! *** Maximum number of iterations in outer (state variables) loop ***
|
! *** Maximum number of iterations in outer (state variables) loop ***
|
||||||
integer(pInt), parameter :: nState = 50_pInt
|
integer(pInt), parameter :: nState = 500_pInt
|
||||||
! *** Convergence criteria for outer (state variables) loop ***
|
! *** Convergence criteria for outer (state variables) loop ***
|
||||||
real(pReal), parameter :: reltol_State = 1.0e-6_pReal
|
real(pReal), parameter :: reltol_State = 1.0e-6_pReal
|
||||||
! *** Maximum number of iterations in inner (stress) loop ***
|
! *** Maximum number of iterations in inner (stress) loop ***
|
||||||
integer(pInt), parameter :: nStress = 500_pInt
|
integer(pInt), parameter :: nStress = 1000_pInt
|
||||||
! *** Convergence criteria for inner (stress) loop ***
|
! *** Convergence criteria for inner (stress) loop ***
|
||||||
real(pReal), parameter :: reltol_Stress = 1.0e-6_pReal
|
real(pReal), parameter :: reltol_Stress = 1.0e-6_pReal
|
||||||
! *** Convergence criteria for inner (stress) loop ***
|
! *** Convergence criteria for inner (stress) loop ***
|
||||||
|
|
Loading…
Reference in New Issue