moved petsc option string to numerics and added new numerics parameters to config file
This commit is contained in:
parent
93658c72db
commit
32f8c9c6ea
|
@ -56,7 +56,6 @@ module DAMASK_spectral_SolverAL
|
||||||
PetscInt, private :: xs,xm,gxs,gxm
|
PetscInt, private :: xs,xm,gxs,gxm
|
||||||
PetscInt, private :: ys,ym,gys,gym
|
PetscInt, private :: ys,ym,gys,gym
|
||||||
PetscInt, private :: zs,zm,gzs,gzm
|
PetscInt, private :: zs,zm,gzs,gzm
|
||||||
character(len=1024), private :: PetSc_options = '-snes_type ngmres -snes_ngmres_anderson -snes_monitor -snes_view'
|
|
||||||
|
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! common pointwise data
|
! common pointwise data
|
||||||
|
@ -104,10 +103,14 @@ module DAMASK_spectral_SolverAL
|
||||||
Utilities_constitutiveResponse, &
|
Utilities_constitutiveResponse, &
|
||||||
Utilities_updateGamma, &
|
Utilities_updateGamma, &
|
||||||
debugrestart
|
debugrestart
|
||||||
|
|
||||||
|
use numerics, only: &
|
||||||
|
petsc_options
|
||||||
|
|
||||||
use mesh, only: &
|
use mesh, only: &
|
||||||
res, &
|
res, &
|
||||||
geomdim
|
geomdim
|
||||||
|
|
||||||
use math, only: &
|
use math, only: &
|
||||||
math_invSym3333
|
math_invSym3333
|
||||||
|
|
||||||
|
@ -208,7 +211,7 @@ module DAMASK_spectral_SolverAL
|
||||||
call SNESSetDM(snes,da,ierr_psc)
|
call SNESSetDM(snes,da,ierr_psc)
|
||||||
call SNESSetFunction(snes,residual,AL_FormRHS,dummy,ierr_psc)
|
call SNESSetFunction(snes,residual,AL_FormRHS,dummy,ierr_psc)
|
||||||
call SNESSetConvergenceTest(snes,AL_converged,dummy,PETSC_NULL_FUNCTION,ierr_psc)
|
call SNESSetConvergenceTest(snes,AL_converged,dummy,PETSC_NULL_FUNCTION,ierr_psc)
|
||||||
call PetscOptionsInsertString(PetSc_options,ierr_psc)
|
call PetscOptionsInsertString(petsc_options,ierr_psc)
|
||||||
call SNESSetFromOptions(snes,ierr_psc)
|
call SNESSetFromOptions(snes,ierr_psc)
|
||||||
call DMDAGetCorners(da,xs,ys,zs,xm,ym,zm,ierr_psc)
|
call DMDAGetCorners(da,xs,ys,zs,xm,ym,zm,ierr_psc)
|
||||||
call DMDAGetCorners(da,gxs,gys,gzs,gxm,gym,gzm,ierr_psc)
|
call DMDAGetCorners(da,gxs,gys,gzs,gxm,gym,gzm,ierr_psc)
|
||||||
|
@ -321,8 +324,9 @@ module DAMASK_spectral_SolverAL
|
||||||
|
|
||||||
end function AL_solution
|
end function AL_solution
|
||||||
|
|
||||||
! -------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
!> @brief fills solution vector with forwarded fields
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine AL_InitialGuess(xx_psc)
|
subroutine AL_InitialGuess(xx_psc)
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
|
@ -360,6 +364,9 @@ module DAMASK_spectral_SolverAL
|
||||||
return
|
return
|
||||||
end subroutine AL_InitialGuess
|
end subroutine AL_InitialGuess
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
!> @brief forms the AL residual vector
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine AL_FormRHS(snes_local,X_local,F_local,dummy,ierr_psc)
|
subroutine AL_FormRHS(snes_local,X_local,F_local,dummy,ierr_psc)
|
||||||
|
|
||||||
! Input/output variables:
|
! Input/output variables:
|
||||||
|
@ -409,18 +416,9 @@ module DAMASK_spectral_SolverAL
|
||||||
|
|
||||||
end subroutine AL_FormRHS
|
end subroutine AL_FormRHS
|
||||||
|
|
||||||
! ---------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!
|
!> @brief forms the AL residual vector
|
||||||
! Input Parameter:
|
!--------------------------------------------------------------------------------------------------
|
||||||
! x - local vector data
|
|
||||||
!
|
|
||||||
! Output Parameters:
|
|
||||||
! f - local vector data, f(x)
|
|
||||||
! ierr - error code
|
|
||||||
!
|
|
||||||
! Notes:
|
|
||||||
! This routine uses standard Fortran-style computations over a 3-dim array.
|
|
||||||
!
|
|
||||||
subroutine AL_FormRHS_local(x_scal,f_scal,dummy,ierr_psc)
|
subroutine AL_FormRHS_local(x_scal,f_scal,dummy,ierr_psc)
|
||||||
|
|
||||||
use numerics, only: &
|
use numerics, only: &
|
||||||
|
@ -545,9 +543,9 @@ module DAMASK_spectral_SolverAL
|
||||||
return
|
return
|
||||||
end subroutine AL_FormRHS_local
|
end subroutine AL_FormRHS_local
|
||||||
|
|
||||||
! ---------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! User defined convergence check
|
!> @brief convergence check
|
||||||
!
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine AL_converged(snes_local,it,xnorm,snorm,fnorm,reason,dummy,ierr_psc)
|
subroutine AL_converged(snes_local,it,xnorm,snorm,fnorm,reason,dummy,ierr_psc)
|
||||||
|
|
||||||
use numerics, only: &
|
use numerics, only: &
|
||||||
|
@ -589,6 +587,9 @@ module DAMASK_spectral_SolverAL
|
||||||
|
|
||||||
end subroutine AL_converged
|
end subroutine AL_converged
|
||||||
|
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
|
!> @brief destroy routine
|
||||||
|
!--------------------------------------------------------------------------------------------------
|
||||||
subroutine AL_destroy()
|
subroutine AL_destroy()
|
||||||
use DAMASK_spectral_Utilities, only: &
|
use DAMASK_spectral_Utilities, only: &
|
||||||
Utilities_destroy
|
Utilities_destroy
|
||||||
|
|
|
@ -55,6 +55,8 @@ fixed_seed 0 # put any number larger than zero, intege
|
||||||
err_div_tol 0.1 # Div(P)/avg(P)*meter
|
err_div_tol 0.1 # Div(P)/avg(P)*meter
|
||||||
err_stress_tolrel 0.01 # relative tolerance for fulfillment of stress BC
|
err_stress_tolrel 0.01 # relative tolerance for fulfillment of stress BC
|
||||||
err_stress_tolabs 9.9e40 # absolute tolerance for fulfillment of stress BC
|
err_stress_tolabs 9.9e40 # absolute tolerance for fulfillment of stress BC
|
||||||
|
err_f_tol 1e-6 # tolerance for compatible and incompatible deformation gradient fields in AL solver
|
||||||
|
err_p_tol 1e-5 # tolerance for compatible and incompatible stress fields in AL solver
|
||||||
fftw_timelimit -1.0 # timelimit of plan creation for FFTW, see manual on www.fftw.org, Default -1.0: disable timelimit
|
fftw_timelimit -1.0 # timelimit of plan creation for FFTW, see manual on www.fftw.org, Default -1.0: disable timelimit
|
||||||
rotation_tol 1.0e-12 # tolerance of rotation specified in loadcase, Default 1.0e-12: first guess
|
rotation_tol 1.0e-12 # tolerance of rotation specified in loadcase, Default 1.0e-12: first guess
|
||||||
fftw_plan_mode FFTW_PATIENT # reads the planing-rigor flag, see manual on www.fftw.org, Default FFTW_PATIENT: use patient planner flag
|
fftw_plan_mode FFTW_PATIENT # reads the planing-rigor flag, see manual on www.fftw.org, Default FFTW_PATIENT: use patient planner flag
|
||||||
|
@ -63,3 +65,5 @@ itmin 2 # Minimum iteration number
|
||||||
memory_efficient 1 # Precalculate Gamma-operator (81 double per point)
|
memory_efficient 1 # Precalculate Gamma-operator (81 double per point)
|
||||||
update_gamma 0 # Update Gamma-operator with current dPdF (not possible if memory_efficient=1)
|
update_gamma 0 # Update Gamma-operator with current dPdF (not possible if memory_efficient=1)
|
||||||
divergence_correction 0 # Use dimension-independent divergence criterion
|
divergence_correction 0 # Use dimension-independent divergence criterion
|
||||||
|
myspectralsolver AL # Type of spectral solver (AL-augmented lagrange, basic-basic)
|
||||||
|
petsc_options -snes_type ngmres -snes_ngmres_anderson -snes_view # PetSc solver options
|
||||||
|
|
|
@ -83,6 +83,7 @@ real(pReal) :: err_div_tol = 0.1_pReal, &
|
||||||
rotation_tol = 1.0e-12_pReal ! tolerance of rotation specified in loadcase, Default 1.0e-12: first guess
|
rotation_tol = 1.0e-12_pReal ! tolerance of rotation specified in loadcase, Default 1.0e-12: first guess
|
||||||
character(len=64) :: fftw_plan_mode = 'FFTW_PATIENT', & ! reads the planing-rigor flag, see manual on www.fftw.org, Default FFTW_PATIENT: use patient planner flag
|
character(len=64) :: fftw_plan_mode = 'FFTW_PATIENT', & ! reads the planing-rigor flag, see manual on www.fftw.org, Default FFTW_PATIENT: use patient planner flag
|
||||||
myspectralsolver = 'basic' ! spectral solution method
|
myspectralsolver = 'basic' ! spectral solution method
|
||||||
|
character(len=1024) :: petsc_options = '-snes_type ngmres -snes_ngmres_anderson -snes_view'
|
||||||
integer(pInt) :: fftw_planner_flag = 32_pInt, & ! conversion of fftw_plan_mode to integer, basically what is usually done in the include file of fftw
|
integer(pInt) :: fftw_planner_flag = 32_pInt, & ! conversion of fftw_plan_mode to integer, basically what is usually done in the include file of fftw
|
||||||
itmax = 20_pInt, & ! maximum number of iterations
|
itmax = 20_pInt, & ! maximum number of iterations
|
||||||
itmin = 2_pInt ! minimum number of iterations
|
itmin = 2_pInt ! minimum number of iterations
|
||||||
|
@ -256,6 +257,8 @@ subroutine numerics_init
|
||||||
fftw_plan_mode = IO_stringValue(line,positions,2_pInt)
|
fftw_plan_mode = IO_stringValue(line,positions,2_pInt)
|
||||||
case ('myspectralsolver')
|
case ('myspectralsolver')
|
||||||
myspectralsolver = IO_stringValue(line,positions,2_pInt)
|
myspectralsolver = IO_stringValue(line,positions,2_pInt)
|
||||||
|
case ('petsc_options')
|
||||||
|
petsc_options = IO_stringValue(line,positions,2_pInt)
|
||||||
case ('rotation_tol')
|
case ('rotation_tol')
|
||||||
rotation_tol = IO_floatValue(line,positions,2_pInt)
|
rotation_tol = IO_floatValue(line,positions,2_pInt)
|
||||||
case ('divergence_correction')
|
case ('divergence_correction')
|
||||||
|
@ -266,7 +269,7 @@ subroutine numerics_init
|
||||||
#ifndef Spectral
|
#ifndef Spectral
|
||||||
case ('err_div_tol','err_stress_tolrel','err_stress_tolabs',&
|
case ('err_div_tol','err_stress_tolrel','err_stress_tolabs',&
|
||||||
'itmax', 'itmin','memory_efficient','fftw_timelimit','fftw_plan_mode','myspectralsolver', &
|
'itmax', 'itmin','memory_efficient','fftw_timelimit','fftw_plan_mode','myspectralsolver', &
|
||||||
'rotation_tol','divergence_correction','update_gamma')
|
'rotation_tol','divergence_correction','update_gamma','petsc_options')
|
||||||
call IO_warning(40_pInt,ext_msg=tag)
|
call IO_warning(40_pInt,ext_msg=tag)
|
||||||
#endif
|
#endif
|
||||||
case default
|
case default
|
||||||
|
@ -360,6 +363,7 @@ subroutine numerics_init
|
||||||
endif
|
endif
|
||||||
write(6,'(a24,1x,a)') ' fftw_plan_mode: ',trim(fftw_plan_mode)
|
write(6,'(a24,1x,a)') ' fftw_plan_mode: ',trim(fftw_plan_mode)
|
||||||
write(6,'(a24,1x,a)') ' myspectralsolver: ',trim(myspectralsolver)
|
write(6,'(a24,1x,a)') ' myspectralsolver: ',trim(myspectralsolver)
|
||||||
|
write(6,'(a24,1x,a)') ' PetSc_options: ',trim(petsc_options)
|
||||||
write(6,'(a24,1x,i8)') ' fftw_planner_flag: ',fftw_planner_flag
|
write(6,'(a24,1x,i8)') ' fftw_planner_flag: ',fftw_planner_flag
|
||||||
write(6,'(a24,1x,es8.1)') ' rotation_tol: ',rotation_tol
|
write(6,'(a24,1x,es8.1)') ' rotation_tol: ',rotation_tol
|
||||||
write(6,'(a24,1x,L8,/)') ' divergence_correction: ',divergence_correction
|
write(6,'(a24,1x,L8,/)') ' divergence_correction: ',divergence_correction
|
||||||
|
|
Loading…
Reference in New Issue