prefix should be name of the module
poor substitute for namespace
This commit is contained in:
parent
da0e16520c
commit
b499578a95
|
@ -115,19 +115,19 @@ subroutine CPFEM_init
|
||||||
|
|
||||||
!------------------------------------------------------------------------------
|
!------------------------------------------------------------------------------
|
||||||
! read numerical parameters and do sanity check
|
! read numerical parameters and do sanity check
|
||||||
num_commercialFEM => numerics_root%get('commercialFEM',defaultVal=emptyDict)
|
num_commercialFEM => config_numerics%get('commercialFEM',defaultVal=emptyDict)
|
||||||
num%iJacoStiffness = num_commercialFEM%get_asInt('ijacostiffness',defaultVal=1)
|
num%iJacoStiffness = num_commercialFEM%get_asInt('ijacostiffness',defaultVal=1)
|
||||||
if (num%iJacoStiffness < 1) call IO_error(301,ext_msg='iJacoStiffness')
|
if (num%iJacoStiffness < 1) call IO_error(301,ext_msg='iJacoStiffness')
|
||||||
|
|
||||||
!------------------------------------------------------------------------------
|
!------------------------------------------------------------------------------
|
||||||
! read debug options
|
! read debug options
|
||||||
|
|
||||||
debug_CPFEM => debug_root%get('cpfem',defaultVal=emptyList)
|
debug_CPFEM => config_debug%get('cpfem',defaultVal=emptyList)
|
||||||
debugCPFEM%basic = debug_CPFEM%contains('basic')
|
debugCPFEM%basic = debug_CPFEM%contains('basic')
|
||||||
debugCPFEM%extensive = debug_CPFEM%contains('extensive')
|
debugCPFEM%extensive = debug_CPFEM%contains('extensive')
|
||||||
debugCPFEM%selective = debug_CPFEM%contains('selective')
|
debugCPFEM%selective = debug_CPFEM%contains('selective')
|
||||||
debugCPFEM%element = debug_root%get_asInt('element',defaultVal = 1)
|
debugCPFEM%element = config_debug%get_asInt('element',defaultVal = 1)
|
||||||
debugCPFEM%ip = debug_root%get_asInt('integrationpoint',defaultVal = 1)
|
debugCPFEM%ip = config_debug%get_asInt('integrationpoint',defaultVal = 1)
|
||||||
|
|
||||||
if(debugCPFEM%basic) then
|
if(debugCPFEM%basic) then
|
||||||
write(6,'(a32,1x,6(i8,1x))') 'CPFEM_cs: ', shape(CPFEM_cs)
|
write(6,'(a32,1x,6(i8,1x))') 'CPFEM_cs: ', shape(CPFEM_cs)
|
||||||
|
|
|
@ -277,7 +277,7 @@ subroutine hypela2(d,g,e,de,s,t,dt,ngens,m,nn,kcus,matus,ndi,nshear,disp, &
|
||||||
if (.not. CPFEM_init_done) then
|
if (.not. CPFEM_init_done) then
|
||||||
CPFEM_init_done = .true.
|
CPFEM_init_done = .true.
|
||||||
call CPFEM_initAll
|
call CPFEM_initAll
|
||||||
debug_Marc => debug_root%get('marc',defaultVal=emptyList)
|
debug_Marc => config_debug%get('marc',defaultVal=emptyList)
|
||||||
debug_basic = debug_Marc%contains('basic')
|
debug_basic = debug_Marc%contains('basic')
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
|
@ -20,9 +20,9 @@ module config
|
||||||
private
|
private
|
||||||
|
|
||||||
class(tNode), pointer, public :: &
|
class(tNode), pointer, public :: &
|
||||||
material_root, &
|
config_material, &
|
||||||
numerics_root, &
|
config_numerics, &
|
||||||
debug_root
|
config_debug
|
||||||
|
|
||||||
public :: &
|
public :: &
|
||||||
config_init, &
|
config_init, &
|
||||||
|
@ -60,7 +60,7 @@ subroutine parse_material
|
||||||
if(.not. fileExists) call IO_error(100,ext_msg=fname)
|
if(.not. fileExists) call IO_error(100,ext_msg=fname)
|
||||||
endif
|
endif
|
||||||
write(6,*) 'reading '//fname; flush(6)
|
write(6,*) 'reading '//fname; flush(6)
|
||||||
material_root => parse_flow(to_flow(IO_read(fname)))
|
config_material => parse_flow(to_flow(IO_read(fname)))
|
||||||
|
|
||||||
end subroutine parse_material
|
end subroutine parse_material
|
||||||
|
|
||||||
|
@ -73,11 +73,11 @@ subroutine parse_numerics
|
||||||
|
|
||||||
logical :: fexist
|
logical :: fexist
|
||||||
|
|
||||||
numerics_root => emptyDict
|
config_numerics => emptyDict
|
||||||
inquire(file='numerics.yaml', exist=fexist)
|
inquire(file='numerics.yaml', exist=fexist)
|
||||||
if (fexist) then
|
if (fexist) then
|
||||||
write(6,*) 'reading numerics.yaml'; flush(6)
|
write(6,*) 'reading numerics.yaml'; flush(6)
|
||||||
numerics_root => parse_flow(to_flow(IO_read('numerics.yaml')))
|
config_numerics => parse_flow(to_flow(IO_read('numerics.yaml')))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
end subroutine parse_numerics
|
end subroutine parse_numerics
|
||||||
|
@ -90,11 +90,11 @@ subroutine parse_debug
|
||||||
|
|
||||||
logical :: fexist
|
logical :: fexist
|
||||||
|
|
||||||
debug_root => emptyDict
|
config_debug => emptyDict
|
||||||
inquire(file='debug.yaml', exist=fexist)
|
inquire(file='debug.yaml', exist=fexist)
|
||||||
fileExists: if (fexist) then
|
fileExists: if (fexist) then
|
||||||
write(6,*) 'reading debug.yaml'; flush(6)
|
write(6,*) 'reading debug.yaml'; flush(6)
|
||||||
debug_root => parse_flow(to_flow(IO_read('debug.yaml')))
|
config_debug => parse_flow(to_flow(IO_read('debug.yaml')))
|
||||||
endif fileExists
|
endif fileExists
|
||||||
|
|
||||||
end subroutine parse_debug
|
end subroutine parse_debug
|
||||||
|
@ -106,7 +106,7 @@ end subroutine parse_debug
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine config_deallocate
|
subroutine config_deallocate
|
||||||
|
|
||||||
deallocate(material_root)
|
deallocate(config_material)
|
||||||
|
|
||||||
end subroutine config_deallocate
|
end subroutine config_deallocate
|
||||||
|
|
||||||
|
|
|
@ -394,17 +394,17 @@ subroutine constitutive_init
|
||||||
elastic, &
|
elastic, &
|
||||||
stiffDegradation
|
stiffDegradation
|
||||||
|
|
||||||
debug_constitutive => debug_root%get('constitutive', defaultVal=emptyList)
|
debug_constitutive => config_debug%get('constitutive', defaultVal=emptyList)
|
||||||
debugConstitutive%basic = debug_constitutive%contains('basic')
|
debugConstitutive%basic = debug_constitutive%contains('basic')
|
||||||
debugConstitutive%extensive = debug_constitutive%contains('extensive')
|
debugConstitutive%extensive = debug_constitutive%contains('extensive')
|
||||||
debugConstitutive%selective = debug_constitutive%contains('selective')
|
debugConstitutive%selective = debug_constitutive%contains('selective')
|
||||||
debugConstitutive%element = debug_root%get_asInt('element',defaultVal = 1)
|
debugConstitutive%element = config_debug%get_asInt('element',defaultVal = 1)
|
||||||
debugConstitutive%ip = debug_root%get_asInt('integrationpoint',defaultVal = 1)
|
debugConstitutive%ip = config_debug%get_asInt('integrationpoint',defaultVal = 1)
|
||||||
debugConstitutive%grain = debug_root%get_asInt('grain',defaultVal = 1)
|
debugConstitutive%grain = config_debug%get_asInt('grain',defaultVal = 1)
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! initialize elasticity (hooke) !ToDO: Maybe move to elastic submodule along with function homogenizedC?
|
! initialize elasticity (hooke) !ToDO: Maybe move to elastic submodule along with function homogenizedC?
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(phase_elasticity(phases%length), source = ELASTICITY_undefined_ID)
|
allocate(phase_elasticity(phases%length), source = ELASTICITY_undefined_ID)
|
||||||
allocate(phase_elasticityInstance(phases%length), source = 0)
|
allocate(phase_elasticityInstance(phases%length), source = 0)
|
||||||
allocate(phase_NstiffnessDegradations(phases%length),source=0)
|
allocate(phase_NstiffnessDegradations(phases%length),source=0)
|
||||||
|
@ -483,7 +483,7 @@ module function source_active(source_label,src_length) result(active_source)
|
||||||
src
|
src
|
||||||
integer :: p,s
|
integer :: p,s
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(active_source(src_length,phases%length), source = .false. )
|
allocate(active_source(src_length,phases%length), source = .false. )
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
@ -515,7 +515,7 @@ module function kinematics_active(kinematics_label,kinematics_length) result(ac
|
||||||
kinematics_type
|
kinematics_type
|
||||||
integer :: p,k
|
integer :: p,k
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(active_kinematics(kinematics_length,phases%length), source = .false. )
|
allocate(active_kinematics(kinematics_length,phases%length), source = .false. )
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -117,7 +117,7 @@ module subroutine damage_init
|
||||||
sources, &
|
sources, &
|
||||||
kinematics
|
kinematics
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
|
|
||||||
allocate(sourceState (phases%length))
|
allocate(sourceState (phases%length))
|
||||||
allocate(phase_Nsources(phases%length),source = 0) ! same for kinematics
|
allocate(phase_Nsources(phases%length),source = 0) ! same for kinematics
|
||||||
|
|
|
@ -198,7 +198,7 @@ module subroutine plastic_init
|
||||||
integer :: p
|
integer :: p
|
||||||
class(tNode), pointer :: phases
|
class(tNode), pointer :: phases
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
|
|
||||||
allocate(plasticState(phases%length))
|
allocate(plasticState(phases%length))
|
||||||
allocate(phase_plasticity(phases%length),source = PLASTICITY_undefined_ID)
|
allocate(phase_plasticity(phases%length),source = PLASTICITY_undefined_ID)
|
||||||
|
@ -235,7 +235,7 @@ module function plastic_active(plastic_label) result(active_plastic)
|
||||||
pl
|
pl
|
||||||
integer :: p
|
integer :: p
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(active_plastic(phases%length), source = .false. )
|
allocate(active_plastic(phases%length), source = .false. )
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -112,7 +112,7 @@ module function plastic_disloTungsten_init() result(myPlasticity)
|
||||||
allocate(dotState(Ninstance))
|
allocate(dotState(Ninstance))
|
||||||
allocate(dependentState(Ninstance))
|
allocate(dependentState(Ninstance))
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
i = 0
|
i = 0
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -165,7 +165,7 @@ module function plastic_dislotwin_init() result(myPlasticity)
|
||||||
allocate(dotState(Ninstance))
|
allocate(dotState(Ninstance))
|
||||||
allocate(dependentState(Ninstance))
|
allocate(dependentState(Ninstance))
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
i = 0
|
i = 0
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -83,7 +83,7 @@ module function plastic_isotropic_init() result(myPlasticity)
|
||||||
allocate(state(Ninstance))
|
allocate(state(Ninstance))
|
||||||
allocate(dotState(Ninstance))
|
allocate(dotState(Ninstance))
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
i = 0
|
i = 0
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -92,7 +92,7 @@ module function plastic_kinehardening_init() result(myPlasticity)
|
||||||
allocate(dotState(Ninstance))
|
allocate(dotState(Ninstance))
|
||||||
allocate(deltaState(Ninstance))
|
allocate(deltaState(Ninstance))
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
i = 0
|
i = 0
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -26,7 +26,7 @@ module function plastic_none_init() result(myPlasticity)
|
||||||
|
|
||||||
write(6,'(/,a)') ' <<<+- plastic_none init -+>>>'
|
write(6,'(/,a)') ' <<<+- plastic_none init -+>>>'
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(myPlasticity(phases%length), source = .false. )
|
allocate(myPlasticity(phases%length), source = .false. )
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -209,7 +209,7 @@ module function plastic_nonlocal_init() result(myPlasticity)
|
||||||
allocate(deltaState(Ninstance))
|
allocate(deltaState(Ninstance))
|
||||||
allocate(microstructure(Ninstance))
|
allocate(microstructure(Ninstance))
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
i = 0
|
i = 0
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -101,7 +101,7 @@ module function plastic_phenopowerlaw_init() result(myPlasticity)
|
||||||
allocate(state(Ninstance))
|
allocate(state(Ninstance))
|
||||||
allocate(dotState(Ninstance))
|
allocate(dotState(Ninstance))
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
i = 0
|
i = 0
|
||||||
do p = 1, phases%length
|
do p = 1, phases%length
|
||||||
phase => phases%get(p)
|
phase => phases%get(p)
|
||||||
|
|
|
@ -150,13 +150,13 @@ subroutine crystallite_init
|
||||||
|
|
||||||
write(6,'(/,a)') ' <<<+- crystallite init -+>>>'
|
write(6,'(/,a)') ' <<<+- crystallite init -+>>>'
|
||||||
|
|
||||||
debug_crystallite => debug_root%get('crystallite', defaultVal=emptyList)
|
debug_crystallite => config_debug%get('crystallite', defaultVal=emptyList)
|
||||||
debugCrystallite%basic = debug_crystallite%contains('basic')
|
debugCrystallite%basic = debug_crystallite%contains('basic')
|
||||||
debugCrystallite%extensive = debug_crystallite%contains('extensive')
|
debugCrystallite%extensive = debug_crystallite%contains('extensive')
|
||||||
debugCrystallite%selective = debug_crystallite%contains('selective')
|
debugCrystallite%selective = debug_crystallite%contains('selective')
|
||||||
debugCrystallite%element = debug_root%get_asInt('element', defaultVal=1)
|
debugCrystallite%element = config_debug%get_asInt('element', defaultVal=1)
|
||||||
debugCrystallite%ip = debug_root%get_asInt('integrationpoint', defaultVal=1)
|
debugCrystallite%ip = config_debug%get_asInt('integrationpoint', defaultVal=1)
|
||||||
debugCrystallite%grain = debug_root%get_asInt('grain', defaultVal=1)
|
debugCrystallite%grain = config_debug%get_asInt('grain', defaultVal=1)
|
||||||
|
|
||||||
cMax = homogenization_maxNgrains
|
cMax = homogenization_maxNgrains
|
||||||
iMax = discretization_nIP
|
iMax = discretization_nIP
|
||||||
|
@ -189,7 +189,7 @@ subroutine crystallite_init
|
||||||
allocate(crystallite_requested(cMax,iMax,eMax), source=.false.)
|
allocate(crystallite_requested(cMax,iMax,eMax), source=.false.)
|
||||||
allocate(crystallite_converged(cMax,iMax,eMax), source=.true.)
|
allocate(crystallite_converged(cMax,iMax,eMax), source=.true.)
|
||||||
|
|
||||||
num_crystallite => numerics_root%get('crystallite',defaultVal=emptyDict)
|
num_crystallite => config_numerics%get('crystallite',defaultVal=emptyDict)
|
||||||
|
|
||||||
num%subStepMinCryst = num_crystallite%get_asFloat ('subStepMin', defaultVal=1.0e-3_pReal)
|
num%subStepMinCryst = num_crystallite%get_asFloat ('subStepMin', defaultVal=1.0e-3_pReal)
|
||||||
num%subStepSizeCryst = num_crystallite%get_asFloat ('subStepSize', defaultVal=0.25_pReal)
|
num%subStepSizeCryst = num_crystallite%get_asFloat ('subStepSize', defaultVal=0.25_pReal)
|
||||||
|
@ -236,7 +236,7 @@ subroutine crystallite_init
|
||||||
call IO_error(301,ext_msg='integrator')
|
call IO_error(301,ext_msg='integrator')
|
||||||
end select
|
end select
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
|
|
||||||
allocate(output_constituent(phases%length))
|
allocate(output_constituent(phases%length))
|
||||||
do c = 1, phases%length
|
do c = 1, phases%length
|
||||||
|
|
|
@ -53,14 +53,14 @@ subroutine damage_local_init
|
||||||
|
|
||||||
!----------------------------------------------------------------------------------------------
|
!----------------------------------------------------------------------------------------------
|
||||||
! read numerics parameter and do sanity check
|
! read numerics parameter and do sanity check
|
||||||
num_generic => numerics_root%get('generic',defaultVal=emptyDict)
|
num_generic => config_numerics%get('generic',defaultVal=emptyDict)
|
||||||
num%residualStiffness = num_generic%get_asFloat('residualStiffness', defaultVal=1.0e-6_pReal)
|
num%residualStiffness = num_generic%get_asFloat('residualStiffness', defaultVal=1.0e-6_pReal)
|
||||||
if (num%residualStiffness < 0.0_pReal) call IO_error(301,ext_msg='residualStiffness')
|
if (num%residualStiffness < 0.0_pReal) call IO_error(301,ext_msg='residualStiffness')
|
||||||
|
|
||||||
Ninstance = count(damage_type == DAMAGE_local_ID)
|
Ninstance = count(damage_type == DAMAGE_local_ID)
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
do h = 1, material_homogenization%length
|
do h = 1, material_homogenization%length
|
||||||
if (damage_type(h) /= DAMAGE_LOCAL_ID) cycle
|
if (damage_type(h) /= DAMAGE_LOCAL_ID) cycle
|
||||||
homog => material_homogenization%get(h)
|
homog => material_homogenization%get(h)
|
||||||
|
|
|
@ -57,13 +57,13 @@ subroutine damage_nonlocal_init
|
||||||
|
|
||||||
!------------------------------------------------------------------------------------
|
!------------------------------------------------------------------------------------
|
||||||
! read numerics parameter
|
! read numerics parameter
|
||||||
num_generic => numerics_root%get('generic',defaultVal= emptyDict)
|
num_generic => config_numerics%get('generic',defaultVal= emptyDict)
|
||||||
num%charLength = num_generic%get_asFloat('charLength',defaultVal=1.0_pReal)
|
num%charLength = num_generic%get_asFloat('charLength',defaultVal=1.0_pReal)
|
||||||
|
|
||||||
Ninstance = count(damage_type == DAMAGE_nonlocal_ID)
|
Ninstance = count(damage_type == DAMAGE_nonlocal_ID)
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
do h = 1, material_homogenization%length
|
do h = 1, material_homogenization%length
|
||||||
if (damage_type(h) /= DAMAGE_NONLOCAL_ID) cycle
|
if (damage_type(h) /= DAMAGE_NONLOCAL_ID) cycle
|
||||||
homog => material_homogenization%get(h)
|
homog => material_homogenization%get(h)
|
||||||
|
|
|
@ -114,7 +114,7 @@ program DAMASK_grid
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! reading field paramters from numerics file and do sanity checks
|
! reading field paramters from numerics file and do sanity checks
|
||||||
num_grid => numerics_root%get('grid', defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid', defaultVal=emptyDict)
|
||||||
stagItMax = num_grid%get_asInt('maxStaggeredIter',defaultVal=10)
|
stagItMax = num_grid%get_asInt('maxStaggeredIter',defaultVal=10)
|
||||||
maxCutBack = num_grid%get_asInt('maxCutBack',defaultVal=3)
|
maxCutBack = num_grid%get_asInt('maxCutBack',defaultVal=3)
|
||||||
|
|
||||||
|
@ -124,7 +124,7 @@ program DAMASK_grid
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! assign mechanics solver depending on selected type
|
! assign mechanics solver depending on selected type
|
||||||
|
|
||||||
debug_grid => debug_root%get('grid',defaultVal=emptyList)
|
debug_grid => config_debug%get('grid',defaultVal=emptyList)
|
||||||
select case (trim(num_grid%get_asString('solver', defaultVal = 'Basic')))
|
select case (trim(num_grid%get_asString('solver', defaultVal = 'Basic')))
|
||||||
case ('Basic')
|
case ('Basic')
|
||||||
mech_init => grid_mech_spectral_basic_init
|
mech_init => grid_mech_spectral_basic_init
|
||||||
|
|
|
@ -93,8 +93,8 @@ subroutine discretization_grid_init(restart)
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! debug parameters
|
! debug parameters
|
||||||
debug_element = debug_root%get_asInt('element',defaultVal=1)
|
debug_element = config_debug%get_asInt('element',defaultVal=1)
|
||||||
debug_ip = debug_root%get_asInt('integrationpoint',defaultVal=1)
|
debug_ip = config_debug%get_asInt('integrationpoint',defaultVal=1)
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! general discretization
|
! general discretization
|
||||||
|
|
|
@ -84,12 +84,12 @@ subroutine grid_damage_spectral_init
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! read numerical parameters and do sanity checks
|
! read numerical parameters and do sanity checks
|
||||||
num_grid => numerics_root%get('grid',defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid',defaultVal=emptyDict)
|
||||||
num%itmax = num_grid%get_asInt ('itmax',defaultVal=250)
|
num%itmax = num_grid%get_asInt ('itmax',defaultVal=250)
|
||||||
num%eps_damage_atol = num_grid%get_asFloat ('eps_damage_atol',defaultVal=1.0e-2_pReal)
|
num%eps_damage_atol = num_grid%get_asFloat ('eps_damage_atol',defaultVal=1.0e-2_pReal)
|
||||||
num%eps_damage_rtol = num_grid%get_asFloat ('eps_damage_rtol',defaultVal=1.0e-6_pReal)
|
num%eps_damage_rtol = num_grid%get_asFloat ('eps_damage_rtol',defaultVal=1.0e-6_pReal)
|
||||||
|
|
||||||
num_generic => numerics_root%get('generic',defaultVal=emptyDict)
|
num_generic => config_numerics%get('generic',defaultVal=emptyDict)
|
||||||
num%residualStiffness = num_generic%get_asFloat('residualStiffness', defaultVal=1.0e-6_pReal)
|
num%residualStiffness = num_generic%get_asFloat('residualStiffness', defaultVal=1.0e-6_pReal)
|
||||||
|
|
||||||
if (num%residualStiffness < 0.0_pReal) call IO_error(301,ext_msg='residualStiffness')
|
if (num%residualStiffness < 0.0_pReal) call IO_error(301,ext_msg='residualStiffness')
|
||||||
|
|
|
@ -126,12 +126,12 @@ subroutine grid_mech_FEM_init
|
||||||
|
|
||||||
!-----------------------------------------------------------------------------------------------
|
!-----------------------------------------------------------------------------------------------
|
||||||
! debugging options
|
! debugging options
|
||||||
debug_grid => debug_root%get('grid', defaultVal=emptyList)
|
debug_grid => config_debug%get('grid', defaultVal=emptyList)
|
||||||
debugRotation = debug_grid%contains('rotation')
|
debugRotation = debug_grid%contains('rotation')
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! read numerical parameter and do sanity checks
|
! read numerical parameter and do sanity checks
|
||||||
num_grid => numerics_root%get('grid',defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid',defaultVal=emptyDict)
|
||||||
num%eps_div_atol = num_grid%get_asFloat ('eps_div_atol', defaultVal=1.0e-4_pReal)
|
num%eps_div_atol = num_grid%get_asFloat ('eps_div_atol', defaultVal=1.0e-4_pReal)
|
||||||
num%eps_div_rtol = num_grid%get_asFloat ('eps_div_rtol', defaultVal=5.0e-4_pReal)
|
num%eps_div_rtol = num_grid%get_asFloat ('eps_div_rtol', defaultVal=5.0e-4_pReal)
|
||||||
num%eps_stress_atol = num_grid%get_asFloat ('eps_stress_atol', defaultVal=1.0e3_pReal)
|
num%eps_stress_atol = num_grid%get_asFloat ('eps_stress_atol', defaultVal=1.0e3_pReal)
|
||||||
|
|
|
@ -120,12 +120,12 @@ subroutine grid_mech_spectral_basic_init
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! debugging options
|
! debugging options
|
||||||
debug_grid => debug_root%get('grid', defaultVal=emptyList)
|
debug_grid => config_debug%get('grid', defaultVal=emptyList)
|
||||||
debugRotation = debug_grid%contains('rotation')
|
debugRotation = debug_grid%contains('rotation')
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! read numerical parameters and do sanity checks
|
! read numerical parameters and do sanity checks
|
||||||
num_grid => numerics_root%get('grid',defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid',defaultVal=emptyDict)
|
||||||
|
|
||||||
num%update_gamma = num_grid%get_asBool ('update_gamma', defaultVal=.false.)
|
num%update_gamma = num_grid%get_asBool ('update_gamma', defaultVal=.false.)
|
||||||
num%eps_div_atol = num_grid%get_asFloat ('eps_div_atol', defaultVal=1.0e-4_pReal)
|
num%eps_div_atol = num_grid%get_asFloat ('eps_div_atol', defaultVal=1.0e-4_pReal)
|
||||||
|
|
|
@ -130,12 +130,12 @@ subroutine grid_mech_spectral_polarisation_init
|
||||||
|
|
||||||
!------------------------------------------------------------------------------------------------
|
!------------------------------------------------------------------------------------------------
|
||||||
! debugging options
|
! debugging options
|
||||||
debug_grid => debug_root%get('grid',defaultVal=emptyList)
|
debug_grid => config_debug%get('grid',defaultVal=emptyList)
|
||||||
debugRotation = debug_grid%contains('rotation')
|
debugRotation = debug_grid%contains('rotation')
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! read numerical parameters
|
! read numerical parameters
|
||||||
num_grid => numerics_root%get('grid',defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid',defaultVal=emptyDict)
|
||||||
|
|
||||||
num%update_gamma = num_grid%get_asBool ('update_gamma', defaultVal=.false.)
|
num%update_gamma = num_grid%get_asBool ('update_gamma', defaultVal=.false.)
|
||||||
num%eps_div_atol = num_grid%get_asFloat ('eps_div_atol', defaultVal=1.0e-4_pReal)
|
num%eps_div_atol = num_grid%get_asFloat ('eps_div_atol', defaultVal=1.0e-4_pReal)
|
||||||
|
|
|
@ -81,7 +81,7 @@ subroutine grid_thermal_spectral_init
|
||||||
|
|
||||||
!-------------------------------------------------------------------------------------------------
|
!-------------------------------------------------------------------------------------------------
|
||||||
! read numerical parameter and do sanity checks
|
! read numerical parameter and do sanity checks
|
||||||
num_grid => numerics_root%get('grid',defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid',defaultVal=emptyDict)
|
||||||
num%itmax = num_grid%get_asInt ('itmax', defaultVal=250)
|
num%itmax = num_grid%get_asInt ('itmax', defaultVal=250)
|
||||||
num%eps_thermal_atol = num_grid%get_asFloat ('eps_thermal_atol',defaultVal=1.0e-2_pReal)
|
num%eps_thermal_atol = num_grid%get_asFloat ('eps_thermal_atol',defaultVal=1.0e-2_pReal)
|
||||||
num%eps_thermal_rtol = num_grid%get_asFloat ('eps_thermal_rtol',defaultVal=1.0e-6_pReal)
|
num%eps_thermal_rtol = num_grid%get_asFloat ('eps_thermal_rtol',defaultVal=1.0e-6_pReal)
|
||||||
|
|
|
@ -207,7 +207,7 @@ subroutine spectral_utilities_init
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! set debugging parameters
|
! set debugging parameters
|
||||||
debug_grid => debug_root%get('grid',defaultVal=emptyList)
|
debug_grid => config_debug%get('grid',defaultVal=emptyList)
|
||||||
debugGeneral = debug_grid%contains('basic')
|
debugGeneral = debug_grid%contains('basic')
|
||||||
debugRotation = debug_grid%contains('rotation')
|
debugRotation = debug_grid%contains('rotation')
|
||||||
debugPETSc = debug_grid%contains('petsc')
|
debugPETSc = debug_grid%contains('petsc')
|
||||||
|
@ -218,7 +218,7 @@ subroutine spectral_utilities_init
|
||||||
trim(PETScDebug), &
|
trim(PETScDebug), &
|
||||||
' add more using the PETSc_Options keyword in numerics.yaml '; flush(6)
|
' add more using the PETSc_Options keyword in numerics.yaml '; flush(6)
|
||||||
|
|
||||||
num_grid => numerics_root%get('grid',defaultVal=emptyDict)
|
num_grid => config_numerics%get('grid',defaultVal=emptyDict)
|
||||||
|
|
||||||
call PETScOptionsClear(PETSC_NULL_OPTIONS,ierr)
|
call PETScOptionsClear(PETSC_NULL_OPTIONS,ierr)
|
||||||
CHKERRQ(ierr)
|
CHKERRQ(ierr)
|
||||||
|
|
|
@ -149,20 +149,20 @@ subroutine homogenization_init
|
||||||
num_homogGeneric, &
|
num_homogGeneric, &
|
||||||
debug_homogenization
|
debug_homogenization
|
||||||
|
|
||||||
debug_homogenization => debug_root%get('homogenization', defaultVal=emptyList)
|
debug_homogenization => config_debug%get('homogenization', defaultVal=emptyList)
|
||||||
debugHomog%basic = debug_homogenization%contains('basic')
|
debugHomog%basic = debug_homogenization%contains('basic')
|
||||||
debugHomog%extensive = debug_homogenization%contains('extensive')
|
debugHomog%extensive = debug_homogenization%contains('extensive')
|
||||||
debugHomog%selective = debug_homogenization%contains('selective')
|
debugHomog%selective = debug_homogenization%contains('selective')
|
||||||
debugHomog%element = debug_root%get_asInt('element',defaultVal = 1)
|
debugHomog%element = config_debug%get_asInt('element',defaultVal = 1)
|
||||||
debugHomog%ip = debug_root%get_asInt('integrationpoint',defaultVal = 1)
|
debugHomog%ip = config_debug%get_asInt('integrationpoint',defaultVal = 1)
|
||||||
debugHomog%grain = debug_root%get_asInt('grain',defaultVal = 1)
|
debugHomog%grain = config_debug%get_asInt('grain',defaultVal = 1)
|
||||||
|
|
||||||
if (debugHomog%grain < 1 &
|
if (debugHomog%grain < 1 &
|
||||||
.or. debugHomog%grain > homogenization_Ngrains(material_homogenizationAt(debugHomog%element))) &
|
.or. debugHomog%grain > homogenization_Ngrains(material_homogenizationAt(debugHomog%element))) &
|
||||||
call IO_error(602,ext_msg='constituent', el=debugHomog%element, g=debugHomog%grain)
|
call IO_error(602,ext_msg='constituent', el=debugHomog%element, g=debugHomog%grain)
|
||||||
|
|
||||||
|
|
||||||
num_homog => numerics_root%get('homogenization',defaultVal=emptyDict)
|
num_homog => config_numerics%get('homogenization',defaultVal=emptyDict)
|
||||||
num_homogMech => num_homog%get('mech',defaultVal=emptyDict)
|
num_homogMech => num_homog%get('mech',defaultVal=emptyDict)
|
||||||
num_homogGeneric => num_homog%get('generic',defaultVal=emptyDict)
|
num_homogGeneric => num_homog%get('generic',defaultVal=emptyDict)
|
||||||
|
|
||||||
|
|
|
@ -139,7 +139,7 @@ module subroutine mech_RGC_init(num_homogMech)
|
||||||
if (num%volDiscrPow <= 0.0_pReal) call IO_error(301,ext_msg='volDiscrPw_RGC')
|
if (num%volDiscrPow <= 0.0_pReal) call IO_error(301,ext_msg='volDiscrPw_RGC')
|
||||||
|
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
do h = 1, size(homogenization_type)
|
do h = 1, size(homogenization_type)
|
||||||
if (homogenization_type(h) /= HOMOGENIZATION_RGC_ID) cycle
|
if (homogenization_type(h) /= HOMOGENIZATION_RGC_ID) cycle
|
||||||
homog => material_homogenization%get(h)
|
homog => material_homogenization%get(h)
|
||||||
|
|
|
@ -44,7 +44,7 @@ module subroutine mech_isostrain_init
|
||||||
|
|
||||||
allocate(param(Ninstance)) ! one container of parameters per instance
|
allocate(param(Ninstance)) ! one container of parameters per instance
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
do h = 1, size(homogenization_type)
|
do h = 1, size(homogenization_type)
|
||||||
if (homogenization_type(h) /= HOMOGENIZATION_ISOSTRAIN_ID) cycle
|
if (homogenization_type(h) /= HOMOGENIZATION_ISOSTRAIN_ID) cycle
|
||||||
homog => material_homogenization%get(h)
|
homog => material_homogenization%get(h)
|
||||||
|
|
|
@ -53,7 +53,7 @@ module function kinematics_cleavage_opening_init(kinematics_length) result(myKin
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(kinematics_cleavage_opening_instance(phases%length), source=0)
|
allocate(kinematics_cleavage_opening_instance(phases%length), source=0)
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,7 @@ module function kinematics_slipplane_opening_init(kinematics_length) result(myKi
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(kinematics_slipplane_opening_instance(phases%length), source=0)
|
allocate(kinematics_slipplane_opening_instance(phases%length), source=0)
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,7 @@ module function kinematics_thermal_expansion_init(kinematics_length) result(myKi
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(kinematics_thermal_expansion_instance(phases%length), source=0)
|
allocate(kinematics_thermal_expansion_instance(phases%length), source=0)
|
||||||
|
|
||||||
|
|
|
@ -459,7 +459,7 @@ subroutine lattice_init
|
||||||
|
|
||||||
write(6,'(/,a)') ' <<<+- lattice init -+>>>'; flush(6)
|
write(6,'(/,a)') ' <<<+- lattice init -+>>>'; flush(6)
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
Nphases = phases%length
|
Nphases = phases%length
|
||||||
|
|
||||||
allocate(lattice_structure(Nphases),source = lattice_UNDEFINED_ID)
|
allocate(lattice_structure(Nphases),source = lattice_UNDEFINED_ID)
|
||||||
|
|
|
@ -167,21 +167,21 @@ subroutine material_init(restart)
|
||||||
|
|
||||||
write(6,'(/,a)') ' <<<+- material init -+>>>'; flush(6)
|
write(6,'(/,a)') ' <<<+- material init -+>>>'; flush(6)
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(material_name_phase(phases%length))
|
allocate(material_name_phase(phases%length))
|
||||||
do ph = 1, phases%length
|
do ph = 1, phases%length
|
||||||
write(sectionName,'(i0,a)') ph,'_'
|
write(sectionName,'(i0,a)') ph,'_'
|
||||||
material_name_phase(ph) = trim(adjustl(sectionName))//phases%getKey(ph) !ToDO: No reason to do. Update damage tests
|
material_name_phase(ph) = trim(adjustl(sectionName))//phases%getKey(ph) !ToDO: No reason to do. Update damage tests
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
allocate(material_name_homogenization(material_homogenization%length))
|
allocate(material_name_homogenization(material_homogenization%length))
|
||||||
do myHomog = 1, material_homogenization%length
|
do myHomog = 1, material_homogenization%length
|
||||||
write(sectionName,'(i0,a)') myHomog,'_'
|
write(sectionName,'(i0,a)') myHomog,'_'
|
||||||
material_name_homogenization(myHomog) = trim(adjustl(sectionName))//material_homogenization%getKey(myHomog)
|
material_name_homogenization(myHomog) = trim(adjustl(sectionName))//material_homogenization%getKey(myHomog)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
debug_material => debug_root%get('material',defaultVal=emptyList)
|
debug_material => config_debug%get('material',defaultVal=emptyList)
|
||||||
|
|
||||||
call material_parseMicrostructure()
|
call material_parseMicrostructure()
|
||||||
if (debug_material%contains('basic')) write(6,'(a)') ' Microstructure parsed'; flush(6)
|
if (debug_material%contains('basic')) write(6,'(a)') ' Microstructure parsed'; flush(6)
|
||||||
|
@ -242,7 +242,7 @@ subroutine material_parseHomogenization
|
||||||
|
|
||||||
integer :: h
|
integer :: h
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
material_Nhomogenization = material_homogenization%length
|
material_Nhomogenization = material_homogenization%length
|
||||||
|
|
||||||
allocate(homogenization_type(material_Nhomogenization), source=HOMOGENIZATION_undefined_ID)
|
allocate(homogenization_type(material_Nhomogenization), source=HOMOGENIZATION_undefined_ID)
|
||||||
|
@ -347,9 +347,9 @@ subroutine material_parseMicrostructure
|
||||||
|
|
||||||
real(pReal), dimension(4) :: phase_orientation
|
real(pReal), dimension(4) :: phase_orientation
|
||||||
|
|
||||||
homogenization => material_root%get('homogenization')
|
homogenization => config_material%get('homogenization')
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
microstructure => material_root%get('microstructure')
|
microstructure => config_material%get('microstructure')
|
||||||
allocate(microstructure_Nconstituents(microstructure%length), source = 0)
|
allocate(microstructure_Nconstituents(microstructure%length), source = 0)
|
||||||
|
|
||||||
if(any(discretization_microstructureAt > microstructure%length)) &
|
if(any(discretization_microstructureAt > microstructure%length)) &
|
||||||
|
|
|
@ -97,7 +97,7 @@ subroutine math_init
|
||||||
|
|
||||||
write(6,'(/,a)') ' <<<+- math init -+>>>'; flush(6)
|
write(6,'(/,a)') ' <<<+- math init -+>>>'; flush(6)
|
||||||
|
|
||||||
num_generic => numerics_root%get('generic',defaultVal=emptyDict)
|
num_generic => config_numerics%get('generic',defaultVal=emptyDict)
|
||||||
randomSeed = num_generic%get_asInt('random_seed', defaultVal = 0)
|
randomSeed = num_generic%get_asInt('random_seed', defaultVal = 0)
|
||||||
|
|
||||||
call random_seed(size=randSize)
|
call random_seed(size=randSize)
|
||||||
|
|
|
@ -57,7 +57,7 @@ module function source_damage_anisoBrittle_init(source_length) result(mySources)
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(source_damage_anisoBrittle_offset (phases%length), source=0)
|
allocate(source_damage_anisoBrittle_offset (phases%length), source=0)
|
||||||
allocate(source_damage_anisoBrittle_instance(phases%length), source=0)
|
allocate(source_damage_anisoBrittle_instance(phases%length), source=0)
|
||||||
|
|
|
@ -52,7 +52,7 @@ module function source_damage_anisoDuctile_init(source_length) result(mySources)
|
||||||
|
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(source_damage_anisoDuctile_offset (phases%length), source=0)
|
allocate(source_damage_anisoDuctile_offset (phases%length), source=0)
|
||||||
allocate(source_damage_anisoDuctile_instance(phases%length), source=0)
|
allocate(source_damage_anisoDuctile_instance(phases%length), source=0)
|
||||||
|
|
|
@ -47,7 +47,7 @@ module function source_damage_isoBrittle_init(source_length) result(mySources)
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(source_damage_isoBrittle_offset (phases%length), source=0)
|
allocate(source_damage_isoBrittle_offset (phases%length), source=0)
|
||||||
allocate(source_damage_isoBrittle_instance(phases%length), source=0)
|
allocate(source_damage_isoBrittle_instance(phases%length), source=0)
|
||||||
|
|
|
@ -49,7 +49,7 @@ module function source_damage_isoDuctile_init(source_length) result(mySources)
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(source_damage_isoDuctile_offset (phases%length), source=0)
|
allocate(source_damage_isoDuctile_offset (phases%length), source=0)
|
||||||
allocate(source_damage_isoDuctile_instance(phases%length), source=0)
|
allocate(source_damage_isoDuctile_instance(phases%length), source=0)
|
||||||
|
|
|
@ -45,7 +45,7 @@ module function source_thermal_dissipation_init(source_length) result(mySources)
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(source_thermal_dissipation_offset (phases%length), source=0)
|
allocate(source_thermal_dissipation_offset (phases%length), source=0)
|
||||||
allocate(source_thermal_dissipation_instance(phases%length), source=0)
|
allocate(source_thermal_dissipation_instance(phases%length), source=0)
|
||||||
|
|
|
@ -49,7 +49,7 @@ module function source_thermal_externalheat_init(source_length) result(mySources
|
||||||
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
write(6,'(a16,1x,i5,/)') '# instances:',Ninstance; flush(6)
|
||||||
if(Ninstance == 0) return
|
if(Ninstance == 0) return
|
||||||
|
|
||||||
phases => material_root%get('phase')
|
phases => config_material%get('phase')
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
allocate(source_thermal_externalheat_offset (phases%length), source=0)
|
allocate(source_thermal_externalheat_offset (phases%length), source=0)
|
||||||
allocate(source_thermal_externalheat_instance(phases%length), source=0)
|
allocate(source_thermal_externalheat_instance(phases%length), source=0)
|
||||||
|
|
|
@ -53,7 +53,7 @@ subroutine thermal_adiabatic_init
|
||||||
|
|
||||||
allocate(param(maxNinstance))
|
allocate(param(maxNinstance))
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
do h = 1, material_Nhomogenization
|
do h = 1, material_Nhomogenization
|
||||||
if (thermal_type(h) /= THERMAL_adiabatic_ID) cycle
|
if (thermal_type(h) /= THERMAL_adiabatic_ID) cycle
|
||||||
homog => material_homogenization%get(h)
|
homog => material_homogenization%get(h)
|
||||||
|
|
|
@ -52,7 +52,7 @@ subroutine thermal_conduction_init
|
||||||
Ninstance = count(thermal_type == THERMAL_conduction_ID)
|
Ninstance = count(thermal_type == THERMAL_conduction_ID)
|
||||||
allocate(param(Ninstance))
|
allocate(param(Ninstance))
|
||||||
|
|
||||||
material_homogenization => material_root%get('homogenization')
|
material_homogenization => config_material%get('homogenization')
|
||||||
do h = 1, material_Nhomogenization
|
do h = 1, material_Nhomogenization
|
||||||
if (thermal_type(h) /= THERMAL_conduction_ID) cycle
|
if (thermal_type(h) /= THERMAL_conduction_ID) cycle
|
||||||
homog => material_homogenization%get(h)
|
homog => material_homogenization%get(h)
|
||||||
|
|
Loading…
Reference in New Issue