changed input of loadcase. Now fdot (time derivative) can be used instead of velocity gradient. Velocity gradient needs to have each line fully or not at all defined, as for other loadcases the stress BCs are not known in advance. Also added the possibility to keep guessing along trajectory of former loadcase.
changed back to use the compliance of initial linear material behavior. added counter of non-converged steps renamed compiler flags in makefile
This commit is contained in:
parent
8153cd50b4
commit
56340fd487
|
@ -63,20 +63,22 @@ program DAMASK_spectral
|
||||||
integer(pInt), dimension (1+maxNchunksInput*2) :: posInput
|
integer(pInt), dimension (1+maxNchunksInput*2) :: posInput
|
||||||
integer(pInt), parameter :: maxNchunksGeom = 7 ! 4 identifiers, 3 values
|
integer(pInt), parameter :: maxNchunksGeom = 7 ! 4 identifiers, 3 values
|
||||||
integer(pInt), dimension (1+2*maxNchunksGeom) :: posGeom
|
integer(pInt), dimension (1+2*maxNchunksGeom) :: posGeom
|
||||||
integer(pInt) unit, N_l, N_s, N_t, N_n, N_f ! numbers of identifiers
|
integer(pInt) unit, N_l, N_s, N_t, N_n, N_freq, N_Fdot ! numbers of identifiers
|
||||||
character(len=1024) path, line
|
character(len=1024) path, line
|
||||||
logical gotResolution,gotDimension,gotHomogenization
|
logical gotResolution,gotDimension,gotHomogenization
|
||||||
logical, dimension(9) :: bc_maskvector
|
logical, dimension(9) :: bc_maskvector
|
||||||
|
|
||||||
! variables storing information from loadcase file
|
! variables storing information from loadcase file
|
||||||
real(pReal) time, time0, timeinc ! elapsed time, begin of interval, time interval
|
real(pReal) time, time0, timeinc ! elapsed time, begin of interval, time interval
|
||||||
real(pReal), dimension (:,:,:), allocatable :: bc_velocityGrad, &
|
real(pReal), dimension (:,:,:), allocatable :: bc_deformation, & ! applied velocity gradient or time derivative of deformation gradient
|
||||||
bc_stress ! velocity gradient and stress BC
|
bc_stress ! stress BC (if applicable)
|
||||||
real(pReal), dimension(:), allocatable :: bc_timeIncrement ! length of increment
|
real(pReal), dimension(:), allocatable :: bc_timeIncrement ! length of increment
|
||||||
integer(pInt) N_Loadcases, step
|
integer(pInt) N_Loadcases, step ! ToDo: rename?
|
||||||
integer(pInt), dimension(:), allocatable :: bc_steps ! number of steps
|
integer(pInt), dimension(:), allocatable :: bc_steps, & ! number of steps
|
||||||
integer(pInt), dimension(:), allocatable :: bc_frequency ! frequency of result writes
|
bc_frequency ! frequency of result writes
|
||||||
integer(pInt), dimension(:), allocatable :: bc_logscale ! linear/logaritmic time step flag
|
logical, dimension(:), allocatable :: bc_logscale, & ! linear/logaritmic time step flag
|
||||||
|
followFormeTrajectory,& ! follow trajectory of former loadcase
|
||||||
|
velGradApplied ! decide wether velocity gradient or fdot is given
|
||||||
logical, dimension(:,:,:,:), allocatable :: bc_mask ! mask of boundary conditions
|
logical, dimension(:,:,:,:), allocatable :: bc_mask ! mask of boundary conditions
|
||||||
|
|
||||||
! variables storing information from geom file
|
! variables storing information from geom file
|
||||||
|
@ -109,7 +111,7 @@ program DAMASK_spectral
|
||||||
! loop variables, convergence etc.
|
! loop variables, convergence etc.
|
||||||
real(pReal) guessmode, err_div, err_stress, err_defgrad, p_hat_av
|
real(pReal) guessmode, err_div, err_stress, err_defgrad, p_hat_av
|
||||||
integer(pInt) i, j, k, l, m, n, p
|
integer(pInt) i, j, k, l, m, n, p
|
||||||
integer(pInt) loadcase, ielem, iter, calcmode, CPFEM_mode, ierr
|
integer(pInt) loadcase, ielem, iter, calcmode, CPFEM_mode, ierr, doesNotConverge
|
||||||
logical errmatinv
|
logical errmatinv
|
||||||
|
|
||||||
real(pReal) temperature ! not used, but needed for call to CPFEM_general
|
real(pReal) temperature ! not used, but needed for call to CPFEM_general
|
||||||
|
@ -126,7 +128,9 @@ program DAMASK_spectral
|
||||||
N_t = 0_pInt
|
N_t = 0_pInt
|
||||||
time = 0.0_pReal
|
time = 0.0_pReal
|
||||||
N_n = 0_pInt
|
N_n = 0_pInt
|
||||||
N_f = 0_pInt
|
N_freq = 0_pInt
|
||||||
|
N_Fdot = 0_pInt
|
||||||
|
doesNotConverge = 0_pInt
|
||||||
gotResolution =.false.; gotDimension =.false.; gotHomogenization = .false.
|
gotResolution =.false.; gotDimension =.false.; gotHomogenization = .false.
|
||||||
resolution = 1_pInt
|
resolution = 1_pInt
|
||||||
geomdimension = 0.0_pReal
|
geomdimension = 0.0_pReal
|
||||||
|
@ -152,29 +156,34 @@ program DAMASK_spectral
|
||||||
select case (IO_lc(IO_stringValue(line,posInput,i)))
|
select case (IO_lc(IO_stringValue(line,posInput,i)))
|
||||||
case('l', 'velocitygrad')
|
case('l', 'velocitygrad')
|
||||||
N_l = N_l+1
|
N_l = N_l+1
|
||||||
case('s','stress')
|
case('fdot')
|
||||||
|
N_Fdot = N_Fdot+1
|
||||||
|
case('s', 'stress', 'pk1', 'piolakirchhoff')
|
||||||
N_s = N_s+1
|
N_s = N_s+1
|
||||||
case('t', 'time', 'delta')
|
case('t', 'time', 'delta')
|
||||||
N_t = N_t+1
|
N_t = N_t+1
|
||||||
case('n', 'incs', 'increments', 'steps', 'logincs', 'logsteps')
|
case('n', 'incs', 'increments', 'steps', 'logincs', 'logsteps')
|
||||||
N_n = N_n+1
|
N_n = N_n+1
|
||||||
case('f', 'freq', 'frequency')
|
case('f', 'freq', 'frequency')
|
||||||
N_f = N_f+1
|
N_freq = N_freq+1
|
||||||
end select
|
end select
|
||||||
enddo ! count all identifiers to allocate memory and do sanity check
|
enddo ! count all identifiers to allocate memory and do sanity check
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
101 N_Loadcases = N_l
|
101 N_Loadcases = N_n
|
||||||
|
if ((N_l + N_Fdot /= N_n).or.(N_n /= N_t)) & ! sanity check
|
||||||
|
call IO_error(46,ext_msg = path) ! error message for incomplete inp !ToDo:change message
|
||||||
|
|
||||||
! allocate memory depending on lines in input file
|
! allocate memory depending on lines in input file
|
||||||
allocate (bc_velocityGrad(3,3,N_Loadcases)); bc_velocityGrad = 0.0_pReal
|
allocate (bc_deformation(3,3,N_Loadcases)); bc_deformation = 0.0_pReal
|
||||||
allocate (bc_stress(3,3,N_Loadcases)); bc_stress = 0.0_pReal
|
allocate (bc_stress(3,3,N_Loadcases)); bc_stress = 0.0_pReal
|
||||||
allocate (bc_mask(3,3,2,N_Loadcases)); bc_mask = .false.
|
allocate (bc_mask(3,3,2,N_Loadcases)); bc_mask = .false.
|
||||||
|
allocate (velGradApplied(N_Loadcases)); velGradApplied = .false.
|
||||||
allocate (bc_timeIncrement(N_Loadcases)); bc_timeIncrement = 0.0_pReal
|
allocate (bc_timeIncrement(N_Loadcases)); bc_timeIncrement = 0.0_pReal
|
||||||
allocate (bc_steps(N_Loadcases)); bc_steps = 0_pInt
|
allocate (bc_steps(N_Loadcases)); bc_steps = 0_pInt
|
||||||
allocate (bc_logscale(N_Loadcases)); bc_logscale = 0_pInt
|
allocate (bc_logscale(N_Loadcases)); bc_logscale = .false.
|
||||||
allocate (bc_frequency(N_Loadcases)); bc_frequency = 1_pInt
|
allocate (bc_frequency(N_Loadcases)); bc_frequency = 1_pInt
|
||||||
|
allocate (followFormeTrajectory(N_Loadcases)); followFormeTrajectory = .false.
|
||||||
|
|
||||||
rewind(unit)
|
rewind(unit)
|
||||||
i = 0_pInt
|
i = 0_pInt
|
||||||
|
@ -186,14 +195,24 @@ program DAMASK_spectral
|
||||||
do j = 1,maxNchunksInput,2
|
do j = 1,maxNchunksInput,2
|
||||||
select case (IO_lc(IO_stringValue(line,posInput,j)))
|
select case (IO_lc(IO_stringValue(line,posInput,j)))
|
||||||
case('l','velocitygrad')
|
case('l','velocitygrad')
|
||||||
|
velGradApplied(i) = .true.
|
||||||
valuevector = 0.0_pReal
|
valuevector = 0.0_pReal
|
||||||
forall (k = 1:9) bc_maskvector(k) = IO_stringValue(line,posInput,j+k) /= '*'
|
forall (k = 1:9) bc_maskvector(k) = IO_stringValue(line,posInput,j+k) /= '*'
|
||||||
do k = 1,9
|
do k = 1,9
|
||||||
if (bc_maskvector(k)) valuevector(k) = IO_floatValue(line,posInput,j+k) ! assign values for the velocity gradient matrix
|
if (bc_maskvector(k)) valuevector(k) = IO_floatValue(line,posInput,j+k) ! assign values for the velocity gradient matrix
|
||||||
enddo
|
enddo
|
||||||
bc_mask(:,:,1,i) = transpose(reshape(bc_maskvector,(/3,3/)))
|
bc_mask(:,:,1,i) = transpose(reshape(bc_maskvector,(/3,3/)))
|
||||||
bc_velocityGrad(:,:,i) = math_transpose3x3(reshape(valuevector,(/3,3/)))
|
bc_deformation(:,:,i) = math_transpose3x3(reshape(valuevector,(/3,3/)))
|
||||||
case('s','stress')
|
case('fdot')
|
||||||
|
velGradApplied(i) = .false.
|
||||||
|
valuevector = 0.0_pReal
|
||||||
|
forall (k = 1:9) bc_maskvector(k) = IO_stringValue(line,posInput,j+k) /= '*'
|
||||||
|
do k = 1,9
|
||||||
|
if (bc_maskvector(k)) valuevector(k) = IO_floatValue(line,posInput,j+k) ! assign values for the matrix of time derivative of defgrad
|
||||||
|
enddo
|
||||||
|
bc_mask(:,:,1,i) = transpose(reshape(bc_maskvector,(/3,3/)))
|
||||||
|
bc_deformation(:,:,i) = math_transpose3x3(reshape(valuevector,(/3,3/)))
|
||||||
|
case('s', 'stress', 'pk1', 'piolakirchhoff')
|
||||||
valuevector = 0.0_pReal
|
valuevector = 0.0_pReal
|
||||||
forall (k = 1:9) bc_maskvector(k) = IO_stringValue(line,posInput,j+k) /= '*'
|
forall (k = 1:9) bc_maskvector(k) = IO_stringValue(line,posInput,j+k) /= '*'
|
||||||
do k = 1,9
|
do k = 1,9
|
||||||
|
@ -205,11 +224,13 @@ program DAMASK_spectral
|
||||||
bc_timeIncrement(i) = IO_floatValue(line,posInput,j+1)
|
bc_timeIncrement(i) = IO_floatValue(line,posInput,j+1)
|
||||||
case('n','incs','increments','steps') ! bc_steps
|
case('n','incs','increments','steps') ! bc_steps
|
||||||
bc_steps(i) = IO_intValue(line,posInput,j+1)
|
bc_steps(i) = IO_intValue(line,posInput,j+1)
|
||||||
case('logincs','logsteps') ! = 1, if log scale
|
case('logincs','logsteps') ! true, if log scale
|
||||||
bc_steps(i) = IO_intValue(line,posInput,j+1)
|
bc_steps(i) = IO_intValue(line,posInput,j+1)
|
||||||
bc_logscale(i) = 1
|
bc_logscale(i) = .true.
|
||||||
case('f','freq','frequency') ! frequency of result writings
|
case('f','freq','frequency') ! frequency of result writings
|
||||||
bc_frequency(i) = IO_intValue(line,posInput,j+1)
|
bc_frequency(i) = IO_intValue(line,posInput,j+1)
|
||||||
|
case('continue','keepguessing','followtrajectory','followformertrajectory')
|
||||||
|
followFormeTrajectory(i) = .true. ! continue to predict deformation along former trajectory
|
||||||
end select
|
end select
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
|
||||||
|
@ -217,12 +238,25 @@ program DAMASK_spectral
|
||||||
|
|
||||||
do i = 1, N_Loadcases ! consistency checks
|
do i = 1, N_Loadcases ! consistency checks
|
||||||
if (any(bc_mask(:,:,1,i) == bc_mask(:,:,2,i))) call IO_error(46,i) ! exclusive or masking only
|
if (any(bc_mask(:,:,1,i) == bc_mask(:,:,2,i))) call IO_error(46,i) ! exclusive or masking only
|
||||||
|
if (velGradApplied(i) == .true.) then
|
||||||
|
do j = 1, 3
|
||||||
|
if (any(bc_mask(j,:,1,i) == .true.) .and. any(bc_mask(j,:,1,i) == .false.)) &
|
||||||
|
call IO_error(46,i) ! ToDo: change message
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
|
if (followFormeTrajectory(1) == .true.) call IO_error(47,i) ! ToDo: Change message
|
||||||
if (bc_timeIncrement(i) < 0.0_pReal) call IO_error(47,i) ! negative time increment
|
if (bc_timeIncrement(i) < 0.0_pReal) call IO_error(47,i) ! negative time increment
|
||||||
if (bc_steps(i) < 1_pInt) call IO_error(48,i) ! non-positive increment count
|
if (bc_steps(i) < 1_pInt) call IO_error(48,i) ! non-positive increment count
|
||||||
if (bc_frequency(i) < 1_pInt) call IO_error(49,i) ! non-positive result frequency
|
if (bc_frequency(i) < 1_pInt) call IO_error(49,i) ! non-positive result frequency
|
||||||
print '(a,/,3(3(f12.6,x)/))','L:' ,math_transpose3x3(bc_velocityGrad(:,:,i))
|
print '(a,i5)', 'Loadcase:', i
|
||||||
|
if (velGradApplied(i) == .true.) then
|
||||||
|
print '(a,/,3(3(f12.6,x)/))','L:' ,math_transpose3x3(bc_deformation(:,:,i))
|
||||||
|
print '(a,/,3(3(l,x)/))', 'bc_mask for L:',transpose(bc_mask(:,:,1,i))
|
||||||
|
else
|
||||||
|
print '(a,/,3(3(f12.6,x)/))','Fdot:' ,math_transpose3x3(bc_deformation(:,:,i))
|
||||||
|
print '(a,/,3(3(l,x)/))', 'bc_mask for Fdot:',transpose(bc_mask(:,:,1,i))
|
||||||
|
endif
|
||||||
print '(a,/,3(3(f12.6,x)/))','bc_stress:',math_transpose3x3(bc_stress(:,:,i))
|
print '(a,/,3(3(f12.6,x)/))','bc_stress:',math_transpose3x3(bc_stress(:,:,i))
|
||||||
print '(a,/,3(3(l,x)/))', 'bc_mask for velocitygrad:',transpose(bc_mask(:,:,1,i))
|
|
||||||
print '(a,/,3(3(l,x)/))', 'bc_mask for stress:' ,transpose(bc_mask(:,:,2,i))
|
print '(a,/,3(3(l,x)/))', 'bc_mask for stress:' ,transpose(bc_mask(:,:,2,i))
|
||||||
print '(a,f12.6)','time: ',bc_timeIncrement(i)
|
print '(a,f12.6)','time: ',bc_timeIncrement(i)
|
||||||
print '(a,i6)','incs: ',bc_steps(i)
|
print '(a,i6)','incs: ',bc_steps(i)
|
||||||
|
@ -304,6 +338,9 @@ program DAMASK_spectral
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
c066 = c066 * wgt
|
c066 = c066 * wgt
|
||||||
c0 = math_mandel66to3333(c066) ! linear reference material stiffness
|
c0 = math_mandel66to3333(c066) ! linear reference material stiffness
|
||||||
|
call math_invert(6, c066, s066,i, errmatinv) ! ToDo
|
||||||
|
if(errmatinv) call IO_error(800) ! Matrix inversion error ToDo
|
||||||
|
s0 = math_mandel66to3333(s066) ! ToDo
|
||||||
|
|
||||||
do k = 1, resolution(3) ! calculation of discrete angular frequencies, ordered as in FFTW (wrap around)
|
do k = 1, resolution(3) ! calculation of discrete angular frequencies, ordered as in FFTW (wrap around)
|
||||||
k_s(3) = k-1
|
k_s(3) = k-1
|
||||||
|
@ -344,7 +381,7 @@ program DAMASK_spectral
|
||||||
|
|
||||||
! Initialization of fftw (see manual on fftw.org for more details)
|
! Initialization of fftw (see manual on fftw.org for more details)
|
||||||
call dfftw_init_threads(ierr)
|
call dfftw_init_threads(ierr)
|
||||||
if(ierr == 0) call IO_error(104,ierr)
|
if(ierr == 0_pInt) call IO_error(104,ierr)
|
||||||
call dfftw_plan_with_nthreads(DAMASK_NumThreadsInt)
|
call dfftw_plan_with_nthreads(DAMASK_NumThreadsInt)
|
||||||
call dfftw_plan_many_dft_r2c(plan_fft(1),3,(/resolution(1),resolution(2),resolution(3)/),9,&
|
call dfftw_plan_many_dft_r2c(plan_fft(1),3,(/resolution(1),resolution(2),resolution(3)/),9,&
|
||||||
workfft,(/resolution(1) +2,resolution(2),resolution(3)/),1,(resolution(1) +2)*resolution(2)*resolution(3),&
|
workfft,(/resolution(1) +2,resolution(2),resolution(3)/),1,(resolution(1) +2)*resolution(2)*resolution(3),&
|
||||||
|
@ -363,7 +400,7 @@ program DAMASK_spectral
|
||||||
write(538), 'dimension', geomdimension
|
write(538), 'dimension', geomdimension
|
||||||
write(538), 'materialpoint_sizeResults', materialpoint_sizeResults
|
write(538), 'materialpoint_sizeResults', materialpoint_sizeResults
|
||||||
write(538), 'loadcases', N_Loadcases
|
write(538), 'loadcases', N_Loadcases
|
||||||
write(538), 'logscale', bc_logscale ! one entry per loadcase (0: linear, 1: log)
|
write(538), 'logscale', bc_logscale ! one entry per loadcase (false: linear, true: log)
|
||||||
write(538), 'frequencies', bc_frequency ! one entry per loadcase
|
write(538), 'frequencies', bc_frequency ! one entry per loadcase
|
||||||
write(538), 'times', bc_timeIncrement ! one entry per loadcase
|
write(538), 'times', bc_timeIncrement ! one entry per loadcase
|
||||||
bc_steps(1) = bc_steps(1)+1 ! +1 to store initial situation
|
bc_steps(1) = bc_steps(1)+1 ! +1 to store initial situation
|
||||||
|
@ -379,7 +416,12 @@ program DAMASK_spectral
|
||||||
do loadcase = 1, N_Loadcases
|
do loadcase = 1, N_Loadcases
|
||||||
!*************************************************************
|
!*************************************************************
|
||||||
time0 = time ! loadcase start time
|
time0 = time ! loadcase start time
|
||||||
|
|
||||||
|
if (followFormeTrajectory(loadcase) == .true.) then
|
||||||
|
guessmode = 1.0_pReal
|
||||||
|
else
|
||||||
guessmode = 0.0_pReal ! change of load case, homogeneous guess for the first step
|
guessmode = 0.0_pReal ! change of load case, homogeneous guess for the first step
|
||||||
|
endif
|
||||||
|
|
||||||
mask_defgrad = merge(ones,zeroes,bc_mask(:,:,1,loadcase))
|
mask_defgrad = merge(ones,zeroes,bc_mask(:,:,1,loadcase))
|
||||||
mask_stress = merge(ones,zeroes,bc_mask(:,:,2,loadcase))
|
mask_stress = merge(ones,zeroes,bc_mask(:,:,2,loadcase))
|
||||||
|
@ -388,9 +430,9 @@ program DAMASK_spectral
|
||||||
! loop oper steps defined in input file for current loadcase
|
! loop oper steps defined in input file for current loadcase
|
||||||
do step = 1, bc_steps(loadcase)
|
do step = 1, bc_steps(loadcase)
|
||||||
!*************************************************************
|
!*************************************************************
|
||||||
if (bc_logscale(loadcase) == 1) then ! loglinear scale
|
if (bc_logscale(loadcase) == .true.) then ! loglinear scale
|
||||||
if (loadcase == 1) then ! 1st loadcase of loglinear scale
|
if (loadcase == 1_pInt) then ! 1st loadcase of loglinear scale
|
||||||
if (step == 1) then ! 1st step of 1st loadcase of loglinear scale
|
if (step == 1_pInt) then ! 1st step of 1st loadcase of loglinear scale
|
||||||
timeinc = bc_timeIncrement(1)*(2.0**(1 - bc_steps(1))) ! assume 1st step is equal to 2nd
|
timeinc = bc_timeIncrement(1)*(2.0**(1 - bc_steps(1))) ! assume 1st step is equal to 2nd
|
||||||
else ! not-1st step of 1st loadcase of loglinear scale
|
else ! not-1st step of 1st loadcase of loglinear scale
|
||||||
timeinc = bc_timeIncrement(1)*(2.0**(step - (1 + bc_steps(1))))
|
timeinc = bc_timeIncrement(1)*(2.0**(step - (1 + bc_steps(1))))
|
||||||
|
@ -404,29 +446,47 @@ program DAMASK_spectral
|
||||||
endif
|
endif
|
||||||
|
|
||||||
time = time + timeinc
|
time = time + timeinc
|
||||||
temp33_Real = defgradAim
|
|
||||||
defgradAim = defgradAim & ! update macroscopic displacement gradient (defgrad BC)
|
|
||||||
+ guessmode * mask_stress * (defgradAim - defgradAimOld) &
|
|
||||||
+ math_mul33x33(bc_velocityGrad(:,:,loadcase), defgradAim)*timeinc
|
|
||||||
defgradAimOld = temp33_Real
|
|
||||||
|
|
||||||
|
! update macroscopic deformation gradient (defgrad BC)
|
||||||
|
temp33_Real = defgradAim
|
||||||
|
if (velGradApplied(loadcase) == .true.) then ! calculate from given L and current F
|
||||||
|
defgradAim = defgradAim &
|
||||||
|
+ guessmode * mask_stress * (defgradAim - defgradAimOld) &
|
||||||
|
+ math_mul33x33(bc_deformation(:,:,loadcase), defgradAim)*timeinc
|
||||||
|
else ! calculate from given Fdot and current F
|
||||||
|
defgradAim = defgradAim &
|
||||||
|
+ guessmode * mask_stress * (defgradAim - defgradAimOld) &
|
||||||
|
+ mask_defgrad * bc_deformation(:,:,loadcase) * timeinc
|
||||||
|
endif
|
||||||
|
defgradAimOld = temp33_Real
|
||||||
|
! update local deformation gradient
|
||||||
do k = 1, resolution(3); do j = 1, resolution(2); do i = 1, resolution(1)
|
do k = 1, resolution(3); do j = 1, resolution(2); do i = 1, resolution(1)
|
||||||
|
if (velGradApplied(loadcase) == .true.) then ! using velocity gradient to calculate new deformation gradient (if not guessing)
|
||||||
temp33_Real = defgrad(i,j,k,:,:)
|
temp33_Real = defgrad(i,j,k,:,:)
|
||||||
defgrad(i,j,k,:,:) = defgrad(i,j,k,:,:)& ! old fluctuations as guess for new step, no fluctuations for new loadcase
|
defgrad(i,j,k,:,:) = defgrad(i,j,k,:,:) & ! decide if guessing along former trajectory or apply homogeneous addon
|
||||||
+ guessmode * (defgrad(i,j,k,:,:) - defgradold(i,j,k,:,:))&
|
+ guessmode * (defgrad(i,j,k,:,:) - defgradold(i,j,k,:,:))&
|
||||||
+ (1.0_pReal-guessmode) * math_mul33x33(bc_velocityGrad(:,:,loadcase),defgradold(i,j,k,:,:))*timeinc
|
+ (1.0_pReal-guessmode) * math_mul33x33(bc_deformation(:,:,loadcase),defgradold(i,j,k,:,:))*timeinc
|
||||||
defgradold(i,j,k,:,:) = temp33_Real
|
defgradold(i,j,k,:,:) = temp33_Real
|
||||||
|
else ! using time derivative of deformation gradient to calculate new deformation gradient (if not guessing)
|
||||||
|
temp33_Real = defgrad(i,j,k,:,:)
|
||||||
|
defgrad(i,j,k,:,:) = defgrad(i,j,k,:,:) & ! decide if guessing along former trajectory or apply homogeneous addon
|
||||||
|
+ guessmode * (defgrad(i,j,k,:,:) - defgradold(i,j,k,:,:))&
|
||||||
|
+ (1.0_pReal-guessmode) * bc_deformation(:,:,loadcase) * timeinc
|
||||||
|
defgradold(i,j,k,:,:) = temp33_Real
|
||||||
|
endif
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
|
|
||||||
guessmode = 1.0_pReal ! keep guessing along former trajectory during same loadcase
|
guessmode = 1.0_pReal ! keep guessing along former trajectory during same loadcase
|
||||||
|
|
||||||
if(all(bc_mask(:,:,1,loadcase))) then
|
if(all(bc_mask(:,:,1,loadcase))) then
|
||||||
calcmode = 1_pInt ! if no stress BC is given (calmode 0 is not needed)
|
calcmode = 1_pInt ! if no stress BC is given (calmode 0 is not needed)
|
||||||
else
|
else
|
||||||
calcmode = 0_pInt ! start calculation of BC fulfillment
|
calcmode = 0_pInt ! start calculation of BC fulfillment
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CPFEM_mode = 1_pInt ! winding forward
|
CPFEM_mode = 1_pInt ! winding forward
|
||||||
iter = 0_pInt
|
iter = 0_pInt
|
||||||
err_div= 2_pReal * err_div_tol ! go into loop
|
err_div= 2.0_pReal * err_div_tol ! go into loop
|
||||||
defgradAimCorr = 0.0_pReal ! reset damping calculation
|
defgradAimCorr = 0.0_pReal ! reset damping calculation
|
||||||
damper = damper * 0.9_pReal
|
damper = damper * 0.9_pReal
|
||||||
|
|
||||||
|
@ -437,6 +497,7 @@ program DAMASK_spectral
|
||||||
err_stress > err_stress_tol .or. &
|
err_stress > err_stress_tol .or. &
|
||||||
err_defgrad > err_defgrad_tol))
|
err_defgrad > err_defgrad_tol))
|
||||||
iter = iter + 1_pInt
|
iter = iter + 1_pInt
|
||||||
|
if (iter == itmax) doesNotConverge = doesNotConverge + 1
|
||||||
print*, ' '
|
print*, ' '
|
||||||
print '(3(A,I5.5,tr2))', ' Loadcase = ',loadcase, ' Step = ',step, ' Iteration = ',iter
|
print '(3(A,I5.5,tr2))', ' Loadcase = ',loadcase, ' Step = ',step, ' Iteration = ',iter
|
||||||
cstress_av = 0.0_pReal
|
cstress_av = 0.0_pReal
|
||||||
|
@ -456,7 +517,7 @@ program DAMASK_spectral
|
||||||
cstress,dsde, pstress, dPdF)
|
cstress,dsde, pstress, dPdF)
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
|
|
||||||
c0_temp = 0.0_pReal !for calculation of s0
|
! c0_temp = 0.0_pReal !for calculation of s0 ToDo
|
||||||
ielem = 0_pInt
|
ielem = 0_pInt
|
||||||
do k = 1, resolution(3); do j = 1, resolution(2); do i = 1, resolution(1)
|
do k = 1, resolution(3); do j = 1, resolution(2); do i = 1, resolution(1)
|
||||||
ielem = ielem + 1_pInt
|
ielem = ielem + 1_pInt
|
||||||
|
@ -466,14 +527,14 @@ program DAMASK_spectral
|
||||||
temperature,timeinc,ielem,1_pInt,&
|
temperature,timeinc,ielem,1_pInt,&
|
||||||
cstress,dsde, pstress, dPdF)
|
cstress,dsde, pstress, dPdF)
|
||||||
CPFEM_mode = 2_pInt
|
CPFEM_mode = 2_pInt
|
||||||
c0_temp = c0_temp + dPdF
|
! c0_temp = c0_temp + dPdF ToDo
|
||||||
workfft(i,j,k,:,:) = pstress ! build up average P-K stress
|
workfft(i,j,k,:,:) = pstress ! build up average P-K stress
|
||||||
cstress_av = cstress_av + math_mandel6to33(cstress) ! build up average Cauchy stress
|
cstress_av = cstress_av + math_mandel6to33(cstress) ! build up average Cauchy stress
|
||||||
enddo; enddo; enddo
|
enddo; enddo; enddo
|
||||||
|
|
||||||
call math_invert(9, math_plain3333to99(c0_temp),s099,i,errmatinv)
|
! call math_invert(9, math_plain3333to99(c0_temp),s099,i,errmatinv) ToDo
|
||||||
if(errmatinv) call IO_error(800,ext_msg = "problem in c0 inversion")
|
! if(errmatinv) call IO_error(800,ext_msg = "problem in c0 inversion") ToDo
|
||||||
s0 = math_plain99to3333(s099) *real(resolution(1)*resolution(2)*resolution(3), pReal) ! average s0 for calculation of BC
|
! s0 = math_plain99to3333(s099) *real(resolution(1)*resolution(2)*resolution(3), pReal) ! average s0 for calculation of BC ToDo
|
||||||
|
|
||||||
cstress_av = cstress_av * wgt
|
cstress_av = cstress_av * wgt
|
||||||
do n = 1,3; do m = 1,3
|
do n = 1,3; do m = 1,3
|
||||||
|
@ -501,12 +562,12 @@ program DAMASK_spectral
|
||||||
do m = 1,3; do n = 1,3
|
do m = 1,3; do n = 1,3
|
||||||
defgrad(:,:,:,m,n) = defgrad(:,:,:,m,n) + (defgradAim(m,n) - defgrad_av(m,n)) ! anticipated target minus current state
|
defgrad(:,:,:,m,n) = defgrad(:,:,:,m,n) + (defgradAim(m,n) - defgrad_av(m,n)) ! anticipated target minus current state
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
err_div = 2 * err_div_tol
|
err_div = 2.0_pReal * err_div_tol
|
||||||
err_defgrad = maxval(abs(mask_defgrad * (defgrad_av - defgradAim)))
|
err_defgrad = maxval(abs(mask_defgrad * (defgrad_av - defgradAim)))
|
||||||
print '(a,/,3(3(f12.7,x)/))', ' Deformation Gradient:',math_transpose3x3(defgrad_av)
|
print '(a,/,3(3(f12.7,x)/))', ' Deformation Gradient:',math_transpose3x3(defgrad_av)
|
||||||
print '(a,/,3(3(f10.4,x)/))', ' Cauchy Stress / MPa: ',math_transpose3x3(cstress_av)/1.e6
|
print '(a,/,3(3(f10.4,x)/))', ' Piola-Kirchhoff Stress / MPa: ',math_transpose3x3(pstress_av)/1.e6
|
||||||
print '(2(a,E8.2))', ' error stress: ',err_stress, ' Tol. = ', err_stress_tol
|
print '(2(a,E8.2))', ' error stress: ',err_stress, ' Tol. = ', err_stress_tol*0.8
|
||||||
print '(2(a,E8.2))', ' error deformation gradient: ',err_defgrad,' Tol. = ', err_defgrad_tol*0.8
|
print '(2(a,E8.2))', ' error deformation gradient: ',err_defgrad,' Tol. = ', err_defgrad_tol
|
||||||
if(err_stress < err_stress_tol*0.8) then
|
if(err_stress < err_stress_tol*0.8) then
|
||||||
calcmode = 1_pInt
|
calcmode = 1_pInt
|
||||||
endif
|
endif
|
||||||
|
@ -590,7 +651,7 @@ program DAMASK_spectral
|
||||||
defgrad = defgrad + workfft(1:resolution(1),:,:,:,:)*wgt
|
defgrad = defgrad + workfft(1:resolution(1),:,:,:,:)*wgt
|
||||||
do m = 1,3; do n = 1,3
|
do m = 1,3; do n = 1,3
|
||||||
defgrad_av(m,n) = sum(defgrad(:,:,:,m,n))*wgt
|
defgrad_av(m,n) = sum(defgrad(:,:,:,m,n))*wgt
|
||||||
defgrad(:,:,:,m,n) = defgrad(:,:,:,m,n) + (defgradAim(m,n) - defgrad_av(m,n)) ! anticipated target minus current state
|
defgrad(:,:,:,m,n) = defgrad(:,:,:,m,n) + mask_defgrad(m,n)*(defgradAim(m,n) - defgrad_av(m,n)) ! anticipated target minus current state on components with prescribed deformation
|
||||||
enddo; enddo
|
enddo; enddo
|
||||||
|
|
||||||
err_stress = maxval(abs(mask_stress * (pstress_av - bc_stress(:,:,loadcase))))
|
err_stress = maxval(abs(mask_stress * (pstress_av - bc_stress(:,:,loadcase))))
|
||||||
|
@ -616,9 +677,11 @@ program DAMASK_spectral
|
||||||
print '(a,/,3(3(f12.7,x)/))', ' Deformation Aim: ',math_transpose3x3(defgradAim)
|
print '(a,/,3(3(f12.7,x)/))', ' Deformation Aim: ',math_transpose3x3(defgradAim)
|
||||||
print '(a,/,3(3(f12.7,x)/))', ' Deformation Gradient:',math_transpose3x3(defgrad_av)
|
print '(a,/,3(3(f12.7,x)/))', ' Deformation Gradient:',math_transpose3x3(defgrad_av)
|
||||||
print '(a,/,3(3(f10.4,x)/))', ' Cauchy Stress / MPa: ',math_transpose3x3(cstress_av)/1.e6
|
print '(a,/,3(3(f10.4,x)/))', ' Cauchy Stress / MPa: ',math_transpose3x3(cstress_av)/1.e6
|
||||||
|
print '(a,/,3(3(f10.4,x)/))', ' Piola-Kirchhoff Stress / MPa: ',math_transpose3x3(pstress_av)/1.e6
|
||||||
print '(A)', '************************************************************'
|
print '(A)', '************************************************************'
|
||||||
enddo ! end looping over steps in current loadcase
|
enddo ! end looping over steps in current loadcase
|
||||||
enddo ! end looping over loadcases
|
enddo ! end looping over loadcases
|
||||||
|
print '(a,i10,a)', 'A Total of ', doesNotConverge, ' Steps did not converge!'
|
||||||
close(538)
|
close(538)
|
||||||
call dfftw_destroy_plan(plan_fft(1)); call dfftw_destroy_plan(plan_fft(2))
|
call dfftw_destroy_plan(plan_fft(1)); call dfftw_destroy_plan(plan_fft(2))
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,8 @@
|
||||||
# Install fftw3 (v3.2.2 is tested) with "./configure --enable-threads --enable-float" and "make", "make install" is not needed
|
# Install fftw3 (v3.2.2 is tested) with "./configure --enable-threads --enable-float" and "make", "make install" is not needed
|
||||||
# as long as the two library files are copied to the source code directory.
|
# as long as the two library files are copied to the source code directory.
|
||||||
|
|
||||||
COMPILE_DOUBLE = -openmp -c -O3 -fpp -heap-arrays 500000000
|
COMPILE_HEAP = -openmp -c -O3 -fpp -heap-arrays 500000000
|
||||||
COMPILE_SINGLE = -openmp -c -O3 -fpp
|
COMPILE = -openmp -c -O3 -fpp
|
||||||
|
|
||||||
|
|
||||||
precision :=double
|
precision :=double
|
||||||
|
@ -19,28 +19,28 @@ ifeq ($(precision),single)
|
||||||
DAMASK_spectral_single.exe: DAMASK_spectral_single.o CPFEM.a
|
DAMASK_spectral_single.exe: DAMASK_spectral_single.o CPFEM.a
|
||||||
ifort -openmp -o DAMASK_spectral_single.exe DAMASK_spectral_single.o CPFEM.a include/libfftw3f_threads.a include/libfftw3f.a constitutive.a advanced.a basics.a -lpthread
|
ifort -openmp -o DAMASK_spectral_single.exe DAMASK_spectral_single.o CPFEM.a include/libfftw3f_threads.a include/libfftw3f.a constitutive.a advanced.a basics.a -lpthread
|
||||||
DAMASK_spectral_single.o: DAMASK_spectral_single.f90 CPFEM.o
|
DAMASK_spectral_single.o: DAMASK_spectral_single.f90 CPFEM.o
|
||||||
ifort $(COMPILE_DOUBLE) DAMASK_spectral_single.f90
|
ifort $(COMPILE_HEAP) DAMASK_spectral_single.f90
|
||||||
|
|
||||||
else
|
else
|
||||||
DAMASK_spectral.exe: DAMASK_spectral.o CPFEM.a
|
DAMASK_spectral.exe: DAMASK_spectral.o CPFEM.a
|
||||||
ifort -openmp -o DAMASK_spectral.exe DAMASK_spectral.o CPFEM.a include/libfftw3_threads.a include/libfftw3.a constitutive.a advanced.a basics.a -lpthread
|
ifort -openmp -o DAMASK_spectral.exe DAMASK_spectral.o CPFEM.a include/libfftw3_threads.a include/libfftw3.a constitutive.a advanced.a basics.a -lpthread
|
||||||
DAMASK_spectral.o: DAMASK_spectral.f90 CPFEM.o
|
DAMASK_spectral.o: DAMASK_spectral.f90 CPFEM.o
|
||||||
ifort $(COMPILE_DOUBLE) DAMASK_spectral.f90
|
ifort $(COMPILE_HEAP) DAMASK_spectral.f90
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CPFEM.a: CPFEM.o
|
CPFEM.a: CPFEM.o
|
||||||
ar rc CPFEM.a homogenization.o homogenization_RGC.o homogenization_isostrain.o crystallite.o CPFEM.o constitutive.o
|
ar rc CPFEM.a homogenization.o homogenization_RGC.o homogenization_isostrain.o crystallite.o CPFEM.o constitutive.o
|
||||||
|
|
||||||
CPFEM.o: CPFEM.f90 homogenization.o
|
CPFEM.o: CPFEM.f90 homogenization.o
|
||||||
ifort $(COMPILE_DOUBLE) CPFEM.f90
|
ifort $(COMPILE_HEAP) CPFEM.f90
|
||||||
homogenization.o: homogenization.f90 homogenization_isostrain.o homogenization_RGC.o crystallite.o
|
homogenization.o: homogenization.f90 homogenization_isostrain.o homogenization_RGC.o crystallite.o
|
||||||
ifort $(COMPILE_DOUBLE) homogenization.f90
|
ifort $(COMPILE_HEAP) homogenization.f90
|
||||||
homogenization_RGC.o: homogenization_RGC.f90 constitutive.a
|
homogenization_RGC.o: homogenization_RGC.f90 constitutive.a
|
||||||
ifort $(COMPILE_DOUBLE) homogenization_RGC.f90
|
ifort $(COMPILE_HEAP) homogenization_RGC.f90
|
||||||
homogenization_isostrain.o: homogenization_isostrain.f90 basics.a advanced.a
|
homogenization_isostrain.o: homogenization_isostrain.f90 basics.a advanced.a
|
||||||
ifort $(COMPILE_DOUBLE) homogenization_isostrain.f90
|
ifort $(COMPILE_HEAP) homogenization_isostrain.f90
|
||||||
crystallite.o: crystallite.f90 constitutive.a
|
crystallite.o: crystallite.f90 constitutive.a
|
||||||
ifort $(COMPILE_DOUBLE) crystallite.f90
|
ifort $(COMPILE_HEAP) crystallite.f90
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -48,22 +48,22 @@ constitutive.a: constitutive.o
|
||||||
ar rc constitutive.a constitutive.o constitutive_titanmod.o constitutive_nonlocal.o constitutive_dislotwin.o constitutive_j2.o constitutive_phenopowerlaw.o basics.a advanced.a
|
ar rc constitutive.a constitutive.o constitutive_titanmod.o constitutive_nonlocal.o constitutive_dislotwin.o constitutive_j2.o constitutive_phenopowerlaw.o basics.a advanced.a
|
||||||
|
|
||||||
constitutive.o: constitutive.f90 constitutive_titanmod.o constitutive_nonlocal.o constitutive_dislotwin.o constitutive_j2.o constitutive_phenopowerlaw.o
|
constitutive.o: constitutive.f90 constitutive_titanmod.o constitutive_nonlocal.o constitutive_dislotwin.o constitutive_j2.o constitutive_phenopowerlaw.o
|
||||||
ifort $(COMPILE_DOUBLE) constitutive.f90
|
ifort $(COMPILE_HEAP) constitutive.f90
|
||||||
|
|
||||||
constitutive_titanmod.o: constitutive_titanmod.f90 basics.a advanced.a
|
constitutive_titanmod.o: constitutive_titanmod.f90 basics.a advanced.a
|
||||||
ifort $(COMPILE_DOUBLE) constitutive_titanmod.f90
|
ifort $(COMPILE_HEAP) constitutive_titanmod.f90
|
||||||
|
|
||||||
constitutive_nonlocal.o: constitutive_nonlocal.f90 basics.a advanced.a
|
constitutive_nonlocal.o: constitutive_nonlocal.f90 basics.a advanced.a
|
||||||
ifort $(COMPILE_DOUBLE) constitutive_nonlocal.f90
|
ifort $(COMPILE_HEAP) constitutive_nonlocal.f90
|
||||||
|
|
||||||
constitutive_dislotwin.o: constitutive_dislotwin.f90 basics.a advanced.a
|
constitutive_dislotwin.o: constitutive_dislotwin.f90 basics.a advanced.a
|
||||||
ifort $(COMPILE_DOUBLE) constitutive_dislotwin.f90
|
ifort $(COMPILE_HEAP) constitutive_dislotwin.f90
|
||||||
|
|
||||||
constitutive_j2.o: constitutive_j2.f90 basics.a advanced.a
|
constitutive_j2.o: constitutive_j2.f90 basics.a advanced.a
|
||||||
ifort $(COMPILE_DOUBLE) constitutive_j2.f90
|
ifort $(COMPILE_HEAP) constitutive_j2.f90
|
||||||
|
|
||||||
constitutive_phenopowerlaw.o: constitutive_phenopowerlaw.f90 basics.a advanced.a
|
constitutive_phenopowerlaw.o: constitutive_phenopowerlaw.f90 basics.a advanced.a
|
||||||
ifort $(COMPILE_DOUBLE) constitutive_phenopowerlaw.f90
|
ifort $(COMPILE_HEAP) constitutive_phenopowerlaw.f90
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -72,13 +72,13 @@ advanced.a: lattice.o
|
||||||
|
|
||||||
|
|
||||||
lattice.o: lattice.f90 material.o
|
lattice.o: lattice.f90 material.o
|
||||||
ifort $(COMPILE_DOUBLE) lattice.f90
|
ifort $(COMPILE_HEAP) lattice.f90
|
||||||
material.o: material.f90 mesh.o
|
material.o: material.f90 mesh.o
|
||||||
ifort $(COMPILE_DOUBLE) material.f90
|
ifort $(COMPILE_HEAP) material.f90
|
||||||
mesh.o: mesh.f90 FEsolving.o
|
mesh.o: mesh.f90 FEsolving.o
|
||||||
ifort $(COMPILE_DOUBLE) mesh.f90
|
ifort $(COMPILE_HEAP) mesh.f90
|
||||||
FEsolving.o: FEsolving.f90 basics.a
|
FEsolving.o: FEsolving.f90 basics.a
|
||||||
ifort $(COMPILE_DOUBLE) FEsolving.f90
|
ifort $(COMPILE_HEAP) FEsolving.f90
|
||||||
|
|
||||||
ifeq ($(precision),single)
|
ifeq ($(precision),single)
|
||||||
basics.a: debug.o math.o
|
basics.a: debug.o math.o
|
||||||
|
@ -89,32 +89,29 @@ basics.a: debug.o math.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
debug.o: debug.f90 numerics.o
|
debug.o: debug.f90 numerics.o
|
||||||
ifort $(COMPILE_SINGLE) debug.f90
|
ifort $(COMPILE) debug.f90
|
||||||
math.o: math.f90 numerics.o
|
math.o: math.f90 numerics.o
|
||||||
ifort $(COMPILE_SINGLE) math.f90
|
ifort $(COMPILE) math.f90
|
||||||
|
|
||||||
numerics.o: numerics.f90 IO.o
|
numerics.o: numerics.f90 IO.o
|
||||||
ifort $(COMPILE_SINGLE) numerics.f90
|
ifort $(COMPILE) numerics.f90
|
||||||
IO.o: IO.f90 DAMASK_spectral_interface.o
|
IO.o: IO.f90 DAMASK_spectral_interface.o
|
||||||
ifort $(COMPILE_SINGLE) IO.f90
|
ifort $(COMPILE) IO.f90
|
||||||
|
|
||||||
ifeq ($(precision),single)
|
ifeq ($(precision),single)
|
||||||
DAMASK_spectral_interface.o: DAMASK_spectral_interface.f90 prec_single.o
|
DAMASK_spectral_interface.o: DAMASK_spectral_interface.f90 prec_single.o
|
||||||
ifort $(COMPILE_SINGLE) DAMASK_spectral_interface.f90
|
ifort $(COMPILE) DAMASK_spectral_interface.f90
|
||||||
prec_single.o: prec_single.f90
|
prec_single.o: prec_single.f90
|
||||||
ifort $(COMPILE_SINGLE) prec_single.f90
|
ifort $(COMPILE) prec_single.f90
|
||||||
else
|
else
|
||||||
DAMASK_spectral_interface.o: DAMASK_spectral_interface.f90 prec.o
|
DAMASK_spectral_interface.o: DAMASK_spectral_interface.f90 prec.o
|
||||||
ifort $(COMPILE_SINGLE) DAMASK_spectral_interface.f90
|
ifort $(COMPILE) DAMASK_spectral_interface.f90
|
||||||
prec.o: prec.f90
|
prec.o: prec.f90
|
||||||
ifort $(COMPILE_SINGLE) prec.f90
|
ifort $(COMPILE) prec.f90
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -rf *.o
|
rm -rf *.o
|
||||||
rm -rf *.mod
|
rm -rf *.mod
|
||||||
rm -rf basics.a
|
rm -rf *.a
|
||||||
rm -rf advanced.a
|
|
||||||
rm -rf constitutive.a
|
|
||||||
rm -rf CPFEM.a
|
|
||||||
|
|
Loading…
Reference in New Issue