DAMASK_EICMD/src/homogenization_damage.f90

196 lines
5.9 KiB
Fortran
Raw Normal View History

2021-01-21 01:24:31 +05:30
!--------------------------------------------------------------------------------------------------
!> @author Martin Diehl, KU Leuven
!--------------------------------------------------------------------------------------------------
2021-04-06 15:25:30 +05:30
submodule(homogenization) damage
2021-01-21 01:24:31 +05:30
2021-04-06 15:25:30 +05:30
interface
module subroutine pass_init
end subroutine pass_init
end interface
type :: tDataContainer
real(pREAL), dimension(:), allocatable :: phi
end type tDataContainer
type(tDataContainer), dimension(:), allocatable :: current
type :: tParameters
2023-06-04 10:47:38 +05:30
character(len=pSTRLEN), allocatable, dimension(:) :: &
output
end type tParameters
type(tparameters), dimension(:), allocatable :: &
param
2021-01-21 01:24:31 +05:30
2021-04-11 12:02:13 +05:30
contains
2021-01-21 01:24:31 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief Allocate variables and set parameters.
!--------------------------------------------------------------------------------------------------
module subroutine damage_init()
type(tDict), pointer :: &
configHomogenizations, &
configHomogenization, &
2021-07-20 21:44:19 +05:30
configHomogenizationDamage
2021-05-23 13:40:25 +05:30
integer :: ho,Nmembers
2021-01-21 01:24:31 +05:30
print'(/,1x,a)', '<<<+- homogenization:damage init -+>>>'
2021-04-11 19:02:17 +05:30
configHomogenizations => config_material%get_dict('homogenization')
allocate(param(configHomogenizations%length))
allocate(current(configHomogenizations%length))
do ho = 1, configHomogenizations%length
2023-01-23 13:01:59 +05:30
Nmembers = count(material_ID_homogenization == ho)
allocate(current(ho)%phi(Nmembers), source=1.0_pREAL)
configHomogenization => configHomogenizations%get_dict(ho)
associate(prm => param(ho))
if (configHomogenization%contains('damage')) then
configHomogenizationDamage => configHomogenization%get_dict('damage')
#if defined (__GFORTRAN__)
2023-06-04 10:47:38 +05:30
prm%output = output_as1dStr(configHomogenizationDamage)
#else
2023-06-04 10:47:38 +05:30
prm%output = configHomogenizationDamage%get_as1dStr('output',defaultVal=emptyStrArray)
#endif
2021-04-11 19:02:17 +05:30
damageState_h(ho)%sizeState = 1
allocate(damageState_h(ho)%state0(1,Nmembers), source=1.0_pREAL)
allocate(damageState_h(ho)%state (1,Nmembers), source=1.0_pREAL)
else
2023-06-04 10:47:38 +05:30
prm%output = emptyStrArray
2022-06-09 02:36:01 +05:30
end if
end associate
2022-06-09 02:36:01 +05:30
end do
2021-01-21 01:24:31 +05:30
2021-04-11 19:02:17 +05:30
call pass_init()
2021-04-07 16:52:22 +05:30
2021-01-21 01:24:31 +05:30
end subroutine damage_init
!--------------------------------------------------------------------------------------------------
!> @brief Check if damage homogemization description is present in the configuration file
!--------------------------------------------------------------------------------------------------
module function homogenization_damage_active() result(active)
logical :: active
active = any(damage_active(:))
end function homogenization_damage_active
2021-01-21 01:24:31 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief Partition temperature onto the individual constituents.
!--------------------------------------------------------------------------------------------------
module subroutine damage_partition(ce)
2021-01-21 01:24:31 +05:30
2022-06-24 10:34:52 +05:30
integer, intent(in) :: ce
real(pREAL) :: phi
integer :: co
2021-01-21 01:24:31 +05:30
2023-01-23 13:01:59 +05:30
if (damageState_h(material_ID_homogenization(ce))%sizeState < 1) return
phi = damagestate_h(material_ID_homogenization(ce))%state(1,material_entry_homogenization(ce))
do co = 1, homogenization_Nconstituents(material_ID_homogenization(ce))
call phase_set_phi(phi,co,ce)
end do
2021-01-21 01:24:31 +05:30
end subroutine damage_partition
2021-01-24 23:17:19 +05:30
!--------------------------------------------------------------------------------------------------
2022-06-24 10:34:52 +05:30
!> @brief Homogenize damage viscosity.
2021-01-24 23:17:19 +05:30
!--------------------------------------------------------------------------------------------------
2021-04-09 03:10:20 +05:30
module function homogenization_mu_phi(ce) result(mu)
2021-01-24 23:17:19 +05:30
integer, intent(in) :: ce
real(pREAL) :: mu
2021-01-24 23:17:19 +05:30
2021-04-11 12:02:13 +05:30
2021-04-11 16:51:27 +05:30
mu = phase_mu_phi(1,ce)
2021-01-24 23:17:19 +05:30
2021-04-08 17:01:21 +05:30
end function homogenization_mu_phi
2021-01-24 23:17:19 +05:30
2021-01-25 03:14:47 +05:30
!--------------------------------------------------------------------------------------------------
2022-06-24 10:34:52 +05:30
!> @brief Homogenize damage conductivity.
2021-04-11 12:02:13 +05:30
!--------------------------------------------------------------------------------------------------
module function homogenization_K_phi(ce) result(K)
integer, intent(in) :: ce
real(pREAL), dimension(3,3) :: K
2021-04-11 12:02:13 +05:30
2021-07-20 21:44:19 +05:30
K = phase_K_phi(1,ce)
2021-04-11 12:02:13 +05:30
end function homogenization_K_phi
!--------------------------------------------------------------------------------------------------
2022-06-24 10:34:52 +05:30
!> @brief Homogenize damage driving force.
2021-01-25 03:14:47 +05:30
!--------------------------------------------------------------------------------------------------
2021-04-09 03:10:20 +05:30
module function homogenization_f_phi(phi,ce) result(f)
2021-01-25 03:14:47 +05:30
integer, intent(in) :: ce
real(pREAL), intent(in) :: phi
real(pREAL) :: f
2021-01-25 03:14:47 +05:30
2021-04-11 12:02:13 +05:30
2021-04-09 03:10:20 +05:30
f = phase_f_phi(phi, 1, ce)
2021-01-25 03:14:47 +05:30
2021-04-08 17:01:21 +05:30
end function homogenization_f_phi
2021-01-25 03:14:47 +05:30
2021-01-25 19:43:17 +05:30
!--------------------------------------------------------------------------------------------------
2021-04-11 12:02:13 +05:30
!> @brief Set damage field.
2021-01-25 19:43:17 +05:30
!--------------------------------------------------------------------------------------------------
2021-04-08 00:36:29 +05:30
module subroutine homogenization_set_phi(phi,ce)
2021-01-25 19:43:17 +05:30
integer, intent(in) :: ce
real(pREAL), intent(in) :: phi
2021-04-11 12:02:13 +05:30
2021-01-25 19:43:17 +05:30
integer :: &
ho, &
2021-04-06 15:08:44 +05:30
en
2021-01-25 19:43:17 +05:30
2021-04-11 12:02:13 +05:30
2023-01-23 13:01:59 +05:30
ho = material_ID_homogenization(ce)
en = material_entry_homogenization(ce)
2021-04-06 15:08:44 +05:30
damagestate_h(ho)%state(1,en) = phi
2021-04-07 18:26:11 +05:30
current(ho)%phi(en) = phi
2021-01-25 19:43:17 +05:30
2021-04-08 00:36:29 +05:30
end subroutine homogenization_set_phi
2021-01-25 19:43:17 +05:30
!--------------------------------------------------------------------------------------------------
!> @brief writes results to HDF5 output file
!--------------------------------------------------------------------------------------------------
2023-01-19 22:07:45 +05:30
module subroutine damage_result(ho,group)
2021-01-25 19:43:17 +05:30
integer, intent(in) :: ho
2021-01-25 19:43:17 +05:30
character(len=*), intent(in) :: group
integer :: o
associate(prm => param(ho))
2021-04-11 19:02:17 +05:30
outputsLoop: do o = 1,size(prm%output)
select case(prm%output(o))
case ('phi')
2023-01-19 22:07:45 +05:30
call result_writeDataset(current(ho)%phi,group,prm%output(o),&
'damage indicator','-')
2021-04-11 19:02:17 +05:30
end select
2022-06-09 02:36:01 +05:30
end do outputsLoop
2021-01-25 19:43:17 +05:30
end associate
2023-01-19 22:07:45 +05:30
end subroutine damage_result
2021-01-25 19:43:17 +05:30
2021-04-06 15:25:30 +05:30
end submodule damage