2012-10-02 18:23:25 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2013-03-06 20:11:15 +05:30
|
|
|
! $Id$
|
2012-10-02 18:23:25 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
2013-03-06 20:11:15 +05:30
|
|
|
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
2012-10-02 18:23:25 +05:30
|
|
|
!> @brief elasticity, plasticity, internal microstructure state
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
module constitutive
|
2013-01-16 15:44:57 +05:30
|
|
|
use prec, only: &
|
2014-07-02 17:57:39 +05:30
|
|
|
pInt
|
2013-01-16 15:44:57 +05:30
|
|
|
|
|
|
|
implicit none
|
|
|
|
private
|
2014-05-27 20:16:03 +05:30
|
|
|
integer(pInt), public, protected :: &
|
|
|
|
constitutive_maxSizePostResults, &
|
|
|
|
constitutive_maxSizeDotState
|
2014-06-26 19:23:12 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
public :: &
|
|
|
|
constitutive_init, &
|
|
|
|
constitutive_homogenizedC, &
|
|
|
|
constitutive_microstructure, &
|
|
|
|
constitutive_LpAndItsTangent, &
|
|
|
|
constitutive_TandItsTangent, &
|
|
|
|
constitutive_collectDotState, &
|
|
|
|
constitutive_collectDeltaState, &
|
|
|
|
constitutive_postResults
|
|
|
|
|
|
|
|
private :: &
|
|
|
|
constitutive_hooke_TandItsTangent
|
|
|
|
|
2012-03-09 01:55:28 +05:30
|
|
|
contains
|
2012-10-02 18:23:25 +05:30
|
|
|
|
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief allocates arrays pointing to array of the various constitutive modules
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2012-03-09 01:55:28 +05:30
|
|
|
subroutine constitutive_init
|
2014-03-12 13:03:51 +05:30
|
|
|
#ifdef HDF
|
|
|
|
use hdf5, only: &
|
|
|
|
HID_T
|
|
|
|
use IO, only : &
|
2014-03-12 22:21:01 +05:30
|
|
|
HDF5_mappingConstitutive
|
2014-03-12 13:03:51 +05:30
|
|
|
#endif
|
|
|
|
|
2012-10-02 18:23:25 +05:30
|
|
|
use, intrinsic :: iso_fortran_env ! to get compiler_version and compiler_options (at least for gfortran 4.6 at the moment)
|
2014-07-02 17:57:39 +05:30
|
|
|
use prec, only: &
|
|
|
|
pReal
|
2013-01-16 15:44:57 +05:30
|
|
|
use debug, only: &
|
|
|
|
debug_level, &
|
|
|
|
debug_constitutive, &
|
|
|
|
debug_levelBasic
|
|
|
|
use numerics, only: &
|
|
|
|
numerics_integrator
|
|
|
|
use IO, only: &
|
|
|
|
IO_error, &
|
|
|
|
IO_open_file, &
|
|
|
|
IO_open_jobFile_stat, &
|
|
|
|
IO_write_jobFile, &
|
2013-09-18 19:37:55 +05:30
|
|
|
IO_write_jobIntFile, &
|
2013-02-25 22:04:59 +05:30
|
|
|
IO_timeStamp
|
2013-01-16 15:44:57 +05:30
|
|
|
use mesh, only: &
|
|
|
|
mesh_maxNips, &
|
|
|
|
mesh_NcpElems, &
|
|
|
|
mesh_element, &
|
|
|
|
FE_Nips, &
|
|
|
|
FE_geomtype
|
|
|
|
use material, only: &
|
|
|
|
material_phase, &
|
|
|
|
material_Nphase, &
|
|
|
|
material_localFileExt, &
|
|
|
|
material_configFile, &
|
|
|
|
phase_name, &
|
|
|
|
phase_elasticity, &
|
|
|
|
phase_plasticity, &
|
|
|
|
phase_plasticityInstance, &
|
|
|
|
phase_Noutput, &
|
|
|
|
homogenization_Ngrains, &
|
2013-11-27 13:34:05 +05:30
|
|
|
homogenization_maxNgrains, &
|
|
|
|
ELASTICITY_HOOKE_ID, &
|
|
|
|
PLASTICITY_NONE_ID, &
|
|
|
|
PLASTICITY_J2_ID, &
|
|
|
|
PLASTICITY_PHENOPOWERLAW_ID, &
|
|
|
|
PLASTICITY_DISLOTWIN_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOKMC_ID, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_TITANMOD_ID, &
|
|
|
|
PLASTICITY_NONLOCAL_ID ,&
|
|
|
|
ELASTICITY_HOOKE_label, &
|
|
|
|
PLASTICITY_NONE_label, &
|
|
|
|
PLASTICITY_J2_label, &
|
|
|
|
PLASTICITY_PHENOPOWERLAW_label, &
|
|
|
|
PLASTICITY_DISLOTWIN_label, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOKMC_label, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_TITANMOD_label, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_NONLOCAL_label, &
|
2014-05-08 20:25:19 +05:30
|
|
|
plasticState, &
|
2014-08-08 16:34:40 +05:30
|
|
|
mappingConstitutive
|
2014-07-02 17:57:39 +05:30
|
|
|
|
2014-08-08 16:34:40 +05:30
|
|
|
|
2012-07-03 16:46:38 +05:30
|
|
|
use constitutive_none
|
2012-03-09 01:55:28 +05:30
|
|
|
use constitutive_j2
|
|
|
|
use constitutive_phenopowerlaw
|
2014-06-03 19:16:42 +05:30
|
|
|
use constitutive_dislotwin
|
2014-08-08 16:34:40 +05:30
|
|
|
use constitutive_dislokmc
|
2012-03-09 01:55:28 +05:30
|
|
|
use constitutive_titanmod
|
2014-06-14 02:23:17 +05:30
|
|
|
use constitutive_nonlocal
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
2013-12-12 22:39:59 +05:30
|
|
|
integer(pInt), parameter :: FILEUNIT = 200_pInt
|
2013-01-16 15:44:57 +05:30
|
|
|
integer(pInt) :: &
|
2014-07-03 18:47:29 +05:30
|
|
|
e, & !< maximum number of elements
|
2014-02-28 15:48:40 +05:30
|
|
|
phase, &
|
2014-07-03 18:47:29 +05:30
|
|
|
instance
|
2014-05-08 20:25:19 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
integer(pInt), dimension(:,:), pointer :: thisSize
|
|
|
|
character(len=64), dimension(:,:), pointer :: thisOutput
|
2013-11-27 13:34:05 +05:30
|
|
|
character(len=32) :: outputName !< name of output, intermediate fix until HDF5 output is ready
|
2013-05-24 19:13:44 +05:30
|
|
|
logical :: knownPlasticity, nonlocalConstitutionPresent
|
|
|
|
nonlocalConstitutionPresent = .false.
|
2013-01-16 15:44:57 +05:30
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
! parse plasticities from config file
|
2013-12-12 22:39:59 +05:30
|
|
|
if (.not. IO_open_jobFile_stat(FILEUNIT,material_localFileExt)) & ! no local material configuration present...
|
|
|
|
call IO_open_file(FILEUNIT,material_configFile) ! ... open material.config file
|
2014-03-09 02:20:31 +05:30
|
|
|
if (any(phase_plasticity == PLASTICITY_NONE_ID)) call constitutive_none_init(FILEUNIT)
|
|
|
|
if (any(phase_plasticity == PLASTICITY_J2_ID)) call constitutive_j2_init(FILEUNIT)
|
|
|
|
if (any(phase_plasticity == PLASTICITY_PHENOPOWERLAW_ID)) call constitutive_phenopowerlaw_init(FILEUNIT)
|
2014-06-03 19:16:42 +05:30
|
|
|
if (any(phase_plasticity == PLASTICITY_DISLOTWIN_ID)) call constitutive_dislotwin_init(FILEUNIT)
|
2014-08-08 16:34:40 +05:30
|
|
|
if (any(phase_plasticity == PLASTICITY_DISLOKMC_ID)) call constitutive_dislokmc_init(FILEUNIT)
|
2014-03-09 02:20:31 +05:30
|
|
|
if (any(phase_plasticity == PLASTICITY_TITANMOD_ID)) call constitutive_titanmod_init(FILEUNIT)
|
2014-07-08 20:28:23 +05:30
|
|
|
if (any(phase_plasticity == PLASTICITY_NONLOCAL_ID)) then
|
|
|
|
call constitutive_nonlocal_init(FILEUNIT)
|
|
|
|
call constitutive_nonlocal_stateInit()
|
|
|
|
endif
|
2013-12-12 22:39:59 +05:30
|
|
|
close(FILEUNIT)
|
2013-01-16 15:44:57 +05:30
|
|
|
|
2013-05-28 23:01:55 +05:30
|
|
|
write(6,'(/,a)') ' <<<+- constitutive init -+>>>'
|
|
|
|
write(6,'(a)') ' $Id$'
|
2013-05-08 14:53:47 +05:30
|
|
|
write(6,'(a15,a)') ' Current time: ',IO_timeStamp()
|
2012-10-09 18:04:57 +05:30
|
|
|
#include "compilation_info.f90"
|
2013-01-16 15:44:57 +05:30
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
! write description file for constitutive phase output
|
2013-12-12 22:39:59 +05:30
|
|
|
call IO_write_jobFile(FILEUNIT,'outputConstitutive')
|
2014-02-28 15:48:40 +05:30
|
|
|
do phase = 1_pInt,material_Nphase
|
|
|
|
instance = phase_plasticityInstance(phase) ! which instance of a plasticity is present phase
|
2013-01-16 15:44:57 +05:30
|
|
|
knownPlasticity = .true. ! assume valid
|
2014-02-28 15:48:40 +05:30
|
|
|
select case(phase_plasticity(phase)) ! split per constititution
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_NONE_ID)
|
|
|
|
outputName = PLASTICITY_NONE_label
|
2014-03-13 12:13:49 +05:30
|
|
|
thisOutput => null() ! constitutive_none_output
|
|
|
|
thisSize => null() ! constitutive_none_sizePostResult
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_J2_ID)
|
|
|
|
outputName = PLASTICITY_J2_label
|
2013-01-16 15:44:57 +05:30
|
|
|
thisOutput => constitutive_j2_output
|
|
|
|
thisSize => constitutive_j2_sizePostResult
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_PHENOPOWERLAW_ID)
|
2013-12-18 12:58:01 +05:30
|
|
|
outputName = PLASTICITY_PHENOPOWERLAW_label
|
2013-01-16 15:44:57 +05:30
|
|
|
thisOutput => constitutive_phenopowerlaw_output
|
|
|
|
thisSize => constitutive_phenopowerlaw_sizePostResult
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_DISLOTWIN_ID)
|
|
|
|
outputName = PLASTICITY_DISLOTWIN_label
|
2013-01-16 15:44:57 +05:30
|
|
|
thisOutput => constitutive_dislotwin_output
|
|
|
|
thisSize => constitutive_dislotwin_sizePostResult
|
2014-08-08 16:34:40 +05:30
|
|
|
case (PLASTICITY_DISLOKMC_ID)
|
|
|
|
outputName = PLASTICITY_DISLOKMC_label
|
|
|
|
thisOutput => constitutive_dislokmc_output
|
|
|
|
thisSize => constitutive_dislokmc_sizePostResult
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_TITANMOD_ID)
|
|
|
|
outputName = PLASTICITY_TITANMOD_label
|
|
|
|
thisOutput => constitutive_titanmod_output
|
|
|
|
thisSize => constitutive_titanmod_sizePostResult
|
|
|
|
case (PLASTICITY_NONLOCAL_ID)
|
|
|
|
outputName = PLASTICITY_NONLOCAL_label
|
2013-01-16 15:44:57 +05:30
|
|
|
thisOutput => constitutive_nonlocal_output
|
|
|
|
thisSize => constitutive_nonlocal_sizePostResult
|
|
|
|
case default
|
|
|
|
knownPlasticity = .false.
|
|
|
|
end select
|
2014-02-28 15:48:40 +05:30
|
|
|
write(FILEUNIT,'(/,a,/)') '['//trim(phase_name(phase))//']'
|
2013-01-16 15:44:57 +05:30
|
|
|
if (knownPlasticity) then
|
2013-12-12 22:39:59 +05:30
|
|
|
write(FILEUNIT,'(a)') '(plasticity)'//char(9)//trim(outputName)
|
2014-06-25 04:52:52 +05:30
|
|
|
if (phase_plasticity(phase) /= PLASTICITY_NONE_ID) then
|
|
|
|
do e = 1_pInt,phase_Noutput(phase)
|
|
|
|
write(FILEUNIT,'(a,i4)') trim(thisOutput(e,instance))//char(9),thisSize(e,instance)
|
|
|
|
enddo
|
|
|
|
endif
|
2013-01-16 15:44:57 +05:30
|
|
|
endif
|
|
|
|
enddo
|
2013-12-12 22:39:59 +05:30
|
|
|
close(FILEUNIT)
|
2013-01-16 15:44:57 +05:30
|
|
|
|
2014-07-03 18:47:29 +05:30
|
|
|
constitutive_maxSizeDotState = 0_pInt
|
|
|
|
constitutive_maxSizePostResults = 0_pInt
|
|
|
|
|
|
|
|
PhaseLoop2:do phase = 1_pInt,material_Nphase
|
|
|
|
plasticState(phase)%partionedState0 = plasticState(phase)%State0
|
|
|
|
plasticState(phase)%State = plasticState(phase)%State0
|
|
|
|
constitutive_maxSizeDotState = max(constitutive_maxSizeDotState, plasticState(phase)%sizeDotState)
|
|
|
|
constitutive_maxSizePostResults = max(constitutive_maxSizePostResults, plasticState(phase)%sizePostResults)
|
|
|
|
enddo PhaseLoop2
|
2014-06-24 14:54:59 +05:30
|
|
|
|
2014-03-12 13:03:51 +05:30
|
|
|
#ifdef HDF
|
2014-03-26 14:11:45 +05:30
|
|
|
call HDF5_mappingConstitutive(mappingConstitutive)
|
2014-04-15 15:39:20 +05:30
|
|
|
do phase = 1_pInt,material_Nphase
|
|
|
|
instance = phase_plasticityInstance(phase) ! which instance of a plasticity is present phase
|
|
|
|
select case(phase_plasticity(phase)) ! split per constititution
|
|
|
|
case (PLASTICITY_NONE_ID)
|
|
|
|
case (PLASTICITY_J2_ID)
|
|
|
|
end select
|
|
|
|
enddo
|
2014-03-12 13:03:51 +05:30
|
|
|
#endif
|
2014-05-08 20:25:19 +05:30
|
|
|
|
2014-07-02 17:57:39 +05:30
|
|
|
#ifdef TODO
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
! write out state size file
|
2013-09-18 19:37:55 +05:30
|
|
|
call IO_write_jobIntFile(777,'sizeStateConst', size(constitutive_sizeState))
|
2013-01-16 15:44:57 +05:30
|
|
|
write (777,rec=1) constitutive_sizeState
|
|
|
|
close(777)
|
2009-03-06 15:32:36 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
! report
|
|
|
|
constitutive_maxSizeState = maxval(constitutive_sizeState)
|
|
|
|
constitutive_maxSizeDotState = maxval(constitutive_sizeDotState)
|
|
|
|
constitutive_maxSizePostResults = maxval(constitutive_sizePostResults)
|
|
|
|
|
|
|
|
if (iand(debug_level(debug_constitutive),debug_levelBasic) /= 0_pInt) then
|
2013-11-27 13:34:05 +05:30
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_state0: ', shape(constitutive_state0)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_partionedState0: ', shape(constitutive_partionedState0)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_subState0: ', shape(constitutive_subState0)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_state: ', shape(constitutive_state)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_aTolState: ', shape(constitutive_aTolState)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_dotState: ', shape(constitutive_dotState)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_deltaState: ', shape(constitutive_deltaState)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_sizeState: ', shape(constitutive_sizeState)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'constitutive_sizeDotState: ', shape(constitutive_sizeDotState)
|
|
|
|
write(6,'(a32,1x,7(i8,1x),/)') 'constitutive_sizePostResults: ', shape(constitutive_sizePostResults)
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'maxSizeState: ', constitutive_maxSizeState
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'maxSizeDotState: ', constitutive_maxSizeDotState
|
|
|
|
write(6,'(a32,1x,7(i8,1x))') 'maxSizePostResults: ', constitutive_maxSizePostResults
|
2013-01-16 15:44:57 +05:30
|
|
|
endif
|
|
|
|
flush(6)
|
2014-07-02 17:57:39 +05:30
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2012-10-02 18:23:25 +05:30
|
|
|
end subroutine constitutive_init
|
2009-03-06 15:32:36 +05:30
|
|
|
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief returns the homogenize elasticity matrix
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-07-02 17:57:39 +05:30
|
|
|
function constitutive_homogenizedC(ipc,ip,el)
|
|
|
|
use prec, only: &
|
|
|
|
pReal
|
2013-01-16 15:44:57 +05:30
|
|
|
use material, only: &
|
|
|
|
phase_plasticity, &
|
2013-11-27 13:34:05 +05:30
|
|
|
material_phase, &
|
|
|
|
PLASTICITY_TITANMOD_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOTWIN_ID, &
|
|
|
|
PLASTICITY_DISLOKMC_ID, &
|
2014-06-03 19:16:42 +05:30
|
|
|
plasticState,&
|
2014-08-08 16:34:40 +05:30
|
|
|
mappingConstitutive
|
|
|
|
|
2013-11-27 13:34:05 +05:30
|
|
|
use constitutive_titanmod, only: &
|
|
|
|
constitutive_titanmod_homogenizedC
|
2014-06-03 19:16:42 +05:30
|
|
|
use constitutive_dislotwin, only: &
|
|
|
|
constitutive_dislotwin_homogenizedC
|
2014-08-08 16:34:40 +05:30
|
|
|
use constitutive_dislokmc, only: &
|
|
|
|
constitutive_dislokmc_homogenizedC
|
2014-03-09 02:20:31 +05:30
|
|
|
use lattice, only: &
|
|
|
|
lattice_C66
|
|
|
|
|
2009-03-04 19:31:36 +05:30
|
|
|
implicit none
|
|
|
|
real(pReal), dimension(6,6) :: constitutive_homogenizedC
|
2013-01-16 15:44:57 +05:30
|
|
|
integer(pInt), intent(in) :: &
|
2013-09-19 13:16:01 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2009-03-06 15:32:36 +05:30
|
|
|
|
2013-09-19 13:16:01 +05:30
|
|
|
select case (phase_plasticity(material_phase(ipc,ip,el)))
|
2014-06-03 19:16:42 +05:30
|
|
|
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_DISLOTWIN_ID)
|
2014-08-08 16:34:40 +05:30
|
|
|
constitutive_homogenizedC = constitutive_dislotwin_homogenizedC(ipc,ip,el)
|
|
|
|
case (PLASTICITY_DISLOKMC_ID)
|
|
|
|
constitutive_homogenizedC = constitutive_dislokmc_homogenizedC(ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_TITANMOD_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
constitutive_homogenizedC = constitutive_titanmod_homogenizedC (ipc,ip,el)
|
2014-03-09 02:20:31 +05:30
|
|
|
case default
|
2014-07-02 17:57:39 +05:30
|
|
|
constitutive_homogenizedC = lattice_C66(1:6,1:6,material_phase (ipc,ip,el))
|
2009-08-11 22:01:57 +05:30
|
|
|
|
2009-03-04 19:31:36 +05:30
|
|
|
end select
|
2009-03-06 15:32:36 +05:30
|
|
|
|
2012-10-02 18:23:25 +05:30
|
|
|
end function constitutive_homogenizedC
|
|
|
|
|
2009-03-06 15:32:36 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief calls microstructure function of the different constitutive models
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2013-10-16 18:34:59 +05:30
|
|
|
subroutine constitutive_microstructure(temperature, Fe, Fp, ipc, ip, el)
|
2014-07-02 17:57:39 +05:30
|
|
|
use prec, only: &
|
|
|
|
pReal
|
2013-01-16 15:44:57 +05:30
|
|
|
use material, only: &
|
|
|
|
phase_plasticity, &
|
2013-11-27 13:34:05 +05:30
|
|
|
material_phase, &
|
|
|
|
PLASTICITY_DISLOTWIN_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOKMC_ID, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_TITANMOD_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_NONLOCAL_ID, &
|
|
|
|
plasticState, &
|
|
|
|
mappingConstitutive
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_titanmod, only: &
|
|
|
|
constitutive_titanmod_microstructure
|
|
|
|
use constitutive_nonlocal, only: &
|
|
|
|
constitutive_nonlocal_microstructure
|
2014-06-03 19:16:42 +05:30
|
|
|
use constitutive_dislotwin, only: &
|
|
|
|
constitutive_dislotwin_microstructure
|
2014-08-08 16:34:40 +05:30
|
|
|
use constitutive_dislokmc, only: &
|
|
|
|
constitutive_dislokmc_microstructure
|
2014-06-03 19:16:42 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in) :: &
|
2013-10-16 18:34:59 +05:30
|
|
|
temperature
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(3,3) :: &
|
|
|
|
Fe, & !< elastic deformation gradient
|
|
|
|
Fp !< plastic deformation gradient
|
2014-06-03 19:16:42 +05:30
|
|
|
|
2013-09-19 13:16:01 +05:30
|
|
|
select case (phase_plasticity(material_phase(ipc,ip,el)))
|
2013-11-27 13:34:05 +05:30
|
|
|
|
|
|
|
case (PLASTICITY_DISLOTWIN_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_dislotwin_microstructure(temperature,ipc,ip,el)
|
2014-08-08 16:34:40 +05:30
|
|
|
case (PLASTICITY_DISLOKMC_ID)
|
|
|
|
call constitutive_dislokmc_microstructure(temperature,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_TITANMOD_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_titanmod_microstructure (temperature,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_NONLOCAL_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_nonlocal_microstructure (Fe,Fp, ip,el)
|
|
|
|
|
2014-06-03 19:16:42 +05:30
|
|
|
end select
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
end subroutine constitutive_microstructure
|
openmp parallelization working again (at least for j2 and nonlocal constitutive model).
In order to keep it like that, please follow these simple rules:
DON'T use implicit array subscripts:
example: real, dimension(3,3) :: A,B
A(:,2) = B(:,1) <--- DON'T USE
A(1:3,2) = B(1:3,1) <--- BETTER USE
In many cases the use of explicit array subscripts is inevitable for parallelization. Additionally, it is an easy means to prevent memory leaks.
Enclose all write statements with the following:
!$OMP CRITICAL (write2out)
<your write statement>
!$OMP END CRITICAL (write2out)
Whenever you change something in the code and are not sure if it affects parallelization and leads to nonconforming behavior, please ask me and/or Franz to check this.
2011-03-17 16:16:17 +05:30
|
|
|
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2013-09-19 13:16:01 +05:30
|
|
|
!> @brief contains the constitutive equation for calculating the velocity gradient
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2013-10-16 18:34:59 +05:30
|
|
|
subroutine constitutive_LpAndItsTangent(Lp, dLp_dTstar, Tstar_v, temperature, ipc, ip, el)
|
2014-07-02 17:57:39 +05:30
|
|
|
use prec, only: &
|
|
|
|
pReal
|
2013-10-16 18:34:59 +05:30
|
|
|
use math, only: &
|
|
|
|
math_identity2nd
|
2013-01-16 15:44:57 +05:30
|
|
|
use material, only: &
|
|
|
|
phase_plasticity, &
|
2013-11-27 13:34:05 +05:30
|
|
|
material_phase, &
|
2014-05-22 20:54:12 +05:30
|
|
|
plasticState,&
|
2014-06-23 00:28:29 +05:30
|
|
|
mappingConstitutive, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_NONE_ID, &
|
|
|
|
PLASTICITY_J2_ID, &
|
|
|
|
PLASTICITY_PHENOPOWERLAW_ID, &
|
|
|
|
PLASTICITY_DISLOTWIN_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOKMC_ID, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_TITANMOD_ID, &
|
|
|
|
PLASTICITY_NONLOCAL_ID
|
2014-08-08 19:32:20 +05:30
|
|
|
use constitutive_damage, only: &
|
|
|
|
constitutive_damageValue
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_j2, only: &
|
|
|
|
constitutive_j2_LpAndItsTangent
|
|
|
|
use constitutive_phenopowerlaw, only: &
|
2014-05-22 20:54:12 +05:30
|
|
|
constitutive_phenopowerlaw_LpAndItsTangent
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_dislotwin, only: &
|
|
|
|
constitutive_dislotwin_LpAndItsTangent
|
2014-08-08 16:34:40 +05:30
|
|
|
use constitutive_dislokmc, only: &
|
|
|
|
constitutive_dislokmc_LpAndItsTangent
|
2013-11-27 13:34:05 +05:30
|
|
|
use constitutive_titanmod, only: &
|
|
|
|
constitutive_titanmod_LpAndItsTangent
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_nonlocal, only: &
|
|
|
|
constitutive_nonlocal_LpAndItsTangent
|
2014-06-14 02:23:17 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in) :: &
|
|
|
|
Temperature
|
|
|
|
real(pReal), intent(in), dimension(6) :: &
|
|
|
|
Tstar_v !< 2nd Piola-Kirchhoff stress
|
|
|
|
real(pReal), intent(out), dimension(3,3) :: &
|
|
|
|
Lp !< plastic velocity gradient
|
|
|
|
real(pReal), intent(out), dimension(9,9) :: &
|
|
|
|
dLp_dTstar !< derivative of Lp with respect to Tstar (4th-order tensor)
|
|
|
|
|
2013-09-19 13:16:01 +05:30
|
|
|
select case (phase_plasticity(material_phase(ipc,ip,el)))
|
2013-01-16 15:44:57 +05:30
|
|
|
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_NONE_ID)
|
2013-10-16 18:34:59 +05:30
|
|
|
Lp = 0.0_pReal
|
2014-08-10 15:36:03 +05:30
|
|
|
dLp_dTstar = 0.0_pReal
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_J2_ID)
|
2014-08-09 03:59:38 +05:30
|
|
|
call constitutive_j2_LpAndItsTangent (Lp,dLp_dTstar,Tstar_v,constitutive_damageValue(ipc,ip,el),ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_PHENOPOWERLAW_ID)
|
2014-08-09 03:59:38 +05:30
|
|
|
call constitutive_phenopowerlaw_LpAndItsTangent(Lp,dLp_dTstar,Tstar_v,constitutive_damageValue(ipc,ip,el),ipc,ip,el)
|
2014-07-02 17:57:39 +05:30
|
|
|
case (PLASTICITY_NONLOCAL_ID)
|
|
|
|
call constitutive_nonlocal_LpAndItsTangent (Lp,dLp_dTstar,Tstar_v,temperature, ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_DISLOTWIN_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_dislotwin_LpAndItsTangent (Lp,dLp_dTstar,Tstar_v,temperature,ipc,ip,el)
|
2014-08-08 16:34:40 +05:30
|
|
|
case (PLASTICITY_DISLOKMC_ID)
|
|
|
|
call constitutive_dislokmc_LpAndItsTangent (Lp,dLp_dTstar,Tstar_v,temperature,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_TITANMOD_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_titanmod_LpAndItsTangent (Lp,dLp_dTstar,Tstar_v,temperature,ipc,ip,el)
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
end select
|
|
|
|
|
2012-10-02 18:23:25 +05:30
|
|
|
end subroutine constitutive_LpAndItsTangent
|
2009-03-06 15:32:36 +05:30
|
|
|
|
|
|
|
|
openmp parallelization working again (at least for j2 and nonlocal constitutive model).
In order to keep it like that, please follow these simple rules:
DON'T use implicit array subscripts:
example: real, dimension(3,3) :: A,B
A(:,2) = B(:,1) <--- DON'T USE
A(1:3,2) = B(1:3,1) <--- BETTER USE
In many cases the use of explicit array subscripts is inevitable for parallelization. Additionally, it is an easy means to prevent memory leaks.
Enclose all write statements with the following:
!$OMP CRITICAL (write2out)
<your write statement>
!$OMP END CRITICAL (write2out)
Whenever you change something in the code and are not sure if it affects parallelization and leads to nonconforming behavior, please ask me and/or Franz to check this.
2011-03-17 16:16:17 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief returns the 2nd Piola-Kirchhoff stress tensor and its tangent with respect to
|
2013-10-14 16:24:45 +05:30
|
|
|
!> the elastic deformation gradient depending on the selected elastic law (so far no case switch
|
|
|
|
!! because only hooke is implemented
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-07-02 17:57:39 +05:30
|
|
|
subroutine constitutive_TandItsTangent(T, dT_dFe, Fe, ipc, ip, el)
|
|
|
|
use prec, only: &
|
|
|
|
pReal
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(3,3) :: &
|
|
|
|
Fe !< elastic deformation gradient
|
|
|
|
real(pReal), intent(out), dimension(3,3) :: &
|
|
|
|
T !< 2nd Piola-Kirchhoff stress tensor
|
|
|
|
real(pReal), intent(out), dimension(3,3,3,3) :: &
|
|
|
|
dT_dFe !< derivative of 2nd P-K stress with respect to elastic deformation gradient
|
|
|
|
|
2013-10-14 16:24:45 +05:30
|
|
|
call constitutive_hooke_TandItsTangent(T, dT_dFe, Fe, ipc, ip, el)
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
|
2012-10-02 18:23:25 +05:30
|
|
|
end subroutine constitutive_TandItsTangent
|
2012-03-15 15:21:33 +05:30
|
|
|
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief returns the 2nd Piola-Kirchhoff stress tensor and its tangent with respect to
|
2013-10-14 20:05:41 +05:30
|
|
|
!> the elastic deformation gradient using hookes law
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-07-02 17:57:39 +05:30
|
|
|
subroutine constitutive_hooke_TandItsTangent(T, dT_dFe, Fe, ipc, ip, el)
|
|
|
|
use prec, only: &
|
|
|
|
pReal
|
|
|
|
use math, only : &
|
|
|
|
math_mul3x3, &
|
|
|
|
math_mul33x33, &
|
|
|
|
math_mul3333xx33, &
|
|
|
|
math_Mandel66to3333, &
|
|
|
|
math_transpose33, &
|
2014-08-09 03:59:38 +05:30
|
|
|
math_trace33, &
|
|
|
|
math_I3
|
2014-07-02 17:57:39 +05:30
|
|
|
use material, only: &
|
2014-08-08 19:32:20 +05:30
|
|
|
mappingConstitutive
|
2014-06-25 04:52:52 +05:30
|
|
|
use lattice, only: &
|
2014-07-02 17:57:39 +05:30
|
|
|
lattice_referenceTemperature, &
|
|
|
|
lattice_thermalExpansion33
|
2014-08-08 19:32:20 +05:30
|
|
|
use constitutive_damage, only: &
|
|
|
|
constitutive_damageValue
|
|
|
|
use constitutive_thermal, only: &
|
|
|
|
constitutive_temperature
|
2012-11-07 21:13:29 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(3,3) :: &
|
|
|
|
Fe !< elastic deformation gradient
|
|
|
|
real(pReal), intent(out), dimension(3,3) :: &
|
|
|
|
T !< 2nd Piola-Kirchhoff stress tensor
|
|
|
|
real(pReal), intent(out), dimension(3,3,3,3) :: &
|
|
|
|
dT_dFe !< dT/dFe
|
|
|
|
|
2014-01-22 14:08:13 +05:30
|
|
|
integer(pInt) :: i, j, k, l
|
2014-08-10 16:15:07 +05:30
|
|
|
real(pReal) :: damage, pressure
|
2014-08-09 03:59:38 +05:30
|
|
|
real(pReal), dimension(3,3,3,3) :: C
|
|
|
|
|
|
|
|
C = math_Mandel66to3333(constitutive_homogenizedC(ipc,ip,el))
|
2014-08-10 16:15:07 +05:30
|
|
|
T = math_mul3333xx33(C,0.5_pReal*(math_mul33x33(math_transpose33(Fe),Fe)-math_I3) - &
|
|
|
|
lattice_thermalExpansion33(1:3,1:3,mappingConstitutive(2,ipc,ip,el))* &
|
|
|
|
(constitutive_temperature(ipc,ip,el) - &
|
|
|
|
lattice_referenceTemperature(mappingConstitutive(2,ipc,ip,el))))
|
|
|
|
|
|
|
|
pressure = math_trace33(T)/3.0_pReal
|
2014-08-09 03:59:38 +05:30
|
|
|
damage = constitutive_damageValue(ipc,ip,el)
|
2014-08-10 16:15:07 +05:30
|
|
|
T = damage*T
|
|
|
|
if (pressure < 0.0_pReal) T = T + (1.0_pReal - damage)*pressure*math_I3
|
2014-08-08 21:07:32 +05:30
|
|
|
|
2014-01-22 14:08:13 +05:30
|
|
|
dT_dFe = 0.0_pReal
|
|
|
|
forall (i=1_pInt:3_pInt, j=1_pInt:3_pInt, k=1_pInt:3_pInt, l=1_pInt:3_pInt) &
|
2014-08-10 16:15:07 +05:30
|
|
|
dT_dFe(i,j,k,l) = sum(C(i,j,l,1:3)*Fe(k,1:3)) ! dT*_ij/dFe_kl
|
|
|
|
|
|
|
|
if (pressure < 0.0_pReal) then
|
|
|
|
do i=1_pInt, 3_pInt; do k=1_pInt,3_pInt; do l=1_pInt,3_pInt; do j=1_pInt,3_pInt
|
|
|
|
dT_dFe(i,i,k,l) = dT_dFe(i,i,k,l) + &
|
|
|
|
(1.0_pReal - damage)*math_trace33(C(1:3,1:3,l,j))*Fe(k,j)/3.0_pReal
|
|
|
|
enddo; enddo; enddo; enddo
|
|
|
|
endif
|
|
|
|
|
2012-03-15 15:21:33 +05:30
|
|
|
end subroutine constitutive_hooke_TandItsTangent
|
|
|
|
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief contains the constitutive equation for calculating the rate of change of microstructure
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-03-13 12:13:49 +05:30
|
|
|
subroutine constitutive_collectDotState(Tstar_v, FeArray, FpArray, Temperature, subdt, subfracArray,&
|
|
|
|
ipc, ip, el)
|
2013-01-16 15:44:57 +05:30
|
|
|
use prec, only: &
|
2014-07-02 17:57:39 +05:30
|
|
|
pReal, &
|
2013-01-16 15:44:57 +05:30
|
|
|
pLongInt
|
|
|
|
use debug, only: &
|
|
|
|
debug_cumDotStateCalls, &
|
|
|
|
debug_cumDotStateTicks, &
|
|
|
|
debug_level, &
|
|
|
|
debug_constitutive, &
|
|
|
|
debug_levelBasic
|
|
|
|
use mesh, only: &
|
|
|
|
mesh_NcpElems, &
|
2013-05-08 14:53:47 +05:30
|
|
|
mesh_maxNips
|
2013-01-16 15:44:57 +05:30
|
|
|
use material, only: &
|
|
|
|
phase_plasticity, &
|
2014-05-22 20:54:12 +05:30
|
|
|
plasticState, &
|
2014-07-02 17:57:39 +05:30
|
|
|
mappingConstitutive, &
|
2013-01-16 15:44:57 +05:30
|
|
|
material_phase, &
|
2013-11-27 13:34:05 +05:30
|
|
|
homogenization_maxNgrains, &
|
|
|
|
PLASTICITY_NONE_ID, &
|
|
|
|
PLASTICITY_J2_ID, &
|
|
|
|
PLASTICITY_PHENOPOWERLAW_ID, &
|
|
|
|
PLASTICITY_DISLOTWIN_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOKMC_ID, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_TITANMOD_ID, &
|
|
|
|
PLASTICITY_NONLOCAL_ID
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_j2, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_j2_dotState
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_phenopowerlaw, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_phenopowerlaw_dotState
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_dislotwin, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_dislotwin_dotState
|
2014-08-08 16:34:40 +05:30
|
|
|
use constitutive_dislokmc, only: &
|
|
|
|
constitutive_dislokmc_dotState
|
2013-11-27 13:34:05 +05:30
|
|
|
use constitutive_titanmod, only: &
|
|
|
|
constitutive_titanmod_dotState
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_nonlocal, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_nonlocal_dotState
|
2014-06-14 02:23:17 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in) :: &
|
|
|
|
Temperature, &
|
|
|
|
subdt !< timestep
|
|
|
|
real(pReal), intent(in), dimension(homogenization_maxNgrains,mesh_maxNips,mesh_NcpElems) :: &
|
2014-03-13 12:13:49 +05:30
|
|
|
subfracArray !< subfraction of timestep
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(3,3,homogenization_maxNgrains,mesh_maxNips,mesh_NcpElems) :: &
|
2014-03-13 12:13:49 +05:30
|
|
|
FeArray, & !< elastic deformation gradient
|
|
|
|
FpArray !< plastic deformation gradient
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(6) :: &
|
|
|
|
Tstar_v !< 2nd Piola Kirchhoff stress tensor (Mandel)
|
|
|
|
integer(pLongInt) :: &
|
|
|
|
tick, tock, &
|
|
|
|
tickrate, &
|
|
|
|
maxticks
|
2012-07-03 16:46:38 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
if (iand(debug_level(debug_constitutive), debug_levelBasic) /= 0_pInt) &
|
|
|
|
call system_clock(count=tick,count_rate=tickrate,count_max=maxticks)
|
2009-12-15 13:50:31 +05:30
|
|
|
|
2013-09-19 13:16:01 +05:30
|
|
|
select case (phase_plasticity(material_phase(ipc,ip,el)))
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_J2_ID)
|
2014-08-10 16:17:12 +05:30
|
|
|
call constitutive_j2_dotState (Tstar_v,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_PHENOPOWERLAW_ID)
|
2014-08-10 16:17:12 +05:30
|
|
|
call constitutive_phenopowerlaw_dotState(Tstar_v,ipc,ip,el)
|
2014-06-03 19:16:42 +05:30
|
|
|
case (PLASTICITY_DISLOTWIN_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_dislotwin_dotState (Tstar_v,Temperature,ipc,ip,el)
|
2014-08-08 16:34:40 +05:30
|
|
|
case (PLASTICITY_DISLOKMC_ID)
|
|
|
|
call constitutive_dislokmc_dotState (Tstar_v,Temperature,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_TITANMOD_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_titanmod_dotState (Tstar_v,Temperature,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_NONLOCAL_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
call constitutive_nonlocal_dotState (Tstar_v,FeArray,FpArray,Temperature, subdt, &
|
|
|
|
subfracArray,ip,el)
|
2013-01-16 15:44:57 +05:30
|
|
|
end select
|
|
|
|
|
|
|
|
if (iand(debug_level(debug_constitutive), debug_levelBasic) /= 0_pInt) then
|
|
|
|
call system_clock(count=tock,count_rate=tickrate,count_max=maxticks)
|
|
|
|
!$OMP CRITICAL (debugTimingDotState)
|
|
|
|
debug_cumDotStateCalls = debug_cumDotStateCalls + 1_pInt
|
|
|
|
debug_cumDotStateTicks = debug_cumDotStateTicks + tock-tick
|
|
|
|
!$OMP FLUSH (debug_cumDotStateTicks)
|
|
|
|
if (tock < tick) debug_cumDotStateTicks = debug_cumDotStateTicks + maxticks
|
|
|
|
!$OMP END CRITICAL (debugTimingDotState)
|
|
|
|
endif
|
2012-10-02 18:23:25 +05:30
|
|
|
end subroutine constitutive_collectDotState
|
2009-03-06 15:32:36 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-06-17 12:24:49 +05:30
|
|
|
!> @brief for constitutive models having an instantaneous change of state (so far, only nonlocal)
|
|
|
|
!> will return false if delta state is not needed/supported by the constitutive model
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-06-17 12:24:49 +05:30
|
|
|
logical function constitutive_collectDeltaState(Tstar_v, ipc, ip, el)
|
2013-01-16 15:44:57 +05:30
|
|
|
use prec, only: &
|
2014-07-02 17:57:39 +05:30
|
|
|
pReal, &
|
2013-01-16 15:44:57 +05:30
|
|
|
pLongInt
|
|
|
|
use debug, only: &
|
|
|
|
debug_cumDeltaStateCalls, &
|
|
|
|
debug_cumDeltaStateTicks, &
|
|
|
|
debug_level, &
|
|
|
|
debug_constitutive, &
|
|
|
|
debug_levelBasic
|
|
|
|
use material, only: &
|
|
|
|
phase_plasticity, &
|
2013-11-27 13:34:05 +05:30
|
|
|
material_phase, &
|
2014-06-14 02:23:17 +05:30
|
|
|
#ifdef NEWSTATE
|
|
|
|
plasticState, &
|
2014-06-23 00:28:29 +05:30
|
|
|
mappingConstitutive, &
|
2014-06-14 02:23:17 +05:30
|
|
|
#endif
|
|
|
|
PLASTICITY_NONLOCAL_ID
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_nonlocal, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_nonlocal_deltaState
|
2013-01-16 15:44:57 +05:30
|
|
|
|
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(6) :: &
|
|
|
|
Tstar_v !< 2nd Piola-Kirchhoff stress
|
|
|
|
integer(pLongInt) :: &
|
|
|
|
tick, tock, &
|
|
|
|
tickrate, &
|
|
|
|
maxticks
|
|
|
|
|
|
|
|
if (iand(debug_level(debug_constitutive), debug_levelBasic) /= 0_pInt) &
|
|
|
|
call system_clock(count=tick,count_rate=tickrate,count_max=maxticks)
|
|
|
|
|
2013-09-19 13:16:01 +05:30
|
|
|
select case (phase_plasticity(material_phase(ipc,ip,el)))
|
2012-05-16 20:13:26 +05:30
|
|
|
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_NONLOCAL_ID)
|
2014-06-17 12:24:49 +05:30
|
|
|
constitutive_collectDeltaState = .true.
|
2014-06-26 19:23:12 +05:30
|
|
|
call constitutive_nonlocal_deltaState(Tstar_v,ip,el)
|
2013-10-14 16:24:45 +05:30
|
|
|
case default
|
2014-06-17 12:24:49 +05:30
|
|
|
constitutive_collectDeltaState = .false.
|
2014-07-02 17:57:39 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
end select
|
2012-05-16 20:13:26 +05:30
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
if (iand(debug_level(debug_constitutive), debug_levelBasic) /= 0_pInt) then
|
|
|
|
call system_clock(count=tock,count_rate=tickrate,count_max=maxticks)
|
|
|
|
!$OMP CRITICAL (debugTimingDeltaState)
|
|
|
|
debug_cumDeltaStateCalls = debug_cumDeltaStateCalls + 1_pInt
|
|
|
|
debug_cumDeltaStateTicks = debug_cumDeltaStateTicks + tock-tick
|
|
|
|
!$OMP FLUSH (debug_cumDeltaStateTicks)
|
|
|
|
if (tock < tick) debug_cumDeltaStateTicks = debug_cumDeltaStateTicks + maxticks
|
|
|
|
!$OMP END CRITICAL (debugTimingDeltaState)
|
|
|
|
endif
|
2012-05-16 20:13:26 +05:30
|
|
|
|
2014-06-17 12:24:49 +05:30
|
|
|
end function constitutive_collectDeltaState
|
|
|
|
|
|
|
|
|
2013-01-16 15:44:57 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief returns array of constitutive results
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
2014-03-13 12:13:49 +05:30
|
|
|
function constitutive_postResults(Tstar_v, FeArray, temperature, ipc, ip, el)
|
2014-07-02 17:57:39 +05:30
|
|
|
use prec, only: &
|
|
|
|
pReal
|
2013-01-16 15:44:57 +05:30
|
|
|
use mesh, only: &
|
|
|
|
mesh_NcpElems, &
|
|
|
|
mesh_maxNips
|
|
|
|
use material, only: &
|
2014-05-22 20:54:12 +05:30
|
|
|
plasticState, &
|
2014-06-23 00:28:29 +05:30
|
|
|
mappingConstitutive, &
|
2013-01-16 15:44:57 +05:30
|
|
|
phase_plasticity, &
|
|
|
|
material_phase, &
|
2013-11-27 13:34:05 +05:30
|
|
|
homogenization_maxNgrains, &
|
|
|
|
PLASTICITY_NONE_ID, &
|
|
|
|
PLASTICITY_J2_ID, &
|
|
|
|
PLASTICITY_PHENOPOWERLAW_ID, &
|
|
|
|
PLASTICITY_DISLOTWIN_ID, &
|
2014-08-08 16:34:40 +05:30
|
|
|
PLASTICITY_DISLOKMC_ID, &
|
2013-11-27 13:34:05 +05:30
|
|
|
PLASTICITY_TITANMOD_ID, &
|
|
|
|
PLASTICITY_NONLOCAL_ID
|
2014-08-09 03:59:38 +05:30
|
|
|
use constitutive_damage, only: &
|
|
|
|
constitutive_damageValue
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_j2, only: &
|
2014-04-15 15:39:20 +05:30
|
|
|
#ifdef HDF
|
|
|
|
constitutive_j2_postResults2,&
|
|
|
|
#endif
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_j2_postResults
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_phenopowerlaw, only: &
|
2014-05-22 20:54:12 +05:30
|
|
|
constitutive_phenopowerlaw_postResults
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_dislotwin, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_dislotwin_postResults
|
2014-08-08 16:34:40 +05:30
|
|
|
use constitutive_dislokmc, only: &
|
|
|
|
constitutive_dislokmc_postResults
|
2013-11-27 13:34:05 +05:30
|
|
|
use constitutive_titanmod, only: &
|
|
|
|
constitutive_titanmod_postResults
|
2013-01-16 15:44:57 +05:30
|
|
|
use constitutive_nonlocal, only: &
|
2013-11-27 13:34:05 +05:30
|
|
|
constitutive_nonlocal_postResults
|
2013-01-16 15:44:57 +05:30
|
|
|
implicit none
|
|
|
|
integer(pInt), intent(in) :: &
|
2013-10-14 16:24:45 +05:30
|
|
|
ipc, & !< grain number
|
|
|
|
ip, & !< integration point number
|
|
|
|
el !< element number
|
2014-07-04 15:16:43 +05:30
|
|
|
real(pReal), dimension(plasticState(material_phase(ipc,ip,el))%sizePostResults) :: &
|
2013-01-16 15:44:57 +05:30
|
|
|
constitutive_postResults
|
|
|
|
real(pReal), intent(in) :: &
|
2013-10-16 18:34:59 +05:30
|
|
|
temperature
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(3,3,homogenization_maxNgrains,mesh_maxNips,mesh_NcpElems) :: &
|
2014-03-13 12:13:49 +05:30
|
|
|
FeArray !< elastic deformation gradient
|
2013-01-16 15:44:57 +05:30
|
|
|
real(pReal), intent(in), dimension(6) :: &
|
|
|
|
Tstar_v !< 2nd Piola Kirchhoff stress tensor (Mandel)
|
|
|
|
|
|
|
|
constitutive_postResults = 0.0_pReal
|
|
|
|
|
2013-09-19 13:16:01 +05:30
|
|
|
select case (phase_plasticity(material_phase(ipc,ip,el)))
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_TITANMOD_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
constitutive_postResults = constitutive_titanmod_postResults (ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_J2_ID)
|
2014-08-10 16:17:12 +05:30
|
|
|
constitutive_postResults= constitutive_j2_postResults (Tstar_v,constitutive_damageValue(ipc,ip,el),ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_PHENOPOWERLAW_ID)
|
2014-08-09 03:59:38 +05:30
|
|
|
constitutive_postResults = constitutive_phenopowerlaw_postResults(Tstar_v,constitutive_damageValue(ipc,ip,el),ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_DISLOTWIN_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
constitutive_postResults = constitutive_dislotwin_postResults(Tstar_v,Temperature,ipc,ip,el)
|
2014-08-08 16:34:40 +05:30
|
|
|
case (PLASTICITY_DISLOKMC_ID)
|
|
|
|
constitutive_postResults = constitutive_dislokmc_postResults(Tstar_v,Temperature,ipc,ip,el)
|
2013-11-27 13:34:05 +05:30
|
|
|
case (PLASTICITY_NONLOCAL_ID)
|
2014-07-02 17:57:39 +05:30
|
|
|
constitutive_postResults = constitutive_nonlocal_postResults (Tstar_v,FeArray, ip,el)
|
2013-01-16 15:44:57 +05:30
|
|
|
end select
|
openmp parallelization working again (at least for j2 and nonlocal constitutive model).
In order to keep it like that, please follow these simple rules:
DON'T use implicit array subscripts:
example: real, dimension(3,3) :: A,B
A(:,2) = B(:,1) <--- DON'T USE
A(1:3,2) = B(1:3,1) <--- BETTER USE
In many cases the use of explicit array subscripts is inevitable for parallelization. Additionally, it is an easy means to prevent memory leaks.
Enclose all write statements with the following:
!$OMP CRITICAL (write2out)
<your write statement>
!$OMP END CRITICAL (write2out)
Whenever you change something in the code and are not sure if it affects parallelization and leads to nonconforming behavior, please ask me and/or Franz to check this.
2011-03-17 16:16:17 +05:30
|
|
|
|
2012-10-02 18:23:25 +05:30
|
|
|
end function constitutive_postResults
|
2009-03-06 15:32:36 +05:30
|
|
|
|
2012-03-14 21:46:11 +05:30
|
|
|
|
2013-02-11 16:13:45 +05:30
|
|
|
end module constitutive
|