final enum removal for plastic laws
This commit is contained in:
parent
b1780e71c8
commit
7311d50df7
|
@ -48,32 +48,6 @@ submodule(constitutive) plastic_nonlocal
|
||||||
real(pReal), dimension(:,:,:,:,:,:), allocatable :: &
|
real(pReal), dimension(:,:,:,:,:,:), allocatable :: &
|
||||||
compatibility !< slip system compatibility between me and my neighbors
|
compatibility !< slip system compatibility between me and my neighbors
|
||||||
|
|
||||||
enum, bind(c)
|
|
||||||
enumerator :: &
|
|
||||||
undefined_ID, &
|
|
||||||
rho_sgl_mob_edg_pos_ID, &
|
|
||||||
rho_sgl_mob_edg_neg_ID, &
|
|
||||||
rho_sgl_mob_scr_pos_ID, &
|
|
||||||
rho_sgl_mob_scr_neg_ID, &
|
|
||||||
rho_sgl_imm_edg_pos_ID, &
|
|
||||||
rho_sgl_imm_edg_neg_ID, &
|
|
||||||
rho_sgl_imm_scr_pos_ID, &
|
|
||||||
rho_sgl_imm_scr_neg_ID, &
|
|
||||||
rho_dip_edg_ID, &
|
|
||||||
rho_dip_scr_ID, &
|
|
||||||
rho_forest_ID, &
|
|
||||||
resolvedstress_back_ID, &
|
|
||||||
tau_pass_ID, &
|
|
||||||
rho_dot_sgl_ID, &
|
|
||||||
rho_dot_sgl_mobile_ID, &
|
|
||||||
rho_dot_dip_ID, &
|
|
||||||
v_edg_pos_ID, &
|
|
||||||
v_edg_neg_ID, &
|
|
||||||
v_scr_pos_ID, &
|
|
||||||
v_scr_neg_ID, &
|
|
||||||
gamma_ID
|
|
||||||
end enum
|
|
||||||
|
|
||||||
type :: tParameters !< container type for internal constitutive parameters
|
type :: tParameters !< container type for internal constitutive parameters
|
||||||
real(pReal) :: &
|
real(pReal) :: &
|
||||||
atomicVolume, & !< atomic volume
|
atomicVolume, & !< atomic volume
|
||||||
|
@ -135,14 +109,12 @@ submodule(constitutive) plastic_nonlocal
|
||||||
integer, dimension(:) ,allocatable :: &
|
integer, dimension(:) ,allocatable :: &
|
||||||
Nslip,&
|
Nslip,&
|
||||||
colinearSystem !< colinear system to the active slip system (only valid for fcc!)
|
colinearSystem !< colinear system to the active slip system (only valid for fcc!)
|
||||||
|
character(len=pStringLen), allocatable, dimension(:) :: &
|
||||||
|
output
|
||||||
logical :: &
|
logical :: &
|
||||||
shortRangeStressCorrection, & !< flag indicating the use of the short range stress correction by a excess density gradient term
|
shortRangeStressCorrection, & !< flag indicating the use of the short range stress correction by a excess density gradient term
|
||||||
probabilisticMultiplication
|
probabilisticMultiplication
|
||||||
|
|
||||||
integer(kind(undefined_ID)), dimension(:), allocatable :: &
|
|
||||||
outputID !< ID of each post result output
|
|
||||||
|
|
||||||
end type tParameters
|
end type tParameters
|
||||||
|
|
||||||
type :: tNonlocalMicrostructure
|
type :: tNonlocalMicrostructure
|
||||||
|
@ -205,15 +177,12 @@ module subroutine plastic_nonlocal_init
|
||||||
t, &
|
t, &
|
||||||
c
|
c
|
||||||
|
|
||||||
integer(kind(undefined_ID)) :: &
|
|
||||||
outputID
|
|
||||||
character(len=pStringLen) :: &
|
character(len=pStringLen) :: &
|
||||||
extmsg = '', &
|
extmsg = '', &
|
||||||
structure
|
structure
|
||||||
character(len=pStringLen), dimension(:), allocatable :: outputs
|
|
||||||
integer :: NofMyPhase
|
integer :: NofMyPhase
|
||||||
|
|
||||||
write(6,'(/,a)') ' <<<+- constitutive_'//PLASTICITY_NONLOCAL_label//' init -+>>>'
|
write(6,'(/,a)') ' <<<+- constitutive_'//PLASTICITY_NONLOCAL_label//' init -+>>>'; flush(6)
|
||||||
|
|
||||||
write(6,'(/,a)') ' Reuber et al., Acta Materialia 71:333–348, 2014'
|
write(6,'(/,a)') ' Reuber et al., Acta Materialia 71:333–348, 2014'
|
||||||
write(6,'(a)') ' https://doi.org/10.1016/j.actamat.2014.03.012'
|
write(6,'(a)') ' https://doi.org/10.1016/j.actamat.2014.03.012'
|
||||||
|
@ -407,60 +376,7 @@ module subroutine plastic_nonlocal_init
|
||||||
|
|
||||||
endif slipActive
|
endif slipActive
|
||||||
|
|
||||||
outputs = config%getStrings('(output)',defaultVal=emptyStringArray)
|
prm%output = config%getStrings('(output)',defaultVal=emptyStringArray)
|
||||||
allocate(prm%outputID(0))
|
|
||||||
do i=1, size(outputs)
|
|
||||||
outputID = undefined_ID
|
|
||||||
select case(trim(outputs(i)))
|
|
||||||
case ('rho_sgl_mob_edg_pos')
|
|
||||||
outputID = merge(rho_sgl_mob_edg_pos_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_mob_edg_neg')
|
|
||||||
outputID = merge(rho_sgl_mob_edg_neg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_mob_scr_pos')
|
|
||||||
outputID = merge(rho_sgl_mob_scr_pos_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_mob_scr_neg')
|
|
||||||
outputID = merge(rho_sgl_mob_scr_neg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_imm_edg_pos')
|
|
||||||
outputID = merge(rho_sgl_imm_edg_pos_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_imm_edg_neg')
|
|
||||||
outputID = merge(rho_sgl_imm_edg_neg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_imm_scr_pos')
|
|
||||||
outputID = merge(rho_sgl_imm_scr_pos_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_sgl_imm_scr_neg')
|
|
||||||
outputID = merge(rho_sgl_imm_scr_neg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_dip_edg')
|
|
||||||
outputID = merge(rho_dip_edg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_dip_scr')
|
|
||||||
outputID = merge(rho_dip_scr_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_forest')
|
|
||||||
outputID = merge(rho_forest_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('resolvedstress_back')
|
|
||||||
outputID = merge(resolvedstress_back_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('tau_pass')
|
|
||||||
outputID = merge(tau_pass_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_dot_sgl')
|
|
||||||
outputID = merge(rho_dot_sgl_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_dot_sgl_mobile')
|
|
||||||
outputID = merge(rho_dot_sgl_mobile_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('rho_dot_dip')
|
|
||||||
outputID = merge(rho_dot_dip_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('v_edg_pos')
|
|
||||||
outputID = merge(v_edg_pos_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('v_edg_neg')
|
|
||||||
outputID = merge(v_edg_neg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('v_scr_pos')
|
|
||||||
outputID = merge(v_scr_pos_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('v_scr_neg')
|
|
||||||
outputID = merge(v_scr_neg_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
case ('gamma')
|
|
||||||
outputID = merge(gamma_ID,undefined_ID,prm%totalNslip>0)
|
|
||||||
end select
|
|
||||||
|
|
||||||
if (outputID /= undefined_ID) then
|
|
||||||
prm%outputID = [prm%outputID , outputID]
|
|
||||||
endif
|
|
||||||
|
|
||||||
enddo
|
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! allocate state arrays
|
! allocate state arrays
|
||||||
|
@ -561,7 +477,7 @@ module subroutine plastic_nonlocal_init
|
||||||
stt%v_scr_neg => plasticState(p)%state (15*prm%totalNslip + 1:16*prm%totalNslip ,1:NofMyPhase)
|
stt%v_scr_neg => plasticState(p)%state (15*prm%totalNslip + 1:16*prm%totalNslip ,1:NofMyPhase)
|
||||||
|
|
||||||
allocate(dst%tau_pass(prm%totalNslip,NofMyPhase),source=0.0_pReal)
|
allocate(dst%tau_pass(prm%totalNslip,NofMyPhase),source=0.0_pReal)
|
||||||
allocate(dst%tau_Back(prm%totalNslip,NofMyPhase), source=0.0_pReal)
|
allocate(dst%tau_back(prm%totalNslip,NofMyPhase),source=0.0_pReal)
|
||||||
end associate
|
end associate
|
||||||
|
|
||||||
if (NofMyPhase > 0) call stateInit(p,NofMyPhase)
|
if (NofMyPhase > 0) call stateInit(p,NofMyPhase)
|
||||||
|
@ -1968,61 +1884,62 @@ module subroutine plastic_nonlocal_results(instance,group)
|
||||||
|
|
||||||
integer, intent(in) :: instance
|
integer, intent(in) :: instance
|
||||||
character(len=*),intent(in) :: group
|
character(len=*),intent(in) :: group
|
||||||
|
|
||||||
integer :: o
|
integer :: o
|
||||||
|
|
||||||
associate(prm => param(instance),dst => microstructure(instance),stt=>state(instance))
|
associate(prm => param(instance),dst => microstructure(instance),stt=>state(instance))
|
||||||
outputsLoop: do o = 1,size(prm%outputID)
|
outputsLoop: do o = 1,size(prm%output)
|
||||||
select case(prm%outputID(o))
|
select case(trim(prm%output(o)))
|
||||||
case (rho_sgl_mob_edg_pos_ID)
|
case('rho_sgl_mob_edg_pos')
|
||||||
call results_writeDataset(group,stt%rho_sgl_mob_edg_pos, 'rho_sgl_mob_edg_pos', &
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_mob_edg_pos, 'rho_sgl_mob_edg_pos', &
|
||||||
'positive mobile edge density','1/m²')
|
'positive mobile edge density','1/m²')
|
||||||
case (rho_sgl_imm_edg_pos_ID)
|
case('rho_sgl_imm_edg_pos')
|
||||||
call results_writeDataset(group,stt%rho_sgl_imm_edg_pos, 'rho_sgl_imm_edg_pos',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_imm_edg_pos, 'rho_sgl_imm_edg_pos',&
|
||||||
'positive immobile edge density','1/m²')
|
'positive immobile edge density','1/m²')
|
||||||
case (rho_sgl_mob_edg_neg_ID)
|
case('rho_sgl_mob_edg_neg')
|
||||||
call results_writeDataset(group,stt%rho_sgl_mob_edg_neg, 'rho_sgl_mob_edg_neg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_mob_edg_neg, 'rho_sgl_mob_edg_neg',&
|
||||||
'negative mobile edge density','1/m²')
|
'negative mobile edge density','1/m²')
|
||||||
case (rho_sgl_imm_edg_neg_ID)
|
case('rho_sgl_imm_edg_neg')
|
||||||
call results_writeDataset(group,stt%rho_sgl_imm_edg_neg, 'rho_sgl_imm_edg_neg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_imm_edg_neg, 'rho_sgl_imm_edg_neg',&
|
||||||
'negative immobile edge density','1/m²')
|
'negative immobile edge density','1/m²')
|
||||||
case (rho_dip_edg_ID)
|
case('rho_dip_edg_ID')
|
||||||
call results_writeDataset(group,stt%rho_dip_edg, 'rho_dip_edg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_dip_edg, 'rho_dip_edg',&
|
||||||
'edge dipole density','1/m²')
|
'edge dipole density','1/m²')
|
||||||
case (rho_sgl_mob_scr_pos_ID)
|
case('rho_sgl_mob_scr_pos')
|
||||||
call results_writeDataset(group,stt%rho_sgl_mob_scr_pos, 'rho_sgl_mob_scr_pos',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_mob_scr_pos, 'rho_sgl_mob_scr_pos',&
|
||||||
'positive mobile screw density','1/m²')
|
'positive mobile screw density','1/m²')
|
||||||
case (rho_sgl_imm_scr_pos_ID)
|
case('rho_sgl_imm_scr_pos')
|
||||||
call results_writeDataset(group,stt%rho_sgl_imm_scr_pos, 'rho_sgl_imm_scr_pos',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_imm_scr_pos, 'rho_sgl_imm_scr_pos',&
|
||||||
'positive immobile screw density','1/m²')
|
'positive immobile screw density','1/m²')
|
||||||
case (rho_sgl_mob_scr_neg_ID)
|
case('rho_sgl_mob_scr_neg')
|
||||||
call results_writeDataset(group,stt%rho_sgl_mob_scr_neg, 'rho_sgl_mob_scr_neg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_mob_scr_neg, 'rho_sgl_mob_scr_neg',&
|
||||||
'negative mobile screw density','1/m²')
|
'negative mobile screw density','1/m²')
|
||||||
case (rho_sgl_imm_scr_neg_ID)
|
case('rho_sgl_imm_scr_neg')
|
||||||
call results_writeDataset(group,stt%rho_sgl_imm_scr_neg, 'rho_sgl_imm_scr_neg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_sgl_imm_scr_neg, 'rho_sgl_imm_scr_neg',&
|
||||||
'negative immobile screw density','1/m²')
|
'negative immobile screw density','1/m²')
|
||||||
case (rho_dip_scr_ID)
|
case('rho_dip_scr')
|
||||||
call results_writeDataset(group,stt%rho_dip_scr, 'rho_dip_scr',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_dip_scr, 'rho_dip_scr',&
|
||||||
'screw dipole density','1/m²')
|
'screw dipole density','1/m²')
|
||||||
case (rho_forest_ID)
|
case('rho_forest')
|
||||||
call results_writeDataset(group,stt%rho_forest, 'rho_forest',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%rho_forest, 'rho_forest',&
|
||||||
'forest density','1/m²')
|
'forest density','1/m²')
|
||||||
case (v_edg_pos_ID)
|
case('v_edg_pos')
|
||||||
call results_writeDataset(group,stt%v_edg_pos, 'v_edg_pos',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%v_edg_pos, 'v_edg_pos',&
|
||||||
'positive edge velocity','m/s')
|
'positive edge velocity','m/s')
|
||||||
case (v_edg_neg_ID)
|
case('v_edg_neg')
|
||||||
call results_writeDataset(group,stt%v_edg_neg, 'v_edg_neg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%v_edg_neg, 'v_edg_neg',&
|
||||||
'negative edge velocity','m/s')
|
'negative edge velocity','m/s')
|
||||||
case (v_scr_pos_ID)
|
case('v_scr_pos')
|
||||||
call results_writeDataset(group,stt%v_scr_pos, 'v_scr_pos',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%v_scr_pos, 'v_scr_pos',&
|
||||||
'positive srew velocity','m/s')
|
'positive srew velocity','m/s')
|
||||||
case (v_scr_neg_ID)
|
case('v_scr_neg')
|
||||||
call results_writeDataset(group,stt%v_scr_neg, 'v_scr_neg',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%v_scr_neg, 'v_scr_neg',&
|
||||||
'negative screw velocity','m/s')
|
'negative screw velocity','m/s')
|
||||||
case(gamma_ID)
|
case('gamma')
|
||||||
call results_writeDataset(group,stt%gamma,'gamma',&
|
if(prm%totalNslip>0) call results_writeDataset(group,stt%gamma,'gamma',&
|
||||||
'plastic shear','1')
|
'plastic shear','1')
|
||||||
case (tau_pass_ID)
|
case('tau_pass')
|
||||||
call results_writeDataset(group,dst%tau_pass,'tau_pass',&
|
if(prm%totalNslip>0) call results_writeDataset(group,dst%tau_pass,'tau_pass',&
|
||||||
'passing stress for slip','Pa')
|
'passing stress for slip','Pa')
|
||||||
end select
|
end select
|
||||||
enddo outputsLoop
|
enddo outputsLoop
|
||||||
|
|
Loading…
Reference in New Issue