polishing
This commit is contained in:
parent
0badba032b
commit
eee455c0d3
|
@ -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)
|
||||||
|
|
|
@ -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))
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue