polishing

This commit is contained in:
Martin Diehl 2021-11-18 12:46:37 +01:00
parent 0badba032b
commit eee455c0d3
3 changed files with 33 additions and 29 deletions

View File

@ -2,12 +2,12 @@ submodule(phase:mechanical) elastic
type :: tParameters type :: tParameters
real(pReal) :: & real(pReal) :: &
C_11, & C_11 = 0.0_pReal, &
C_12, & C_12 = 0.0_pReal, &
C_13, & C_13 = 0.0_pReal, &
C_33, & C_33 = 0.0_pReal, &
C_44, & C_44 = 0.0_pReal, &
C_66 C_66 = 0.0_pReal
end type tParameters end type tParameters
type(tParameters), allocatable, dimension(:) :: param type(tParameters), allocatable, dimension(:) :: param
@ -15,7 +15,7 @@ submodule(phase:mechanical) elastic
contains contains
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
!> @brief Initialize elasticity !> @brief Initialize elasticity.
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
module subroutine elastic_init(phases) module subroutine elastic_init(phases)
@ -60,9 +60,9 @@ module subroutine elastic_init(phases)
end subroutine elastic_init end subroutine elastic_init
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
!> @brief returns 6x6 elasticity tensor !> @brief Return 6x6 elasticity tensor.
! internal function call to return dynamic values of the elasticity tensor
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
function get_C66(ph,en) function get_C66(ph,en)
@ -71,6 +71,7 @@ function get_C66(ph,en)
en en
real(pReal), dimension(6,6) :: get_C66 real(pReal), dimension(6,6) :: get_C66
associate(prm => param(ph)) associate(prm => param(ph))
get_C66 = 0.0_pReal get_C66 = 0.0_pReal
get_C66(1,1) = prm%C_11 get_C66(1,1) = prm%C_11
@ -82,8 +83,7 @@ function get_C66(ph,en)
get_C66(3,3) = prm%C_33 get_C66(3,3) = prm%C_33
end if end if
if (phase_lattice(ph) == 'tI') & if (phase_lattice(ph) == 'tI') get_C66(6,6) = prm%C_66
get_C66(6,6) = prm%C_66
get_C66 = lattice_symmetrize_C66(get_C66,phase_lattice(ph)) get_C66 = lattice_symmetrize_C66(get_C66,phase_lattice(ph))
@ -91,8 +91,9 @@ function get_C66(ph,en)
end function get_C66 end function get_C66
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
!> @brief returns 6x6 elasticity tensor in Voigt notation !> @brief Return 6x6 elasticity tensor.
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
module function elastic_C66(ph,en) result(C66) module function elastic_C66(ph,en) result(C66)
@ -101,6 +102,8 @@ module function elastic_C66(ph,en) result(C66)
en en
real(pReal), dimension(6,6) :: & real(pReal), dimension(6,6) :: &
C66 C66
associate(prm => param(ph)) associate(prm => param(ph))
C66 = get_C66(ph,en) C66 = get_C66(ph,en)
@ -110,8 +113,9 @@ module function elastic_C66(ph,en) result(C66)
end function elastic_C66 end function elastic_C66
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
!> @brief returns value of shear modulus !> @brief Return shear modulus.
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
module function elastic_mu(ph,en) result(mu) module function elastic_mu(ph,en) result(mu)
@ -121,12 +125,13 @@ module function elastic_mu(ph,en) result(mu)
real(pReal) :: & real(pReal) :: &
mu mu
mu = lattice_equivalent_mu(get_C66(ph,en),'voigt') mu = lattice_equivalent_mu(get_C66(ph,en),'voigt')
end function elastic_mu end function elastic_mu
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
!> @brief returns value of poisson ratio !> @brief Return Poisson ratio.
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
module function elastic_nu(ph,en) result(nu) module function elastic_nu(ph,en) result(nu)
@ -136,6 +141,7 @@ module function elastic_nu(ph,en) result(nu)
real(pReal) :: & real(pReal) :: &
nu nu
nu = lattice_equivalent_nu(get_C66(ph,en),'voigt') nu = lattice_equivalent_nu(get_C66(ph,en),'voigt')
end function elastic_nu end function elastic_nu
@ -190,6 +196,7 @@ module function phase_homogenizedC(ph,en) result(C)
real(pReal), dimension(6,6) :: C real(pReal), dimension(6,6) :: C
integer, intent(in) :: ph, en integer, intent(in) :: ph, en
plasticType: select case (phase_plasticity(ph)) plasticType: select case (phase_plasticity(ph))
case (PLASTICITY_DISLOTWIN_ID) plasticType case (PLASTICITY_DISLOTWIN_ID) plasticType
C = plastic_dislotwin_homogenizedC(ph,en) C = plastic_dislotwin_homogenizedC(ph,en)

View File

@ -372,8 +372,7 @@ module subroutine dislotungsten_dependentState(ph,en)
real(pReal), dimension(param(ph)%sum_N_sl) :: & real(pReal), dimension(param(ph)%sum_N_sl) :: &
Lambda_sl_inv Lambda_sl_inv
real(pReal) :: &
mu
associate(prm => param(ph), stt => state(ph), dst => dependentState(ph)) associate(prm => param(ph), stt => state(ph), dst => dependentState(ph))

View File

@ -791,12 +791,10 @@ module subroutine dislotwin_dependentState(T,ph,en)
dst%V_tr(:,en) = (PI/4.0_pReal)*prm%t_tr*dst%Lambda_tr(:,en)**2.0_pReal dst%V_tr(:,en) = (PI/4.0_pReal)*prm%t_tr*dst%Lambda_tr(:,en)**2.0_pReal
x0 = mu*prm%b_tw**2.0_pReal/(Gamma*8.0_pReal*PI)*(2.0_pReal+nu)/& x0 = mu*prm%b_tw**2.0_pReal/(Gamma*8.0_pReal*PI)*(2.0_pReal+nu)/(1.0_pReal-nu) ! ToDo: In the paper, this is the Burgers vector for slip
(1.0_pReal-nu) ! ToDo: In the paper, this is the Burgers vector for slip
dst%tau_r_tw(:,en) = mu*prm%b_tw/(2.0_pReal*PI)*(1.0_pReal/(x0+prm%x_c_tw)+cos(pi/3.0_pReal)/x0) dst%tau_r_tw(:,en) = mu*prm%b_tw/(2.0_pReal*PI)*(1.0_pReal/(x0+prm%x_c_tw)+cos(pi/3.0_pReal)/x0)
x0 = mu*prm%b_tr**2.0_pReal/(Gamma*8.0_pReal*PI)*(2.0_pReal+nu)/& x0 = mu*prm%b_tr**2.0_pReal/(Gamma*8.0_pReal*PI)*(2.0_pReal+nu)/(1.0_pReal-nu) ! ToDo: In the paper, this is the Burgers vector for slip
(1.0_pReal-nu) ! ToDo: In the paper, this is the Burgers vector for slip
dst%tau_r_tr(:,en) = mu*prm%b_tr/(2.0_pReal*PI)*(1.0_pReal/(x0+prm%x_c_tr)+cos(pi/3.0_pReal)/x0) dst%tau_r_tr(:,en) = mu*prm%b_tr/(2.0_pReal*PI)*(1.0_pReal/(x0+prm%x_c_tr)+cos(pi/3.0_pReal)/x0)
end associate end associate