prepared loop distributions to hold "over shooters"

This commit is contained in:
Philip Eisenlohr 2012-10-12 18:00:55 +00:00
parent 82a13af474
commit 05c5ea42d7
1 changed files with 35 additions and 32 deletions

View File

@ -65,19 +65,19 @@ module debug
debug_level = 0_pInt debug_level = 0_pInt
integer(pInt), public :: & integer(pInt), public :: &
debug_cumLpCalls = 0_pInt, & debug_cumLpCalls = 0_pInt, & ! total number of calls to LpAndItsTangent
debug_cumDeltaStateCalls = 0_pInt, & debug_cumDeltaStateCalls = 0_pInt, & ! total number of calls to deltaState
debug_cumDotStateCalls = 0_pInt, & debug_cumDotStateCalls = 0_pInt, & ! total number of calls to dotState
debug_cumDotTemperatureCalls = 0_pInt, & debug_cumDotTemperatureCalls = 0_pInt, & ! total number of calls to dotTemprature
debug_e = 1_pInt, & debug_e = 1_pInt, &
debug_i = 1_pInt, & debug_i = 1_pInt, &
debug_g = 1_pInt debug_g = 1_pInt
integer(pLongInt), public :: & integer(pLongInt), public :: &
debug_cumLpTicks = 0_pLongInt, & debug_cumLpTicks = 0_pLongInt, & ! total cpu ticks spent in LpAndItsTangent
debug_cumDeltaStateTicks = 0_pLongInt, & debug_cumDeltaStateTicks = 0_pLongInt, & ! total cpu ticks spent in deltaState
debug_cumDotStateTicks = 0_pLongInt, & debug_cumDotStateTicks = 0_pLongInt, & ! total cpu ticks spent in dotState
debug_cumDotTemperatureTicks = 0_pLongInt debug_cumDotTemperatureTicks = 0_pLongInt ! total cpu ticks spent in dotTemperature
integer(pInt), dimension(2), public :: & integer(pInt), dimension(2), public :: &
debug_stressMaxLocation = 0_pInt, & debug_stressMaxLocation = 0_pInt, &
@ -86,14 +86,14 @@ module debug
debug_jacobianMinLocation = 0_pInt debug_jacobianMinLocation = 0_pInt
integer(pInt), dimension(:), allocatable, public :: & integer(pInt), dimension(:), allocatable, public :: &
debug_CrystalliteLoopDistribution, & debug_CrystalliteLoopDistribution, & ! distribution of crystallite cutbacks
debug_MaterialpointStateLoopDistribution, & debug_MaterialpointStateLoopDistribution, &
debug_MaterialpointLoopDistribution debug_MaterialpointLoopDistribution
integer(pInt), dimension(:,:), allocatable, public :: & integer(pInt), dimension(:,:), allocatable, public :: &
debug_StressLoopDistribution, & debug_StressLoopDistribution, & ! distribution of stress iterations until convergence
debug_LeapfrogBreakDistribution, & debug_LeapfrogBreakDistribution, & ! distribution of iterations where leapfrog breaks occurred
debug_StateLoopDistribution debug_StateLoopDistribution ! distribution of state iterations until convergence
real(pReal), public :: & real(pReal), public :: &
debug_stressMax = -huge(1.0_pReal), & debug_stressMax = -huge(1.0_pReal), &
@ -149,15 +149,15 @@ subroutine debug_init
if (allocated(debug_StressLoopDistribution)) & if (allocated(debug_StressLoopDistribution)) &
deallocate(debug_StressLoopDistribution) deallocate(debug_StressLoopDistribution)
allocate(debug_StressLoopDistribution(nStress,2)) allocate(debug_StressLoopDistribution(nStress+1,2))
debug_StressLoopDistribution = 0_pInt debug_StressLoopDistribution = 0_pInt
if (allocated(debug_LeapfrogBreakDistribution)) & if (allocated(debug_LeapfrogBreakDistribution)) &
deallocate(debug_LeapfrogBreakDistribution) deallocate(debug_LeapfrogBreakDistribution)
allocate(debug_LeapfrogBreakDistribution(nStress,2)) allocate(debug_LeapfrogBreakDistribution(nStress+1,2))
debug_LeapfrogBreakDistribution = 0_pInt debug_LeapfrogBreakDistribution = 0_pInt
if (allocated(debug_StateLoopDistribution)) & if (allocated(debug_StateLoopDistribution)) &
deallocate(debug_StateLoopDistribution) deallocate(debug_StateLoopDistribution)
allocate(debug_StateLoopDistribution(nState,2)) allocate(debug_StateLoopDistribution(nState+1,2))
debug_StateLoopDistribution = 0_pInt debug_StateLoopDistribution = 0_pInt
if (allocated(debug_CrystalliteLoopDistribution)) & if (allocated(debug_CrystalliteLoopDistribution)) &
deallocate(debug_CrystalliteLoopDistribution) deallocate(debug_CrystalliteLoopDistribution)
@ -364,6 +364,7 @@ subroutine debug_info
implicit none implicit none
integer(pInt) :: i,integral integer(pInt) :: i,integral
integer(pLongInt) :: tickrate integer(pLongInt) :: tickrate
character(len=1) :: exceed
call system_clock(count_rate=tickrate) call system_clock(count_rate=tickrate)
@ -411,11 +412,14 @@ subroutine debug_info
write(6,*) write(6,*)
write(6,*) write(6,*)
write(6,*) 'distribution_StressLoop : stress frogbreak stiffness frogbreak' write(6,*) 'distribution_StressLoop : stress frogbreak stiffness frogbreak'
do i=1_pInt,nStress do i=1_pInt,nStress+1_pInt
if (any(debug_StressLoopDistribution(i,:) /= 0_pInt ) .or. & if (any(debug_StressLoopDistribution(i,:) /= 0_pInt ) .or. &
any(debug_LeapfrogBreakDistribution(i,:) /= 0_pInt ) ) then any(debug_LeapfrogBreakDistribution(i,:) /= 0_pInt ) ) then
integral = integral + i*debug_StressLoopDistribution(i,1) + i*debug_StressLoopDistribution(i,2) integral = integral + i*(debug_StressLoopDistribution(i,1) + debug_StressLoopDistribution(i,2))
write(6,'(i25,1x,i10,1x,i10,1x,i10,1x,i10)') i,debug_StressLoopDistribution(i,1),debug_LeapfrogBreakDistribution(i,1), & exceed = ' '
if (i > nStress) exceed = '+' ! last entry gets "+"
write(6,'(i25,a1,i10,1x,i10,1x,i10,1x,i10)') min(nStress,i),exceed, &
debug_StressLoopDistribution(i,1),debug_LeapfrogBreakDistribution(i,1), &
debug_StressLoopDistribution(i,2),debug_LeapfrogBreakDistribution(i,2) debug_StressLoopDistribution(i,2),debug_LeapfrogBreakDistribution(i,2)
endif endif
enddo enddo
@ -426,10 +430,13 @@ subroutine debug_info
integral = 0_pInt integral = 0_pInt
write(6,*) write(6,*)
write(6,*) 'distribution_CrystalliteStateLoop :' write(6,*) 'distribution_CrystalliteStateLoop :'
do i=1_pInt,nState do i=1_pInt,nState+1_pInt
if (any(debug_StateLoopDistribution(i,:) /= 0)) then if (any(debug_StateLoopDistribution(i,:) /= 0)) then
integral = integral + i*debug_StateLoopDistribution(i,1) + i*debug_StateLoopDistribution(i,2) integral = integral + i*(debug_StateLoopDistribution(i,1) + debug_StateLoopDistribution(i,2))
write(6,'(i25,1x,i10,12x,i10)') i,debug_StateLoopDistribution(i,1),debug_StateLoopDistribution(i,2) exceed = ' '
if (i > nState) exceed = '+' ! last entry gets "+"
write(6,'(i25,a1,i10,12x,i10)') min(nState,i),exceed, &
debug_StateLoopDistribution(i,1),debug_StateLoopDistribution(i,2)
endif endif
enddo enddo
write(6,'(a15,i10,1x,i10,12x,i10)') ' total',integral,& write(6,'(a15,i10,1x,i10,12x,i10)') ' total',integral,&
@ -442,11 +449,9 @@ subroutine debug_info
do i=1_pInt,nCryst+1_pInt do i=1_pInt,nCryst+1_pInt
if (debug_CrystalliteLoopDistribution(i) /= 0) then if (debug_CrystalliteLoopDistribution(i) /= 0) then
integral = integral + i*debug_CrystalliteLoopDistribution(i) integral = integral + i*debug_CrystalliteLoopDistribution(i)
if (i <= nCryst) then exceed = ' '
write(6,'(i25,1x,i10)') i,debug_CrystalliteLoopDistribution(i) if (i > nCryst) exceed = '+'
else write(6,'(i25,a1,i10)') min(nCryst,i),exceed,debug_CrystalliteLoopDistribution(i)
write(6,'(i25,a1,i10)') i-1_pInt,'+',debug_CrystalliteLoopDistribution(i)
endif
endif endif
enddo enddo
write(6,'(a15,i10,1x,i10)') ' total',integral,sum(debug_CrystalliteLoopDistribution) write(6,'(a15,i10,1x,i10)') ' total',integral,sum(debug_CrystalliteLoopDistribution)
@ -470,11 +475,9 @@ subroutine debug_info
do i=1_pInt,nHomog+1_pInt do i=1_pInt,nHomog+1_pInt
if (debug_MaterialpointLoopDistribution(i) /= 0) then if (debug_MaterialpointLoopDistribution(i) /= 0) then
integral = integral + i*debug_MaterialpointLoopDistribution(i) integral = integral + i*debug_MaterialpointLoopDistribution(i)
if (i <= nHomog) then exceed = ' '
write(6,'(i25,1x,i10)') i,debug_MaterialpointLoopDistribution(i) if (i > nHomog) exceed = '+'
else write(6,'(i25,a1,i10)') min(nHomog,i),exceed,debug_MaterialpointLoopDistribution(i)
write(6,'(i25,a1,i10)') i-1_pInt,'+',debug_MaterialpointLoopDistribution(i)
endif
endif endif
enddo enddo
write(6,'(a15,i10,1x,i10)') ' total',integral,sum(debug_MaterialpointLoopDistribution) write(6,'(a15,i10,1x,i10)') ' total',integral,sum(debug_MaterialpointLoopDistribution)