added doxygen documentation and unified variable names and some common parts of the code
This commit is contained in:
parent
c496288144
commit
82faf74363
File diff suppressed because it is too large
Load Diff
|
@ -36,10 +36,10 @@ module constitutive_j2
|
||||||
character (len=*), parameter, public :: &
|
character (len=*), parameter, public :: &
|
||||||
CONSTITUTIVE_J2_label = 'j2' !< label for this constitutive model
|
CONSTITUTIVE_J2_label = 'j2' !< label for this constitutive model
|
||||||
|
|
||||||
integer(pInt), dimension(:), allocatable, public :: &
|
integer(pInt), dimension(:), allocatable, public, protected :: &
|
||||||
constitutive_j2_sizeDotState, &
|
constitutive_j2_sizeDotState, & !< number of dotStates
|
||||||
constitutive_j2_sizeState, &
|
constitutive_j2_sizeState, & !< total number of microstructural variables
|
||||||
constitutive_j2_sizePostResults
|
constitutive_j2_sizePostResults !< cumulative size of post results
|
||||||
|
|
||||||
integer(pInt), dimension(:,:), allocatable, target, public :: &
|
integer(pInt), dimension(:,:), allocatable, target, public :: &
|
||||||
constitutive_j2_sizePostResult !< size of each post result output
|
constitutive_j2_sizePostResult !< size of each post result output
|
||||||
|
@ -48,10 +48,10 @@ module constitutive_j2
|
||||||
constitutive_j2_output !< name of each post result output
|
constitutive_j2_output !< name of each post result output
|
||||||
|
|
||||||
character(len=32), dimension(:), allocatable, private :: &
|
character(len=32), dimension(:), allocatable, private :: &
|
||||||
constitutive_j2_structureName
|
constitutive_j2_structureName !< name of the lattice structure
|
||||||
|
|
||||||
integer(pInt), dimension(:), allocatable, private :: &
|
integer(pInt), dimension(:), allocatable, private :: &
|
||||||
constitutive_j2_Noutput !< ??
|
constitutive_j2_Noutput !< number of outputs per instance
|
||||||
|
|
||||||
real(pReal), dimension(:), allocatable, private :: &
|
real(pReal), dimension(:), allocatable, private :: &
|
||||||
constitutive_j2_fTaylor, & !< Taylor factor
|
constitutive_j2_fTaylor, & !< Taylor factor
|
||||||
|
@ -313,13 +313,13 @@ end subroutine constitutive_j2_init
|
||||||
!> @brief sets the initial microstructural state for a given instance of this plasticity
|
!> @brief sets the initial microstructural state for a given instance of this plasticity
|
||||||
!> @details initial microstructural state is set to the value specified by tau0
|
!> @details initial microstructural state is set to the value specified by tau0
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function constitutive_j2_stateInit(myInstance)
|
pure function constitutive_j2_stateInit(matID)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
real(pReal), dimension(1) :: constitutive_j2_stateInit
|
real(pReal), dimension(1) :: constitutive_j2_stateInit
|
||||||
integer(pInt), intent(in) :: myInstance !< number specifying the instance of the plasticity
|
integer(pInt), intent(in) :: matID !< number specifying the instance of the plasticity
|
||||||
|
|
||||||
constitutive_j2_stateInit = constitutive_j2_tau0(myInstance)
|
constitutive_j2_stateInit = constitutive_j2_tau0(matID)
|
||||||
|
|
||||||
end function constitutive_j2_stateInit
|
end function constitutive_j2_stateInit
|
||||||
|
|
||||||
|
@ -327,15 +327,15 @@ end function constitutive_j2_stateInit
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief sets the relevant state values for a given instance of this plasticity
|
!> @brief sets the relevant state values for a given instance of this plasticity
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function constitutive_j2_aTolState(myInstance)
|
pure function constitutive_j2_aTolState(matID)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
integer(pInt), intent(in) :: myInstance !< number specifying the instance of the plasticity
|
integer(pInt), intent(in) :: matID !< number specifying the instance of the plasticity
|
||||||
|
|
||||||
real(pReal), dimension(constitutive_j2_sizeState(myInstance)) :: &
|
real(pReal), dimension(constitutive_j2_sizeState(matID)) :: &
|
||||||
constitutive_j2_aTolState
|
constitutive_j2_aTolState
|
||||||
|
|
||||||
constitutive_j2_aTolState = constitutive_j2_aTolResistance(myInstance)
|
constitutive_j2_aTolState = constitutive_j2_aTolResistance(matID)
|
||||||
|
|
||||||
end function constitutive_j2_aTolState
|
end function constitutive_j2_aTolState
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,7 @@ module constitutive_none
|
||||||
character (len=*), parameter, public :: &
|
character (len=*), parameter, public :: &
|
||||||
CONSTITUTIVE_NONE_label = 'none' !< label for this constitutive model
|
CONSTITUTIVE_NONE_label = 'none' !< label for this constitutive model
|
||||||
|
|
||||||
integer(pInt), dimension(:), allocatable, public :: &
|
integer(pInt), dimension(:), allocatable, public, protected :: &
|
||||||
constitutive_none_sizeDotState, &
|
constitutive_none_sizeDotState, &
|
||||||
constitutive_none_sizeState, &
|
constitutive_none_sizeState, &
|
||||||
constitutive_none_sizePostResults
|
constitutive_none_sizePostResults
|
||||||
|
@ -193,11 +193,11 @@ end subroutine constitutive_none_init
|
||||||
!> @brief sets the initial microstructural state for a given instance of this plasticity
|
!> @brief sets the initial microstructural state for a given instance of this plasticity
|
||||||
!> @details dummy function, returns 0.0
|
!> @details dummy function, returns 0.0
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function constitutive_none_stateInit(myInstance)
|
pure function constitutive_none_stateInit(matID)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
real(pReal), dimension(1) :: constitutive_none_stateInit
|
real(pReal), dimension(1) :: constitutive_none_stateInit
|
||||||
integer(pInt), intent(in) :: myInstance !< number specifying the instance of the plasticity
|
integer(pInt), intent(in) :: matID !< number specifying the instance of the plasticity
|
||||||
|
|
||||||
constitutive_none_stateInit = 0.0_pReal
|
constitutive_none_stateInit = 0.0_pReal
|
||||||
|
|
||||||
|
@ -208,12 +208,12 @@ end function constitutive_none_stateInit
|
||||||
!> @brief sets the relevant state values for a given instance of this plasticity
|
!> @brief sets the relevant state values for a given instance of this plasticity
|
||||||
!> @details ensures convergence as state is always 0.0
|
!> @details ensures convergence as state is always 0.0
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function constitutive_none_aTolState(myInstance)
|
pure function constitutive_none_aTolState(matID)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
integer(pInt), intent(in) :: myInstance !< number specifying the instance of the plasticity
|
integer(pInt), intent(in) :: matID !< number specifying the instance of the plasticity
|
||||||
|
|
||||||
real(pReal), dimension(constitutive_none_sizeState(myInstance)) :: &
|
real(pReal), dimension(constitutive_none_sizeState(matID)) :: &
|
||||||
constitutive_none_aTolState
|
constitutive_none_aTolState
|
||||||
|
|
||||||
constitutive_none_aTolState = 1.0_pReal
|
constitutive_none_aTolState = 1.0_pReal
|
||||||
|
|
|
@ -76,7 +76,7 @@ KB = 1.38e-23_pReal !< Physical
|
||||||
|
|
||||||
!* Definition of global variables
|
!* Definition of global variables
|
||||||
|
|
||||||
integer(pInt), dimension(:), allocatable, public :: &
|
integer(pInt), dimension(:), allocatable, public, protected :: &
|
||||||
constitutive_nonlocal_sizeDotState, & !< number of dotStates = number of basic state variables
|
constitutive_nonlocal_sizeDotState, & !< number of dotStates = number of basic state variables
|
||||||
constitutive_nonlocal_sizeDependentState, & !< number of dependent state variables
|
constitutive_nonlocal_sizeDependentState, & !< number of dependent state variables
|
||||||
constitutive_nonlocal_sizeState, & !< total number of state variables
|
constitutive_nonlocal_sizeState, & !< total number of state variables
|
||||||
|
|
|
@ -34,7 +34,7 @@ module constitutive_phenopowerlaw
|
||||||
character (len=*), parameter, public :: &
|
character (len=*), parameter, public :: &
|
||||||
CONSTITUTIVE_PHENOPOWERLAW_label = 'phenopowerlaw'
|
CONSTITUTIVE_PHENOPOWERLAW_label = 'phenopowerlaw'
|
||||||
|
|
||||||
integer(pInt), dimension(:), allocatable, public :: &
|
integer(pInt), dimension(:), allocatable, public, protected :: &
|
||||||
constitutive_phenopowerlaw_sizeDotState, &
|
constitutive_phenopowerlaw_sizeDotState, &
|
||||||
constitutive_phenopowerlaw_sizeState, &
|
constitutive_phenopowerlaw_sizeState, &
|
||||||
constitutive_phenopowerlaw_sizePostResults, & !< cumulative size of post results
|
constitutive_phenopowerlaw_sizePostResults, & !< cumulative size of post results
|
||||||
|
@ -142,7 +142,7 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
i,j,k, f,o, &
|
i,j,k, f,o, &
|
||||||
Nchunks_SlipSlip, Nchunks_SlipTwin, Nchunks_TwinSlip, Nchunks_TwinTwin, &
|
Nchunks_SlipSlip, Nchunks_SlipTwin, Nchunks_TwinSlip, Nchunks_TwinTwin, &
|
||||||
Nchunks_SlipFamilies, Nchunks_TwinFamilies, Nchunks_nonSchmid, &
|
Nchunks_SlipFamilies, Nchunks_TwinFamilies, Nchunks_nonSchmid, &
|
||||||
myStructure, index_myFamily, index_otherFamily, &
|
structID, index_myFamily, index_otherFamily, &
|
||||||
mySize=0_pInt, section = 0_pInt
|
mySize=0_pInt, section = 0_pInt
|
||||||
character(len=65536) :: &
|
character(len=65536) :: &
|
||||||
tag = '', &
|
tag = '', &
|
||||||
|
@ -419,14 +419,15 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
sanityChecks: do i = 1_pInt,maxNinstance
|
sanityChecks: do i = 1_pInt,maxNinstance
|
||||||
constitutive_phenopowerlaw_structure(i) = lattice_initializeStructure(constitutive_phenopowerlaw_structureName(i), & ! get structure
|
constitutive_phenopowerlaw_structure(i) = &
|
||||||
constitutive_phenopowerlaw_CoverA(i))
|
lattice_initializeStructure(constitutive_phenopowerlaw_structureName(i), constitutive_phenopowerlaw_CoverA(i)) ! get structure
|
||||||
|
|
||||||
constitutive_phenopowerlaw_Nslip(1:lattice_maxNslipFamily,i) = &
|
constitutive_phenopowerlaw_Nslip(1:lattice_maxNslipFamily,i) = &
|
||||||
min(lattice_NslipSystem(1:lattice_maxNslipFamily,constitutive_phenopowerlaw_structure(i)),& ! limit active slip systems per family to min of available and requested
|
min(lattice_NslipSystem(1:lattice_maxNslipFamily,constitutive_phenopowerlaw_structure(i)),& ! limit active slip systems per family to min of available and requested
|
||||||
constitutive_phenopowerlaw_Nslip(1:lattice_maxNslipFamily,i))
|
constitutive_phenopowerlaw_Nslip(1:lattice_maxNslipFamily,i))
|
||||||
constitutive_phenopowerlaw_Ntwin(1:lattice_maxNtwinFamily,i) = &
|
constitutive_phenopowerlaw_Ntwin(1:lattice_maxNtwinFamily,i) = &
|
||||||
min(lattice_NtwinSystem(1:lattice_maxNtwinFamily,constitutive_phenopowerlaw_structure(i)),& ! limit active twin systems per family to min of available and requested
|
min(lattice_NtwinSystem(1:lattice_maxNtwinFamily,constitutive_phenopowerlaw_structure(i)),& ! limit active twin systems per family to min of available and requested
|
||||||
constitutive_phenopowerlaw_Ntwin(:,i))
|
constitutive_phenopowerlaw_Ntwin(:,i))
|
||||||
constitutive_phenopowerlaw_totalNslip(i) = sum(constitutive_phenopowerlaw_Nslip(:,i)) ! how many slip systems altogether
|
constitutive_phenopowerlaw_totalNslip(i) = sum(constitutive_phenopowerlaw_Nslip(:,i)) ! how many slip systems altogether
|
||||||
constitutive_phenopowerlaw_totalNtwin(i) = sum(constitutive_phenopowerlaw_Ntwin(:,i)) ! how many twin systems altogether
|
constitutive_phenopowerlaw_totalNtwin(i) = sum(constitutive_phenopowerlaw_Ntwin(:,i)) ! how many twin systems altogether
|
||||||
|
|
||||||
|
@ -504,11 +505,10 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
call IO_error(212_pInt,ext_msg=constitutive_phenopowerlaw_output(o,i)//' ('//CONSTITUTIVE_PHENOPOWERLAW_label//')')
|
call IO_error(212_pInt,ext_msg=constitutive_phenopowerlaw_output(o,i)//' ('//CONSTITUTIVE_PHENOPOWERLAW_label//')')
|
||||||
end select
|
end select
|
||||||
|
|
||||||
if (mySize > 0_pInt) then ! any meaningful output found
|
outputFound: if (mySize > 0_pInt) then
|
||||||
constitutive_phenopowerlaw_sizePostResult(o,i) = mySize
|
constitutive_phenopowerlaw_sizePostResult(o,i) = mySize
|
||||||
constitutive_phenopowerlaw_sizePostResults(i) = &
|
constitutive_phenopowerlaw_sizePostResults(i) = constitutive_phenopowerlaw_sizePostResults(i) + mySize
|
||||||
constitutive_phenopowerlaw_sizePostResults(i) + mySize
|
endif outputFound
|
||||||
endif
|
|
||||||
enddo outputsLoop
|
enddo outputsLoop
|
||||||
|
|
||||||
constitutive_phenopowerlaw_sizeDotState(i) = constitutive_phenopowerlaw_totalNslip(i)+ &
|
constitutive_phenopowerlaw_sizeDotState(i) = constitutive_phenopowerlaw_totalNslip(i)+ &
|
||||||
|
@ -518,11 +518,12 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
constitutive_phenopowerlaw_totalNtwin(i) ! s_slip, s_twin, sum(gamma), sum(f), accshear_slip, accshear_twin
|
constitutive_phenopowerlaw_totalNtwin(i) ! s_slip, s_twin, sum(gamma), sum(f), accshear_slip, accshear_twin
|
||||||
constitutive_phenopowerlaw_sizeState(i) = constitutive_phenopowerlaw_sizeDotState(i)
|
constitutive_phenopowerlaw_sizeState(i) = constitutive_phenopowerlaw_sizeDotState(i)
|
||||||
|
|
||||||
myStructure = constitutive_phenopowerlaw_structure(i)
|
structID = constitutive_phenopowerlaw_structure(i)
|
||||||
|
|
||||||
|
constitutive_phenopowerlaw_Cslip_66(:,:,i) = &
|
||||||
|
lattice_symmetrizeC66(constitutive_phenopowerlaw_structureName(i),&
|
||||||
|
constitutive_phenopowerlaw_Cslip_66(:,:,i)) ! assign elasticity tensor
|
||||||
|
|
||||||
constitutive_phenopowerlaw_Cslip_66(:,:,i) = lattice_symmetrizeC66(constitutive_phenopowerlaw_structureName(i),&
|
|
||||||
constitutive_phenopowerlaw_Cslip_66(:,:,i))
|
|
||||||
! assign elasticity tensor
|
|
||||||
constitutive_phenopowerlaw_Cslip_66(:,:,i) = &
|
constitutive_phenopowerlaw_Cslip_66(:,:,i) = &
|
||||||
math_Mandel3333to66(math_Voigt66to3333(constitutive_phenopowerlaw_Cslip_66(:,:,i)))
|
math_Mandel3333to66(math_Voigt66to3333(constitutive_phenopowerlaw_Cslip_66(:,:,i)))
|
||||||
|
|
||||||
|
@ -534,9 +535,9 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
do k = 1_pInt,constitutive_phenopowerlaw_Nslip(o,i) ! loop over (active) systems in other family (slip)
|
do k = 1_pInt,constitutive_phenopowerlaw_Nslip(o,i) ! loop over (active) systems in other family (slip)
|
||||||
constitutive_phenopowerlaw_hardeningMatrix_SlipSlip(index_myFamily+j,index_otherFamily+k,i) = &
|
constitutive_phenopowerlaw_hardeningMatrix_SlipSlip(index_myFamily+j,index_otherFamily+k,i) = &
|
||||||
constitutive_phenopowerlaw_interaction_SlipSlip(lattice_interactionSlipSlip( &
|
constitutive_phenopowerlaw_interaction_SlipSlip(lattice_interactionSlipSlip( &
|
||||||
sum(lattice_NslipSystem(1:f-1,myStructure))+j, &
|
sum(lattice_NslipSystem(1:f-1,structID))+j, &
|
||||||
sum(lattice_NslipSystem(1:o-1,myStructure))+k, &
|
sum(lattice_NslipSystem(1:o-1,structID))+k, &
|
||||||
myStructure), i )
|
structID), i )
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
|
||||||
do o = 1_pInt,lattice_maxNtwinFamily
|
do o = 1_pInt,lattice_maxNtwinFamily
|
||||||
|
@ -544,9 +545,9 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
do k = 1_pInt,constitutive_phenopowerlaw_Ntwin(o,i) ! loop over (active) systems in other family (twin)
|
do k = 1_pInt,constitutive_phenopowerlaw_Ntwin(o,i) ! loop over (active) systems in other family (twin)
|
||||||
constitutive_phenopowerlaw_hardeningMatrix_SlipTwin(index_myFamily+j,index_otherFamily+k,i) = &
|
constitutive_phenopowerlaw_hardeningMatrix_SlipTwin(index_myFamily+j,index_otherFamily+k,i) = &
|
||||||
constitutive_phenopowerlaw_interaction_SlipTwin(lattice_interactionSlipTwin( &
|
constitutive_phenopowerlaw_interaction_SlipTwin(lattice_interactionSlipTwin( &
|
||||||
sum(lattice_NslipSystem(1:f-1_pInt,myStructure))+j, &
|
sum(lattice_NslipSystem(1:f-1_pInt,structID))+j, &
|
||||||
sum(lattice_NtwinSystem(1:o-1_pInt,myStructure))+k, &
|
sum(lattice_NtwinSystem(1:o-1_pInt,structID))+k, &
|
||||||
myStructure), i )
|
structID), i )
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
@ -560,9 +561,9 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
do k = 1_pInt,constitutive_phenopowerlaw_Nslip(o,i) ! loop over (active) systems in other family (slip)
|
do k = 1_pInt,constitutive_phenopowerlaw_Nslip(o,i) ! loop over (active) systems in other family (slip)
|
||||||
constitutive_phenopowerlaw_hardeningMatrix_TwinSlip(index_myFamily+j,index_otherFamily+k,i) = &
|
constitutive_phenopowerlaw_hardeningMatrix_TwinSlip(index_myFamily+j,index_otherFamily+k,i) = &
|
||||||
constitutive_phenopowerlaw_interaction_TwinSlip(lattice_interactionTwinSlip( &
|
constitutive_phenopowerlaw_interaction_TwinSlip(lattice_interactionTwinSlip( &
|
||||||
sum(lattice_NtwinSystem(1:f-1_pInt,myStructure))+j, &
|
sum(lattice_NtwinSystem(1:f-1_pInt,structID))+j, &
|
||||||
sum(lattice_NslipSystem(1:o-1_pInt,myStructure))+k, &
|
sum(lattice_NslipSystem(1:o-1_pInt,structID))+k, &
|
||||||
myStructure), i )
|
structID), i )
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
|
||||||
do o = 1_pInt,lattice_maxNtwinFamily
|
do o = 1_pInt,lattice_maxNtwinFamily
|
||||||
|
@ -570,9 +571,9 @@ subroutine constitutive_phenopowerlaw_init(myFile)
|
||||||
do k = 1_pInt,constitutive_phenopowerlaw_Ntwin(o,i) ! loop over (active) systems in other family (twin)
|
do k = 1_pInt,constitutive_phenopowerlaw_Ntwin(o,i) ! loop over (active) systems in other family (twin)
|
||||||
constitutive_phenopowerlaw_hardeningMatrix_TwinTwin(index_myFamily+j,index_otherFamily+k,i) = &
|
constitutive_phenopowerlaw_hardeningMatrix_TwinTwin(index_myFamily+j,index_otherFamily+k,i) = &
|
||||||
constitutive_phenopowerlaw_interaction_TwinTwin(lattice_interactionTwinTwin( &
|
constitutive_phenopowerlaw_interaction_TwinTwin(lattice_interactionTwinTwin( &
|
||||||
sum(lattice_NtwinSystem(1:f-1_pInt,myStructure))+j, &
|
sum(lattice_NtwinSystem(1:f-1_pInt,structID))+j, &
|
||||||
sum(lattice_NtwinSystem(1:o-1_pInt,myStructure))+k, &
|
sum(lattice_NtwinSystem(1:o-1_pInt,structID))+k, &
|
||||||
myStructure), i )
|
structID), i )
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
@ -585,15 +586,15 @@ end subroutine constitutive_phenopowerlaw_init
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief sets the initial microstructural state for a given instance of this plasticity
|
!> @brief sets the initial microstructural state for a given instance of this plasticity
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function constitutive_phenopowerlaw_stateInit(myInstance)
|
pure function constitutive_phenopowerlaw_stateInit(matID)
|
||||||
use lattice, only: &
|
use lattice, only: &
|
||||||
lattice_maxNslipFamily, &
|
lattice_maxNslipFamily, &
|
||||||
lattice_maxNtwinFamily
|
lattice_maxNtwinFamily
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
integer(pInt), intent(in) :: &
|
integer(pInt), intent(in) :: &
|
||||||
myInstance !< number specifying the instance of the plasticity
|
matID !< number specifying the instance of the plasticity
|
||||||
real(pReal), dimension(constitutive_phenopowerlaw_sizeDotState(myInstance)) :: &
|
real(pReal), dimension(constitutive_phenopowerlaw_sizeDotState(matID)) :: &
|
||||||
constitutive_phenopowerlaw_stateInit
|
constitutive_phenopowerlaw_stateInit
|
||||||
integer(pInt) :: &
|
integer(pInt) :: &
|
||||||
i
|
i
|
||||||
|
@ -602,17 +603,17 @@ pure function constitutive_phenopowerlaw_stateInit(myInstance)
|
||||||
|
|
||||||
do i = 1_pInt,lattice_maxNslipFamily
|
do i = 1_pInt,lattice_maxNslipFamily
|
||||||
constitutive_phenopowerlaw_stateInit(1+&
|
constitutive_phenopowerlaw_stateInit(1+&
|
||||||
sum(constitutive_phenopowerlaw_Nslip(1:i-1,myInstance)) : &
|
sum(constitutive_phenopowerlaw_Nslip(1:i-1,matID)) : &
|
||||||
sum(constitutive_phenopowerlaw_Nslip(1:i ,myInstance))) = &
|
sum(constitutive_phenopowerlaw_Nslip(1:i ,matID))) = &
|
||||||
constitutive_phenopowerlaw_tau0_slip(i,myInstance)
|
constitutive_phenopowerlaw_tau0_slip(i,matID)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
do i = 1_pInt,lattice_maxNtwinFamily
|
do i = 1_pInt,lattice_maxNtwinFamily
|
||||||
constitutive_phenopowerlaw_stateInit(1+sum(constitutive_phenopowerlaw_Nslip(:,myInstance))+&
|
constitutive_phenopowerlaw_stateInit(1+sum(constitutive_phenopowerlaw_Nslip(:,matID))+&
|
||||||
sum(constitutive_phenopowerlaw_Ntwin(1:i-1,myInstance)) : &
|
sum(constitutive_phenopowerlaw_Ntwin(1:i-1,matID)) : &
|
||||||
sum(constitutive_phenopowerlaw_Nslip(:,myInstance))+&
|
sum(constitutive_phenopowerlaw_Nslip(:,matID))+&
|
||||||
sum(constitutive_phenopowerlaw_Ntwin(1:i ,myInstance))) = &
|
sum(constitutive_phenopowerlaw_Ntwin(1:i ,matID))) = &
|
||||||
constitutive_phenopowerlaw_tau0_twin(i,myInstance)
|
constitutive_phenopowerlaw_tau0_twin(i,matID)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
end function constitutive_phenopowerlaw_stateInit
|
end function constitutive_phenopowerlaw_stateInit
|
||||||
|
@ -621,28 +622,28 @@ end function constitutive_phenopowerlaw_stateInit
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief sets the relevant state values for a given instance of this plasticity
|
!> @brief sets the relevant state values for a given instance of this plasticity
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
pure function constitutive_phenopowerlaw_aTolState(myInstance)
|
pure function constitutive_phenopowerlaw_aTolState(matID)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
integer(pInt), intent(in) :: myInstance !< number specifying the instance of the plasticity
|
integer(pInt), intent(in) :: matID !< number specifying the instance of the plasticity
|
||||||
|
|
||||||
real(pReal), dimension(constitutive_phenopowerlaw_sizeState(myInstance)) :: &
|
real(pReal), dimension(constitutive_phenopowerlaw_sizeState(matID)) :: &
|
||||||
constitutive_phenopowerlaw_aTolState
|
constitutive_phenopowerlaw_aTolState
|
||||||
|
|
||||||
constitutive_phenopowerlaw_aTolState(1:constitutive_phenopowerlaw_totalNslip(myInstance)+ &
|
constitutive_phenopowerlaw_aTolState(1:constitutive_phenopowerlaw_totalNslip(matID)+ &
|
||||||
constitutive_phenopowerlaw_totalNtwin(myInstance)) = &
|
constitutive_phenopowerlaw_totalNtwin(matID)) = &
|
||||||
constitutive_phenopowerlaw_aTolResistance(myInstance)
|
constitutive_phenopowerlaw_aTolResistance(matID)
|
||||||
constitutive_phenopowerlaw_aTolState(1+constitutive_phenopowerlaw_totalNslip(myInstance)+ &
|
constitutive_phenopowerlaw_aTolState(1+constitutive_phenopowerlaw_totalNslip(matID)+ &
|
||||||
constitutive_phenopowerlaw_totalNtwin(myInstance)) = &
|
constitutive_phenopowerlaw_totalNtwin(matID)) = &
|
||||||
constitutive_phenopowerlaw_aTolShear(myInstance)
|
constitutive_phenopowerlaw_aTolShear(matID)
|
||||||
constitutive_phenopowerlaw_aTolState(2+constitutive_phenopowerlaw_totalNslip(myInstance)+ &
|
constitutive_phenopowerlaw_aTolState(2+constitutive_phenopowerlaw_totalNslip(matID)+ &
|
||||||
constitutive_phenopowerlaw_totalNtwin(myInstance)) = &
|
constitutive_phenopowerlaw_totalNtwin(matID)) = &
|
||||||
constitutive_phenopowerlaw_aTolTwinFrac(myInstance)
|
constitutive_phenopowerlaw_aTolTwinFrac(matID)
|
||||||
constitutive_phenopowerlaw_aTolState(3+constitutive_phenopowerlaw_totalNslip(myInstance)+ &
|
constitutive_phenopowerlaw_aTolState(3+constitutive_phenopowerlaw_totalNslip(matID)+ &
|
||||||
constitutive_phenopowerlaw_totalNtwin(myInstance): &
|
constitutive_phenopowerlaw_totalNtwin(matID): &
|
||||||
2+2*(constitutive_phenopowerlaw_totalNslip(myInstance)+ &
|
2+2*(constitutive_phenopowerlaw_totalNslip(matID)+ &
|
||||||
constitutive_phenopowerlaw_totalNtwin(myInstance))) = &
|
constitutive_phenopowerlaw_totalNtwin(matID))) = &
|
||||||
constitutive_phenopowerlaw_aTolShear(myInstance)
|
constitutive_phenopowerlaw_aTolShear(matID)
|
||||||
|
|
||||||
end function constitutive_phenopowerlaw_aTolState
|
end function constitutive_phenopowerlaw_aTolState
|
||||||
|
|
||||||
|
@ -735,7 +736,7 @@ pure subroutine constitutive_phenopowerlaw_LpAndItsTangent(Lp,dLp_dTstar99,Tstar
|
||||||
real(pReal), dimension(3,3), intent(out) :: &
|
real(pReal), dimension(3,3), intent(out) :: &
|
||||||
Lp !< plastic velocity gradient
|
Lp !< plastic velocity gradient
|
||||||
real(pReal), dimension(9,9), intent(out) :: &
|
real(pReal), dimension(9,9), intent(out) :: &
|
||||||
dLp_dTstar99 !< derivative of Lp with respect to 2nd Piola Kirchhoff stress
|
dLp_dTstar99 !< derivative of Lp with respect to 2nd Piola Kirchhoff stress
|
||||||
|
|
||||||
real(pReal), dimension(6), intent(in) :: &
|
real(pReal), dimension(6), intent(in) :: &
|
||||||
Tstar_v !< 2nd Piola Kirchhoff stress tensor in Mandel notation
|
Tstar_v !< 2nd Piola Kirchhoff stress tensor in Mandel notation
|
||||||
|
@ -896,9 +897,15 @@ function constitutive_phenopowerlaw_dotState(Tstar_v,temperature,state,ipc,ip,el
|
||||||
real(pReal), dimension(constitutive_phenopowerlaw_sizeDotState(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
real(pReal), dimension(constitutive_phenopowerlaw_sizeDotState(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
||||||
constitutive_phenopowerlaw_dotState
|
constitutive_phenopowerlaw_dotState
|
||||||
|
|
||||||
integer(pInt) :: matID,nSlip,nTwin,f,i,j,k,structID, &
|
integer(pInt) :: &
|
||||||
index_Gamma,index_F,offset_accshear_slip,offset_accshear_twin,index_myFamily
|
matID,structID, &
|
||||||
real(pReal) :: c_SlipSlip,c_SlipTwin,c_TwinSlip,c_TwinTwin, ssat_offset
|
nSlip,nTwin, &
|
||||||
|
f,i,j,k, &
|
||||||
|
index_Gamma,index_F,index_myFamily, &
|
||||||
|
offset_accshear_slip,offset_accshear_twin
|
||||||
|
real(pReal) :: &
|
||||||
|
c_SlipSlip,c_SlipTwin,c_TwinSlip,c_TwinTwin, &
|
||||||
|
ssat_offset
|
||||||
|
|
||||||
real(pReal), dimension(constitutive_phenopowerlaw_totalNslip(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
real(pReal), dimension(constitutive_phenopowerlaw_totalNslip(phase_plasticityInstance(material_phase(ipc,ip,el)))) :: &
|
||||||
gdot_slip,tau_slip_pos,tau_slip_neg,left_SlipSlip,left_SlipTwin,right_SlipSlip,right_TwinSlip
|
gdot_slip,tau_slip_pos,tau_slip_neg,left_SlipSlip,left_SlipTwin,right_SlipSlip,right_TwinSlip
|
||||||
|
@ -1028,7 +1035,7 @@ end function constitutive_phenopowerlaw_dotState
|
||||||
!> @brief (instantaneous) incremental change of microstructure
|
!> @brief (instantaneous) incremental change of microstructure
|
||||||
!> @details dummy function, returns 0.0
|
!> @details dummy function, returns 0.0
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
function constitutive_phenopowerlaw_deltaState(Tstar_v,temperature,state,ipc,ip,el)
|
pure function constitutive_phenopowerlaw_deltaState(Tstar_v,temperature,state,ipc,ip,el)
|
||||||
use prec, only: &
|
use prec, only: &
|
||||||
p_vec
|
p_vec
|
||||||
use mesh, only: &
|
use mesh, only: &
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue