TRIP input parameters for fcc to hex
This commit is contained in:
parent
1e9682eef9
commit
d2c748e716
|
@ -82,10 +82,13 @@ module plastic_dislotwin
|
||||||
plastic_dislotwin_aTolRho, & !< absolute tolerance for integration of dislocation density
|
plastic_dislotwin_aTolRho, & !< absolute tolerance for integration of dislocation density
|
||||||
plastic_dislotwin_aTolTwinFrac, & !< absolute tolerance for integration of twin volume fraction
|
plastic_dislotwin_aTolTwinFrac, & !< absolute tolerance for integration of twin volume fraction
|
||||||
plastic_dislotwin_aTolTransFrac, & !< absolute tolerance for integration of trans volume fraction
|
plastic_dislotwin_aTolTransFrac, & !< absolute tolerance for integration of trans volume fraction
|
||||||
plastic_dislotwin_Cdwp, & !< Coefficient for double well potential
|
plastic_dislotwin_Cdwp, & !< Coefficient for double well potential (fcc to bcc transformation)
|
||||||
plastic_dislotwin_Cnuc, & !< Coefficient for strain-induced martensite nucleation
|
plastic_dislotwin_Cnuc, & !< Coefficient for strain-induced martensite nucleation (fcc to bcc transformation)
|
||||||
plastic_dislotwin_Cgro, & !< Coefficient for stress-assisted martensite growth
|
plastic_dislotwin_Cgro, & !< Coefficient for stress-assisted martensite growth (fcc to bcc transformation)
|
||||||
plastic_dislotwin_deltaG !< Free energy difference between austensite and martensite [MPa]
|
plastic_dislotwin_deltaG, & !< Free energy difference between austensite and martensite
|
||||||
|
plastic_dislotwin_Cmfptrans, & !<
|
||||||
|
plastic_dislotwin_Cthresholdtrans, & !<
|
||||||
|
plastic_dislotwin_transStackHeight !< Stack height of hex nucleus
|
||||||
|
|
||||||
real(pReal), dimension(:,:,:,:), allocatable, private :: &
|
real(pReal), dimension(:,:,:,:), allocatable, private :: &
|
||||||
plastic_dislotwin_Ctwin66 !< twin elasticity matrix in Mandel notation for each instance
|
plastic_dislotwin_Ctwin66 !< twin elasticity matrix in Mandel notation for each instance
|
||||||
|
@ -102,6 +105,8 @@ module plastic_dislotwin
|
||||||
plastic_dislotwin_burgersPerSlipSystem, & !< absolute length of burgers vector [m] for each slip system and instance
|
plastic_dislotwin_burgersPerSlipSystem, & !< absolute length of burgers vector [m] for each slip system and instance
|
||||||
plastic_dislotwin_burgersPerTwinFamily, & !< absolute length of burgers vector [m] for each twin family and instance
|
plastic_dislotwin_burgersPerTwinFamily, & !< absolute length of burgers vector [m] for each twin family and instance
|
||||||
plastic_dislotwin_burgersPerTwinSystem, & !< absolute length of burgers vector [m] for each twin system and instance
|
plastic_dislotwin_burgersPerTwinSystem, & !< absolute length of burgers vector [m] for each twin system and instance
|
||||||
|
plastic_dislotwin_burgersPerTransFamily, & !< absolute length of burgers vector [m] for each trans family and instance
|
||||||
|
plastic_dislotwin_burgersPerTransSystem, & !< absolute length of burgers vector [m] for each trans system and instance
|
||||||
plastic_dislotwin_QedgePerSlipFamily, & !< activation energy for glide [J] for each slip family and instance
|
plastic_dislotwin_QedgePerSlipFamily, & !< activation energy for glide [J] for each slip family and instance
|
||||||
plastic_dislotwin_QedgePerSlipSystem, & !< activation energy for glide [J] for each slip system and instance
|
plastic_dislotwin_QedgePerSlipSystem, & !< activation energy for glide [J] for each slip system and instance
|
||||||
plastic_dislotwin_v0PerSlipFamily, & !< dislocation velocity prefactor [m/s] for each family and instance
|
plastic_dislotwin_v0PerSlipFamily, & !< dislocation velocity prefactor [m/s] for each family and instance
|
||||||
|
@ -122,7 +127,8 @@ module plastic_dislotwin
|
||||||
plastic_dislotwin_interaction_TwinTwin, & !< coefficients for twin-twin interaction for each interaction type and instance
|
plastic_dislotwin_interaction_TwinTwin, & !< coefficients for twin-twin interaction for each interaction type and instance
|
||||||
plastic_dislotwin_pPerSlipFamily, & !< p-exponent in glide velocity
|
plastic_dislotwin_pPerSlipFamily, & !< p-exponent in glide velocity
|
||||||
plastic_dislotwin_qPerSlipFamily, & !< q-exponent in glide velocity
|
plastic_dislotwin_qPerSlipFamily, & !< q-exponent in glide velocity
|
||||||
plastic_dislotwin_rPerTwinFamily !< r-exponent in twin nucleation rate
|
plastic_dislotwin_rPerTwinFamily, & !< r-exponent in twin nucleation rate
|
||||||
|
plastic_dislotwin_sPerTransFamily !< s-exponent in trans nucleation rate
|
||||||
real(pReal), dimension(:,:,:), allocatable, private :: &
|
real(pReal), dimension(:,:,:), allocatable, private :: &
|
||||||
plastic_dislotwin_interactionMatrix_SlipSlip, & !< interaction matrix of the different slip systems for each instance
|
plastic_dislotwin_interactionMatrix_SlipSlip, & !< interaction matrix of the different slip systems for each instance
|
||||||
plastic_dislotwin_interactionMatrix_SlipTwin, & !< interaction matrix of slip systems with twin systems for each instance
|
plastic_dislotwin_interactionMatrix_SlipTwin, & !< interaction matrix of slip systems with twin systems for each instance
|
||||||
|
@ -292,12 +298,17 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
allocate(plastic_dislotwin_Cnuc(maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_Cnuc(maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_Cgro(maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_Cgro(maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_deltaG(maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_deltaG(maxNinstance), source=0.0_pReal)
|
||||||
|
allocate(plastic_dislotwin_Cmfptrans(maxNinstance), source=0.0_pReal)
|
||||||
|
allocate(plastic_dislotwin_Cthresholdtrans(maxNinstance), source=0.0_pReal)
|
||||||
|
allocate(plastic_dislotwin_transStackHeight(maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_rhoEdge0(lattice_maxNslipFamily,maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_rhoEdge0(lattice_maxNslipFamily,maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_rhoEdgeDip0(lattice_maxNslipFamily,maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_rhoEdgeDip0(lattice_maxNslipFamily,maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_burgersPerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
allocate(plastic_dislotwin_burgersPerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_burgersPerTwinFamily(lattice_maxNtwinFamily,maxNinstance), &
|
allocate(plastic_dislotwin_burgersPerTwinFamily(lattice_maxNtwinFamily,maxNinstance), &
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
|
allocate(plastic_dislotwin_burgersPerTransFamily(lattice_maxNtransFamily,maxNinstance), &
|
||||||
|
source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_QedgePerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
allocate(plastic_dislotwin_QedgePerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_v0PerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
allocate(plastic_dislotwin_v0PerSlipFamily(lattice_maxNslipFamily,maxNinstance), &
|
||||||
|
@ -325,6 +336,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_lamellarsizePerTransFamily(lattice_maxNtransFamily,maxNinstance), &
|
allocate(plastic_dislotwin_lamellarsizePerTransFamily(lattice_maxNtransFamily,maxNinstance), &
|
||||||
source=0.0_pReal)
|
source=0.0_pReal)
|
||||||
|
allocate(plastic_dislotwin_sPerTransFamily(lattice_maxNtransFamily,maxNinstance),source=0.0_pReal)
|
||||||
|
|
||||||
|
|
||||||
rewind(fileUnit)
|
rewind(fileUnit)
|
||||||
|
@ -553,11 +565,18 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
do j = 1_pInt, Nchunks_TransFamilies
|
do j = 1_pInt, Nchunks_TransFamilies
|
||||||
plastic_dislotwin_Ntrans(j,instance) = IO_intValue(line,positions,1_pInt+j)
|
plastic_dislotwin_Ntrans(j,instance) = IO_intValue(line,positions,1_pInt+j)
|
||||||
enddo
|
enddo
|
||||||
case ('lamellarsize')
|
case ('lamellarsize','transburgers','s_trans')
|
||||||
do j = 1_pInt, Nchunks_TransFamilies
|
do j = 1_pInt, Nchunks_TransFamilies
|
||||||
tempPerTrans(j) = IO_floatValue(line,positions,1_pInt+j)
|
tempPerTrans(j) = IO_floatValue(line,positions,1_pInt+j)
|
||||||
enddo
|
enddo
|
||||||
plastic_dislotwin_lamellarsizePerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
select case(tag)
|
||||||
|
case ('lamellarsize')
|
||||||
|
plastic_dislotwin_lamellarsizePerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
||||||
|
case ('transburgers')
|
||||||
|
plastic_dislotwin_burgersPerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
||||||
|
case ('s_trans')
|
||||||
|
plastic_dislotwin_sPerTransFamily(1:Nchunks_TransFamilies,instance) = tempPerTrans(1:Nchunks_TransFamilies)
|
||||||
|
end select
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! parameters depending on number of interactions
|
! parameters depending on number of interactions
|
||||||
case ('interaction_slipslip','interactionslipslip')
|
case ('interaction_slipslip','interactionslipslip')
|
||||||
|
@ -585,7 +604,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
plastic_dislotwin_interaction_TwinTwin(j,instance) = IO_floatValue(line,positions,1_pInt+j)
|
plastic_dislotwin_interaction_TwinTwin(j,instance) = IO_floatValue(line,positions,1_pInt+j)
|
||||||
enddo
|
enddo
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! parameters independent of number of slip/twin systems
|
! parameters independent of number of slip/twin/trans systems
|
||||||
case ('grainsize')
|
case ('grainsize')
|
||||||
plastic_dislotwin_GrainSize(instance) = IO_floatValue(line,positions,2_pInt)
|
plastic_dislotwin_GrainSize(instance) = IO_floatValue(line,positions,2_pInt)
|
||||||
case ('maxtwinfraction')
|
case ('maxtwinfraction')
|
||||||
|
@ -640,6 +659,12 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
plastic_dislotwin_Cgro(instance) = IO_floatValue(line,positions,2_pInt)
|
plastic_dislotwin_Cgro(instance) = IO_floatValue(line,positions,2_pInt)
|
||||||
case ('deltag')
|
case ('deltag')
|
||||||
plastic_dislotwin_deltaG(instance) = IO_floatValue(line,positions,2_pInt)
|
plastic_dislotwin_deltaG(instance) = IO_floatValue(line,positions,2_pInt)
|
||||||
|
case ('cmfptrans')
|
||||||
|
plastic_dislotwin_Cmfptrans(instance) = IO_floatValue(line,positions,2_pInt)
|
||||||
|
case ('cthresholdtrans')
|
||||||
|
plastic_dislotwin_Cthresholdtrans(instance) = IO_floatValue(line,positions,2_pInt)
|
||||||
|
case ('transstackheight')
|
||||||
|
plastic_dislotwin_transStackHeight(instance) = IO_floatValue(line,positions,2_pInt)
|
||||||
end select
|
end select
|
||||||
endif; endif
|
endif; endif
|
||||||
enddo parsingFile
|
enddo parsingFile
|
||||||
|
@ -739,6 +764,7 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
|
|
||||||
allocate(plastic_dislotwin_burgersPerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_burgersPerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_burgersPerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_burgersPerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
||||||
|
allocate(plastic_dislotwin_burgersPerTransSystem(maxTotalNtrans, maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_QedgePerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_QedgePerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_v0PerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_v0PerSlipSystem(maxTotalNslip, maxNinstance), source=0.0_pReal)
|
||||||
allocate(plastic_dislotwin_Ndot0PerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
allocate(plastic_dislotwin_Ndot0PerTwinSystem(maxTotalNtwin, maxNinstance), source=0.0_pReal)
|
||||||
|
@ -980,6 +1006,10 @@ subroutine plastic_dislotwin_init(fileUnit)
|
||||||
plastic_dislotwin_lamellarsizePerTransSystem(index_myFamily+j,instance) = &
|
plastic_dislotwin_lamellarsizePerTransSystem(index_myFamily+j,instance) = &
|
||||||
plastic_dislotwin_lamellarsizePerTransFamily(f,instance)
|
plastic_dislotwin_lamellarsizePerTransFamily(f,instance)
|
||||||
|
|
||||||
|
! Burgers vector for transformation system
|
||||||
|
plastic_dislotwin_burgersPerTransSystem(index_myFamily+j,instance) = &
|
||||||
|
plastic_dislotwin_burgersPerTransFamily(f,instance)
|
||||||
|
|
||||||
!* Rotate trans elasticity matrices
|
!* Rotate trans elasticity matrices
|
||||||
index_otherFamily = sum(lattice_NtransSystem(1:f-1_pInt,phase)) ! index in full lattice trans list
|
index_otherFamily = sum(lattice_NtransSystem(1:f-1_pInt,phase)) ! index in full lattice trans list
|
||||||
do l = 1_pInt,3_pInt; do m = 1_pInt,3_pInt; do n = 1_pInt,3_pInt; do o = 1_pInt,3_pInt
|
do l = 1_pInt,3_pInt; do m = 1_pInt,3_pInt; do n = 1_pInt,3_pInt; do o = 1_pInt,3_pInt
|
||||||
|
|
Loading…
Reference in New Issue