polishing

This commit is contained in:
Martin Diehl 2018-06-02 05:39:40 +02:00
parent a0a5d4c549
commit 29a0ec2800
1 changed files with 55 additions and 63 deletions

View File

@ -118,18 +118,9 @@ subroutine plastic_phenopowerlaw_init
math_Voigt66to3333, & math_Voigt66to3333, &
math_expand math_expand
use IO, only: & use IO, only: &
IO_read, &
IO_lc, &
IO_getTag, &
IO_isBlank, &
IO_stringPos, &
IO_stringValue, &
IO_floatValue, &
IO_intValue, &
IO_warning, & IO_warning, &
IO_error, & IO_error, &
IO_timeStamp, & IO_timeStamp
IO_EOF
use material, only: & use material, only: &
phase_plasticity, & phase_plasticity, &
phase_plasticityInstance, & phase_plasticityInstance, &
@ -152,8 +143,9 @@ subroutine plastic_phenopowerlaw_init
instance,phase,j,k, f,o, i,& instance,phase,j,k, f,o, i,&
NipcMyPhase, outputSize, & NipcMyPhase, outputSize, &
offset_slip, index_myFamily, index_otherFamily, & offset_slip, index_myFamily, index_otherFamily, &
sizeState,sizeDotState, sizeDeltaState, & sizeState,sizeDotState, &
startIndex, endIndex startIndex, endIndex
integer(pInt), dimension(0), parameter :: emptyInt = [integer(pInt)::] integer(pInt), dimension(0), parameter :: emptyInt = [integer(pInt)::]
real(pReal), dimension(0), parameter :: emptyReal = [real(pReal)::] real(pReal), dimension(0), parameter :: emptyReal = [real(pReal)::]
@ -162,7 +154,7 @@ subroutine plastic_phenopowerlaw_init
integer(kind(undefined_ID)) :: & integer(kind(undefined_ID)) :: &
outputID !< ID of each post result output outputID !< ID of each post result output
character(len=65536) :: & character(len=512) :: &
extmsg = '' extmsg = ''
character(len=64), dimension(:), allocatable :: outputs character(len=64), dimension(:), allocatable :: outputs
@ -192,12 +184,12 @@ subroutine plastic_phenopowerlaw_init
if (sum(p%Nslip) > 0_pInt) then if (sum(p%Nslip) > 0_pInt) then
p%tau0_slip = phaseConfig(phase)%getFloatArray('tau0_slip') p%tau0_slip = phaseConfig(phase)%getFloatArray('tau0_slip')
p%tausat_slip = phaseConfig(phase)%getFloatArray('tausat_slip') p%tausat_slip = phaseConfig(phase)%getFloatArray('tausat_slip')
p%H_int = phaseConfig(phase)%getFloatArray('h_int',defaultVal=[(0.0_pReal,i=1_pInt,size(p%Nslip))])
print*, (shape(p%H_int))
print*, (shape(p%Nslip))
p%interaction_SlipSlip = phaseConfig(phase)%getFloatArray('interaction_slipslip') p%interaction_SlipSlip = phaseConfig(phase)%getFloatArray('interaction_slipslip')
p%H_int = phaseConfig(phase)%getFloatArray('h_int',&
defaultVal=[(0.0_pReal,i=1_pInt,size(p%Nslip))])
p%nonSchmidCoeff = phaseConfig(phase)%getFloatArray('nonschmid_coefficients',& p%nonSchmidCoeff = phaseConfig(phase)%getFloatArray('nonschmid_coefficients',&
defaultVal = [real(pReal)::1] ) defaultVal = [real(pReal)::1] )
p%gdot0_slip = phaseConfig(phase)%getFloat('gdot0_slip') p%gdot0_slip = phaseConfig(phase)%getFloat('gdot0_slip')
p%n_slip = phaseConfig(phase)%getFloat('n_slip') p%n_slip = phaseConfig(phase)%getFloat('n_slip')
p%a_slip = phaseConfig(phase)%getFloat('a_slip') p%a_slip = phaseConfig(phase)%getFloat('a_slip')
@ -209,6 +201,7 @@ subroutine plastic_phenopowerlaw_init
if (sum(p%Ntwin) > 0_pInt) then if (sum(p%Ntwin) > 0_pInt) then
p%tau0_twin = phaseConfig(phase)%getFloatArray('tau0_twin') p%tau0_twin = phaseConfig(phase)%getFloatArray('tau0_twin')
p%interaction_TwinTwin = phaseConfig(phase)%getFloatArray('interaction_twintwin') p%interaction_TwinTwin = phaseConfig(phase)%getFloatArray('interaction_twintwin')
p%gdot0_twin = phaseConfig(phase)%getFloat('gdot0_twin') p%gdot0_twin = phaseConfig(phase)%getFloat('gdot0_twin')
p%n_twin = phaseConfig(phase)%getFloat('n_twin') p%n_twin = phaseConfig(phase)%getFloat('n_twin')
p%spr = phaseConfig(phase)%getFloat('s_pr') p%spr = phaseConfig(phase)%getFloat('s_pr')
@ -218,6 +211,7 @@ subroutine plastic_phenopowerlaw_init
p%twinE = phaseConfig(phase)%getFloat('twin_e') p%twinE = phaseConfig(phase)%getFloat('twin_e')
p%h0_TwinTwin = phaseConfig(phase)%getFloat('h0_twintwin') p%h0_TwinTwin = phaseConfig(phase)%getFloat('h0_twintwin')
endif endif
if (sum(p%Nslip) > 0_pInt .and. sum(p%Ntwin) > 0_pInt) then if (sum(p%Nslip) > 0_pInt .and. sum(p%Ntwin) > 0_pInt) then
p%interaction_SlipTwin = phaseConfig(phase)%getFloatArray('interaction_sliptwin') p%interaction_SlipTwin = phaseConfig(phase)%getFloatArray('interaction_sliptwin')
p%interaction_TwinSlip = phaseConfig(phase)%getFloatArray('interaction_twinslip') p%interaction_TwinSlip = phaseConfig(phase)%getFloatArray('interaction_twinslip')
@ -228,9 +222,11 @@ subroutine plastic_phenopowerlaw_init
allocate(p%matrix_SlipTwin(sum(p%Nslip),sum(p%Ntwin)),source =0.0_pReal) allocate(p%matrix_SlipTwin(sum(p%Nslip),sum(p%Ntwin)),source =0.0_pReal)
allocate(p%matrix_TwinSlip(sum(p%Ntwin),sum(p%Nslip)),source =0.0_pReal) allocate(p%matrix_TwinSlip(sum(p%Ntwin),sum(p%Nslip)),source =0.0_pReal)
allocate(p%matrix_TwinTwin(sum(p%Ntwin),sum(p%Ntwin)),source =0.0_pReal) allocate(p%matrix_TwinTwin(sum(p%Ntwin),sum(p%Ntwin)),source =0.0_pReal)
p%aTolResistance = phaseConfig(phase)%getFloat('atol_resistance',defaultVal=1.0_pReal) p%aTolResistance = phaseConfig(phase)%getFloat('atol_resistance',defaultVal=1.0_pReal)
p%aTolShear = phaseConfig(phase)%getFloat('atol_shear',defaultVal=1.0e-6_pReal) p%aTolShear = phaseConfig(phase)%getFloat('atol_shear',defaultVal=1.0e-6_pReal)
p%aTolTwinfrac = phaseConfig(phase)%getFloat('atol_twinfrac',defaultVal=1.0e-6_pReal) p%aTolTwinfrac = phaseConfig(phase)%getFloat('atol_twinfrac',defaultVal=1.0e-6_pReal)
outputs = phaseConfig(phase)%getStrings('(output)') outputs = phaseConfig(phase)%getStrings('(output)')
allocate(p%outputID(0)) allocate(p%outputID(0))
do i=1_pInt, size(outputs) do i=1_pInt, size(outputs)
@ -280,21 +276,21 @@ subroutine plastic_phenopowerlaw_init
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
! parameters independent of number of slip/twin systems ! parameters independent of number of slip/twin systems
extmsg = '' extmsg = ''
if (size(p%tau0_slip) /= size(p%nslip)) extmsg = trim(extmsg)//" shape(tau0_slip) " if (size(p%tau0_slip) /= size(p%nslip)) extmsg = trim(extmsg)//" shape(tau0_slip) "
if (size(p%tausat_slip) /= size(p%nslip)) extmsg = trim(extmsg)//" shape(tausat_slip) " if (size(p%tausat_slip) /= size(p%nslip)) extmsg = trim(extmsg)//" shape(tausat_slip) "
if (size(p%H_int) /= size(p%nslip)) extmsg = trim(extmsg)//" shape(h_int) " if (size(p%H_int) /= size(p%nslip)) extmsg = trim(extmsg)//" shape(h_int) "
if (size(p%tau0_twin) /= size(p%ntwin)) extmsg = trim(extmsg)//" shape(tau0_twin) " if (size(p%tau0_twin) /= size(p%ntwin)) extmsg = trim(extmsg)//" shape(tau0_twin) "
if (extmsg /= '') call IO_error(211_pInt,ip=instance,& if (extmsg /= '') call IO_error(211_pInt,ip=instance,&
ext_msg=trim(extmsg)//'('//PLASTICITY_PHENOPOWERLAW_label//')') ext_msg=trim(extmsg)//'('//PLASTICITY_PHENOPOWERLAW_label//')')
if (any(p%tau0_slip < 0.0_pReal .and. p%Nslip > 0_pInt)) & if (any(p%tau0_slip < 0.0_pReal .and. p%Nslip > 0_pInt)) &
extmsg = trim(extmsg)//" 'tau0_slip' " extmsg = trim(extmsg)//" 'tau0_slip' "
if (any(p%tau0_slip < p%tausat_slip .and. p%Nslip > 0_pInt)) & if (any(p%tau0_slip < p%tausat_slip .and. p%Nslip > 0_pInt)) &
extmsg = trim(extmsg)//" 'tausat_slip' " extmsg = trim(extmsg)//" 'tausat_slip' "
if (any(p%gdot0_slip <= 0.0_pReal .and. p%Nslip > 0_pInt)) & if (any(p%gdot0_slip <= 0.0_pReal .and. p%Nslip > 0_pInt)) &
extmsg = trim(extmsg)//" 'tausat_slip' " extmsg = trim(extmsg)//" 'tausat_slip' "
if (p%n_slip <= 0.0_pReal) extmsg = trim(extmsg)//" 'n_slip' " if (p%n_slip <= 0.0_pReal) extmsg = trim(extmsg)//" 'n_slip' "
!if (any(dEq0(p%a_slip) .and. sum(p%Nslip) > 0)) & !if (any(dEq0(p%a_slip) .and. sum(p%Nslip) > 0)) &
! call IO_error(211_pInt,el=instance,ext_msg='a_slip ('//PLASTICITY_PHENOPOWERLAW_label//')') ! call IO_error(211_pInt,el=instance,ext_msg='a_slip ('//PLASTICITY_PHENOPOWERLAW_label//')')
@ -317,21 +313,16 @@ if (p%n_slip <= 0.0_pReal) extmsg = trim(extmsg)//" 'n_slip' "
call IO_error(211_pInt,el=instance,ext_msg='aTolTwinfrac ('//PLASTICITY_PHENOPOWERLAW_label//')') call IO_error(211_pInt,el=instance,ext_msg='aTolTwinfrac ('//PLASTICITY_PHENOPOWERLAW_label//')')
NipcMyPhase = count(material_phase == phase) ! number of IPCs containing my phase
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
! allocate state arrays ! allocate state arrays
NipcMyPhase = count(material_phase == phase) ! number of IPCs containing my phase
sizeState = size(['tau_slip ','accshear_slip']) * sum(p%nslip) & sizeState = size(['tau_slip ','accshear_slip']) * sum(p%nslip) &
+ size(['tau_twin ','accshear_twin']) * sum(p%ntwin) & + size(['tau_twin ','accshear_twin']) * sum(p%ntwin) &
+ size(['sum(gamma)', 'sum(f) ']) + size(['sum(gamma)', 'sum(f) '])
sizeDotState = sizeState sizeDotState = sizeState
sizeDeltaState = 0_pInt
plasticState(phase)%sizeState = sizeState plasticState(phase)%sizeState = sizeState
plasticState(phase)%sizeDotState = sizeDotState plasticState(phase)%sizeDotState = sizeDotState
plasticState(phase)%sizeDeltaState = sizeDeltaState
plasticState(phase)%nSlip = sum(p%Nslip) plasticState(phase)%nSlip = sum(p%Nslip)
plasticState(phase)%nTwin = sum(p%Ntwin) plasticState(phase)%nTwin = sum(p%Ntwin)
allocate(plasticState(phase)%aTolState ( sizeState), source=0.0_pReal) allocate(plasticState(phase)%aTolState ( sizeState), source=0.0_pReal)
@ -339,8 +330,9 @@ if (p%n_slip <= 0.0_pReal) extmsg = trim(extmsg)//" 'n_slip' "
allocate(plasticState(phase)%partionedState0 ( sizeState,NipcMyPhase), source=0.0_pReal) allocate(plasticState(phase)%partionedState0 ( sizeState,NipcMyPhase), source=0.0_pReal)
allocate(plasticState(phase)%subState0 ( sizeState,NipcMyPhase), source=0.0_pReal) allocate(plasticState(phase)%subState0 ( sizeState,NipcMyPhase), source=0.0_pReal)
allocate(plasticState(phase)%state ( sizeState,NipcMyPhase), source=0.0_pReal) allocate(plasticState(phase)%state ( sizeState,NipcMyPhase), source=0.0_pReal)
allocate(plasticState(phase)%dotState (sizeDotState,NipcMyPhase), source=0.0_pReal) allocate(plasticState(phase)%dotState (sizeDotState,NipcMyPhase), source=0.0_pReal)
allocate(plasticState(phase)%deltaState (sizeDeltaState,NipcMyPhase), source=0.0_pReal) allocate(plasticState(phase)%deltaState (0_pInt,NipcMyPhase), source=0.0_pReal)
if (any(numerics_integrator == 1_pInt)) then if (any(numerics_integrator == 1_pInt)) then
allocate(plasticState(phase)%previousDotState (sizeDotState,NipcMyPhase),source=0.0_pReal) allocate(plasticState(phase)%previousDotState (sizeDotState,NipcMyPhase),source=0.0_pReal)
allocate(plasticState(phase)%previousDotState2(sizeDotState,NipcMyPhase),source=0.0_pReal) allocate(plasticState(phase)%previousDotState2(sizeDotState,NipcMyPhase),source=0.0_pReal)
@ -350,12 +342,6 @@ if (p%n_slip <= 0.0_pReal) extmsg = trim(extmsg)//" 'n_slip' "
if (any(numerics_integrator == 5_pInt)) & if (any(numerics_integrator == 5_pInt)) &
allocate(plasticState(phase)%RKCK45dotState (6,sizeDotState,NipcMyPhase), source=0.0_pReal) allocate(plasticState(phase)%RKCK45dotState (6,sizeDotState,NipcMyPhase), source=0.0_pReal)
offset_slip = plasticState(phase)%nSlip+plasticState(phase)%nTwin+2_pInt
plasticState(phase)%slipRate => &
plasticState(phase)%dotState(offset_slip+1:offset_slip+plasticState(phase)%nSlip,1:NipcMyPhase)
plasticState(phase)%accumulatedSlip => &
plasticState(phase)%state(offset_slip+1:offset_slip+plasticState(phase)%nSlip,1:NipcMyPhase)
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
! calculate hardening matrices ! calculate hardening matrices
mySlipFamilies: do f = 1_pInt,size(p%Nslip,1) ! >>> interaction slip -- X mySlipFamilies: do f = 1_pInt,size(p%Nslip,1) ! >>> interaction slip -- X
@ -455,6 +441,12 @@ if (p%n_slip <= 0.0_pReal) extmsg = trim(extmsg)//" 'n_slip' "
dotState(instance)%accshear_twin=>plasticState(phase)%dotState(startIndex:endIndex,:) dotState(instance)%accshear_twin=>plasticState(phase)%dotState(startIndex:endIndex,:)
plasticState(phase)%aTolState(startIndex:endIndex) = p%aTolShear plasticState(phase)%aTolState(startIndex:endIndex) = p%aTolShear
offset_slip = plasticState(phase)%nSlip+plasticState(phase)%nTwin+2_pInt
plasticState(phase)%slipRate => &
plasticState(phase)%dotState(offset_slip+1:offset_slip+plasticState(phase)%nSlip,1:NipcMyPhase)
plasticState(phase)%accumulatedSlip => &
plasticState(phase)%state(offset_slip+1:offset_slip+plasticState(phase)%nSlip,1:NipcMyPhase)
endif endif
enddo enddo