indroduced 3 more flags for fine control of spectral algorithm

This commit is contained in:
Martin Diehl 2012-01-25 08:56:46 +00:00
parent 52a43c3b32
commit 3e521e32a6
1 changed files with 19 additions and 4 deletions

View File

@ -73,7 +73,10 @@ real(pReal) :: relevantStrain, & ! strain
character(len=64) :: fftw_planner_string ! reads the planing-rigor flag, see manual on www.fftw.org character(len=64) :: fftw_planner_string ! reads the planing-rigor flag, see manual on www.fftw.org
integer(pInt) :: fftw_planner_flag ! conversion of fftw_planner_string to integer, basically what is usually done in the include file of fftw integer(pInt) :: fftw_planner_flag ! conversion of fftw_planner_string to integer, basically what is usually done in the include file of fftw
logical :: memory_efficient,& ! for fast execution (pre calculation of gamma_hat) logical :: memory_efficient,& ! for fast execution (pre calculation of gamma_hat)
divergence_correction ! correct divergence calculation in fourier space divergence_correction,& ! correct divergence calculation in fourier space
update_gamma,& ! update gamma operator with current stiffness
simplified_algorithm ! use short algorithm without fluctuation field
real(pReal) :: cut_off_value ! percentage of frequencies to cut away
integer(pInt) :: itmax , & ! maximum number of iterations integer(pInt) :: itmax , & ! maximum number of iterations
@ -174,7 +177,11 @@ subroutine numerics_init()
fftw_timelimit = -1.0_pReal ! no timelimit of plan creation for FFTW fftw_timelimit = -1.0_pReal ! no timelimit of plan creation for FFTW
fftw_planner_string ='FFTW_PATIENT' fftw_planner_string ='FFTW_PATIENT'
rotation_tol = 1.0e-12 rotation_tol = 1.0e-12
divergence_correction = .true. divergence_correction = .true. ! correct divergence by empirical factor
simplified_algorithm = .true. ! use algorithm without fluctuation field
update_gamma = .false. ! do not update gamma operator with current stiffness
cut_off_value = 0.0_pReal ! use all frequencies
!* Random seeding parameters !* Random seeding parameters
fixedSeed = 0_pInt fixedSeed = 0_pInt
@ -294,6 +301,12 @@ subroutine numerics_init()
rotation_tol = IO_floatValue(line,positions,2) rotation_tol = IO_floatValue(line,positions,2)
case ('divergence_correction') case ('divergence_correction')
divergence_correction = IO_intValue(line,positions,2) > 0_pInt divergence_correction = IO_intValue(line,positions,2) > 0_pInt
case ('update_gamma')
update_gamma = IO_intValue(line,positions,2) > 0_pInt
case ('simplified_algorithm')
simplified_algorithm = IO_intValue(line,positions,2) > 0_pInt
case ('cut_off_value')
cut_off_value = IO_floatValue(line,positions,2)
!* Random seeding parameters !* Random seeding parameters
case ('fixed_seed') case ('fixed_seed')
@ -370,7 +383,7 @@ subroutine numerics_init()
write(6,'(a24,x,e8.1)') ' err_stress_tolrel: ',err_stress_tolrel write(6,'(a24,x,e8.1)') ' err_stress_tolrel: ',err_stress_tolrel
write(6,'(a24,x,i8)') ' itmax: ',itmax write(6,'(a24,x,i8)') ' itmax: ',itmax
write(6,'(a24,x,L8)') ' memory_efficient: ',memory_efficient write(6,'(a24,x,L8)') ' memory_efficient: ',memory_efficient
if(fftw_timelimit<0) then if(fftw_timelimit<0.0_pReal) then
write(6,'(a24,x,L8)') ' fftw_timelimit: ',.false. write(6,'(a24,x,L8)') ' fftw_timelimit: ',.false.
else else
write(6,'(a24,x,e8.1)') ' fftw_timelimit: ',fftw_timelimit write(6,'(a24,x,e8.1)') ' fftw_timelimit: ',fftw_timelimit
@ -379,7 +392,9 @@ subroutine numerics_init()
write(6,'(a24,x,i8)') ' fftw_planner_flag: ',fftw_planner_flag write(6,'(a24,x,i8)') ' fftw_planner_flag: ',fftw_planner_flag
write(6,'(a24,x,e8.1)') ' rotation_tol: ',rotation_tol write(6,'(a24,x,e8.1)') ' rotation_tol: ',rotation_tol
write(6,'(a24,x,L8,/)') ' divergence_correction: ',divergence_correction write(6,'(a24,x,L8,/)') ' divergence_correction: ',divergence_correction
write(6,'(a24,x,L8,/)') ' update_gamma: ',update_gamma
write(6,'(a24,x,L8,/)') ' simplified_algorithm: ',simplified_algorithm
write(6,'(a24,x,e8.1)') ' cut_off_value: ',cut_off_value
!* Random seeding parameters !* Random seeding parameters
write(6,'(a24,x,i16,/)') ' fixed_seed: ',fixedSeed write(6,'(a24,x,i16,/)') ' fixed_seed: ',fixedSeed
!$OMP END CRITICAL (write2out) !$OMP END CRITICAL (write2out)