2020-07-15 18:05:21 +05:30
|
|
|
!----------------------------------------------------------------------------------------------------
|
2020-08-13 00:44:00 +05:30
|
|
|
!> @brief internal microstructure state for all thermal sources and kinematics constitutive models
|
2020-07-15 18:05:21 +05:30
|
|
|
!----------------------------------------------------------------------------------------------------
|
2021-01-27 01:22:48 +05:30
|
|
|
submodule(phase) thermal
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2021-04-11 12:16:31 +05:30
|
|
|
type :: tThermalParameters
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: C_p = 0.0_pREAL !< heat capacity
|
|
|
|
real(pREAL), dimension(3,3) :: K = 0.0_pREAL !< thermal conductivity
|
2023-06-04 10:47:38 +05:30
|
|
|
character(len=pSTRLEN), allocatable, dimension(:) :: output
|
2021-04-11 12:16:31 +05:30
|
|
|
end type tThermalParameters
|
|
|
|
|
2021-02-13 23:11:30 +05:30
|
|
|
integer, dimension(:), allocatable :: &
|
|
|
|
thermal_Nsources
|
|
|
|
|
2021-02-13 12:25:32 +05:30
|
|
|
type(tSourceState), allocatable, dimension(:) :: &
|
|
|
|
thermalState
|
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
type :: tFieldQuantities
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL), dimension(:), allocatable :: T, dot_T
|
2023-07-18 07:42:57 +05:30
|
|
|
end type tFieldQuantities
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
type(tFieldQuantities), dimension(:), allocatable :: current
|
2020-07-09 04:31:08 +05:30
|
|
|
|
2021-04-11 12:16:31 +05:30
|
|
|
type(tThermalParameters), dimension(:), allocatable :: param
|
|
|
|
|
2021-01-08 02:45:18 +05:30
|
|
|
integer :: thermal_source_maxSizeDotState
|
2021-01-26 12:25:06 +05:30
|
|
|
|
|
|
|
|
2020-07-09 04:31:08 +05:30
|
|
|
interface
|
|
|
|
|
2023-07-23 00:34:11 +05:30
|
|
|
module function source_dissipation_init(maxNsources) result(isMySource)
|
|
|
|
integer, intent(in) :: maxNsources
|
|
|
|
logical, dimension(:,:), allocatable :: isMySource
|
2023-07-18 07:42:57 +05:30
|
|
|
end function source_dissipation_init
|
2020-12-30 14:24:06 +05:30
|
|
|
|
2023-07-23 00:34:11 +05:30
|
|
|
module function source_externalheat_init(maxNsources) result(isMySource)
|
|
|
|
integer, intent(in) :: maxNsources
|
|
|
|
logical, dimension(:,:), allocatable :: isMySource
|
2023-07-18 07:42:57 +05:30
|
|
|
end function source_externalheat_init
|
2020-08-13 00:44:00 +05:30
|
|
|
|
2021-01-27 04:36:41 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
module subroutine source_externalheat_dotState(ph, en)
|
2021-01-26 12:25:06 +05:30
|
|
|
integer, intent(in) :: &
|
|
|
|
ph, &
|
2021-04-25 11:36:52 +05:30
|
|
|
en
|
2023-07-18 07:42:57 +05:30
|
|
|
end subroutine source_externalheat_dotState
|
2021-01-26 12:25:06 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
module function source_dissipation_f_T(ph,en) result(f_T)
|
2021-01-26 12:25:06 +05:30
|
|
|
integer, intent(in) :: &
|
2021-01-27 04:14:11 +05:30
|
|
|
ph, &
|
2021-04-25 11:36:52 +05:30
|
|
|
en
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: f_T
|
2023-07-18 07:42:57 +05:30
|
|
|
end function source_dissipation_f_T
|
2021-01-26 12:25:06 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
module function source_externalheat_f_T(ph,en) result(f_T)
|
2021-01-19 15:00:10 +05:30
|
|
|
integer, intent(in) :: &
|
2021-01-19 15:02:56 +05:30
|
|
|
ph, &
|
2021-04-25 11:36:52 +05:30
|
|
|
en
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: f_T
|
2023-07-18 07:42:57 +05:30
|
|
|
end function source_externalheat_f_T
|
2020-07-09 04:31:08 +05:30
|
|
|
|
|
|
|
end interface
|
2020-07-12 20:14:26 +05:30
|
|
|
|
2020-07-09 04:31:08 +05:30
|
|
|
contains
|
|
|
|
|
2020-07-12 20:14:26 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2022-06-24 10:34:52 +05:30
|
|
|
!< @brief Initializes thermal sources and kinematics mechanism.
|
2020-07-12 20:14:26 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2020-12-30 17:04:00 +05:30
|
|
|
module subroutine thermal_init(phases)
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2022-10-25 21:39:36 +05:30
|
|
|
type(tDict), pointer :: &
|
2020-12-30 17:04:00 +05:30
|
|
|
phases
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2022-10-25 21:39:36 +05:30
|
|
|
type(tDict), pointer :: &
|
|
|
|
phase, &
|
|
|
|
thermal
|
|
|
|
type(tList), pointer :: &
|
|
|
|
sources
|
2023-09-02 03:00:17 +05:30
|
|
|
character(len=:), allocatable :: &
|
|
|
|
refs, &
|
|
|
|
extmsg
|
2020-12-30 17:04:00 +05:30
|
|
|
integer :: &
|
2021-01-08 02:45:18 +05:30
|
|
|
ph, so, &
|
2021-03-05 01:46:36 +05:30
|
|
|
Nmembers
|
2020-12-30 17:04:00 +05:30
|
|
|
|
|
|
|
|
2021-11-15 23:05:44 +05:30
|
|
|
print'(/,1x,a)', '<<<+- phase:thermal init -+>>>'
|
2020-12-30 17:04:00 +05:30
|
|
|
|
2023-01-18 23:20:01 +05:30
|
|
|
allocate(current(phases%length))
|
2021-03-05 01:46:36 +05:30
|
|
|
allocate(thermalState(phases%length))
|
2021-01-08 02:45:18 +05:30
|
|
|
allocate(thermal_Nsources(phases%length),source = 0)
|
2021-04-11 12:16:31 +05:30
|
|
|
allocate(param(phases%length))
|
2023-09-02 03:00:17 +05:30
|
|
|
extmsg = ''
|
2020-07-09 04:31:08 +05:30
|
|
|
|
2020-12-30 17:04:00 +05:30
|
|
|
do ph = 1, phases%length
|
2023-01-23 13:01:59 +05:30
|
|
|
Nmembers = count(material_ID_phase == ph)
|
2022-02-13 03:08:58 +05:30
|
|
|
allocate(current(ph)%T(Nmembers),source=T_ROOM)
|
2023-06-04 10:52:25 +05:30
|
|
|
allocate(current(ph)%dot_T(Nmembers),source=0.0_pREAL)
|
2022-10-25 21:39:36 +05:30
|
|
|
phase => phases%get_dict(ph)
|
|
|
|
thermal => phase%get_dict('thermal',defaultVal=emptyDict)
|
2021-04-11 17:25:30 +05:30
|
|
|
|
2022-02-13 03:08:58 +05:30
|
|
|
! ToDo: temperature dependency of K and C_p
|
|
|
|
if (thermal%length > 0) then
|
2023-03-01 01:27:44 +05:30
|
|
|
print'(/,1x,a,i0,a)', 'phase ',ph,': '//phases%key(ph)
|
|
|
|
refs = config_listReferences(thermal,indent=3)
|
|
|
|
if (len(refs) > 0) print'(/,1x,a)', refs
|
2023-06-03 20:36:32 +05:30
|
|
|
param(ph)%C_p = thermal%get_asReal('C_p')
|
|
|
|
param(ph)%K(1,1) = thermal%get_asReal('K_11')
|
|
|
|
if (any(phase_lattice(ph) == ['hP','tI'])) param(ph)%K(3,3) = thermal%get_asReal('K_33')
|
2023-07-15 23:58:57 +05:30
|
|
|
param(ph)%K = crystal_symmetrize_33(param(ph)%K,phase_lattice(ph))
|
2022-02-13 03:08:58 +05:30
|
|
|
|
2023-09-02 03:00:17 +05:30
|
|
|
! sanity checks
|
|
|
|
if ( param(ph)%C_p <= 0.0_pREAL ) extmsg = trim(extmsg)//' C_p'
|
|
|
|
if (any(param(ph)%K < 0.0_pREAL)) extmsg = trim(extmsg)//' K'
|
|
|
|
if ( phase_rho(ph) <= 0.0_pREAL ) extmsg = trim(extmsg)//' rho'
|
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
! exit if any parameter is out of range
|
|
|
|
if (extmsg /= '') call IO_error(211,ext_msg=trim(extmsg))
|
|
|
|
|
2022-02-19 23:26:41 +05:30
|
|
|
#if defined(__GFORTRAN__)
|
2023-06-04 10:47:38 +05:30
|
|
|
param(ph)%output = output_as1dStr(thermal)
|
2022-02-19 23:26:41 +05:30
|
|
|
#else
|
2023-06-04 10:47:38 +05:30
|
|
|
param(ph)%output = thermal%get_as1dStr('output',defaultVal=emptyStrArray)
|
2022-02-19 23:26:41 +05:30
|
|
|
#endif
|
2022-10-25 21:39:36 +05:30
|
|
|
sources => thermal%get_list('source',defaultVal=emptyList)
|
2022-02-13 03:08:58 +05:30
|
|
|
thermal_Nsources(ph) = sources%length
|
|
|
|
else
|
|
|
|
thermal_Nsources(ph) = 0
|
|
|
|
end if
|
|
|
|
|
2021-01-08 02:45:18 +05:30
|
|
|
allocate(thermalstate(ph)%p(thermal_Nsources(ph)))
|
2021-04-11 17:25:30 +05:30
|
|
|
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2023-07-18 08:58:44 +05:30
|
|
|
allocate(thermal_source_type(maxval(thermal_Nsources),phases%length), source = UNDEFINED)
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2021-03-05 01:46:36 +05:30
|
|
|
if (maxval(thermal_Nsources) /= 0) then
|
2023-07-18 08:58:44 +05:30
|
|
|
where(source_dissipation_init (maxval(thermal_Nsources))) thermal_source_type = THERMAL_SOURCE_DISSIPATION
|
|
|
|
where(source_externalheat_init(maxval(thermal_Nsources))) thermal_source_type = THERMAL_SOURCE_EXTERNALHEAT
|
2022-06-09 02:36:01 +05:30
|
|
|
end if
|
2020-12-30 14:24:06 +05:30
|
|
|
|
2021-01-08 02:45:18 +05:30
|
|
|
thermal_source_maxSizeDotState = 0
|
2021-03-05 01:46:36 +05:30
|
|
|
do ph = 1,phases%length
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
do so = 1,thermal_Nsources(ph)
|
2021-01-25 18:33:49 +05:30
|
|
|
thermalState(ph)%p(so)%state = thermalState(ph)%p(so)%state0
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2021-01-25 18:33:49 +05:30
|
|
|
thermal_source_maxSizeDotState = max(thermal_source_maxSizeDotState, &
|
|
|
|
maxval(thermalState(ph)%p%sizeDotState))
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2020-07-09 04:31:08 +05:30
|
|
|
end subroutine thermal_init
|
|
|
|
|
|
|
|
|
2020-07-12 20:14:26 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2023-07-18 07:42:57 +05:30
|
|
|
!< @brief Calculate thermal source (forcing term).
|
2020-07-12 20:14:26 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2021-04-25 11:36:52 +05:30
|
|
|
module function phase_f_T(ph,en) result(f)
|
2020-12-29 11:50:37 +05:30
|
|
|
|
2021-04-25 11:36:52 +05:30
|
|
|
integer, intent(in) :: ph, en
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: f
|
2020-07-09 04:31:08 +05:30
|
|
|
|
2021-04-08 02:11:49 +05:30
|
|
|
|
|
|
|
integer :: so
|
2020-08-13 00:44:00 +05:30
|
|
|
|
|
|
|
|
2023-06-04 10:52:25 +05:30
|
|
|
f = 0.0_pREAL
|
2021-01-27 04:14:11 +05:30
|
|
|
|
2021-01-27 04:26:20 +05:30
|
|
|
do so = 1, thermal_Nsources(ph)
|
2023-07-18 08:58:44 +05:30
|
|
|
select case(thermal_source_type(so,ph))
|
2021-04-08 02:11:49 +05:30
|
|
|
|
2023-07-18 08:58:44 +05:30
|
|
|
case (THERMAL_SOURCE_DISSIPATION)
|
2023-07-18 07:42:57 +05:30
|
|
|
f = f + source_dissipation_f_T(ph,en)
|
2020-08-13 00:44:00 +05:30
|
|
|
|
2023-07-18 08:58:44 +05:30
|
|
|
case (THERMAL_SOURCE_EXTERNALHEAT)
|
2023-07-18 07:42:57 +05:30
|
|
|
f = f + source_externalheat_f_T(ph,en)
|
2020-08-13 00:44:00 +05:30
|
|
|
|
2021-01-27 04:26:20 +05:30
|
|
|
end select
|
2021-04-08 02:11:49 +05:30
|
|
|
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
2021-01-27 04:14:11 +05:30
|
|
|
|
2021-04-08 02:11:49 +05:30
|
|
|
end function phase_f_T
|
2020-07-09 04:31:08 +05:30
|
|
|
|
2020-07-15 18:05:21 +05:30
|
|
|
|
2021-01-08 02:45:18 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2022-06-24 10:34:52 +05:30
|
|
|
!> @brief tbd.
|
2021-01-08 02:45:18 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2023-07-18 07:42:57 +05:30
|
|
|
function phase_thermal_collectDotState(ph,en) result(ok)
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2021-04-25 11:36:52 +05:30
|
|
|
integer, intent(in) :: ph, en
|
2023-07-18 07:42:57 +05:30
|
|
|
logical :: ok
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
integer :: i
|
|
|
|
|
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
ok = .true.
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
SourceLoop: do i = 1, thermal_Nsources(ph)
|
|
|
|
|
2023-07-18 08:58:44 +05:30
|
|
|
if (thermal_source_type(i,ph) == THERMAL_SOURCE_EXTERNALHEAT) &
|
2023-07-18 07:42:57 +05:30
|
|
|
call source_externalheat_dotState(ph,en)
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
ok = ok .and. .not. any(IEEE_is_NaN(thermalState(ph)%p(i)%dotState(:,en)))
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2022-06-09 02:36:01 +05:30
|
|
|
end do SourceLoop
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2021-02-09 03:51:53 +05:30
|
|
|
end function phase_thermal_collectDotState
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
|
2021-04-11 16:51:27 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2021-04-15 15:37:33 +05:30
|
|
|
!> @brief Thermal viscosity.
|
2021-04-11 16:51:27 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
module function phase_mu_T(co,ce) result(mu)
|
|
|
|
|
|
|
|
integer, intent(in) :: co, ce
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: mu
|
2021-04-11 16:51:27 +05:30
|
|
|
|
|
|
|
|
2023-01-23 13:01:59 +05:30
|
|
|
mu = phase_rho(material_ID_phase(co,ce)) &
|
|
|
|
* param(material_ID_phase(co,ce))%C_p
|
2021-04-11 16:51:27 +05:30
|
|
|
|
|
|
|
end function phase_mu_T
|
|
|
|
|
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2022-06-24 10:34:52 +05:30
|
|
|
!> @brief Thermal conductivity in reference configuration.
|
2021-04-11 16:51:27 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
module function phase_K_T(co,ce) result(K)
|
|
|
|
|
|
|
|
integer, intent(in) :: co, ce
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL), dimension(3,3) :: K
|
2021-04-11 16:51:27 +05:30
|
|
|
|
|
|
|
|
2023-01-23 13:01:59 +05:30
|
|
|
K = crystallite_push33ToRef(co,ce,param(material_ID_phase(co,ce))%K)
|
2021-04-11 16:51:27 +05:30
|
|
|
|
|
|
|
end function phase_K_T
|
|
|
|
|
|
|
|
|
2021-07-17 00:20:08 +05:30
|
|
|
module function phase_thermal_constitutive(Delta_t,ph,en) result(converged_)
|
2021-01-17 14:00:42 +05:30
|
|
|
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL), intent(in) :: Delta_t
|
2021-04-25 11:36:52 +05:30
|
|
|
integer, intent(in) :: ph, en
|
2021-01-17 14:00:42 +05:30
|
|
|
logical :: converged_
|
|
|
|
|
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
converged_ = integrateThermalState(Delta_t,ph,en)
|
2021-01-17 14:00:42 +05:30
|
|
|
|
2021-07-17 00:20:08 +05:30
|
|
|
end function phase_thermal_constitutive
|
2021-01-17 14:00:42 +05:30
|
|
|
|
2021-01-08 05:10:21 +05:30
|
|
|
|
2021-01-08 02:45:18 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2023-07-18 07:42:57 +05:30
|
|
|
!> @brief Integrate state with 1st order explicit Euler method.
|
2021-01-08 02:45:18 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2023-07-18 07:42:57 +05:30
|
|
|
function integrateThermalState(Delta_t, ph,en) result(converged)
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL), intent(in) :: Delta_t
|
2021-04-25 11:36:52 +05:30
|
|
|
integer, intent(in) :: ph, en
|
2023-07-18 07:42:57 +05:30
|
|
|
logical :: converged
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
integer :: &
|
2021-01-08 05:10:21 +05:30
|
|
|
so, &
|
|
|
|
sizeDotState
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2022-06-24 10:34:52 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
converged = phase_thermal_collectDotState(ph,en)
|
|
|
|
if (converged) then
|
2021-01-08 02:45:18 +05:30
|
|
|
|
2023-07-18 07:42:57 +05:30
|
|
|
do so = 1, thermal_Nsources(ph)
|
|
|
|
sizeDotState = thermalState(ph)%p(so)%sizeDotState
|
|
|
|
thermalState(ph)%p(so)%state(1:sizeDotState,en) = thermalState(ph)%p(so)%state0(1:sizeDotState,en) &
|
|
|
|
+ thermalState(ph)%p(so)%dotState(1:sizeDotState,en) * Delta_t
|
|
|
|
end do
|
|
|
|
|
|
|
|
end if
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
end function integrateThermalState
|
|
|
|
|
|
|
|
|
2022-01-11 01:04:50 +05:30
|
|
|
module subroutine thermal_restartWrite(groupHandle,ph)
|
|
|
|
|
|
|
|
integer(HID_T), intent(in) :: groupHandle
|
|
|
|
integer, intent(in) :: ph
|
|
|
|
|
|
|
|
integer :: so
|
|
|
|
|
2022-02-03 12:28:51 +05:30
|
|
|
|
2022-01-11 01:04:50 +05:30
|
|
|
do so = 1,thermal_Nsources(ph)
|
2022-02-03 03:52:44 +05:30
|
|
|
call HDF5_write(thermalState(ph)%p(so)%state,groupHandle,'omega_thermal')
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
2022-01-11 01:04:50 +05:30
|
|
|
|
|
|
|
end subroutine thermal_restartWrite
|
|
|
|
|
|
|
|
|
|
|
|
module subroutine thermal_restartRead(groupHandle,ph)
|
|
|
|
|
|
|
|
integer(HID_T), intent(in) :: groupHandle
|
|
|
|
integer, intent(in) :: ph
|
|
|
|
|
|
|
|
integer :: so
|
|
|
|
|
2022-02-03 12:28:51 +05:30
|
|
|
|
2022-01-11 01:04:50 +05:30
|
|
|
do so = 1,thermal_Nsources(ph)
|
2022-02-03 03:52:44 +05:30
|
|
|
call HDF5_read(thermalState(ph)%p(so)%state0,groupHandle,'omega_thermal')
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
2022-01-11 01:04:50 +05:30
|
|
|
|
|
|
|
end subroutine thermal_restartRead
|
|
|
|
|
|
|
|
|
2020-12-31 14:24:13 +05:30
|
|
|
module subroutine thermal_forward()
|
|
|
|
|
|
|
|
integer :: ph, so
|
|
|
|
|
|
|
|
|
|
|
|
do ph = 1, size(thermalState)
|
2021-01-08 02:45:18 +05:30
|
|
|
do so = 1, size(thermalState(ph)%p)
|
2020-12-31 14:24:13 +05:30
|
|
|
thermalState(ph)%p(so)%state0 = thermalState(ph)%p(so)%state
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
|
|
|
end do
|
2020-12-31 14:24:13 +05:30
|
|
|
|
|
|
|
end subroutine thermal_forward
|
|
|
|
|
|
|
|
|
2020-12-30 18:27:37 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2023-07-18 07:42:57 +05:30
|
|
|
!< @brief Get temperature (for use by non-thermal physics).
|
2020-12-30 18:27:37 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2021-12-20 02:37:23 +05:30
|
|
|
pure module function thermal_T(ph,en) result(T)
|
2020-12-30 14:24:06 +05:30
|
|
|
|
2021-04-25 11:36:52 +05:30
|
|
|
integer, intent(in) :: ph, en
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: T
|
2020-12-30 14:24:06 +05:30
|
|
|
|
|
|
|
|
2021-04-25 11:36:52 +05:30
|
|
|
T = current(ph)%T(en)
|
2020-12-30 14:24:06 +05:30
|
|
|
|
2020-12-30 17:04:00 +05:30
|
|
|
end function thermal_T
|
2020-12-30 14:24:06 +05:30
|
|
|
|
|
|
|
|
2021-01-27 04:36:41 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2023-07-18 07:42:57 +05:30
|
|
|
!< @brief Get rate of temperature (for use by non-thermal physics).
|
2021-01-27 04:36:41 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2021-04-25 11:36:52 +05:30
|
|
|
module function thermal_dot_T(ph,en) result(dot_T)
|
2021-01-27 04:36:41 +05:30
|
|
|
|
2021-04-25 11:36:52 +05:30
|
|
|
integer, intent(in) :: ph, en
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL) :: dot_T
|
2021-01-27 04:36:41 +05:30
|
|
|
|
|
|
|
|
2021-04-25 11:36:52 +05:30
|
|
|
dot_T = current(ph)%dot_T(en)
|
2021-01-27 04:36:41 +05:30
|
|
|
|
|
|
|
end function thermal_dot_T
|
|
|
|
|
|
|
|
|
2020-12-30 18:27:37 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
|
|
|
!< @brief Set temperature
|
|
|
|
!----------------------------------------------------------------------------------------------
|
2021-02-09 03:51:53 +05:30
|
|
|
module subroutine phase_thermal_setField(T,dot_T, co,ce)
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2023-06-04 10:52:25 +05:30
|
|
|
real(pREAL), intent(in) :: T, dot_T
|
2021-01-17 19:22:52 +05:30
|
|
|
integer, intent(in) :: ce, co
|
2020-12-30 18:27:37 +05:30
|
|
|
|
|
|
|
|
2023-01-23 13:01:59 +05:30
|
|
|
current(material_ID_phase(co,ce))%T(material_entry_phase(co,ce)) = T
|
|
|
|
current(material_ID_phase(co,ce))%dot_T(material_entry_phase(co,ce)) = dot_T
|
2020-12-30 18:27:37 +05:30
|
|
|
|
2021-02-09 03:51:53 +05:30
|
|
|
end subroutine phase_thermal_setField
|
2020-12-30 16:30:47 +05:30
|
|
|
|
|
|
|
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief checks if a source mechanism is active or not
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
function thermal_active(source_label,src_length) result(active_source)
|
|
|
|
|
|
|
|
character(len=*), intent(in) :: source_label !< name of source mechanism
|
|
|
|
integer, intent(in) :: src_length !< max. number of sources in system
|
|
|
|
logical, dimension(:,:), allocatable :: active_source
|
|
|
|
|
2022-10-25 21:39:36 +05:30
|
|
|
type(tDict), pointer :: &
|
2021-01-08 02:45:18 +05:30
|
|
|
phases, &
|
|
|
|
phase, &
|
2022-10-25 21:39:36 +05:30
|
|
|
thermal, &
|
2021-01-08 02:45:18 +05:30
|
|
|
src
|
2022-10-25 21:39:36 +05:30
|
|
|
type(tList), pointer :: &
|
|
|
|
sources
|
2021-01-08 02:45:18 +05:30
|
|
|
integer :: p,s
|
|
|
|
|
2022-10-25 21:39:36 +05:30
|
|
|
phases => config_material%get_dict('phase')
|
2021-01-08 02:45:18 +05:30
|
|
|
allocate(active_source(src_length,phases%length), source = .false. )
|
|
|
|
do p = 1, phases%length
|
2022-10-25 21:39:36 +05:30
|
|
|
phase => phases%get_dict(p)
|
|
|
|
thermal => phase%get_dict('thermal',defaultVal=emptyDict)
|
|
|
|
sources => thermal%get_list('source',defaultVal=emptyList)
|
2021-03-05 01:46:36 +05:30
|
|
|
do s = 1, sources%length
|
2022-10-25 21:39:36 +05:30
|
|
|
src => sources%get_dict(s)
|
2023-06-04 10:47:38 +05:30
|
|
|
active_source(s,p) = src%get_asStr('type') == source_label
|
2022-06-09 02:36:01 +05:30
|
|
|
end do
|
|
|
|
end do
|
2021-01-08 02:45:18 +05:30
|
|
|
|
|
|
|
|
|
|
|
end function thermal_active
|
|
|
|
|
|
|
|
|
2022-02-19 23:26:41 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2023-01-19 22:07:45 +05:30
|
|
|
!< @brief Write thermal sources results to HDF5 output file.
|
2022-02-19 23:26:41 +05:30
|
|
|
!----------------------------------------------------------------------------------------------
|
2023-01-19 22:07:45 +05:30
|
|
|
module subroutine thermal_result(group,ph)
|
2022-02-19 23:26:41 +05:30
|
|
|
|
|
|
|
character(len=*), intent(in) :: group
|
|
|
|
integer, intent(in) :: ph
|
|
|
|
|
|
|
|
|
|
|
|
integer :: ou
|
|
|
|
|
2022-02-23 03:46:14 +05:30
|
|
|
if (.not. allocated(param(ph)%output)) return
|
|
|
|
|
2023-01-19 22:07:45 +05:30
|
|
|
call result_closeGroup(result_addGroup(group//'thermal'))
|
2022-02-19 23:26:41 +05:30
|
|
|
|
|
|
|
do ou = 1, size(param(ph)%output)
|
|
|
|
|
|
|
|
select case(trim(param(ph)%output(ou)))
|
|
|
|
|
|
|
|
case ('T')
|
2023-01-19 22:07:45 +05:30
|
|
|
call result_writeDataset(current(ph)%T,group//'thermal','T', 'temperature','K')
|
2022-02-19 23:26:41 +05:30
|
|
|
|
|
|
|
end select
|
|
|
|
|
|
|
|
end do
|
|
|
|
|
2023-01-19 22:07:45 +05:30
|
|
|
end subroutine thermal_result
|
2022-02-19 23:26:41 +05:30
|
|
|
|
|
|
|
|
2021-01-26 05:50:45 +05:30
|
|
|
end submodule thermal
|