- corrected an if statement in the state loop
- nonlocal stiffness calculation: we perturb all material points at the same time, so instead of N^2 loops we just need N - set "forceLocalStiffnessCalculation" to false as standard
This commit is contained in:
parent
a0d28ebc18
commit
61bd0224c1
|
@ -400,7 +400,8 @@ subroutine crystallite_stressAndItsTangent(updateJaco)
|
||||||
myNgrains, &
|
myNgrains, &
|
||||||
mySizeState, &
|
mySizeState, &
|
||||||
mySizeDotState
|
mySizeDotState
|
||||||
integer(pInt), dimension(2,9) :: kl
|
integer(pInt), dimension(2,9,homogenization_maxNgrains,mesh_maxNips,mesh_NcpElems) :: &
|
||||||
|
kl
|
||||||
logical onTrack, & ! flag indicating whether we are still on track
|
logical onTrack, & ! flag indicating whether we are still on track
|
||||||
temperatureConverged, & ! flag indicating if temperature converged
|
temperatureConverged, & ! flag indicating if temperature converged
|
||||||
stateConverged, & ! flag indicating if state converged
|
stateConverged, & ! flag indicating if state converged
|
||||||
|
@ -431,7 +432,7 @@ subroutine crystallite_stressAndItsTangent(updateJaco)
|
||||||
storedConvergenceFlag
|
storedConvergenceFlag
|
||||||
logical, dimension(3,3) :: mask
|
logical, dimension(3,3) :: mask
|
||||||
logical forceLocalStiffnessCalculation ! flag indicating that stiffness calculation is always done locally
|
logical forceLocalStiffnessCalculation ! flag indicating that stiffness calculation is always done locally
|
||||||
forceLocalStiffnessCalculation = .true.
|
forceLocalStiffnessCalculation = .false.
|
||||||
|
|
||||||
|
|
||||||
! ------ initialize to starting condition ------
|
! ------ initialize to starting condition ------
|
||||||
|
@ -615,11 +616,12 @@ subroutine crystallite_stressAndItsTangent(updateJaco)
|
||||||
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e) ! iterate over IPs of this element to be processed
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e) ! iterate over IPs of this element to be processed
|
||||||
do g = 1,myNgrains
|
do g = 1,myNgrains
|
||||||
! selectiveDebugger = (e == debug_e .and. i == debug_i .and. g == debug_g)
|
! selectiveDebugger = (e == debug_e .and. i == debug_i .and. g == debug_g)
|
||||||
if (crystallite_todo(g,i,e)) & ! all undone crystallites
|
if (crystallite_todo(g,i,e)) then ! all undone crystallites
|
||||||
crystallite_todo(g,i,e) = crystallite_integrateStress(g,i,e)
|
crystallite_todo(g,i,e) = crystallite_integrateStress(g,i,e)
|
||||||
if ( .not. crystallite_localConstitution(g,i,e) &
|
if ( .not. crystallite_localConstitution(g,i,e) &
|
||||||
.and. .not. crystallite_todo(g,i,e)) & ! if broken non-local...
|
.and. .not. crystallite_todo(g,i,e)) & ! if broken non-local...
|
||||||
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
||||||
|
endif
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
!$OMPEND PARALLEL DO
|
!$OMPEND PARALLEL DO
|
||||||
|
|
||||||
|
@ -873,110 +875,148 @@ subroutine crystallite_stressAndItsTangent(updateJaco)
|
||||||
enddo ! element loop
|
enddo ! element loop
|
||||||
!$OMPEND PARALLEL DO
|
!$OMPEND PARALLEL DO
|
||||||
|
|
||||||
elseif (any(.not. crystallite_localConstitution)) then ! if any nonlocal grain present, we have to do a full loop over all grains after each perturbance
|
elseif (any(.not. crystallite_localConstitution)) then ! if any nonlocal grain present, we have to do a full loop over all grains after each perturbance
|
||||||
|
|
||||||
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
do g = 1,myNgrains
|
do g = 1,myNgrains
|
||||||
|
|
||||||
! perturb components in the order of biggest change in F (-> component with biggest change in F is perturbed in first cycle, component with second biggest change in next cycle, ...)
|
|
||||||
mask = .true.
|
mask = .true.
|
||||||
do comp = 1,9
|
do comp = 1,9
|
||||||
kl(:,comp) = maxloc(abs(crystallite_subF(:,:,g,i,e)-crystallite_F0(:,:,g,i,e)), mask)
|
kl(:,comp,g,i,e) = maxloc(abs(crystallite_subF(:,:,g,i,e)-crystallite_F0(:,:,g,i,e)), mask) ! map from component to array indices for F (sorted in descending order of abs(deltaF))
|
||||||
mask(kl(1,comp),kl(2,comp)) = .false.
|
mask(kl(1,comp,g,i,e),kl(2,comp,g,i,e)) = .false.
|
||||||
enddo
|
enddo
|
||||||
k = kl(1,mod((cycleCounter-1)/2+1,9))
|
k = kl(1,mod((cycleCounter-1)/2+1,9),g,i,e) ! perturb components in the descending order of change in F (-> component with biggest change in F is perturbed in first cycle, component with second biggest change in next cycle, ...)
|
||||||
l = kl(2,mod((cycleCounter-1)/2+1,9))
|
l = kl(2,mod((cycleCounter-1)/2+1,9),g,i,e)
|
||||||
|
crystallite_subF(k,l,g,i,e) = crystallite_subF(k,l,g,i,e) + pert_Fg ! perturb single component
|
||||||
|
enddo; enddo; enddo
|
||||||
|
|
||||||
crystallite_subF(k,l,g,i,e) = crystallite_subF(k,l,g,i,e) + pert_Fg ! perturb single component
|
!$OMP PARALLEL DO
|
||||||
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
|
do g = 1,myNgrains
|
||||||
|
if (crystallite_todo(g,i,e)) then
|
||||||
|
crystallite_stateConverged(g,i,e) = crystallite_updateState(g,i,e) ! preguess for state
|
||||||
|
crystallite_temperatureConverged(g,i,e) = crystallite_updateTemperature(g,i,e)
|
||||||
|
if ( .not. crystallite_localConstitution(g,i,e) &
|
||||||
|
.and. .not. crystallite_todo(g,i,e)) & ! if broken non-local...
|
||||||
|
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
||||||
|
endif
|
||||||
|
enddo; enddo; enddo
|
||||||
|
!$OMPEND PARALLEL DO
|
||||||
|
|
||||||
NiterationState = 0_pInt
|
NiterationState = 0_pInt
|
||||||
crystallite_todo = .true.
|
crystallite_todo = .true.
|
||||||
do while ( any(crystallite_todo(:,:,FEsolving_execELem(1):FEsolving_execElem(2))) .and. NiterationState < nState)
|
do while ( any(crystallite_todo(:,:,FEsolving_execELem(1):FEsolving_execElem(2))) .and. NiterationState < nState)
|
||||||
NiterationState = NiterationState + 1_pInt
|
NiterationState = NiterationState + 1_pInt
|
||||||
|
|
||||||
do ee = FEsolving_execElem(1),FEsolving_execElem(2)
|
!$OMP PARALLEL DO
|
||||||
myNgrains = homogenization_Ngrains(mesh_element(3,ee))
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
do ii = FEsolving_execIP(1,ee),FEsolving_execIP(2,ee)
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
do gg = 1,myNgrains
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
if (crystallite_todo(gg,ii,ee)) &
|
do g = 1,myNgrains
|
||||||
crystallite_todo(gg,ii,ee) = crystallite_integrateStress(gg,ii,ee) ! stress integration
|
if (crystallite_todo(g,i,e)) then
|
||||||
if ( .not. crystallite_localConstitution(g,i,e) &
|
crystallite_todo(g,i,e) = crystallite_integrateStress(g,i,e) ! stress integration
|
||||||
.and. .not. crystallite_todo(g,i,e)) & ! if broken non-local...
|
if ( .not. crystallite_localConstitution(g,i,e) &
|
||||||
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
.and. .not. crystallite_todo(g,i,e)) & ! if broken non-local...
|
||||||
enddo; enddo; enddo
|
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
||||||
|
endif
|
||||||
|
enddo; enddo; enddo
|
||||||
|
!$OMPEND PARALLEL DO
|
||||||
|
|
||||||
do ee = FEsolving_execElem(1),FEsolving_execElem(2)
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
myNgrains = homogenization_Ngrains(mesh_element(3,ee))
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
do ii = FEsolving_execIP(1,ee),FEsolving_execIP(2,ee)
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
do gg = 1,myNgrains
|
do g = 1,myNgrains
|
||||||
if (crystallite_todo(gg,ii,ee)) &
|
if (crystallite_todo(g,i,e)) &
|
||||||
constitutive_dotState(gg,ii,ee)%p = 0.0_pReal ! zero out dotState
|
constitutive_dotState(g,i,e)%p = 0.0_pReal ! zero out dotState
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
|
|
||||||
do ee = FEsolving_execElem(1),FEsolving_execElem(2)
|
crystallite_statedamper = 1.0_pReal
|
||||||
myNgrains = homogenization_Ngrains(mesh_element(3,ee))
|
|
||||||
do ii = FEsolving_execIP(1,ee),FEsolving_execIP(2,ee)
|
|
||||||
do gg = 1,myNgrains
|
|
||||||
if (crystallite_todo(gg,ii,ee)) &
|
|
||||||
call constitutive_collectDotState(crystallite_Tstar_v(:,gg,ii,ee), crystallite_subTstar0_v(:,gg,ii,ee), &
|
|
||||||
crystallite_Fe, crystallite_Fp, crystallite_Temperature(gg,ii,ee), &
|
|
||||||
crystallite_misorientation(:,:,g,i,e), crystallite_subdt(gg,ii,ee), &
|
|
||||||
gg, ii, ee) ! collect dot state
|
|
||||||
enddo; enddo; enddo
|
|
||||||
|
|
||||||
do ee = FEsolving_execElem(1),FEsolving_execElem(2)
|
!$OMP PARALLEL DO
|
||||||
myNgrains = homogenization_Ngrains(mesh_element(3,ee))
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
do ii = FEsolving_execIP(1,ee),FEsolving_execIP(2,ee)
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
do gg = 1,myNgrains
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
if (crystallite_todo(gg,ii,ee)) then
|
do g = 1,myNgrains
|
||||||
crystallite_stateConverged(gg,ii,ee) = crystallite_updateState(gg,ii,ee) ! update state
|
if (crystallite_todo(g,i,e)) then
|
||||||
crystallite_temperatureConverged(gg,ii,ee) = crystallite_updateTemperature(gg,ii,ee) ! update temperature
|
call constitutive_collectDotState(crystallite_Tstar_v(:,g,i,e), crystallite_subTstar0_v(:,g,i,e), &
|
||||||
crystallite_converged(gg,ii,ee) = crystallite_stateConverged(gg,ii,ee) &
|
crystallite_Fe, crystallite_Fp, crystallite_Temperature(g,i,e), &
|
||||||
.and. crystallite_temperatureConverged(gg,ii,ee)
|
crystallite_misorientation(:,:,g,i,e), crystallite_subdt(g,i,e), &
|
||||||
if ( .not. crystallite_localConstitution(g,i,e) &
|
g,i,e) ! collect dot state
|
||||||
.and. .not. crystallite_todo(g,i,e)) & ! if updateState signals broken non-local...
|
delta_dotState1 = constitutive_dotState(g,i,e)%p - constitutive_previousDotState(g,i,e)%p
|
||||||
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
delta_dotState2 = constitutive_previousDotState(g,i,e)%p - constitutive_previousDotState2(g,i,e)%p
|
||||||
endif
|
dot_prod12 = dot_product(delta_dotState1, delta_dotState2)
|
||||||
enddo; enddo; enddo
|
dot_prod22 = dot_product(delta_dotState2, delta_dotState2)
|
||||||
|
if ( dot_prod22 > 0.0_pReal &
|
||||||
|
.and. ( dot_prod12 < 0.0_pReal &
|
||||||
|
.or. dot_product(constitutive_dotState(g,i,e)%p, constitutive_previousDotState(g,i,e)%p) < 0.0_pReal))&
|
||||||
|
crystallite_statedamper = min(crystallite_statedamper, &
|
||||||
|
0.75_pReal + 0.25_pReal * tanh(2.0_pReal + 4.0_pReal * dot_prod12 / dot_prod22) )
|
||||||
|
endif
|
||||||
|
enddo; enddo; enddo
|
||||||
|
!$OMPEND PARALLEL DO
|
||||||
|
|
||||||
if (any(.not. crystallite_converged .and. .not. crystallite_localConstitution)) & ! any non-local not yet converged?
|
!$OMP PARALLEL DO
|
||||||
crystallite_converged = crystallite_converged .and. crystallite_localConstitution ! all non-local not converged
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
|
do g = 1,myNgrains
|
||||||
|
if (crystallite_todo(g,i,e)) then
|
||||||
|
crystallite_stateConverged(g,i,e) = crystallite_updateState(g,i,e) ! update state
|
||||||
|
crystallite_temperatureConverged(g,i,e) = crystallite_updateTemperature(g,i,e) ! update temperature
|
||||||
|
crystallite_converged(g,i,e) = crystallite_stateConverged(g,i,e) &
|
||||||
|
.and. crystallite_temperatureConverged(g,i,e)
|
||||||
|
if ( .not. crystallite_localConstitution(g,i,e) &
|
||||||
|
.and. .not. crystallite_todo(g,i,e)) & ! if updateState signals broken non-local...
|
||||||
|
crystallite_todo = crystallite_todo .and. crystallite_localConstitution ! ...all non-locals skipped
|
||||||
|
endif
|
||||||
|
enddo; enddo; enddo
|
||||||
|
!$OMPEND PARALLEL DO
|
||||||
|
|
||||||
crystallite_todo = crystallite_todo .and. .not. crystallite_converged ! skip all converged
|
if (any(.not. crystallite_converged .and. .not. crystallite_localConstitution)) & ! any non-local not yet converged?
|
||||||
|
crystallite_converged = crystallite_converged .and. crystallite_localConstitution ! all non-local not converged
|
||||||
|
|
||||||
enddo ! state loop
|
crystallite_todo = crystallite_todo .and. .not. crystallite_converged ! skip all converged
|
||||||
|
|
||||||
if (all(crystallite_converged(:,:,FEsolving_execELem(1):FEsolving_execElem(2)))) then
|
enddo
|
||||||
crystallite_dPdF(:,:,k,l,g,i,e) = (crystallite_P(:,:,g,i,e) - storedP(:,:,g,i,e))/pert_Fg ! tangent dP_ij/dFg_kl
|
|
||||||
else ! grain did not converge
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
crystallite_dPdF(:,:,k,l,g,i,e) = crystallite_fallbackdPdF(:,:,k,l,g,i,e) ! use (elastic) fallback
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
|
do g = 1,myNgrains
|
||||||
|
if (crystallite_converged(g,i,e)) then ! if stiffness calculation converged...
|
||||||
|
k = kl(1,mod((cycleCounter-1)/2+1,9),g,i,e)
|
||||||
|
l = kl(2,mod((cycleCounter-1)/2+1,9),g,i,e)
|
||||||
|
crystallite_dPdF(:,:,k,l,g,i,e) = (crystallite_P(:,:,g,i,e) - storedP(:,:,g,i,e))/pert_Fg ! ... use tangent dP_ij/dFg_kl
|
||||||
|
elseif (.not. storedConvergenceFlag(g,i,e)) then ! if crystallite didnÕt converge before...
|
||||||
|
crystallite_dPdF(:,:,:,:,g,i,e) = crystallite_fallbackdPdF(:,:,:,:,g,i,e) ! ... use (elastic) fallback
|
||||||
endif
|
endif
|
||||||
|
enddo; enddo; enddo
|
||||||
|
|
||||||
do ee = FEsolving_execElem(1),FEsolving_execElem(2)
|
do e = FEsolving_execElem(1),FEsolving_execElem(2)
|
||||||
myNgrains = homogenization_Ngrains(mesh_element(3,ee))
|
myNgrains = homogenization_Ngrains(mesh_element(3,e))
|
||||||
do ii = FEsolving_execIP(1,ee),FEsolving_execIP(2,ee)
|
do i = FEsolving_execIP(1,e),FEsolving_execIP(2,e)
|
||||||
do gg = 1,myNgrains
|
do g = 1,myNgrains
|
||||||
mySizeState = constitutive_sizeState(gg,ii,ee)
|
mySizeState = constitutive_sizeState(g,i,e)
|
||||||
mySizeDotState = constitutive_sizeDotState(gg,ii,ee)
|
mySizeDotState = constitutive_sizeDotState(g,i,e)
|
||||||
constitutive_state(gg,ii,ee)%p = storedState(1:mySizeState,gg,ii,ee)
|
constitutive_state(g,i,e)%p = storedState(1:mySizeState,g,i,e)
|
||||||
constitutive_dotState(gg,ii,ee)%p = storedDotState(1:mySizeDotState,gg,ii,ee)
|
constitutive_dotState(g,i,e)%p = storedDotState(1:mySizeDotState,g,i,e)
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
crystallite_Temperature = storedTemperature
|
crystallite_Temperature = storedTemperature
|
||||||
crystallite_subF = storedF
|
crystallite_subF = storedF
|
||||||
crystallite_Fp = storedFp
|
crystallite_Fp = storedFp
|
||||||
crystallite_invFp = storedInvFp
|
crystallite_invFp = storedInvFp
|
||||||
crystallite_Fe = storedFe
|
crystallite_Fe = storedFe
|
||||||
crystallite_Lp = storedLp
|
crystallite_Lp = storedLp
|
||||||
crystallite_Tstar_v = storedTstar_v
|
crystallite_Tstar_v = storedTstar_v
|
||||||
crystallite_P = storedP
|
crystallite_P = storedP
|
||||||
|
|
||||||
!$OMP CRITICAL (out)
|
!$OMP CRITICAL (out)
|
||||||
debug_StiffnessStateLoopDistribution(NiterationState) = debug_StiffnessstateLoopDistribution(NiterationState) + 1
|
debug_StiffnessStateLoopDistribution(NiterationState) = debug_StiffnessstateLoopDistribution(NiterationState) + 1
|
||||||
!$OMPEND CRITICAL (out)
|
!$OMPEND CRITICAL (out)
|
||||||
|
|
||||||
enddo; enddo; enddo ! element,ip,grain loop (e,i,g)
|
|
||||||
crystallite_converged = storedConvergenceFlag
|
crystallite_converged = storedConvergenceFlag
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
Loading…
Reference in New Issue