From a52f3d3e77f6a4b90624ba3ae6e67313a74fe001 Mon Sep 17 00:00:00 2001 From: albert <92109627+Albkat@users.noreply.github.com> Date: Sun, 17 Sep 2023 21:46:46 +0200 Subject: [PATCH] accuracy->set%acc (#866) Signed-off-by: albert <92109627+Albkat@users.noreply.github.com> --- src/prog/main.F90 | 26 ++++++++++---------------- src/set_module.f90 | 1 + src/setparam.f90 | 1 + 3 files changed, 12 insertions(+), 16 deletions(-) diff --git a/src/prog/main.F90 b/src/prog/main.F90 index cba5b8e91..c319615be 100644 --- a/src/prog/main.F90 +++ b/src/prog/main.F90 @@ -183,7 +183,7 @@ subroutine xtbMain(env, argParser) integer :: nFiles, iFile integer :: rohf,err real(wp) :: dum5,egap,etot,ipeashift - real(wp) :: zero,t0,t1,w0,w1,acc,etot2,g298 + real(wp) :: zero,t0,t1,w0,w1,etot2,g298 real(wp) :: one,two real(wp) :: ea,ip real(wp) :: vomega @@ -213,7 +213,7 @@ subroutine xtbMain(env, argParser) ! ------------------------------------------------------------------------ !> read the command line arguments - call parseArguments(env, argParser, xcontrol, fnv, acc, lgrad, & + call parseArguments(env, argParser, xcontrol, fnv, lgrad, & & restart, gsolvstate, strict, copycontrol, coffee, printTopo, oniom, tblite) !> Spin-polarization is only available in the tblite library @@ -415,8 +415,6 @@ subroutine xtbMain(env, argParser) call setup_summary(env%unit,mol%n,fname,xcontrol,chk%wfn,xrc) - if(set%fit) acc=0.2 ! higher SCF accuracy during fit - ! ------------------------------------------------------------------------ !> 2D => 3D STRUCTURE CONVERTER ! ------------------------------------------------------------------------ @@ -540,7 +538,7 @@ subroutine xtbMain(env, argParser) ! ------------------------------------------------------------------------ !> Obtain the parameter data - call newCalculator(env, mol, calc, fnv, restart, acc, oniom, iff_data, tblite) + call newCalculator(env, mol, calc, fnv, restart, set%acc, oniom, iff_data, tblite) call env%checkpoint("Could not setup single-point calculator") call initDefaults(env, calc, mol, gsolvstate) @@ -648,7 +646,7 @@ subroutine xtbMain(env, argParser) if (set%runtyp.eq.p_run_bhess) then call set_metadynamic(metaset,mol%n,mol%at,mol%xyz) call get_kopt (metaset,env,restart,mol,chk,calc,egap,set%etemp,set%maxscciter, & - & set%optset%maxoptcycle,set%optset%optlev,etot,g,sigma,acc) + & set%optset%maxoptcycle,set%optset%optlev,etot,g,sigma,set%acc) end if ! ------------------------------------------------------------------------ @@ -892,7 +890,7 @@ subroutine xtbMain(env, argParser) select type(calc) type is(TxTBCalculator) call main_property(iprop,env,mol,chk%wfn,calc%basis,calc%xtbData,res, & - & calc%solvation,acc) + & calc%solvation,set%acc) call main_cube(set%verbose,mol,chk%wfn,calc%basis,res) end select endif @@ -1142,7 +1140,7 @@ end subroutine xtbMain !> Parse command line arguments and forward them to settings -subroutine parseArguments(env, args, inputFile, paramFile, accuracy, lgrad, & +subroutine parseArguments(env, args, inputFile, paramFile, lgrad, & & restart, gsolvstate, strict, copycontrol, coffee, printTopo, oniom, tblite) use xtb_mctc_global, only : persistentEnv @@ -1161,9 +1159,6 @@ subroutine parseArguments(env, args, inputFile, paramFile, accuracy, lgrad, & !> Parameter file name character(len=:),allocatable,intent(out) :: paramFile - !> Accuracy number for numerical thresholds - real(wp), intent(out) :: accuracy - !> Reference state for solvation free energies integer, intent(out) :: gsolvstate @@ -1211,7 +1206,6 @@ subroutine parseArguments(env, args, inputFile, paramFile, accuracy, lgrad, & restart = .true. copycontrol = .false. lgrad = .false. - accuracy = 1.0_wp gsolvstate = solutionState%gsolv tblite%color = get_xtb_feature('color') @@ -1313,16 +1307,16 @@ subroutine parseArguments(env, args, inputFile, paramFile, accuracy, lgrad, & if (ddum.lt.1.e-4_wp) then call env%warning("We cannot provide this level of accuracy, "//& & "resetted accuracy to 0.0001", source) - accuracy = 1.e-4_wp + set%acc = 1.e-4_wp else if (ddum.gt.1.e+3_wp) then call env%warning("We cannot provide this level of accuracy, "//& & "resetted accuracy to 1000", source) - accuracy = 1.e+3_wp + set%acc = 1.e+3_wp else - accuracy = ddum + set%acc = ddum endif end if - tblite%accuracy = accuracy + tblite%accuracy = set%acc else call env%error("Accuracy is not provided", source) end if diff --git a/src/set_module.f90 b/src/set_module.f90 index d9e19ce60..104abd18c 100644 --- a/src/set_module.f90 +++ b/src/set_module.f90 @@ -1057,6 +1057,7 @@ end subroutine set_derived subroutine set_fit implicit none set%fit = .true. + set%acc = 0.2_wp end subroutine set_fit subroutine set_cma diff --git a/src/setparam.f90 b/src/setparam.f90 index ec49e6eff..2ff0ffe0b 100644 --- a/src/setparam.f90 +++ b/src/setparam.f90 @@ -183,6 +183,7 @@ module xtb_setparam type :: TSet integer :: gfn_method = -1 integer :: maxscciter = 250 + real(wp) :: acc = 1.0_wp logical :: newdisp = .true. logical :: solve_scc = .true. logical :: periodic = .false.