diff --git a/CHANGES/v2.3.md b/CHANGES/v2.3.md index e1abeb4c9ab7c4fa1ac21ed5bf75ef4f3dfebea8..c92fea35335240d8bd7cddedd5a8151a8f79d814 100644 --- a/CHANGES/v2.3.md +++ b/CHANGES/v2.3.md @@ -233,3 +233,6 @@ For developers: For users: - Fixed a problem leading to NaN derivatives of \ref switchingfunction `Q` when distance between two atoms is large. +For developers: +- Fixed small issue in debug options of \ref driver (see \issue{245}). + diff --git a/regtest/basic/rt-drift-2/config b/regtest/basic/rt-drift-2/config index 83e7371bb04b738d4dbfcc64917e3612f6ef9646..386f20a9a53540949e38e0ddc580dbcda024c836 100644 --- a/regtest/basic/rt-drift-2/config +++ b/regtest/basic/rt-drift-2/config @@ -1,5 +1,5 @@ mpiprocs=4 type=driver # this is to test a different name -arg="--plumed plumed.dat --timestep=0.005 --initial-step=1 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-dd" +arg="--plumed plumed.dat --timestep=0.005 --initial-step=1 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-dd yes" diff --git a/regtest/basic/rt-drift-3/config b/regtest/basic/rt-drift-3/config index c39bca25643048964211c40706eff80e089832b1..224b2c7679b7d7adc59a509dd7f14d1035acd6e3 100644 --- a/regtest/basic/rt-drift-3/config +++ b/regtest/basic/rt-drift-3/config @@ -1,5 +1,5 @@ mpiprocs=4 type=driver # this is to test a different name -arg="--plumed plumed.dat --timestep=0.005 --initial-step=1 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-pd" +arg="--plumed plumed.dat --timestep=0.005 --initial-step=1 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-pd yes" diff --git a/regtest/basic/rt-maxent-4/config b/regtest/basic/rt-maxent-4/config index 68180249a9fb89da802856c924dee104afa365fe..1563b03701752aeadccc54f27d19cf84e0766e3f 100644 --- a/regtest/basic/rt-maxent-4/config +++ b/regtest/basic/rt-maxent-4/config @@ -1,3 +1,3 @@ mpiprocs=6 type=driver -arg="--plumed plumed.dat --mf_xtc traj.xtc --dump-forces forces --dump-forces-fmt=%8.4f --debug-dd" +arg="--plumed plumed.dat --mf_xtc traj.xtc --dump-forces forces --dump-forces-fmt=%8.4f --debug-dd yes" diff --git a/regtest/basic/rt-maxent-5/config b/regtest/basic/rt-maxent-5/config index 0fa56a9d2e722b519986affce7eb6a616e756dea..c3cf79a0240860f9986c8cd5b513efffc31b8c98 100644 --- a/regtest/basic/rt-maxent-5/config +++ b/regtest/basic/rt-maxent-5/config @@ -1,3 +1,3 @@ mpiprocs=6 type=driver -arg="--plumed plumed.dat --mf_xtc traj.xtc --dump-forces forces --multi 3 --dump-forces-fmt=%8.4f --debug-dd" +arg="--plumed plumed.dat --mf_xtc traj.xtc --dump-forces forces --multi 3 --dump-forces-fmt=%8.4f --debug-dd yes" diff --git a/regtest/basic/rt-mpi1/config b/regtest/basic/rt-mpi1/config index 46557af1e4bb2bb5da12d023b1e85ccba295086e..4cbfe19b55fab375c30306210ed8e76d5fcd03be 100644 --- a/regtest/basic/rt-mpi1/config +++ b/regtest/basic/rt-mpi1/config @@ -1,5 +1,5 @@ mpiprocs=4 type=driver # this is to test a different name -arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --debug-pd" +arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --debug-pd yes" extra_files="../../trajectories/trajectory.xyz" diff --git a/regtest/basic/rt-mpi10/config b/regtest/basic/rt-mpi10/config index 76dfdc6b12170bc00eed88bf29596f0fcf4d5e69..9790c05f510bb6b42c4d85cfb857d68347749be4 100644 --- a/regtest/basic/rt-mpi10/config +++ b/regtest/basic/rt-mpi10/config @@ -1,3 +1,3 @@ mpiprocs=6 type=driver -arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --multi 3 --debug-dd --debug-grex 6 --debug-grex-log log.grex --initial-step 3" +arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --multi 3 --debug-dd yes --debug-grex 6 --debug-grex-log log.grex --initial-step 3" diff --git a/regtest/basic/rt-mpi2/config b/regtest/basic/rt-mpi2/config index bc4f1e9d001efc92491833e8961a0c5d1915e97e..138134b522f74e80150bf2540651a4e7b0dea24b 100644 --- a/regtest/basic/rt-mpi2/config +++ b/regtest/basic/rt-mpi2/config @@ -1,5 +1,5 @@ mpiprocs=4 type=driver # this is to test a different name -arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-dd" +arg="--debug-dd yes --plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb" extra_files="../../trajectories/trajectory.xyz" diff --git a/regtest/basic/rt-mpi2sync/config b/regtest/basic/rt-mpi2sync/config index e5f0f8483748f26986a721678b3500f573b8b111..95a0ed84cb6a2f1c8820f079ccc840b7a0edb875 100644 --- a/regtest/basic/rt-mpi2sync/config +++ b/regtest/basic/rt-mpi2sync/config @@ -1,6 +1,6 @@ mpiprocs=4 type=driver # this is to test a different name -arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-dd" +arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --debug-dd yes" extra_files="../../trajectories/trajectory.xyz" export PLUMED_ASYNC_SHARE=no diff --git a/regtest/basic/rt-mpi3/config b/regtest/basic/rt-mpi3/config index 84aa17316418a8f2982bd8d9fe3e9708166cba83..bdc7f44f768e032b2f446f20d5a1823378ebf949 100644 --- a/regtest/basic/rt-mpi3/config +++ b/regtest/basic/rt-mpi3/config @@ -2,4 +2,4 @@ mpiprocs=6 type=driver # this is to test a different name arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --multi 3 - --debug-dd --debug-grex 2 --debug-grex-log log.grex" + --debug-dd yes --debug-grex 2 --debug-grex-log log.grex" diff --git a/regtest/basic/rt-mpi4/config b/regtest/basic/rt-mpi4/config index 2b5d1124cf68c30b71921a030081e0c4aecebbb3..8df03bbd31302e649c41e4e61d19ddb15b26b4b5 100644 --- a/regtest/basic/rt-mpi4/config +++ b/regtest/basic/rt-mpi4/config @@ -2,4 +2,4 @@ mpiprocs=6 type=driver # this is to test a different name arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --pdb test.pdb --multi 3 - --debug-dd --debug-grex 2 --debug-grex-log log.grex" + --debug-dd yes --debug-grex 2 --debug-grex-log log.grex" diff --git a/regtest/basic/rt-mpi8/config b/regtest/basic/rt-mpi8/config index e77c2576345c9305a71239a01e56a9c9673d1ddb..70148af92f85f2b9ed4585858ee9f51e6c3f2c20 100644 --- a/regtest/basic/rt-mpi8/config +++ b/regtest/basic/rt-mpi8/config @@ -2,4 +2,4 @@ mpiprocs=6 type=driver # this is to test a different name arg="--plumed=plumed.dat --timestep=0.05 --ixyz trajectory.xyz --dump-forces ff --multi 3 - --debug-dd --debug-grex 2 --debug-grex-log log.grex" + --debug-dd yes --debug-grex 2 --debug-grex-log log.grex" diff --git a/regtest/basic/rt63-mpi/config b/regtest/basic/rt63-mpi/config index 0dfe7a16268757e4f2e743f78cb51acddbe35317..95732d30602aa5227f9fb218a41a2dc8ee6bcaa1 100644 --- a/regtest/basic/rt63-mpi/config +++ b/regtest/basic/rt63-mpi/config @@ -1,3 +1,3 @@ type=driver mpiprocs=2 -arg="--plumed plumed.dat --trajectory-stride 10 --timestep 0.005 --igro helix.input.gro --dump-forces ff --dump-full-virial --debug-dd" +arg="--plumed plumed.dat --trajectory-stride 10 --timestep 0.005 --igro helix.input.gro --dump-forces ff --dump-full-virial --debug-dd yes" diff --git a/regtest/basic/rt63c-mpi/config b/regtest/basic/rt63c-mpi/config index 1198851bd603e4702b4ecb0fb9202385ecfa081d..82b8aaaafe8c4704fd636fd9ea0f3ac1bbf848bb 100644 --- a/regtest/basic/rt63c-mpi/config +++ b/regtest/basic/rt63c-mpi/config @@ -1,3 +1,3 @@ type=driver mpiprocs=2 -arg="--plumed plumed.dat --trajectory-stride 10 --timestep 0.005 --igro helix.input.gro --dump-forces ff --dump-full-virial --dump-forces-fmt=%7.4f --debug-dd" +arg="--plumed plumed.dat --trajectory-stride 10 --timestep 0.005 --igro helix.input.gro --dump-forces ff --dump-full-virial --dump-forces-fmt=%7.4f --debug-dd yes" diff --git a/src/cltools/Driver.cpp b/src/cltools/Driver.cpp index 7a56fa9a62d12baa4e582c9796fea56edc7ab9d7..d575b48ef44ece2ea9085d9fe2798ad126bb4456 100644 --- a/src/cltools/Driver.cpp +++ b/src/cltools/Driver.cpp @@ -241,9 +241,9 @@ void Driver<real>::registerKeywords( Keywords& keys ) { keys.add("optional","--initial-step","provides a number for the initial step, default is 0"); keys.add("optional","--debug-forces","output a file containing the forces due to the bias evaluated using numerical derivatives " "and using the analytical derivatives implemented in plumed"); - keys.add("hidden","--debug-float","turns on the single precision version (to check float interface)"); - keys.add("hidden","--debug-dd","use a fake domain decomposition"); - keys.add("hidden","--debug-pd","use a fake particle decomposition"); + keys.add("hidden","--debug-float","[yes/no] turns on the single precision version (to check float interface)"); + keys.add("hidden","--debug-dd","[yes/no] use a fake domain decomposition"); + keys.add("hidden","--debug-pd","[yes/no] use a fake particle decomposition"); keys.add("hidden","--debug-grex","use a fake gromacs-like replica exchange, specify exchange stride"); keys.add("hidden","--debug-grex-log","log file for debug=grex"); #ifdef __PLUMED_HAS_MOLFILE_PLUGINS @@ -277,9 +277,9 @@ int Driver<real>::main(FILE* in,FILE*out,Communicator& pc) { if( printhelpdebug ) { fprintf(out,"%s", "Additional options for debug (only to be used in regtest):\n" - " [--debug-float] : turns on the single precision version (to check float interface)\n" - " [--debug-dd] : use a fake domain decomposition\n" - " [--debug-pd] : use a fake particle decomposition\n" + " [--debug-float yes] : turns on the single precision version (to check float interface)\n" + " [--debug-dd yes] : use a fake domain decomposition\n" + " [--debug-pd yes] : use a fake particle decomposition\n" ); return 0; } @@ -287,16 +287,39 @@ int Driver<real>::main(FILE* in,FILE*out,Communicator& pc) { bool noatoms; parseFlag("--noatoms",noatoms); std::string fakein; - bool debugfloat=parse("--debug-float",fakein); - if(debugfloat && sizeof(real)!=sizeof(float)) { + bool debug_float=false; + fakein=""; + if(parse("--debug-float",fakein)) { + if(fakein=="yes") debug_float=true; + else if(fakein=="no") debug_float=false; + else error("--debug-float should have argument yes or no"); + } + + if(debug_float && sizeof(real)!=sizeof(float)) { std::unique_ptr<CLTool> cl(cltoolRegister().create(CLToolOptions("driver-float"))); cl->setInputData(this->getInputData()); int ret=cl->main(in,out,pc); return ret; } - bool debug_pd=parse("--debug-pd",fakein); - bool debug_dd=parse("--debug-dd",fakein); + bool debug_pd=false; + fakein=""; + if(parse("--debug-pd",fakein)) { + if(fakein=="yes") debug_pd=true; + else if(fakein=="no") debug_pd=false; + else error("--debug-pd should have argument yes or no"); + } + if(debug_pd) fprintf(out,"DEBUGGING PARTICLE DECOMPOSITION\n"); + + bool debug_dd=false; + fakein=""; + if(parse("--debug-dd",fakein)) { + if(fakein=="yes") debug_dd=true; + else if(fakein=="no") debug_dd=false; + else error("--debug-dd should have argument yes or no"); + } + if(debug_dd) fprintf(out,"DEBUGGING DOMAIN DECOMPOSITION\n"); + if( debug_pd || debug_dd ) { if(noatoms) error("cannot debug without atoms"); }