Reading in of parameters made consistent
This commit is contained in:
parent
57c6f44dfc
commit
2480d2f1ba
|
@ -43,14 +43,6 @@ module plastic_dislotwin
|
||||||
real(pReal), dimension(:,:,:,:,:,:), allocatable, private :: &
|
real(pReal), dimension(:,:,:,:,:,:), allocatable, private :: &
|
||||||
Ctrans3333 !< trans elasticity matrix for each instance
|
Ctrans3333 !< trans elasticity matrix for each instance
|
||||||
real(pReal), dimension(:,:), allocatable, private :: &
|
real(pReal), dimension(:,:), allocatable, private :: &
|
||||||
rhoEdge0, & !< initial edge dislocation density per slip system for each family and instance
|
|
||||||
rhoEdgeDip0, & !< initial edge dipole density per slip system for each family and instance
|
|
||||||
burgersPerSlipFamily, & !< absolute length of burgers vector [m] for each slip family and instance
|
|
||||||
burgersPerSlipSystem, & !< absolute length of burgers vector [m] for each slip system and instance
|
|
||||||
burgersPerTwinFamily, & !< absolute length of burgers vector [m] for each twin family and instance
|
|
||||||
burgersPerTwinSystem, & !< absolute length of burgers vector [m] for each twin system and instance
|
|
||||||
burgersPerTransFamily, & !< absolute length of burgers vector [m] for each trans family and instance
|
|
||||||
burgersPerTransSystem, & !< absolute length of burgers vector [m] for each trans system and instance
|
|
||||||
QedgePerSlipFamily, & !< activation energy for glide [J] for each slip family and instance
|
QedgePerSlipFamily, & !< activation energy for glide [J] for each slip family and instance
|
||||||
QedgePerSlipSystem, & !< activation energy for glide [J] for each slip system and instance
|
QedgePerSlipSystem, & !< activation energy for glide [J] for each slip system and instance
|
||||||
v0PerSlipFamily, & !< dislocation velocity prefactor [m/s] for each family and instance
|
v0PerSlipFamily, & !< dislocation velocity prefactor [m/s] for each family and instance
|
||||||
|
@ -154,13 +146,21 @@ module plastic_dislotwin
|
||||||
Cthresholdtrans, & !<
|
Cthresholdtrans, & !<
|
||||||
transStackHeight !< Stack height of hex nucleus
|
transStackHeight !< Stack height of hex nucleus
|
||||||
|
|
||||||
!integer(pInt), dimension(:), allocatable, private :: &
|
integer(pInt), dimension(:), allocatable, private :: &
|
||||||
! Nslip, & !< number of active slip systems for each family and instance
|
Nslip, & !< number of active slip systems for each family and instance
|
||||||
! Ntwin, & !< number of active twin systems for each family and instance
|
Ntwin, & !< number of active twin systems for each family and instance
|
||||||
! Ntrans !< number of active transformation systems for each family and instance
|
Ntrans !< number of active transformation systems for each family and instance
|
||||||
|
real(pReal), dimension(:), allocatable, private :: &
|
||||||
|
rho0, & !< initial unipolar dislocation density per slip system
|
||||||
|
rhoDip0, & !< initial dipole dislocation density per slip system
|
||||||
|
burgers_slip, & !< absolute length of burgers vector [m] for each slip systems
|
||||||
|
burgers_twin, & !< absolute length of burgers vector [m] for each slip systems
|
||||||
|
burgers_trans !< absolute length of burgers vector [m] for each twin family and instance
|
||||||
|
|
||||||
|
|
||||||
end type
|
end type
|
||||||
|
|
||||||
type(tParameters), dimension(:), allocatable, private :: param !< containers of constitutive parameters (len Ninstance)
|
type(tParameters), dimension(:), allocatable, private, target :: param !< containers of constitutive parameters (len Ninstance)
|
||||||
|
|
||||||
|
|
||||||
type, private :: tDislotwinState
|
type, private :: tDislotwinState
|
||||||
|
@ -253,7 +253,8 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
material_phase, &
|
material_phase, &
|
||||||
plasticState
|
plasticState
|
||||||
use config, only: &
|
use config, only: &
|
||||||
MATERIAL_partPhase
|
MATERIAL_partPhase, &
|
||||||
|
phaseConfig
|
||||||
use lattice
|
use lattice
|
||||||
use numerics,only: &
|
use numerics,only: &
|
||||||
numerics_integrator
|
numerics_integrator
|
||||||
|
@ -269,7 +270,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
Nchunks_SlipTrans = 0_pInt, Nchunks_TransSlip = 0_pInt, Nchunks_TransTrans = 0_pInt, &
|
Nchunks_SlipTrans = 0_pInt, Nchunks_TransSlip = 0_pInt, Nchunks_TransTrans = 0_pInt, &
|
||||||
Nchunks_SlipFamilies = 0_pInt, Nchunks_TwinFamilies = 0_pInt, Nchunks_TransFamilies = 0_pInt, &
|
Nchunks_SlipFamilies = 0_pInt, Nchunks_TwinFamilies = 0_pInt, Nchunks_TransFamilies = 0_pInt, &
|
||||||
offset_slip, index_myFamily, index_otherFamily, &
|
offset_slip, index_myFamily, index_otherFamily, &
|
||||||
startIndex, endIndex, output_ID
|
startIndex, endIndex, outputID,outputSize
|
||||||
integer(pInt) :: sizeState, sizeDotState, sizeDeltaState
|
integer(pInt) :: sizeState, sizeDotState, sizeDeltaState
|
||||||
integer(pInt) :: NofMyPhase
|
integer(pInt) :: NofMyPhase
|
||||||
|
|
||||||
|
@ -286,7 +287,13 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
tag = '', &
|
tag = '', &
|
||||||
line = ''
|
line = ''
|
||||||
|
|
||||||
|
character(len=65536), dimension(:), allocatable :: outputs
|
||||||
|
integer(pInt), dimension(0), parameter :: emptyInt = [integer(pInt)::]
|
||||||
|
real(pReal), dimension(0), parameter :: emptyReal = [real(pReal)::]
|
||||||
|
character(len=65536), dimension(0), parameter :: emptyString = [character(len=65536)::]
|
||||||
|
|
||||||
|
|
||||||
|
type(tParameters), pointer :: prm
|
||||||
|
|
||||||
real(pReal), dimension(:), allocatable :: tempPerSlip, tempPerTwin, tempPerTrans
|
real(pReal), dimension(:), allocatable :: tempPerSlip, tempPerTwin, tempPerTrans
|
||||||
|
|
||||||
|
@ -321,16 +328,6 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
allocate(Ntwin(lattice_maxNtwinFamily,maxNinstance), source=0_pInt)
|
allocate(Ntwin(lattice_maxNtwinFamily,maxNinstance), source=0_pInt)
|
||||||
allocate(Ntrans(lattice_maxNtransFamily,maxNinstance), source=0_pInt)
|
allocate(Ntrans(lattice_maxNtransFamily,maxNinstance), source=0_pInt)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
allocate(rhoEdge0(lattice_maxNslipFamily,maxNinstance), source=0.0_pReal)
|
|
||||||
allocate(rhoEdgeDip0(lattice_maxNslipFamily,maxNinstance), source=0.0_pReal)
|
|
||||||
allocate(burgersPerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
|
||||||
source=0.0_pReal)
|
|
||||||
allocate(burgersPerTwinFamily(lattice_maxNtwinFamily,maxNinstance), &
|
|
||||||
source=0.0_pReal)
|
|
||||||
allocate(burgersPerTransFamily(lattice_maxNtransFamily,maxNinstance), &
|
|
||||||
source=0.0_pReal)
|
|
||||||
allocate(QedgePerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
allocate(QedgePerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
allocate(v0PerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
allocate(v0PerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
||||||
|
@ -368,6 +365,210 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
allocate(sPerTransFamily(lattice_maxNtransFamily,maxNinstance),source=0.0_pReal)
|
allocate(sPerTransFamily(lattice_maxNtransFamily,maxNinstance),source=0.0_pReal)
|
||||||
|
|
||||||
|
do phase = 1_pInt, size(phase_plasticityInstance)
|
||||||
|
if (phase_plasticity(phase) == PLASTICITY_DISLOTWIN_ID) then
|
||||||
|
instance = phase_plasticityInstance(phase)
|
||||||
|
prm => param(instance)
|
||||||
|
|
||||||
|
prm%Nslip = phaseConfig(phase)%getInts('nslip',defaultVal=emptyInt)
|
||||||
|
!if (size > Nchunks_SlipFamilies + 1_pInt) call IO_error(150_pInt,ext_msg=extmsg)
|
||||||
|
if (sum(prm%Nslip) > 0_pInt) then
|
||||||
|
prm%rho0 = phaseConfig(phase)%getFloats('rhoedge0')
|
||||||
|
prm%rhoDip0 = phaseConfig(phase)%getFloats('rhoedgedip0')
|
||||||
|
prm%burgers_slip = phaseConfig(phase)%getFloats('slipburgers')
|
||||||
|
|
||||||
|
prm%aTolRho = phaseConfig(phase)%getFloat('atol_rho')
|
||||||
|
|
||||||
|
prm%CEdgeDipMinDistance = phaseConfig(phase)%getFloat('cedgedipmindistance')
|
||||||
|
endif
|
||||||
|
|
||||||
|
prm%Ntwin = phaseConfig(phase)%getInts('ntwin', defaultVal=emptyInt)
|
||||||
|
!if (size > Nchunks_SlipFamilies + 1_pInt) call IO_error(150_pInt,ext_msg=extmsg)
|
||||||
|
if (sum(prm%Ntwin) > 0_pInt) then
|
||||||
|
prm%burgers_twin = phaseConfig(phase)%getFloats('twinburgers')
|
||||||
|
prm%xc_twin = phaseConfig(phase)%getFloat('xc_twin')
|
||||||
|
|
||||||
|
prm%aTolTwinFrac = phaseConfig(phase)%getFloat('atol_twinfrac')
|
||||||
|
prm%L0_twin = phaseConfig(phase)%getFloat('l0_twin')
|
||||||
|
endif
|
||||||
|
|
||||||
|
prm%Ntrans = phaseConfig(phase)%getInts('ntrans', defaultVal=emptyInt)
|
||||||
|
!if (size > Nchunks_SlipFamilies + 1_pInt) call IO_error(150_pInt,ext_msg=extmsg)
|
||||||
|
if (sum(prm%Ntrans) > 0_pInt) then
|
||||||
|
prm%burgers_trans = phaseConfig(phase)%getFloats('transburgers')
|
||||||
|
prm%Cthresholdtrans = phaseConfig(phase)%getFloat('cthresholdtrans', defaultVal=0.0_pReal) ! ToDo: How to handle that???
|
||||||
|
prm%transStackHeight = phaseConfig(phase)%getFloat('transstackheight', defaultVal=0.0_pReal) ! ToDo: How to handle that???
|
||||||
|
prm%Cmfptrans = phaseConfig(phase)%getFloat('cmfptrans', defaultVal=0.0_pReal) ! ToDo: How to handle that???
|
||||||
|
prm%deltaG = phaseConfig(phase)%getFloat('deltag')
|
||||||
|
prm%xc_trans = phaseConfig(phase)%getFloat('xc_trans', defaultVal=0.0_pReal) ! ToDo: How to handle that???
|
||||||
|
prm%L0_trans = phaseConfig(phase)%getFloat('l0_trans')
|
||||||
|
prm%aTolTransFrac = phaseConfig(phase)%getFloat('atol_transfrac')
|
||||||
|
endif
|
||||||
|
|
||||||
|
if (sum(prm%Ntwin) > 0_pInt .or. sum(prm%Ntrans) > 0_pInt) then
|
||||||
|
prm%SFE_0K = phaseConfig(phase)%getFloat('sfe_0k')
|
||||||
|
prm%dSFE_dT = phaseConfig(phase)%getFloat('dsfe_dt')
|
||||||
|
prm%VcrossSlip = phaseConfig(phase)%getFloat('vcrossslip')
|
||||||
|
endif
|
||||||
|
|
||||||
|
prm%sbResistance = phaseConfig(phase)%getFloat('shearbandresistance',defaultVal=0.0_pReal)
|
||||||
|
prm%sbVelocity = phaseConfig(phase)%getFloat('shearbandvelocity',defaultVal=0.0_pReal)
|
||||||
|
|
||||||
|
|
||||||
|
prm%CAtomicVolume = phaseConfig(phase)%getFloat('catomicvolume')
|
||||||
|
prm%GrainSize = phaseConfig(phase)%getFloat('grainsize')
|
||||||
|
prm%MaxTwinFraction = phaseConfig(phase)%getFloat('maxtwinfraction') ! ToDo: only used in postResults
|
||||||
|
prm%pShearBand = phaseConfig(phase)%getFloat('p_shearband')
|
||||||
|
prm%qShearBand = phaseConfig(phase)%getFloat('q_shearband')
|
||||||
|
prm%D0 = phaseConfig(phase)%getFloat('d0')
|
||||||
|
prm%Qsd = phaseConfig(phase)%getFloat('qsd')
|
||||||
|
prm%SolidSolutionStrength = phaseConfig(phase)%getFloat('solidsolutionstrength')
|
||||||
|
prm%dipoleFormationFactor= phaseConfig(phase)%getFloat('dipoleformationfactor', defaultVal=0.0_pReal) ! ToDo: How to handle that???
|
||||||
|
prm%sbQedge = phaseConfig(phase)%getFloat('qedgepersbsystem')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
! case ('p_shearband')
|
||||||
|
! prm%pShearBand = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('q_shearband')
|
||||||
|
! prm%qShearBand = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('d0')
|
||||||
|
! prm%D0 = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('qsd')
|
||||||
|
! prm%Qsd = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
|
||||||
|
! case ('atol_twinfrac')
|
||||||
|
! prm%aTolTwinFrac = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('atol_transfrac')
|
||||||
|
! prm%aTolTransFrac = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('solidsolutionstrength')
|
||||||
|
! prm%SolidSolutionStrength = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('l0_twin')
|
||||||
|
! prm%L0_twin = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
|
||||||
|
! case ('vcrossslip')
|
||||||
|
! prm%VcrossSlip = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('cedgedipmindistance')
|
||||||
|
! prm%CEdgeDipMinDistance = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
|
||||||
|
! case ('sfe_0k')
|
||||||
|
! prm%SFE_0K = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('dsfe_dt')
|
||||||
|
! prm%dSFE_dT = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
! case ('dipoleformationfactor')
|
||||||
|
! prm%dipoleFormationFactor = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
|
||||||
|
! case ('qedgepersbsystem')
|
||||||
|
! prm%sbQedge = IO_floatValue(line,chunkPos,2_pInt)
|
||||||
|
|
||||||
|
|
||||||
|
outputs = phaseConfig(phase)%getStrings('(output)', defaultVal=emptyString)
|
||||||
|
allocate(prm%outputID(0))
|
||||||
|
do i= 1_pInt, size(outputs)
|
||||||
|
outputID = undefined_ID
|
||||||
|
select case(outputs(i))
|
||||||
|
|
||||||
|
case ('edge_density')
|
||||||
|
outputID = edge_density_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('dipole_density')
|
||||||
|
outputID = dipole_density_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('shear_rate_slip','shearrate_slip')
|
||||||
|
outputID = shear_rate_slip_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('accumulated_shear_slip')
|
||||||
|
outputID = accumulated_shear_slip_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('mfp_slip')
|
||||||
|
outputID = mfp_slip_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('resolved_stress_slip')
|
||||||
|
outputID = resolved_stress_slip_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('threshold_stress_slip')
|
||||||
|
outputID= threshold_stress_slip_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('edge_dipole_distance')
|
||||||
|
outputID = edge_dipole_distance_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('stress_exponent')
|
||||||
|
outputID = stress_exponent_ID
|
||||||
|
outputSize = sum(prm%Nslip)
|
||||||
|
|
||||||
|
case ('twin_fraction')
|
||||||
|
outputID = twin_fraction_ID
|
||||||
|
outputSize = sum(prm%Ntwin)
|
||||||
|
|
||||||
|
case ('shear_rate_twin','shearrate_twin')
|
||||||
|
outputID= shear_rate_twin_ID
|
||||||
|
outputSize = sum(prm%Ntwin)
|
||||||
|
|
||||||
|
case ('accumulated_shear_twin')
|
||||||
|
outputID = accumulated_shear_twin_ID
|
||||||
|
outputSize = sum(prm%Ntwin)
|
||||||
|
|
||||||
|
case ('mfp_twin')
|
||||||
|
outputID = mfp_twin_ID
|
||||||
|
outputSize = sum(prm%Ntwin)
|
||||||
|
|
||||||
|
case ('resolved_stress_twin')
|
||||||
|
outputID = resolved_stress_twin_ID
|
||||||
|
outputSize = sum(prm%Ntwin)
|
||||||
|
|
||||||
|
case ('threshold_stress_twin')
|
||||||
|
outputID = threshold_stress_twin_ID
|
||||||
|
outputSize = sum(prm%Ntwin)
|
||||||
|
|
||||||
|
case ('resolved_stress_shearband')
|
||||||
|
outputID = resolved_stress_shearband_ID
|
||||||
|
outputSize = 6_pInt
|
||||||
|
|
||||||
|
case ('shear_rate_shearband','shearrate_shearband')
|
||||||
|
outputID = shear_rate_shearband_ID
|
||||||
|
outputSize = 6_pInt
|
||||||
|
|
||||||
|
case ('sb_eigenvalues')
|
||||||
|
outputID = sb_eigenvalues_ID
|
||||||
|
outputSize = 3_pInt
|
||||||
|
|
||||||
|
case ('sb_eigenvectors')
|
||||||
|
outputID = sb_eigenvectors_ID
|
||||||
|
outputSize = 3_pInt
|
||||||
|
|
||||||
|
case ('stress_trans_fraction')
|
||||||
|
outputID = stress_trans_fraction_ID
|
||||||
|
outputSize = sum(prm%Ntrans)
|
||||||
|
|
||||||
|
case ('strain_trans_fraction')
|
||||||
|
outputID = strain_trans_fraction_ID
|
||||||
|
outputSize = sum(prm%Ntrans)
|
||||||
|
|
||||||
|
case ('trans_fraction','total_trans_fraction')
|
||||||
|
outputID = trans_fraction_ID
|
||||||
|
outputSize = sum(prm%Ntrans)
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
|
if (outputID /= undefined_ID) then
|
||||||
|
plastic_dislotwin_output(i,instance) = outputs(i)
|
||||||
|
plastic_dislotwin_sizePostResult(i,instance) = outputSize
|
||||||
|
prm%outputID = [prm%outputID , outputID]
|
||||||
|
endif
|
||||||
|
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
|
||||||
|
|
||||||
rewind(fileUnit)
|
rewind(fileUnit)
|
||||||
phase = 0_pInt
|
phase = 0_pInt
|
||||||
|
@ -402,7 +603,6 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
allocate(tempPerSlip(Nchunks_SlipFamilies))
|
allocate(tempPerSlip(Nchunks_SlipFamilies))
|
||||||
allocate(tempPerTwin(Nchunks_TwinFamilies))
|
allocate(tempPerTwin(Nchunks_TwinFamilies))
|
||||||
allocate(tempPerTrans(Nchunks_TransFamilies))
|
allocate(tempPerTrans(Nchunks_TransFamilies))
|
||||||
allocate(param(instance)%outputID(phase_Noutput(phase)), source=undefined_ID)
|
|
||||||
endif
|
endif
|
||||||
cycle ! skip to next line
|
cycle ! skip to next line
|
||||||
endif
|
endif
|
||||||
|
@ -412,82 +612,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
chunkPos = IO_stringPos(line)
|
chunkPos = IO_stringPos(line)
|
||||||
tag = IO_lc(IO_stringValue(line,chunkPos,1_pInt)) ! extract key
|
tag = IO_lc(IO_stringValue(line,chunkPos,1_pInt)) ! extract key
|
||||||
select case(tag)
|
select case(tag)
|
||||||
case ('(output)')
|
|
||||||
output_ID = undefined_ID
|
|
||||||
select case(IO_lc(IO_stringValue(line,chunkPos,2_pInt)))
|
|
||||||
case ('edge_density')
|
|
||||||
output_ID = edge_density_ID
|
|
||||||
|
|
||||||
case ('dipole_density')
|
|
||||||
output_ID = dipole_density_ID
|
|
||||||
|
|
||||||
case ('shear_rate_slip','shearrate_slip')
|
|
||||||
output_ID = shear_rate_slip_ID
|
|
||||||
|
|
||||||
case ('accumulated_shear_slip')
|
|
||||||
output_ID = accumulated_shear_slip_ID
|
|
||||||
|
|
||||||
case ('mfp_slip')
|
|
||||||
output_ID = mfp_slip_ID
|
|
||||||
|
|
||||||
case ('resolved_stress_slip')
|
|
||||||
output_ID = resolved_stress_slip_ID
|
|
||||||
|
|
||||||
case ('threshold_stress_slip')
|
|
||||||
output_ID= threshold_stress_slip_ID
|
|
||||||
|
|
||||||
case ('edge_dipole_distance')
|
|
||||||
output_ID = edge_dipole_distance_ID
|
|
||||||
|
|
||||||
case ('stress_exponent')
|
|
||||||
output_ID = stress_exponent_ID
|
|
||||||
|
|
||||||
case ('twin_fraction')
|
|
||||||
output_ID = twin_fraction_ID
|
|
||||||
|
|
||||||
case ('shear_rate_twin','shearrate_twin')
|
|
||||||
output_ID= shear_rate_twin_ID
|
|
||||||
|
|
||||||
case ('accumulated_shear_twin')
|
|
||||||
output_ID = accumulated_shear_twin_ID
|
|
||||||
|
|
||||||
case ('mfp_twin')
|
|
||||||
output_ID = mfp_twin_ID
|
|
||||||
|
|
||||||
case ('resolved_stress_twin')
|
|
||||||
output_ID = resolved_stress_twin_ID
|
|
||||||
|
|
||||||
case ('threshold_stress_twin')
|
|
||||||
output_ID = threshold_stress_twin_ID
|
|
||||||
|
|
||||||
case ('resolved_stress_shearband')
|
|
||||||
output_ID = resolved_stress_shearband_ID
|
|
||||||
|
|
||||||
case ('shear_rate_shearband','shearrate_shearband')
|
|
||||||
output_ID = shear_rate_shearband_ID
|
|
||||||
|
|
||||||
case ('sb_eigenvalues')
|
|
||||||
output_ID = sb_eigenvalues_ID
|
|
||||||
|
|
||||||
case ('sb_eigenvectors')
|
|
||||||
output_ID = sb_eigenvectors_ID
|
|
||||||
|
|
||||||
case ('stress_trans_fraction')
|
|
||||||
output_ID = stress_trans_fraction_ID
|
|
||||||
|
|
||||||
case ('strain_trans_fraction')
|
|
||||||
output_ID = strain_trans_fraction_ID
|
|
||||||
|
|
||||||
case ('trans_fraction','total_trans_fraction')
|
|
||||||
output_ID = trans_fraction_ID
|
|
||||||
|
|
||||||
end select
|
|
||||||
|
|
||||||
if (output_ID /= undefined_ID) then
|
|
||||||
plastic_dislotwin_Noutput(instance) = plastic_dislotwin_Noutput(instance) + 1_pInt
|
|
||||||
plastic_dislotwin_output(plastic_dislotwin_Noutput(instance),instance) = IO_lc(IO_stringValue(line,chunkPos,2_pInt))
|
|
||||||
param(instance)%outputID(plastic_dislotwin_Noutput(instance)) = output_ID
|
|
||||||
endif
|
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! parameters depending on number of slip system families
|
! parameters depending on number of slip system families
|
||||||
|
@ -501,17 +626,11 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
|
|
||||||
Nslip(j,instance) = IO_intValue(line,chunkPos,1_pInt+j)
|
Nslip(j,instance) = IO_intValue(line,chunkPos,1_pInt+j)
|
||||||
enddo
|
enddo
|
||||||
case ('rhoedge0','rhoedgedip0','slipburgers','qedge','v0','clambdaslip','tau_peierls','p_slip','q_slip')
|
case ('qedge','v0','clambdaslip','tau_peierls','p_slip','q_slip')
|
||||||
do j = 1_pInt, Nchunks_SlipFamilies
|
do j = 1_pInt, Nchunks_SlipFamilies
|
||||||
tempPerSlip(j) = IO_floatValue(line,chunkPos,1_pInt+j)
|
tempPerSlip(j) = IO_floatValue(line,chunkPos,1_pInt+j)
|
||||||
enddo
|
enddo
|
||||||
select case(tag)
|
select case(tag)
|
||||||
case ('rhoedge0')
|
|
||||||
rhoEdge0(1:Nchunks_SlipFamilies,instance) = tempPerSlip(1:Nchunks_SlipFamilies)
|
|
||||||
case ('rhoedgedip0')
|
|
||||||
rhoEdgeDip0(1:Nchunks_SlipFamilies,instance) = tempPerSlip(1:Nchunks_SlipFamilies)
|
|
||||||
case ('slipburgers')
|
|
||||||
burgersPerSlipFamily(1:Nchunks_SlipFamilies,instance) = tempPerSlip(1:Nchunks_SlipFamilies)
|
|
||||||
case ('qedge')
|
case ('qedge')
|
||||||
QedgePerSlipFamily(1:Nchunks_SlipFamilies,instance) = tempPerSlip(1:Nchunks_SlipFamilies)
|
QedgePerSlipFamily(1:Nchunks_SlipFamilies,instance) = tempPerSlip(1:Nchunks_SlipFamilies)
|
||||||
case ('v0')
|
case ('v0')
|
||||||
|
@ -549,8 +668,6 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
Ndot0PerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
Ndot0PerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
||||||
case ('twinsize')
|
case ('twinsize')
|
||||||
twinsizePerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
twinsizePerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
||||||
case ('twinburgers')
|
|
||||||
burgersPerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
|
||||||
case ('r_twin')
|
case ('r_twin')
|
||||||
rPerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
rPerTwinFamily(1:Nchunks_TwinFamilies,instance) = tempPerTwin(1:Nchunks_TwinFamilies)
|
||||||
end select
|
end select
|
||||||
|
@ -576,8 +693,6 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
Ndot0PerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
Ndot0PerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
||||||
case ('lamellarsize')
|
case ('lamellarsize')
|
||||||
lamellarsizePerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
lamellarsizePerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
||||||
case ('transburgers')
|
|
||||||
burgersPerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
|
||||||
case ('s_trans')
|
case ('s_trans')
|
||||||
sPerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
sPerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
||||||
end select
|
end select
|
||||||
|
@ -625,66 +740,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
do j = 1_pInt, Nchunks_TransTrans
|
do j = 1_pInt, Nchunks_TransTrans
|
||||||
interaction_TransTrans(j,instance) = IO_floatValue(line,chunkPos,1_pInt+j)
|
interaction_TransTrans(j,instance) = IO_floatValue(line,chunkPos,1_pInt+j)
|
||||||
enddo
|
enddo
|
||||||
!--------------------------------------------------------------------------------------------------
|
|
||||||
! parameters independent of number of slip/twin/trans systems
|
|
||||||
case ('grainsize')
|
|
||||||
param(instance)%GrainSize = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('maxtwinfraction')
|
|
||||||
param(instance)%MaxTwinFraction = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('p_shearband')
|
|
||||||
param(instance)%pShearBand = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('q_shearband')
|
|
||||||
param(instance)%qShearBand = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('d0')
|
|
||||||
param(instance)%D0 = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('qsd')
|
|
||||||
param(instance)%Qsd = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('atol_rho')
|
|
||||||
param(instance)%aTolRho = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('atol_twinfrac')
|
|
||||||
param(instance)%aTolTwinFrac = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('atol_transfrac')
|
|
||||||
param(instance)%aTolTransFrac = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('cmfptwin')
|
|
||||||
param(instance)%Cmfptwin = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('cthresholdtwin')
|
|
||||||
param(instance)%Cthresholdtwin = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('solidsolutionstrength')
|
|
||||||
param(instance)%SolidSolutionStrength = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('l0_twin')
|
|
||||||
param(instance)%L0_twin = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('l0_trans')
|
|
||||||
param(instance)%L0_trans = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('xc_twin')
|
|
||||||
param(instance)%xc_twin = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('xc_trans')
|
|
||||||
param(instance)%xc_trans = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('vcrossslip')
|
|
||||||
param(instance)%VcrossSlip = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('cedgedipmindistance')
|
|
||||||
param(instance)%CEdgeDipMinDistance = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('catomicvolume')
|
|
||||||
param(instance)%CAtomicVolume = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('sfe_0k')
|
|
||||||
param(instance)%SFE_0K = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('dsfe_dt')
|
|
||||||
param(instance)%dSFE_dT = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('dipoleformationfactor')
|
|
||||||
param(instance)%dipoleFormationFactor = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('shearbandresistance')
|
|
||||||
param(instance)%sbResistance = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('shearbandvelocity')
|
|
||||||
param(instance)%sbVelocity = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('qedgepersbsystem')
|
|
||||||
param(instance)%sbQedge = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('deltag')
|
|
||||||
param(instance)%deltaG = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('cmfptrans')
|
|
||||||
param(instance)%Cmfptrans = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('cthresholdtrans')
|
|
||||||
param(instance)%Cthresholdtrans = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
case ('transstackheight')
|
|
||||||
param(instance)%transStackHeight = IO_floatValue(line,chunkPos,2_pInt)
|
|
||||||
end select
|
end select
|
||||||
endif; endif
|
endif; endif
|
||||||
enddo parsingFile
|
enddo parsingFile
|
||||||
|
@ -701,12 +757,12 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='Ntrans ('//PLASTICITY_DISLOTWIN_label//')')
|
call IO_error(211_pInt,el=instance,ext_msg='Ntrans ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
do f = 1_pInt,lattice_maxNslipFamily
|
do f = 1_pInt,lattice_maxNslipFamily
|
||||||
if (Nslip(f,instance) > 0_pInt) then
|
if (Nslip(f,instance) > 0_pInt) then
|
||||||
if (rhoEdge0(f,instance) < 0.0_pReal) &
|
! if (rhoEdge0(f,instance) < 0.0_pReal) &
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='rhoEdge0 ('//PLASTICITY_DISLOTWIN_label//')')
|
! call IO_error(211_pInt,el=instance,ext_msg='rhoEdge0 ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
if (rhoEdgeDip0(f,instance) < 0.0_pReal) &
|
! if (rhoEdgeDip0(f,instance) < 0.0_pReal) &
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='rhoEdgeDip0 ('//PLASTICITY_DISLOTWIN_label//')')
|
! call IO_error(211_pInt,el=instance,ext_msg='rhoEdgeDip0 ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
if (burgersPerSlipFamily(f,instance) <= 0.0_pReal) &
|
! if (burgersPerSlipFamily(f,instance) <= 0.0_pReal) &
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='slipBurgers ('//PLASTICITY_DISLOTWIN_label//')')
|
! call IO_error(211_pInt,el=instance,ext_msg='slipBurgers ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
if (v0PerSlipFamily(f,instance) <= 0.0_pReal) &
|
if (v0PerSlipFamily(f,instance) <= 0.0_pReal) &
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='v0 ('//PLASTICITY_DISLOTWIN_label//')')
|
call IO_error(211_pInt,el=instance,ext_msg='v0 ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
if (tau_peierlsPerSlipFamily(f,instance) < 0.0_pReal) &
|
if (tau_peierlsPerSlipFamily(f,instance) < 0.0_pReal) &
|
||||||
|
@ -715,8 +771,8 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
enddo
|
enddo
|
||||||
do f = 1_pInt,lattice_maxNtwinFamily
|
do f = 1_pInt,lattice_maxNtwinFamily
|
||||||
if (Ntwin(f,instance) > 0_pInt) then
|
if (Ntwin(f,instance) > 0_pInt) then
|
||||||
if (burgersPerTwinFamily(f,instance) <= 0.0_pReal) &
|
! if (burgersPerTwinFamily(f,instance) <= 0.0_pReal) &
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='twinburgers ('//PLASTICITY_DISLOTWIN_label//')')
|
! call IO_error(211_pInt,el=instance,ext_msg='twinburgers ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
if (Ndot0PerTwinFamily(f,instance) < 0.0_pReal) &
|
if (Ndot0PerTwinFamily(f,instance) < 0.0_pReal) &
|
||||||
call IO_error(211_pInt,el=instance,ext_msg='ndot0_twin ('//PLASTICITY_DISLOTWIN_label//')')
|
call IO_error(211_pInt,el=instance,ext_msg='ndot0_twin ('//PLASTICITY_DISLOTWIN_label//')')
|
||||||
endif
|
endif
|
||||||
|
@ -776,9 +832,6 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
maxTotalNtwin = maxval(totalNtwin)
|
maxTotalNtwin = maxval(totalNtwin)
|
||||||
maxTotalNtrans = maxval(totalNtrans)
|
maxTotalNtrans = maxval(totalNtrans)
|
||||||
|
|
||||||
allocate(burgersPerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
|
||||||
allocate(burgersPerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
|
||||||
allocate(burgersPerTransSystem(maxTotalNtrans, maxNinstance), source=0.0_pReal)
|
|
||||||
allocate(QedgePerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
allocate(QedgePerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
||||||
allocate(v0PerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
allocate(v0PerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
||||||
allocate(Ndot0PerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
allocate(Ndot0PerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
||||||
|
@ -879,7 +932,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! allocate state arrays
|
! allocate state arrays
|
||||||
|
|
||||||
sizeDotState = int(size(['rhoEdge ','rhoEdgeDip ','accshearslip']),pInt) * ns &
|
sizeDotState = int(size(['rho ','rhoDip ','accshearslip']),pInt) * ns &
|
||||||
+ int(size(['twinFraction','accsheartwin']),pInt) * nt &
|
+ int(size(['twinFraction','accsheartwin']),pInt) * nt &
|
||||||
+ int(size(['stressTransFraction','strainTransFraction']),pInt) * nr
|
+ int(size(['stressTransFraction','strainTransFraction']),pInt) * nr
|
||||||
sizeDeltaState = 0_pInt
|
sizeDeltaState = 0_pInt
|
||||||
|
@ -920,6 +973,10 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
plasticState(phase)%accumulatedSlip => &
|
plasticState(phase)%accumulatedSlip => &
|
||||||
plasticState(phase)%state (offset_slip+1:offset_slip+plasticState(phase)%nslip,1:NofMyPhase)
|
plasticState(phase)%state (offset_slip+1:offset_slip+plasticState(phase)%nslip,1:NofMyPhase)
|
||||||
|
|
||||||
|
|
||||||
|
prm%burgers_slip = math_expand(prm%burgers_slip,Nslip(:,instance))
|
||||||
|
prm%burgers_twin = math_expand(prm%burgers_twin,Ntwin(:,instance))
|
||||||
|
prm%burgers_trans = math_expand(prm%burgers_trans,Ntrans(:,instance))
|
||||||
!* Process slip related parameters ------------------------------------------------
|
!* Process slip related parameters ------------------------------------------------
|
||||||
slipFamiliesLoop: do f = 1_pInt,lattice_maxNslipFamily
|
slipFamiliesLoop: do f = 1_pInt,lattice_maxNslipFamily
|
||||||
index_myFamily = sum(Nslip(1:f-1_pInt,instance)) ! index in truncated slip system list
|
index_myFamily = sum(Nslip(1:f-1_pInt,instance)) ! index in truncated slip system list
|
||||||
|
@ -930,8 +987,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
! mean free path prefactor,
|
! mean free path prefactor,
|
||||||
! and minimum dipole distance
|
! and minimum dipole distance
|
||||||
|
|
||||||
burgersPerSlipSystem(index_myFamily+j,instance) = &
|
|
||||||
burgersPerSlipFamily(f,instance)
|
|
||||||
|
|
||||||
QedgePerSlipSystem(index_myFamily+j,instance) = &
|
QedgePerSlipSystem(index_myFamily+j,instance) = &
|
||||||
QedgePerSlipFamily(f,instance)
|
QedgePerSlipFamily(f,instance)
|
||||||
|
@ -985,12 +1041,8 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
index_myFamily = sum(Ntwin(1:f-1_pInt,instance)) ! index in truncated twin system list
|
index_myFamily = sum(Ntwin(1:f-1_pInt,instance)) ! index in truncated twin system list
|
||||||
twinSystemsLoop: do j = 1_pInt,Ntwin(f,instance)
|
twinSystemsLoop: do j = 1_pInt,Ntwin(f,instance)
|
||||||
|
|
||||||
!* Burgers vector,
|
|
||||||
! nucleation rate prefactor,
|
! nucleation rate prefactor,
|
||||||
! and twin size
|
! and twin size
|
||||||
|
|
||||||
burgersPerTwinSystem(index_myFamily+j,instance) = &
|
|
||||||
burgersPerTwinFamily(f,instance)
|
|
||||||
|
|
||||||
Ndot0PerTwinSystem(index_myFamily+j,instance) = &
|
Ndot0PerTwinSystem(index_myFamily+j,instance) = &
|
||||||
Ndot0PerTwinFamily(f,instance)
|
Ndot0PerTwinFamily(f,instance)
|
||||||
|
@ -1047,9 +1099,6 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
! nucleation rate prefactor,
|
! nucleation rate prefactor,
|
||||||
! and martensite size
|
! and martensite size
|
||||||
|
|
||||||
burgersPerTransSystem(index_myFamily+j,instance) = &
|
|
||||||
burgersPerTransFamily(f,instance)
|
|
||||||
|
|
||||||
Ndot0PerTransSystem(index_myFamily+j,instance) = &
|
Ndot0PerTransSystem(index_myFamily+j,instance) = &
|
||||||
Ndot0PerTransFamily(f,instance)
|
Ndot0PerTransFamily(f,instance)
|
||||||
|
|
||||||
|
@ -1113,7 +1162,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
state(instance)%rhoEdge=>plasticState(phase)%state(startIndex:endIndex,:)
|
state(instance)%rhoEdge=>plasticState(phase)%state(startIndex:endIndex,:)
|
||||||
dotState(instance)%rhoEdge=>plasticState(phase)%dotState(startIndex:endIndex,:)
|
dotState(instance)%rhoEdge=>plasticState(phase)%dotState(startIndex:endIndex,:)
|
||||||
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
||||||
spread(math_expand(rhoEdge0(instance,:),Nslip(instance,:)),2,NofMyPhase)
|
spread(math_expand(prm%rho0,Nslip(instance,:)),2,NofMyPhase)
|
||||||
plasticState(phase)%aTolState(startIndex:endIndex) = param(instance)%aTolRho
|
plasticState(phase)%aTolState(startIndex:endIndex) = param(instance)%aTolRho
|
||||||
|
|
||||||
startIndex=endIndex+1
|
startIndex=endIndex+1
|
||||||
|
@ -1121,7 +1170,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
state(instance)%rhoEdgeDip=>plasticState(phase)%state(startIndex:endIndex,:)
|
state(instance)%rhoEdgeDip=>plasticState(phase)%state(startIndex:endIndex,:)
|
||||||
dotState(instance)%rhoEdgeDip=>plasticState(phase)%dotState(startIndex:endIndex,:)
|
dotState(instance)%rhoEdgeDip=>plasticState(phase)%dotState(startIndex:endIndex,:)
|
||||||
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
||||||
spread(math_expand(rhoEdgeDip0(instance,:),Nslip(instance,:)),2,NofMyPhase)
|
spread(math_expand(prm%rhoDip0,Nslip(instance,:)),2,NofMyPhase)
|
||||||
plasticState(phase)%aTolState(startIndex:endIndex) = param(instance)%aTolRho
|
plasticState(phase)%aTolState(startIndex:endIndex) = param(instance)%aTolRho
|
||||||
|
|
||||||
startIndex=endIndex+1
|
startIndex=endIndex+1
|
||||||
|
@ -1159,8 +1208,8 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
state(instance)%invLambdaSlip=>plasticState(phase)%state(startIndex:endIndex,:)
|
state(instance)%invLambdaSlip=>plasticState(phase)%state(startIndex:endIndex,:)
|
||||||
invLambdaSlip0 = spread(0.0_pReal,1,ns)
|
invLambdaSlip0 = spread(0.0_pReal,1,ns)
|
||||||
forall (i = 1_pInt:ns) &
|
forall (i = 1_pInt:ns) &
|
||||||
invLambdaSlip0(i) = sqrt(dot_product(math_expand(rhoEdge0(instance,:),Nslip(instance,:))+ &
|
invLambdaSlip0(i) = sqrt(dot_product(math_expand(prm%rho0,Nslip(instance,:))+ &
|
||||||
math_expand(rhoEdgeDip0(instance,:),Nslip(instance,:)),forestProjectionEdge(1:ns,i,instance)))/ &
|
math_expand(prm%rhoDip0,Nslip(instance,:)),forestProjectionEdge(1:ns,i,instance)))/ &
|
||||||
CLambdaSlipPerSlipSystem(i,instance)
|
CLambdaSlipPerSlipSystem(i,instance)
|
||||||
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
||||||
spread(math_expand(invLambdaSlip0,Nslip(instance,:)),2, NofMyPhase)
|
spread(math_expand(invLambdaSlip0,Nslip(instance,:)),2, NofMyPhase)
|
||||||
|
@ -1208,8 +1257,8 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
state(instance)%threshold_stress_slip=>plasticState(phase)%state(startIndex:endIndex,:)
|
state(instance)%threshold_stress_slip=>plasticState(phase)%state(startIndex:endIndex,:)
|
||||||
tauSlipThreshold0 = spread(0.0_pReal,1,ns)
|
tauSlipThreshold0 = spread(0.0_pReal,1,ns)
|
||||||
forall (i = 1_pInt:ns) tauSlipThreshold0(i) = &
|
forall (i = 1_pInt:ns) tauSlipThreshold0(i) = &
|
||||||
lattice_mu(phase)*burgersPerSlipSystem(i,instance) * &
|
lattice_mu(phase)*prm%burgers_slip(i) * &
|
||||||
sqrt(dot_product(math_expand(rhoEdge0(instance,:) + rhoEdgeDip0(instance,:),Nslip(instance,:)),&
|
sqrt(dot_product(math_expand(prm%rho0 + prm%rhoDip0,Nslip(instance,:)),&
|
||||||
interactionMatrix_SlipSlip(i,1:ns,instance)))
|
interactionMatrix_SlipSlip(i,1:ns,instance)))
|
||||||
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
plasticState(phase)%state0(startIndex:endIndex,:) = &
|
||||||
spread(math_expand(tauSlipThreshold0,Nslip(instance,:)),2, NofMyPhase)
|
spread(math_expand(tauSlipThreshold0,Nslip(instance,:)),2, NofMyPhase)
|
||||||
|
@ -1333,7 +1382,10 @@ subroutine plastic_dislotwin_microstructure(temperature,ipc,ip,el)
|
||||||
real(pReal), dimension(totalNtwin(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: fOverStacksize
|
real(pReal), dimension(totalNtwin(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: fOverStacksize
|
||||||
real(pReal), dimension(totalNtrans(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
real(pReal), dimension(totalNtrans(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
||||||
ftransOverLamellarSize
|
ftransOverLamellarSize
|
||||||
|
|
||||||
|
type(tParameters), pointer :: prm
|
||||||
|
|
||||||
|
|
||||||
!* Shortened notation
|
!* Shortened notation
|
||||||
of = phasememberAt(ipc,ip,el)
|
of = phasememberAt(ipc,ip,el)
|
||||||
ph = phaseAt(ipc,ip,el)
|
ph = phaseAt(ipc,ip,el)
|
||||||
|
@ -1341,7 +1393,7 @@ subroutine plastic_dislotwin_microstructure(temperature,ipc,ip,el)
|
||||||
ns = totalNslip(instance)
|
ns = totalNslip(instance)
|
||||||
nt = totalNtwin(instance)
|
nt = totalNtwin(instance)
|
||||||
nr = totalNtrans(instance)
|
nr = totalNtrans(instance)
|
||||||
|
prm => param(instance)
|
||||||
!* Total twin volume fraction
|
!* Total twin volume fraction
|
||||||
sumf = sum(state(instance)%twinFraction(1_pInt:nt,of)) ! safe for nt == 0
|
sumf = sum(state(instance)%twinFraction(1_pInt:nt,of)) ! safe for nt == 0
|
||||||
|
|
||||||
|
@ -1427,7 +1479,7 @@ subroutine plastic_dislotwin_microstructure(temperature,ipc,ip,el)
|
||||||
!* threshold stress for dislocation motion
|
!* threshold stress for dislocation motion
|
||||||
forall (s = 1_pInt:ns) &
|
forall (s = 1_pInt:ns) &
|
||||||
state(instance)%threshold_stress_slip(s,of) = &
|
state(instance)%threshold_stress_slip(s,of) = &
|
||||||
lattice_mu(ph)*burgersPerSlipSystem(s,instance)*&
|
lattice_mu(ph)*prm%burgers_slip(s)*&
|
||||||
sqrt(dot_product((state(instance)%rhoEdge(1_pInt:ns,of)+state(instance)%rhoEdgeDip(1_pInt:ns,of)),&
|
sqrt(dot_product((state(instance)%rhoEdge(1_pInt:ns,of)+state(instance)%rhoEdgeDip(1_pInt:ns,of)),&
|
||||||
interactionMatrix_SlipSlip(s,1:ns,instance)))
|
interactionMatrix_SlipSlip(s,1:ns,instance)))
|
||||||
|
|
||||||
|
@ -1435,27 +1487,27 @@ subroutine plastic_dislotwin_microstructure(temperature,ipc,ip,el)
|
||||||
forall (t = 1_pInt:nt) &
|
forall (t = 1_pInt:nt) &
|
||||||
state(instance)%threshold_stress_twin(t,of) = &
|
state(instance)%threshold_stress_twin(t,of) = &
|
||||||
param(instance)%Cthresholdtwin* &
|
param(instance)%Cthresholdtwin* &
|
||||||
(sfe/(3.0_pReal*burgersPerTwinSystem(t,instance)) &
|
(sfe/(3.0_pReal**prm%burgers_twin(t)) &
|
||||||
+ 3.0_pReal*burgersPerTwinSystem(t,instance)*lattice_mu(ph)/&
|
+ 3.0_pReal*prm%burgers_twin(t)*lattice_mu(ph)/&
|
||||||
(param(instance)%L0_twin*burgersPerSlipSystem(t,instance)) &
|
(param(instance)%L0_twin*prm%burgers_slip(t)) &
|
||||||
)
|
)
|
||||||
|
|
||||||
!* threshold stress for growing martensite
|
!* threshold stress for growing martensite
|
||||||
forall (r = 1_pInt:nr) &
|
forall (r = 1_pInt:nr) &
|
||||||
state(instance)%threshold_stress_trans(r,of) = &
|
state(instance)%threshold_stress_trans(r,of) = &
|
||||||
param(instance)%Cthresholdtrans* &
|
param(instance)%Cthresholdtrans* &
|
||||||
(sfe/(3.0_pReal*burgersPerTransSystem(r,instance)) &
|
(sfe/(3.0_pReal*prm%burgers_trans(r)) &
|
||||||
+ 3.0_pReal*burgersPerTransSystem(r,instance)*lattice_mu(ph)/&
|
+ 3.0_pReal*prm%burgers_trans(r)*lattice_mu(ph)/&
|
||||||
(param(instance)%L0_trans*burgersPerSlipSystem(r,instance))&
|
(param(instance)%L0_trans*prm%burgers_slip(r))&
|
||||||
+ param(instance)%transStackHeight*param(instance)%deltaG/ &
|
+ param(instance)%transStackHeight*param(instance)%deltaG/ &
|
||||||
(3.0_pReal*burgersPerTransSystem(r,instance)) &
|
(3.0_pReal*prm%burgers_trans(r)) &
|
||||||
)
|
)
|
||||||
|
|
||||||
!* final twin volume after growth
|
!* final twin volume after growth
|
||||||
forall (t = 1_pInt:nt) &
|
forall (t = 1_pInt:nt) &
|
||||||
state(instance)%twinVolume(t,of) = &
|
state(instance)%twinVolume(t,of) = &
|
||||||
(pi/4.0_pReal)*twinsizePerTwinSystem(t,instance)*&
|
(pi/4.0_pReal)*twinsizePerTwinSystem(t,instance)*&
|
||||||
state(instance)%mfp_twin(t,of)**(2.0_pReal)
|
state(instance)%mfp_twin(t,of)**2.0_pReal
|
||||||
|
|
||||||
!* final martensite volume after growth
|
!* final martensite volume after growth
|
||||||
forall (r = 1_pInt:nr) &
|
forall (r = 1_pInt:nr) &
|
||||||
|
@ -1465,19 +1517,19 @@ subroutine plastic_dislotwin_microstructure(temperature,ipc,ip,el)
|
||||||
|
|
||||||
!* equilibrium separation of partial dislocations (twin)
|
!* equilibrium separation of partial dislocations (twin)
|
||||||
do t = 1_pInt,nt
|
do t = 1_pInt,nt
|
||||||
x0 = lattice_mu(ph)*burgersPerTwinSystem(t,instance)**(2.0_pReal)/&
|
x0 = lattice_mu(ph)*prm%burgers_twin(t)**(2.0_pReal)/&
|
||||||
(sfe*8.0_pReal*pi)*(2.0_pReal+lattice_nu(ph))/(1.0_pReal-lattice_nu(ph))
|
(sfe*8.0_pReal*pi)*(2.0_pReal+lattice_nu(ph))/(1.0_pReal-lattice_nu(ph))
|
||||||
tau_r_twin(t,instance)= &
|
tau_r_twin(t,instance)= &
|
||||||
lattice_mu(ph)*burgersPerTwinSystem(t,instance)/(2.0_pReal*pi)*&
|
lattice_mu(ph)*prm%burgers_twin(t)/(2.0_pReal*pi)*&
|
||||||
(1/(x0+param(instance)%xc_twin)+cos(pi/3.0_pReal)/x0)
|
(1/(x0+param(instance)%xc_twin)+cos(pi/3.0_pReal)/x0)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
!* equilibrium separation of partial dislocations (trans)
|
!* equilibrium separation of partial dislocations (trans)
|
||||||
do r = 1_pInt,nr
|
do r = 1_pInt,nr
|
||||||
x0 = lattice_mu(ph)*burgersPerTransSystem(r,instance)**(2.0_pReal)/&
|
x0 = lattice_mu(ph)*prm%burgers_trans(r)**(2.0_pReal)/&
|
||||||
(sfe*8.0_pReal*pi)*(2.0_pReal+lattice_nu(ph))/(1.0_pReal-lattice_nu(ph))
|
(sfe*8.0_pReal*pi)*(2.0_pReal+lattice_nu(ph))/(1.0_pReal-lattice_nu(ph))
|
||||||
tau_r_trans(r,instance)= &
|
tau_r_trans(r,instance)= &
|
||||||
lattice_mu(ph)*burgersPerTransSystem(r,instance)/(2.0_pReal*pi)*&
|
lattice_mu(ph)*prm%burgers_trans(r)/(2.0_pReal*pi)*&
|
||||||
(1/(x0+param(instance)%xc_trans)+cos(pi/3.0_pReal)/x0)
|
(1/(x0+param(instance)%xc_trans)+cos(pi/3.0_pReal)/x0)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
@ -1561,6 +1613,9 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
0, 1,-1, &
|
0, 1,-1, &
|
||||||
0, 1, 1 &
|
0, 1, 1 &
|
||||||
],pReal),[ 3,6])
|
],pReal),[ 3,6])
|
||||||
|
|
||||||
|
type(tParameters), pointer :: prm
|
||||||
|
|
||||||
!* Shortened notation
|
!* Shortened notation
|
||||||
of = phasememberAt(ipc,ip,el)
|
of = phasememberAt(ipc,ip,el)
|
||||||
ph = phaseAt(ipc,ip,el)
|
ph = phaseAt(ipc,ip,el)
|
||||||
|
@ -1571,7 +1626,9 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
|
|
||||||
Lp = 0.0_pReal
|
Lp = 0.0_pReal
|
||||||
dLp_dTstar3333 = 0.0_pReal
|
dLp_dTstar3333 = 0.0_pReal
|
||||||
|
|
||||||
|
|
||||||
|
prm => param(instance)
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! Dislocation glide part
|
! Dislocation glide part
|
||||||
gdot_slip = 0.0_pReal
|
gdot_slip = 0.0_pReal
|
||||||
|
@ -1596,7 +1653,7 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
||||||
!* Initial shear rates
|
!* Initial shear rates
|
||||||
DotGamma0 = &
|
DotGamma0 = &
|
||||||
state(instance)%rhoEdge(j,of)*burgersPerSlipSystem(j,instance)*&
|
state(instance)%rhoEdge(j,of)*prm%burgers_slip(j)*&
|
||||||
v0PerSlipSystem(j,instance)
|
v0PerSlipSystem(j,instance)
|
||||||
|
|
||||||
!* Shear rates due to slip
|
!* Shear rates due to slip
|
||||||
|
@ -1715,7 +1772,7 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
if (tau_twin(j) < tau_r_twin(j,instance)) then
|
if (tau_twin(j) < tau_r_twin(j,instance)) then
|
||||||
Ndot0_twin=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(ph)%rhoEdgeDip(s2,of))+& !!!!! correct?
|
Ndot0_twin=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(ph)%rhoEdgeDip(s2,of))+& !!!!! correct?
|
||||||
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
||||||
(param(instance)%L0_twin*burgersPerSlipSystem(j,instance))*&
|
(param(instance)%L0_twin*prm%burgers_slip(j))*&
|
||||||
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
||||||
(tau_r_twin(j,instance)-tau_twin(j))))
|
(tau_r_twin(j,instance)-tau_twin(j))))
|
||||||
else
|
else
|
||||||
|
@ -1765,7 +1822,7 @@ subroutine plastic_dislotwin_LpAndItsTangent(Lp,dLp_dTstar99,Tstar_v,Temperature
|
||||||
if (tau_trans(j) < tau_r_trans(j,instance)) then
|
if (tau_trans(j) < tau_r_trans(j,instance)) then
|
||||||
Ndot0_trans=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+& !!!!! correct?
|
Ndot0_trans=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+& !!!!! correct?
|
||||||
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
||||||
(param(instance)%L0_trans*burgersPerSlipSystem(j,instance))*&
|
(param(instance)%L0_trans*prm%burgers_slip(j))*&
|
||||||
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
||||||
(tau_r_trans(j,instance)-tau_trans(j))))
|
(tau_r_trans(j,instance)-tau_trans(j))))
|
||||||
else
|
else
|
||||||
|
@ -1855,6 +1912,8 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
real(pReal), dimension(totalNtrans(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
real(pReal), dimension(totalNtrans(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
||||||
tau_trans
|
tau_trans
|
||||||
|
|
||||||
|
type(tParameters), pointer :: prm
|
||||||
|
|
||||||
!* Shortened notation
|
!* Shortened notation
|
||||||
of = phasememberAt(ipc,ip,el)
|
of = phasememberAt(ipc,ip,el)
|
||||||
ph = phaseAt(ipc,ip,el)
|
ph = phaseAt(ipc,ip,el)
|
||||||
|
@ -1862,7 +1921,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
ns = totalNslip(instance)
|
ns = totalNslip(instance)
|
||||||
nt = totalNtwin(instance)
|
nt = totalNtwin(instance)
|
||||||
nr = totalNtrans(instance)
|
nr = totalNtrans(instance)
|
||||||
|
prm => param(instance)
|
||||||
!* Total twin volume fraction
|
!* Total twin volume fraction
|
||||||
sumf = sum(state(instance)%twinFraction(1_pInt:nt,of)) ! safe for nt == 0
|
sumf = sum(state(instance)%twinFraction(1_pInt:nt,of)) ! safe for nt == 0
|
||||||
plasticState(ph)%dotState(:,of) = 0.0_pReal
|
plasticState(ph)%dotState(:,of) = 0.0_pReal
|
||||||
|
@ -1892,7 +1951,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
||||||
!* Initial shear rates
|
!* Initial shear rates
|
||||||
DotGamma0 = &
|
DotGamma0 = &
|
||||||
plasticState(ph)%state(j, of)*burgersPerSlipSystem(j,instance)*&
|
plasticState(ph)%state(j, of)*prm%burgers_slip(j)*&
|
||||||
v0PerSlipSystem(j,instance)
|
v0PerSlipSystem(j,instance)
|
||||||
|
|
||||||
!* Shear rates due to slip
|
!* Shear rates due to slip
|
||||||
|
@ -1901,36 +1960,36 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
endif
|
endif
|
||||||
!* Multiplication
|
!* Multiplication
|
||||||
DotRhoMultiplication = abs(gdot_slip(j))/&
|
DotRhoMultiplication = abs(gdot_slip(j))/&
|
||||||
(burgersPerSlipSystem(j,instance)*state(instance)%mfp_slip(j,of))
|
(prm%burgers_slip(j)*state(instance)%mfp_slip(j,of))
|
||||||
!* Dipole formation
|
!* Dipole formation
|
||||||
EdgeDipMinDistance = &
|
EdgeDipMinDistance = &
|
||||||
param(instance)%CEdgeDipMinDistance*burgersPerSlipSystem(j,instance)
|
param(instance)%CEdgeDipMinDistance*prm%burgers_slip(j)
|
||||||
if (dEq0(tau_slip(j))) then
|
if (dEq0(tau_slip(j))) then
|
||||||
DotRhoDipFormation = 0.0_pReal
|
DotRhoDipFormation = 0.0_pReal
|
||||||
else
|
else
|
||||||
EdgeDipDistance = &
|
EdgeDipDistance = &
|
||||||
(3.0_pReal*lattice_mu(ph)*burgersPerSlipSystem(j,instance))/&
|
(3.0_pReal*lattice_mu(ph)*prm%burgers_slip(j))/&
|
||||||
(16.0_pReal*pi*abs(tau_slip(j)))
|
(16.0_pReal*pi*abs(tau_slip(j)))
|
||||||
if (EdgeDipDistance>state(instance)%mfp_slip(j,of)) EdgeDipDistance=state(instance)%mfp_slip(j,of)
|
if (EdgeDipDistance>state(instance)%mfp_slip(j,of)) EdgeDipDistance=state(instance)%mfp_slip(j,of)
|
||||||
if (EdgeDipDistance<EdgeDipMinDistance) EdgeDipDistance=EdgeDipMinDistance
|
if (EdgeDipDistance<EdgeDipMinDistance) EdgeDipDistance=EdgeDipMinDistance
|
||||||
DotRhoDipFormation = &
|
DotRhoDipFormation = &
|
||||||
((2.0_pReal*(EdgeDipDistance-EdgeDipMinDistance))/burgersPerSlipSystem(j,instance))*&
|
((2.0_pReal*(EdgeDipDistance-EdgeDipMinDistance))/prm%burgers_slip(j))*&
|
||||||
state(instance)%rhoEdge(j,of)*abs(gdot_slip(j))*param(instance)%dipoleFormationFactor
|
state(instance)%rhoEdge(j,of)*abs(gdot_slip(j))*param(instance)%dipoleFormationFactor
|
||||||
endif
|
endif
|
||||||
|
|
||||||
!* Spontaneous annihilation of 2 single edge dislocations
|
!* Spontaneous annihilation of 2 single edge dislocations
|
||||||
DotRhoEdgeEdgeAnnihilation = &
|
DotRhoEdgeEdgeAnnihilation = &
|
||||||
((2.0_pReal*EdgeDipMinDistance)/burgersPerSlipSystem(j,instance))*&
|
((2.0_pReal*EdgeDipMinDistance)/prm%burgers_slip(j))*&
|
||||||
state(instance)%rhoEdge(j,of)*abs(gdot_slip(j))
|
state(instance)%rhoEdge(j,of)*abs(gdot_slip(j))
|
||||||
|
|
||||||
!* Spontaneous annihilation of a single edge dislocation with a dipole constituent
|
!* Spontaneous annihilation of a single edge dislocation with a dipole constituent
|
||||||
DotRhoEdgeDipAnnihilation = &
|
DotRhoEdgeDipAnnihilation = &
|
||||||
((2.0_pReal*EdgeDipMinDistance)/burgersPerSlipSystem(j,instance))*&
|
((2.0_pReal*EdgeDipMinDistance)/prm%burgers_slip(j))*&
|
||||||
state(instance)%rhoEdgeDip(j,of)*abs(gdot_slip(j))
|
state(instance)%rhoEdgeDip(j,of)*abs(gdot_slip(j))
|
||||||
|
|
||||||
!* Dislocation dipole climb
|
!* Dislocation dipole climb
|
||||||
AtomicVolume = &
|
AtomicVolume = &
|
||||||
param(instance)%CAtomicVolume*burgersPerSlipSystem(j,instance)**(3.0_pReal)
|
param(instance)%CAtomicVolume*prm%burgers_slip(j)**(3.0_pReal)
|
||||||
VacancyDiffusion = &
|
VacancyDiffusion = &
|
||||||
param(instance)%D0*exp(-param(instance)%Qsd/(kB*Temperature))
|
param(instance)%D0*exp(-param(instance)%Qsd/(kB*Temperature))
|
||||||
if (dEq0(tau_slip(j))) then
|
if (dEq0(tau_slip(j))) then
|
||||||
|
@ -1981,7 +2040,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
if (tau_twin(j) < tau_r_twin(j,instance)) then
|
if (tau_twin(j) < tau_r_twin(j,instance)) then
|
||||||
Ndot0_twin=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+&
|
Ndot0_twin=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+&
|
||||||
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
||||||
(param(instance)%L0_twin*burgersPerSlipSystem(j,instance))*&
|
(param(instance)%L0_twin*prm%burgers_slip(j))*&
|
||||||
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
||||||
(tau_r_twin(j,instance)-tau_twin(j))))
|
(tau_r_twin(j,instance)-tau_twin(j))))
|
||||||
else
|
else
|
||||||
|
@ -2022,7 +2081,7 @@ subroutine plastic_dislotwin_dotState(Tstar_v,Temperature,ipc,ip,el)
|
||||||
if (tau_trans(j) < tau_r_trans(j,instance)) then
|
if (tau_trans(j) < tau_r_trans(j,instance)) then
|
||||||
Ndot0_trans=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+&
|
Ndot0_trans=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+&
|
||||||
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
||||||
(param(instance)%L0_trans*burgersPerSlipSystem(j,instance))*&
|
(param(instance)%L0_trans*prm%burgers_slip(j))*&
|
||||||
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
||||||
(tau_r_trans(j,instance)-tau_trans(j))))
|
(tau_r_trans(j,instance)-tau_trans(j))))
|
||||||
else
|
else
|
||||||
|
@ -2101,6 +2160,8 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
real(pReal), dimension(3,3) :: eigVectors
|
real(pReal), dimension(3,3) :: eigVectors
|
||||||
real(pReal), dimension (3) :: eigValues
|
real(pReal), dimension (3) :: eigValues
|
||||||
|
|
||||||
|
type(tParameters), pointer :: prm
|
||||||
|
|
||||||
!* Shortened notation
|
!* Shortened notation
|
||||||
of = phasememberAt(ipc,ip,el)
|
of = phasememberAt(ipc,ip,el)
|
||||||
ph = phaseAt(ipc,ip,el)
|
ph = phaseAt(ipc,ip,el)
|
||||||
|
@ -2109,6 +2170,7 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
nt = totalNtwin(instance)
|
nt = totalNtwin(instance)
|
||||||
nr = totalNtrans(instance)
|
nr = totalNtrans(instance)
|
||||||
|
|
||||||
|
prm => param(instance)
|
||||||
!* Total twin volume fraction
|
!* Total twin volume fraction
|
||||||
sumf = sum(state(instance)%twinFraction(1_pInt:nt,of)) ! safe for nt == 0
|
sumf = sum(state(instance)%twinFraction(1_pInt:nt,of)) ! safe for nt == 0
|
||||||
|
|
||||||
|
@ -2145,7 +2207,7 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
||||||
!* Initial shear rates
|
!* Initial shear rates
|
||||||
DotGamma0 = &
|
DotGamma0 = &
|
||||||
state(instance)%rhoEdge(j,of)*burgersPerSlipSystem(j,instance)* &
|
state(instance)%rhoEdge(j,of)*prm%burgers_slip(j)* &
|
||||||
v0PerSlipSystem(j,instance)
|
v0PerSlipSystem(j,instance)
|
||||||
|
|
||||||
!* Shear rates due to slip
|
!* Shear rates due to slip
|
||||||
|
@ -2187,7 +2249,7 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
do i = 1_pInt,Nslip(f,instance) ! process each (active) slip system in family
|
do i = 1_pInt,Nslip(f,instance) ! process each (active) slip system in family
|
||||||
j = j + 1_pInt
|
j = j + 1_pInt
|
||||||
plastic_dislotwin_postResults(c+j) = &
|
plastic_dislotwin_postResults(c+j) = &
|
||||||
(3.0_pReal*lattice_mu(ph)*burgersPerSlipSystem(j,instance))/&
|
(3.0_pReal*lattice_mu(ph)*prm%burgers_slip(j))/&
|
||||||
(16.0_pReal*pi*abs(dot_product(Tstar_v,lattice_Sslip_v(:,1,index_myFamily+i,ph))))
|
(16.0_pReal*pi*abs(dot_product(Tstar_v,lattice_Sslip_v(:,1,index_myFamily+i,ph))))
|
||||||
plastic_dislotwin_postResults(c+j)=min(plastic_dislotwin_postResults(c+j),&
|
plastic_dislotwin_postResults(c+j)=min(plastic_dislotwin_postResults(c+j),&
|
||||||
state(instance)%mfp_slip(j,of))
|
state(instance)%mfp_slip(j,of))
|
||||||
|
@ -2254,7 +2316,7 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
||||||
!* Initial shear rates
|
!* Initial shear rates
|
||||||
DotGamma0 = &
|
DotGamma0 = &
|
||||||
state(instance)%rhoEdge(j,of)*burgersPerSlipSystem(j,instance)* &
|
state(instance)%rhoEdge(j,of)*prm%burgers_slip(j)* &
|
||||||
v0PerSlipSystem(j,instance)
|
v0PerSlipSystem(j,instance)
|
||||||
|
|
||||||
!* Shear rates due to slip
|
!* Shear rates due to slip
|
||||||
|
@ -2284,7 +2346,7 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
Ndot0_twin=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+&
|
Ndot0_twin=(abs(gdot_slip(s1))*(state(instance)%rhoEdge(s2,of)+state(instance)%rhoEdgeDip(s2,of))+&
|
||||||
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
abs(gdot_slip(s2))*(state(instance)%rhoEdge(s1,of)+state(instance)%rhoEdgeDip(s1,of)))/&
|
||||||
(param(instance)%L0_twin*&
|
(param(instance)%L0_twin*&
|
||||||
burgersPerSlipSystem(j,instance))*&
|
prm%burgers_slip(j))*&
|
||||||
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
(1.0_pReal-exp(-param(instance)%VcrossSlip/(kB*Temperature)*&
|
||||||
(tau_r_twin(j,instance)-tau)))
|
(tau_r_twin(j,instance)-tau)))
|
||||||
else
|
else
|
||||||
|
@ -2346,7 +2408,7 @@ function plastic_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
||||||
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
BoltzmannRatio = QedgePerSlipSystem(j,instance)/(kB*Temperature)
|
||||||
!* Initial shear rates
|
!* Initial shear rates
|
||||||
DotGamma0 = &
|
DotGamma0 = &
|
||||||
state(instance)%rhoEdge(j,of)*burgersPerSlipSystem(j,instance)* &
|
state(instance)%rhoEdge(j,of)*prm%burgers_slip(j)* &
|
||||||
v0PerSlipSystem(j,instance)
|
v0PerSlipSystem(j,instance)
|
||||||
|
|
||||||
!* Shear rates due to slip
|
!* Shear rates due to slip
|
||||||
|
|
Loading…
Reference in New Issue