removed few bugs from nonlocal (newstate)

This commit is contained in:
Luv Sharma 2014-06-24 09:24:19 +00:00
parent 6347adcb65
commit 9ef7d2261e
2 changed files with 99 additions and 43 deletions

View File

@ -1249,10 +1249,18 @@ do instance = 1_pInt,maxNinstances
s = nint(rnd(3)*real(ns,pReal)+0.5_pReal,pInt) s = nint(rnd(3)*real(ns,pReal)+0.5_pReal,pInt)
t = nint(rnd(4)*4.0_pReal+0.5_pReal,pInt) t = nint(rnd(4)*4.0_pReal+0.5_pReal,pInt)
meanDensity = meanDensity + densityBinning * mesh_ipVolume(ip,el) / totalVolume meanDensity = meanDensity + densityBinning * mesh_ipVolume(ip,el) / totalVolume
plasticState(mapping(2,1,ip,el))%state0(iRhoU(s,t,instance),mapping(1,1,ip,el)) = &
plasticState(mapping(2,1,ip,el))%state0(iRhoU(s,t,instance),mapping(1,1,ip,el)) &
+ densityBinning
plasticState(mapping(2,1,ip,el))%state(iRhoU(s,t,instance),mapping(1,1,ip,el)) = & plasticState(mapping(2,1,ip,el))%state(iRhoU(s,t,instance),mapping(1,1,ip,el)) = &
plasticState(mapping(2,1,ip,el))%state(iRhoU(s,t,instance),mapping(1,1,ip,el)) & plasticState(mapping(2,1,ip,el))%state(iRhoU(s,t,instance),mapping(1,1,ip,el)) &
+ densityBinning + densityBinning
plasticState(mapping(2,1,ip,el))%partionedState0(iRhoU(s,t,instance),mapping(1,1,ip,el)) = &
plasticState(mapping(2,1,ip,el))%partionedState0(iRhoU(s,t,instance),mapping(1,1,ip,el)) &
+ densityBinning
endif endif
enddo enddo
! homogeneous distribution of density with some noise ! homogeneous distribution of density with some noise
@ -1269,39 +1277,68 @@ do instance = 1_pInt,maxNinstances
noise(j) = math_sampleGaussVar(0.0_pReal, rhoSglScatter(instance)) noise(j) = math_sampleGaussVar(0.0_pReal, rhoSglScatter(instance))
enddo enddo
plasticState(mapping(2,1,i,e))%state(iRhoU(s,1,instance),mapping(1,1,i,e)) = & plasticState(mapping(2,1,i,e))%state0(iRhoU(s,1,instance),mapping(1,1,i,e)) = &
rhoSglEdgePos0(f,instance) + noise(1) rhoSglEdgePos0(f,instance) + noise(1)
plasticState(mapping(2,1,i,e))%state(iRhoU(s,2,instance),mapping(1,1,i,e)) = & plasticState(mapping(2,1,i,e))%state0(iRhoU(s,2,instance),mapping(1,1,i,e)) = &
rhoSglEdgeNeg0(f,instance) + noise(1) rhoSglEdgeNeg0(f,instance) + noise(1)
plasticState(mapping(2,1,i,e))%state(iRhoU(s,3,instance),mapping(1,1,i,e)) = & plasticState(mapping(2,1,i,e))%state0(iRhoU(s,3,instance),mapping(1,1,i,e)) = &
rhoSglScrewPos0(f,instance) + noise(2) rhoSglScrewPos0(f,instance) + noise(2)
plasticState(mapping(2,1,i,e))%state(iRhoU(s,4,instance),mapping(1,1,i,e)) = & plasticState(mapping(2,1,i,e))%state0(iRhoU(s,4,instance),mapping(1,1,i,e)) = &
rhoSglScrewNeg0(f,instance) + noise(2) rhoSglScrewNeg0(f,instance) + noise(2)
! plasticState(mapping(2,1,i,e))%state(iRhoU(s,1,instance),mapping(1,1,i,e)) = &
! rhoSglEdgePos0(f,instance) + noise(1)
! plasticState(mapping(2,1,i,e))%state(iRhoU(s,2,instance),mapping(1,1,i,e)) = &
! rhoSglEdgeNeg0(f,instance) + noise(1)
! plasticState(mapping(2,1,i,e))%state(iRhoU(s,3,instance),mapping(1,1,i,e)) = &
! rhoSglScrewPos0(f,instance) + noise(2)
! plasticState(mapping(2,1,i,e))%state(iRhoU(s,4,instance),mapping(1,1,i,e)) = &
! rhoSglScrewNeg0(f,instance) + noise(2)
!
! plasticState(mapping(2,1,i,e))%partionedState0(iRhoU(s,1,instance),mapping(1,1,i,e)) = &
! rhoSglEdgePos0(f,instance) + noise(1)
! plasticState(mapping(2,1,i,e))%partionedState0(iRhoU(s,2,instance),mapping(1,1,i,e)) = &
! rhoSglEdgeNeg0(f,instance) + noise(1)
! plasticState(mapping(2,1,i,e))%partionedState0(iRhoU(s,3,instance),mapping(1,1,i,e)) = &
! rhoSglScrewPos0(f,instance) + noise(2)
! plasticState(mapping(2,1,i,e))%partionedState0(iRhoU(s,4,instance),mapping(1,1,i,e)) = &
! rhoSglScrewNeg0(f,instance) + noise(2)
enddo enddo
plasticState(mapping(2,1,i,e))%state(iRhoD(from:upto,1,instance),mapping(1,1,i,e)) = & plasticState(mapping(2,1,i,e))%state0(iRhoD(from:upto,1,instance),mapping(1,1,i,e)) = &
rhoDipEdge0(f,instance) rhoDipEdge0(f,instance)
plasticState(mapping(2,1,i,e))%state(iRhoD(from:upto,2,instance),mapping(1,1,i,e)) = & plasticState(mapping(2,1,i,e))%state0(iRhoD(from:upto,2,instance),mapping(1,1,i,e)) = &
rhoDipScrew0(f,instance) rhoDipScrew0(f,instance)
! plasticState(mapping(2,1,i,e))%state(iRhoD(from:upto,1,instance),mapping(1,1,i,e)) = &
! rhoDipEdge0(f,instance)
! plasticState(mapping(2,1,i,e))%state(iRhoD(from:upto,2,instance),mapping(1,1,i,e)) = &
! rhoDipScrew0(f,instance)
!
! plasticState(mapping(2,1,i,e))%partionedState0(iRhoD(from:upto,1,instance),mapping(1,1,i,e)) = &
! rhoDipEdge0(f,instance)
! plasticState(mapping(2,1,i,e))%partionedState0(iRhoD(from:upto,2,instance),mapping(1,1,i,e)) = &
! rhoDipScrew0(f,instance)
enddo enddo
endif endif
enddo enddo
enddo enddo
do e = 1_pInt,mesh_NcpElems !do e = 1_pInt,mesh_NcpElems
do i = 1_pInt,FE_Nips(FE_geomtype(mesh_element(2,e))) ! do i = 1_pInt,FE_Nips(FE_geomtype(mesh_element(2,e)))
if (PLASTICITY_NONLOCAL_ID == phase_plasticity(material_phase(1,i,e)) & ! if(plasticState(mapping(2,1,i,e))%nonlocal == .true.) then
.and. instance == phase_plasticityInstance(material_phase(1,i,e))) then ! if (PLASTICITY_NONLOCAL_ID == phase_plasticity(material_phase(1,i,e)) &
plasticState(mapping(2,1,i,e))%state0(:,mapping(1,1,i,e)) = & ! .and. instance == phase_plasticityInstance(material_phase(1,i,e))) then
plasticState(mapping(2,1,i,e))%state(:,mapping(1,1,i,e)) ! plasticState(mapping(2,1,i,e))%partionedState0(:,mapping(1,1,i,e)) = &
plasticState(mapping(2,1,i,e))%partionedState0(:,mapping(1,1,i,e)) = & ! plasticState(mapping(2,1,i,e))%state0(:,mapping(1,1,i,e))
plasticState(mapping(2,1,i,e))%state0(:,mapping(1,1,i,e)) ! plasticState(mapping(2,1,i,e))%State(:,mapping(1,1,i,e)) = &
plasticState(mapping(2,1,i,e))%State(:,mapping(1,1,i,e)) = & ! plasticState(mapping(2,1,i,e))%state0(:,mapping(1,1,i,e))
plasticState(mapping(2,1,i,e))%state0(:,mapping(1,1,i,e)) ! endif
endif ! enddo
enddo !enddo
enddo
endif endif
enddo enddo
@ -1319,7 +1356,7 @@ implicit none
integer(pInt), intent(in) :: & integer(pInt), intent(in) :: &
instance, & !< number specifying the instance of the plasticity instance, & !< number specifying the instance of the plasticity
phase phase
real(pReal), dimension(size(plasticState(phase)%aTolState(:))) :: tempTol real(pReal), dimension(plasticState(phase)%sizeState) :: tempTol
!*** local variables !*** local variables
integer(pInt) :: ns, t, c integer(pInt) :: ns, t, c
@ -1334,7 +1371,8 @@ endforall
forall (c = 1_pInt:2_pInt) & forall (c = 1_pInt:2_pInt) &
tempTol(iRhoD(1:ns,c,instance)) = aTolRho(instance) tempTol(iRhoD(1:ns,c,instance)) = aTolRho(instance)
tempTol(iGamma(1:ns,instance)) = aTolShear(instance) tempTol(iGamma(1:ns,instance)) = aTolShear(instance)
plasticState(phase)%aTolState = tempTol plasticState(phase)%aTolState(1:plasticState(phase)%sizeDotState) = &
tempTol(1:plasticState(phase)%sizeDotState)
end subroutine constitutive_nonlocal_aTolState end subroutine constitutive_nonlocal_aTolState
@ -1707,6 +1745,22 @@ if (.not. phase_localPlasticity(phase) .and. shortRangeStressCorrection(instance
- max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% & - max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iRhoU(s,2*c,neighbor_instance), & state(iRhoU(s,2*c,neighbor_instance), &
mapping(1,ipc,neighbor_ip,neighbor_el)),0.0_pReal) ! negative mobiles mapping(1,ipc,neighbor_ip,neighbor_el)),0.0_pReal) ! negative mobiles
neighbor_rhoTotal(c,s,n) = &
max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iRhoU(s,2*c-1,neighbor_instance),mapping(1,ipc,neighbor_ip,neighbor_el)),&
0.0_pReal) &! positive mobiles
+ max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iRhoU(s,2*c,neighbor_instance),mapping(1,ipc,neighbor_ip,neighbor_el)), &
0.0_pReal) & ! negative mobiles
+ abs(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iRhoB(s,2*c-1,neighbor_instance),mapping(1,ipc,neighbor_ip,neighbor_el)))& ! positive deads
+ abs(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iRhoB(s,2*c,neighbor_instance),mapping(1,ipc,neighbor_ip,neighbor_el))) & ! negative deads
+ max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iRhoD(s,c,neighbor_instance),mapping(1,ipc,neighbor_ip,neighbor_el)), &
0.0_pReal) ! dipoles
endforall endforall
connection_latticeConf(1:3,n) = & connection_latticeConf(1:3,n) = &
math_mul33x3(invFe, mesh_ipCoordinates(1:3,neighbor_ip,neighbor_el) & math_mul33x3(invFe, mesh_ipCoordinates(1:3,neighbor_ip,neighbor_el) &
@ -1789,9 +1843,9 @@ endif
!*** set dependent states !*** set dependent states
plasticState(mapping(2,ipc,ip,el))%state(iRhoF(1:ns,instance),mapping(1,ipc,ip,el)) = rhoForest plasticState(mapping(2,ipc,ip,el))%state(iRhoF(1:ns,instance),mapping(1,ipc,ip,el)) = rhoForest
plasticState(mapping(2,ipc,ip,el))%state(iTauF(1:ns,instance),mapping(1,ipc,ip,el)) = tauThreshold plasticState(mapping(2,ipc,ip,el))%state(iTauF(1:ns,instance),mapping(1,ipc,ip,el)) = tauThreshold
plasticState(mapping(2,ipc,ip,el))%state(iTauB(1:ns,instance),mapping(1,ipc,ip,el)) = tauBack plasticState(mapping(2,ipc,ip,el))%state(iTauB(1:ns,instance),mapping(1,ipc,ip,el)) = tauBack
#ifndef _OPENMP #ifndef _OPENMP
if (iand(debug_level(debug_constitutive),debug_levelExtensive) /= 0_pInt & if (iand(debug_level(debug_constitutive),debug_levelExtensive) /= 0_pInt &
@ -2370,16 +2424,16 @@ ns = totalNslip(instance)
forall (s = 1_pInt:ns, t = 1_pInt:4_pInt) forall (s = 1_pInt:ns, t = 1_pInt:4_pInt)
rhoSgl(s,t) = max(plasticState(mapping(2,1,ip,el))%state(iRhoU(s,t,instance),mapping(1,ipc,ip,el)), & rhoSgl(s,t) = max(plasticState(mapping(2,ipc,ip,el))%state(iRhoU(s,t,instance),mapping(1,ipc,ip,el)), &
0.0_pReal) ! ensure positive single mobile densities 0.0_pReal) ! ensure positive single mobile densities
rhoSgl(s,t+4_pInt) = plasticState(mapping(2,1,ip,el))%state(iRhoB(s,t,instance),mapping(1,ipc,ip,el)) rhoSgl(s,t+4_pInt) = plasticState(mapping(2,ipc,ip,el))%state(iRhoB(s,t,instance),mapping(1,ipc,ip,el))
endforall endforall
where (abs(rhoSgl) * mesh_ipVolume(ip,el) ** 0.667_pReal < significantN(instance) & where (abs(rhoSgl) * mesh_ipVolume(ip,el) ** 0.667_pReal < significantN(instance) &
.or. abs(rhoSgl) < significantRho(instance)) & .or. abs(rhoSgl) < significantRho(instance)) &
rhoSgl = 0.0_pReal rhoSgl = 0.0_pReal
tauBack = plasticState(mapping(2,1,ip,el))%state(iTauB(1:ns,instance),mapping(1,ipc,ip,el)) tauBack = plasticState(mapping(2,ipc,ip,el))%state(iTauB(1:ns,instance),mapping(1,ipc,ip,el))
tauThreshold = plasticState(mapping(2,1,ip,el))%state(iTauF(1:ns,instance),mapping(1,ipc,ip,el)) tauThreshold = plasticState(mapping(2,ipc,ip,el))%state(iTauF(1:ns,instance),mapping(1,ipc,ip,el))
!*** get resolved shear stress !*** get resolved shear stress
@ -2751,6 +2805,7 @@ real(pReal), dimension(totalNslip(phase_plasticityInstance(material_phase(ipc,ip
deltaDUpper ! change in maximum stable dipole distance for edges and screws deltaDUpper ! change in maximum stable dipole distance for edges and screws
integer(pInt),dimension(2,homogenization_maxngrains,mesh_maxNips,mesh_ncpelems), intent(in) :: & integer(pInt),dimension(2,homogenization_maxngrains,mesh_maxNips,mesh_ncpelems), intent(in) :: &
mapping mapping
integer(pInt) :: sizeDot
#ifndef _OPENMP #ifndef _OPENMP
if (iand(debug_level(debug_constitutive),debug_levelBasic) /= 0_pInt & if (iand(debug_level(debug_constitutive),debug_levelBasic) /= 0_pInt &
.and. ((debug_e == el .and. debug_i == ip .and. debug_g == ipc)& .and. ((debug_e == el .and. debug_i == ip .and. debug_g == ipc)&
@ -2773,7 +2828,7 @@ forall (s = 1_pInt:ns, t = 1_pInt:4_pInt)
mapping(1,ipc,ip,el)),0.0_pReal) ! ensure positive single mobile densities mapping(1,ipc,ip,el)),0.0_pReal) ! ensure positive single mobile densities
rhoSgl(s,t+4_pInt) = plasticState(mapping(2,ipc,ip,el))%state(iRhoB(s,t,instance), & rhoSgl(s,t+4_pInt) = plasticState(mapping(2,ipc,ip,el))%state(iRhoB(s,t,instance), &
mapping(1,ipc,ip,el)) mapping(1,ipc,ip,el))
v(s,t) = plasticState(mapping(2,ipc,ip,el))%state(iRhoU(s,t,instance),mapping(1,ipc,ip,el)) v(s,t) = plasticState(mapping(2,ipc,ip,el))%state(iV(s,t,instance),mapping(1,ipc,ip,el))
endforall endforall
forall (s = 1_pInt:ns, c = 1_pInt:2_pInt) forall (s = 1_pInt:ns, c = 1_pInt:2_pInt)
rhoDip(s,c) = max(plasticState(mapping(2,ipc,ip,el))%state(iRhoD(s,c,instance),mapping(1,ipc,ip,el)), 0.0_pReal) ! ensure positive dipole densities rhoDip(s,c) = max(plasticState(mapping(2,ipc,ip,el))%state(iRhoD(s,c,instance),mapping(1,ipc,ip,el)), 0.0_pReal) ! ensure positive dipole densities
@ -2855,8 +2910,9 @@ forall (s = 1_pInt:ns, c = 1_pInt:2_pInt) &
deltaRho = deltaRhoRemobilization & deltaRho = deltaRhoRemobilization &
+ deltaRhoDipole2SingleStress + deltaRhoDipole2SingleStress
sizeDot = plasticState(mapping(2,ipc,ip,el))%sizeDotState
!deltaState%p = 0.0_pReal !deltaState%p = 0.0_pReal
plasticState(mapping(2,ipc,ip,el))%deltaState(:,mapping(1,ipc,ip,el)) = 0.0_pReal plasticState(mapping(2,ipc,ip,el))%deltaState(1:sizeDot,mapping(1,ipc,ip,el)) = 0.0_pReal
forall (s = 1:ns, t = 1_pInt:4_pInt) forall (s = 1:ns, t = 1_pInt:4_pInt)
plasticState(mapping(2,ipc,ip,el))%deltaState(iRhoU(s,t,instance),mapping(1,ipc,ip,el)) = & plasticState(mapping(2,ipc,ip,el))%deltaState(iRhoU(s,t,instance),mapping(1,ipc,ip,el)) = &
deltaRho(s,t) deltaRho(s,t)
@ -3263,10 +3319,10 @@ where (abs(rhoDip) * mesh_ipVolume(ip,el) ** 0.667_pReal < significantN(instance
if (numerics_timeSyncing) then if (numerics_timeSyncing) then
forall (s = 1_pInt:ns, t = 1_pInt:4_pInt) forall (s = 1_pInt:ns, t = 1_pInt:4_pInt)
rhoSgl0(s,t) = max(plasticState(mapping(2,ipc,ip,el))%state(iRhoU(s,t,instance), & rhoSgl0(s,t) = max(plasticState(mapping(2,ipc,ip,el))%state0(iRhoU(s,t,instance), &
mapping(1,ipc,ip,el)), 0.0_pReal) mapping(1,ipc,ip,el)), 0.0_pReal)
rhoSgl0(s,t+4_pInt) = plasticState(mapping(2,ipc,ip,el))%state(iRhoB(s,t,instance),mapping(1,ipc,ip,el)) rhoSgl0(s,t+4_pInt) = plasticState(mapping(2,ipc,ip,el))%state0(iRhoB(s,t,instance),mapping(1,ipc,ip,el))
v0(s,t) = plasticState(mapping(2,ipc,ip,el))%state(iV(s,t,instance),mapping(1,ipc,ip,el)) v0(s,t) = plasticState(mapping(2,ipc,ip,el))%state0(iV(s,t,instance),mapping(1,ipc,ip,el))
endforall endforall
where (abs(rhoSgl0) * mesh_ipVolume(ip,el) ** 0.667_pReal < significantN(instance) & where (abs(rhoSgl0) * mesh_ipVolume(ip,el) ** 0.667_pReal < significantN(instance) &
.or. abs(rhoSgl0) < significantRho(instance)) & .or. abs(rhoSgl0) < significantRho(instance)) &
@ -3460,14 +3516,14 @@ if (.not. phase_localPlasticity(material_phase(ipc,ip,el))) then
neighbor_v(s,t) = plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% & neighbor_v(s,t) = plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state0(iV(s,t,neighbor_instance),mapping(1,ipc,ip,el)) state0(iV(s,t,neighbor_instance),mapping(1,ipc,ip,el))
neighbor_rhoSgl(s,t) = max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% & neighbor_rhoSgl(s,t) = max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state0(iV(s,t,neighbor_instance),mapping(1,ipc,ip,el)), 0.0_pReal) state0(iRhoU(s,t,neighbor_instance),mapping(1,ipc,ip,el)), 0.0_pReal)
endforall endforall
else else
forall (s = 1:ns, t = 1_pInt:4_pInt) forall (s = 1:ns, t = 1_pInt:4_pInt)
neighbor_v(s,t) = plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% & neighbor_v(s,t) = plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iV(s,t,neighbor_instance),mapping(1,ipc,ip,el)) state(iV(s,t,neighbor_instance),mapping(1,ipc,ip,el))
neighbor_rhoSgl(s,t) = max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% & neighbor_rhoSgl(s,t) = max(plasticState(mapping(2,ipc,neighbor_ip,neighbor_el))% &
state(iV(s,t,neighbor_instance),mapping(1,ipc,ip,el)), 0.0_pReal) state(iRhoU(s,t,neighbor_instance),mapping(1,ipc,ip,el)), 0.0_pReal)
endforall endforall
endif endif
where (neighbor_rhoSgl * mesh_ipVolume(neighbor_ip,neighbor_el) ** 0.667_pReal < significantN(instance) & where (neighbor_rhoSgl * mesh_ipVolume(neighbor_ip,neighbor_el) ** 0.667_pReal < significantN(instance) &

View File

@ -64,7 +64,7 @@ module prec
!http://stackoverflow.com/questions/3948210/can-i-have-a-pointer-to-an-item-in-an-allocatable-array !http://stackoverflow.com/questions/3948210/can-i-have-a-pointer-to-an-item-in-an-allocatable-array
type, public :: tState type, public :: tState
integer(pInt) :: sizeState,sizeDotState integer(pInt) :: sizeState,sizeDotState
! logical :: nonlocal logical :: nonlocal
real(pReal), pointer, dimension(:) :: atolState real(pReal), pointer, dimension(:) :: atolState
real(pReal), pointer, dimension(:,:) :: state, & ! material points, state size real(pReal), pointer, dimension(:,:) :: state, & ! material points, state size
dotState, & dotState, &