From 860f95ff9f27f0d95a30446825d6f1c8837969b6 Mon Sep 17 00:00:00 2001 From: Carlo Camilloni Date: Fri, 17 Jan 2025 09:24:00 +0100 Subject: [PATCH] Revert "Proposing: removing lines with more than one statements. (#1114)" This reverts commit ea3b17f3020da18f5b508638c866496483ad90b2. --- .astyle.options | 14 +- .git-blame-ignore-revs | 4 - src/adjmat/ActionWithInputMatrix.cpp | 66 +- src/adjmat/ActionWithInputMatrix.h | 8 +- src/adjmat/AdjacencyMatrixBase.cpp | 120 +-- src/adjmat/AdjacencyMatrixBase.h | 12 +- src/adjmat/AdjacencyMatrixVessel.cpp | 95 +- src/adjmat/AlignedMatrixBase.cpp | 45 +- src/adjmat/ClusterAnalysisBase.cpp | 33 +- src/adjmat/ClusterAnalysisBase.h | 4 +- src/adjmat/ClusterDiameter.cpp | 29 +- src/adjmat/ClusterDistribution.cpp | 57 +- src/adjmat/ClusterProperties.cpp | 59 +- src/adjmat/ClusterSize.cpp | 29 +- src/adjmat/ClusterWithSurface.cpp | 57 +- src/adjmat/ClusteringBase.cpp | 34 +- src/adjmat/ContactAlignedMatrix.cpp | 26 +- src/adjmat/ContactMatrix.cpp | 29 +- src/adjmat/DFSClustering.cpp | 42 +- src/adjmat/DumpGraph.cpp | 48 +- src/adjmat/HbondMatrix.cpp | 76 +- src/adjmat/MatrixColumnSums.cpp | 50 +- src/adjmat/MatrixRowSums.cpp | 38 +- src/adjmat/OutputCluster.cpp | 113 +-- src/adjmat/SMACMatrix.cpp | 49 +- src/adjmat/Sprint.cpp | 40 +- src/adjmat/TopologyMatrix.cpp | 132 +-- src/analysis/AnalysisBase.cpp | 36 +- src/analysis/AnalysisBase.h | 15 +- src/analysis/Average.cpp | 30 +- src/analysis/AverageVessel.cpp | 21 +- src/analysis/AverageVessel.h | 4 +- src/analysis/Committor.cpp | 40 +- src/analysis/DataCollectionObject.cpp | 34 +- src/analysis/DataCollectionObject.h | 14 +- src/analysis/EuclideanDissimilarityMatrix.cpp | 59 +- src/analysis/FarthestPointSampling.cpp | 28 +- src/analysis/Histogram.cpp | 282 ++---- src/analysis/LandmarkSelectionBase.cpp | 34 +- src/analysis/LandmarkSelectionBase.h | 4 +- src/analysis/LandmarkStaged.cpp | 40 +- src/analysis/OutputColvarFile.cpp | 76 +- src/analysis/OutputPDBFile.cpp | 43 +- src/analysis/PrintDissimilarityMatrix.cpp | 29 +- src/analysis/ReadAnalysisFrames.cpp | 106 +- src/analysis/ReadAnalysisFrames.h | 8 +- src/analysis/ReadDissimilarityMatrix.cpp | 71 +- src/analysis/ReselectLandmarks.cpp | 18 +- src/analysis/SelectRandomFrames.cpp | 6 +- src/analysis/SelectWithStride.cpp | 7 +- src/analysis/WhamHistogram.cpp | 41 +- src/analysis/WhamWeights.cpp | 26 +- src/annfunc/ANN.cpp | 33 +- src/astyle.sh | 64 +- src/bias/ABMD.cpp | 42 +- src/bias/Bias.cpp | 14 +- src/bias/Bias.h | 3 +- src/bias/BiasValue.cpp | 9 +- src/bias/ExtendedLagrangian.cpp | 31 +- src/bias/External.cpp | 33 +- src/bias/LWalls.cpp | 26 +- src/bias/MaxEnt.cpp | 146 +-- src/bias/MetaD.cpp | 926 ++++++------------ src/bias/MovingRestraint.cpp | 66 +- src/bias/PBMetaD.cpp | 445 +++------ src/bias/Restraint.cpp | 15 +- src/bias/ReweightBase.cpp | 20 +- src/bias/ReweightBase.h | 15 +- src/bias/ReweightBias.cpp | 11 +- src/bias/ReweightMetad.cpp | 11 +- src/bias/ReweightTemperaturePressure.cpp | 55 +- src/bias/ReweightWham.cpp | 80 +- src/bias/UWalls.cpp | 26 +- src/cltools/Completion.cpp | 30 +- src/cltools/Driver.cpp | 605 +++--------- src/cltools/DriverFloat.cpp | 4 +- src/cltools/GenExample.cpp | 348 ++----- src/cltools/GenJson.cpp | 88 +- src/cltools/GenTemplate.cpp | 10 +- src/cltools/Info.cpp | 75 +- src/cltools/Manual.cpp | 20 +- src/cltools/PdbRenumber.cpp | 14 +- src/cltools/SimpleMD.cpp | 205 ++-- src/cltools/SumHills.cpp | 165 +--- src/cltools/kT.cpp | 15 +- src/cltools/pesmd.cpp | 132 +-- src/colvar/Angle.cpp | 25 +- src/colvar/Cell.cpp | 52 +- src/colvar/Constant.cpp | 32 +- src/colvar/ContactMap.cpp | 83 +- src/colvar/Coordination.cpp | 11 +- src/colvar/CoordinationBase.cpp | 77 +- src/colvar/DHEnergy.cpp | 7 +- src/colvar/DRMSD.cpp | 33 +- src/colvar/Dimer.cpp | 62 +- src/colvar/Dipole.cpp | 29 +- src/colvar/Distance.cpp | 42 +- src/colvar/EEFSolv.cpp | 84 +- src/colvar/ERMSD.cpp | 29 +- src/colvar/Energy.cpp | 6 +- src/colvar/ExtraCV.cpp | 6 +- src/colvar/Fake.cpp | 3 +- src/colvar/GHBFIX.cpp | 10 +- src/colvar/Gyration.cpp | 197 ++-- src/colvar/MultiRMSD.cpp | 43 +- src/colvar/PCARMSD.cpp | 97 +- src/colvar/PathMSD.cpp | 15 +- src/colvar/PathMSDBase.cpp | 116 +-- src/colvar/Position.cpp | 31 +- src/colvar/ProjectionOnAxis.cpp | 39 +- src/colvar/PropertyMap.cpp | 14 +- src/colvar/Puckering.cpp | 152 +-- src/colvar/RMSD.cpp | 42 +- src/colvar/Template.cpp | 16 +- src/colvar/Torsion.cpp | 35 +- src/colvar/Volume.cpp | 6 +- src/config/Config.inc.in | 32 +- src/core/Action.cpp | 99 +- src/core/Action.h | 77 +- src/core/ActionAnyorder.cpp | 3 +- src/core/ActionAtomistic.cpp | 194 +--- src/core/ActionAtomistic.h | 23 +- src/core/ActionPilot.cpp | 11 +- src/core/ActionPilot.h | 3 +- src/core/ActionRegister.cpp | 50 +- src/core/ActionSet.cpp | 11 +- src/core/ActionSet.h | 31 +- src/core/ActionSetup.cpp | 7 +- src/core/ActionShortcut.cpp | 32 +- src/core/ActionWithArguments.cpp | 84 +- src/core/ActionWithArguments.h | 3 +- src/core/ActionWithValue.cpp | 58 +- src/core/ActionWithValue.h | 14 +- src/core/ActionWithVirtualAtom.cpp | 20 +- src/core/ActionWithVirtualAtom.h | 3 +- src/core/Atoms.cpp | 222 ++--- src/core/Atoms.h | 67 +- src/core/CLTool.cpp | 79 +- src/core/CLTool.h | 24 +- src/core/CLToolMain.cpp | 68 +- src/core/CLToolMain.h | 3 +- src/core/CLToolRegister.cpp | 30 +- src/core/Colvar.cpp | 36 +- src/core/Colvar.h | 7 +- src/core/DataFetchingObject.cpp | 33 +- src/core/ExchangePatterns.cpp | 18 +- src/core/FlexibleBin.cpp | 24 +- src/core/GREX.cpp | 19 +- src/core/GREX.h | 3 +- src/core/GenericMolInfo.cpp | 132 +-- src/core/MDAtoms.cpp | 74 +- src/core/MDAtoms.h | 3 +- src/core/PlumedMain.cpp | 332 ++----- src/core/PlumedMain.h | 21 +- src/core/PlumedMainInitializer.cpp | 182 +--- src/core/TargetDist.cpp | 16 +- src/core/Value.cpp | 61 +- src/core/Value.h | 27 +- src/crystallization/BondOrientation.cpp | 36 +- src/crystallization/CubicHarmonicBase.cpp | 66 +- src/crystallization/CubicHarmonicBase.h | 4 +- src/crystallization/EnvironmentSimilarity.cpp | 121 +-- src/crystallization/Fccubic.cpp | 6 +- src/crystallization/Gradient.cpp | 106 +- src/crystallization/GradientVessel.cpp | 58 +- .../InterMolecularTorsions.cpp | 65 +- src/crystallization/LocalSteinhardt.h | 14 +- src/crystallization/MoleculeOrientation.cpp | 56 +- src/crystallization/MoleculePlane.cpp | 17 +- src/crystallization/OrientationSphere.cpp | 61 +- src/crystallization/OrientationSphere.h | 7 +- src/crystallization/PolymerAngles.cpp | 22 +- src/crystallization/Q3.cpp | 3 +- src/crystallization/Q4.cpp | 9 +- src/crystallization/Q6.cpp | 12 +- src/crystallization/SMAC.cpp | 66 +- src/crystallization/SimpleCubic.cpp | 3 +- src/crystallization/Steinhardt.cpp | 82 +- src/crystallization/Tetrahedral.cpp | 15 +- src/crystallization/VectorMean.cpp | 39 +- src/crystallization/VectorMultiColvar.cpp | 40 +- src/crystallization/VectorMultiColvar.h | 8 +- src/crystallization/VectorSum.cpp | 29 +- .../ClassicalMultiDimensionalScaling.cpp | 38 +- src/dimred/DimensionalityReductionBase.cpp | 73 +- src/dimred/DimensionalityReductionBase.h | 4 +- src/dimred/OutputPCAProjections.cpp | 54 +- src/dimred/PCA.cpp | 118 +-- src/dimred/PCA.h | 12 +- src/dimred/ProjectNonLandmarkPoints.cpp | 49 +- src/dimred/SMACOF.cpp | 59 +- src/dimred/SketchMap.cpp | 75 +- src/dimred/SketchMapBase.cpp | 81 +- src/dimred/SketchMapBase.h | 20 +- src/dimred/SketchMapConjGrad.cpp | 3 +- src/dimred/SketchMapPointwise.cpp | 52 +- src/dimred/SketchMapRead.cpp | 108 +- src/dimred/SketchMapSmacof.cpp | 29 +- src/dimred/SmacoffMDS.cpp | 10 +- src/drr/DRR.cpp | 41 +- src/drr/DRR.h | 49 +- src/drr/DynamicReferenceRestraining.cpp | 16 +- src/drr/colvar_UIestimator.h | 346 ++++--- src/drr/drrtool.cpp | 18 +- src/eds/EDS.cpp | 463 +++++---- src/fisst/FISST.cpp | 101 +- src/fisst/legendre_rule_fast.cpp | 55 +- src/function/Combine.cpp | 38 +- src/function/Custom.cpp | 39 +- src/function/Ensemble.cpp | 81 +- src/function/FuncPathGeneral.cpp | 56 +- src/function/FuncPathMSD.cpp | 47 +- src/function/FuncSumHills.cpp | 262 ++--- src/function/Function.cpp | 28 +- src/function/Function.h | 3 +- src/function/LocalEnsemble.cpp | 29 +- src/function/Piecewise.cpp | 29 +- src/function/Sort.cpp | 9 +- src/function/Stats.cpp | 65 +- src/function/Target.cpp | 26 +- src/funnel/FPS.cpp | 20 +- src/funnel/Funnel.cpp | 77 +- src/generic/Debug.cpp | 42 +- src/generic/DumpAtoms.cpp | 93 +- src/generic/DumpDerivatives.cpp | 22 +- src/generic/DumpForces.cpp | 14 +- src/generic/DumpMassCharge.cpp | 29 +- src/generic/DumpProjections.cpp | 14 +- src/generic/EffectiveEnergyDrift.cpp | 48 +- src/generic/EndPlumed.cpp | 6 +- src/generic/FitToTemplate.cpp | 54 +- src/generic/Flush.cpp | 9 +- src/generic/Group.cpp | 52 +- src/generic/Include.cpp | 6 +- src/generic/Plumed.cpp | 196 +--- src/generic/Print.cpp | 14 +- src/generic/RandomExchanges.cpp | 10 +- src/generic/Read.cpp | 92 +- src/generic/ResetCell.cpp | 14 +- src/generic/Time.cpp | 10 +- src/generic/UpdateIf.cpp | 46 +- src/generic/WholeMolecules.cpp | 52 +- src/generic/WrapAround.cpp | 34 +- src/gridtools/ActionWithGrid.cpp | 67 +- src/gridtools/ActionWithInputGrid.cpp | 36 +- src/gridtools/ActionWithInputGrid.h | 9 +- src/gridtools/ActionWithIntegral.cpp | 25 +- src/gridtools/ActionWithIntegral.h | 4 +- src/gridtools/AverageOnGrid.cpp | 38 +- src/gridtools/AverageOnGrid.h | 12 +- src/gridtools/ContourFindingBase.cpp | 10 +- src/gridtools/ContourFindingBase.h | 8 +- src/gridtools/ConvertToFES.cpp | 85 +- src/gridtools/DumpCube.cpp | 30 +- src/gridtools/DumpGrid.cpp | 32 +- src/gridtools/FindContour.cpp | 115 +-- src/gridtools/FindContourSurface.cpp | 147 +-- src/gridtools/FindSphericalContour.cpp | 50 +- src/gridtools/FourierTransform.cpp | 79 +- src/gridtools/GridPrintingBase.cpp | 92 +- src/gridtools/GridSearch.h | 54 +- src/gridtools/GridToXYZ.cpp | 45 +- src/gridtools/GridVessel.cpp | 472 +++------ src/gridtools/GridVessel.h | 24 +- src/gridtools/HistogramOnGrid.cpp | 106 +- src/gridtools/HistogramOnGrid.h | 8 +- src/gridtools/IntegrateGrid.cpp | 10 +- src/gridtools/InterpolateGrid.cpp | 41 +- src/isdb/CS2Backbone.cpp | 840 +++++----------- src/isdb/Caliber.cpp | 115 +-- src/isdb/EMMI.cpp | 507 ++++------ src/isdb/FretEfficiency.cpp | 17 +- src/isdb/Jcoupling.cpp | 49 +- src/isdb/Metainference.cpp | 613 ++++-------- src/isdb/MetainferenceBase.cpp | 604 ++++-------- src/isdb/MetainferenceBase.h | 66 +- src/isdb/NOE.cpp | 101 +- src/isdb/PRE.cpp | 118 +-- src/isdb/RDC.cpp | 134 +-- src/isdb/Rescale.cpp | 137 +-- src/isdb/SAXS.cpp | 884 +++++------------ src/isdb/Select.cpp | 20 +- src/isdb/Selector.cpp | 6 +- src/logmfd/LogMFD.cpp | 92 +- src/main/main.cpp | 20 +- src/manyrestraints/LWalls.cpp | 3 +- src/manyrestraints/ManyRestraintsBase.cpp | 14 +- src/manyrestraints/ManyRestraintsBase.h | 15 +- src/manyrestraints/UWalls.cpp | 3 +- src/mapping/AdaptivePath.cpp | 103 +- src/mapping/Mapping.cpp | 136 +-- src/mapping/Mapping.h | 11 +- src/mapping/PCAVars.cpp | 179 +--- src/mapping/Path.cpp | 16 +- src/mapping/PathBase.cpp | 26 +- src/mapping/PathReparameterization.cpp | 77 +- src/mapping/PathTools.cpp | 158 +-- src/mapping/PropertyMap.cpp | 9 +- src/mapping/SpathVessel.cpp | 17 +- src/mapping/TrigonometricPathVessel.cpp | 165 +--- src/mapping/ZpathVessel.cpp | 9 +- src/maze/Loss.cpp | 3 +- src/maze/Memetic.cpp | 3 +- src/maze/Memetic.h | 41 +- src/maze/Optimizer.cpp | 30 +- src/maze/Optimizer_Bias.cpp | 3 +- src/maze/Random_Acceleration_MD.cpp | 3 +- src/maze/Random_Walk.cpp | 3 +- src/maze/Simulated_Annealing.cpp | 18 +- src/maze/Steered_MD.cpp | 6 +- src/maze/Tools.h | 9 +- src/membranefusion/FusionPoreExpansionP.cpp | 206 ++-- src/membranefusion/FusionPoreNucleationP.cpp | 272 ++--- src/membranefusion/MemFusionP.cpp | 202 ++-- src/multicolvar/ActionVolume.cpp | 65 +- src/multicolvar/AlphaBeta.cpp | 23 +- src/multicolvar/Angles.cpp | 62 +- src/multicolvar/AtomValuePack.cpp | 36 +- src/multicolvar/AtomValuePack.h | 29 +- src/multicolvar/Bridge.cpp | 40 +- .../BridgedMultiColvarFunction.cpp | 55 +- src/multicolvar/BridgedMultiColvarFunction.h | 8 +- src/multicolvar/CatomPack.cpp | 3 +- src/multicolvar/CenterOfMultiColvar.cpp | 70 +- src/multicolvar/CoordinationNumbers.cpp | 52 +- src/multicolvar/Density.cpp | 29 +- src/multicolvar/DihedralCorrelation.cpp | 7 +- src/multicolvar/DistanceFromContour.cpp | 212 ++-- src/multicolvar/Distances.cpp | 48 +- src/multicolvar/DumpMultiColvar.cpp | 66 +- src/multicolvar/FilterBetween.cpp | 31 +- src/multicolvar/FilterLessThan.cpp | 26 +- src/multicolvar/FilterMoreThan.cpp | 26 +- src/multicolvar/InPlaneDistances.cpp | 53 +- src/multicolvar/LocalAverage.cpp | 90 +- src/multicolvar/MultiColvarBase.cpp | 807 ++++----------- src/multicolvar/MultiColvarBase.h | 19 +- src/multicolvar/MultiColvarCombine.cpp | 35 +- src/multicolvar/MultiColvarDensity.cpp | 206 ++-- src/multicolvar/MultiColvarFilter.cpp | 32 +- src/multicolvar/MultiColvarProduct.cpp | 31 +- src/multicolvar/NumberOfLinks.cpp | 40 +- src/multicolvar/Torsions.cpp | 21 +- src/multicolvar/VolumeAround.cpp | 51 +- src/multicolvar/VolumeBetweenContours.cpp | 77 +- src/multicolvar/VolumeCavity.cpp | 101 +- src/multicolvar/VolumeGradientBase.cpp | 70 +- src/multicolvar/VolumeGradientBase.h | 8 +- src/multicolvar/VolumeInCylinder.cpp | 61 +- src/multicolvar/VolumeInSphere.cpp | 25 +- src/multicolvar/VolumeTetrapore.cpp | 139 +-- src/multicolvar/XAngle.cpp | 60 +- src/multicolvar/XDistances.cpp | 48 +- src/multicolvar/XYDistances.cpp | 49 +- src/multicolvar/XYTorsion.cpp | 79 +- src/opes/ECVcustom.cpp | 94 +- src/opes/ECVlinear.cpp | 88 +- src/opes/ECVmultiThermal.cpp | 79 +- src/opes/ECVmultiThermalBaric.cpp | 229 +++-- src/opes/ECVumbrellasFile.cpp | 110 ++- src/opes/ECVumbrellasLine.cpp | 113 ++- src/opes/ExpansionCVs.cpp | 132 +-- src/opes/ExpansionCVs.h | 16 +- src/opes/OPESexpanded.cpp | 448 +++++---- src/opes/OPESmetad.cpp | 902 +++++++++-------- src/pamm/HBPammHydrogens.cpp | 102 +- src/pamm/HBPammMatrix.cpp | 34 +- src/pamm/HBPammObject.cpp | 28 +- src/pamm/PAMM.cpp | 64 +- src/pamm/PammObject.cpp | 53 +- src/pamm/PammObject.h | 6 +- src/piv/PIV.cpp | 116 +-- src/pytorch/PytorchModel.cpp | 16 +- src/reference/ArgumentOnlyDistance.cpp | 15 +- src/reference/ArgumentOnlyDistance.h | 8 +- src/reference/DRMSD.cpp | 39 +- src/reference/Direction.cpp | 45 +- src/reference/Direction.h | 7 +- src/reference/DotProductDistance.cpp | 15 +- src/reference/EuclideanDistance.cpp | 3 +- src/reference/FakeFrame.h | 7 +- src/reference/IntermolecularDRMSD.cpp | 23 +- src/reference/IntramolecularDRMSD.cpp | 23 +- src/reference/MahalanobisDistance.cpp | 3 +- src/reference/MetricRegister.cpp | 11 +- src/reference/MetricRegister.h | 4 +- src/reference/MultiDomainRMSD.cpp | 161 +-- src/reference/NormalizedEuclideanDistance.cpp | 3 +- src/reference/OptimalRMSD.cpp | 89 +- src/reference/RMSDBase.cpp | 3 +- src/reference/ReferenceArguments.cpp | 112 +-- src/reference/ReferenceArguments.h | 3 +- src/reference/ReferenceAtoms.cpp | 41 +- src/reference/ReferenceAtoms.h | 3 +- src/reference/ReferenceConfiguration.cpp | 68 +- src/reference/ReferenceConfiguration.h | 12 +- src/reference/ReferenceValuePack.cpp | 39 +- src/reference/ReferenceValuePack.h | 32 +- src/reference/SimpleRMSD.cpp | 42 +- src/reference/SingleDomainRMSD.cpp | 62 +- src/s2cm/S2ContactModel.cpp | 33 +- src/sasa/sasa_HASEL.cpp | 65 +- src/sasa/sasa_LCPO.cpp | 77 +- src/secondarystructure/AlphaRMSD.cpp | 21 +- src/secondarystructure/AntibetaRMSD.cpp | 51 +- src/secondarystructure/ParabetaRMSD.cpp | 51 +- .../SecondaryStructureRMSD.cpp | 114 +-- .../SecondaryStructureRMSD.h | 7 +- src/setup/Load.cpp | 6 +- src/setup/Restart.cpp | 14 +- src/setup/Units.cpp | 56 +- src/tools/BiasRepresentation.cpp | 113 +-- src/tools/Brent1DRootSearch.h | 73 +- src/tools/Citations.cpp | 12 +- src/tools/Communicator.cpp | 165 +--- src/tools/Communicator.h | 114 +-- src/tools/ConjugateGradient.h | 26 +- src/tools/DLLoader.cpp | 8 +- src/tools/DynamicList.h | 90 +- src/tools/ERMSD.cpp | 16 +- src/tools/Exception.cpp | 40 +- src/tools/Exception.h | 21 +- src/tools/FileBase.cpp | 64 +- src/tools/FileBase.h | 4 +- src/tools/ForwardDecl.h | 3 +- src/tools/Grid.cpp | 408 ++------ src/tools/Grid.h | 53 +- src/tools/HistogramBead.cpp | 123 +-- src/tools/HistogramBead.h | 20 +- src/tools/IFile.cpp | 115 +-- src/tools/KernelFunctions.cpp | 265 ++--- src/tools/KernelFunctions.h | 3 +- src/tools/Keywords.cpp | 406 ++------ src/tools/Keywords.h | 54 +- src/tools/LatticeReduction.cpp | 83 +- src/tools/LinkCells.cpp | 64 +- src/tools/Log.h | 3 +- src/tools/Matrix.h | 357 ++----- src/tools/Minimise1DBrent.h | 99 +- src/tools/MinimiseBase.h | 15 +- src/tools/MolDataClass.cpp | 482 +++------ src/tools/MultiValue.cpp | 77 +- src/tools/MultiValue.h | 26 +- src/tools/NeighborList.cpp | 38 +- src/tools/NeighborList.h | 3 +- src/tools/OFile.cpp | 124 +-- src/tools/OpenMP.cpp | 8 +- src/tools/OpenMP.h | 14 +- src/tools/PDB.cpp | 563 ++++------- src/tools/Pbc.cpp | 154 +-- src/tools/PlumedHandle.cpp | 24 +- src/tools/PlumedHandle.h | 6 +- src/tools/RMSD.cpp | 610 +++--------- src/tools/RMSD.h | 86 +- src/tools/Random.cpp | 65 +- src/tools/Random.h | 10 +- src/tools/RootFindingBase.h | 4 +- src/tools/Stopwatch.cpp | 16 +- src/tools/Stopwatch.h | 32 +- src/tools/Subprocess.cpp | 74 +- src/tools/SwitchingFunction.cpp | 116 +-- src/tools/Tensor.h | 88 +- src/tools/Tools.cpp | 270 ++--- src/tools/Tools.h | 119 +-- src/tools/Tree.cpp | 29 +- src/tools/Tree.h | 3 +- src/tools/TypesafePtr.cpp | 8 +- src/tools/TypesafePtr.h | 83 +- src/tools/Units.cpp | 3 +- src/tools/Vector.h | 10 +- src/tools/h36.cpp | 103 +- src/vatom/Center.cpp | 96 +- src/vatom/FixedAtom.cpp | 22 +- src/vatom/Ghost.cpp | 18 +- src/ves/BF_Chebyshev.cpp | 9 +- src/ves/BF_Combined.cpp | 24 +- src/ves/BF_Cosine.cpp | 10 +- src/ves/BF_CubicBsplines.cpp | 23 +- src/ves/BF_Custom.cpp | 118 +-- src/ves/BF_Fourier.cpp | 10 +- src/ves/BF_Gaussians.cpp | 24 +- src/ves/BF_Legendre.cpp | 16 +- src/ves/BF_Powers.cpp | 16 +- src/ves/BF_Sine.cpp | 10 +- src/ves/BF_Wavelets.cpp | 38 +- src/ves/BasisFunctions.cpp | 117 +-- src/ves/BasisFunctions.h | 141 +-- src/ves/CoeffsBase.cpp | 60 +- src/ves/CoeffsBase.h | 107 +- src/ves/CoeffsMatrix.cpp | 41 +- src/ves/CoeffsMatrix.h | 23 +- src/ves/CoeffsVector.cpp | 56 +- src/ves/CoeffsVector.h | 27 +- src/ves/FermiSwitchingFunction.cpp | 36 +- src/ves/GridIntegrationWeights.cpp | 13 +- src/ves/GridLinearInterpolation.cpp | 27 +- src/ves/GridLinearInterpolation.h | 3 +- src/ves/GridProjWeights.h | 21 +- src/ves/LinearBasisSetExpansion.cpp | 127 +-- src/ves/LinearBasisSetExpansion.h | 112 +-- src/ves/MD_LinearExpansionPES.cpp | 110 +-- src/ves/Opt_Adam.cpp | 14 +- src/ves/Opt_BachAveragedSGD.cpp | 13 +- src/ves/Opt_Dummy.cpp | 6 +- src/ves/Opt_RobbinsMonroSGD.cpp | 3 +- src/ves/Optimizer.cpp | 180 ++-- src/ves/Optimizer.h | 186 +--- src/ves/OutputBasisFunctions.cpp | 41 +- src/ves/OutputFesBias.cpp | 7 +- src/ves/OutputTargetDistribution.cpp | 27 +- src/ves/TD_Chi.cpp | 31 +- src/ves/TD_ChiSquared.cpp | 31 +- src/ves/TD_Custom.cpp | 44 +- src/ves/TD_Exponential.cpp | 19 +- src/ves/TD_ExponentiallyModifiedGaussian.cpp | 35 +- src/ves/TD_Gaussian.cpp | 33 +- src/ves/TD_GeneralizedExtremeValue.cpp | 30 +- src/ves/TD_GeneralizedNormal.cpp | 35 +- src/ves/TD_Grid.cpp | 34 +- src/ves/TD_LinearCombination.cpp | 43 +- src/ves/TD_Multicanonical.cpp | 74 +- src/ves/TD_MultithermalMultibaric.cpp | 38 +- src/ves/TD_ProductCombination.cpp | 34 +- src/ves/TD_ProductDistribution.cpp | 19 +- src/ves/TD_Uniform.cpp | 57 +- src/ves/TD_VonMises.cpp | 46 +- src/ves/TD_WellTempered.cpp | 3 +- src/ves/TargetDistribution.cpp | 68 +- src/ves/TargetDistribution.h | 125 +-- src/ves/VesBias.cpp | 68 +- src/ves/VesBias.h | 266 ++--- src/ves/VesDeltaF.cpp | 290 +++--- src/ves/VesLinearExpansion.cpp | 23 +- src/ves/VesTools.cpp | 10 +- src/ves/VesTools.h | 14 +- src/ves/WaveletGrid.cpp | 41 +- src/vesselbase/ActionWithAveraging.cpp | 155 +-- src/vesselbase/ActionWithAveraging.h | 19 +- src/vesselbase/ActionWithInputVessel.cpp | 20 +- src/vesselbase/ActionWithVessel.cpp | 226 ++--- src/vesselbase/ActionWithVessel.h | 24 +- src/vesselbase/AltMin.cpp | 20 +- src/vesselbase/AveragingVessel.cpp | 18 +- src/vesselbase/AveragingVessel.h | 18 +- src/vesselbase/Between.cpp | 30 +- src/vesselbase/BridgeVessel.cpp | 68 +- src/vesselbase/FunctionVessel.cpp | 37 +- src/vesselbase/Highest.cpp | 3 +- src/vesselbase/Histogram.cpp | 21 +- src/vesselbase/LessThan.cpp | 18 +- src/vesselbase/Lowest.cpp | 3 +- src/vesselbase/Max.cpp | 21 +- src/vesselbase/Mean.cpp | 10 +- src/vesselbase/Min.cpp | 20 +- src/vesselbase/Moments.cpp | 73 +- src/vesselbase/MoreThan.cpp | 18 +- src/vesselbase/OrderingVessel.cpp | 21 +- src/vesselbase/ShortcutVessel.cpp | 10 +- src/vesselbase/ShortcutVessel.h | 20 +- src/vesselbase/StoreDataVessel.cpp | 88 +- src/vesselbase/StoreDataVessel.h | 33 +- src/vesselbase/Sum.cpp | 6 +- src/vesselbase/ValueVessel.cpp | 17 +- src/vesselbase/Vessel.cpp | 44 +- src/vesselbase/Vessel.h | 25 +- src/vesselbase/VesselRegister.cpp | 14 +- src/wrapper/Plumed.h | 386 ++------ 567 files changed, 13058 insertions(+), 26864 deletions(-) delete mode 100644 .git-blame-ignore-revs diff --git a/.astyle.options b/.astyle.options index 5b9545ac1f..0a17526e3b 100644 --- a/.astyle.options +++ b/.astyle.options @@ -1,13 +1 @@ -# long options can be written without the preceding '--' -suffix=none #equivalent to "-n" -style=attach -add-braces -indent=spaces=2 -break-one-line-headers - -# old options -#suffix=none -#indent=spaces=2 -#keep-one-line-statements -#keep-one-line-blocks -# end old options +-n --indent=spaces=2 --keep-one-line-statements --keep-one-line-blocks diff --git a/.git-blame-ignore-revs b/.git-blame-ignore-revs deleted file mode 100644 index f0162bbe0c..0000000000 --- a/.git-blame-ignore-revs +++ /dev/null @@ -1,4 +0,0 @@ -# .git-blame-ignore-revs -# https://docs.github.com/en/repositories/working-with-files/using-files/viewing-a-file#ignore-commits-in-the-blame-view -# new astyle applied to v2.9.3 -250c27f90ae7322dbad983964203b6a581f900c8 diff --git a/src/adjmat/ActionWithInputMatrix.cpp b/src/adjmat/ActionWithInputMatrix.cpp index 775ecec4c3..449240d64a 100644 --- a/src/adjmat/ActionWithInputMatrix.cpp +++ b/src/adjmat/ActionWithInputMatrix.cpp @@ -38,38 +38,25 @@ void ActionWithInputMatrix::registerKeywords( Keywords& keys ) { ActionWithInputMatrix::ActionWithInputMatrix(const ActionOptions& ao): Action(ao), MultiColvarBase(ao), - mymatrix(NULL) { + mymatrix(NULL) +{ matsums=true; if( keywords.exists("MATRIX") ) { std::vector fake_atoms; - if( !parseMultiColvarAtomList("MATRIX",-1,fake_atoms ) ) { - error("unable to interpret input matrix"); - } - if( mybasemulticolvars.size()!=1 ) { - error("should be exactly one matrix input"); - } + if( !parseMultiColvarAtomList("MATRIX",-1,fake_atoms ) ) error("unable to interpret input matrix"); + if( mybasemulticolvars.size()!=1 ) error("should be exactly one matrix input"); // Retrieve the adjacency matrix of interest for(unsigned i=0; igetNumberOfVessels(); ++i) { mymatrix = dynamic_cast( mybasemulticolvars[0]->getPntrToVessel(i) ); - if( mymatrix ) { - break ; - } - } - if( !mymatrix ) { - error( mybasemulticolvars[0]->getLabel() + " does not calculate an adjacency matrix"); + if( mymatrix ) break ; } + if( !mymatrix ) error( mybasemulticolvars[0]->getLabel() + " does not calculate an adjacency matrix"); - atom_lab.resize(0); - unsigned nnodes; // Delete all the atom labels that have been created - if( mymatrix->undirectedGraph() ) { - nnodes = (mymatrix->function)->ablocks[0].size(); - } else { - nnodes = (mymatrix->function)->ablocks[0].size() + (mymatrix->function)->ablocks[1].size(); - } - for(unsigned i=0; i( 1, i ) ); - } + atom_lab.resize(0); unsigned nnodes; // Delete all the atom labels that have been created + if( mymatrix->undirectedGraph() ) nnodes = (mymatrix->function)->ablocks[0].size(); + else nnodes = (mymatrix->function)->ablocks[0].size() + (mymatrix->function)->ablocks[1].size(); + for(unsigned i=0; i( 1, i ) ); } } @@ -90,9 +77,7 @@ AtomNumber ActionWithInputMatrix::getAbsoluteIndexOfCentralAtom(const unsigned& } double ActionWithInputMatrix::retrieveConnectionValue( const unsigned& i, const unsigned& j, std::vector& vals ) const { - if( !mymatrix->matrixElementIsActive( i, j ) ) { - return 0; - } + if( !mymatrix->matrixElementIsActive( i, j ) ) return 0; unsigned myelem = mymatrix->getStoreIndexFromMatrixIndices( i, j ); // unsigned vi; double df; @@ -102,24 +87,18 @@ double ActionWithInputMatrix::retrieveConnectionValue( const unsigned& i, const void ActionWithInputMatrix::getInputData( const unsigned& ind, const bool& normed, const multicolvar::AtomValuePack& myatoms, std::vector& orient0 ) const { if( (mymatrix->function)->mybasemulticolvars.size()==0 ) { - std::vector tvals( mymatrix->getNumberOfComponents() ); - orient0.assign(orient0.size(),0); + std::vector tvals( mymatrix->getNumberOfComponents() ); orient0.assign(orient0.size(),0); for(unsigned i=0; igetNumberOfColumns(); ++i) { - if( mymatrix->undirectedGraph() && ind==i ) { - continue; - } + if( mymatrix->undirectedGraph() && ind==i ) continue; orient0[1]+=retrieveConnectionValue( ind, i, tvals ); } - orient0[0]=1.0; - return; + orient0[0]=1.0; return; } (mymatrix->function)->getInputData( ind, normed, myatoms, orient0 ); } void ActionWithInputMatrix::addConnectionDerivatives( const unsigned& i, const unsigned& j, MultiValue& myvals, MultiValue& myvout ) const { - if( !mymatrix->matrixElementIsActive( i, j ) ) { - return; - } + if( !mymatrix->matrixElementIsActive( i, j ) ) return; unsigned myelem = mymatrix->getStoreIndexFromMatrixIndices( i, j ); // Get derivatives and add mymatrix->retrieveDerivatives( myelem, false, myvals ); @@ -138,29 +117,22 @@ MultiValue& ActionWithInputMatrix::getInputDerivatives( const unsigned& ind, con myder.clearAll(); MultiValue myvals( (mymatrix->function)->getNumberOfQuantities(), (mymatrix->function)->getNumberOfDerivatives() ); for(unsigned i=0; igetNumberOfColumns(); ++i) { - if( mymatrix->undirectedGraph() && ind==i ) { - continue; - } + if( mymatrix->undirectedGraph() && ind==i ) continue; addConnectionDerivatives( ind, i, myvals, myder ); } - myder.updateDynamicList(); - return myder; + myder.updateDynamicList(); return myder; } return (mymatrix->function)->getInputDerivatives( ind, normed, myatoms ); } unsigned ActionWithInputMatrix::getNumberOfNodeTypes() const { unsigned size = (mymatrix->function)->mybasemulticolvars.size(); - if( size==0 ) { - return 1; - } + if( size==0 ) return 1; return size; } unsigned ActionWithInputMatrix::getNumberOfQuantities() const { - if( (mymatrix->function)->mybasemulticolvars.size()==0 ) { - return 2; - } + if( (mymatrix->function)->mybasemulticolvars.size()==0 ) return 2; return (mymatrix->function)->mybasemulticolvars[0]->getNumberOfQuantities(); } diff --git a/src/adjmat/ActionWithInputMatrix.h b/src/adjmat/ActionWithInputMatrix.h index e21270468b..9d5c44dcdd 100644 --- a/src/adjmat/ActionWithInputMatrix.h +++ b/src/adjmat/ActionWithInputMatrix.h @@ -57,16 +57,12 @@ class ActionWithInputMatrix : public multicolvar::MultiColvarBase { unsigned getNumberOfDerivatives() override; /// Get the number of rows/cols in the adjacency matrix vessel virtual unsigned getNumberOfNodes() const; - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } unsigned getNumberOfQuantities() const override; /// AtomNumber getAbsoluteIndexOfCentralAtom(const unsigned& i) const override; /// No loop over tasks for ActionWithInputMatrix - double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const override { - plumed_error(); - } + double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const override { plumed_error(); } /// Vector getPositionOfAtomForLinkCells( const unsigned& iatom ) const override; }; diff --git a/src/adjmat/AdjacencyMatrixBase.cpp b/src/adjmat/AdjacencyMatrixBase.cpp index 775ffc4f53..87c47ca732 100644 --- a/src/adjmat/AdjacencyMatrixBase.cpp +++ b/src/adjmat/AdjacencyMatrixBase.cpp @@ -31,8 +31,7 @@ namespace adjmat { void AdjacencyMatrixBase::registerKeywords( Keywords& keys ) { multicolvar::MultiColvarBase::registerKeywords( keys ); - keys.remove("LOWMEM"); - keys.use("HIGHMEM"); + keys.remove("LOWMEM"); keys.use("HIGHMEM"); } AdjacencyMatrixBase::AdjacencyMatrixBase(const ActionOptions& ao): @@ -40,7 +39,8 @@ AdjacencyMatrixBase::AdjacencyMatrixBase(const ActionOptions& ao): MultiColvarBase(ao), connect_id(0), no_third_dim_accum(true), - mat(NULL) { + mat(NULL) +{ log<<" Bibliography "< sw; if( !multiple ) { - sw.resize(1); - parse(key,sw[0]); - if(sw[0].length()==0) { - error("could not find " + key + " keyword"); - } + sw.resize(1); parse(key,sw[0]); + if(sw[0].length()==0) error("could not find " + key + " keyword"); } else { std::string input; for(int i=1;; i++) { - if( !parseNumbered(key, i, input ) ) { - break; - } + if( !parseNumbered(key, i, input ) ) break; sw.push_back( input ); } } setupConnector( connect_id, 0, 0, sw ); } else { - if( multiple ) { - error("keyword " + key + " does not work with multiple input strings"); - } + if( multiple ) error("keyword " + key + " does not work with multiple input strings"); unsigned nr, nc; if( nrow_t==0 ) { nr=nc=getNumberOfNodeTypes(); } else { - nr=nrow_t; - nc = getNumberOfNodeTypes() - nr; + nr=nrow_t; nc = getNumberOfNodeTypes() - nr; } for(unsigned i=0; i sw(1); - parseNumbered(key,ibase+j+1,sw[0]); + std::vector sw(1); parseNumbered(key,ibase+j+1,sw[0]); if(sw[0].length()==0) { - std::string num; - Tools::convert(ibase+j+1,num); + std::string num; Tools::convert(ibase+j+1,num); error("could not find " + key + num + " keyword. Need one " + key + " keyword for each distinct base-multicolvar-pair type"); } setupConnector( connect_id, i, j, sw ); @@ -101,24 +91,18 @@ void AdjacencyMatrixBase::parseConnectionDescriptions( const std::string& key, c } unsigned AdjacencyMatrixBase::getSizeOfInputVectors() const { - if( mybasemulticolvars.size()==0 ) { - return 2; - } + if( mybasemulticolvars.size()==0 ) return 2; unsigned nq = mybasemulticolvars[0]->getNumberOfQuantities(); for(unsigned i=1; igetNumberOfQuantities()!=nq ) { - error("mismatch between vectors in base colvars"); - } + if( mybasemulticolvars[i]->getNumberOfQuantities()!=nq ) error("mismatch between vectors in base colvars"); } return nq; } unsigned AdjacencyMatrixBase::getNumberOfNodeTypes() const { unsigned size=mybasemulticolvars.size(); - if( size==0 ) { - return 1; - } + if( size==0 ) return 1; return size; } @@ -126,90 +110,57 @@ void AdjacencyMatrixBase::retrieveTypeDimensions( unsigned& nrows, unsigned& nco bool allsame=(ablocks[0].size()==ablocks[1].size()); if( allsame ) { for(unsigned i=0; i types(1); - types[0]=atom_lab[ablocks[0][0]].first; + std::vector types(1); types[0]=atom_lab[ablocks[0][0]].first; for(unsigned i=1; i types(1); - types[0]=atom_lab[ablocks[0][0]].first; + std::vector types(1); types[0]=atom_lab[ablocks[0][0]].first; for(unsigned i=1; i& all_atoms ) { std::string param; - if( symmetric && ablocks[0].size()==ablocks[1].size() ) { - param="SYMMETRIC"; - } + if( symmetric && ablocks[0].size()==ablocks[1].size() ) param="SYMMETRIC"; if( !symmetric ) { bool usehbonds=( ablocks[0].size()==ablocks[1].size() ); if( usehbonds ) { for(unsigned i=0; i(da2); addVessel( std::move( ves ) ); @@ -217,14 +168,12 @@ void AdjacencyMatrixBase::finishMatrixSetup( const bool& symmetric, const std::v } void AdjacencyMatrixBase::readMaxTwoSpeciesMatrix( const std::string& key0, const std::string& key1, const std::string& key2, const bool& symmetric ) { - std::vector all_atoms; - readTwoGroups( key0, key1, key2, all_atoms ); + std::vector all_atoms; readTwoGroups( key0, key1, key2, all_atoms ); finishMatrixSetup( symmetric, all_atoms ); } void AdjacencyMatrixBase::readMaxThreeSpeciesMatrix( const std::string& key0, const std::string& key1, const std::string& key2, const std::string& keym, const bool& symmetric ) { - std::vector all_atoms; - readGroupKeywords( key0, key1, key2, keym, true, symmetric, all_atoms ); + std::vector all_atoms; readGroupKeywords( key0, key1, key2, keym, true, symmetric, all_atoms ); finishMatrixSetup( symmetric, all_atoms ); } @@ -236,13 +185,10 @@ void AdjacencyMatrixBase::readMaxThreeSpeciesMatrix( const std::string& key0, co // } void AdjacencyMatrixBase::recalculateMatrixElement( const unsigned& myelem, MultiValue& myvals ) { - std::vector myatoms; - decodeIndexToAtoms( getTaskCode( myelem ), myatoms ); + std::vector myatoms; decodeIndexToAtoms( getTaskCode( myelem ), myatoms ); unsigned i=myatoms[0], j=myatoms[1]; for(unsigned k=bookeeping(i,j).first; k& desc ) = 0; /// None of these things are allowed - bool isPeriodic() { - return false; - } - Vector getCentralAtom() { - plumed_merror("cannot find central atoms for adjacency matrix actions"); - } + bool isPeriodic() { return false; } + Vector getCentralAtom() { plumed_merror("cannot find central atoms for adjacency matrix actions"); } /// Get the atom number AtomNumber getAbsoluteIndexOfCentralAtom( const unsigned& i ) const ; }; @@ -90,9 +86,7 @@ AdjacencyMatrixVessel* AdjacencyMatrixBase::getAdjacencyVessel() { inline unsigned AdjacencyMatrixBase::getBaseColvarNumber( const unsigned& inum ) const { - if( atom_lab[inum].first>0 ) { - return atom_lab[inum].first-1; - } + if( atom_lab[inum].first>0 ) return atom_lab[inum].first-1; return 0; } diff --git a/src/adjmat/AdjacencyMatrixVessel.cpp b/src/adjmat/AdjacencyMatrixVessel.cpp index 3e916b00ed..b4136f0f53 100644 --- a/src/adjmat/AdjacencyMatrixVessel.cpp +++ b/src/adjmat/AdjacencyMatrixVessel.cpp @@ -33,20 +33,14 @@ void AdjacencyMatrixVessel::registerKeywords( Keywords& keys ) { } AdjacencyMatrixVessel::AdjacencyMatrixVessel( const vesselbase::VesselOptions& da ): - StoreDataVessel(da) { + StoreDataVessel(da) +{ function=dynamic_cast( getAction() ); plumed_assert( function ); - parseFlag("SYMMETRIC",symmetric); - parseFlag("HBONDS",hbonds); - if( symmetric && hbonds ) { - error("matrix should be either symmetric or hbonds"); - } - if( symmetric && function->ablocks[0].size()!=function->ablocks[1].size() ) { - error("matrix is supposed to be symmetric but nrows!=ncols"); - } - if( hbonds && function->ablocks[0].size()!=function->ablocks[1].size() ) { - error("matrix is supposed to be hbonds but nrows!=ncols"); - } + parseFlag("SYMMETRIC",symmetric); parseFlag("HBONDS",hbonds); + if( symmetric && hbonds ) error("matrix should be either symmetric or hbonds"); + if( symmetric && function->ablocks[0].size()!=function->ablocks[1].size() ) error("matrix is supposed to be symmetric but nrows!=ncols"); + if( hbonds && function->ablocks[0].size()!=function->ablocks[1].size() ) error("matrix is supposed to be hbonds but nrows!=ncols"); } bool AdjacencyMatrixVessel::isSymmetric() const { @@ -70,19 +64,13 @@ bool AdjacencyMatrixVessel::matrixElementIsActive( const unsigned& ielem, const } unsigned AdjacencyMatrixVessel::getStoreIndexFromMatrixIndices( const unsigned& ielem, const unsigned& jelem ) const { - if( !symmetric && !hbonds ) { - return (function->ablocks[1].size())*ielem + jelem; - } + if( !symmetric && !hbonds ) return (function->ablocks[1].size())*ielem + jelem; if( !symmetric ) { plumed_dbg_assert( ielem!=jelem ); - if( jelemablocks[1].size()-1)*ielem + jelem; - } + if( jelemablocks[1].size()-1)*ielem + jelem; return (function->ablocks[1].size()-1)*ielem + jelem - 1; } - if( ielem>jelem ) { - return 0.5*ielem*(ielem-1)+jelem; - } + if( ielem>jelem ) return 0.5*ielem*(ielem-1)+jelem; return 0.5*jelem*(jelem-1) + ielem; } @@ -91,33 +79,22 @@ AdjacencyMatrixBase* AdjacencyMatrixVessel::getMatrixAction() { } void AdjacencyMatrixVessel::getMatrixIndices( const unsigned& code, unsigned& i, unsigned& j ) const { - std::vector myatoms; - function->decodeIndexToAtoms( function->getTaskCode(code), myatoms ); - i=myatoms[0]; - j=myatoms[1]; - if( !undirectedGraph() ) { - j -= function->ablocks[0].size(); // Have to remove number of columns as returns number in ablocks[1] - } + std::vector myatoms; function->decodeIndexToAtoms( function->getTaskCode(code), myatoms ); + i=myatoms[0]; j=myatoms[1]; + if( !undirectedGraph() ) j -= function->ablocks[0].size(); // Have to remove number of columns as returns number in ablocks[1] } void AdjacencyMatrixVessel::retrieveMatrix( DynamicList& myactive_elements, Matrix& mymatrix ) { - myactive_elements.deactivateAll(); - std::vector vals( getNumberOfComponents() ); + myactive_elements.deactivateAll(); std::vector vals( getNumberOfComponents() ); for(unsigned i=0; igetPositionInFullTaskList(i), k, j ); - - if( symmetric ) { - mymatrix(k,j)=mymatrix(j,k)=vals[0]*vals[1]; - } else { - mymatrix(k,j)=vals[0]*vals[1]; - } + unsigned j, k; getMatrixIndices( function->getPositionInFullTaskList(i), k, j ); + + if( symmetric ) mymatrix(k,j)=mymatrix(j,k)=vals[0]*vals[1]; + else mymatrix(k,j)=vals[0]*vals[1]; } myactive_elements.updateActiveMembers(); } @@ -125,48 +102,34 @@ void AdjacencyMatrixVessel::retrieveMatrix( DynamicList& myactive_elem void AdjacencyMatrixVessel::retrieveAdjacencyLists( std::vector& nneigh, Matrix& adj_list ) { plumed_dbg_assert( undirectedGraph() ); // Currently everything has zero neighbors - for(unsigned i=0; i myvals( getNumberOfComponents() ); for(unsigned i=0; igetPositionInFullTaskList(i), k, j ); + unsigned j, k; getMatrixIndices( function->getPositionInFullTaskList(i), k, j ); - if( nneigh[j]>=adj_list.ncols() || nneigh[k]>=adj_list.ncols() ) { - error("adjacency lists are not large enough, increase maxconnections"); - } + if( nneigh[j]>=adj_list.ncols() || nneigh[k]>=adj_list.ncols() ) error("adjacency lists are not large enough, increase maxconnections"); // Store if atoms are connected // unsigned j, k; getMatrixIndices( i, k, j ); - adj_list(k,nneigh[k])=j; - nneigh[k]++; - adj_list(j,nneigh[j])=k; - nneigh[j]++; + adj_list(k,nneigh[k])=j; nneigh[k]++; + adj_list(j,nneigh[j])=k; nneigh[j]++; } } void AdjacencyMatrixVessel::retrieveEdgeList( unsigned& nedge, std::vector >& edge_list ) { - plumed_dbg_assert( undirectedGraph() ); - nedge=0; + plumed_dbg_assert( undirectedGraph() ); nedge=0; std::vector myvals( getNumberOfComponents() ); - if( getNumberOfStoredValues()>edge_list.size() ) { - error("adjacency lists are not large enough, increase maxconnections"); - } + if( getNumberOfStoredValues()>edge_list.size() ) error("adjacency lists are not large enough, increase maxconnections"); for(unsigned i=0; igetPositionInFullTaskList(i), edge_list[nedge].first, edge_list[nedge].second ); nedge++; @@ -174,9 +137,7 @@ void AdjacencyMatrixVessel::retrieveEdgeList( unsigned& nedge, std::vector myvals( getNumberOfComponents() ); diff --git a/src/adjmat/AlignedMatrixBase.cpp b/src/adjmat/AlignedMatrixBase.cpp index a251264649..7d865e964d 100644 --- a/src/adjmat/AlignedMatrixBase.cpp +++ b/src/adjmat/AlignedMatrixBase.cpp @@ -47,17 +47,13 @@ void AlignedMatrixBase::registerKeywords( Keywords& keys ) { AlignedMatrixBase::AlignedMatrixBase( const ActionOptions& ao ): Action(ao), - AdjacencyMatrixBase(ao) { + AdjacencyMatrixBase(ao) +{ // Read in the atomic positions readMaxTwoSpeciesMatrix( "ATOMS", "ATOMSA", "ATOMSB", true ); - unsigned nrows, ncols; - retrieveTypeDimensions( nrows, ncols, ncol_t ); - if( mybasemulticolvars.size()==0 ) { - error("cannot use atom indices as input to this variable / input was not specified"); - } - if( getSizeOfInputVectors()<3 ) { - error("base multicolvars do not calculate an orientation"); - } + unsigned nrows, ncols; retrieveTypeDimensions( nrows, ncols, ncol_t ); + if( mybasemulticolvars.size()==0 ) error("cannot use atom indices as input to this variable / input was not specified"); + if( getSizeOfInputVectors()<3 ) error("base multicolvars do not calculate an orientation"); // Read in the switching function switchingFunction.resize( nrows, ncols ); parseConnectionDescriptions("SWITCH",false,ncol_t); @@ -67,9 +63,7 @@ AlignedMatrixBase::AlignedMatrixBase( const ActionOptions& ao ): for(unsigned i=0; isfmax ) { - sfmax=tsf; - } + if( tsf>sfmax ) sfmax=tsf; } } // And set the link cell cutoff @@ -79,15 +73,9 @@ AlignedMatrixBase::AlignedMatrixBase( const ActionOptions& ao ): void AlignedMatrixBase::setupConnector( const unsigned& id, const unsigned& i, const unsigned& j, const std::vector& desc ) { plumed_assert( id<2 ); if( id==0 ) { - plumed_assert( desc.size()==1 ); - std::string errors; - switchingFunction(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function in SWITCH keywrd description " + errors); - } - if( j!=i) { - switchingFunction(i,j).set(desc[0],errors); - } + plumed_assert( desc.size()==1 ); std::string errors; switchingFunction(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function in SWITCH keywrd description " + errors); + if( j!=i) switchingFunction(i,j).set(desc[0],errors); log.printf(" %u th and %u th multicolvar groups must be within %s\n",i+1,j+1,(switchingFunction(i,j).description()).c_str() ); } else if( id==1 ) { readOrientationConnector( i, j, desc ); @@ -96,19 +84,15 @@ void AlignedMatrixBase::setupConnector( const unsigned& id, const unsigned& i, c double AlignedMatrixBase::calculateWeight( const unsigned& taskCode, const double& weight, multicolvar::AtomValuePack& myatoms ) const { Vector distance = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - if( distance.modulo2() orient0(ncomp), orient1(ncomp), dorient0(ncomp), dorient1(ncomp); Vector distance = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - getInputData( 0, true, myatoms, orient0 ); - getInputData( 1, true, myatoms, orient1 ); + getInputData( 0, true, myatoms, orient0 ); getInputData( 1, true, myatoms, orient1 ); double f_dot = computeVectorFunction( getBaseColvarNumber( myatoms.getIndex(0) ), getBaseColvarNumber( myatoms.getIndex(1) )-ncol_t, distance, orient0, orient1, ddistance, dorient0, dorient1 ); @@ -121,10 +105,7 @@ double AlignedMatrixBase::compute( const unsigned& tindex, multicolvar::AtomValu myatoms.addBoxDerivatives( 1, (-dfunc)*f_dot*Tensor(distance,distance) - sw*extProduct( distance, ddistance ) ); // Add derivatives of orientation - for(unsigned k=2; k fake_atoms; + matsums=usespecies=true; std::vector fake_atoms; // Find what action we are taking the clusters from - if( !parseMultiColvarAtomList("CLUSTERS",-1,fake_atoms ) ) { - error("unable to interpret input CLUSTERS" ); - } - if( mybasemulticolvars.size()!=1 ) { - error("should be exactly one multicolvar input"); - } - atom_lab.resize(0); - myclusters = dynamic_cast( mybasemulticolvars[0] ); - if( !myclusters ) { - error("input label is not that of a DFS object"); - } + if( !parseMultiColvarAtomList("CLUSTERS",-1,fake_atoms ) ) error("unable to interpret input CLUSTERS" ); + if( mybasemulticolvars.size()!=1 ) error("should be exactly one multicolvar input"); + atom_lab.resize(0); myclusters = dynamic_cast( mybasemulticolvars[0] ); + if( !myclusters ) error("input label is not that of a DFS object"); // Setup the atom pack myfatoms.setNumberOfAtoms( myclusters->getNumberOfNodes() ); myfvals.getIndices().resize( myclusters->getNumberOfNodes() ); - for(unsigned i=0; igetNumberOfNodes(); ++i) { - myfatoms.setAtomIndex( i, i ); - } + for(unsigned i=0; igetNumberOfNodes(); ++i) myfatoms.setAtomIndex( i, i ); } void ClusterAnalysisBase::turnOnDerivatives() { // Check for dubious vessels for(unsigned i=0; igetName()=="MEAN" ) { - error("MEAN of cluster is not differentiable"); - } - if( getPntrToVessel(i)->getName()=="VMEAN" ) { - error("VMEAN of cluster is not differentiable"); - } + if( getPntrToVessel(i)->getName()=="MEAN" ) error("MEAN of cluster is not differentiable"); + if( getPntrToVessel(i)->getName()=="VMEAN" ) error("VMEAN of cluster is not differentiable"); } MultiColvarBase::turnOnDerivatives(); } diff --git a/src/adjmat/ClusterAnalysisBase.h b/src/adjmat/ClusterAnalysisBase.h index b43cb465cd..97593afb5d 100644 --- a/src/adjmat/ClusterAnalysisBase.h +++ b/src/adjmat/ClusterAnalysisBase.h @@ -50,9 +50,7 @@ class ClusterAnalysisBase : public multicolvar::MultiColvarBase { void turnOnDerivatives() override; void setupActiveTaskSet( std::vector& active_tasks, const std::string& input_label ) {} Vector getPositionOfAtomForLinkCells( const unsigned& ) const override; - double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const override { - plumed_error(); - } + double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const override { plumed_error(); } }; } diff --git a/src/adjmat/ClusterDiameter.cpp b/src/adjmat/ClusterDiameter.cpp index 1879d81134..aa67dce394 100644 --- a/src/adjmat/ClusterDiameter.cpp +++ b/src/adjmat/ClusterDiameter.cpp @@ -86,27 +86,20 @@ void ClusterDiameter::registerKeywords( Keywords& keys ) { ClusterDiameter::ClusterDiameter(const ActionOptions&ao): Action(ao), - ClusterAnalysisBase(ao) { + ClusterAnalysisBase(ao) +{ // Find out which cluster we want parse("CLUSTER",clustr); - if( clustr<1 ) { - error("cannot look for a cluster larger than the largest cluster"); - } - if( clustr>getNumberOfNodes() ) { - error("cluster selected is invalid - too few atoms in system"); - } + if( clustr<1 ) error("cannot look for a cluster larger than the largest cluster"); + if( clustr>getNumberOfNodes() ) error("cluster selected is invalid - too few atoms in system"); // Create the task list for(unsigned i=0; i fake_atoms; - setupMultiColvarBase( fake_atoms ); + addVessel("HIGHEST", "", -1); std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); } void ClusterDiameter::turnOnDerivatives() { @@ -115,14 +108,11 @@ void ClusterDiameter::turnOnDerivatives() { void ClusterDiameter::calculate() { // Retrieve the atoms in the largest cluster - std::vector myatoms; - retrieveAtomsInCluster( clustr, myatoms ); + std::vector myatoms; retrieveAtomsInCluster( clustr, myatoms ); // Activate the relevant tasks deactivateAllTasks(); for(unsigned i=1; i fake_atoms; - setupMultiColvarBase( fake_atoms ); + std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); } void ClusterDistribution::calculate() { // Activate the relevant tasks nderivatives = getNumberOfDerivatives(); deactivateAllTasks(); - for(unsigned i=0; i myatoms; - retrieveAtomsInCluster( current+1, myatoms ); + std::vector myatoms; retrieveAtomsInCluster( current+1, myatoms ); // This deals with filters - if( myatoms.size()==1 && !nodeIsActive(myatoms[0]) ) { - return ; - } + if( myatoms.size()==1 && !nodeIsActive(myatoms[0]) ) return ; std::vector vals( getNumberOfQuantities() ); MultiValue tvals( getNumberOfQuantities(), nderivatives ); @@ -155,16 +137,12 @@ void ClusterDistribution::performTask( const unsigned& task_index, const unsigne getPropertiesOfNode( i, vals ); if( use_switch && !inverse ) { vv = 1.0 - sf.calculate( vals[1], df ); - tval += vals[0]*vv; - df=-df*vals[1]; + tval += vals[0]*vv; df=-df*vals[1]; } else if( use_switch ) { vv = sf.calculate( vals[1], df ); - tval += vals[0]*vv; - df=df*vals[1]; + tval += vals[0]*vv; df=df*vals[1]; } else { - tval += vals[0]*vals[1]; - df=1.; - vv=vals[1]; + tval += vals[0]*vals[1]; df=1.; vv=vals[1]; } if( !doNotCalculateDerivatives() ) { getNodePropertyDerivatives( i, tvals ); @@ -175,8 +153,7 @@ void ClusterDistribution::performTask( const unsigned& task_index, const unsigne tvals.clearAll(); } } - myvals.setValue( 0, 1.0 ); - myvals.setValue( 1, tval ); + myvals.setValue( 0, 1.0 ); myvals.setValue( 1, tval ); } } diff --git a/src/adjmat/ClusterProperties.cpp b/src/adjmat/ClusterProperties.cpp index d27c5ba518..5739fd443b 100644 --- a/src/adjmat/ClusterProperties.cpp +++ b/src/adjmat/ClusterProperties.cpp @@ -76,72 +76,45 @@ PLUMED_REGISTER_ACTION(ClusterProperties,"CLUSTER_PROPERTIES") void ClusterProperties::registerKeywords( Keywords& keys ) { ClusterAnalysisBase::registerKeywords( keys ); keys.add("compulsory","CLUSTER","1","which cluster would you like to look at 1 is the largest cluster, 2 is the second largest, 3 is the the third largest and so on."); - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("LESS_THAN"); - if( keys.reserved("VMEAN") ) { - keys.use("VMEAN"); - } - if( keys.reserved("VSUM") ) { - keys.use("VSUM"); - } - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); - keys.use("ALT_MIN"); - keys.use("MIN"); - keys.use("MAX"); - keys.use("SUM"); - keys.use("LOWEST"); - keys.use("HIGHEST"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("LESS_THAN"); + if( keys.reserved("VMEAN") ) keys.use("VMEAN"); + if( keys.reserved("VSUM") ) keys.use("VSUM"); + keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.use("ALT_MIN"); + keys.use("MIN"); keys.use("MAX"); keys.use("SUM"); keys.use("LOWEST"); keys.use("HIGHEST"); } ClusterProperties::ClusterProperties(const ActionOptions&ao): Action(ao), - ClusterAnalysisBase(ao) { + ClusterAnalysisBase(ao) +{ // Find out which cluster we want parse("CLUSTER",clustr); - if( clustr<1 ) { - error("cannot look for a cluster larger than the largest cluster"); - } - if( clustr>getNumberOfNodes() ) { - error("cluster selected is invalid - too few atoms in system"); - } + if( clustr<1 ) error("cannot look for a cluster larger than the largest cluster"); + if( clustr>getNumberOfNodes() ) error("cluster selected is invalid - too few atoms in system"); // Create all tasks by copying those from underlying DFS object (which is actually MultiColvar) - for(unsigned i=0; i fake_atoms; - setupMultiColvarBase( fake_atoms ); + std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); } void ClusterProperties::calculate() { // Retrieve the atoms in the largest cluster - std::vector myatoms; - retrieveAtomsInCluster( clustr, myatoms ); + std::vector myatoms; retrieveAtomsInCluster( clustr, myatoms ); // Activate the relevant tasks deactivateAllTasks(); - for(unsigned i=0; i vals( myvals.getNumberOfValues() ); - getPropertiesOfNode( current, vals ); - if( !doNotCalculateDerivatives() ) { - getNodePropertyDerivatives( current, myvals ); - } - for(unsigned k=0; k vals( myvals.getNumberOfValues() ); getPropertiesOfNode( current, vals ); + if( !doNotCalculateDerivatives() ) getNodePropertyDerivatives( current, myvals ); + for(unsigned k=0; kgetNumberOfNodes() ) { - error("cluster selected is invalid - too few atoms in system"); - } + if( clustr<1 ) error("cannot look for a cluster larger than the largest cluster"); + if( clustr>getNumberOfNodes() ) error("cluster selected is invalid - too few atoms in system"); // Create all tasks by copying those from underlying DFS object (which is actually MultiColvar) - for(unsigned i=0; i fake_atoms; - setupMultiColvarBase( fake_atoms ); - addValue(); - setNotPeriodic(); + std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); + addValue(); setNotPeriodic(); } void ClusterSize::turnOnDerivatives() { @@ -115,9 +106,7 @@ void ClusterSize::turnOnDerivatives() { void ClusterSize::calculate() { // Retrieve the atoms in the largest cluster - std::vector myatoms; - retrieveAtomsInCluster( clustr, myatoms ); - setValue( myatoms.size() ); + std::vector myatoms; retrieveAtomsInCluster( clustr, myatoms ); setValue( myatoms.size() ); } } diff --git a/src/adjmat/ClusterWithSurface.cpp b/src/adjmat/ClusterWithSurface.cpp index acb7be9e16..780dd7ab95 100644 --- a/src/adjmat/ClusterWithSurface.cpp +++ b/src/adjmat/ClusterWithSurface.cpp @@ -107,28 +107,19 @@ void ClusterWithSurface::registerKeywords( Keywords& keys ) { ClusterWithSurface::ClusterWithSurface(const ActionOptions&ao): Action(ao), - ClusteringBase(ao) { + ClusteringBase(ao) +{ std::vector fake_atoms; - if( !parseMultiColvarAtomList("CLUSTERS",-1,fake_atoms ) ) { - error("unable to find CLUSTERS input"); - } - if( mybasemulticolvars.size()!=1 ) { - error("should be exactly one multicolvar input"); - } + if( !parseMultiColvarAtomList("CLUSTERS",-1,fake_atoms ) ) error("unable to find CLUSTERS input"); + if( mybasemulticolvars.size()!=1 ) error("should be exactly one multicolvar input"); // Retrieve the adjacency matrix of interest - atom_lab.resize(0); - myclusters = dynamic_cast( mybasemulticolvars[0] ); - if( !myclusters ) { - error( mybasemulticolvars[0]->getLabel() + " does not calculate clusters"); - } + atom_lab.resize(0); myclusters = dynamic_cast( mybasemulticolvars[0] ); + if( !myclusters ) error( mybasemulticolvars[0]->getLabel() + " does not calculate clusters"); // Setup switching function for surface atoms - double rcut_surf; - parse("RCUT_SURF",rcut_surf); - if( rcut_surf>0 ) { - log.printf(" counting surface atoms that are within %f of the cluster atoms \n",rcut_surf); - } + double rcut_surf; parse("RCUT_SURF",rcut_surf); + if( rcut_surf>0 ) log.printf(" counting surface atoms that are within %f of the cluster atoms \n",rcut_surf); rcut_surf2=rcut_surf*rcut_surf; // And now finish the setup of everything in the base @@ -161,51 +152,35 @@ unsigned ClusterWithSurface::getNumberOfQuantities() const { double ClusterWithSurface::getCutoffForConnection() const { double tcut = myclusters->getCutoffForConnection(); - if( tcut>std::sqrt(rcut_surf2) ) { - return tcut; - } + if( tcut>std::sqrt(rcut_surf2) ) return tcut; return std::sqrt(rcut_surf2); } void ClusterWithSurface::retrieveAtomsInCluster( const unsigned& clust, std::vector& myatoms ) const { - std::vector tmpat; - myclusters->retrieveAtomsInCluster( clust, tmpat ); + std::vector tmpat; myclusters->retrieveAtomsInCluster( clust, tmpat ); // Prevent double counting std::vector incluster( getNumberOfNodes(), false ); - for(unsigned i=0; i surface_atom( getNumberOfNodes(), false ); for(unsigned i=0; iundirectedGraph() ) { - error("input contact matrix is incompatible with clustering"); - } + cluster_sizes.resize(getNumberOfNodes()); which_cluster.resize(getNumberOfNodes()); + if( getNumberOfNodeTypes()!=1 ) error("should only be running clustering with one base multicolvar in function"); + if( !getAdjacencyVessel()->undirectedGraph() ) error("input contact matrix is incompatible with clustering"); } if( keywords.exists("MATRIX") ) { - std::vector fake_atoms; - setupMultiColvarBase( fake_atoms ); + std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); } } void ClusteringBase::turnOnDerivatives() { // Check base multicolvar isn't density probably other things shouldn't be allowed here as well if( (getAdjacencyVessel()->getMatrixAction())->getNumberOfBaseMultiColvars()>0 ) { - if( getBaseMultiColvar(0)->isDensity() ) { - error("DFS clustering cannot be differentiated if base multicolvar is DENSITY"); - } + if( getBaseMultiColvar(0)->isDensity() ) error("DFS clustering cannot be differentiated if base multicolvar is DENSITY"); } // Ensure that derivatives are turned on in base classes @@ -64,10 +57,7 @@ void ClusteringBase::turnOnDerivatives() { void ClusteringBase::calculate() { // All the clusters have zero size initially - for(unsigned i=0; i& myatoms ) const { - unsigned n=0; - myatoms.resize( cluster_sizes[cluster_sizes.size() - clust].first ); + unsigned n=0; myatoms.resize( cluster_sizes[cluster_sizes.size() - clust].first ); for(unsigned i=0; i& desc ) { - plumed_assert( desc.size()==1 ); - std::string errors; - sf(j,i).set(desc[0],errors); - if( j!=i ) { - sf(i,j).set(desc[0],errors); - } + plumed_assert( desc.size()==1 ); std::string errors; sf(j,i).set(desc[0],errors); + if( j!=i ) sf(i,j).set(desc[0],errors); log.printf(" vectors in %u th and %u th groups must have a dot product that is greater than %s \n",i+1,j+1,(sf(i,j).description()).c_str() ); } double ContactAlignedMatrix::computeVectorFunction( const unsigned& iv, const unsigned& jv, const Vector& conn, const std::vector& vec1, const std::vector& vec2, Vector& dconn, std::vector& dvec1, std::vector& dvec2 ) const { - double dot_df, dot=0; - dconn.zero(); - for(unsigned k=2; ksfmax ) { - sfmax=tsf; - } + if( tsf>sfmax ) sfmax=tsf; } } // And set the link cell cutoff @@ -123,23 +120,15 @@ ContactMatrix::ContactMatrix( const ActionOptions& ao ): } void ContactMatrix::setupConnector( const unsigned& id, const unsigned& i, const unsigned& j, const std::vector& desc ) { - plumed_assert( id==0 && desc.size()==1 ); - std::string errors; - switchingFunction(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i) { - switchingFunction(i,j).set(desc[0],errors); - } + plumed_assert( id==0 && desc.size()==1 ); std::string errors; switchingFunction(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i) switchingFunction(i,j).set(desc[0],errors); log.printf(" %u th and %u th multicolvar groups must be within %s\n",i+1,j+1,(switchingFunction(i,j).description()).c_str() ); } double ContactMatrix::calculateWeight( const unsigned& taskCode, const double& weight, multicolvar::AtomValuePack& myatoms ) const { Vector distance = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - if( distance.modulo2()0 ) { - edge_list.resize( getNumberOfNodes()*maxconnections ); - } else { - edge_list.resize(0.5*getNumberOfNodes()*(getNumberOfNodes()-1)); - } + if( maxconnections>0 ) edge_list.resize( getNumberOfNodes()*maxconnections ); + else edge_list.resize(0.5*getNumberOfNodes()*(getNumberOfNodes()-1)); #else - nneigh.resize( getNumberOfNodes() ); - color.resize(getNumberOfNodes()); - if( maxconnections>0 ) { - adj_list.resize(getNumberOfNodes(),maxconnections); - } else { - adj_list.resize(getNumberOfNodes(),getNumberOfNodes()); - } + nneigh.resize( getNumberOfNodes() ); color.resize(getNumberOfNodes()); + if( maxconnections>0 ) adj_list.resize(getNumberOfNodes(),maxconnections); + else adj_list.resize(getNumberOfNodes(),getNumberOfNodes()); #endif } void DFSClustering::performClustering() { #ifdef __PLUMED_HAS_BOOST_GRAPH // Get the list of edges - unsigned nedges=0; - getAdjacencyVessel()->retrieveEdgeList( nedges, edge_list ); + unsigned nedges=0; getAdjacencyVessel()->retrieveEdgeList( nedges, edge_list ); // Build the graph using boost boost::adjacency_list sg(&edge_list[0],&edge_list[nedges],getNumberOfNodes()); @@ -136,21 +128,15 @@ void DFSClustering::performClustering() { number_of_cluster=boost::connected_components(sg,&which_cluster[0]) - 1; // And work out the size of each cluster - for(unsigned i=0; iretrieveAdjacencyLists( nneigh, adj_list ); // Perform clustering - number_of_cluster=-1; - color.assign(color.size(),0); + number_of_cluster=-1; color.assign(color.size(),0); for(unsigned i=0; i( mstring ); - if( !mm ) { - error("found no action in set with label " + mstring + " that calculates matrix"); - } + if( !mm ) error("found no action in set with label " + mstring + " that calculates matrix"); log.printf(" printing graph for matrix calculated by action %s\n", mm->getLabel().c_str() ); // Retrieve the adjacency matrix of interest for(unsigned i=0; igetNumberOfVessels(); ++i) { mymatrix = dynamic_cast( mm->getPntrToVessel(i) ); - if( mymatrix ) { - break ; - } - } - if( !mymatrix ) { - error( mm->getLabel() + " does not calculate an adjacency matrix"); - } - if( !mymatrix->isSymmetric() ) { - error("input contact matrix must be symmetric"); - } - if( maxconnections==0 ) { - maxconnections=mymatrix->getNumberOfRows(); + if( mymatrix ) break ; } + if( !mymatrix ) error( mm->getLabel() + " does not calculate an adjacency matrix"); + if( !mymatrix->isSymmetric() ) error("input contact matrix must be symmetric"); + if( maxconnections==0 ) maxconnections=mymatrix->getNumberOfRows(); parse("FILE",filename); log.printf(" printing graph to file named %s \n",filename.c_str() ); checkRead(); } void DumpGraph::update() { - OFile ofile; - ofile.link(*this); - ofile.setBackupString("graph"); - ofile.open( filename ); - ofile.printf("graph G { \n"); + OFile ofile; ofile.link(*this); ofile.setBackupString("graph"); + ofile.open( filename ); ofile.printf("graph G { \n"); // Print all nodes - for(unsigned i=0; igetNumberOfRows(); ++i) { - ofile.printf("%u [label=\"%u\"];\n",i,i); - } + for(unsigned i=0; igetNumberOfRows(); ++i) ofile.printf("%u [label=\"%u\"];\n",i,i); // Now retrieve connectivitives - unsigned nedge; - std::vector > edge_list( mymatrix->getNumberOfRows()*maxconnections ); + unsigned nedge; std::vector > edge_list( mymatrix->getNumberOfRows()*maxconnections ); mymatrix->retrieveEdgeList( nedge, edge_list ); - for(unsigned i=0; isfmax ) { - sfmax=tsf; - } + if( tsf>sfmax ) sfmax=tsf; } } // Set the link cell cutoff @@ -165,70 +161,45 @@ HBondMatrix::HBondMatrix( const ActionOptions& ao ): void HBondMatrix::setupConnector( const unsigned& id, const unsigned& i, const unsigned& j, const std::vector& desc ) { plumed_assert( id<3 && desc.size()==1 ); if( id==0 ) { - std::string errors; - distanceOOSwitch(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i) { - distanceOOSwitch(i,j).set(desc[0],errors); - } + std::string errors; distanceOOSwitch(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i) distanceOOSwitch(i,j).set(desc[0],errors); log.printf(" atoms of type %u and %u must be within %s\n",i+1,j+1,(distanceOOSwitch(i,j).description()).c_str() ); } else if( id==1 ) { - std::string errors; - distanceOHSwitch(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i) { - distanceOHSwitch(i,j).set(desc[0],errors); - } + std::string errors; distanceOHSwitch(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i) distanceOHSwitch(i,j).set(desc[0],errors); log.printf(" for atoms of type %u and %u the OH distance must be less than %s \n",i+1,j+1,(distanceOHSwitch(i,j).description()).c_str() ); } else if( id==2 ) { - std::string errors; - angleSwitch(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i) { - angleSwitch(i,j).set(desc[0],errors); - } + std::string errors; angleSwitch(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i) angleSwitch(i,j).set(desc[0],errors); log.printf(" for atoms of type %u and %u the OOH angle must be less than %s \n",i+1,j+1,(angleSwitch(i,j).description()).c_str() ); } } double HBondMatrix::calculateWeight( const unsigned& taskCode, const double& weight, multicolvar::AtomValuePack& myatoms ) const { // Ensure we skip diagonal elements of square matrix - if( myatoms.getIndex(0)==myatoms.getIndex(1) ) { - return 0.0; - } + if( myatoms.getIndex(0)==myatoms.getIndex(1) ) return 0.0; Vector distance = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - if( distance.modulo2()3 ) { - for(unsigned i=2; igetMatrixAction())->mybasemulticolvars.size()>0 ) { - error("matrix row sums should only be calculated when inputs are atoms"); - } + ActionWithInputMatrix(ao) +{ + if( (mymatrix->getMatrixAction())->mybasemulticolvars.size()>0 ) error("matrix row sums should only be calculated when inputs are atoms"); // Setup the tasks unsigned ncols = mymatrix->getNumberOfColumns(); - ablocks.resize(1); - ablocks[0].resize( ncols ); - for(unsigned i=0; iundirectedGraph() ) { - for(unsigned i=0; igetNumberOfRows() + i; - } + for(unsigned i=0; igetNumberOfRows() + i; } - std::vector fake_atoms; - setupMultiColvarBase( fake_atoms ); + std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); } double MatrixColumnSums::compute( const unsigned& tinded, multicolvar::AtomValuePack& myatoms ) const { - double sum=0.0; - std::vector tvals( mymatrix->getNumberOfComponents() ); + double sum=0.0; std::vector tvals( mymatrix->getNumberOfComponents() ); unsigned nrows = mymatrix->getNumberOfRows(); for(unsigned i=0; iundirectedGraph() && tinded==i ) { - continue; - } + if( mymatrix->undirectedGraph() && tinded==i ) continue; sum+=retrieveConnectionValue( i, tinded, tvals ); } @@ -131,9 +111,7 @@ double MatrixColumnSums::compute( const unsigned& tinded, multicolvar::AtomValue MultiValue myvals( mymatrix->getNumberOfComponents(), myatoms.getNumberOfDerivatives() ); MultiValue& myvout=myatoms.getUnderlyingMultiValue(); for(unsigned i=0; iisSymmetric() && tinded==i ) { - continue ; - } + if( mymatrix->isSymmetric() && tinded==i ) continue ; addConnectionDerivatives( i, tinded, myvals, myvout ); } } diff --git a/src/adjmat/MatrixRowSums.cpp b/src/adjmat/MatrixRowSums.cpp index ab0568744f..4905f9b0aa 100644 --- a/src/adjmat/MatrixRowSums.cpp +++ b/src/adjmat/MatrixRowSums.cpp @@ -76,45 +76,29 @@ PLUMED_REGISTER_ACTION(MatrixRowSums,"ROWSUMS") void MatrixRowSums::registerKeywords( Keywords& keys ) { ActionWithInputMatrix::registerKeywords( keys ); - keys.use("ALT_MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("MAX"); - keys.use("LESS_THAN"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("ALT_MIN"); keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("MEAN"); keys.use("MIN"); keys.use("MAX"); keys.use("LESS_THAN"); + keys.use("MORE_THAN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); } MatrixRowSums::MatrixRowSums(const ActionOptions& ao): Action(ao), - ActionWithInputMatrix(ao) { - if( (mymatrix->getMatrixAction())->mybasemulticolvars.size()>0 ) { - warning("matrix row may be problematic when inputs are not atoms"); - } + ActionWithInputMatrix(ao) +{ + if( (mymatrix->getMatrixAction())->mybasemulticolvars.size()>0 ) warning("matrix row may be problematic when inputs are not atoms"); // Setup the tasks unsigned nrows = mymatrix->getNumberOfRows(); - ablocks.resize(1); - ablocks[0].resize( nrows ); - for(unsigned i=0; i fake_atoms; - setupMultiColvarBase( fake_atoms ); + ablocks.resize(1); ablocks[0].resize( nrows ); + for(unsigned i=0; i fake_atoms; setupMultiColvarBase( fake_atoms ); } double MatrixRowSums::compute( const unsigned& tinded, multicolvar::AtomValuePack& myatoms ) const { std::vector tvals( mymatrix->getNumberOfComponents() ); - getInputData( tinded, false, myatoms, tvals ); - double fval=tvals[1]; + getInputData( tinded, false, myatoms, tvals ); double fval=tvals[1]; if( !doNotCalculateDerivatives() ) { - tvals.assign( tvals.size(), 0 ); - tvals[1]=1.0; + tvals.assign( tvals.size(), 0 ); tvals[1]=1.0; mergeInputDerivatives( 1, 1, 2, tinded, tvals, getInputDerivatives( tinded, false, myatoms ), myatoms ); } return fval; diff --git a/src/adjmat/OutputCluster.cpp b/src/adjmat/OutputCluster.cpp index f9ae8da564..7fe7a3cd27 100644 --- a/src/adjmat/OutputCluster.cpp +++ b/src/adjmat/OutputCluster.cpp @@ -103,52 +103,33 @@ void OutputCluster::registerKeywords( Keywords& keys ) { OutputCluster::OutputCluster(const ActionOptions& ao): Action(ao), ActionPilot(ao), - myclusters(NULL) { + myclusters(NULL) +{ // Setup output file - ofile.link(*this); - std::string file; - parse("FILE",file); - if( file.length()==0 ) { - error("output file name was not specified"); - } + ofile.link(*this); std::string file; parse("FILE",file); + if( file.length()==0 ) error("output file name was not specified"); // Search for xyz extension output_xyz=false; if( file.find(".")!=std::string::npos ) { std::size_t dot=file.find_first_of('.'); - if( file.substr(dot+1)=="xyz" ) { - output_xyz=true; - } + if( file.substr(dot+1)=="xyz" ) output_xyz=true; } - ofile.open(file); - log.printf(" on file %s \n",file.c_str()); - parseFlag("MAKE_WHOLE",makewhole); - parse("MAXDEPTH",maxdepth); - parse("MAXGOES",maxgoes); - if( makewhole && !output_xyz) { - error("MAKE_WHOLE flag is not compatible with output of non-xyz files"); - } + ofile.open(file); log.printf(" on file %s \n",file.c_str()); + parseFlag("MAKE_WHOLE",makewhole); parse("MAXDEPTH",maxdepth); parse("MAXGOES",maxgoes); + if( makewhole && !output_xyz) error("MAKE_WHOLE flag is not compatible with output of non-xyz files"); // Find what action we are taking the clusters from - std::vector matname(1); - parse("CLUSTERS",matname[0]); + std::vector matname(1); parse("CLUSTERS",matname[0]); myclusters = plumed.getActionSet().selectWithLabel( matname[0] ); - if( !myclusters ) { - error( matname[0] + " does not calculate perform a clustering of the atomic positions"); - } + if( !myclusters ) error( matname[0] + " does not calculate perform a clustering of the atomic positions"); // N.B. the +0.3 is a fudge factor. Reconstrucing PBC doesnt work without this GAT - addDependency( myclusters ); - double rcut=myclusters->getCutoffForConnection() + 0.3; - rcut2=rcut*rcut; + addDependency( myclusters ); double rcut=myclusters->getCutoffForConnection() + 0.3; rcut2=rcut*rcut; // Read in the cluster we are calculating parse("CLUSTER",clustr); - if( clustr<1 ) { - error("cannot look for a cluster larger than the largest cluster"); - } - if( clustr>myclusters->getNumberOfNodes() ) { - error("cluster selected is invalid - too few atoms in system"); - } + if( clustr<1 ) error("cannot look for a cluster larger than the largest cluster"); + if( clustr>myclusters->getNumberOfNodes() ) error("cluster selected is invalid - too few atoms in system"); log.printf(" outputting atoms in %u th largest cluster found by %s \n",clustr,matname[0].c_str() ); } @@ -160,58 +141,35 @@ void OutputCluster::update() { if( makewhole ) { // Retrieve the atom positions atomsin.resize( myatoms.size() ); - for(unsigned i=0; igetPositionOfAtomForLinkCells( myatoms[i] ); - } + for(unsigned i=0; igetPositionOfAtomForLinkCells( myatoms[i] ); // Build a connectivity matrix neglecting the pbc - nneigh.resize( myatoms.size(), 0 ); - adj_list.resize( myatoms.size(), myatoms.size() ); + nneigh.resize( myatoms.size(), 0 ); adj_list.resize( myatoms.size(), myatoms.size() ); for(unsigned i=1; iareConnected( myatoms[i], myatoms[j] ) ) { - adj_list(i,nneigh[i])=j; - adj_list(j,nneigh[j])=i; - nneigh[i]++; - nneigh[j]++; - } + if( myclusters->areConnected( myatoms[i], myatoms[j] ) ) { adj_list(i,nneigh[i])=j; adj_list(j,nneigh[j])=i; nneigh[i]++; nneigh[j]++; } } } @@ -219,24 +177,18 @@ void OutputCluster::update() { for(unsigned jj=0; jjrcut2 ) { visited[j]=true; - for(unsigned depth=0; depth<=maxdepth; ++depth) { - explore( j, depth ); - } + for(unsigned depth=0; depth<=maxdepth; ++depth) explore( j, depth ); } } } } // And print final positions - for(unsigned i=0; igetPositionOfAtomForLinkCells( myatoms[i] ); @@ -246,21 +198,16 @@ void OutputCluster::update() { } else { ofile.printf("CLUSTERING RESULTS AT TIME %f : NUMBER OF ATOMS IN %u TH LARGEST CLUSTER EQUALS %u \n",getTime(),clustr,static_cast(myatoms.size()) ); ofile.printf("INDICES OF ATOMS : "); - for(unsigned i=0; igetAbsoluteIndexOfCentralAtom(myatoms[i])).index()); - } + for(unsigned i=0; igetAbsoluteIndexOfCentralAtom(myatoms[i])).index()); ofile.printf("\n"); } } void OutputCluster::explore( const unsigned& index, const unsigned& depth ) { - if( depth==0 ) { - return ; - } + if( depth==0 ) return ; for(unsigned i=0; ipbcDistance( atomsin[index], atomsin[j] ); atomsin[j] = atomsin[index] + svec; explore( j, depth-1 ); @@ -271,9 +218,7 @@ bool OutputCluster::explore_dfs( const unsigned& index ) { visited[index]=true; for(unsigned i=0; i& desc ) { for(int i=0; i& vec1, const std::vector& vec2, Vector& dconn, std::vector& dvec1, std::vector& dvec2 ) const { - unsigned nvectors = ( vec1.size() - 2 ) / 3; - plumed_assert( (vec1.size()-2)%3==0 ); - std::vector dv1(nvectors), dv2(nvectors), tdconn(nvectors); - Torsion t; - std::vector v1(nvectors), v2(nvectors); + unsigned nvectors = ( vec1.size() - 2 ) / 3; plumed_assert( (vec1.size()-2)%3==0 ); + std::vector dv1(nvectors), dv2(nvectors), tdconn(nvectors); Torsion t; std::vector v1(nvectors), v2(nvectors); std::vector> pos; - for(unsigned i=0; i() ); - pos[i]->setDomain( "-pi", "pi" ); - } + for(unsigned i=0; i() ); pos[i]->setDomain( "-pi", "pi" ); } for(unsigned j=0; jset( angle ); } - double ans=0; - std::vector deriv( nvectors ), df( nvectors, 0 ); + double ans=0; std::vector deriv( nvectors ), df( nvectors, 0 ); auto pos_ptr=Tools::unique2raw(pos); for(unsigned i=0; ihasDifferentiableOrientation() ) error("cannot use multicolvar of type " + getBaseMultiColvar(i)->getName() ); // } - if( !getAdjacencyVessel()->isSymmetric() ) { - error("input contact matrix is not symmetric"); - } - std::vector fake_atoms; - setupMultiColvarBase( fake_atoms ); + if( !getAdjacencyVessel()->isSymmetric() ) error("input contact matrix is not symmetric"); + std::vector fake_atoms; setupMultiColvarBase( fake_atoms ); // Create all the values sqrtn = std::sqrt( static_cast( getNumberOfNodes() ) ); for(unsigned i=0; iresizeDerivatives( getNumberOfDerivatives() ); @@ -148,9 +145,7 @@ Sprint::Sprint(const ActionOptions&ao): // Setup the dynamic list to hold all the tasks unsigned ntriangle = 0.5*getNumberOfNodes()*(getNumberOfNodes()-1); - for(unsigned i=0; i mymat_ders( getNumberOfComponents(), getNumberOfDerivatives() ); // std::vector catoms(2); - unsigned nval = getNumberOfNodes(); - mymat_ders=0; + unsigned nval = getNumberOfNodes(); mymat_ders=0; for(unsigned i=rank; igetMatrixIndices( active_elements[i], j, k ); + unsigned j, k; getAdjacencyVessel()->getMatrixIndices( active_elements[i], j, k ); double tmp1 = 2 * eigenvecs(nval-1,j)*eigenvecs(nval-1,k); for(int icomp=0; icompaddDerivative( i, mymat_ders(j,i) ); - } + for(unsigned i=0; iaddDerivative( i, mymat_ders(j,i) ); } } diff --git a/src/adjmat/TopologyMatrix.cpp b/src/adjmat/TopologyMatrix.cpp index b537735cd2..07abbd501a 100644 --- a/src/adjmat/TopologyMatrix.cpp +++ b/src/adjmat/TopologyMatrix.cpp @@ -99,29 +99,21 @@ void TopologyMatrix::registerKeywords( Keywords& keys ) { TopologyMatrix::TopologyMatrix( const ActionOptions& ao ): Action(ao), AdjacencyMatrixBase(ao), - maxbins(0) { + maxbins(0) +{ readMaxThreeSpeciesMatrix("NODES", "FAKE", "FAKE", "ATOMS", true ); - unsigned nrows, ncols, ndonor_types; - retrieveTypeDimensions( nrows, ncols, ndonor_types ); - switchingFunction.resize( nrows, ncols ); - parseConnectionDescriptions("SWITCH",false,ndonor_types); - cylinder_sw.resize( nrows, ncols ); - parseConnectionDescriptions("RADIUS",false,ndonor_types); - low_sf.resize( nrows, ncols ); - parseConnectionDescriptions("CYLINDER_SWITCH",false,ndonor_types); - binw_mat.resize( nrows, ncols ); - cell_volume.resize( nrows, ncols ); + unsigned nrows, ncols, ndonor_types; retrieveTypeDimensions( nrows, ncols, ndonor_types ); + switchingFunction.resize( nrows, ncols ); parseConnectionDescriptions("SWITCH",false,ndonor_types); + cylinder_sw.resize( nrows, ncols ); parseConnectionDescriptions("RADIUS",false,ndonor_types); + low_sf.resize( nrows, ncols ); parseConnectionDescriptions("CYLINDER_SWITCH",false,ndonor_types); + binw_mat.resize( nrows, ncols ); cell_volume.resize( nrows, ncols ); parseConnectionDescriptions("BIN_SIZE",false,ndonor_types); // Read in stuff for grid - parse("SIGMA",sigma); - parse("KERNEL",kerneltype); + parse("SIGMA",sigma); parse("KERNEL",kerneltype); // Read in threshold for density cutoff - std::string errors, thresh_sw_str; - parse("DENSITY_THRESHOLD",thresh_sw_str); + std::string errors, thresh_sw_str; parse("DENSITY_THRESHOLD",thresh_sw_str); threshold_switch.set(thresh_sw_str, errors ); - if( errors.length()>0 ) { - error("errors in DENSITY_THRESHOLD switching function : " + errors ); - } + if( errors.length()>0 ) error("errors in DENSITY_THRESHOLD switching function : " + errors ); log.printf(" threshold on density of atoms in cylinder equals %s\n",threshold_switch.description().c_str() ); for(unsigned i=0; isfmax ) { - sfmax=tsf; - } + if( tsf>sfmax ) sfmax=tsf; double rsf=cylinder_sw(i,j).get_dmax(); - if( rsf>rfmax ) { - rfmax=rsf; - } + if( rsf>rfmax ) rfmax=rsf; double lsf=low_sf(i,j).get_dmax(); - if( lsf>lsfmax ) { - lsfmax=lsf; - } + if( lsf>lsfmax ) lsfmax=lsf; } } // Get the width of the bead - HistogramBead bead; - bead.isNotPeriodic(); - bead.setKernelType( kerneltype ); - bead.set( 0.0, 1.0, sigma ); + HistogramBead bead; bead.isNotPeriodic(); + bead.setKernelType( kerneltype ); bead.set( 0.0, 1.0, sigma ); beadrad = bead.getCutoff(); // Set the link cell cutoff @@ -165,9 +149,7 @@ TopologyMatrix::TopologyMatrix( const ActionOptions& ao ): double maxsize=0; for(unsigned i=0; imaxsize ) { - maxsize=binw_mat(i,j); - } + if( binw_mat(i,j)>maxsize ) maxsize=binw_mat(i,j); } } // Set the maximum number of bins that we will need to compute @@ -184,85 +166,55 @@ unsigned TopologyMatrix::getNumberOfQuantities() const { void TopologyMatrix::setupConnector( const unsigned& id, const unsigned& i, const unsigned& j, const std::vector& desc ) { plumed_assert( id<4 ); if( id==0 ) { - std::string errors; - switchingFunction(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i) { - switchingFunction(i,j).set(desc[0],errors); - } + std::string errors; switchingFunction(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i) switchingFunction(i,j).set(desc[0],errors); log.printf(" %u th and %u th multicolvar groups must be within %s\n",i+1,j+1,(switchingFunction(i,j).description()).c_str() ); } else if( id==1 ) { - std::string errors; - cylinder_sw(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i) { - cylinder_sw(i,j).set(desc[0],errors); - } + std::string errors; cylinder_sw(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i) cylinder_sw(i,j).set(desc[0],errors); log.printf(" there must be not atoms within the cylinder connections atoms of multicolvar groups %u th and %u th. This cylinder has radius %s \n",i+1,j+1,(cylinder_sw(i,j).description()).c_str() ); } else if( id==2 ) { - std::string errors; - low_sf(j,i).set(desc[0],errors); - if( errors.length()!=0 ) { - error("problem reading switching function description " + errors); - } - if( j!=i ) { - low_sf(i,j).set(desc[0],errors); - } + std::string errors; low_sf(j,i).set(desc[0],errors); + if( errors.length()!=0 ) error("problem reading switching function description " + errors); + if( j!=i ) low_sf(i,j).set(desc[0],errors); log.printf(" %u th and %u th multicolvar groups must be further apart than %s\n",i+1,j+1,(low_sf(j,i).description()).c_str() ); } else if( id==3 ) { Tools::convert( desc[0], binw_mat(j,i) ); - if( i!=j ) { - binw_mat(i,j)=binw_mat(j,i); - } + if( i!=j ) binw_mat(i,j)=binw_mat(j,i); log.printf(" cylinder for %u th and %u th multicolvar groups is split into bins of length %f \n",i,j,binw_mat(i,j) ); } } double TopologyMatrix::calculateWeight( const unsigned& taskCode, const double& weight, multicolvar::AtomValuePack& myatoms ) const { Vector distance = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - if( distance.modulo2() binvals( 1+maxbins ); for(unsigned i=1;imax ) { - max=myatoms.getValue(i); - vout=i; - } + if( myatoms.getValue(i)>max ) { max=myatoms.getValue(i); vout=i; } } // Calculate value and derivative of switching function between atoms 1 and 2 double dfuncl, sw = switchingFunction( getBaseColvarNumber( myatoms.getIndex(0) ), @@ -296,16 +248,12 @@ void TopologyMatrix::calculateForThreeAtoms( const unsigned& iat, const Vector& // This tells us if we are outside the end of the cylinder double excess = proj - d1_len; // Return if we are outside of the cylinder as calculated based on excess - if( excess>low_sf( getBaseColvarNumber( myatoms.getIndex(0) ), getBaseColvarNumber( myatoms.getIndex(1) ) ).get_dmax() ) { - return; - } + if( excess>low_sf( getBaseColvarNumber( myatoms.getIndex(0) ), getBaseColvarNumber( myatoms.getIndex(1) ) ).get_dmax() ) return; // Find the length of the cylinder double binw = binw_mat( getBaseColvarNumber( myatoms.getIndex(0) ), getBaseColvarNumber( myatoms.getIndex(1) ) ); double lcylinder = (std::floor( d1_len / binw ) + 1)*binw; // Return if the projection is outside the length of interest - if( proj<-bead.getCutoff() || proj>(lcylinder+bead.getCutoff()) ) { - return; - } + if( proj<-bead.getCutoff() || proj>(lcylinder+bead.getCutoff()) ) return; // Calculate the excess swiching function double edf, eval = low_sf( getBaseColvarNumber( myatoms.getIndex(0) ), getBaseColvarNumber( myatoms.getIndex(1) ) ).calculate( excess, edf ); @@ -349,15 +297,11 @@ void TopologyMatrix::calculateForThreeAtoms( const unsigned& iat, const Vector& Vector pos1 = myatoms.getPosition(0) + d1_len*d1; Vector pos2 = myatoms.getPosition(0) + d2; - Vector g1derivf,g2derivf,lderivf; - Tensor vir; + Vector g1derivf,g2derivf,lderivf; Tensor vir; for(unsigned bin=0; binbinw*(bin+1)+bead.getCutoff() ) { - continue; - } - double der, contr=bead.calculateWithCutoff( proj, der ) / cellv; - der /= cellv; + if( proj<(bin*binw-bead.getCutoff()) || proj>binw*(bin+1)+bead.getCutoff() ) continue; + double der, contr=bead.calculateWithCutoff( proj, der ) / cellv; der /= cellv; myatoms.addValue( 2+bin, contr*val*eval ); if( !doNotCalculateDerivatives() ) { diff --git a/src/analysis/AnalysisBase.cpp b/src/analysis/AnalysisBase.cpp index af78327f32..f283e4dd0d 100644 --- a/src/analysis/AnalysisBase.cpp +++ b/src/analysis/AnalysisBase.cpp @@ -28,16 +28,10 @@ namespace PLMD { namespace analysis { void AnalysisBase::registerKeywords( Keywords& keys ) { - Action::registerKeywords( keys ); - ActionPilot::registerKeywords( keys ); - ActionWithValue::registerKeywords( keys ); - ActionAtomistic::registerKeywords( keys ); - ActionWithArguments::registerKeywords( keys ); - keys.remove("NUMERICAL_DERIVATIVES"); - ActionWithVessel::registerKeywords( keys ); - keys.remove("TOL"); - keys.reset_style("TIMINGS","hidden"); - keys.isAnalysis(); + Action::registerKeywords( keys ); ActionPilot::registerKeywords( keys ); + ActionWithValue::registerKeywords( keys ); ActionAtomistic::registerKeywords( keys ); + ActionWithArguments::registerKeywords( keys ); keys.remove("NUMERICAL_DERIVATIVES"); + ActionWithVessel::registerKeywords( keys ); keys.remove("TOL"); keys.reset_style("TIMINGS","hidden"); keys.isAnalysis(); keys.add("atoms-2","USE_OUTPUT_DATA_FROM","use the output of the analysis performed by this object as input to your new analysis object"); } @@ -48,20 +42,16 @@ AnalysisBase::AnalysisBase(const ActionOptions&ao): ActionAtomistic(ao), ActionWithArguments(ao), ActionWithVessel(ao), - my_input_data(NULL) { + my_input_data(NULL) +{ // We have an if statement here so that this doesn't break with READ_DISSIMILARITIES if( keywords.exists("USE_OUTPUT_DATA_FROM") ) { - std::string datastr; - parse("USE_OUTPUT_DATA_FROM",datastr); - if( keywords.style("USE_OUTPUT_DATA_FROM","atoms") && datastr.length()==0 ) { - error("input analysis action was not specified use USE_OUTPUT_DATA_FROM"); - } + std::string datastr; parse("USE_OUTPUT_DATA_FROM",datastr); + if( keywords.style("USE_OUTPUT_DATA_FROM","atoms") && datastr.length()==0 ) error("input analysis action was not specified use USE_OUTPUT_DATA_FROM"); if( datastr.length()>0 ) { my_input_data=plumed.getActionSet().selectWithLabel( datastr ); log.printf(" performing analysis on output from %s \n",datastr.c_str() ); - if( !my_input_data ) { - error("could not find analysis action named " + datastr ); - } + if( !my_input_data ) error("could not find analysis action named " + datastr ); addDependency( my_input_data ); } } @@ -78,17 +68,13 @@ std::vector AnalysisBase::getArgumentNames() { } void AnalysisBase::update() { - if( getStep()==0 || ( getStride()>0 && !onStep() ) ) { - return; - } + if( getStep()==0 || ( getStride()>0 && !onStep() ) ) return; // And do the analysis performAnalysis(); } void AnalysisBase::runFinalJobs() { - if( getStride()>0 ) { - return; - } + if( getStride()>0 ) return; performAnalysis(); } diff --git a/src/analysis/AnalysisBase.h b/src/analysis/AnalysisBase.h index 3f4f1bd5d7..db41daf97b 100644 --- a/src/analysis/AnalysisBase.h +++ b/src/analysis/AnalysisBase.h @@ -47,7 +47,8 @@ class AnalysisBase : public ActionWithValue, public ActionAtomistic, public ActionWithArguments, - public vesselbase::ActionWithVessel { + public vesselbase::ActionWithVessel +{ friend class ReselectLandmarks; friend class ReadDissimilarityMatrix; protected: @@ -88,15 +89,9 @@ class AnalysisBase : /// This actually performs the analysis virtual void performAnalysis()=0; /// These overwrite things from inherited classes (this is a bit of a fudge) - bool isPeriodic() override { - plumed_error(); - } - unsigned getNumberOfDerivatives() override { - plumed_error(); - } - void calculateNumericalDerivatives( ActionWithValue* a=NULL ) override { - plumed_error(); - } + bool isPeriodic() override { plumed_error(); } + unsigned getNumberOfDerivatives() override { plumed_error(); } + void calculateNumericalDerivatives( ActionWithValue* a=NULL ) override { plumed_error(); } /// Calculate and apply do nothing all analysis is done during update step void calculate() override {} void apply() override {} diff --git a/src/analysis/Average.cpp b/src/analysis/Average.cpp index 824984200a..436bb2f6ad 100644 --- a/src/analysis/Average.cpp +++ b/src/analysis/Average.cpp @@ -99,44 +99,34 @@ class Average : public vesselbase::ActionWithAveraging { void apply() override {} void performOperations( const bool& from_update ) override; void finishAveraging() override; - bool isPeriodic() override { - return false; - } - void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { - plumed_error(); - } + bool isPeriodic() override { return false; } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { plumed_error(); } void accumulateAverage( MultiValue& myvals ) const override; }; PLUMED_REGISTER_ACTION(Average,"AVERAGE") void Average::registerKeywords( Keywords& keys ) { - vesselbase::ActionWithAveraging::registerKeywords( keys ); - keys.use("ARG"); - keys.remove("SERIAL"); - keys.remove("LOWMEM"); + vesselbase::ActionWithAveraging::registerKeywords( keys ); keys.use("ARG"); + keys.remove("SERIAL"); keys.remove("LOWMEM"); } Average::Average( const ActionOptions& ao ): Action(ao), - ActionWithAveraging(ao) { + ActionWithAveraging(ao) +{ addValue(); // Create a value so that we can output the average - if( getNumberOfArguments()!=1 ) { - error("only one quantity can be averaged at a time"); - } + if( getNumberOfArguments()!=1 ) error("only one quantity can be averaged at a time"); std::string instring; if( getPntrToArgument(0)->isPeriodic() ) { - std::string min, max; - getPntrToArgument(0)->getDomain(min,max); - instring = "PERIODIC=" + min + "," + max; - setPeriodic( min, max ); + std::string min, max; getPntrToArgument(0)->getDomain(min,max); + instring = "PERIODIC=" + min + "," + max; setPeriodic( min, max ); } else { setNotPeriodic(); } // Create a vessel to hold the average vesselbase::VesselOptions da("myaverage","",-1,instring,this); - Keywords keys; - AverageVessel::registerKeywords( keys ); + Keywords keys; AverageVessel::registerKeywords( keys ); vesselbase::VesselOptions dar( da, keys ); auto average=Tools::make_unique(dar); myaverage = average.get(); diff --git a/src/analysis/AverageVessel.cpp b/src/analysis/AverageVessel.cpp index 1bb244f656..18e543689d 100644 --- a/src/analysis/AverageVessel.cpp +++ b/src/analysis/AverageVessel.cpp @@ -30,35 +30,28 @@ void AverageVessel::registerKeywords( Keywords& keys ) { } AverageVessel::AverageVessel( const vesselbase::VesselOptions& da): - AveragingVessel(da) { + AveragingVessel(da) +{ parseVector("PERIODIC",domain); plumed_assert( domain.size()==2 || domain.size()==0 ); } void AverageVessel::resize() { resizeBuffer(0); - if( domain.size()==2 ) { - setDataSize(2); - } else { - setDataSize(1); - } + if( domain.size()==2 ) setDataSize(2); + else setDataSize(1); } void AverageVessel::accumulate( const double& weight, const double& val ) { if( domain.size()==2 ) { // Average with Berry Phase double tval = 2*pi*( val - domain[0] ) / ( domain[1] - domain[0] ); - addDataElement( 0, weight*std::sin(tval) ); - addDataElement( 1, weight*std::cos(tval) ); - } else { - addDataElement( 0, weight*val ); - } + addDataElement( 0, weight*std::sin(tval) ); addDataElement( 1, weight*std::cos(tval) ); + } else addDataElement( 0, weight*val ); } double AverageVessel::getAverage() const { - if( domain.size()==2 ) { - return domain[0] + (( domain[1] - domain[0] )*std::atan2( getDataElement(0), getDataElement(1) ) / (2*pi)); - } + if( domain.size()==2 ) return domain[0] + (( domain[1] - domain[0] )*std::atan2( getDataElement(0), getDataElement(1) ) / (2*pi)); return getDataElement(0); } diff --git a/src/analysis/AverageVessel.h b/src/analysis/AverageVessel.h index c6e71674cc..304cb39246 100644 --- a/src/analysis/AverageVessel.h +++ b/src/analysis/AverageVessel.h @@ -39,9 +39,7 @@ class AverageVessel : public vesselbase::AveragingVessel { void resize() override; /// This does nothing void calculate( const unsigned& current, MultiValue& myvals, std::vector& buffer, std::vector& der_list ) const override; - std::string description() override { - return ""; - } + std::string description() override { return ""; } /// Accumulate the average void accumulate( const double& weight, const double& val ); /// Get the average value diff --git a/src/analysis/Committor.cpp b/src/analysis/Committor.cpp index 04447577b5..5c65db67d8 100644 --- a/src/analysis/Committor.cpp +++ b/src/analysis/Committor.cpp @@ -56,7 +56,8 @@ COMMITTOR ... class Committor : public ActionPilot, - public ActionWithArguments { + public ActionWithArguments +{ private: std::string file; OFile ofile; @@ -82,8 +83,7 @@ void Committor::registerKeywords( Keywords& keys ) { keys.use("ARG"); keys.add("numbered", "BASIN_LL","List of lower limits for basin #"); keys.add("numbered", "BASIN_UL","List of upper limits for basin #"); - keys.reset_style("BASIN_LL","compulsory"); - keys.reset_style("BASIN_UL","compulsory"); + keys.reset_style("BASIN_LL","compulsory"); keys.reset_style("BASIN_UL","compulsory"); keys.add("compulsory","STRIDE","1","the frequency with which the CVs are analyzed"); keys.add("optional","FILE","the name of the file on which to output the reached basin"); keys.add("optional","FMT","the format that should be used to output real numbers"); @@ -96,7 +96,8 @@ Committor::Committor(const ActionOptions&ao): ActionWithArguments(ao), fmt("%f"), basin(0), - doNotStop(false) { + doNotStop(false) +{ ofile.link(*this); parse("FILE",file); if(file.length()>0) { @@ -114,15 +115,9 @@ Committor::Committor(const ActionOptions&ao): std::vector tmpl, tmpu; parseNumberedVector("BASIN_LL", b, tmpl ); parseNumberedVector("BASIN_UL", b, tmpu ); - if( tmpl.empty() && tmpu.empty() ) { - break; - } - if( tmpl.size()!=getNumberOfArguments()) { - error("Wrong number of values for BASIN_LL: they should be equal to the number of arguments"); - } - if( tmpu.size()!=getNumberOfArguments()) { - error("Wrong number of values for BASIN_UL: they should be equal to the number of arguments"); - } + if( tmpl.empty() && tmpu.empty() ) break; + if( tmpl.size()!=getNumberOfArguments()) error("Wrong number of values for BASIN_LL: they should be equal to the number of arguments"); + if( tmpu.size()!=getNumberOfArguments()) error("Wrong number of values for BASIN_UL: they should be equal to the number of arguments"); lowerlimits.push_back(tmpl); upperlimits.push_back(tmpu); nbasins=b; @@ -136,19 +131,13 @@ Committor::Committor(const ActionOptions&ao): for(unsigned b=0; bupperlimits[b][i]) { - error("COMMITTOR: UPPER bounds must always be greater than LOWER bounds"); - } + if(lowerlimits[b][i]>upperlimits[b][i]) error("COMMITTOR: UPPER bounds must always be greater than LOWER bounds"); log.printf(" %f - %f\n", lowerlimits[b][i], upperlimits[b][i]); } - if(doNotStop) { - log.printf(" COMMITOR will keep track of the visited basins without stopping the simulations\n"); - } + if(doNotStop) log.printf(" COMMITOR will keep track of the visited basins without stopping the simulations\n"); } - for(unsigned i=0; i& ind, const std::vector& arg_names ) { - myaction=action_label; - indices.resize( ind.size() ); - positions.resize( indices.size() ); - for(unsigned i=0; i( arg_names[i], 0.0 ) ); - } + myaction=action_label; indices.resize( ind.size() ); positions.resize( indices.size() ); + for(unsigned i=0; i( arg_names[i], 0.0 ) ); } void DataCollectionObject::setAtomPositions( const std::vector& pos ) { plumed_dbg_assert( pos.size()==positions.size() && pos.size()==indices.size() ); - for(unsigned i=0; i::iterator it = args.find(name); - if( it!=args.end() ) { - it->second = value; - } else { - args.insert( std::pair( name, value ) ); - } + if( it!=args.end() ) it->second = value; + else args.insert( std::pair( name, value ) ); } bool DataCollectionObject::transferDataToPDB( PDB& mypdb ) { @@ -60,18 +49,13 @@ bool DataCollectionObject::transferDataToPDB( PDB& mypdb ) { std::map::iterator it; for(unsigned i=0; isecond ); } // Now set the atomic positions std::vector pdb_pos( mypdb.getAtomNumbers() ); - if( pdb_pos.size()==positions.size() ) { - mypdb.setAtomPositions( positions ); - } else if( pdb_pos.size()>0 ) { - plumed_merror("This feature is currently not ready"); - } + if( pdb_pos.size()==positions.size() ) mypdb.setAtomPositions( positions ); + else if( pdb_pos.size()>0 ) plumed_merror("This feature is currently not ready"); return true; } diff --git a/src/analysis/DataCollectionObject.h b/src/analysis/DataCollectionObject.h index 10fa8b9fd5..2828ba9b10 100644 --- a/src/analysis/DataCollectionObject.h +++ b/src/analysis/DataCollectionObject.h @@ -67,16 +67,10 @@ Vector DataCollectionObject::getAtomPosition( const AtomNumber& ind ) const { inline double DataCollectionObject::getArgumentValue( const std::string& name ) const { std::map::const_iterator it = args.find(name); - if( it != args.end() ) { - return it->second; - } - std::size_t dot=name.find_first_of('.'); - std::string a=name.substr(0,dot); - if( a==myaction ) { - return args.find( name.substr(dot+1) )->second; - } else { - plumed_merror("could not find required data in collection object"); - } + if( it != args.end() ) return it->second; + std::size_t dot=name.find_first_of('.'); std::string a=name.substr(0,dot); + if( a==myaction ) return args.find( name.substr(dot+1) )->second; + else plumed_merror("could not find required data in collection object"); } } diff --git a/src/analysis/EuclideanDissimilarityMatrix.cpp b/src/analysis/EuclideanDissimilarityMatrix.cpp index 5b4514c1ab..fff6bf51b5 100644 --- a/src/analysis/EuclideanDissimilarityMatrix.cpp +++ b/src/analysis/EuclideanDissimilarityMatrix.cpp @@ -48,34 +48,28 @@ class EuclideanDissimilarityMatrix : public AnalysisBase { /// Do the analysis void performAnalysis() override; /// This ensures that classes that use this data know that dissimilarities were set - bool dissimilaritiesWereSet() const override { - return true; - } + bool dissimilaritiesWereSet() const override { return true; } /// Get information on how to calculate dissimilarities std::string getDissimilarityInstruction() const override; /// Get the squared dissimilarity between two reference configurations double getDissimilarity( const unsigned& i, const unsigned& j ) override; /// This is just to deal with ActionWithVessel - void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { plumed_error(); } }; PLUMED_REGISTER_ACTION(EuclideanDissimilarityMatrix,"EUCLIDEAN_DISSIMILARITIES") void EuclideanDissimilarityMatrix::registerKeywords( Keywords& keys ) { - AnalysisBase::registerKeywords( keys ); - keys.use("ARG"); - keys.reset_style("ARG","optional"); + AnalysisBase::registerKeywords( keys ); keys.use("ARG"); keys.reset_style("ARG","optional"); keys.add("compulsory","METRIC","EUCLIDEAN","the method that you are going to use to measure the distances between points"); keys.add("atoms","ATOMS","the list of atoms that you are going to use in the measure of distance that you are using"); } EuclideanDissimilarityMatrix::EuclideanDissimilarityMatrix( const ActionOptions& ao ): Action(ao), - AnalysisBase(ao) { - parse("METRIC",mtype); - std::vector atoms; + AnalysisBase(ao) +{ + parse("METRIC",mtype); std::vector atoms; if( my_input_data->getNumberOfAtoms()>0 ) { parseAtomList("ATOMS",atoms); if( atoms.size()!=0 ) { @@ -83,14 +77,10 @@ EuclideanDissimilarityMatrix::EuclideanDissimilarityMatrix( const ActionOptions& for(unsigned i=0; igetAtomIndexes().size(); ++j) { - if( my_input_data->getAtomIndexes()[j]==atoms[i] ) { - found=true; - break; - } + if( my_input_data->getAtomIndexes()[j]==atoms[i] ) { found=true; break; } } if( !found ) { - std::string num; - Tools::convert( atoms[i].serial(), num ); + std::string num; Tools::convert( atoms[i].serial(), num ); error("atom number " + num + " is not stored in any action that has been input"); } } @@ -98,17 +88,14 @@ EuclideanDissimilarityMatrix::EuclideanDissimilarityMatrix( const ActionOptions& } else if( getNumberOfArguments()==0 ) { mypdb.setAtomNumbers( my_input_data->getAtomIndexes() ); mypdb.addBlockEnd( my_input_data->getAtomIndexes().size() ); - if( mtype=="EUCLIDEAN" ) { - mtype="OPTIMAL"; - } + if( mtype=="EUCLIDEAN" ) mtype="OPTIMAL"; } } log.printf(" measuring distances using %s metric \n",mtype.c_str() ); if( my_input_data->getArgumentNames().size()>0 ) { if( getNumberOfArguments()==0 && atoms.size()==0 ) { std::vector argnames( my_input_data->getArgumentNames() ); - mypdb.setArgumentNames( argnames ); - requestArguments( my_input_data->getArgumentList() ); + mypdb.setArgumentNames( argnames ); requestArguments( my_input_data->getArgumentList() ); } else { std::vector myargs( getArguments() ); std::vector inargnames( my_input_data->getArgumentNames() ); @@ -117,17 +104,11 @@ EuclideanDissimilarityMatrix::EuclideanDissimilarityMatrix( const ActionOptions& argnames[i]=myargs[i]->getName(); bool found=false; for(unsigned j=0; jgetLabel() + " does not store/calculate quantity named " + argnames[i] ); + if( argnames[i]==inargnames[j] ) { found=true; break; } } + if( !found ) error("input named " + my_input_data->getLabel() + " does not store/calculate quantity named " + argnames[i] ); } - mypdb.setArgumentNames( argnames ); - requestArguments( myargs ); + mypdb.setArgumentNames( argnames ); requestArguments( myargs ); } } } @@ -135,8 +116,7 @@ EuclideanDissimilarityMatrix::EuclideanDissimilarityMatrix( const ActionOptions& void EuclideanDissimilarityMatrix::performAnalysis() { // Resize dissimilarities matrix and set all elements to zero if( !usingLowMem() ) { - dissimilarities.resize( getNumberOfDataPoints(), getNumberOfDataPoints() ); - dissimilarities=0; + dissimilarities.resize( getNumberOfDataPoints(), getNumberOfDataPoints() ); dissimilarities=0; } } @@ -147,9 +127,7 @@ std::string EuclideanDissimilarityMatrix::getDissimilarityInstruction() const { double EuclideanDissimilarityMatrix::getDissimilarity( const unsigned& iframe, const unsigned& jframe ) { plumed_dbg_assert( iframe0. ) { - return dissimilarities(iframe,jframe); - } + if( dissimilarities(iframe,jframe)>0. ) { return dissimilarities(iframe,jframe); } } if( iframe!=jframe ) { double dd; @@ -157,11 +135,8 @@ double EuclideanDissimilarityMatrix::getDissimilarity( const unsigned& iframe, c auto myref1=metricRegister().create(mtype, mypdb); getStoredData( jframe, true ).transferDataToPDB( mypdb ); auto myref2=metricRegister().create(mtype, mypdb); - if( !usingLowMem() ) { - dd=dissimilarities(iframe,jframe) = dissimilarities(jframe,iframe) = distance( getPbc(), getArguments(), myref1.get(), myref2.get(), true ); - } else { - dd=distance( getPbc(), getArguments(), myref1.get(), myref2.get(), true ); - } + if( !usingLowMem() ) dd=dissimilarities(iframe,jframe) = dissimilarities(jframe,iframe) = distance( getPbc(), getArguments(), myref1.get(), myref2.get(), true ); + else dd=distance( getPbc(), getArguments(), myref1.get(), myref2.get(), true ); return dd; } return 0.0; diff --git a/src/analysis/FarthestPointSampling.cpp b/src/analysis/FarthestPointSampling.cpp index fdb664ce45..80bbce30e6 100644 --- a/src/analysis/FarthestPointSampling.cpp +++ b/src/analysis/FarthestPointSampling.cpp @@ -53,10 +53,9 @@ void FarthestPointSampling::registerKeywords( Keywords& keys ) { FarthestPointSampling::FarthestPointSampling( const ActionOptions& ao ): Action(ao), - LandmarkSelectionBase(ao) { - if( !dissimilaritiesWereSet() ) { - error("dissimilarities have not been calcualted in input action"); - } + LandmarkSelectionBase(ao) +{ + if( !dissimilaritiesWereSet() ) error("dissimilarities have not been calcualted in input action"); parse("SEED",seed); } @@ -64,17 +63,13 @@ void FarthestPointSampling::selectLandmarks() { std::vector landmarks( getNumberOfDataPoints() ); // Select first point at random - Random random; - random.setSeed(-seed); - double rand=random.RandU01(); + Random random; random.setSeed(-seed); double rand=random.RandU01(); landmarks[0] = std::floor( my_input_data->getNumberOfDataPoints()*rand ); selectFrame( landmarks[0] ); // Now find distance to all other points (N.B. We can use squared distances here for speed) Matrix distances( getNumberOfDataPoints(), my_input_data->getNumberOfDataPoints() ); - for(unsigned i=0; igetNumberOfDataPoints(); ++i) { - distances(0,i) = my_input_data->getDissimilarity( landmarks[0], i ); - } + for(unsigned i=0; igetNumberOfDataPoints(); ++i) distances(0,i) = my_input_data->getDissimilarity( landmarks[0], i ); // Now find all other landmarks for(unsigned i=1; igetNumberOfDataPoints(); ++j) { double mind=distances(0,j); for(unsigned k=1; kmaxd ) { - maxd=mind; - landmarks[i]=j; + if( distances(k,j)maxd ) { maxd=mind; landmarks[i]=j; } } selectFrame( landmarks[i] ); - for(unsigned k=0; kgetNumberOfDataPoints(); ++k) { - distances(i,k) = my_input_data->getDissimilarity( landmarks[i], k ); - } + for(unsigned k=0; kgetNumberOfDataPoints(); ++k) distances(i,k) = my_input_data->getDissimilarity( landmarks[i], k ); } } diff --git a/src/analysis/Histogram.cpp b/src/analysis/Histogram.cpp index e6875f2c57..e13b905bad 100644 --- a/src/analysis/Histogram.cpp +++ b/src/analysis/Histogram.cpp @@ -212,12 +212,8 @@ class Histogram : public gridtools::ActionWithGrid { void prepareForAveraging() override; void performOperations( const bool& from_update ) override; void finishAveraging() override; - bool threadSafe() const override { - return !in_apply; - } - bool isPeriodic() override { - return false; - } + bool threadSafe() const override { return !in_apply; } + bool isPeriodic() override { return false; } unsigned getNumberOfDerivatives() override; void turnOnDerivatives() override; void compute( const unsigned&, MultiValue& ) const override; @@ -227,9 +223,7 @@ class Histogram : public gridtools::ActionWithGrid { PLUMED_REGISTER_ACTION(Histogram,"HISTOGRAM") void Histogram::registerKeywords( Keywords& keys ) { - gridtools::ActionWithGrid::registerKeywords( keys ); - keys.use("ARG"); - keys.remove("NORMALIZATION"); + gridtools::ActionWithGrid::registerKeywords( keys ); keys.use("ARG"); keys.remove("NORMALIZATION"); keys.add("compulsory","NORMALIZATION","ndata","This controls how the data is normalized it can be set equal to true, false or ndata. See above for an explanation"); keys.add("optional","DATA","input data from action with vessel and compute histogram"); keys.add("optional","VECTORS","input three dimensional vectors for computing histogram"); @@ -237,8 +231,7 @@ void Histogram::registerKeywords( Keywords& keys ) { keys.add("compulsory","GRID_MAX","the upper bounds for the grid"); keys.add("optional","GRID_BIN","the number of bins for the grid"); keys.add("optional","GRID_SPACING","the approximate grid spacing (to be used as an alternative or together with GRID_BIN)"); - keys.use("UPDATE_FROM"); - keys.use("UPDATE_UNTIL"); + keys.use("UPDATE_FROM"); keys.use("UPDATE_UNTIL"); } Histogram::Histogram(const ActionOptions&ao): @@ -246,49 +239,35 @@ Histogram::Histogram(const ActionOptions&ao): ActionWithGrid(ao), ww(0.0), in_apply(false), - mvectors(false) { + mvectors(false) +{ // Read in arguments if( getNumberOfArguments()==0 ) { - std::string vlab; - parse("VECTORS",vlab); + std::string vlab; parse("VECTORS",vlab); if( vlab.length()>0 ) { ActionWithVessel* myv = plumed.getActionSet().selectWithLabel( vlab ); - if( !myv ) { - error("action labelled " + vlab + " does not exist or is not an ActionWithVessel"); - } - myvessels.push_back( myv ); - stashes.push_back( myv->buildDataStashes( NULL ) ); - addDependency( myv ); - mvectors=true; - if( myv->getNumberOfQuantities()!=5 ) { - error("can only compute histograms for three dimensional vectors"); - } + if( !myv ) error("action labelled " + vlab + " does not exist or is not an ActionWithVessel"); + myvessels.push_back( myv ); stashes.push_back( myv->buildDataStashes( NULL ) ); + addDependency( myv ); mvectors=true; + if( myv->getNumberOfQuantities()!=5 ) error("can only compute histograms for three dimensional vectors"); log.printf(" for vector quantities calculated by %s \n", vlab.c_str() ); } else { - std::vector mlab; - parseVector("DATA",mlab); + std::vector mlab; parseVector("DATA",mlab); if( mlab.size()>0 ) { for(unsigned i=0; i( mlab[i] ); - if( !myv ) { - error("action labelled " + mlab[i] + " does not exist or is not an ActionWithVessel"); - } - myvessels.push_back( myv ); - stashes.push_back( myv->buildDataStashes( NULL ) ); + if( !myv ) error("action labelled " + mlab[i] + " does not exist or is not an ActionWithVessel"); + myvessels.push_back( myv ); stashes.push_back( myv->buildDataStashes( NULL ) ); // log.printf(" for all base quantities calculated by %s \n",myvessel->getLabel().c_str() ); // Add the dependency addDependency( myv ); } unsigned nvals = myvessels[0]->getFullNumberOfTasks(); for(unsigned i=1; igetFullNumberOfTasks() ) { - error("mismatched number of quantities calculated by actions input to histogram"); - } + if( nvals!=myvessels[i]->getFullNumberOfTasks() ) error("mismatched number of quantities calculated by actions input to histogram"); } log.printf(" for all base quantities calculated by %s ", myvessels[0]->getLabel().c_str() ); - for(unsigned i=1; igetLabel().c_str() ); - } + for(unsigned i=1; igetLabel().c_str() ); log.printf("\n"); } else { error("input data is missing use ARG/VECTORS/DATA"); @@ -298,93 +277,61 @@ Histogram::Histogram(const ActionOptions&ao): // Read stuff for grid unsigned narg = getNumberOfArguments(); - if( myvessels.size()>0 ) { - narg=myvessels.size(); - } + if( myvessels.size()>0 ) narg=myvessels.size(); // Input of name and labels std::string vstring="COMPONENTS=" + getLabel(); if( mvectors ) { vstring += " COORDINATES=x,y,z PBC=F,F,F"; } else if( myvessels.size()>0 ) { vstring += " COORDINATES=" + myvessels[0]->getLabel(); - for(unsigned i=1; igetLabel(); - } + for(unsigned i=1; igetLabel(); // Input for PBC - if( myvessels[0]->isPeriodic() ) { - vstring+=" PBC=T"; - } else { - vstring+=" PBC=F"; - } + if( myvessels[0]->isPeriodic() ) vstring+=" PBC=T"; + else vstring+=" PBC=F"; for(unsigned i=1; iisPeriodic() ) { - vstring+=",T"; - } else { - vstring+=",F"; - } + if( myvessels[i]->isPeriodic() ) vstring+=",T"; + else vstring+=",F"; } } else { vstring += " COORDINATES=" + getPntrToArgument(0)->getName(); - for(unsigned i=1; igetName(); - } + for(unsigned i=1; igetName(); // Input for PBC - if( getPntrToArgument(0)->isPeriodic() ) { - vstring+=" PBC=T"; - } else { - vstring+=" PBC=F"; - } + if( getPntrToArgument(0)->isPeriodic() ) vstring+=" PBC=T"; + else vstring+=" PBC=F"; for(unsigned i=1; iisPeriodic() ) { - vstring+=",T"; - } else { - vstring+=",F"; - } + if( getPntrToArgument(i)->isPeriodic() ) vstring+=",T"; + else vstring+=",F"; } } // And create the grid auto grid=createGrid( "histogram", vstring ); // notice that createGrid also sets mygrid=grid.get() if( mygrid->getType()=="flat" ) { - if( mvectors ) { - error("computing histogram for three dimensional vectors but grid is not of fibonacci type - use CONCENTRATION"); - } + if( mvectors ) error("computing histogram for three dimensional vectors but grid is not of fibonacci type - use CONCENTRATION"); std::vector gmin( narg ), gmax( narg ); - parseVector("GRID_MIN",gmin); - parseVector("GRID_MAX",gmax); - std::vector nbin; - parseVector("GRID_BIN",nbin); - std::vector gspacing; - parseVector("GRID_SPACING",gspacing); + parseVector("GRID_MIN",gmin); parseVector("GRID_MAX",gmax); + std::vector nbin; parseVector("GRID_BIN",nbin); + std::vector gspacing; parseVector("GRID_SPACING",gspacing); if( nbin.size()!=narg && gspacing.size()!=narg ) { error("GRID_BIN or GRID_SPACING must be set"); } mygrid->setBounds( gmin, gmax, nbin, gspacing ); } else { - std::vector nbin; - parseVector("GRID_BIN",nbin); - if( nbin.size()!=1 ) { - error("should only be one index for number of bins with spherical grid"); - } - if( mygrid->getType()=="fibonacci" ) { - mygrid->setupFibonacciGrid( nbin[0] ); - } + std::vector nbin; parseVector("GRID_BIN",nbin); + if( nbin.size()!=1 ) error("should only be one index for number of bins with spherical grid"); + if( mygrid->getType()=="fibonacci" ) mygrid->setupFibonacciGrid( nbin[0] ); } myhist = dynamic_cast( mygrid ); plumed_assert( myhist ); if( myvessels.size()>0 ) { // Create a task list - for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetFullNumberOfTasks(); ++i) addTaskToList(i); setAveragingAction( std::move(grid), true ); } else if( storeThenAverage() ) { setAveragingAction( std::move(grid), true ); } else { // Create a task list - for(unsigned i=0; igetNumberOfPoints(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetNumberOfPoints(); ++i) addTaskToList(i); myhist->addOneKernelEachTimeOnly(); setAveragingAction( std::move(grid), myhist->noDiscreteKernels() ); } @@ -396,13 +343,9 @@ void Histogram::turnOnDerivatives() { std::vector all_atoms, tmp_atoms; for(unsigned i=0; i( myvessels[i] ); - if( !mbase ) { - error("do not know how to get histogram derivatives for actions of type " + myvessels[i]->getName() ); - } + if( !mbase ) error("do not know how to get histogram derivatives for actions of type " + myvessels[i]->getName() ); tmp_atoms = mbase->getAbsoluteIndexes(); - for(unsigned j=0; jresizeTemporyMultiValues( 1 ); } @@ -410,80 +353,55 @@ void Histogram::turnOnDerivatives() { finalForces.resize( 3*all_atoms.size() + 9 ); forcesToApply.resize( 3*all_atoms.size() + 9*myvessels.size() ); // And make sure we still have the dependencies which are cleared by requestAtoms - for(unsigned i=0; iresize(); - in_apply=false; + in_apply=true; mygrid->resize(); in_apply=false; } unsigned Histogram::getNumberOfDerivatives() { if( in_apply ) { unsigned nder=0; - for(unsigned i=0; igetNumberOfDerivatives(); - } + for(unsigned i=0; igetNumberOfDerivatives(); return nder; } return getNumberOfArguments(); } unsigned Histogram::getNumberOfQuantities() const { - if( mvectors ) { - return myvessels[0]->getNumberOfQuantities(); - } else if( myvessels.size()>0 ) { - return myvessels.size()+2; - } + if( mvectors ) return myvessels[0]->getNumberOfQuantities(); + else if( myvessels.size()>0 ) return myvessels.size()+2; return ActionWithAveraging::getNumberOfQuantities(); } void Histogram::prepareForAveraging() { if( myvessels.size()>0 ) { - deactivateAllTasks(); - double norm=0; + deactivateAllTasks(); double norm=0; for(unsigned i=0; igetNumberOfStoredValues(); ++i) { std::vector cvals( myvessels[0]->getNumberOfQuantities() ); stashes[0]->retrieveSequentialValue( i, false, cvals ); - unsigned itask=myvessels[0]->getActiveTask(i); - double tnorm = cvals[0]; + unsigned itask=myvessels[0]->getActiveTask(i); double tnorm = cvals[0]; for(unsigned j=1; jgetActiveTask(i)!=itask ) { - error("mismatched task identities in histogram suggests histogram is meaningless"); - } - if( cvals.size()!=myvessels[j]->getNumberOfQuantities() ) { - cvals.resize( myvessels[j]->getNumberOfQuantities() ); - } - stashes[j]->retrieveSequentialValue( i, false, cvals ); - tnorm *= cvals[0]; + if( myvessels[j]->getActiveTask(i)!=itask ) error("mismatched task identities in histogram suggests histogram is meaningless"); + if( cvals.size()!=myvessels[j]->getNumberOfQuantities() ) cvals.resize( myvessels[j]->getNumberOfQuantities() ); + stashes[j]->retrieveSequentialValue( i, false, cvals ); tnorm *= cvals[0]; } - norm += tnorm; - taskFlags[i]=1; + norm += tnorm; taskFlags[i]=1; } lockContributors(); // Sort out normalization of histogram - if( !noNormalization() ) { - ww = cweight / norm; - } else { - ww = cweight; - } + if( !noNormalization() ) ww = cweight / norm; + else ww = cweight; } else if( !storeThenAverage() ) { // Now fetch the kernel and the active points std::vector point( getNumberOfArguments() ); - for(unsigned i=0; i neighbors(1); + for(unsigned i=0; i neighbors(1); kernel=myhist->getKernelAndNeighbors( point, num_neigh, neighbors ); if( num_neigh>1 ) { // Activate relevant tasks deactivateAllTasks(); - for(unsigned i=0; inoDiscreteKernels() ); - } -} +void Histogram::performOperations( const bool& from_update ) { if( myvessels.size()==0 ) plumed_dbg_assert( !myhist->noDiscreteKernels() ); } void Histogram::finishAveraging() { - if( myvessels.size()==0 ) { - kernel.reset(); - } + if( myvessels.size()==0 ) kernel.reset(); } void Histogram::compute( const unsigned& current, MultiValue& myvals ) const { if( mvectors ) { std::vector cvals( myvessels[0]->getNumberOfQuantities() ); stashes[0]->retrieveSequentialValue( current, true, cvals ); - for(unsigned i=2; igetNumberOfQuantities(); ++i) { - myvals.setValue( i-1, cvals[i] ); - } - myvals.setValue( 0, cvals[0] ); - myvals.setValue( myvessels[0]->getNumberOfQuantities() - 1, ww ); + for(unsigned i=2; igetNumberOfQuantities(); ++i) myvals.setValue( i-1, cvals[i] ); + myvals.setValue( 0, cvals[0] ); myvals.setValue( myvessels[0]->getNumberOfQuantities() - 1, ww ); if( in_apply ) { MultiValue& tmpval = stashes[0]->getTemporyMultiValue(0); if( tmpval.getNumberOfValues()!=myvessels[0]->getNumberOfQuantities() || - tmpval.getNumberOfDerivatives()!=myvessels[0]->getNumberOfDerivatives() ) { + tmpval.getNumberOfDerivatives()!=myvessels[0]->getNumberOfDerivatives() ) tmpval.resize( myvessels[0]->getNumberOfQuantities(), myvessels[0]->getNumberOfDerivatives() ); - } stashes[0]->retrieveDerivatives( stashes[0]->getTrueIndex(current), true, tmpval ); for(unsigned j=0; jgetNumberOfQuantities(); ++i) { - myvals.addDerivative( i-1, jder, tmpval.getDerivative(i, jder) ); - } + unsigned jder=tmpval.getActiveIndex(j); myvals.addDerivative( 0, jder, tmpval.getDerivative(0, jder) ); + for(unsigned i=2; igetNumberOfQuantities(); ++i) myvals.addDerivative( i-1, jder, tmpval.getDerivative(i, jder) ); } myvals.updateDynamicList(); } } else if( myvessels.size()>0 ) { std::vector cvals( myvessels[0]->getNumberOfQuantities() ); stashes[0]->retrieveSequentialValue( current, false, cvals ); - unsigned derbase=0; - double totweight=cvals[0], tnorm = cvals[0]; - myvals.setValue( 1, cvals[1] ); + unsigned derbase=0; double totweight=cvals[0], tnorm = cvals[0]; myvals.setValue( 1, cvals[1] ); // Get the derivatives as well if we are in apply if( in_apply ) { // This bit gets the total weight double weight0 = cvals[0]; // Store the current weight for(unsigned j=1; jretrieveSequentialValue( current, false, cvals ); - totweight *= cvals[0]; + stashes[j]->retrieveSequentialValue( current, false, cvals ); totweight *= cvals[0]; } // And this bit the derivatives MultiValue& tmpval = stashes[0]->getTemporyMultiValue(0); if( tmpval.getNumberOfValues()!=myvessels[0]->getNumberOfQuantities() || - tmpval.getNumberOfDerivatives()!=myvessels[0]->getNumberOfDerivatives() ) { + tmpval.getNumberOfDerivatives()!=myvessels[0]->getNumberOfDerivatives() ) tmpval.resize( myvessels[0]->getNumberOfQuantities(), myvessels[0]->getNumberOfDerivatives() ); - } stashes[0]->retrieveDerivatives( stashes[0]->getTrueIndex(current), false, tmpval ); for(unsigned j=0; jgetNumberOfDerivatives(); } for(unsigned i=1; igetNumberOfQuantities() ) { - cvals.resize( myvessels[i]->getNumberOfQuantities() ); - } + if( cvals.size()!=myvessels[i]->getNumberOfQuantities() ) cvals.resize( myvessels[i]->getNumberOfQuantities() ); stashes[i]->retrieveSequentialValue( current, false, cvals ); - tnorm *= cvals[0]; - myvals.setValue( 1+i, cvals[1] ); + tnorm *= cvals[0]; myvals.setValue( 1+i, cvals[1] ); // Get the derivatives as well if we are in apply if( in_apply ) { MultiValue& tmpval = stashes[0]->getTemporyMultiValue(0); if( tmpval.getNumberOfValues()!=myvessels[0]->getNumberOfQuantities() || - tmpval.getNumberOfDerivatives()!=myvessels[0]->getNumberOfDerivatives() ) { + tmpval.getNumberOfDerivatives()!=myvessels[0]->getNumberOfDerivatives() ) tmpval.resize( myvessels[0]->getNumberOfQuantities(), myvessels[0]->getNumberOfDerivatives() ); - } stashes[i]->retrieveDerivatives( stashes[i]->getTrueIndex(current), false, tmpval ); for(unsigned j=0; jgetNumberOfDerivatives(); } } - myvals.setValue( 0, tnorm ); - myvals.setValue( 1+myvessels.size(), ww ); - if( in_apply ) { - myvals.updateDynamicList(); - } + myvals.setValue( 0, tnorm ); myvals.setValue( 1+myvessels.size(), ww ); + if( in_apply ) myvals.updateDynamicList(); } else { plumed_assert( !in_apply ); std::vector> vv( myhist->getVectorOfValues() ); @@ -592,58 +486,40 @@ void Histogram::compute( const unsigned& current, MultiValue& myvals ) const { // Retrieve the location of the grid point at which we are evaluating the kernel mygrid->getGridPointCoordinates( current, val ); if( kernel ) { - for(unsigned i=0; iset( val[i] ); - } + for(unsigned i=0; iset( val[i] ); // Evaluate the histogram at the relevant grid point and set the values - double vvh = kernel->evaluate( Tools::unique2raw(vv), der,true); - myvals.setValue( 1, vvh ); + double vvh = kernel->evaluate( Tools::unique2raw(vv), der,true); myvals.setValue( 1, vvh ); } else { plumed_merror("normalisation of vectors does not work with arguments and spherical grids"); // Evalulate dot product - double dot=0; - for(unsigned j=0; jvon_misses_norm)*std::exp( (myhist->von_misses_concentration)*dot ); - myvals.setValue( 1, newval ); + double newval = (myhist->von_misses_norm)*std::exp( (myhist->von_misses_concentration)*dot ); myvals.setValue( 1, newval ); // And final derivatives - for(unsigned j=0; jvon_misses_concentration)*newval; - } + for(unsigned j=0; jvon_misses_concentration)*newval; } // Set the derivatives and delete the vector of values - for(unsigned i=0; iwasForced() ) { - return ; - } + if( !myhist->wasForced() ) return ; in_apply=true; // Run the loop to calculate the forces - runAllTasks(); - finishAveraging(); + runAllTasks(); finishAveraging(); // We now need to retrieve the buffer and set the forces on the atoms myhist->applyForce( forcesToApply ); // Now make the forces make sense for the virial unsigned fbase=0, tbase=0, vbase = getNumberOfDerivatives() - myvessels.size()*9; - for(unsigned i=vbase; igetNumberOfDerivatives()-9; ++j) { finalForces[fbase + j] = forcesToApply[tbase + j]; } unsigned k=0; for(unsigned j=myvessels[i]->getNumberOfDerivatives()-9; jgetNumberOfDerivatives(); ++j) { - finalForces[vbase + k] += forcesToApply[tbase + j]; - k++; + finalForces[vbase + k] += forcesToApply[tbase + j]; k++; } fbase += myvessels[i]->getNumberOfDerivatives() - 9; tbase += myvessels[i]->getNumberOfDerivatives(); diff --git a/src/analysis/LandmarkSelectionBase.cpp b/src/analysis/LandmarkSelectionBase.cpp index ae32f7de30..e307a86428 100644 --- a/src/analysis/LandmarkSelectionBase.cpp +++ b/src/analysis/LandmarkSelectionBase.cpp @@ -34,23 +34,17 @@ void LandmarkSelectionBase::registerKeywords( Keywords& keys ) { LandmarkSelectionBase::LandmarkSelectionBase( const ActionOptions& ao ): Action(ao), AnalysisBase(ao), - nlandmarks(0) { - if( keywords.exists("NLANDMARKS") ) { - parse("NLANDMARKS",nlandmarks); - } + nlandmarks(0) +{ + if( keywords.exists("NLANDMARKS") ) parse("NLANDMARKS",nlandmarks); log.printf(" selecting %u landmark points \n",nlandmarks); lweights.resize( nlandmarks ); parseFlag("NOVORONOI",novoronoi); - if( !novoronoi && !dissimilaritiesWereSet() ) { - error("cannot calculate voronoi weights without dissimilarity mesaure"); - } + if( !novoronoi && !dissimilaritiesWereSet() ) error("cannot calculate voronoi weights without dissimilarity mesaure"); - if( !novoronoi ) { - log.printf(" ascribing weights to landmarks using voronoi analysis\n"); - } else { - log.printf(" ascribing weights of original points to landmark\n"); - } + if( !novoronoi ) log.printf(" ascribing weights to landmarks using voronoi analysis\n"); + else log.printf(" ascribing weights of original points to landmark\n"); } void LandmarkSelectionBase::selectFrame( const unsigned& iframe ) { @@ -58,21 +52,16 @@ void LandmarkSelectionBase::selectFrame( const unsigned& iframe ) { } void LandmarkSelectionBase::performAnalysis() { - landmark_indices.resize(0); - selectLandmarks(); + landmark_indices.resize(0); selectLandmarks(); plumed_dbg_assert( nlandmarks==getNumberOfDataPoints() ); - if( lweights.size()!=nlandmarks ) { - lweights.resize( nlandmarks ); - } + if( lweights.size()!=nlandmarks ) lweights.resize( nlandmarks ); if( !novoronoi ) { lweights.assign(lweights.size(),0.0); std::vector tmpass( my_input_data->getNumberOfDataPoints() ); voronoiAnalysis( landmark_indices, lweights, tmpass ); } else { - for(unsigned i=0; igetWeight( landmark_indices[i] ); - } + for(unsigned i=0; igetWeight( landmark_indices[i] ); } } @@ -85,10 +74,7 @@ void LandmarkSelectionBase::voronoiAnalysis( const std::vector& myindi double mindist=my_input_data->getDissimilarity( i, myindices[0] ); for(unsigned j=1; jgetDissimilarity( i, myindices[j] ); - if( distgetWeight(i); } diff --git a/src/analysis/LandmarkSelectionBase.h b/src/analysis/LandmarkSelectionBase.h index b68d1da256..79647069d1 100644 --- a/src/analysis/LandmarkSelectionBase.h +++ b/src/analysis/LandmarkSelectionBase.h @@ -60,9 +60,7 @@ class LandmarkSelectionBase : public AnalysisBase { /// Get the squared dissimilarity between two reference configurations double getDissimilarity( const unsigned& i, const unsigned& j ) override; /// This does nothing - it just ensures the final class is not abstract - void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { plumed_error(); } }; inline diff --git a/src/analysis/LandmarkStaged.cpp b/src/analysis/LandmarkStaged.cpp index 8413fb4276..5471c79391 100644 --- a/src/analysis/LandmarkStaged.cpp +++ b/src/analysis/LandmarkStaged.cpp @@ -57,9 +57,9 @@ void LandmarkStaged::registerKeywords( Keywords& keys ) { LandmarkStaged::LandmarkStaged( const ActionOptions& ao ): Action(ao), - LandmarkSelectionBase(ao) { - parse("SEED",seed); - parse("GAMMA",gamma); + LandmarkSelectionBase(ao) +{ + parse("SEED",seed); parse("GAMMA",gamma); log.printf(" probability of selecting voronoi polyhedra equal to exp(-weight/%f) \n", gamma ); } @@ -69,9 +69,7 @@ void LandmarkStaged::selectLandmarks() { unsigned int m = static_cast( std::sqrt(n*N) ); std::vector fpslandmarks(m); // Select first point at random - Random random; - random.setSeed(-seed); - double rand=random.RandU01(); + Random random; random.setSeed(-seed); double rand=random.RandU01(); fpslandmarks[0] = std::floor( N*rand ); // using FPS we want to find m landmarks where m = sqrt(nN) @@ -88,18 +86,11 @@ void LandmarkStaged::selectLandmarks() { for(unsigned j=0; jmaxd ) { - maxd=mind; - fpslandmarks[i]=j; + if( distances(k,j)maxd ) { maxd=mind; fpslandmarks[i]=j; } } - for(unsigned k=0; kgetDissimilarity( fpslandmarks[i], k ); - } + for(unsigned k=0; kgetDissimilarity( fpslandmarks[i], k ); } // Initial FPS selection of m landmarks completed @@ -109,13 +100,9 @@ void LandmarkStaged::selectLandmarks() { voronoiAnalysis( fpslandmarks, weights, poly_assign ); //Calculate total weight of voronoi polyhedras - double vweight=0; - for(unsigned i=0; i selected(N, false); - unsigned ncount=0; + std::vector selected(N, false); unsigned ncount=0; while ( ncount=rand ) { double tweight=0; for(unsigned i=0; i=rand_poly && !selected[i] ) { - selectFrame(i); - selected[i]=true; - ncount++; - break; + selectFrame(i); selected[i]=true; ncount++; break; } else if( running_tweight>=rand_poly ) { break; } diff --git a/src/analysis/OutputColvarFile.cpp b/src/analysis/OutputColvarFile.cpp index 7e0d5a6135..c5f67ee37a 100644 --- a/src/analysis/OutputColvarFile.cpp +++ b/src/analysis/OutputColvarFile.cpp @@ -53,17 +53,14 @@ class OutputColvarFile : public AnalysisBase { public: static void registerKeywords( Keywords& keys ); explicit OutputColvarFile( const ActionOptions& ); - void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { plumed_error(); } void performAnalysis() override; }; PLUMED_REGISTER_ACTION(OutputColvarFile,"OUTPUT_ANALYSIS_DATA_TO_COLVAR") void OutputColvarFile::registerKeywords( Keywords& keys ) { - AnalysisBase::registerKeywords( keys ); - keys.use("ARG"); + AnalysisBase::registerKeywords( keys ); keys.use("ARG"); keys.add("compulsory","FILE","the name of the file to output to"); keys.add("compulsory","REPLICA","0","the replicas for which you would like to output this information"); keys.add("compulsory","STRIDE","0","the frequency with which to perform the required analysis and to output the data. The default value of 0 tells plumed to use all the data"); @@ -74,72 +71,44 @@ OutputColvarFile::OutputColvarFile( const ActionOptions& ao ): Action(ao), AnalysisBase(ao), fmt("%f"), - output_for_all_replicas(false) { - parse("FILE",filename); - parse("FMT",fmt); - if( !getRestart() ) { - OFile ofile; - ofile.link(*this); - ofile.setBackupString("analysis"); - ofile.backupAllFiles(filename); - } + output_for_all_replicas(false) +{ + parse("FILE",filename); parse("FMT",fmt); + if( !getRestart() ) { OFile ofile; ofile.link(*this); ofile.setBackupString("analysis"); ofile.backupAllFiles(filename); } log.printf(" printing data to file named %s \n",filename.c_str() ); if( getArguments().size()==0 ) { std::vector tmp_vals( my_input_data->getArgumentNames() ); - req_vals.resize( tmp_vals.size() ); - for(unsigned i=0; igetName(); - } + req_vals.resize( getArguments().size() ); for(unsigned i=0; igetName(); } if( req_vals.size()==0 ) { log.printf(" outputting weights from input action \n"); } else { log.printf(" outputting %s", req_vals[0].c_str() ); - for(unsigned i=1; igetAtomIndexes() ); mypdb.setArgumentNames( my_input_data->getArgumentNames() ); // Find a moldata object auto* moldat=plumed.getActionSet().selectLatest(this); - if( ! moldat ) { - warning("PDB output files do not have atom types unless you use MOLDATA"); - } + if( ! moldat ) warning("PDB output files do not have atom types unless you use MOLDATA"); - parse("FILE",filename); - parse("FMT",fmt); - if( !getRestart() ) { - OFile ofile; - ofile.link(*this); - ofile.setBackupString("analysis"); - ofile.backupAllFiles(filename); - } + parse("FILE",filename); parse("FMT",fmt); + if( !getRestart() ) { OFile ofile; ofile.link(*this); ofile.setBackupString("analysis"); ofile.backupAllFiles(filename); } log.printf(" printing data to file named %s \n",filename.c_str() ); } @@ -93,24 +84,14 @@ void OutputPDBFile::performAnalysis() { // Find a moldata object auto* mymoldat=plumed.getActionSet().selectLatest(this); // Output the embedding in plumed pdb format - OFile afile; - afile.link(*this); - afile.setBackupString("analysis"); - std::size_t psign=fmt.find("%"); - afile.open( filename ); - std::string descr="REMARK WEIGHT=%-" + fmt.substr(psign+1) + "\n"; + OFile afile; afile.link(*this); afile.setBackupString("analysis"); std::size_t psign=fmt.find("%"); + afile.open( filename ); std::string descr="REMARK WEIGHT=%-" + fmt.substr(psign+1) + "\n"; for(unsigned j=0; jgetDissimilarity( i,j ) ) ); - } + for(unsigned j=0; jgetDissimilarity( i,j ) ) ); ofile.printf("\n"); } ofile.close(); diff --git a/src/analysis/ReadAnalysisFrames.cpp b/src/analysis/ReadAnalysisFrames.cpp index cd4e511eab..4739c2df72 100644 --- a/src/analysis/ReadAnalysisFrames.cpp +++ b/src/analysis/ReadAnalysisFrames.cpp @@ -40,9 +40,7 @@ PLUMED_REGISTER_ACTION(ReadAnalysisFrames,"COLLECT_FRAMES") void ReadAnalysisFrames::registerKeywords( Keywords& keys ) { AnalysisBase::registerKeywords( keys ); - keys.remove("SERIAL"); - keys.remove("USE_OUTPUT_DATA_FROM"); - keys.use("ARG"); + keys.remove("SERIAL"); keys.remove("USE_OUTPUT_DATA_FROM"); keys.use("ARG"); keys.add("atoms-1","ATOMS","the atoms whose positions we are tracking for the purpose of analyzing the data"); keys.add("atoms-1","STRIDE","the frequency with which data should be stored for analysis. By default data is collected on every step"); keys.add("compulsory","CLEAR","0","the frequency with which data should all be deleted and restarted"); @@ -55,39 +53,28 @@ ReadAnalysisFrames::ReadAnalysisFrames( const ActionOptions& ao ): AnalysisBase(ao), clearonnextstep(false), wham_pointer(NULL), - weights_calculated(false) { + weights_calculated(false) +{ parse("CLEAR",clearstride); - if( clearstride!=0 ) { - log.printf(" clearing stored data every %u steps\n",clearstride); - } + if( clearstride!=0 ) log.printf(" clearing stored data every %u steps\n",clearstride); // Get the names of the argumes argument_names.resize( getNumberOfArguments() ); - for(unsigned i=0; igetName(); - } + for(unsigned i=0; igetName(); // Find the atom numbers to read in parseAtomList("ATOMS",atom_numbers); if( atom_numbers.size()>0 ) { log.printf(" monitoring positions of atoms "); - for(unsigned i=0; i wwstr; - parseVector("LOGWEIGHTS",wwstr); - if( wwstr.size()>0 ) { - log.printf(" reweighting using weights from "); - } + std::vector wwstr; parseVector("LOGWEIGHTS",wwstr); + if( wwstr.size()>0 ) log.printf(" reweighting using weights from "); std::vector arg( ActionWithArguments::getArguments() ); for(unsigned i=0; i(wwstr[i]); - if( !val ) { - error("could not find value named"); - } + if( !val ) error("could not find value named"); weight_vals.push_back( val->copyOutput(val->getLabel()) ); arg.push_back( val->copyOutput(val->getLabel()) ); log.printf("%s ",wwstr[i].c_str() ); @@ -95,31 +82,19 @@ ReadAnalysisFrames::ReadAnalysisFrames( const ActionOptions& ao ): if( wwstr.size()>0 ) { log.printf("\n"); wham_pointer = dynamic_cast( weight_vals[0]->getPntrToAction() ); - if( !wham_pointer ) { - wham_pointer = NULL; - } else if( !wham_pointer->buildsWeightStore() ) { - wham_pointer = NULL; - } - if( wham_pointer && weight_vals.size()!=1 ) { - error("can only extract weights from one wham object"); - } - } else { - log.printf(" weights are all equal to one\n"); - } + if( !wham_pointer ) wham_pointer = NULL; + else if( !wham_pointer->buildsWeightStore() ) wham_pointer = NULL; + if( wham_pointer && weight_vals.size()!=1 ) error("can only extract weights from one wham object"); + } else log.printf(" weights are all equal to one\n"); requestArguments( arg ); // Now add fake components to the underlying ActionWithValue for the arguments - for(unsigned i=0; i ReadAnalysisFrames::getArgumentList() { std::vector arg_vals( ActionWithArguments::getArguments() ); - for(unsigned i=0; icalculateWeights( logweights.size() ); - for(unsigned i=0; igetWeight(i); - } + for(unsigned i=0; igetWeight(i); } else { // Find the maximum weight double maxweight=logweights[0]; for(unsigned i=1; imaxweight) { - maxweight=logweights[i]; - } + if(logweights[i]>maxweight) maxweight=logweights[i]; } // Calculate weights (no memory) -- business here with maxweight is to prevent overflows - for(unsigned i=0; iclearData(); - } + my_data_stash.clear(); my_data_stash.resize(0); + logweights.clear(); logweights.resize(0); + if( wham_pointer ) wham_pointer->clearData(); clearonnextstep=false; } // Get the weight and store it in the weights array - double ww=0; - for(unsigned i=0; iget(); - } - weights_calculated=false; - logweights.push_back(ww); + double ww=0; for(unsigned i=0; iget(); + weights_calculated=false; logweights.push_back(ww); // Now create the data collection object and push it back to be stored - unsigned index = my_data_stash.size(); - my_data_stash.push_back( DataCollectionObject() ); + unsigned index = my_data_stash.size(); my_data_stash.push_back( DataCollectionObject() ); my_data_stash[index].setAtomNumbersAndArgumentNames( getLabel(), atom_numbers, argument_names ); my_data_stash[index].setAtomPositions( getPositions() ); - for(unsigned i=0; i0 ) { - if( getStep()%clearstride==0 ) { - clearonnextstep=true; - } + if( getStep()%clearstride==0 ) clearonnextstep=true; } } diff --git a/src/analysis/ReadAnalysisFrames.h b/src/analysis/ReadAnalysisFrames.h index 1cb22de59a..f0b814c758 100644 --- a/src/analysis/ReadAnalysisFrames.h +++ b/src/analysis/ReadAnalysisFrames.h @@ -55,9 +55,7 @@ class ReadAnalysisFrames : public AnalysisBase { /// This does nothing void performAnalysis() override {} /// This does nothing - it just ensures the final class is not abstract - void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { plumed_error(); } /// Get the number of data points unsigned getNumberOfDataPoints() const override; /// Get the index of the data point @@ -93,9 +91,7 @@ bool ReadAnalysisFrames::dissimilaritiesWereSet() const { inline double ReadAnalysisFrames::getWeight( const unsigned& idat ) { - if( !weights_calculated ) { - calculateWeights(); - } + if( !weights_calculated ) calculateWeights(); return weights[idat]; } diff --git a/src/analysis/ReadDissimilarityMatrix.cpp b/src/analysis/ReadDissimilarityMatrix.cpp index 8bcf2e87e3..5654feb71b 100644 --- a/src/analysis/ReadDissimilarityMatrix.cpp +++ b/src/analysis/ReadDissimilarityMatrix.cpp @@ -58,9 +58,7 @@ class ReadDissimilarityMatrix : public AnalysisBase { /// This gives an error as if we read in the matrix we dont have the coordinates DataCollectionObject& getStoredData( const unsigned& idata, const bool& calcdist ) override; /// Tell everyone we have dissimilarities - bool dissimilaritiesWereSet() const override { - return true; - } + bool dissimilaritiesWereSet() const override { return true; } /// Get the dissimilarity between two data points double getDissimilarity( const unsigned&, const unsigned& ) override; /// Get the weight from the input file @@ -72,9 +70,7 @@ class ReadDissimilarityMatrix : public AnalysisBase { /// This does nothing void performAnalysis() override {}; /// Overwrite virtual function in base class - void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const override { plumed_error(); } }; PLUMED_REGISTER_ACTION(ReadDissimilarityMatrix,"READ_DISSIMILARITY_MATRIX") @@ -89,74 +85,52 @@ void ReadDissimilarityMatrix::registerKeywords( Keywords& keys ) { ReadDissimilarityMatrix::ReadDissimilarityMatrix( const ActionOptions& ao ): Action(ao), AnalysisBase(ao), - nnodes(1) { + nnodes(1) +{ setStride(1); // Set the stride equal to one to ensure we don't get stuck in an infinite loop std::vector setupActions=plumed.getActionSet().select(); - if( my_input_data && (plumed.getActionSet().size()-setupActions.size())!=1 ) { - error("should only be this action and the READ_ANALYSIS_FRAMES command in the input file"); - } - if( !my_input_data && plumed.getActionSet().size()!=0 ) { - error("read dissimilarity matrix command must be at top of input file"); - } + if( my_input_data && (plumed.getActionSet().size()-setupActions.size())!=1 ) error("should only be this action and the READ_ANALYSIS_FRAMES command in the input file"); + if( !my_input_data && plumed.getActionSet().size()!=0 ) error("read dissimilarity matrix command must be at top of input file"); parse("FILE",fname); log.printf(" reading dissimilarity matrix from file %s \n",fname.c_str() ); parse("WFILE",wfile); - if( wfile.length()>0 ) { - log.printf(" reading weights of nodes from file named %s \n",wfile.c_str() ); - } else { - log.printf(" setting weights of all nodes equal to one\n"); - } + if( wfile.length()>0 ) log.printf(" reading weights of nodes from file named %s \n",wfile.c_str() ); + else log.printf(" setting weights of all nodes equal to one\n"); } -void ReadDissimilarityMatrix::update() { - if(!my_input_data) { - plumed.stop(); - } -} +void ReadDissimilarityMatrix::update() { if(!my_input_data) plumed.stop(); } void ReadDissimilarityMatrix::runFinalJobs() { - IFile mfile; - mfile.open(fname); + IFile mfile; mfile.open(fname); // Read in first line - std::vector words; - nnodes=0; + std::vector words; nnodes=0; while( nnodes==0 ) { Tools::getParsedLine( mfile, words ); nnodes=words.size(); } std::vector tmpdis( nnodes ); - for(unsigned j=0; j0 ) { - IFile wfilef; - wfilef.open(wfile); + IFile wfilef; wfilef.open(wfile); for(unsigned i=0; i( datastr ); - if( !mylandmarks ) { - error("input to LANDMARKS is not a landmark selection action"); - } + if( !mylandmarks ) error("input to LANDMARKS is not a landmark selection action"); nlandmarks = mylandmarks->nlandmarks; - if( (mylandmarks->my_input_data)->getNumberOfDataPoints()!=my_input_data->getNumberOfDataPoints() ) { - error("mismatch between amount of landmark class and base class"); - } + if( (mylandmarks->my_input_data)->getNumberOfDataPoints()!=my_input_data->getNumberOfDataPoints() ) error("mismatch between amount of landmark class and base class"); } void ReselectLandmarks::selectLandmarks() { - for(unsigned i=0; igetNumberOfDataPoints(); ++i) { - selectFrame( mylandmarks->getDataPointIndexInBase(i) ); - } + for(unsigned i=0; igetNumberOfDataPoints(); ++i) selectFrame( mylandmarks->getDataPointIndexInBase(i) ); } } diff --git a/src/analysis/SelectRandomFrames.cpp b/src/analysis/SelectRandomFrames.cpp index 1345af1257..a0ab44c1fe 100644 --- a/src/analysis/SelectRandomFrames.cpp +++ b/src/analysis/SelectRandomFrames.cpp @@ -53,13 +53,13 @@ void SelectRandomFrames::registerKeywords( Keywords& keys ) { SelectRandomFrames::SelectRandomFrames( const ActionOptions& ao ): Action(ao), - LandmarkSelectionBase(ao) { + LandmarkSelectionBase(ao) +{ parse("SEED",seed); } void SelectRandomFrames::selectLandmarks() { - Random r; - r.setSeed(-seed); + Random r; r.setSeed(-seed); unsigned nframe=my_input_data->getNumberOfDataPoints(); unsigned nland=getNumberOfDataPoints(); diff --git a/src/analysis/SelectWithStride.cpp b/src/analysis/SelectWithStride.cpp index c5a444cfe1..3af046af6c 100644 --- a/src/analysis/SelectWithStride.cpp +++ b/src/analysis/SelectWithStride.cpp @@ -49,14 +49,13 @@ void SelectWithStride::registerKeywords( Keywords& keys ) { SelectWithStride::SelectWithStride( const ActionOptions& ao ): Action(ao), - LandmarkSelectionBase(ao) { + LandmarkSelectionBase(ao) +{ } void SelectWithStride::selectLandmarks() { unsigned stride = std::floor( my_input_data->getNumberOfDataPoints() / getNumberOfDataPoints() ), max=stride*getNumberOfDataPoints(); - for(unsigned i=0; i num_nodes; @@ -110,8 +111,7 @@ PLUMED_REGISTER_ACTION(ANN,"ANN") void ANN::registerKeywords( Keywords& keys ) { Function::registerKeywords(keys); - keys.use("ARG"); - keys.use("PERIODIC"); + keys.use("ARG"); keys.use("PERIODIC"); keys.add("compulsory", "NUM_LAYERS", "number of layers of the neural network"); keys.add("compulsory", "NUM_NODES", "numbers of nodes in each layer of the neural network"); keys.add("compulsory", "ACTIVATIONS", "activation functions for the neural network"); @@ -126,7 +126,8 @@ void ANN::registerKeywords( Keywords& keys ) { ANN::ANN(const ActionOptions&ao): Action(ao), - Function(ao) { + Function(ao) +{ parse("NUM_LAYERS", num_layers); num_nodes = vector(num_layers); activations = vector(num_layers - 1); @@ -228,11 +229,13 @@ void ANN::calculate_output_of_each_layer(const vector& input) { for(int jj = 0; jj < num_nodes[ii]; jj ++) { output_of_each_layer[ii][jj] = input_of_each_layer[ii][jj]; } - } else if (activations[ii - 1] == string("Tanh")) { + } + else if (activations[ii - 1] == string("Tanh")) { for(int jj = 0; jj < num_nodes[ii]; jj ++) { output_of_each_layer[ii][jj] = tanh(input_of_each_layer[ii][jj]); } - } else if (activations[ii - 1] == string("Circular")) { + } + else if (activations[ii - 1] == string("Circular")) { assert (num_nodes[ii] % 2 == 0); for(int jj = 0; jj < num_nodes[ii] / 2; jj ++) { double radius = sqrt(input_of_each_layer[ii][2 * jj] * input_of_each_layer[ii][2 * jj] @@ -241,7 +244,8 @@ void ANN::calculate_output_of_each_layer(const vector& input) { output_of_each_layer[ii][2 * jj + 1] = input_of_each_layer[ii][2 * jj + 1] / radius; } - } else { + } + else { printf("layer type not found!\n\n"); return; } @@ -254,7 +258,8 @@ void ANN::calculate_output_of_each_layer(const vector& input) { printf("layer[%d]: ", ii); if (ii != 0) { cout << activations[ii - 1] << "\t"; - } else { + } + else { cout << "input \t" ; } for (int jj = 0; jj < num_nodes[ii]; jj ++) { @@ -273,7 +278,8 @@ void ANN::back_prop(vector >& derivatives_of_each_layer, int inde for (int ii = 0; ii < num_nodes[num_nodes.size() - 1]; ii ++ ) { if (ii == index_of_output_component) { derivatives_of_each_layer[num_nodes.size() - 1][ii] = 1; - } else { + } + else { derivatives_of_each_layer[num_nodes.size() - 1][ii] = 0; } } @@ -317,7 +323,8 @@ void ANN::back_prop(vector >& derivatives_of_each_layer, int inde } } // TODO: should be fine, pass all tests, although there seems to be some problems here previously - } else { + } + else { for (int mm = 0; mm < num_nodes[jj]; mm ++) { derivatives_of_each_layer[jj][mm] = 0; for (int kk = 0; kk < num_nodes[jj + 1]; kk ++) { @@ -326,12 +333,14 @@ void ANN::back_prop(vector >& derivatives_of_each_layer, int inde derivatives_of_each_layer[jj][mm] += derivatives_of_each_layer[jj + 1][kk] \ * coeff[jj][kk][mm] \ * (1 - output_of_each_layer[jj + 1][kk] * output_of_each_layer[jj + 1][kk]); - } else if (activations[jj] == string("Linear")) { + } + else if (activations[jj] == string("Linear")) { // printf("linear\n"); derivatives_of_each_layer[jj][mm] += derivatives_of_each_layer[jj + 1][kk] \ * coeff[jj][kk][mm] \ * 1; - } else { + } + else { printf("layer type not found!\n\n"); return; } diff --git a/src/astyle.sh b/src/astyle.sh index 26a77d6568..c3239afac7 100755 --- a/src/astyle.sh +++ b/src/astyle.sh @@ -1,52 +1,50 @@ #! /usr/bin/env bash -#formatted with shfmt v3.6.0 + DIRS=$1 # keep only dirname DIRS=${DIRS##*/} echo "$DIRS" -# shellcheck disable=SC2125 + test -z "$DIRS" && DIRS=* -options=../../.astyle.options +for dir in $DIRS +do +test -d "$dir" || continue + +test "$dir" = lapack && continue +test "$dir" = blas && continue +test "$dir" = molfile && continue +test "$dir" = lepton && continue +test "$dir" = asmjit && continue +test "$dir" = xdrfile && continue -for dir in $DIRS; do - test -d "$dir" || continue +cd $dir - test "$dir" = lapack && continue - test "$dir" = blas && continue - test "$dir" = molfile && continue - test "$dir" = lepton && continue - test "$dir" = asmjit && continue - test "$dir" = xdrfile && continue - cd "$dir" || { - echo "Problem with 'cd $dir'" - exit 1 - } +for file in *.c *.cpp *.h *.inc.in +do - for file in *.c *.cpp *.h *.inc.in; do +test -f "$file" || continue - test -f "$file" || continue +echo -n "astyle $file" - echo -n "astyle $file" +../../astyle/astyle --options=../../.astyle.options < $file > $file.tmp && { +if cmp -s $file $file.tmp ; then + echo +else + cp $file.tmp $file + echo " +++ PATCHED" + git add $file +fi +} - ../../astyle/astyle --options="$options" <"$file" >"$file.tmp" && { - if cmp -s "$file" "$file.tmp"; then - echo - else - cp "$file.tmp" "$file" - echo " +++ PATCHED" - git add "$file" - fi - } +rm $file.tmp - rm "$file.tmp" +done - done - cd - || { - echo "Problem with 'cd -' from '$dir'" - exit 1 - } +cd - done + + diff --git a/src/bias/ABMD.cpp b/src/bias/ABMD.cpp index 83539f9830..dd9400ce52 100644 --- a/src/bias/ABMD.cpp +++ b/src/bias/ABMD.cpp @@ -115,50 +115,35 @@ ABMD::ABMD(const ActionOptions&ao): kappa(getNumberOfArguments(),0.0), temp(getNumberOfArguments(),0.0), seed(getNumberOfArguments(),std::time(0)), - random(getNumberOfArguments()) { + random(getNumberOfArguments()) +{ // Note : parseVector will check that number of arguments is correct parseVector("KAPPA",kappa); parseVector("MIN",min); - if(min.size()==0) { - min.assign(getNumberOfArguments(),-1.0); - } - if(min.size()!=getNumberOfArguments()) { - error("MIN array should have the same size as ARG array"); - } + if(min.size()==0) min.assign(getNumberOfArguments(),-1.0); + if(min.size()!=getNumberOfArguments()) error("MIN array should have the same size as ARG array"); parseVector("NOISE",temp); parseVector("SEED",seed); parseVector("TO",to); checkRead(); log.printf(" min"); - for(unsigned i=0; igetName()+"_min"; - addComponent(str_min); - componentIsNotPeriodic(str_min); - if(min[i]!=-1.0) { - getPntrToComponent(str_min)->set(min[i]); - } - } - for(unsigned i=0; iset(min[i]); } - addComponent("force2"); - componentIsNotPeriodic("force2"); + for(unsigned i=0; i0) { noise = 2.*random[i].Gaussian()*diff; - if(cv2<=diff) { - diff=0.; - temp[i]=0.; - } + if(cv2<=diff) { diff=0.; temp[i]=0.; } } // min < 0 means that the variable has not been used in the input file, so the current position of the CV is used diff --git a/src/bias/Bias.cpp b/src/bias/Bias.cpp index 474cb0f02f..0cb1d61cca 100644 --- a/src/bias/Bias.cpp +++ b/src/bias/Bias.cpp @@ -30,7 +30,8 @@ Bias::Bias(const ActionOptions&ao): ActionPilot(ao), ActionWithValue(ao), ActionWithArguments(ao), - outputForces(getNumberOfArguments(),0.0) { + outputForces(getNumberOfArguments(),0.0) +{ addComponentWithDerivatives("bias"); componentIsNotPeriodic("bias"); valueBias=getPntrToComponent("bias"); @@ -75,18 +76,13 @@ void Bias::apply() { for(unsigned i=0; iapplyForce(forces)) { at_least_one_forced=true; - for(unsigned j=0; jaddForce(f[i]); } diff --git a/src/bias/Bias.h b/src/bias/Bias.h index 9de689847d..482181e10b 100644 --- a/src/bias/Bias.h +++ b/src/bias/Bias.h @@ -40,7 +40,8 @@ information as to how to go about implementing a new bias. class Bias : public ActionPilot, public ActionWithValue, - public ActionWithArguments { + public ActionWithArguments +{ /// the vector of the forces std::vector outputForces; /// the pointer to the bias component diff --git a/src/bias/BiasValue.cpp b/src/bias/BiasValue.cpp index 4bf24c890e..161385f6c5 100644 --- a/src/bias/BiasValue.cpp +++ b/src/bias/BiasValue.cpp @@ -92,21 +92,20 @@ void BiasValue::registerKeywords(Keywords& keys) { } BiasValue::BiasValue(const ActionOptions&ao): - PLUMED_BIAS_INIT(ao) { + PLUMED_BIAS_INIT(ao) +{ checkRead(); // add one bias for each argument for(unsigned i=0; igetName()+"_bias"; - addComponent(ss); - componentIsNotPeriodic(ss); + addComponent(ss); componentIsNotPeriodic(ss); } } void BiasValue::calculate() { double bias=0.0; for(unsigned i=0; iset(val); setOutputForce(i,-1.); bias+=val; diff --git a/src/bias/ExtendedLagrangian.cpp b/src/bias/ExtendedLagrangian.cpp index 1d27306073..caeffa71a0 100644 --- a/src/bias/ExtendedLagrangian.cpp +++ b/src/bias/ExtendedLagrangian.cpp @@ -156,42 +156,31 @@ ExtendedLagrangian::ExtendedLagrangian(const ActionOptions&ao): friction(getNumberOfArguments(),0.0), fictValue(getNumberOfArguments(),NULL), vfictValue(getNumberOfArguments(),NULL), - kbt(0.0) { + kbt(0.0) +{ parseVector("TAU",tau); parseVector("FRICTION",friction); parseVector("KAPPA",kappa); double temp=-1.0; parse("TEMP",temp); - if(temp>=0.0) { - kbt=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt=plumed.getAtoms().getKbT(); - } + if(temp>=0.0) kbt=plumed.getAtoms().getKBoltzmann()*temp; + else kbt=plumed.getAtoms().getKbT(); checkRead(); log.printf(" with harmonic force constant"); - for(unsigned i=0; i0.0) { - hasFriction=true; - } + for(unsigned i=0; i0.0) hasFriction=true; if(hasFriction) { log.printf(" with friction"); - for(unsigned i=0; igetDomain(a,b); componentIsPeriodic(comp,a,b); - } else { - componentIsNotPeriodic(comp); - } + } else componentIsNotPeriodic(comp); fictValue[i]=getPntrToComponent(comp); comp=getPntrToArgument(i)->getName()+"_vfict"; addComponent(comp); diff --git a/src/bias/External.cpp b/src/bias/External.cpp index f9e56150d8..436208c10b 100644 --- a/src/bias/External.cpp +++ b/src/bias/External.cpp @@ -130,12 +130,11 @@ void External::registerKeywords(Keywords& keys) { } External::External(const ActionOptions& ao): - PLUMED_BIAS_INIT(ao) { + PLUMED_BIAS_INIT(ao) +{ std::string filename; parse("FILE",filename); - if( filename.length()==0 ) { - error("No external potential file was specified"); - } + if( filename.length()==0 ) error("No external potential file was specified"); bool sparsegrid=false; parseFlag("SPARSE",sparsegrid); bool nospline=false; @@ -147,35 +146,25 @@ External::External(const ActionOptions& ao): log.printf(" External potential from file %s\n",filename.c_str()); log.printf(" Multiplied by %lf\n",scale_); - if(spline) { - log.printf(" External potential uses spline interpolation\n"); - } - if(sparsegrid) { - log.printf(" External potential uses sparse grid\n"); - } + if(spline) {log.printf(" External potential uses spline interpolation\n");} + if(sparsegrid) {log.printf(" External potential uses sparse grid\n");} // read grid - IFile gridfile; - gridfile.open(filename); + IFile gridfile; gridfile.open(filename); std::string funcl=getLabel() + ".bias"; BiasGrid_=GridBase::create(funcl,getArguments(),gridfile,sparsegrid,spline,true); - if(BiasGrid_->getDimension()!=getNumberOfArguments()) { - error("mismatch between dimensionality of input grid and number of arguments"); - } + if(BiasGrid_->getDimension()!=getNumberOfArguments()) error("mismatch between dimensionality of input grid and number of arguments"); for(unsigned i=0; iisPeriodic()!=BiasGrid_->getIsPeriodic()[i] ) { - error("periodicity mismatch between arguments and input bias"); - } + if( getPntrToArgument(i)->isPeriodic()!=BiasGrid_->getIsPeriodic()[i] ) error("periodicity mismatch between arguments and input bias"); } } -void External::calculate() { +void External::calculate() +{ unsigned ncv=getNumberOfArguments(); std::vector cv(ncv), der(ncv); - for(unsigned i=0; igetValueAndDerivatives(cv,der); diff --git a/src/bias/LWalls.cpp b/src/bias/LWalls.cpp index 70044f51ef..dc39572687 100644 --- a/src/bias/LWalls.cpp +++ b/src/bias/LWalls.cpp @@ -98,7 +98,8 @@ LWalls::LWalls(const ActionOptions&ao): kappa(getNumberOfArguments(),0.0), exp(getNumberOfArguments(),2.0), eps(getNumberOfArguments(),1.0), - offset(getNumberOfArguments(),0.0) { + offset(getNumberOfArguments(),0.0) +{ // Note sizes of these vectors are automatically checked by parseVector :-) parseVector("OFFSET",offset); parseVector("EPS",eps); @@ -108,33 +109,22 @@ LWalls::LWalls(const ActionOptions&ao): checkRead(); log.printf(" at"); - for(unsigned i=0; i= TSTART"); - } + if(tend<0 && tend != -1.0) error("TSTART should be a positive number"); + if(tend= TSTART"); lagmultfname=getLabel()+".LAGMULT"; parse("FILE",lagmultfname); parse("FMT",fmt); parse("PACE",pace_); - if(pace_<=0 ) { - error("frequency for Lagrangian multipliers update (PACE) is nonsensical"); - } + if(pace_<=0 ) error("frequency for Lagrangian multipliers update (PACE) is nonsensical"); stride_=pace_; //if no STRIDE is passed, then Lagrangian multipliers willbe printed at each update parse("PRINT_STRIDE",stride_); - if(stride_<=0 ) { - error("frequency for Lagrangian multipliers printing (STRIDE) is nonsensical"); - } + if(stride_<=0 ) error("frequency for Lagrangian multipliers printing (STRIDE) is nonsensical"); simtemp=0.; parse("TEMP",simtemp); - if(simtemp>0) { - simtemp*=plumed.getAtoms().getKBoltzmann(); - } else { - simtemp=plumed.getAtoms().getKbT(); - } + if(simtemp>0) simtemp*=plumed.getAtoms().getKBoltzmann(); + else simtemp=plumed.getAtoms().getKbT(); parseFlag("REWEIGHT",reweight); - if(simtemp<=0 && reweight) { - error("Set the temperature (TEMP) if you want to do reweighting."); - } + if(simtemp<=0 && reweight) error("Set the temperature (TEMP) if you want to do reweighting."); checkRead(); log.printf(" at"); - for(unsigned i=0; i0) { + if(fmt.length()>0) log.printf("The format for real number in Lagrangian multipliers file is %s\n",fmt.c_str()); - } - if(tstart >-1.0 && tend>-1.0) { + if(tstart >-1.0 && tend>-1.0) log.printf("Lagrangian multipliers are averaged from %lf ps to %lf ps\n",tstart,tend); - } - if(no_broadcast) { + if(no_broadcast) log.printf("Using NO_BROADCAST options. Lagrangian multipliers will not be comunicated to other replicas.\n"); - } //for(int irep=0;irepgetName()+"_coupling"; - addComponent(comp); - componentIsNotPeriodic(comp); + addComponent(comp); componentIsNotPeriodic(comp); comp=getPntrToArgument(i)->getName()+"_work"; - addComponent(comp); - componentIsNotPeriodic(comp); + addComponent(comp); componentIsNotPeriodic(comp); work.push_back(0.); // initialize the work value comp=getPntrToArgument(i)->getName()+"_error"; - addComponent(comp); - componentIsNotPeriodic(comp); + addComponent(comp); componentIsNotPeriodic(comp); } std::string fname; fname=lagmultfname; @@ -355,28 +321,24 @@ MaxEnt::MaxEnt(const ActionOptions&ao): lagmultOfile_.link(*this); lagmultOfile_.open(fname); - if(fmt.length()>0) { - fmt=" "+fmt; - lagmultOfile_.fmtField(fmt); - } + if(fmt.length()>0) {fmt=" "+fmt; lagmultOfile_.fmtField(fmt);} } ////MEMBER FUNCTIONS -void MaxEnt::ReadLagrangians(IFile &ifile) { +void MaxEnt::ReadLagrangians(IFile &ifile) +{ double dummy; while(ifile.scanField("time",dummy)) { for(unsigned j=0; jgetName()+"_coupling",lambda[j]); - if(dummy>=tstart && dummy <=tend) { + if(dummy>=tstart && dummy <=tend) avglambda[j]+=lambda[j]; - } if(dummy>=tend) { avglambda[j]=lambda[j]; done_average[j]=true; } } - if(dummy>=tstart && dummy <=tend) { + if(dummy>=tstart && dummy <=tend) avg_counter++; - } ifile.scanField(); } } @@ -384,17 +346,15 @@ void MaxEnt::WriteLagrangians(std::vector &lagmult,OFile &file) { if(printFirstStep) { unsigned ncv=getNumberOfArguments(); file.printField("time",getTimeStep()*getStep()); - for(unsigned i=0; igetName()+"_coupling",lagmult[i]); - } file.printField(); } else { if(!isFirstStep) { unsigned ncv=getNumberOfArguments(); file.printField("time",getTimeStep()*getStep()); - for(unsigned i=0; igetName()+"_coupling",lagmult[i]); - } file.printField(); } } @@ -403,9 +363,9 @@ double MaxEnt::compute_error(const std::string &err_type,double l) { double sigma2=std::pow(sigma,2.0); double l2=convert_lambda(type,l); double return_error=0; - if(err_type=="GAUSSIAN" && sigma!=0.0) { + if(err_type=="GAUSSIAN" && sigma!=0.0) return_error=-l2*sigma2; - } else { + else { if(err_type=="LAPLACE" && sigma!=0) { return_error=-l2*sigma2/(1.0-l2*l2*sigma2/(alpha+1)); } @@ -414,22 +374,21 @@ double MaxEnt::compute_error(const std::string &err_type,double l) { } double MaxEnt::convert_lambda(const std::string &type,double lold) { double return_lambda=0; - if(type=="EQUAL") { + if(type=="EQUAL") return_lambda=lold; - } else { + else { if(type=="INEQUAL>") { - if(lold>0.0) { + if(lold>0.0) return_lambda=0.0; - } else { + else return_lambda=lold; - } - } else { + } + else { if(type=="INEQUAL<") { - if(lold<0.0) { + if(lold<0.0) return_lambda=0.0; - } else { + else return_lambda=lold; - } } } } @@ -456,20 +415,18 @@ void MaxEnt::update_lambda() { const double step=getStep(); double KbT=simtemp; double learning_rate; - if(reweight) { + if(reweight) BetaReweightBias=plumed.getBias()/KbT; - } else { + else BetaReweightBias=0.0; - } for(unsigned i=0; i=tstart && time <=tend && !done_average[i]) { @@ -480,18 +437,17 @@ void MaxEnt::update_lambda() { avglambda[i]=avglambda[i]/avg_counter; done_average[i]=true; lambda[i]=avglambda[i]; - } else { - lambda[i]=avglambda[i]; //keep Lagrangian multipliers fixed to the previously computed average. } + else + lambda[i]=avglambda[i]; //keep Lagrangian multipliers fixed to the previously computed average. } work[i]+=(convert_lambda(type,lambda[i])-oldlambda[i])*getArgument(i); //compute the work performed in updating lambda totalWork_+=work[i]; totalWork=totalWork_; oldlambda[i]=convert_lambda(type,lambda[i]); }; - if(time>=tstart && time <=tend) { + if(time>=tstart && time <=tend) avg_counter++; - } } void MaxEnt::calculate() { @@ -514,15 +470,13 @@ void MaxEnt::calculate() { void MaxEnt::update() { - if(getStep()%stride_ == 0) { + if(getStep()%stride_ == 0) WriteLagrangians(lambda,lagmultOfile_); - } if(getStep()%pace_ == 0) { update_lambda(); if(!no_broadcast) { - if(comm.Get_rank()==0) { //Comunicate Lagrangian multipliers from reference replica to higher ones + if(comm.Get_rank()==0) //Comunicate Lagrangian multipliers from reference replica to higher ones multi_sim_comm.Bcast(lambda,learn_replica); - } } comm.Bcast(lambda,0); } diff --git a/src/bias/MetaD.cpp b/src/bias/MetaD.cpp index f9ab361d27..0f1e75533e 100644 --- a/src/bias/MetaD.cpp +++ b/src/bias/MetaD.cpp @@ -384,11 +384,8 @@ class MetaD : public Bias { multivariate(m),height(h),center(c),sigma(s),invsigma(s) { // to avoid troubles from zero element in flexible hills for(unsigned i=0; i1.e-20) { - invsigma[i]=1.0/invsigma[i] ; - } else { - invsigma[i]=0.0; - } + if(std::abs(invsigma[i])>1.e-20) invsigma[i]=1.0/invsigma[i] ; + else invsigma[i]=0.0; } } }; @@ -632,7 +629,8 @@ MetaD::MetaD(const ActionOptions& ao): work_(0), nlist_(false), nlist_update_(false), - nlist_steps_(0) { + nlist_steps_(0) +{ if(!dp2cutoffNoStretch()) { stretchA=dp2cutoffA; stretchB=dp2cutoffB; @@ -659,9 +657,7 @@ MetaD::MetaD(const ActionOptions& ao): parseVector("SIGMA",sigma0_); if(adaptive_==FlexibleBin::none) { // if you use normal sigma you need one sigma per argument - if( sigma0_.size()!=getNumberOfArguments() ) { - error("number of arguments does not match number of SIGMA parameters"); - } + if( sigma0_.size()!=getNumberOfArguments() ) error("number of arguments does not match number of SIGMA parameters"); } else { // if you use flexible hills you need one sigma if(sigma0_.size()!=1) { @@ -679,9 +675,7 @@ MetaD::MetaD(const ActionOptions& ao): error("the number of SIGMA_MIN values be the same of the number of the arguments"); } else if(sigma0min_.size()==0) { sigma0min_.resize(getNumberOfArguments()); - for(unsigned i=0; i(adaptive_,this,sigma0_[0],sigma0min_,sigma0max_); @@ -700,9 +692,7 @@ MetaD::MetaD(const ActionOptions& ao): // note: HEIGHT is not compulsory, since one could use the TAU keyword, see below parse("HEIGHT",height0_); parse("PACE",stride_); - if(stride_<=0) { - error("frequency for hill addition is nonsensical"); - } + if(stride_<=0) error("frequency for hill addition is nonsensical"); current_stride_ = stride_; std::string hillsfname="HILLS"; parse("FILE",hillsfname); @@ -717,36 +707,25 @@ MetaD::MetaD(const ActionOptions& ao): parseVector("RECT",rect_biasf_); if(rect_biasf_.size()>0) { int r=0; - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) r=multi_sim_comm.Get_rank(); comm.Bcast(r,0); biasf_=rect_biasf_[r]; log<<" You are using RECT\n"; } else { parse("BIASFACTOR",biasf_); } - if( biasf_<1.0 && biasf_!=-1.0) { - error("well tempered bias factor is nonsensical"); - } + if( biasf_<1.0 && biasf_!=-1.0) error("well tempered bias factor is nonsensical"); parse("DAMPFACTOR",dampfactor_); double temp=0.0; parse("TEMP",temp); - if(temp>0.0) { - kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt_=plumed.getAtoms().getKbT(); - } + if(temp>0.0) kbt_=plumed.getAtoms().getKBoltzmann()*temp; + else kbt_=plumed.getAtoms().getKbT(); if(biasf_>=1.0) { - if(kbt_==0.0) { - error("Unless the MD engine passes the temperature to plumed, with well-tempered metad you must specify it using TEMP"); - } + if(kbt_==0.0) error("Unless the MD engine passes the temperature to plumed, with well-tempered metad you must specify it using TEMP"); welltemp_=true; } if(dampfactor_>0.0) { - if(kbt_==0.0) { - error("Unless the MD engine passes the temperature to plumed, with damped metad you must specify it using TEMP"); - } + if(kbt_==0.0) error("Unless the MD engine passes the temperature to plumed, with damped metad you must specify it using TEMP"); } parseFlag("CALC_WORK",calc_work_); @@ -754,18 +733,14 @@ MetaD::MetaD(const ActionOptions& ao): // Set transition tempering parameters. // Transition wells are read later via calc_transition_bias_. readTemperingSpecs(tt_specs_); - if (tt_specs_.is_active) { - calc_transition_bias_ = true; - } + if (tt_specs_.is_active) calc_transition_bias_ = true; // If any previous option specified to calculate a transition bias, // now read the transition wells for that quantity. if (calc_transition_bias_) { std::vector tempcoords(getNumberOfArguments()); for (unsigned i = 0; ; i++) { - if (!parseNumberedVector("TRANSITIONWELL", i, tempcoords) ) { - break; - } + if (!parseNumberedVector("TRANSITIONWELL", i, tempcoords) ) break; if (tempcoords.size() != getNumberOfArguments()) { error("incorrect number of coordinates for transition tempering well"); } @@ -774,88 +749,53 @@ MetaD::MetaD(const ActionOptions& ao): } parse("TARGET",targetfilename_); - if(targetfilename_.length()>0 && kbt_==0.0) { - error("with TARGET temperature must be specified"); - } + if(targetfilename_.length()>0 && kbt_==0.0) error("with TARGET temperature must be specified"); double tau=0.0; parse("TAU",tau); if(tau==0.0) { - if(height0_==std::numeric_limits::max()) { - error("At least one between HEIGHT and TAU should be specified"); - } + if(height0_==std::numeric_limits::max()) error("At least one between HEIGHT and TAU should be specified"); // if tau is not set, we compute it here from the other input parameters - if(welltemp_) { - tau=(kbt_*(biasf_-1.0))/height0_*getTimeStep()*stride_; - } else if(dampfactor_>0.0) { - tau=(kbt_*dampfactor_)/height0_*getTimeStep()*stride_; - } + if(welltemp_) tau=(kbt_*(biasf_-1.0))/height0_*getTimeStep()*stride_; + else if(dampfactor_>0.0) tau=(kbt_*dampfactor_)/height0_*getTimeStep()*stride_; } else { - if(height0_!=std::numeric_limits::max()) { - error("At most one between HEIGHT and TAU should be specified"); - } + if(height0_!=std::numeric_limits::max()) error("At most one between HEIGHT and TAU should be specified"); if(welltemp_) { - if(biasf_!=1.0) { - height0_=(kbt_*(biasf_-1.0))/tau*getTimeStep()*stride_; - } else { - height0_=kbt_/tau*getTimeStep()*stride_; // special case for gamma=1 - } - } else if(dampfactor_>0.0) { - height0_=(kbt_*dampfactor_)/tau*getTimeStep()*stride_; - } else { - error("TAU only makes sense in well-tempered or damped metadynamics"); + if(biasf_!=1.0) height0_=(kbt_*(biasf_-1.0))/tau*getTimeStep()*stride_; + else height0_=kbt_/tau*getTimeStep()*stride_; // special case for gamma=1 } + else if(dampfactor_>0.0) height0_=(kbt_*dampfactor_)/tau*getTimeStep()*stride_; + else error("TAU only makes sense in well-tempered or damped metadynamics"); } // Grid Stuff std::vector gmin(getNumberOfArguments()); parseVector("GRID_MIN",gmin); - if(gmin.size()!=getNumberOfArguments() && gmin.size()!=0) { - error("not enough values for GRID_MIN"); - } + if(gmin.size()!=getNumberOfArguments() && gmin.size()!=0) error("not enough values for GRID_MIN"); std::vector gmax(getNumberOfArguments()); parseVector("GRID_MAX",gmax); - if(gmax.size()!=getNumberOfArguments() && gmax.size()!=0) { - error("not enough values for GRID_MAX"); - } + if(gmax.size()!=getNumberOfArguments() && gmax.size()!=0) error("not enough values for GRID_MAX"); std::vector gbin(getNumberOfArguments()); std::vector gspacing; parseVector("GRID_BIN",gbin); - if(gbin.size()!=getNumberOfArguments() && gbin.size()!=0) { - error("not enough values for GRID_BIN"); - } + if(gbin.size()!=getNumberOfArguments() && gbin.size()!=0) error("not enough values for GRID_BIN"); parseVector("GRID_SPACING",gspacing); - if(gspacing.size()!=getNumberOfArguments() && gspacing.size()!=0) { - error("not enough values for GRID_SPACING"); - } - if(gmin.size()!=gmax.size()) { - error("GRID_MAX and GRID_MIN should be either present or absent"); - } - if(gspacing.size()!=0 && gmin.size()==0) { - error("If GRID_SPACING is present also GRID_MIN and GRID_MAX should be present"); - } - if(gbin.size()!=0 && gmin.size()==0) { - error("If GRID_BIN is present also GRID_MIN and GRID_MAX should be present"); - } + if(gspacing.size()!=getNumberOfArguments() && gspacing.size()!=0) error("not enough values for GRID_SPACING"); + if(gmin.size()!=gmax.size()) error("GRID_MAX and GRID_MIN should be either present or absent"); + if(gspacing.size()!=0 && gmin.size()==0) error("If GRID_SPACING is present also GRID_MIN and GRID_MAX should be present"); + if(gbin.size()!=0 && gmin.size()==0) error("If GRID_BIN is present also GRID_MIN and GRID_MAX should be present"); if(gmin.size()!=0) { if(gbin.size()==0 && gspacing.size()==0) { if(adaptive_==FlexibleBin::none) { log<<" Binsize not specified, 1/5 of sigma will be be used\n"; plumed_assert(sigma0_.size()==getNumberOfArguments()); gspacing.resize(getNumberOfArguments()); - for(unsigned i=0; i0) { - grid_=true; - } + if(gbin.size()>0) grid_=true; bool sparsegrid=false; parseFlag("GRID_SPARSE",sparsegrid); @@ -891,39 +824,32 @@ MetaD::MetaD(const ActionOptions& ao): parse("GRID_WFILE",gridfilename_); parseFlag("STORE_GRIDS",storeOldGrids_); if(grid_ && gridfilename_.length()>0) { - if(wgridstride_==0 ) { - error("frequency with which to output grid not specified use GRID_WSTRIDE"); - } + if(wgridstride_==0 ) error("frequency with which to output grid not specified use GRID_WSTRIDE"); } if(grid_ && wgridstride_>0) { - if(gridfilename_.length()==0) { - error("grid filename not specified use GRID_WFILE"); - } + if(gridfilename_.length()==0) error("grid filename not specified use GRID_WFILE"); } std::string gridreadfilename_; parse("GRID_RFILE",gridreadfilename_); - if(!grid_&&gridfilename_.length()> 0) { - error("To write a grid you need first to define it!"); - } - if(!grid_&&gridreadfilename_.length()>0) { - error("To read a grid you need first to define it!"); - } + if(!grid_&&gridfilename_.length()> 0) error("To write a grid you need first to define it!"); + if(!grid_&&gridreadfilename_.length()>0) error("To read a grid you need first to define it!"); /*setup neighbor list stuff*/ parseFlag("NLIST", nlist_); nlist_center_.resize(getNumberOfArguments()); nlist_dev2_.resize(getNumberOfArguments()); - if(nlist_&&grid_) { - error("NLIST and GRID cannot be combined!"); - } + if(nlist_&&grid_) error("NLIST and GRID cannot be combined!"); std::vector nlist_param; parseVector("NLIST_PARAMETERS",nlist_param); - if(nlist_param.size()==0) { + if(nlist_param.size()==0) + { nlist_param_[0]=6.0;//*DP2CUTOFF -> max distance of neighbors nlist_param_[1]=0.5;//*nlist_dev2_[i] -> condition for rebuilding - } else { + } + else + { plumed_massert(nlist_param.size()==2,"two cutoff parameters are needed for the neighbor list"); plumed_massert(nlist_param[0]>1.0,"the first of NLIST_PARAMETERS must be greater than 1. The smaller the first, the smaller should be the second as well"); const double min_PARAM_1=(1.-1./std::sqrt(nlist_param[0]/2))+0.16; @@ -935,23 +861,17 @@ MetaD::MetaD(const ActionOptions& ao): // Reweighting factor rct parseFlag("CALC_RCT",calc_rct_); - if (calc_rct_) { - plumed_massert(grid_,"CALC_RCT is supported only if bias is on a grid"); - } + if (calc_rct_) plumed_massert(grid_,"CALC_RCT is supported only if bias is on a grid"); parse("RCT_USTRIDE",rct_ustride_); if(dampfactor_>0.0) { - if(!grid_) { - error("With DAMPFACTOR you should use grids"); - } + if(!grid_) error("With DAMPFACTOR you should use grids"); } // Multiple walkers parse("WALKERS_N",mw_n_); parse("WALKERS_ID",mw_id_); - if(mw_n_<=mw_id_) { - error("walker ID should be a numerical value less than the total number of walkers"); - } + if(mw_n_<=mw_id_) error("walker ID should be a numerical value less than the total number of walkers"); parse("WALKERS_DIR",mw_dir_); parse("WALKERS_RSTRIDE",mw_rstride_); @@ -970,20 +890,13 @@ MetaD::MetaD(const ActionOptions& ao): // Inteval keyword std::vector tmpI(2); parseVector("INTERVAL",tmpI); - if(tmpI.size()!=2&&tmpI.size()!=0) { - error("both a lower and an upper limits must be provided with INTERVAL"); - } else if(tmpI.size()==2) { + if(tmpI.size()!=2&&tmpI.size()!=0) error("both a lower and an upper limits must be provided with INTERVAL"); + else if(tmpI.size()==2) { lowI_=tmpI.at(0); uppI_=tmpI.at(1); - if(getNumberOfArguments()!=1) { - error("INTERVAL limits correction works only for monodimensional metadynamics!"); - } - if(uppI_isPeriodic()) { - error("INTERVAL cannot be used with periodic variables!"); - } + if(getNumberOfArguments()!=1) error("INTERVAL limits correction works only for monodimensional metadynamics!"); + if(uppI_isPeriodic()) error("INTERVAL cannot be used with periodic variables!"); doInt_=true; } @@ -1021,15 +934,9 @@ MetaD::MetaD(const ActionOptions& ao): checkRead(); log.printf(" Gaussian width "); - if (adaptive_==FlexibleBin::diffusion) { - log.printf(" (Note: The units of sigma are in timesteps) "); - } - if (adaptive_==FlexibleBin::geometry) { - log.printf(" (Note: The units of sigma are in dist units) "); - } - for(unsigned i=0; i 0.0 || tt_specs_.is_active) { // Determine the number of active temperings. int n_active = 0; - if (welltemp_) { - n_active++; - } - if (dampfactor_ > 0.0) { - n_active++; - } - if (tt_specs_.is_active) { - n_active++; - } + if (welltemp_) n_active++; + if (dampfactor_ > 0.0) n_active++; + if (tt_specs_.is_active) n_active++; // Find the greatest alpha. double greatest_alpha = 0.0; - if (welltemp_) { - greatest_alpha = std::max(greatest_alpha, 1.0); - } - if (dampfactor_ > 0.0) { - greatest_alpha = std::max(greatest_alpha, 1.0); - } - if (tt_specs_.is_active) { - greatest_alpha = std::max(greatest_alpha, tt_specs_.alpha); - } + if (welltemp_) greatest_alpha = std::max(greatest_alpha, 1.0); + if (dampfactor_ > 0.0) greatest_alpha = std::max(greatest_alpha, 1.0); + if (tt_specs_.is_active) greatest_alpha = std::max(greatest_alpha, tt_specs_.alpha); // Find the least alpha. double least_alpha = 1.0; - if (welltemp_) { - least_alpha = std::min(least_alpha, 1.0); - } - if (dampfactor_ > 0.0) { - least_alpha = std::min(least_alpha, 1.0); - } - if (tt_specs_.is_active) { - least_alpha = std::min(least_alpha, tt_specs_.alpha); - } + if (welltemp_) least_alpha = std::min(least_alpha, 1.0); + if (dampfactor_ > 0.0) least_alpha = std::min(least_alpha, 1.0); + if (tt_specs_.is_active) least_alpha = std::min(least_alpha, tt_specs_.alpha); // Find the inverse harmonic average of the delta T parameters for all // of the temperings with the greatest alpha values. double total_governing_deltaT_inv = 0.0; - if (welltemp_ && 1.0 == greatest_alpha && biasf_ != 1.0) { - total_governing_deltaT_inv += 1.0 / (biasf_ - 1.0); - } - if (dampfactor_ > 0.0 && 1.0 == greatest_alpha) { - total_governing_deltaT_inv += 1.0 / (dampfactor_); - } - if (tt_specs_.is_active && tt_specs_.alpha == greatest_alpha) { - total_governing_deltaT_inv += 1.0 / (tt_specs_.biasf - 1.0); - } + if (welltemp_ && 1.0 == greatest_alpha && biasf_ != 1.0) total_governing_deltaT_inv += 1.0 / (biasf_ - 1.0); + if (dampfactor_ > 0.0 && 1.0 == greatest_alpha) total_governing_deltaT_inv += 1.0 / (dampfactor_); + if (tt_specs_.is_active && tt_specs_.alpha == greatest_alpha) total_governing_deltaT_inv += 1.0 / (tt_specs_.biasf - 1.0); // Give a newbie-friendly error message for people using one tempering if // only one is active. if (n_active == 1 && total_governing_deltaT_inv < 0.0) { @@ -1119,53 +1002,33 @@ MetaD::MetaD(const ActionOptions& ao): } } - if(doInt_) { - log.printf(" Upper and Lower limits boundaries for the bias are activated at %f - %f\n", lowI_, uppI_); - } + if(doInt_) log.printf(" Upper and Lower limits boundaries for the bias are activated at %f - %f\n", lowI_, uppI_); if(grid_) { log.printf(" Grid min"); - for(unsigned i=0; i0) { - log.printf(" Grid is written on file %s with stride %d\n",gridfilename_.c_str(),wgridstride_); - } + if(spline) {log.printf(" Grid uses spline interpolation\n");} + if(sparsegrid) {log.printf(" Grid uses sparse grid\n");} + if(wgridstride_>0) {log.printf(" Grid is written on file %s with stride %d\n",gridfilename_.c_str(),wgridstride_);} } if(mw_n_>1) { - if(walkers_mpi_) { - error("MPI version of multiple walkers is not compatible with filesystem version of multiple walkers"); - } + if(walkers_mpi_) error("MPI version of multiple walkers is not compatible with filesystem version of multiple walkers"); log.printf(" %d multiple walkers active\n",mw_n_); log.printf(" walker id %d\n",mw_id_); log.printf(" reading stride %d\n",mw_rstride_); - if(mw_dir_!="") { - log.printf(" directory with hills files %s\n",mw_dir_.c_str()); - } + if(mw_dir_!="")log.printf(" directory with hills files %s\n",mw_dir_.c_str()); } else { if(walkers_mpi_) { log.printf(" Multiple walkers active using MPI communnication\n"); - if(mw_dir_!="") { - log.printf(" directory with hills files %s\n",mw_dir_.c_str()); - } + if(mw_dir_!="")log.printf(" directory with hills files %s\n",mw_dir_.c_str()); if(comm.Get_rank()==0) { // Only root of group can communicate with other walkers mpi_nw_=multi_sim_comm.Get_size(); @@ -1177,9 +1040,7 @@ MetaD::MetaD(const ActionOptions& ao): } if(flying_) { - if(!walkers_mpi_) { - error("Flying Gaussian method must be used with MPI version of multiple walkers"); - } + if(!walkers_mpi_) error("Flying Gaussian method must be used with MPI version of multiple walkers"); log.printf(" Flying Gaussian method with %d walkers active\n",mpi_nw_); } @@ -1191,26 +1052,20 @@ MetaD::MetaD(const ActionOptions& ao): } if(calc_rct_) { - addComponent("rbias"); - componentIsNotPeriodic("rbias"); - addComponent("rct"); - componentIsNotPeriodic("rct"); + addComponent("rbias"); componentIsNotPeriodic("rbias"); + addComponent("rct"); componentIsNotPeriodic("rct"); log.printf(" The c(t) reweighting factor will be calculated every %u hills\n",rct_ustride_); getPntrToComponent("rct")->set(reweight_factor_); } - if(calc_work_) { - addComponent("work"); - componentIsNotPeriodic("work"); - } + if(calc_work_) { addComponent("work"); componentIsNotPeriodic("work"); } if(acceleration_) { if (kbt_ == 0.0) { error("The calculation of the acceleration works only if simulation temperature has been defined"); } log.printf(" calculation on the fly of the acceleration factor\n"); - addComponent("acc"); - componentIsNotPeriodic("acc"); + addComponent("acc"); componentIsNotPeriodic("acc"); // Set the initial value of the the acceleration. // If this is not a restart, set to 1.0. if (acc_rfilename.length() == 0) { @@ -1244,9 +1099,7 @@ MetaD::MetaD(const ActionOptions& ao): acc_rfile.scanField(); found=true; } - if(!found) { - error("The ACCELERATION_RFILE file you want to read: " + acc_rfilename + ", does not contain a time field!"); - } + if(!found) error("The ACCELERATION_RFILE file you want to read: " + acc_rfilename + ", does not contain a time field!"); acc_restart_mean_ = acc_rmean; // Set component based on the read values. getPntrToComponent("acc")->set(acc_rmean); @@ -1255,45 +1108,33 @@ MetaD::MetaD(const ActionOptions& ao): } if (calc_max_bias_) { - if (!grid_) { - error("Calculating the maximum bias on the fly works only with a grid"); - } + if (!grid_) error("Calculating the maximum bias on the fly works only with a grid"); log.printf(" calculation on the fly of the maximum bias max(V(s,t)) \n"); addComponent("maxbias"); componentIsNotPeriodic("maxbias"); } if (calc_transition_bias_) { - if (!grid_) { - error("Calculating the transition bias on the fly works only with a grid"); - } + if (!grid_) error("Calculating the transition bias on the fly works only with a grid"); log.printf(" calculation on the fly of the transition bias V*(t)\n"); addComponent("transbias"); componentIsNotPeriodic("transbias"); log<<" Number of transition wells "< max) { - error(" transition well is not in grid"); - } + if (transitionwells_[i][j] < min || transitionwells_[i][j] > max) error(" transition well is not in grid"); } } } @@ -1319,8 +1160,7 @@ MetaD::MetaD(const ActionOptions& ao): if(fa_max_stride_!=0) { log.printf(" The hill addition frequency will not become larger than %d steps\n",fa_max_stride_); } - addComponent("pace"); - componentIsNotPeriodic("pace"); + addComponent("pace"); componentIsNotPeriodic("pace"); updateFrequencyAdaptiveStride(); } @@ -1335,35 +1175,22 @@ MetaD::MetaD(const ActionOptions& ao): Tools::convert(gmax[i],b); double mesh=(b-a)/((double)gbin[i]); if(adaptive_==FlexibleBin::none) { - if(mesh>0.5*sigma0_[i]) { - log<<" WARNING: Using a METAD with a Grid Spacing larger than half of the Gaussians width (SIGMA) can produce artifacts\n"; - } + if(mesh>0.5*sigma0_[i]) log<<" WARNING: Using a METAD with a Grid Spacing larger than half of the Gaussians width (SIGMA) can produce artifacts\n"; } else { - if(sigma0min_[i]<0.) { - error("When using ADAPTIVE Gaussians on a grid SIGMA_MIN must be specified"); - } - if(mesh>0.5*sigma0min_[i]) { - log<<" WARNING: to use a METAD with a GRID and ADAPTIVE you need to set a Grid Spacing lower than half of the Gaussians (SIGMA_MIN) \n"; - } + if(sigma0min_[i]<0.) error("When using ADAPTIVE Gaussians on a grid SIGMA_MIN must be specified"); + if(mesh>0.5*sigma0min_[i]) log<<" WARNING: to use a METAD with a GRID and ADAPTIVE you need to set a Grid Spacing lower than half of the Gaussians (SIGMA_MIN) \n"; } } std::string funcl=getLabel() + ".bias"; - if(!sparsegrid) { - BiasGrid_=Tools::make_unique(funcl,getArguments(),gmin,gmax,gbin,spline,true); - } else { - BiasGrid_=Tools::make_unique(funcl,getArguments(),gmin,gmax,gbin,spline,true); - } + if(!sparsegrid) {BiasGrid_=Tools::make_unique(funcl,getArguments(),gmin,gmax,gbin,spline,true);} + else {BiasGrid_=Tools::make_unique(funcl,getArguments(),gmin,gmax,gbin,spline,true);} std::vector actualmin=BiasGrid_->getMin(); std::vector actualmax=BiasGrid_->getMax(); for(unsigned i=0; igetDimension()!=getNumberOfArguments()) { - error("mismatch between dimensionality of input grid and number of arguments"); - } + if(BiasGrid_->getDimension()!=getNumberOfArguments()) error("mismatch between dimensionality of input grid and number of arguments"); for(unsigned i=0; iisPeriodic()!=BiasGrid_->getIsPeriodic()[i] ) { - error("periodicity mismatch between arguments and input bias"); - } + if( getPntrToArgument(i)->isPeriodic()!=BiasGrid_->getIsPeriodic()[i] ) error("periodicity mismatch between arguments and input bias"); double a, b; Tools::convert(gmin[i],a); Tools::convert(gmax[i],b); double mesh=(b-a)/((double)gbin[i]); - if(mesh>0.5*sigma0_[i]) { - log<<" WARNING: Using a METAD with a Grid Spacing larger than half of the Gaussians width can produce artifacts\n"; - } + if(mesh>0.5*sigma0_[i]) log<<" WARNING: Using a METAD with a Grid Spacing larger than half of the Gaussians width can produce artifacts\n"; } log.printf(" Restarting from %s\n",gridreadfilename_.c_str()); - if(getRestart()) { - restartedFromGrid=true; - } + if(getRestart()) restartedFromGrid=true; } } // if we are restarting from GRID and using WALKERS_MPI we can check that all walkers have actually read the grid if(getRestart()&&walkers_mpi_) { std::vector restarted(mpi_nw_,0); - if(comm.Get_rank()==0) { - multi_sim_comm.Allgather(int(restartedFromGrid), restarted); - } + if(comm.Get_rank()==0) multi_sim_comm.Allgather(int(restartedFromGrid), restarted); comm.Bcast(restarted,0); int result = std::accumulate(restarted.begin(),restarted.end(),0); - if(result!=0&&result!=mpi_nw_) { - error("in this WALKERS_MPI run some replica have restarted from GRID while other do not!"); - } + if(result!=0&&result!=mpi_nw_) error("in this WALKERS_MPI run some replica have restarted from GRID while other do not!"); } #ifdef __PLUMED_HAS_GETCWD @@ -1433,9 +1246,7 @@ MetaD::MetaD(const ActionOptions& ao): plumed_assert(ret)<<"Name of current directory too long, increase buffer size"; mw_dir_ = ret; mw_dir_ = mw_dir_ + "/"; - if(comm.Get_rank()==0) { - multi_sim_comm.Bcast(mw_dir_,0); - } + if(comm.Get_rank()==0) multi_sim_comm.Bcast(mw_dir_,0); comm.Bcast(mw_dir_,0); } #endif @@ -1447,8 +1258,7 @@ MetaD::MetaD(const ActionOptions& ao): std::string fname; if(mw_dir_!="") { if(mw_n_>1) { - std::stringstream out; - out << i; + std::stringstream out; out << i; fname = mw_dir_+"/"+hillsfname+"."+out.str(); } else if(walkers_mpi_) { fname = mw_dir_+"/"+hillsfname; @@ -1457,8 +1267,7 @@ MetaD::MetaD(const ActionOptions& ao): } } else { if(mw_n_>1) { - std::stringstream out; - out << i; + std::stringstream out; out << i; fname = hillsfname+"."+out.str(); } else { fname = hillsfname; @@ -1478,28 +1287,20 @@ MetaD::MetaD(const ActionOptions& ao): } ifiles_[i]->reset(false); // close only the walker own hills file for later writing - if(i==mw_id_) { - ifiles_[i]->close(); - } + if(i==mw_id_) ifiles_[i]->close(); } else { // in case a file does not exist and we are restarting, complain that the file was not found - if(getRestart()&&!restartedFromGrid) { - error("restart file "+fname+" not found"); - } + if(getRestart()&&!restartedFromGrid) error("restart file "+fname+" not found"); } } // if we are restarting from FILE and using WALKERS_MPI we can check that all walkers have actually read the FILE if(getRestart()&&walkers_mpi_) { std::vector restarted(mpi_nw_,0); - if(comm.Get_rank()==0) { - multi_sim_comm.Allgather(int(restartedFromHills), restarted); - } + if(comm.Get_rank()==0) multi_sim_comm.Allgather(int(restartedFromHills), restarted); comm.Bcast(restarted,0); int result = std::accumulate(restarted.begin(),restarted.end(),0); - if(result!=0&&result!=mpi_nw_) { - error("in this WALKERS_MPI run some replica have restarted from FILE while other do not!"); - } + if(result!=0&&result!=mpi_nw_) error("in this WALKERS_MPI run some replica have restarted from FILE while other do not!"); } comm.Barrier(); @@ -1510,34 +1311,23 @@ MetaD::MetaD(const ActionOptions& ao): // it would introduce troubles when using replicas without METAD // (e.g. in bias exchange with a neutral replica) // see issue #168 on github - if(comm.Get_rank()==0 && walkers_mpi_) { - multi_sim_comm.Barrier(); - } + if(comm.Get_rank()==0 && walkers_mpi_) multi_sim_comm.Barrier(); if(targetfilename_.length()>0) { - IFile gridfile; - gridfile.open(targetfilename_); + IFile gridfile; gridfile.open(targetfilename_); std::string funcl=getLabel() + ".target"; TargetGrid_=GridBase::create(funcl,getArguments(),gridfile,false,false,true); - if(TargetGrid_->getDimension()!=getNumberOfArguments()) { - error("mismatch between dimensionality of input grid and number of arguments"); - } + if(TargetGrid_->getDimension()!=getNumberOfArguments()) error("mismatch between dimensionality of input grid and number of arguments"); for(unsigned i=0; iisPeriodic()!=TargetGrid_->getIsPeriodic()[i] ) { - error("periodicity mismatch between arguments and input bias"); - } + if( getPntrToArgument(i)->isPeriodic()!=TargetGrid_->getIsPeriodic()[i] ) error("periodicity mismatch between arguments and input bias"); } } if(getRestart()) { // if this is a restart the neighbor list should be immediately updated - if(nlist_) { - nlist_update_=true; - } + if(nlist_) nlist_update_=true; // Calculate the Tiwary-Parrinello reweighting factor if we are restarting from previous hills - if(calc_rct_) { - computeReweightingFactor(); - } + if(calc_rct_) computeReweightingFactor(); // Calculate all special bias quantities desired if restarting with nonzero bias. if(calc_max_bias_) { max_bias_ = BiasGrid_->getMaxValue(); @@ -1554,18 +1344,12 @@ MetaD::MetaD(const ActionOptions& ao): gridfile_.link(*this); if(walkers_mpi_) { int r=0; - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) r=multi_sim_comm.Get_rank(); comm.Bcast(r,0); - if(r>0) { - gridfilename_="/dev/null"; - } - gridfile_.enforceSuffix(""); - } - if(mw_n_>1) { + if(r>0) gridfilename_="/dev/null"; gridfile_.enforceSuffix(""); } + if(mw_n_>1) gridfile_.enforceSuffix(""); gridfile_.open(gridfilename_); } @@ -1573,22 +1357,14 @@ MetaD::MetaD(const ActionOptions& ao): hillsOfile_.link(*this); if(walkers_mpi_) { int r=0; - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) r=multi_sim_comm.Get_rank(); comm.Bcast(r,0); - if(r>0) { - ifilesnames_[mw_id_]="/dev/null"; - } - hillsOfile_.enforceSuffix(""); - } - if(mw_n_>1) { + if(r>0) ifilesnames_[mw_id_]="/dev/null"; hillsOfile_.enforceSuffix(""); } + if(mw_n_>1) hillsOfile_.enforceSuffix(""); hillsOfile_.open(ifilesnames_[mw_id_]); - if(fmt_.length()>0) { - hillsOfile_.fmtField(fmt_); - } + if(fmt_.length()>0) hillsOfile_.fmtField(fmt_); hillsOfile_.addConstantField("multivariate"); hillsOfile_.addConstantField("kerneltype"); if(doInt_) { @@ -1597,20 +1373,12 @@ MetaD::MetaD(const ActionOptions& ao): } hillsOfile_.setHeavyFlush(); // output periodicities of variables - for(unsigned i=0; i(p.get())) { - concurrent=true; - break; - } - if(concurrent) { - log<<" You are using concurrent metadynamics\n"; - } + for(const auto & p : actionSet) if(dynamic_cast(p.get())) { concurrent=true; break; } + if(concurrent) log<<" You are using concurrent metadynamics\n"; if(rect_biasf_.size()>0) { if(walkers_mpi_) { log<<" You are using RECT in its 'altruistic' implementation\n"; @@ -1620,46 +1388,29 @@ MetaD::MetaD(const ActionOptions& ao): } log<<" Bibliography "<1||walkers_mpi_) { - log<0) { - log<0 && walkers_mpi_) { - log<1||walkers_mpi_) log<0) log<0 && walkers_mpi_) log<0) { log< center(ncv); std::vector sigma(ncv); @@ -1701,22 +1450,20 @@ void MetaD::readGaussians(IFile *ifile) { bool multivariate=false; std::vector tmpvalues; - for(unsigned j=0; jgetName(), false ) ); - } + for(unsigned j=0; jgetName(), false ) ); - while(scanOneHill(ifile,tmpvalues,center,sigma,height,multivariate)) { + while(scanOneHill(ifile,tmpvalues,center,sigma,height,multivariate)) + { nhills++; // note that for gamma=1 we store directly -F - if(welltemp_ && biasf_>1.0) { - height*=(biasf_-1.0)/biasf_; - } + if(welltemp_ && biasf_>1.0) height*=(biasf_-1.0)/biasf_; addGaussian(Gaussian(multivariate,height,center,sigma)); } log.printf(" %d Gaussians read\n",nhills); } -void MetaD::writeGaussian(const Gaussian& hill, OFile&file) { +void MetaD::writeGaussian(const Gaussian& hill, OFile&file) +{ unsigned ncv=getNumberOfArguments(); file.printField("time",getTimeStep()*getStep()); for(unsigned i=0; igetName(),hill.sigma[i]); - } } double height=hill.height; // note that for gamma=1 we store directly -F - if(welltemp_ && biasf_>1.0) { - height*=biasf_/(biasf_-1.0); - } + if(welltemp_ && biasf_>1.0) height*=biasf_/(biasf_-1.0); file.printField("height",height).printField("biasf",biasf_); - if(mw_n_>1) { - file.printField("clock",int(std::time(0))); - } + if(mw_n_>1) file.printField("clock",int(std::time(0))); file.printField(); } -void MetaD::addGaussian(const Gaussian& hill) { +void MetaD::addGaussian(const Gaussian& hill) +{ if(grid_) { size_t ncv=getNumberOfArguments(); std::vector nneighb=getGaussianSupport(hill); @@ -1783,9 +1526,7 @@ void MetaD::addGaussian(const Gaussian& hill) { std::vector dp(ncv); for(size_t i=0; igetPoint(ineigh,xx); double bias=evaluateGaussianAndDerivatives(xx,hill,der,dp); BiasGrid_->addValueAndDerivatives(ineigh,bias,der); @@ -1800,31 +1541,24 @@ void MetaD::addGaussian(const Gaussian& hill) { std::vector dp(ncv); for(unsigned i=rank; igetPoint(ineigh,xx); allbias[i]=evaluateGaussianAndDerivatives(xx,hill,n_der,dp); - for(unsigned j=0; jaddValueAndDerivatives(ineigh,allbias[i],der); } } - } else { - hills_.push_back(hill); - } + } else hills_.push_back(hill); } -std::vector MetaD::getGaussianSupport(const Gaussian& hill) { +std::vector MetaD::getGaussianSupport(const Gaussian& hill) +{ std::vector nneigh; std::vector cutoff; unsigned ncv=getNumberOfArguments(); @@ -1847,13 +1581,9 @@ std::vector MetaD::getGaussianSupport(const Gaussian& hill) { std::vector myautoval(ncv); //should I take this or their square root? diagMat(myinv,myautoval,myautovec); double maxautoval=0.; - unsigned ind_maxautoval; - ind_maxautoval=ncv; + unsigned ind_maxautoval; ind_maxautoval=ncv; for(unsigned i=0; imaxautoval) { - maxautoval=myautoval[i]; - ind_maxautoval=i; - } + if(myautoval[i]>maxautoval) {maxautoval=myautoval[i]; ind_maxautoval=i;} } for(unsigned i=0; i MetaD::getGaussianSupport(const Gaussian& hill) { return nneigh; } -double MetaD::getBias(const std::vector& cv) { +double MetaD::getBias(const std::vector& cv) +{ double bias=0.0; - if(grid_) { - bias = BiasGrid_->getValue(cv); - } else { + if(grid_) bias = BiasGrid_->getValue(cv); + else { unsigned nt=OpenMP::getNumThreads(); unsigned stride=comm.Get_size(); unsigned rank=comm.Get_rank(); @@ -1894,17 +1624,13 @@ double MetaD::getBias(const std::vector& cv) { #pragma omp parallel num_threads(nt) { #pragma omp for reduction(+:bias) nowait - for(unsigned i=rank; i& cv) { return bias; } -double MetaD::getBiasAndDerivatives(const std::vector& cv, std::vector& der) { +double MetaD::getBiasAndDerivatives(const std::vector& cv, std::vector& der) +{ unsigned ncv=getNumberOfArguments(); double bias=0.0; if(grid_) { std::vector vder(ncv); bias=BiasGrid_->getValueAndDerivatives(cv,vder); - for(unsigned i=0; i& cv, std::vector& cv, std::vector& cv, std::vector(ncv)/2.0); } -double MetaD::evaluateGaussian(const std::vector& cv, const Gaussian& hill) { +double MetaD::evaluateGaussian(const std::vector& cv, const Gaussian& hill) +{ unsigned ncv=cv.size(); // I use a pointer here because cv is const (and should be const) @@ -2015,18 +1735,12 @@ double MetaD::evaluateGaussian(const std::vector& cv, const Gaussian& hi // the upper/lower limit in case it is out of range double tmpcv[1]; const double *pcv=NULL; // pointer to cv - if(ncv>0) { - pcv=&cv[0]; - } + if(ncv>0) pcv=&cv[0]; if(doInt_) { plumed_assert(ncv==1); tmpcv[0]=cv[0]; - if(cv[0]uppI_) { - tmpcv[0]=uppI_; - } + if(cv[0]uppI_) tmpcv[0]=uppI_; pcv=&(tmpcv[0]); } @@ -2061,14 +1775,13 @@ double MetaD::evaluateGaussian(const std::vector& cv, const Gaussian& hi } double bias=0.0; - if(dp2& cv, const Gaussian& hill, std::vector& der, std::vector& dp_) { +double MetaD::evaluateGaussianAndDerivatives(const std::vector& cv, const Gaussian& hill, std::vector& der, std::vector& dp_) +{ unsigned ncv=cv.size(); // I use a pointer here because cv is const (and should be const) @@ -2076,26 +1789,18 @@ double MetaD::evaluateGaussianAndDerivatives(const std::vector& cv, cons // the upper/lower limit in case it is out of range const double *pcv=NULL; // pointer to cv double tmpcv[1]; // tmp array with cv (to be used with doInt_) - if(ncv>0) { - pcv=&cv[0]; - } + if(ncv>0) pcv=&cv[0]; if(doInt_) { plumed_assert(ncv==1); tmpcv[0]=cv[0]; - if(cv[0]uppI_) { - tmpcv[0]=uppI_; - } + if(cv[0]uppI_) tmpcv[0]=uppI_; pcv=&(tmpcv[0]); } bool int_der=false; if(doInt_) { - if(cv[0]uppI_) { - int_der=true; - } + if(cv[0]uppI_) int_der=true; } double dp2=0.0; @@ -2126,15 +1831,11 @@ double MetaD::evaluateGaussianAndDerivatives(const std::vector& cv, cons if(!int_der) { for(unsigned i=0; i& cv, cons if(dp2& cv, cons return bias; } -double MetaD::getHeight(const std::vector& cv) { +double MetaD::getHeight(const std::vector& cv) +{ double height=height0_; if(welltemp_) { double vbias = getBias(cv); @@ -2189,7 +1887,8 @@ double MetaD::getHeight(const std::vector& cv) { return height; } -void MetaD::temperHeight(double& height, const TemperingSpecs& t_specs, const double tempering_bias) { +void MetaD::temperHeight(double& height, const TemperingSpecs& t_specs, const double tempering_bias) +{ if (t_specs.alpha == 1.0) { height *= std::exp(-std::max(0.0, tempering_bias - t_specs.threshold) / (kbt_ * (t_specs.biasf - 1.0))); } else { @@ -2197,54 +1896,37 @@ void MetaD::temperHeight(double& height, const TemperingSpecs& t_specs, const do } } -void MetaD::calculate() { +void MetaD::calculate() +{ // this is because presently there is no way to properly pass information // on adaptive hills (diff) after exchanges: - if(adaptive_==FlexibleBin::diffusion && getExchangeStep()) { - error("ADAPTIVE=DIFF is not compatible with replica exchange"); - } + if(adaptive_==FlexibleBin::diffusion && getExchangeStep()) error("ADAPTIVE=DIFF is not compatible with replica exchange"); const unsigned ncv=getNumberOfArguments(); std::vector cv(ncv); - for(unsigned i=0; inlist_param_[1]) { - nlist_update_=true; - break; - } + if(nk_dist2>nlist_param_[1]) {nlist_update_=true; break;} } } - if(nlist_update_) { - updateNlist(); - } + if(nlist_update_) updateNlist(); } double ene = 0.; std::vector der(ncv,0.); - if(biasf_!=1.0) { - ene = getBiasAndDerivatives(cv,der); - } + if(biasf_!=1.0) ene = getBiasAndDerivatives(cv,der); setBias(ene); - for(unsigned i=0; iset(work_); - } - if(calc_rct_) { - getPntrToComponent("rbias")->set(ene - reweight_factor_); - } + if(calc_work_) getPntrToComponent("work")->set(work_); + if(calc_rct_) getPntrToComponent("rbias")->set(ene - reweight_factor_); // calculate the acceleration factor if(acceleration_&&!isFirstStep_) { acc_ += static_cast(getStride()) * std::exp(ene/(kbt_)); @@ -2259,26 +1941,22 @@ void MetaD::calculate() { } } -void MetaD::update() { +void MetaD::update() +{ // adding hills criteria (could be more complex though) bool nowAddAHill; - if(getStep()%current_stride_==0 && !isFirstStep_) { - nowAddAHill=true; - } else { + if(getStep()%current_stride_==0 && !isFirstStep_) nowAddAHill=true; + else { nowAddAHill=false; isFirstStep_=false; } unsigned ncv=getNumberOfArguments(); std::vector cv(ncv); - for(unsigned i=0; igetInverseMatrix(); - } + if(adaptive_!=FlexibleBin::none) thissigma=flexbin_->getInverseMatrix(); // returns normal sigma - else { - thissigma=sigma0_; - } + else thissigma=sigma0_; // In case we use walkers_mpi, it is now necessary to communicate with other replicas. if(walkers_mpi_) { @@ -2331,19 +2005,13 @@ void MetaD::update() { // actually add hills one by one std::vector cv_now(ncv); std::vector sigma_now(thissigma.size()); - for(unsigned j=0; j1.0?(biasf_-1.0)/biasf_:1.0); Gaussian newhill=Gaussian(all_multivariate[i],all_height[i]*fact,cv_now,sigma_now); addGaussian(newhill); - if(!flying_) { - writeGaussian(newhill,hillsOfile_); - } + if(!flying_) writeGaussian(newhill,hillsOfile_); } } else { Gaussian newhill=Gaussian(multivariate,height,cv,thissigma); @@ -2352,21 +2020,15 @@ void MetaD::update() { } // this is to update the hills neighbor list - if(nlist_) { - nlist_update_=true; - } + if(nlist_) nlist_update_=true; } // this should be outside of the if block in case // mw_rstride_ is not a multiple of stride_ - if(mw_n_>1 && getStep()%mw_rstride_==0) { - hillsOfile_.flush(); - } + if(mw_n_>1 && getStep()%mw_rstride_==0) hillsOfile_.flush(); if(calc_work_) { - if(nlist_) { - updateNlist(); - } + if(nlist_) updateNlist(); double vbias1=getBias(cv); work_+=vbias1-vbias; } @@ -2375,22 +2037,16 @@ void MetaD::update() { if(wgridstride_>0&&(getStep()%wgridstride_==0||getCPT())) { // in case old grids are stored, a sequence of grids should appear // this call results in a repetition of the header: - if(storeOldGrids_) { - gridfile_.clearFields(); - } + if(storeOldGrids_) gridfile_.clearFields(); // in case only latest grid is stored, file should be rewound // this will overwrite previously written grids else { int r = 0; if(walkers_mpi_) { - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) r=multi_sim_comm.Get_rank(); comm.Bcast(r,0); } - if(r==0) { - gridfile_.rewind(); - } + if(r==0) gridfile_.rewind(); } BiasGrid_->writeToFile(gridfile_); // if a single grid is stored, it is necessary to flush it, otherwise @@ -2399,18 +2055,14 @@ void MetaD::update() { // on the other hand, if grids are stored one after the other this is // no necessary, and we leave the flushing control to the user as usual // (with FLUSH keyword) - if(!storeOldGrids_) { - gridfile_.flush(); - } + if(!storeOldGrids_) gridfile_.flush(); } // if multiple walkers and time to read Gaussians if(mw_n_>1 && getStep()%mw_rstride_==0) { for(int i=0; iisOpen())) { // check if it exists now and open it! @@ -2426,16 +2078,12 @@ void MetaD::update() { } } // this is to update the hills neighbor list - if(nlist_) { - nlist_update_=true; - } + if(nlist_) nlist_update_=true; } // Recalculate special bias quantities whenever the bias has been changed by the update. bool bias_has_changed = (nowAddAHill || (mw_n_ > 1 && getStep() % mw_rstride_ == 0)); - if (calc_rct_ && bias_has_changed && getStep()%(stride_*rct_ustride_)==0) { - computeReweightingFactor(); - } + if (calc_rct_ && bias_has_changed && getStep()%(stride_*rct_ustride_)==0) computeReweightingFactor(); if (calc_max_bias_ && bias_has_changed) { max_bias_ = BiasGrid_->getMaxValue(); getPntrToComponent("maxbias")->set(max_bias_); @@ -2452,7 +2100,8 @@ void MetaD::update() { } /// takes a pointer to the file and a template std::string with values v and gives back the next center, sigma and height -bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector& center, std::vector& sigma, double& height, bool& multivariate) { +bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector& center, std::vector& sigma, double& height, bool& multivariate) +{ double dummy; multivariate=false; if(ifile->scanField("time",dummy)) { @@ -2462,10 +2111,8 @@ bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector if( tmpvalues[i].isPeriodic() && ! getPntrToArgument(i)->isPeriodic() ) { error("in hills file periodicity for variable " + tmpvalues[i].getName() + " does not match periodicity in input"); } else if( tmpvalues[i].isPeriodic() ) { - std::string imin, imax; - tmpvalues[i].getDomain( imin, imax ); - std::string rmin, rmax; - getPntrToArgument(i)->getDomain( rmin, rmax ); + std::string imin, imax; tmpvalues[i].getDomain( imin, imax ); + std::string rmin, rmax; getPntrToArgument(i)->getDomain( rmin, rmax ); if( imin!=rmin || imax!=rmax ) { error("in hills file periodicity for variable " + tmpvalues[i].getName() + " does not match periodicity in input"); } @@ -2474,9 +2121,7 @@ bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector } // scan for kerneltype std::string ktype="stretched-gaussian"; - if( ifile->FieldExist("kerneltype") ) { - ifile->scanField("kerneltype",ktype); - } + if( ifile->FieldExist("kerneltype") ) ifile->scanField("kerneltype",ktype); if( ktype=="gaussian" ) { noStretchWarning(); } else if( ktype!="stretched-gaussian") { @@ -2485,13 +2130,9 @@ bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector // scan for multivariate label: record the actual file position so to eventually rewind std::string sss; ifile->scanField("multivariate",sss); - if(sss=="true") { - multivariate=true; - } else if(sss=="false") { - multivariate=false; - } else { - plumed_merror("cannot parse multivariate = "+ sss); - } + if(sss=="true") multivariate=true; + else if(sss=="false") multivariate=false; + else plumed_merror("cannot parse multivariate = "+ sss); if(multivariate) { sigma.resize(ncv*(ncv+1)/2); Matrix upper(ncv,ncv); @@ -2523,15 +2164,9 @@ bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector ifile->scanField("height",height); ifile->scanField("biasf",dummy); - if(ifile->FieldExist("clock")) { - ifile->scanField("clock",dummy); - } - if(ifile->FieldExist("lower_int")) { - ifile->scanField("lower_int",dummy); - } - if(ifile->FieldExist("upper_int")) { - ifile->scanField("upper_int",dummy); - } + if(ifile->FieldExist("clock")) ifile->scanField("clock",dummy); + if(ifile->FieldExist("lower_int")) ifile->scanField("lower_int",dummy); + if(ifile->FieldExist("upper_int")) ifile->scanField("upper_int",dummy); ifile->scanField(); return true; } else { @@ -2539,7 +2174,8 @@ bool MetaD::scanOneHill(IFile* ifile, std::vector& tmpvalues, std::vector } } -void MetaD::computeReweightingFactor() { +void MetaD::computeReweightingFactor() +{ if(biasf_==1.0) { // in this case we have no bias, so reweight factor is 0.0 getPntrToComponent("rct")->set(0.0); return; @@ -2569,7 +2205,8 @@ void MetaD::computeReweightingFactor() { getPntrToComponent("rct")->set(reweight_factor_); } -double MetaD::getTransitionBarrierBias() { +double MetaD::getTransitionBarrierBias() +{ // If there is only one well of interest, return the bias at that well point. if (transitionwells_.size() == 1) { double tb_bias = getBias(transitionwells_[0]); @@ -2602,15 +2239,14 @@ double MetaD::getTransitionBarrierBias() { } } -void MetaD::updateFrequencyAdaptiveStride() { +void MetaD::updateFrequencyAdaptiveStride() +{ plumed_massert(freq_adaptive_,"should only be used if frequency adaptive metadynamics is enabled"); plumed_massert(acceleration_,"frequency adaptive metadynamics can only be used if the acceleration factor is calculated"); const double mean_acc = acc_/((double) getStep()); int tmp_stride= stride_*floor((mean_acc/fa_min_acceleration_)+0.5); if(mean_acc >= fa_min_acceleration_) { - if(tmp_stride > current_stride_) { - current_stride_ = tmp_stride; - } + if(tmp_stride > current_stride_) {current_stride_ = tmp_stride;} } if(fa_max_stride_!=0 && current_stride_>fa_max_stride_) { current_stride_=fa_max_stride_; @@ -2618,44 +2254,37 @@ void MetaD::updateFrequencyAdaptiveStride() { getPntrToComponent("pace")->set(current_stride_); } -bool MetaD::checkNeedsGradients()const { +bool MetaD::checkNeedsGradients()const +{ if(adaptive_==FlexibleBin::geometry) { - if(getStep()%stride_==0 && !isFirstStep_) { - return true; - } else { - return false; - } - } else { - return false; - } + if(getStep()%stride_==0 && !isFirstStep_) return true; + else return false; + } else return false; } -void MetaD::updateNlist() { +void MetaD::updateNlist() +{ // no need to check for neighbors - if(hills_.size()==0) { - return; - } + if(hills_.size()==0) return; // here we generate the neighbor list nlist_hills_.clear(); std::vector local_flat_nl; unsigned nt=OpenMP::getNumThreads(); - if(hills_.size()<2*nt) { - nt=1; - } + if(hills_.size()<2*nt) nt=1; #pragma omp parallel num_threads(nt) { std::vector private_flat_nl; #pragma omp for nowait - for(unsigned k=0; k dev2; dev2.resize(getNumberOfArguments(),0); - for(unsigned k=0; k0.) { - nlist_dev2_[i]=dev2[i]/static_cast(nlist_hills_.size()); - } else { - nlist_dev2_[i]=hills_.back().sigma[i]*hills_.back().sigma[i]; - } + if(dev2[i]>0.) nlist_dev2_[i]=dev2[i]/static_cast(nlist_hills_.size()); + else nlist_dev2_[i]=hills_.back().sigma[i]*hills_.back().sigma[i]; } // we are done diff --git a/src/bias/MovingRestraint.cpp b/src/bias/MovingRestraint.cpp index 4df16e2edc..5065d2476c 100644 --- a/src/bias/MovingRestraint.cpp +++ b/src/bias/MovingRestraint.cpp @@ -149,33 +149,25 @@ void MovingRestraint::registerKeywords( Keywords& keys ) { MovingRestraint::MovingRestraint(const ActionOptions&ao): PLUMED_BIAS_INIT(ao), - verse(getNumberOfArguments()) { + verse(getNumberOfArguments()) +{ parseVector("VERSE",verse); - std::vector ss(1); - ss[0]=-1; + std::vector ss(1); ss[0]=-1; std::vector kk( getNumberOfArguments() ), aa( getNumberOfArguments() ); for(int i=0;; i++) { // Read in step - if( !parseNumberedVector("STEP",i,ss) ) { - break; - } + if( !parseNumberedVector("STEP",i,ss) ) break; for(unsigned j=0; jgetName()+"_cntr"; // each spring has its own center - addComponent(comp); - componentIsNotPeriodic(comp); + addComponent(comp); componentIsNotPeriodic(comp); comp=getPntrToArgument(i)->getName()+"_work"; // each spring has its own work - addComponent(comp); - componentIsNotPeriodic(comp); + addComponent(comp); componentIsNotPeriodic(comp); comp=getPntrToArgument(i)->getName()+"_kappa"; // each spring has its own kappa - addComponent(comp); - componentIsNotPeriodic(comp); + addComponent(comp); componentIsNotPeriodic(comp); work.push_back(0.); // initialize the work value } - addComponent("work"); - componentIsNotPeriodic("work"); + addComponent("work"); componentIsNotPeriodic("work"); tot_work=0.0; log<<" Bibliography "; @@ -240,15 +223,10 @@ void MovingRestraint::calculate() { aa=at[step.size()-1]; } else { unsigned i=0; - for(i=1; igetName()+"_cntr")->set(aa[i]); const double k=kk[i]; f[i]=-k*cv; - if(verse[i]=="U" && cv<0) { - continue; - } - if(verse[i]=="L" && cv>0) { - continue; - } + if(verse[i]=="U" && cv<0) continue; + if(verse[i]=="L" && cv>0) continue; plumed_assert(verse[i]=="U" || verse[i]=="L" || verse[i]=="B"); dpotdk[i]=0.5*cv*cv; - if(oldaa.size()==aa.size() && oldf.size()==f.size()) { - work[i]+=0.5*(oldf[i]+f[i])*(aa[i]-oldaa[i]) + 0.5*( dpotdk[i]+olddpotdk[i] )*(kk[i]-oldk[i]); - } + if(oldaa.size()==aa.size() && oldf.size()==f.size()) work[i]+=0.5*(oldf[i]+f[i])*(aa[i]-oldaa[i]) + 0.5*( dpotdk[i]+olddpotdk[i] )*(kk[i]-oldk[i]); getPntrToComponent(getPntrToArgument(i)->getName()+"_work")->set(work[i]); getPntrToComponent(getPntrToArgument(i)->getName()+"_kappa")->set(kk[i]); tot_work+=work[i]; diff --git a/src/bias/PBMetaD.cpp b/src/bias/PBMetaD.cpp index 88da1e46fe..8251a350d2 100644 --- a/src/bias/PBMetaD.cpp +++ b/src/bias/PBMetaD.cpp @@ -247,12 +247,7 @@ class PBMetaD : public Bias { Gaussian(const std::vector & center,const std::vector & sigma, double height, bool multivariate): center(center),sigma(sigma),height(height),multivariate(multivariate),invsigma(sigma) { // to avoid troubles from zero element in flexible hills - for(unsigned i=0; i1.e-20) { - invsigma[i]=1.0/invsigma[i] ; - } else { - invsigma[i]=0.0; - } + for(unsigned i=0; i1.e-20) invsigma[i]=1.0/invsigma[i] ; else invsigma[i]=0.0; } }; // general setup @@ -388,7 +383,8 @@ PBMetaD::PBMetaD(const ActionOptions& ao): pf_n_(0), do_pf_(false), mw_n_(1), mw_dir_(""), mw_id_(0), mw_rstride_(1), walkers_mpi_(false), mpi_nw_(0), - do_select_(false) { + do_select_(false) +{ // parse the flexible hills std::string adaptiveoption; @@ -414,9 +410,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): std::vector familyargs; for(int i = 0;; i++) { parseArgumentList("PF", i, familyargs); - if (familyargs.empty()) { - break; - } + if (familyargs.empty()) break; do_pf_ = true; log << " Identified Partitioned Family " << i << ":"; @@ -455,9 +449,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): } else { // If we are doing PF, make sure each argument got assigned to a family. for (unsigned i = 0; i < getNumberOfArguments(); i++) { - if (pfs_[i] == -1) { - error(getPntrToArgument(i)->getName() + " was not assigned a PF"); - } + if (pfs_[i] == -1) error(getPntrToArgument(i)->getName() + " was not assigned a PF"); } } @@ -486,9 +478,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): error("the number of SIGMA_MIN values be the same of the number of the arguments/PF"); } else if(sigma0min_.size()==0) { sigma0min_.resize(pf_n_); - for(unsigned i=0; i0.0) { - kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt_=plumed.getAtoms().getKbT(); - } + if(temp>0.0) kbt_=plumed.getAtoms().getKBoltzmann()*temp; + else kbt_=plumed.getAtoms().getKbT(); if(biasf_>1.0) { - if(kbt_==0.0) { - error("Unless the MD engine passes the temperature to plumed, with well-tempered metad you must specify it using TEMP"); - } + if(kbt_==0.0) error("Unless the MD engine passes the temperature to plumed, with well-tempered metad you must specify it using TEMP"); welltemp_=true; } double tau=0.0; parse("TAU",tau); if(tau==0.0) { - if(height0_==std::numeric_limits::max()) { - error("At least one between HEIGHT and TAU should be specified"); - } + if(height0_==std::numeric_limits::max()) error("At least one between HEIGHT and TAU should be specified"); // if tau is not set, we compute it here from the other input parameters - if(welltemp_) { - tau=(kbt_*(biasf_-1.0))/height0_*getTimeStep()*stride_; - } + if(welltemp_) tau=(kbt_*(biasf_-1.0))/height0_*getTimeStep()*stride_; } else { - if(!welltemp_) { - error("TAU only makes sense in well-tempered metadynamics"); - } - if(height0_!=std::numeric_limits::max()) { - error("At most one between HEIGHT and TAU should be specified"); - } + if(!welltemp_)error("TAU only makes sense in well-tempered metadynamics"); + if(height0_!=std::numeric_limits::max()) error("At most one between HEIGHT and TAU should be specified"); height0_=(kbt_*(biasf_-1.0))/tau*getTimeStep()*stride_; } @@ -569,9 +540,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): // Multiple walkers parse("WALKERS_N",mw_n_); parse("WALKERS_ID",mw_id_); - if(mw_n_<=mw_id_) { - error("walker ID should be a numerical value less than the total number of walkers"); - } + if(mw_n_<=mw_id_) error("walker ID should be a numerical value less than the total number of walkers"); parse("WALKERS_DIR",mw_dir_); parse("WALKERS_RSTRIDE",mw_rstride_); @@ -591,9 +560,8 @@ PBMetaD::PBMetaD(const ActionOptions& ao): gridfilenames_.push_back(name); } } - if(gridfilenames_.size() > 0 && hillsfname_.size() > 0 && gridfilenames_.size() != hillsfname_.size()) { + if(gridfilenames_.size() > 0 && hillsfname_.size() > 0 && gridfilenames_.size() != hillsfname_.size()) error("number of GRID_WFILES arguments does not match number of HILLS files"); - } // Read grid std::vector gridreadfilenames_; @@ -602,53 +570,32 @@ PBMetaD::PBMetaD(const ActionOptions& ao): // Grid Stuff std::vector gmin(pf_n_); parseVector("GRID_MIN",gmin); - if(gmin.size()!=pf_n_ && gmin.size()!=0) { - error("not enough values for GRID_MIN"); - } + if(gmin.size()!=pf_n_ && gmin.size()!=0) error("not enough values for GRID_MIN"); std::vector gmax(pf_n_); parseVector("GRID_MAX",gmax); - if(gmax.size()!=pf_n_ && gmax.size()!=0) { - error("not enough values for GRID_MAX"); - } + if(gmax.size()!=pf_n_ && gmax.size()!=0) error("not enough values for GRID_MAX"); std::vector gbin(pf_n_); std::vector gspacing; parseVector("GRID_BIN",gbin); - if(gbin.size()!=pf_n_ && gbin.size()!=0) { - error("not enough values for GRID_BIN"); - } + if(gbin.size()!=pf_n_ && gbin.size()!=0) error("not enough values for GRID_BIN"); parseVector("GRID_SPACING",gspacing); - if(gspacing.size()!=pf_n_ && gspacing.size()!=0) { - error("not enough values for GRID_SPACING"); - } - if(gmin.size()!=gmax.size()) { - error("GRID_MAX and GRID_MIN should be either present or absent"); - } - if(gspacing.size()!=0 && gmin.size()==0) { - error("If GRID_SPACING is present also GRID_MIN and GRID_MAX should be present"); - } - if(gbin.size()!=0 && gmin.size()==0) { - error("If GRID_BIN is present also GRID_MIN and GRID_MAX should be present"); - } + if(gspacing.size()!=pf_n_ && gspacing.size()!=0) error("not enough values for GRID_SPACING"); + if(gmin.size()!=gmax.size()) error("GRID_MAX and GRID_MIN should be either present or absent"); + if(gspacing.size()!=0 && gmin.size()==0) error("If GRID_SPACING is present also GRID_MIN and GRID_MAX should be present"); + if(gbin.size()!=0 && gmin.size()==0) error("If GRID_BIN is present also GRID_MIN and GRID_MAX should be present"); if(gmin.size()!=0) { if(gbin.size()==0 && gspacing.size()==0) { if(adaptive_==FlexibleBin::none) { log<<" Binsize not specified, 1/5 of sigma will be be used\n"; plumed_assert(sigma0_.size()==pf_n_); gspacing.resize(pf_n_); - for(unsigned i=0; i0) { - grid_=true; - } + if(gbin.size()>0) grid_=true; bool sparsegrid=false; parseFlag("GRID_SPARSE",sparsegrid); bool nospline=false; parseFlag("GRID_NOSPLINE",nospline); bool spline=!nospline; - if(!grid_&&gridfilenames_.size() > 0) { - error("To write a grid you need first to define it!"); - } - if(!grid_&&gridreadfilenames_.size() > 0) { - error("To read a grid you need first to define it!"); - } + if(!grid_&&gridfilenames_.size() > 0) error("To write a grid you need first to define it!"); + if(!grid_&&gridreadfilenames_.size() > 0) error("To read a grid you need first to define it!"); doInt_.resize(pf_n_,false); // Interval keyword parseVector("INTERVAL_MIN",lowI_); parseVector("INTERVAL_MAX",uppI_); // various checks - if(lowI_.size()!=uppI_.size()) { - error("both a lower and an upper limits must be provided with INTERVAL"); - } - if(lowI_.size()!=0 && lowI_.size()!=pf_n_) { - error("check number of argument of INTERVAL"); - } + if(lowI_.size()!=uppI_.size()) error("both a lower and an upper limits must be provided with INTERVAL"); + if(lowI_.size()!=0 && lowI_.size()!=pf_n_) error("check number of argument of INTERVAL"); for(unsigned i=0; iisPeriodic()) { - warning("INTERVAL is not used for periodic variables"); - } else { - doInt_[i]=true; - } + if(uppI_[i]isPeriodic()) warning("INTERVAL is not used for periodic variables"); + else doInt_[i]=true; } // parse selector stuff @@ -719,21 +646,13 @@ PBMetaD::PBMetaD(const ActionOptions& ao): checkRead(); log.printf(" Gaussian width "); - if (adaptive_==FlexibleBin::diffusion) { - log.printf(" (Note: The units of sigma are in timesteps) "); - } - if (adaptive_==FlexibleBin::geometry) { - log.printf(" (Note: The units of sigma are in dist units) "); - } - for(unsigned i=0; i1) { - if(walkers_mpi_) { - error("MPI version of multiple walkers is not compatible with filesystem version of multiple walkers"); - } + if(walkers_mpi_) error("MPI version of multiple walkers is not compatible with filesystem version of multiple walkers"); log.printf(" %d multiple walkers active\n",mw_n_); log.printf(" walker id %d\n",mw_id_); log.printf(" reading stride %d\n",mw_rstride_); - if(mw_dir_!="") { - log.printf(" directory with hills files %s\n",mw_dir_.c_str()); - } + if(mw_dir_!="")log.printf(" directory with hills files %s\n",mw_dir_.c_str()); } else { if(walkers_mpi_) { log.printf(" Multiple walkers active using MPI communnication\n"); - if(mw_dir_!="") { - log.printf(" directory with hills files %s\n",mw_dir_.c_str()); - } + if(mw_dir_!="")log.printf(" directory with hills files %s\n",mw_dir_.c_str()); if(comm.Get_rank()==0) { // Only root of group can communicate with other walkers mpi_nw_ = multi_sim_comm.Get_size(); @@ -775,32 +688,20 @@ PBMetaD::PBMetaD(const ActionOptions& ao): } for(unsigned i=0; i0) { for(unsigned i=0; i0.5*sigma0_[i]) { - log<<" WARNING: Using a PBMETAD with a Grid Spacing larger than half of the Gaussians width can produce artifacts\n"; - } + if(mesh>0.5*sigma0_[i]) log<<" WARNING: Using a PBMETAD with a Grid Spacing larger than half of the Gaussians width can produce artifacts\n"; } else { - if(mesh>0.5*sigma0min_[i]||sigma0min_[i]<0.) { - log<<" WARNING: to use a PBMETAD with a GRID and ADAPTIVE you need to set a Grid Spacing larger than half of the Gaussians \n"; - } + if(mesh>0.5*sigma0min_[i]||sigma0min_[i]<0.) log<<" WARNING: to use a PBMETAD with a GRID and ADAPTIVE you need to set a Grid Spacing larger than half of the Gaussians \n"; } } std::string funcl=getLabel() + ".bias"; @@ -867,25 +764,16 @@ PBMetaD::PBMetaD(const ActionOptions& ao): error("periodicity mismatch between arguments and input bias"); } log.printf(" Restarting from %s:\n",gridreadfilenames_[i].c_str()); - if(getRestart()) { - restartedFromGrid=true; - } + if(getRestart()) restartedFromGrid=true; } else { - if(!sparsegrid) { - BiasGrid_=Tools::make_unique(funcl,args,gmin_t,gmax_t,gbin_t,spline,true); - } else { - BiasGrid_=Tools::make_unique(funcl,args,gmin_t,gmax_t,gbin_t,spline,true); - } + if(!sparsegrid) {BiasGrid_=Tools::make_unique(funcl,args,gmin_t,gmax_t,gbin_t,spline,true);} + else {BiasGrid_=Tools::make_unique(funcl,args,gmin_t,gmax_t,gbin_t,spline,true);} std::vector actualmin=BiasGrid_->getMin(); std::vector actualmax=BiasGrid_->getMax(); std::string is; Tools::convert(i,is); - if(gmin_t[0]!=actualmin[0]) { - error("GRID_MIN["+is+"] must be adjusted to "+actualmin[0]+" to fit periodicity"); - } - if(gmax_t[0]!=actualmax[0]) { - error("GRID_MAX["+is+"] must be adjusted to "+actualmax[0]+" to fit periodicity"); - } + if(gmin_t[0]!=actualmin[0]) error("GRID_MIN["+is+"] must be adjusted to "+actualmin[0]+" to fit periodicity"); + if(gmax_t[0]!=actualmax[0]) error("GRID_MAX["+is+"] must be adjusted to "+actualmax[0]+" to fit periodicity"); } BiasGrids_.emplace_back(std::move(BiasGrid_)); } @@ -902,8 +790,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): std::string fname; if(mw_dir_!="") { if(mw_n_>1) { - std::stringstream out; - out << j; + std::stringstream out; out << j; fname = mw_dir_+"/"+hillsfname_[i]+"."+out.str(); } else if(walkers_mpi_) { fname = mw_dir_+"/"+hillsfname_[i]; @@ -912,8 +799,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): } } else { if(mw_n_>1) { - std::stringstream out; - out << j; + std::stringstream out; out << j; fname = hillsfname_[i]+"."+out.str(); } else { fname = hillsfname_[i]; @@ -932,22 +818,16 @@ PBMetaD::PBMetaD(const ActionOptions& ao): } ifiles_[k]->reset(false); // close only the walker own hills file for later writing - if(j==mw_id_) { - ifiles_[k]->close(); - } + if(j==mw_id_) ifiles_[k]->close(); } else { // in case a file does not exist and we are restarting, complain that the file was not found - if(getRestart()) { - log<<" WARNING: restart file "<0) { - ifilesnames_[mw_id_*hillsfname_.size()+i]="/dev/null"; - } - ofile->enforceSuffix(""); - } - if(mw_n_>1) { + if(r>0) ifilesnames_[mw_id_*hillsfname_.size()+i]="/dev/null"; ofile->enforceSuffix(""); } + if(mw_n_>1) ofile->enforceSuffix(""); ofile->open(ifilesnames_[mw_id_*hillsfname_.size()+i]); - if(fmt_.length()>0) { - ofile->fmtField(fmt_); - } + if(fmt_.length()>0) ofile->fmtField(fmt_); ofile->addConstantField("multivariate"); ofile->addConstantField("kerneltype"); if(doInt_[i]) { @@ -1002,9 +874,7 @@ PBMetaD::PBMetaD(const ActionOptions& ao): } ofile->enforceSuffix(""); } - if(mw_n_>1) { - ofile->enforceSuffix(""); - } + if(mw_n_>1) ofile->enforceSuffix(""); ofile->open(gridfname_tmp); ofile->setHeavyFlush(); gridfiles_.emplace_back(std::move(ofile)); @@ -1012,24 +882,20 @@ PBMetaD::PBMetaD(const ActionOptions& ao): } log<<" Bibliography "<1||walkers_mpi_) - log<1||walkers_mpi_) log< center(1); std::vector sigma(1); double height; @@ -1043,15 +909,14 @@ void PBMetaD::readGaussians(unsigned iarg, IFile *ifile) { while(scanOneHill(iarg,ifile,tmpvalues,center,sigma,height,multivariate)) { ; nhills++; - if(welltemp_) { - height*=(biasf_-1.0)/biasf_; - } + if(welltemp_) {height*=(biasf_-1.0)/biasf_;} addGaussian(family, Gaussian(center,sigma,height,multivariate)); } log.printf(" %d Gaussians read\n",nhills); } -void PBMetaD::writeGaussian(unsigned iarg, const Gaussian& hill, OFile *ofile) { +void PBMetaD::writeGaussian(unsigned iarg, const Gaussian& hill, OFile *ofile) +{ int family=pfs_[iarg]; ofile->printField("time",getTimeStep()*getStep()); ofile->printField(pfhold_[family],hill.center[0]); @@ -1067,21 +932,17 @@ void PBMetaD::writeGaussian(unsigned iarg, const Gaussian& hill, OFile *ofile) { ofile->printField("sigma_"+pfhold_[family]->getName(),hill.sigma[0]); } double height=hill.height; - if(welltemp_) { - height *= biasf_/(biasf_-1.0); - } + if(welltemp_) height *= biasf_/(biasf_-1.0); ofile->printField("height",height); ofile->printField("biasf",biasf_); - if(mw_n_>1) { - ofile->printField("clock",int(std::time(0))); - } + if(mw_n_>1) ofile->printField("clock",int(std::time(0))); ofile->printField(); } -void PBMetaD::addGaussian(unsigned iarg, const Gaussian& hill) { - if(!grid_) { - hills_[iarg].push_back(hill); - } else { +void PBMetaD::addGaussian(unsigned iarg, const Gaussian& hill) +{ + if(!grid_) {hills_[iarg].push_back(hill);} + else { std::vector nneighb=getGaussianSupport(iarg, hill); std::vector neighbors=BiasGrids_[iarg]->getNeighbors(hill.center,nneighb); std::vector der(1); @@ -1115,7 +976,8 @@ void PBMetaD::addGaussian(unsigned iarg, const Gaussian& hill) { } } -std::vector PBMetaD::getGaussianSupport(unsigned iarg, const Gaussian& hill) { +std::vector PBMetaD::getGaussianSupport(unsigned iarg, const Gaussian& hill) +{ std::vector nneigh; double cutoff; if(hill.multivariate) { @@ -1140,7 +1002,8 @@ std::vector PBMetaD::getGaussianSupport(unsigned iarg, const Gaussian& return nneigh; } -double PBMetaD::getBiasAndDerivatives(unsigned iarg, const std::vector& cv, double* der) { +double PBMetaD::getBiasAndDerivatives(unsigned iarg, const std::vector& cv, double* der) +{ double bias=0.0; int family = pfs_[iarg]; if(!grid_) { @@ -1150,9 +1013,7 @@ double PBMetaD::getBiasAndDerivatives(unsigned iarg, const std::vector& bias += evaluateGaussian(iarg,cv,hills_[family][i],der); } comm.Sum(bias); - if(der) { - comm.Sum(der,1); - } + if(der) comm.Sum(der,1); } else { if(der) { std::vector vder(1); @@ -1166,7 +1027,8 @@ double PBMetaD::getBiasAndDerivatives(unsigned iarg, const std::vector& return bias; } -double PBMetaD::evaluateGaussian(unsigned iarg, const std::vector& cv, const Gaussian& hill, double* der) { +double PBMetaD::evaluateGaussian(unsigned iarg, const std::vector& cv, const Gaussian& hill, double* der) +{ double bias=0.0; // I use a pointer here because cv is const (and should be const) // but when using doInt it is easier to locally replace cv[0] with @@ -1176,13 +1038,8 @@ double PBMetaD::evaluateGaussian(unsigned iarg, const std::vector& cv, c tmpcv[0]=cv[0]; bool isOutOfInt = false; if(doInt_[iarg]) { - if(cv[0]uppI_[iarg]) { - tmpcv[0]=uppI_[iarg]; - isOutOfInt = true; - } + if(cv[0]uppI_[iarg]) { tmpcv[0]=uppI_[iarg]; isOutOfInt = true; } } pcv=&(tmpcv[0]); @@ -1211,12 +1068,11 @@ double PBMetaD::evaluateGaussian(unsigned iarg, const std::vector& cv, c return bias; } -void PBMetaD::calculate() { +void PBMetaD::calculate() +{ // this is because presently there is no way to properly pass information // on adaptive hills (diff) after exchanges: - if(adaptive_==FlexibleBin::diffusion && getExchangeStep()) { - error("ADAPTIVE=DIFF is not compatible with replica exchange"); - } + if(adaptive_==FlexibleBin::diffusion && getExchangeStep()) error("ADAPTIVE=DIFF is not compatible with replica exchange"); std::vector cv(1); double der[1]; @@ -1230,9 +1086,7 @@ void PBMetaD::calculate() { der[0] = 0.0; bias[i] = getBiasAndDerivatives(i, cv, der); deriv[i] = der[0]; - if(bias[i] < bmin) { - bmin = bias[i]; - } + if(bias[i] < bmin) bmin = bias[i]; } double ene = 0.; for(unsigned i=0; i(plumed.passMap[selector_]); - } + if(do_select_) current_value_ = static_cast(plumed.passMap[selector_]); if(!do_select_ || select_value_==current_value_) { for(unsigned i=0; i0 && (getStep()%wgridstride_==0 || getCPT())) { int r = 0; if(walkers_mpi_) { - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) r=multi_sim_comm.Get_rank(); comm.Bcast(r,0); } if(r==0) { @@ -1400,9 +1236,7 @@ void PBMetaD::update() { for(unsigned i=0; iisOpen())) { // check if it exists now and open it! @@ -1423,7 +1257,8 @@ void PBMetaD::update() { } /// takes a pointer to the file and a template string with values v and gives back the next center, sigma and height -bool PBMetaD::scanOneHill(unsigned iarg, IFile *ifile, std::vector &tmpvalues, std::vector ¢er, std::vector &sigma, double &height, bool &multivariate) { +bool PBMetaD::scanOneHill(unsigned iarg, IFile *ifile, std::vector &tmpvalues, std::vector ¢er, std::vector &sigma, double &height, bool &multivariate) +{ double dummy; multivariate=false; Value* argPtr = pfhold_[pfs_[iarg]]; @@ -1432,19 +1267,15 @@ bool PBMetaD::scanOneHill(unsigned iarg, IFile *ifile, std::vector &tmpva if( tmpvalues[0].isPeriodic() && ! argPtr->isPeriodic() ) { error("in hills file periodicity for variable " + tmpvalues[0].getName() + " does not match periodicity in input"); } else if( tmpvalues[0].isPeriodic() ) { - std::string imin, imax; - tmpvalues[0].getDomain( imin, imax ); - std::string rmin, rmax; - argPtr->getDomain( rmin, rmax ); + std::string imin, imax; tmpvalues[0].getDomain( imin, imax ); + std::string rmin, rmax; argPtr->getDomain( rmin, rmax ); if( imin!=rmin || imax!=rmax ) { error("in hills file periodicity for variable " + tmpvalues[0].getName() + " does not match periodicity in input"); } } center[0]=tmpvalues[0].get(); std::string ktype="stretched-gaussian"; - if( ifile->FieldExist("kerneltype") ) { - ifile->scanField("kerneltype",ktype); - } + if( ifile->FieldExist("kerneltype") ) ifile->scanField("kerneltype",ktype); if( ktype=="gaussian" ) { noStretchWarning(); @@ -1454,13 +1285,9 @@ bool PBMetaD::scanOneHill(unsigned iarg, IFile *ifile, std::vector &tmpva std::string sss; ifile->scanField("multivariate",sss); - if(sss=="true") { - multivariate=true; - } else if(sss=="false") { - multivariate=false; - } else { - plumed_merror("cannot parse multivariate = "+ sss); - } + if(sss=="true") multivariate=true; + else if(sss=="false") multivariate=false; + else plumed_merror("cannot parse multivariate = "+ sss); if(multivariate) { ifile->scanField("sigma_"+argPtr->getName()+"_"+ argPtr->getName(),sigma[0]); @@ -1470,15 +1297,9 @@ bool PBMetaD::scanOneHill(unsigned iarg, IFile *ifile, std::vector &tmpva } ifile->scanField("height",height); ifile->scanField("biasf",dummy); - if(ifile->FieldExist("clock")) { - ifile->scanField("clock",dummy); - } - if(ifile->FieldExist("lower_int")) { - ifile->scanField("lower_int",dummy); - } - if(ifile->FieldExist("upper_int")) { - ifile->scanField("upper_int",dummy); - } + if(ifile->FieldExist("clock")) ifile->scanField("clock",dummy); + if(ifile->FieldExist("lower_int")) ifile->scanField("lower_int",dummy); + if(ifile->FieldExist("upper_int")) ifile->scanField("upper_int",dummy); ifile->scanField(); return true; } else { @@ -1487,16 +1308,12 @@ bool PBMetaD::scanOneHill(unsigned iarg, IFile *ifile, std::vector &tmpva } -bool PBMetaD::checkNeedsGradients()const { +bool PBMetaD::checkNeedsGradients()const +{ if(adaptive_==FlexibleBin::geometry) { - if(getStep()%stride_==0 && !isFirstStep_) { - return true; - } else { - return false; - } - } else { - return false; - } + if(getStep()%stride_==0 && !isFirstStep_) return true; + else return false; + } else return false; } } diff --git a/src/bias/Restraint.cpp b/src/bias/Restraint.cpp index ffe239ca0b..4644fa2eae 100644 --- a/src/bias/Restraint.cpp +++ b/src/bias/Restraint.cpp @@ -82,26 +82,21 @@ Restraint::Restraint(const ActionOptions&ao): PLUMED_BIAS_INIT(ao), at(getNumberOfArguments()), kappa(getNumberOfArguments(),0.0), - slope(getNumberOfArguments(),0.0) { + slope(getNumberOfArguments(),0.0) +{ parseVector("SLOPE",slope); parseVector("KAPPA",kappa); parseVector("AT",at); checkRead(); log.printf(" at"); - for(unsigned i=0; i0) { - simtemp*=plumed.getAtoms().getKBoltzmann(); - } else { - simtemp=plumed.getAtoms().getKbT(); - } - if(simtemp==0) { - error("The MD engine does not pass the temperature to plumed so you have to specify it using TEMP"); - } + ActionWithArguments(ao) +{ + simtemp=0.; parse("TEMP",simtemp); + if(simtemp>0) simtemp*=plumed.getAtoms().getKBoltzmann(); + else simtemp=plumed.getAtoms().getKbT(); + if(simtemp==0) error("The MD engine does not pass the temperature to plumed so you have to specify it using TEMP"); // Create something to hold the weight - addValue(); - setNotPeriodic(); + addValue(); setNotPeriodic(); } void ReweightBase::calculate() { diff --git a/src/bias/ReweightBase.h b/src/bias/ReweightBase.h index 34a5ff2c6f..ac690f8c39 100644 --- a/src/bias/ReweightBase.h +++ b/src/bias/ReweightBase.h @@ -30,25 +30,20 @@ namespace bias { class ReweightBase : public ActionWithValue, - public ActionWithArguments { + public ActionWithArguments +{ protected: /// The temperature at which you are running the simulation double simtemp; public: static void registerKeywords(Keywords&); explicit ReweightBase(const ActionOptions&ao); - unsigned getNumberOfDerivatives() override { - return 0; - } - virtual bool buildsWeightStore() const { - return false; - } + unsigned getNumberOfDerivatives() override { return 0; } + virtual bool buildsWeightStore() const { return false; } void calculate() override; virtual void calculateWeights( const unsigned& nframes ) {} virtual double getLogWeight() = 0; - virtual double getWeight( const unsigned& iweight ) const { - plumed_error(); - } + virtual double getWeight( const unsigned& iweight ) const { plumed_error(); } virtual void clearData() {} void apply() override {} }; diff --git a/src/bias/ReweightBias.cpp b/src/bias/ReweightBias.cpp index f7f1b4cd1e..6059c998ea 100644 --- a/src/bias/ReweightBias.cpp +++ b/src/bias/ReweightBias.cpp @@ -78,22 +78,19 @@ class ReweightBias : public ReweightBase { PLUMED_REGISTER_ACTION(ReweightBias,"REWEIGHT_BIAS") void ReweightBias::registerKeywords(Keywords& keys ) { - ReweightBase::registerKeywords( keys ); - keys.remove("ARG"); + ReweightBase::registerKeywords( keys ); keys.remove("ARG"); keys.add("compulsory","ARG","*.bias","the biases that must be taken into account when reweighting"); } ReweightBias::ReweightBias(const ActionOptions&ao): Action(ao), - ReweightBase(ao) { + ReweightBase(ao) +{ } double ReweightBias::getLogWeight() { // Retrieve the bias - double bias=0.0; - for(unsigned i=0; igetName().c_str()); - } + for(unsigned i=0; igetName().c_str()); log.printf("\n"); } //requestArguments(myenergy); @@ -224,9 +223,7 @@ ReweightTemperaturePressure::ReweightTemperaturePressure(const ActionOptions&ao) parseArgumentList("VOLUME",myvol); if(!myvol.empty()) { log.printf(" with volumes: "); - for(unsigned i=0; igetName().c_str()); - } + for(unsigned i=0; igetName().c_str()); log.printf("\n"); } @@ -242,49 +239,27 @@ ReweightTemperaturePressure::ReweightTemperaturePressure(const ActionOptions&ao) log.printf(" WARNING: If the simulation is performed at constant pressure add the keywords PRESSURE and VOLUME \n" ); } // Case 2) Reweight from T to T' with P=const (isothermal-isobaric) - else if (rtemp_>=0 && press_>=0 && rpress_<0 && !myenergy.empty() && !myvol.empty() ) { - log.printf(" reweighting simulation from temperature %f to temperature %f at constant pressure %f \n",simtemp/plumed.getAtoms().getKBoltzmann(),rtemp_/plumed.getAtoms().getKBoltzmann(), press_ ); - } + else if (rtemp_>=0 && press_>=0 && rpress_<0 && !myenergy.empty() && !myvol.empty() ) log.printf(" reweighting simulation from temperature %f to temperature %f at constant pressure %f \n",simtemp/plumed.getAtoms().getKBoltzmann(),rtemp_/plumed.getAtoms().getKBoltzmann(), press_ ); // Case 3) Reweight from P to P' with T=const (isothermal-isobaric) - else if (rtemp_<0 && press_>=0 && rpress_>=0 && myenergy.empty() && !myvol.empty() ) { - log.printf(" reweighting simulation from pressure %f to pressure %f at constant temperature %f\n",press_,rpress_,simtemp/plumed.getAtoms().getKBoltzmann() ); - } + else if (rtemp_<0 && press_>=0 && rpress_>=0 && myenergy.empty() && !myvol.empty() ) log.printf(" reweighting simulation from pressure %f to pressure %f at constant temperature %f\n",press_,rpress_,simtemp/plumed.getAtoms().getKBoltzmann() ); // Case 4) Reweight from T,P to T',P' (isothermal-isobaric) - else if (rtemp_>0 && press_>=0 && rpress_>=0 && !myenergy.empty() && !myvol.empty() ) { - log.printf(" reweighting simulation from temperature %f and pressure %f to temperature %f and pressure %f \n",simtemp/plumed.getAtoms().getKBoltzmann(), press_, rtemp_/plumed.getAtoms().getKBoltzmann(), rpress_); - } else { - error("Combination of ENERGY, VOLUME, REWEIGHT_PRESSURE, PRESSURE and REWEIGHT_TEMP not supported. Please refer to the manual for supported combinations."); - } + else if (rtemp_>0 && press_>=0 && rpress_>=0 && !myenergy.empty() && !myvol.empty() ) log.printf(" reweighting simulation from temperature %f and pressure %f to temperature %f and pressure %f \n",simtemp/plumed.getAtoms().getKBoltzmann(), press_, rtemp_/plumed.getAtoms().getKBoltzmann(), rpress_); + else error("Combination of ENERGY, VOLUME, REWEIGHT_PRESSURE, PRESSURE and REWEIGHT_TEMP not supported. Please refer to the manual for supported combinations."); } double ReweightTemperaturePressure::getLogWeight() { - double energy=0.0; - for(unsigned i=0; i=0 && press_<0 && rpress_<0) { - return ((1.0/simtemp)- (1.0/rtemp_) )*energy; - } + if (rtemp_>=0 && press_<0 && rpress_<0) return ((1.0/simtemp)- (1.0/rtemp_) )*energy; // Case 2) Reweight from T to T' with P=const (isothermal-isobaric) - else if (rtemp_>=0 && press_>=0 && rpress_<0) { - return ((1.0/simtemp)- (1.0/rtemp_) )*energy + ((1.0/simtemp) - (1.0/rtemp_))*press_*volume; - } + else if (rtemp_>=0 && press_>=0 && rpress_<0) return ((1.0/simtemp)- (1.0/rtemp_) )*energy + ((1.0/simtemp) - (1.0/rtemp_))*press_*volume; // Case 3) Reweight from P to P' with T=const (isothermal-isobaric) - else if (rtemp_<0 && press_>=0 && rpress_>=0) { - return (1.0/simtemp)*(press_ - rpress_)*volume; - } + else if (rtemp_<0 && press_>=0 && rpress_>=0) return (1.0/simtemp)*(press_ - rpress_)*volume; // Case 4) Reweight from T,P to T',P' (isothermal-isobaric) - else if (rtemp_>0 && press_>=0 && rpress_>=0) { - return ((1.0/simtemp)- (1.0/rtemp_) )*energy + ((1.0/simtemp)*press_ - (1.0/rtemp_)*rpress_ )*volume; - } else { - return 0; - } + else if (rtemp_>0 && press_>=0 && rpress_>=0) return ((1.0/simtemp)- (1.0/rtemp_) )*energy + ((1.0/simtemp)*press_ - (1.0/rtemp_)*rpress_ )*volume; + else return 0; } } diff --git a/src/bias/ReweightWham.cpp b/src/bias/ReweightWham.cpp index 2f14346dec..b6628aa57d 100644 --- a/src/bias/ReweightWham.cpp +++ b/src/bias/ReweightWham.cpp @@ -86,9 +86,7 @@ class ReweightWham : public ReweightBase { public: static void registerKeywords(Keywords&); explicit ReweightWham(const ActionOptions&ao); - bool buildsWeightStore() const override { - return true; - } + bool buildsWeightStore() const override { return true; } void calculateWeights( const unsigned& nframes ) override; void clearData() override; double getLogWeight() override; @@ -98,8 +96,7 @@ class ReweightWham : public ReweightBase { PLUMED_REGISTER_ACTION(ReweightWham,"REWEIGHT_WHAM") void ReweightWham::registerKeywords(Keywords& keys ) { - ReweightBase::registerKeywords( keys ); - keys.remove("ARG"); + ReweightBase::registerKeywords( keys ); keys.remove("ARG"); keys.add("compulsory","ARG","*.bias","the biases that must be taken into account when reweighting"); keys.add("compulsory","MAXITER","1000","maximum number of iterations for WHAM algorithm"); keys.add("compulsory","WHAMTOL","1e-10","threshold for convergence of WHAM algorithm"); @@ -108,33 +105,22 @@ void ReweightWham::registerKeywords(Keywords& keys ) { ReweightWham::ReweightWham(const ActionOptions&ao): Action(ao), ReweightBase(ao), - weightsCalculated(false) { - parse("MAXITER",maxiter); - parse("WHAMTOL",thresh); - if(comm.Get_rank()==0) { - nreplicas=multi_sim_comm.Get_size(); - } + weightsCalculated(false) +{ + parse("MAXITER",maxiter); parse("WHAMTOL",thresh); + if(comm.Get_rank()==0) nreplicas=multi_sim_comm.Get_size(); comm.Bcast(nreplicas,0); } double ReweightWham::getLogWeight() { - if( getStep()==0 ) { - return 1.0; // This is here as first step is ignored in all analyses - } + if( getStep()==0 ) return 1.0; // This is here as first step is ignored in all analyses weightsCalculated=false; - double bias=0.0; - for(unsigned i=0; i biases(nreplicas,0.0); - if(comm.Get_rank()==0) { - multi_sim_comm.Allgather(bias,biases); - } + if(comm.Get_rank()==0) multi_sim_comm.Allgather(bias,biases); comm.Bcast(biases,0); - for(unsigned i=0; i expv( stored_biases.size() ); - for(unsigned i=0; i Z( nreplicas, 1.0 ), oldZ( nreplicas ); // Now the iterative loop to calculate the WHAM weights for(unsigned iter=0; iter tmp=Tools::ls(std::string(config::getPlumedRoot()+"/scripts")); for(unsigned j=0; j0) { - std::fprintf(out," %s",tmp[j].c_str()); - } + for(unsigned j=0; j0) std::fprintf(out," %s",tmp[j].c_str()); std::fprintf(out,"\"\n"); for(unsigned j=0; j void Driver::registerKeywords( Keywords& keys ) { - CLTool::registerKeywords( keys ); - keys.isDriver(); + CLTool::registerKeywords( keys ); keys.isDriver(); keys.addFlag("--help-debug",false,"print special options that can be used to create regtests"); keys.add("compulsory","--plumed","plumed.dat","specify the name of the plumed input file"); keys.add("compulsory","--timestep","1.0","the timestep that was used in the calculation that produced this trajectory in picoseconds"); @@ -258,13 +257,12 @@ void Driver::registerKeywords( Keywords& keys ) { } template Driver::Driver(const CLToolOptions& co ): - CLTool(co) { + CLTool(co) +{ inputdata=commandline; } template -std::string Driver::description()const { - return "analyze trajectories with plumed"; -} +std::string Driver::description()const { return "analyze trajectories with plumed"; } template int Driver::main(FILE* in,FILE*out,Communicator& pc) { @@ -273,8 +271,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { PDB pdb; // Parse everything - bool printhelpdebug; - parseFlag("--help-debug",printhelpdebug); + bool printhelpdebug; parseFlag("--help-debug",printhelpdebug); if( printhelpdebug ) { std::fprintf(out,"%s", "Additional options for debug (only to be used in regtest):\n" @@ -285,26 +282,18 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { return 0; } // Are we reading trajectory data - bool noatoms; - parseFlag("--noatoms",noatoms); - bool parseOnly; - parseFlag("--parse-only",parseOnly); - std::string full_outputfile; - parse("--shortcut-ofile",full_outputfile); - bool restart; - parseFlag("--restart",restart); + bool noatoms; parseFlag("--noatoms",noatoms); + bool parseOnly; parseFlag("--parse-only",parseOnly); + std::string full_outputfile; parse("--shortcut-ofile",full_outputfile); + bool restart; parseFlag("--restart",restart); std::string fakein; 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(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)) { @@ -317,37 +306,23 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { 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) { - std::fprintf(out,"DEBUGGING PARTICLE DECOMPOSITION\n"); + 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) std::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) { - std::fprintf(out,"DEBUGGING DOMAIN DECOMPOSITION\n"); + 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) std::fprintf(out,"DEBUGGING DOMAIN DECOMPOSITION\n"); if( debug_pd || debug_dd ) { - if(noatoms) { - error("cannot debug without atoms"); - } + if(noatoms) error("cannot debug without atoms"); } // set up for multi replica driver: @@ -358,9 +333,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { if(multi) { int ntot=pc.Get_size(); int nintra=ntot/multi; - if(multi*nintra!=ntot) { - error("invalid number of processes for multi environment"); - } + if(multi*nintra!=ntot) error("invalid number of processes for multi environment"); pc.Split(pc.Get_rank()/nintra,pc.Get_rank(),intracomm); pc.Split(pc.Get_rank()%nintra,pc.Get_rank(),intercomm); } else { @@ -372,23 +345,14 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { int grex_stride=0; FILE*grex_log=NULL; // call fclose when fp goes out of scope - auto deleter=[](FILE* f) { - if(f) { - std::fclose(f); - } - }; + auto deleter=[](FILE* f) { if(f) std::fclose(f); }; std::unique_ptr grex_log_deleter(grex_log,deleter); if(debug_grex) { - if(noatoms) { - error("must have atoms to debug_grex"); - } - if(multi<2) { - error("--debug_grex needs --multi with at least two replicas"); - } + if(noatoms) error("must have atoms to debug_grex"); + if(multi<2) error("--debug_grex needs --multi with at least two replicas"); Tools::convert(fakein,grex_stride); - std::string n; - Tools::convert(intercomm.Get_rank(),n); + std::string n; Tools::convert(intercomm.Get_rank(),n); std::string file; parse("--debug-grex-log",file); if(file.length()>0) { @@ -399,15 +363,12 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { } // Read the plumed input file name - std::string plumedFile; - parse("--plumed",plumedFile); + std::string plumedFile; parse("--plumed",plumedFile); // the timestep - double t; - parse("--timestep",t); + double t; parse("--timestep",t); real timestep=real(t); // the stride - unsigned stride; - parse("--trajectory-stride",stride); + unsigned stride; parse("--trajectory-stride",stride); // are we writing forces std::string dumpforces(""), debugforces(""), dumpforcesFmt("%f");; bool dumpfullvirial=false; @@ -415,18 +376,10 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { parse("--dump-forces",dumpforces); parse("--debug-forces",debugforces); } - if(dumpforces!="" || debugforces!="" ) { - parse("--dump-forces-fmt",dumpforcesFmt); - } - if(dumpforces!="") { - parseFlag("--dump-full-virial",dumpfullvirial); - } - if( debugforces!="" && (debug_dd || debug_pd) ) { - error("cannot debug forces and domain/particle decomposition at same time"); - } - if( debugforces!="" && sizeof(real)!=sizeof(double) ) { - error("cannot debug forces in single precision mode"); - } + if(dumpforces!="" || debugforces!="" ) parse("--dump-forces-fmt",dumpforcesFmt); + if(dumpforces!="") parseFlag("--dump-full-virial",dumpfullvirial); + if( debugforces!="" && (debug_dd || debug_pd) ) error("cannot debug forces and domain/particle decomposition at same time"); + if( debugforces!="" && sizeof(real)!=sizeof(double) ) error("cannot debug forces in single precision mode"); real kt=-1.0; parse("--kt",kt); @@ -437,17 +390,13 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { // Read in an xyz file std::string trajectoryFile(""), pdbfile(""), mcfile(""); - bool pbc_cli_given=false; - std::vector pbc_cli_box(9,0.0); + bool pbc_cli_given=false; std::vector pbc_cli_box(9,0.0); int command_line_natoms=-1; if(!noatoms) { - std::string traj_xyz; - parse("--ixyz",traj_xyz); - std::string traj_gro; - parse("--igro",traj_gro); - std::string traj_dlp4; - parse("--idlp4",traj_dlp4); + std::string traj_xyz; parse("--ixyz",traj_xyz); + std::string traj_gro; parse("--igro",traj_gro); + std::string traj_dlp4; parse("--idlp4",traj_dlp4); std::string traj_xtc; std::string traj_trr; parse("--ixtc",traj_xtc); @@ -466,24 +415,13 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { } } #endif - { - // check that only one fmt is specified + { // check that only one fmt is specified int nn=0; - if(traj_xyz.length()>0) { - nn++; - } - if(traj_gro.length()>0) { - nn++; - } - if(traj_dlp4.length()>0) { - nn++; - } - if(traj_xtc.length()>0) { - nn++; - } - if(traj_trr.length()>0) { - nn++; - } + if(traj_xyz.length()>0) nn++; + if(traj_gro.length()>0) nn++; + if(traj_dlp4.length()>0) nn++; + if(traj_xtc.length()>0) nn++; + if(traj_trr.length()>0) nn++; if(nn>1) { std::fprintf(stderr,"ERROR: cannot provide more than one trajectory file\n"); return 1; @@ -513,45 +451,29 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { std::fprintf(stderr,"ERROR: missing trajectory data\n"); return 1; } - std::string lengthUnits(""); - parse("--length-units",lengthUnits); - if(lengthUnits.length()>0) { - units.setLength(lengthUnits); - } - std::string chargeUnits(""); - parse("--charge-units",chargeUnits); - if(chargeUnits.length()>0) { - units.setCharge(chargeUnits); - } - std::string massUnits(""); - parse("--mass-units",massUnits); - if(massUnits.length()>0) { - units.setMass(massUnits); - } + std::string lengthUnits(""); parse("--length-units",lengthUnits); + if(lengthUnits.length()>0) units.setLength(lengthUnits); + std::string chargeUnits(""); parse("--charge-units",chargeUnits); + if(chargeUnits.length()>0) units.setCharge(chargeUnits); + std::string massUnits(""); parse("--mass-units",massUnits); + if(massUnits.length()>0) units.setMass(massUnits); parse("--pdb",pdbfile); if(pdbfile.length()>0) { bool check=pdb.read(pdbfile,false,1.0); - if(!check) { - error("error reading pdb file"); - } + if(!check) error("error reading pdb file"); } parse("--mc",mcfile); - std::string pbc_cli_list; - parse("--box",pbc_cli_list); + std::string pbc_cli_list; parse("--box",pbc_cli_list); if(pbc_cli_list.length()>0) { pbc_cli_given=true; std::vector words=Tools::getWords(pbc_cli_list,","); if(words.size()==3) { - for(int i=0; i<3; i++) { - std::sscanf(words[i].c_str(),"%100lf",&(pbc_cli_box[4*i])); - } + for(int i=0; i<3; i++) std::sscanf(words[i].c_str(),"%100lf",&(pbc_cli_box[4*i])); } else if(words.size()==9) { - for(int i=0; i<9; i++) { - std::sscanf(words[i].c_str(),"%100lf",&(pbc_cli_box[i])); - } + for(int i=0; i<9; i++) std::sscanf(words[i].c_str(),"%100lf",&(pbc_cli_box[i])); } else { std::string msg="ERROR: cannot parse command-line box "+pbc_cli_list; std::fprintf(stderr,"%s\n",msg.c_str()); @@ -568,9 +490,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { auto mf_deleter=[api](void* h_in) { if(h_in) { std::unique_ptr> lck; - if(api->is_reentrant==VMDPLUGIN_THREADUNSAFE) { - lck=Tools::molfile_lock(); - } + if(api->is_reentrant==VMDPLUGIN_THREADUNSAFE) lck=Tools::molfile_lock(); api->close_file_read(h_in); } }; @@ -588,33 +508,22 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { - if(debug_dd && debug_pd) { - error("cannot use debug-dd and debug-pd at the same time"); - } + if(debug_dd && debug_pd) error("cannot use debug-dd and debug-pd at the same time"); if(debug_pd || debug_dd) { - if( !Communicator::initialized() ) { - error("needs mpi for debug-pd"); - } + if( !Communicator::initialized() ) error("needs mpi for debug-pd"); } - PlumedMain p; - if( parseOnly ) { - p.activateParseOnlyMode(); - } + PlumedMain p; if( parseOnly ) p.activateParseOnlyMode(); p.cmd("setRealPrecision",(int)sizeof(real)); int checknatoms=-1; long long int step=0; parse("--initial-step",step); - if(restart) { - p.cmd("setRestart",1); - } + if(restart) p.cmd("setRestart",1); if(Communicator::initialized()) { if(multi) { - if(intracomm.Get_rank()==0) { - p.cmd("GREX setMPIIntercomm",&intercomm.Get_comm()); - } + if(intracomm.Get_rank()==0) p.cmd("GREX setMPIIntercomm",&intercomm.Get_comm()); p.cmd("GREX setMPIIntracomm",&intracomm.Get_comm()); p.cmd("GREX init"); } @@ -625,9 +534,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { p.cmd("setMDMassUnits",units.getMass()); p.cmd("setMDEngine","driver"); p.cmd("setTimestep",timestep); - if( !parseOnly || full_outputfile.length()==0 ) { - p.cmd("setPlumedDat",plumedFile.c_str()); - } + if( !parseOnly || full_outputfile.length()==0 ) p.cmd("setPlumedDat",plumedFile.c_str()); p.cmd("setLog",out); int natoms; @@ -635,59 +542,43 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { int pb=1; if(parseOnly) { - if(command_line_natoms<0) { - error("--parseOnly requires setting the number of atoms with --natoms"); - } + if(command_line_natoms<0) error("--parseOnly requires setting the number of atoms with --natoms"); natoms=command_line_natoms; } - FILE* fp=NULL; - FILE* fp_forces=NULL; - OFile fp_dforces; + FILE* fp=NULL; FILE* fp_forces=NULL; OFile fp_dforces; std::unique_ptr fp_deleter(fp,deleter); std::unique_ptr fp_forces_deleter(fp_forces,deleter); - auto xdr_deleter=[](xdrfile::XDRFILE* xd) { - if(xd) { - xdrfile::xdrfile_close(xd); - } - }; + auto xdr_deleter=[](xdrfile::XDRFILE* xd) { if(xd) xdrfile::xdrfile_close(xd); }; xdrfile::XDRFILE* xd=NULL; std::unique_ptr xd_deleter(xd,xdr_deleter); if(!noatoms&&!parseOnly) { - if (trajectoryFile=="-") { + if (trajectoryFile=="-") fp=in; - } else { + else { if(multi) { std::string n; Tools::convert(intercomm.Get_rank(),n); std::string testfile=FileBase::appendSuffix(trajectoryFile,"."+n); FILE* tmp_fp=std::fopen(testfile.c_str(),"r"); // no exceptions here - if(tmp_fp) { - std::fclose(tmp_fp); - trajectoryFile=testfile; - } + if(tmp_fp) { std::fclose(tmp_fp); trajectoryFile=testfile;} } if(use_molfile==true) { #ifdef __PLUMED_HAS_MOLFILE_PLUGINS std::unique_ptr> lck; - if(api->is_reentrant==VMDPLUGIN_THREADUNSAFE) { - lck=Tools::molfile_lock(); - } + if(api->is_reentrant==VMDPLUGIN_THREADUNSAFE) lck=Tools::molfile_lock(); h_in = api->open_file_read(trajectoryFile.c_str(), trajectory_fmt.c_str(), &natoms); h_in_deleter.reset(h_in); if(natoms==MOLFILE_NUMATOMS_UNKNOWN) { - if(command_line_natoms>=0) { - natoms=command_line_natoms; - } else { - error("this file format does not provide number of atoms; use --natoms on the command line"); - } + if(command_line_natoms>=0) natoms=command_line_natoms; + else error("this file format does not provide number of atoms; use --natoms on the command line"); } ts_in_coords.resize(3*natoms); ts_in.coords = ts_in_coords.data(); @@ -700,12 +591,8 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { std::fprintf(stderr,"%s\n",msg.c_str()); return 1; } - if(trajectory_fmt=="xdr-xtc") { - xdrfile::read_xtc_natoms(&trajectoryFile[0],&natoms); - } - if(trajectory_fmt=="xdr-trr") { - xdrfile::read_trr_natoms(&trajectoryFile[0],&natoms); - } + if(trajectory_fmt=="xdr-xtc") xdrfile::read_xtc_natoms(&trajectoryFile[0],&natoms); + if(trajectory_fmt=="xdr-trr") xdrfile::read_trr_natoms(&trajectoryFile[0],&natoms); } else { fp=std::fopen(trajectoryFile.c_str(),"r"); fp_deleter.reset(fp); @@ -759,12 +646,8 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { Random rnd; if(trajectory_fmt=="dlp4") { - if(!Tools::getline(fp,line)) { - error("error reading title"); - } - if(!Tools::getline(fp,line)) { - error("error reading atoms"); - } + if(!Tools::getline(fp,line)) error("error reading title"); + if(!Tools::getline(fp,line)) error("error reading atoms"); std::sscanf(line.c_str(),"%d %d %d",&lvl,&pb,&natoms); } @@ -774,9 +657,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { if(use_molfile==true) { #ifdef __PLUMED_HAS_MOLFILE_PLUGINS std::unique_ptr> lck; - if(api->is_reentrant==VMDPLUGIN_THREADUNSAFE) { - lck=Tools::molfile_lock(); - } + if(api->is_reentrant==VMDPLUGIN_THREADUNSAFE) lck=Tools::molfile_lock(); int rc; rc = api->read_next_timestep(h_in, natoms, &ts_in); if(rc==MOLFILE_EOF) { @@ -784,18 +665,13 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { } #endif } else if(trajectory_fmt=="xyz" || trajectory_fmt=="gro" || trajectory_fmt=="dlp4") { - if(!Tools::getline(fp,line)) { - break; - } + if(!Tools::getline(fp,line)) break; } } bool first_step=false; if(!noatoms&&!parseOnly) { if(use_molfile==false && (trajectory_fmt=="xyz" || trajectory_fmt=="gro")) { - if(trajectory_fmt=="gro") - if(!Tools::getline(fp,line)) { - error("premature end of trajectory file"); - } + if(trajectory_fmt=="gro") if(!Tools::getline(fp,line)) error("premature end of trajectory file"); std::sscanf(line.c_str(),"%100d",&natoms); } if(use_molfile==false && trajectory_fmt=="dlp4") { @@ -820,9 +696,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { for(unsigned i=0; i=unsigned(natoms) ) { - error("atom index in pdb exceeds the number of atoms in trajectory"); - } + if( index>=unsigned(natoms) ) error("atom index in pdb exceeds the number of atoms in trajectory"); masses[index]=pdb.getOccupancy()[i]; charges[index]=pdb.getBeta()[i]; } @@ -830,9 +704,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { if(mcfile.length()>0) { IFile ifile; ifile.open(mcfile); - int index; - double mass; - double charge; + int index; double mass; double charge; while(ifile.scanField("index",index).scanField("mass",mass).scanField("charge",charge).scanField()) { masses[index]=mass; charges[index]=charge; @@ -853,78 +725,52 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { // Read in the plumed input file and store what is in there std::map > data; - IFile ifile; - ifile.open(plumedFile); - std::vector words; + IFile ifile; ifile.open(plumedFile); std::vector words; while( Tools::getParsedLine(ifile,words) && !p.getEndPlumed() ) { - p.readInputWords(words); - Action* aa=p.getActionSet()[p.getActionSet().size()-1].get(); + p.readInputWords(words); Action* aa=p.getActionSet()[p.getActionSet().size()-1].get(); ActionWithValue* av=dynamic_cast(aa); if( av && aa->getDefaultString().length()>0 ) { - std::vector def; - def.push_back( "defaults " + aa->getDefaultString() ); + std::vector def; def.push_back( "defaults " + aa->getDefaultString() ); data[ aa->getLabel() ] = def; } ActionShortcut* as=dynamic_cast( aa ); if( as ) { if( aa->getDefaultString().length()>0 ) { - std::vector def; - def.push_back( "defaults " + aa->getDefaultString() ); + std::vector def; def.push_back( "defaults " + aa->getDefaultString() ); data[ as->getShortcutLabel() ] = def; } if( data.find( as->getShortcutLabel() )!=data.end() ) { std::vector shortcut_commands = as->getSavedInputLines(); - for(unsigned i=0; igetShortcutLabel() ].push_back( shortcut_commands[i] ); - } - } else { - data[ as->getShortcutLabel() ] = as->getSavedInputLines(); - } + for(unsigned i=0; igetShortcutLabel() ].push_back( shortcut_commands[i] ); + } else data[ as->getShortcutLabel() ] = as->getSavedInputLines(); } } ifile.close(); // Only output the full version of the input file if there are shortcuts if( data.size()>0 ) { - OFile long_file; - long_file.open( full_outputfile ); - long_file.printf("{\n"); - bool firstpass=true; + OFile long_file; long_file.open( full_outputfile ); long_file.printf("{\n"); bool firstpass=true; for(auto& x : data ) { - if( !firstpass ) { - long_file.printf(" },\n"); - } + if( !firstpass ) long_file.printf(" },\n"); long_file.printf(" \"%s\" : {\n", x.first.c_str() ); - plumed_assert( x.second.size()>0 ); - unsigned sstart=0; + plumed_assert( x.second.size()>0 ); unsigned sstart=0; if( x.second[0].find("defaults")!=std::string::npos ) { - sstart=1; - long_file.printf(" \"defaults\" : \"%s\"", x.second[0].substr( 9 ).c_str() ); - if( x.second.size()>1 ) { - long_file.printf(",\n"); - } else { - long_file.printf("\n"); - } + sstart=1; long_file.printf(" \"defaults\" : \"%s\"", x.second[0].substr( 9 ).c_str() ); + if( x.second.size()>1 ) long_file.printf(",\n"); else long_file.printf("\n"); } if( x.second.size()>sstart ) { long_file.printf(" \"expansion\" : \"%s", x.second[sstart].c_str() ); - for(unsigned j=sstart+1; j::main(FILE* in,FILE*out,Communicator& pc) { std::vector start(npe,0); for(int i=0; inatoms) { - cc=natoms-start[i]; - } + if(start[i]+cc>natoms) cc=natoms-start[i]; loc[i]=cc; start[i+1]=start[i]+loc[i]; } @@ -953,16 +797,8 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { pd_start=start[intracomm.Get_rank()]; if(intracomm.Get_rank()==0) { std::fprintf(out,"\nDRIVER: Reassigning particle decomposition\n"); - std::fprintf(out,"DRIVER: "); - for(int i=0; i::main(FILE* in,FILE*out,Communicator& pc) { dd_nlocal=0; for(int i=0; ir) { - break; - } + int n; for(n=0; nr)break; plumed_assert(n::main(FILE* in,FILE*out,Communicator& pc) { real Cx=real(ts_in.C)*cosAC; real Cy=(real(ts_in.C)*real(ts_in.B)*cosBC-Cx*Bx)/By; real Cz=std::sqrt(real(ts_in.C)*real(ts_in.C)-Cx*Cx-Cy*Cy); - cell[0]=Ax/10.; - cell[1]=0.; - cell[2]=0.; - cell[3]=Bx/10.; - cell[4]=By/10.; - cell[5]=0.; - cell[6]=Cx/10.; - cell[7]=Cy/10.; - cell[8]=Cz/10.; + cell[0]=Ax/10.; cell[1]=0.; cell[2]=0.; + cell[3]=Bx/10.; cell[4]=By/10.; cell[5]=0.; + cell[6]=Cx/10.; cell[7]=Cy/10.; cell[8]=Cz/10.; } else { - cell[0]=0.0; - cell[1]=0.0; - cell[2]=0.0; - cell[3]=0.0; - cell[4]=0.0; - cell[5]=0.0; - cell[6]=0.0; - cell[7]=0.0; - cell[8]=0.0; + cell[0]=0.0; cell[1]=0.0; cell[2]=0.0; + cell[3]=0.0; cell[4]=0.0; cell[5]=0.0; + cell[6]=0.0; cell[7]=0.0; cell[8]=0.0; } } else { - for(unsigned i=0; i<9; i++) { - cell[i]=pbc_cli_box[i]; - } + for(unsigned i=0; i<9; i++)cell[i]=pbc_cli_box[i]; } // info on coords // the order is xyzxyz... @@ -1059,34 +877,17 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { auto pos=Tools::make_unique(natoms); float prec,lambda; int ret=xdrfile::exdrOK; - if(trajectory_fmt=="xdr-xtc") { - ret=xdrfile::read_xtc(xd,natoms,&localstep,&time,box,pos.get(),&prec); - } - if(trajectory_fmt=="xdr-trr") { - ret=xdrfile::read_trr(xd,natoms,&localstep,&time,&lambda,box,pos.get(),NULL,NULL); - } - if(stride==0) { - step=localstep; - } - if(ret==xdrfile::exdrENDOFFILE) { - break; - } - if(ret!=xdrfile::exdrOK) { - break; - } - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<3; j++) { - cell[3*i+j]=box[i][j]; - } - for(int i=0; i celld(9,0.0); if(pbc_cli_given==false) { @@ -1099,52 +900,36 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { &celld[0], &celld[1], &celld[2], &celld[3], &celld[4], &celld[5], &celld[6], &celld[7], &celld[8]); - } else { - error("needed box in second line of xyz file"); - } + } else error("needed box in second line of xyz file"); } else { // from command line celld=pbc_cli_box; } - for(unsigned i=0; i<9; i++) { - cell[i]=real(celld[i]); - } + for(unsigned i=0; i<9; i++)cell[i]=real(celld[i]); } if(trajectory_fmt=="dlp4") { std::vector celld(9,0.0); if(pbc_cli_given==false) { - if(!Tools::getline(fp,line)) { - error("error reading vector a of cell"); - } + if(!Tools::getline(fp,line)) error("error reading vector a of cell"); std::sscanf(line.c_str(),"%lf %lf %lf",&celld[0],&celld[1],&celld[2]); - if(!Tools::getline(fp,line)) { - error("error reading vector b of cell"); - } + if(!Tools::getline(fp,line)) error("error reading vector b of cell"); std::sscanf(line.c_str(),"%lf %lf %lf",&celld[3],&celld[4],&celld[5]); - if(!Tools::getline(fp,line)) { - error("error reading vector c of cell"); - } + if(!Tools::getline(fp,line)) error("error reading vector c of cell"); std::sscanf(line.c_str(),"%lf %lf %lf",&celld[6],&celld[7],&celld[8]); } else { celld=pbc_cli_box; } - for(auto i=0; i<9; i++) { - cell[i]=real(celld[i])*0.1; - } + for(auto i=0; i<9; i++)cell[i]=real(celld[i])*0.1; } int ddist=0; // Read coordinates for(int i=0; i::main(FILE* in,FILE*out,Communicator& pc) { // const char *p1, *p2, *p3; p1 = std::strchr(line.c_str(), '.'); - if (p1 == NULL) { - error("seems there are no coordinates in the gro file"); - } + if (p1 == NULL) error("seems there are no coordinates in the gro file"); p2 = std::strchr(&p1[1], '.'); - if (p2 == NULL) { - error("seems there is only one coordinates in the gro file"); - } + if (p2 == NULL) error("seems there is only one coordinates in the gro file"); ddist = p2 - p1; p3 = std::strchr(&p2[1], '.'); - if (p3 == NULL) { - error("seems there are only two coordinates in the gro file"); - } - if (p3 - p2 != ddist) { - error("not uniform spacing in fields in the gro file"); - } + if (p3 == NULL)error("seems there are only two coordinates in the gro file"); + if (p3 - p2 != ddist)error("not uniform spacing in fields in the gro file"); } Tools::convert(line.substr(20,ddist),cc[0]); Tools::convert(line.substr(20+ddist,ddist),cc[1]); @@ -1179,26 +956,18 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { std::sscanf(line.c_str(),"%8s %d %lf %lf",dummy,&idummy,&m,&c); masses[i]=real(m); charges[i]=real(c); - if(!Tools::getline(fp,line)) { - error("error reading coordinates"); - } + if(!Tools::getline(fp,line)) error("error reading coordinates"); std::sscanf(line.c_str(),"%lf %lf %lf",&cc[0],&cc[1],&cc[2]); cc[0]*=0.1; cc[1]*=0.1; cc[2]*=0.1; if(lvl>0) { - if(!Tools::getline(fp,line)) { - error("error skipping velocities"); - } + if(!Tools::getline(fp,line)) error("error skipping velocities"); } if(lvl>1) { - if(!Tools::getline(fp,line)) { - error("error skipping forces"); - } + if(!Tools::getline(fp,line)) error("error skipping forces"); } - } else { - plumed_error(); - } + } else plumed_error(); if(!debug_pd || ( i>=pd_start && i::main(FILE* in,FILE*out,Communicator& pc) { } } if(trajectory_fmt=="gro") { - if(!Tools::getline(fp,line)) { - error("premature end of trajectory file"); - } + if(!Tools::getline(fp,line)) error("premature end of trajectory file"); std::vector words=Tools::getWords(line); - if(words.size()<3) { - error("cannot understand box format"); - } + if(words.size()<3) error("cannot understand box format"); Tools::convert(words[0],cell[0]); Tools::convert(words[1],cell[4]); Tools::convert(words[2],cell[8]); - if(words.size()>3) { - Tools::convert(words[3],cell[1]); - } - if(words.size()>4) { - Tools::convert(words[4],cell[2]); - } - if(words.size()>5) { - Tools::convert(words[5],cell[3]); - } - if(words.size()>6) { - Tools::convert(words[6],cell[5]); - } - if(words.size()>7) { - Tools::convert(words[7],cell[6]); - } - if(words.size()>8) { - Tools::convert(words[8],cell[7]); - } + if(words.size()>3) Tools::convert(words[3],cell[1]); + if(words.size()>4) Tools::convert(words[4],cell[2]); + if(words.size()>5) Tools::convert(words[5],cell[3]); + if(words.size()>6) Tools::convert(words[6],cell[5]); + if(words.size()>7) Tools::convert(words[7],cell[6]); + if(words.size()>8) Tools::convert(words[8],cell[7]); } } @@ -1278,9 +1031,7 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { // this is necessary as only processor zero is adding to the virial: intracomm.Bcast(virial,0); - if(debug_pd) { - intracomm.Sum(forces); - } + if(debug_pd) intracomm.Sum(forces); if(debug_dd) { for(int i=0; i::main(FILE* in,FILE*out,Communicator& pc) { int r=intercomm.Get_rank(); int n=intercomm.Get_size(); int partner=r+(2*((r+step/grex_stride)%2))-1; - if(partner<0) { - partner=0; - } - if(partner>=n) { - partner=n-1; - } + if(partner<0)partner=0; + if(partner>=n) partner=n-1; p.cmd("GREX setPartner",partner); p.cmd("GREX calculate"); p.cmd("GREX shareAllDeltaBias"); for(int i=0; i::quiet_NaN(); - s="GREX getDeltaBias "+s; - p.cmd(s,&a); - if(grex_log) { - std::fprintf(grex_log," %f",a); - } - } - if(grex_log) { - std::fprintf(grex_log,"\n"); + std::string s; Tools::convert(i,s); + real a=std::numeric_limits::quiet_NaN(); s="GREX getDeltaBias "+s; p.cmd(s,&a); + if(grex_log) std::fprintf(grex_log," %f",a); } + if(grex_log) std::fprintf(grex_log,"\n"); } } @@ -1334,18 +1074,14 @@ int Driver::main(FILE* in,FILE*out,Communicator& pc) { std::fprintf(fp_forces,fmt.c_str(),virial[0],virial[4],virial[8]); } fmt="X "+fmt; - for(int i=0; i0) { // Now call the routine to work out the derivatives numerically - numder.assign(3*natoms+9,real(0.0)); - real base=0; + numder.assign(3*natoms+9,real(0.0)); real base=0; p.cmd("getBias",&base); - if( std::abs(base)::main(FILE* in,FILE*out,Communicator& pc) { } } - if(plumedStopCondition) { - break; - } + if(plumedStopCondition) break; step+=stride; } - if(!parseOnly) { - p.cmd("runFinalJobs"); - } + if(!parseOnly) p.cmd("runFinalJobs"); return 0; } @@ -1383,15 +1115,11 @@ void Driver::evaluateNumericalDerivatives( const long long int& step, Plum const std::vector& masses, const std::vector& charges, std::vector& cell, const double& base, std::vector& numder ) { - int natoms = coordinates.size() / 3; - real delta = std::sqrt(epsilon); - std::vector pos(natoms); - real bias=0; + int natoms = coordinates.size() / 3; real delta = std::sqrt(epsilon); + std::vector pos(natoms); real bias=0; std::vector fake_forces( 3*natoms ), fake_virial(9); for(int i=0; i::evaluateNumericalDerivatives( const long long int& step, Plum // Create the cell Tensor box( cell[0], cell[1], cell[2], cell[3], cell[4], cell[5], cell[6], cell[7], cell[8] ); // And the virial - Pbc pbc; - pbc.setBox( box ); - Tensor nvirial; - for(unsigned i=0; i<3; i++) - for(unsigned k=0; k<3; k++) { + Pbc pbc; pbc.setBox( box ); Tensor nvirial; + for(unsigned i=0; i<3; i++) for(unsigned k=0; k<3; k++) { double arg0=box(i,k); - for(int j=0; j::evaluateNumericalDerivatives( const long long int& step, Plum p.cmd("prepareCalc"); p.cmd("performCalcNoUpdate"); p.cmd("getBias",&bias); - cell[3*i+k]=box(i,k)=arg0; - pbc.setBox(box); - for(int j=0; j DriverFloat; /// Specialized version template<> -std::string Driver::description()const { - return "analyze trajectories with plumed (single precision version)"; -} +std::string Driver::description()const { return "analyze trajectories with plumed (single precision version)"; } PLUMED_REGISTER_CLTOOL(DriverFloat,"driver-float") diff --git a/src/cltools/GenExample.cpp b/src/cltools/GenExample.cpp index 1c0bfad74c..c660c0b92f 100644 --- a/src/cltools/GenExample.cpp +++ b/src/cltools/GenExample.cpp @@ -59,7 +59,8 @@ plumed gen_example --plumed plumed.dat --status working //+ENDPLUMEDOC class GenExample: - public CLTool { + public CLTool +{ private: int multi; std::string status, version; @@ -91,7 +92,8 @@ GenExample::GenExample(const CLToolOptions& co ): CLTool(co), multi(0), status("nobadge"), - version("master") { + version("master") +{ inputdata=commandline; } @@ -100,61 +102,32 @@ int GenExample::main(FILE* in, FILE*out,Communicator& pc) { // set up for multi replica driver: parse("--multi",multi); if(multi) { - int ntot=pc.Get_size(); - int nintra=ntot/multi; - if(multi*nintra!=ntot) { - error("invalid number of processes for multi environment"); - } + int ntot=pc.Get_size(); int nintra=ntot/multi; + if(multi*nintra!=ntot) error("invalid number of processes for multi environment"); pc.Split(pc.Get_rank()/nintra,pc.Get_rank(),intracomm); pc.Split(pc.Get_rank()%nintra,pc.Get_rank(),intercomm); } else { intracomm.Set_comm(pc.Get_comm()); } - if( config::getVersionLong().find("dev")==std::string::npos ) { - version="v"+config::getVersion(); - } - std::string fname, egname, outfile; - parse("--plumed",fname); - parse("--name",egname); - parse("--out",outfile); - parse("--status",status); + if( config::getVersionLong().find("dev")==std::string::npos ) version="v"+config::getVersion(); + std::string fname, egname, outfile; parse("--plumed",fname); + parse("--name",egname); parse("--out",outfile); parse("--status",status); int r=0; - if(intracomm.Get_rank()==0) { - r=intercomm.Get_rank(); - } + if(intracomm.Get_rank()==0) r=intercomm.Get_rank(); intracomm.Bcast(r,0); - if(r>0) { - outfile="/dev/null"; - } + if(r>0) outfile="/dev/null"; - IFile ifile; - ifile.open(fname); - ifile.allowNoEOL(); - std::ofstream ofile; - ofile.open(outfile); - std::vector shortcuts; - bool hasshortcuts=false, endplumed=false; - std::vector > input; - std::vector words; + IFile ifile; ifile.open(fname); ifile.allowNoEOL(); std::ofstream ofile; ofile.open(outfile); std::vector shortcuts; + bool hasshortcuts=false, endplumed=false; std::vector > input; std::vector words; while( Tools::getParsedLine(ifile, words, false) ) { - input.push_back( words ); - shortcuts.push_back( false ); - if( words.empty() || words[0].find("#")!=std::string::npos || endplumed ) { - continue; - } - std::vector interpreted( words ); - Tools::interpretLabel(interpreted); - if( interpreted[0]=="ENDPLUMED" ) { - endplumed=true; - continue; - } - Keywords keys; - actionRegister().getKeywords( interpreted[0], keys ); - if( status=="working" && keys.exists("IS_SHORTCUT") ) { - hasshortcuts=shortcuts[shortcuts.size()-1]=true; - } + input.push_back( words ); shortcuts.push_back( false ); + if( words.empty() || words[0].find("#")!=std::string::npos || endplumed ) continue; + std::vector interpreted( words ); Tools::interpretLabel(interpreted); + if( interpreted[0]=="ENDPLUMED" ) { endplumed=true; continue; } + Keywords keys; actionRegister().getKeywords( interpreted[0], keys ); + if( status=="working" && keys.exists("IS_SHORTCUT") ) hasshortcuts=shortcuts[shortcuts.size()-1]=true; } ifile.close(); if( hasshortcuts ) { @@ -165,17 +138,11 @@ int GenExample::main(FILE* in, FILE*out,Communicator& pc) { } ofile<<"
"; ofile<<"\"tested
"; ofile.flush(); if( hasshortcuts ) { @@ -201,204 +168,107 @@ int GenExample::main(FILE* in, FILE*out,Communicator& pc) { std::vector > long_input = createLongInput( input ); printExampleInput( long_input, egname + "long", egname, ofile ); ofile<<""< > GenExample::createLongInput( const std::vector >& input ) { - std::vector > long_input; - PlumedMain myplumed; - int rr=sizeof(double), natoms=10000000; - double kt=2.49; + std::vector > long_input; PlumedMain myplumed; int rr=sizeof(double), natoms=10000000; double kt=2.49; myplumed.cmd("setRealPrecision",&rr); if(Communicator::initialized()) { if(multi) { - if(intracomm.Get_rank()==0) { - myplumed.cmd("GREX setMPIIntercomm",&intercomm.Get_comm()); - } - myplumed.cmd("GREX setMPIIntracomm",&intracomm.Get_comm()); - myplumed.cmd("GREX init"); + if(intracomm.Get_rank()==0) myplumed.cmd("GREX setMPIIntercomm",&intercomm.Get_comm()); + myplumed.cmd("GREX setMPIIntracomm",&intracomm.Get_comm()); myplumed.cmd("GREX init"); } myplumed.cmd("setMPIComm",&intracomm.Get_comm()); } - bool endplumed=false; - myplumed.cmd("setNatoms",&natoms); - myplumed.cmd("setKbT",&kt); - myplumed.cmd("init"); + bool endplumed=false; myplumed.cmd("setNatoms",&natoms); myplumed.cmd("setKbT",&kt); myplumed.cmd("init"); for(unsigned ll=0; ll interpreted( input[ll] ); - Tools::interpretLabel(interpreted); - if( interpreted[0]=="ENDPLUMED" ) { - endplumed=true; - long_input.push_back( input[ll] ); - continue; - } - Keywords keys; - plumed_assert( actionRegister().check( interpreted[0] ) ); - actionRegister().getKeywords( interpreted[0], keys ); - std::string lab, myinputline; - if( Tools::parse(interpreted, "LABEL", lab ) ) { - myinputline = lab + ": "; - } - myinputline += interpreted[0] + " "; - bool trailingcomment=false; + if( input[ll].empty() || endplumed ) { long_input.push_back( input[ll] ); continue; } + if( input[ll][0].find("#")!=std::string::npos ) { long_input.push_back( input[ll] ); continue; } + std::vector interpreted( input[ll] ); Tools::interpretLabel(interpreted); + if( interpreted[0]=="ENDPLUMED" ) { endplumed=true; long_input.push_back( input[ll] ); continue; } + Keywords keys; plumed_assert( actionRegister().check( interpreted[0] ) ); + actionRegister().getKeywords( interpreted[0], keys ); std::string lab, myinputline; + if( Tools::parse(interpreted, "LABEL", lab ) ) myinputline = lab + ": "; + myinputline += interpreted[0] + " "; bool trailingcomment=false; for(unsigned i=1; i( myplumed.getActionSet()[myplumed.getActionSet().size()-1].get() ); - plumed_assert( as ); - std::vector shortcut_commands = as->getSavedInputLines(); + plumed_assert( as ); std::vector shortcut_commands = as->getSavedInputLines(); for(unsigned i=0; i words = Tools::getWords( shortcut_commands[i] ); - long_input.push_back( words ); + std::vector words = Tools::getWords( shortcut_commands[i] ); long_input.push_back( words ); } - } else { - long_input.push_back( input[ll] ); - myplumed.readInputLine( myinputline ); - } + } else { long_input.push_back( input[ll] ); myplumed.readInputLine( myinputline ); } } return long_input; } void GenExample::printExampleInput( const std::vector >& input, const std::string& egname, const std::string& divname, std::ofstream& ofile ) { - PlumedMain myplumed; - int rr=sizeof(double), natoms=10000000; - double kt=2.49; + PlumedMain myplumed; int rr=sizeof(double), natoms=10000000; double kt=2.49; myplumed.cmd("setRealPrecision",&rr); if(Communicator::initialized()) { if(multi) { - if(intracomm.Get_rank()==0) { - myplumed.cmd("GREX setMPIIntercomm",&intercomm.Get_comm()); - } - myplumed.cmd("GREX setMPIIntracomm",&intracomm.Get_comm()); - myplumed.cmd("GREX init"); + if(intracomm.Get_rank()==0) myplumed.cmd("GREX setMPIIntercomm",&intercomm.Get_comm()); + myplumed.cmd("GREX setMPIIntracomm",&intracomm.Get_comm()); myplumed.cmd("GREX init"); } myplumed.cmd("setMPIComm",&intracomm.Get_comm()); } - myplumed.cmd("setNatoms",&natoms); - myplumed.cmd("setKbT",&kt); - myplumed.cmd("init"); - std::vector labellist; - bool endplumed=false; + myplumed.cmd("setNatoms",&natoms); myplumed.cmd("setKbT",&kt); myplumed.cmd("init"); + std::vector labellist; bool endplumed=false; ofile<<"
"<"<"< interpreted( input[ll] );
-      Tools::interpretLabel(interpreted);
-      std::string lab, myinputline;
+      std::vector interpreted( input[ll] ); Tools::interpretLabel(interpreted); std::string lab, myinputline;
       // Now read in the label
       if( Tools::parse(interpreted,"LABEL",lab) ) {
         ofile<<""<";
-        labellist.push_back(lab);
-        myinputline = lab + ": ";
+        labellist.push_back(lab); myinputline = lab + ": ";
       }
       // Print the keyword in use in the action
-      std::string action = interpreted[0];
-      myinputline += interpreted[0] + " ";
-      if( action=="ENDPLUMED" ) {
-        endplumed=true;
-      }
-      Keywords keys;
-      actionRegister().getKeywords( interpreted[0], keys );
+      std::string action = interpreted[0]; myinputline += interpreted[0] + " ";
+      if( action=="ENDPLUMED" ) endplumed=true;
+      Keywords keys; actionRegister().getKeywords( interpreted[0], keys );
       // Handle conversion of action names to links
-      std::transform(action.begin(), action.end(), action.begin(), [](unsigned char c) {
-        return std::tolower(c);
-      });
+      std::transform(action.begin(), action.end(), action.begin(), [](unsigned char c) { return std::tolower(c); });
       ofile<<""< ";
       // And write out everything else in the input line
       bool trailingcomment=false;
       for(unsigned i=1; i";
-            trailingcomment=false;
-          }
-          if( interpreted[i+1]=="..." ) {
-            ofile<"; trailingcomment=false; }
+          if( interpreted[i+1]=="..." ) ofile<__FILL__";
           continue;
-        } else if( interpreted[i]==action ) {
-          continue;
-        }
-        if( interpreted[i].find("#")!=std::string::npos ) {
-          trailingcomment=true;
-          ofile<<"";
-        }
+        } else if( interpreted[i]==action ) continue;
+        if( interpreted[i].find("#")!=std::string::npos ) { trailingcomment=true; ofile<<""; }
 
         if( !trailingcomment ) {
           std::size_t eq=interpreted[i].find_first_of("=");
@@ -406,41 +276,22 @@ void GenExample::printExampleInput( const std::vector >
             std::string keyword=interpreted[i].substr(0,eq), rest=interpreted[i].substr(eq+1);
             ofile<<"
"<"<
"; if( rest=="__FILL__" ) { - if( status!="incomplete" ) { - error("found __FILL__ statement but status is " + status); - } + if( status!="incomplete" ) error("found __FILL__ statement but status is " + status); ofile<<"=__FILL__"; } else if( rest.find_first_of("{")!=std::string::npos ) { - std::size_t pos = 0; - while ((pos = rest.find("@newline",pos)) != std::string::npos) { - rest.replace(pos, 8, "\n"); - pos++; - } - ofile<<"="< args=Tools::getWords(rest,"\t\n ,"); - ofile<<"="; + std::vector args=Tools::getWords(rest,"\t\n ,"); ofile<<"="; for(unsigned i=0; i"<"; - } else { - ofile<"<"; + else ofile< > } else if( interpreted[i]!="@newline" && interpreted[i]!="..." ) { myinputline += interpreted[i] + " "; ofile<<"
"<"<
"; - } else if( interpreted[i]=="..." ) { - ofile<<"..."; - } - } else { - ofile<"; + } else if( interpreted[i]=="..." ) ofile<<"..."; + } else ofile<"; // This builds the hidden content that tells the user about what is calculated if( status=="working" ) { ofile<<""; @@ -465,42 +310,31 @@ void GenExample::printExampleInput( const std::vector > myplumed.readInputLine( myinputline ); ActionWithValue* av=dynamic_cast( myplumed.getActionSet().selectWithLabel(lab) ); if( av ) { - if( av->getNumberOfComponents()==1 ) { - ofile<<" calculates a single scalar value"; - } else if( av->getNumberOfComponents()>0 ) { + if( av->getNumberOfComponents()==1 ) { ofile<<" calculates a single scalar value"; } + else if( av->getNumberOfComponents()>0 ) { ofile<<" calculates the following quantities:"<"< Quantity Description "<getNumberOfComponents(); for(unsigned k=0; kcopyOutput(k)->getName(); - std::size_t dot=myname.find_first_of("."); - std::string tname=myname.substr(dot+1); - std::size_t und=tname.find_last_of("_"); - std::size_t hyph=tname.find_first_of("-"); - if( und!=std::string::npos && hyph!=std::string::npos ) { - plumed_merror("cannot use underscore and hyphen in name"); - } + std::string myname = av->copyOutput(k)->getName(); std::size_t dot=myname.find_first_of("."); + std::string tname=myname.substr(dot+1); std::size_t und=tname.find_last_of("_"); std::size_t hyph=tname.find_first_of("-"); + if( und!=std::string::npos && hyph!=std::string::npos ) plumed_merror("cannot use underscore and hyphen in name"); ofile<<""<"; if( und!=std::string::npos ) { ofile<"<"<( myplumed.getActionSet().selectWithLabel(lab) ); - if( avv ) { - ofile<<" calculates the position of a virtual atom"; - } else if( interpreted[0]=="GROUP" ) { - ofile<<" defines a group of atoms so that they can be referred to later in the input"; - } + if( avv ) ofile<<" calculates the position of a virtual atom"; + else if( interpreted[0]=="GROUP" ) ofile<<" defines a group of atoms so that they can be referred to later in the input"; } ofile<<""< action_map; while((stat=myfile.getline(line))) { - std::size_t col = line.find_first_of(":"); - std::string docs = line.substr(col+1); - if( docs.find("\\")!=std::string::npos ) { - error("found invalid backslash character in first line of documentation for action " + line.substr(0,col) ); - } + std::size_t col = line.find_first_of(":"); std::string docs = line.substr(col+1); + if( docs.find("\\")!=std::string::npos ) error("found invalid backslash character in first line of documentation for action " + line.substr(0,col) ); action_map.insert(std::pair( line.substr(0,col), docs ) ); } myfile.close(); @@ -101,55 +94,31 @@ int GenJson::main(FILE* in, FILE*out,Communicator& pc) { // Get the names of all the actions std::vector action_names( actionRegister().getActionNames() ); for(unsigned i=0; i3) { - error("ndim should be 1,2 or 3"); - } + if(ndim<1 || ndim>3) error("ndim should be 1,2 or 3"); std::string w; parse("wrapatoms",w); wrapatoms=false; - if(w.length()>0 && (w[0]=='T' || w[0]=='t')) { - wrapatoms=true; - } + if(w.length()>0 && (w[0]=='T' || w[0]=='t')) wrapatoms=true; } void read_natoms(const std::string & inputfile,int & natoms) { // read the number of atoms in file "input.xyz" FILE* fp=std::fopen(inputfile.c_str(),"r"); - if(!fp) { - error(std::string("file ") + inputfile + std::string(" not found")); - } + if(!fp) error(std::string("file ") + inputfile + std::string(" not found")); // call fclose when fp goes out of scope std::unique_ptr fp_deleter(fp,deleter); int ret=std::fscanf(fp,"%1000d",&natoms); - if(ret==0) { - plumed_error() <<"Error reading number of atoms from file "<& positions,double cell[3]) { // read positions and cell from a file called inputfile // natoms (input variable) and number of atoms in the file should be consistent FILE* fp=std::fopen(inputfile.c_str(),"r"); - if(!fp) { - error(std::string("file ") + inputfile + std::string(" not found")); - } + if(!fp) error(std::string("file ") + inputfile + std::string(" not found")); // call fclose when fp goes out of scope std::unique_ptr fp_deleter(fp,deleter); char buffer[256]; char atomname[256]; char* cret=fgets(buffer,256,fp); - if(cret==nullptr) { - plumed_error() <<"Error reading buffer from file "<&masses,std::vector& velocities,Random&random) { // randomize the velocities according to the temperature - for(int iatom=0; iatom& positions,const std::vector&positions0,const double listcutoff, - const double forcecutoff,bool & recompute) { + const double forcecutoff,bool & recompute) + { // check if the neighbour list have to be recomputed recompute=false; auto delta2=(0.5*(listcutoff-forcecutoff))*(0.5*(listcutoff-forcecutoff)); // if ANY atom moved more than half of the skin thickness, recompute is set to .true. for(int iatom=0; iatomdelta2) { - recompute=true; - } + if(modulo2(positions[iatom]-positions0[iatom])>delta2) recompute=true; } } @@ -287,23 +251,19 @@ class SimpleMD: Vector distance_pbc; // minimum-image distance of the two atoms pbc(cell,distance,distance_pbc); // if the interparticle distance is larger than the cutoff, skip - if(modulo2(distance_pbc)>listcutoff2) { - continue; - } + if(modulo2(distance_pbc)>listcutoff2)continue; list[iatom].push_back(jatom); } } } void compute_forces(const int natoms,double epsilon, double sigma,const std::vector& positions,const double cell[3], - double forcecutoff,const std::vector >& list,std::vector& forces,double & engconf) { + double forcecutoff,const std::vector >& list,std::vector& forces,double & engconf) + { double forcecutoff2=forcecutoff*forcecutoff; // squared force cutoff engconf=0.0; double engconf_tmp=0.0; // separate variable for reduction (gcc 4.8 does not make reductions on references) - for(int i=0; iforcecutoff2) { - continue; - } + if(distance_pbc2>forcecutoff2) continue; auto distance_pbcm2=sigma*sigma/distance_pbc2; auto distance_pbcm6=distance_pbcm2*distance_pbcm2*distance_pbcm2; auto distance_pbcm8=distance_pbcm6*distance_pbcm2; @@ -332,16 +290,15 @@ class SimpleMD: } } # pragma omp critical - for(unsigned i=0; i& masses,const std::vector& velocities,double & engkin) { + void compute_engkin(const int natoms,const std::vector& masses,const std::vector& velocities,double & engkin) + { // calculate the kinetic energy from the velocities engkin=0.0; for(int iatom=0; iatom& positions,const double cell[3],const bool wrapatoms) { + void write_positions(const std::string& trajfile,int natoms,const std::vector& positions,const double cell[3],const bool wrapatoms) + { // write positions on file trajfile // positions are appended at the end of the file Vector pos; @@ -385,16 +343,14 @@ class SimpleMD: for(int iatom=0; iatom& positions,const double cell[3],const bool wrapatoms) { + void write_final_positions(const std::string& outputfile,int natoms,const std::vector& positions,const double cell[3],const bool wrapatoms) + { // write positions on file outputfile Vector pos; FILE*fp; @@ -407,11 +363,8 @@ class SimpleMD: for(int iatom=0; iatom(); - if(plumed) { - plumed->cmd("setRealPrecision",int(sizeof(double))); - } + if(plumed) plumed->cmd("setRealPrecision",int(sizeof(double))); read_input(temperature,tstep,friction,forcecutoff, listcutoff,nstep,nconfig,nstat, @@ -530,9 +481,7 @@ class SimpleMD: list.resize(natoms); // masses are hard-coded to 1 - for(int i=0; i1 // even if not necessary in principle in SimpleMD (which is part of plumed) // we leave the check here as a reference - if(pversion>1) { - plumed->cmd("setKbT",temperature); - } + if(pversion>1) plumed->cmd("setKbT",temperature); plumed->cmd("init"); } @@ -564,23 +511,16 @@ class SimpleMD: compute_list(natoms,positions,cell,listcutoff,list); int list_size=0; - for(int i=0; icmd("setStep",istep+1); plumed->cmd("setMasses",&masses[0]); plumed->cmd("setForces",&forces[0][0]); @@ -637,20 +566,14 @@ class SimpleMD: plumed->cmd("setBox",&cell9[0][0]); plumed->cmd("setStopFlag",&plumedWantsToStop); plumed->cmd("calc"); - if(plumedWantsToStop) { - nstep=istep; - } + if(plumedWantsToStop) nstep=istep; } // remove forces if ndim<3 if(ndim<3) - for(int iatom=0; iatom gmin(cvs.size()); if(parseVector("--min",gmin)) { - if(gmin.size()!=cvs.size() && gmin.size()!=0) { - plumed_merror("not enough values for --min"); - } + if(gmin.size()!=cvs.size() && gmin.size()!=0) plumed_merror("not enough values for --min"); grid_check++; } std::vector gmax(cvs.size() ); if(parseVector("--max",gmax)) { - if(gmax.size()!=cvs.size() && gmax.size()!=0) { - plumed_merror("not enough values for --max"); - } + if(gmax.size()!=cvs.size() && gmax.size()!=0) plumed_merror("not enough values for --max"); grid_check++; } std::vector gbin(cvs.size()); - bool grid_has_bin; - grid_has_bin=false; + bool grid_has_bin; grid_has_bin=false; if(parseVector("--bin",gbin)) { - if(gbin.size()!=cvs.size() && gbin.size()!=0) { - plumed_merror("not enough values for --bin"); - } + if(gbin.size()!=cvs.size() && gbin.size()!=0) plumed_merror("not enough values for --bin"); grid_has_bin=true; } std::vector gspacing(cvs.size()); - bool grid_has_spacing; - grid_has_spacing=false; + bool grid_has_spacing; grid_has_spacing=false; if(parseVector("--spacing",gspacing)) { - if(gspacing.size()!=cvs.size() && gspacing.size()!=0) { - plumed_merror("not enough values for --spacing"); - } + if(gspacing.size()!=cvs.size() && gspacing.size()!=0) plumed_merror("not enough values for --spacing"); grid_has_spacing=true; } // allowed: no grids only bin @@ -333,9 +320,7 @@ int CLToolSumHills::main(FILE* in,FILE*out,Communicator& pc) { unsigned nn=1; ss="setNatoms"; plumed.cmd(ss,&nn); - if(Communicator::initialized()) { - plumed.cmd("setMPIComm",&pc.Get_comm()); - } + if(Communicator::initialized()) plumed.cmd("setMPIComm",&pc.Get_comm()); plumed.cmd("init",&nn); std::vector isdone(cvs.size(),false); for(unsigned i=0; i1) { comps.push_back(cvs[j][1]); - periods.push_back(pmin[j]); - periods.push_back(pmax[j]); - isdone[j]=true; - inds.push_back(j); + periods.push_back(pmin[j]); periods.push_back(pmax[j]); + isdone[j]=true; inds.push_back(j); } } @@ -372,9 +349,7 @@ int CLToolSumHills::main(FILE* in,FILE*out,Communicator& pc) { std::string addme; if(comps.size()>0) { addme="COMPONENTS="; - for(unsigned i=0; i1) { - if(idw[i]==cvs[j][0]+"."+cvs[j][1]) { - found=true; - } + if(idw[i]==cvs[j][0]+"."+cvs[j][1])found=true; } else { - if(idw[i]==cvs[j][0]) { - found=true; - } + if(idw[i]==cvs[j][0])found=true; } } - if(!found) { - plumed_merror("variable "+idw[i]+" is not found in the bunch of cvs: revise your --idw option" ); - } + if(!found)plumed_merror("variable "+idw[i]+" is not found in the bunch of cvs: revise your --idw option" ); } plumed_massert( idw.size()<=cvs.size(),"the number of variables to be integrated should be at most equal to the total number of cvs "); // in this case you need a beta factor! } - std::string kt; - kt=std::string("1.");// assign an arbitrary value just in case that idw.size()==cvs.size() + std::string kt; kt=std::string("1.");// assign an arbitrary value just in case that idw.size()==cvs.size() if ( dohisto || idw.size()!=0 ) { plumed_massert(parse("--kt",kt),"if you make a dimensionality reduction (--idw) or a histogram (--histo) then you need to define --kt "); } @@ -481,46 +448,25 @@ int CLToolSumHills::main(FILE* in,FILE*out,Communicator& pc) { // cerr<<"AA "<1) { - mm=cvs.back()[0]+"."+cvs.back()[1]; - } else { - mm=cvs.back()[0]; - } + std::string mm; if((cvs.back()).size()>1) {mm=cvs.back()[0]+"."+cvs.back()[1];} else {mm=cvs.back()[0];} if(ifile.FieldExist("min_"+mm)) { std::string val; ifile.scanField("min_"+mm,val); @@ -678,11 +598,8 @@ bool CLToolSumHills::findCvsAndPeriodic(const std::string & filename, std::vecto if(ifile.FieldExist("multivariate")) { ; ifile.scanField("multivariate",sss); - if(sss=="true") { - multivariate=true; - } else if(sss=="false") { - multivariate=false; - } + if(sss=="true") { multivariate=true;} + else if(sss=="false") { multivariate=false;} } // do interval? if(ifile.FieldExist("lower_int")) { diff --git a/src/cltools/kT.cpp b/src/cltools/kT.cpp index 0717aa0783..f8a39c8ef1 100644 --- a/src/cltools/kT.cpp +++ b/src/cltools/kT.cpp @@ -48,7 +48,8 @@ plumed kt --temp 300 --units eV //+ENDPLUMEDOC class kt: - public CLTool { + public CLTool +{ public: static void registerKeywords( Keywords& keys ); explicit kt(const CLToolOptions& co ); @@ -67,18 +68,16 @@ void kt::registerKeywords( Keywords& keys ) { } kt::kt(const CLToolOptions& co ): - CLTool(co) { + CLTool(co) +{ inputdata=commandline; } int kt::main(FILE* in, FILE*out,Communicator& pc) { - std::string unitname; - parse("--units",unitname); - Units units; - units.setEnergy( unitname ); - double temp; - parse("--temp",temp); + std::string unitname; parse("--units",unitname); + Units units; units.setEnergy( unitname ); + double temp; parse("--temp",temp); double kk=(kBoltzmann*temp)/units.getEnergy(); std::fprintf(out,"When the temperature is %f kelvin kT is equal to %f %s\n",temp,kk,unitname.c_str()); return 0; diff --git a/src/cltools/pesmd.cpp b/src/cltools/pesmd.cpp index 9284d586a6..25d18fe466 100644 --- a/src/cltools/pesmd.cpp +++ b/src/cltools/pesmd.cpp @@ -115,7 +115,8 @@ class PesMD : public PLMD::CLTool { } explicit PesMD( const CLToolOptions& co ) : - CLTool(co) { + CLTool(co) + { inputdata=ifile; } @@ -130,43 +131,29 @@ class PesMD : public PLMD::CLTool { int& nstep, bool& lperiod, std::vector& periods, - int& idum) { + int& idum) + { // Read everything from input file - std::string tempstr; - parse("temperature",tempstr); - if( tempstr!="NVE" ) { - Tools::convert(tempstr,temperature); - } + std::string tempstr; parse("temperature",tempstr); + if( tempstr!="NVE" ) Tools::convert(tempstr,temperature); parse("tstep",tstep); - std::string frictionstr; - parse("friction",frictionstr); + std::string frictionstr; parse("friction",frictionstr); if( tempstr!="NVE" ) { - if(frictionstr=="off") { - error("pecify friction for thermostat"); - } + if(frictionstr=="off") error("pecify friction for thermostat"); Tools::convert(frictionstr,friction); } - parse("plumed",plumedin); - parse("dimension",dim); - parse("nstep",nstep); - parse("idum",idum); - ipos.resize( dim ); - parseVector("ipos",ipos); + parse("plumed",plumedin); parse("dimension",dim); + parse("nstep",nstep); parse("idum",idum); + ipos.resize( dim ); parseVector("ipos",ipos); parseFlag("periodic",lperiod); if( lperiod ) { - if( dim>3 ) { - error("can only do three dimensional periodic functions"); - } - std::vector min( dim ); - parseVector("min",min); - std::vector max( dim ); - parseVector("max",max); + if( dim>3 ) error("can only do three dimensional periodic functions"); + std::vector min( dim ); parseVector("min",min); + std::vector max( dim ); parseVector("max",max); periods.resize( dim ); for(int i=0; i ipos; - double temp, tstep, friction; - bool lperiod; - int dim, nsteps, seed; - std::vector periods; + std::string plumedin; std::vector ipos; + double temp, tstep, friction; bool lperiod; + int dim, nsteps, seed; std::vector periods; int plumedWantsToStop; Random random; @@ -191,26 +175,16 @@ class PesMD : public PLMD::CLTool { // Setup box if we have periodic domain std::vector box(9, 0.0); - if( lperiod && dim==1 ) { - box[0]=box[4]=box[8]=periods[0]; - } else if( lperiod && dim==2 ) { - box[0]=periods[0]; - box[4]=box[8]=periods[1]; - } else if( lperiod && dim==3 ) { - box[0]=periods[0]; - box[4]=periods[1]; - box[8]=periods[2]; - } else if( lperiod ) { - error("invalid dimension for periodic potential must be 1, 2 or 3"); - } + if( lperiod && dim==1 ) { box[0]=box[4]=box[8]=periods[0]; } + else if( lperiod && dim==2 ) { box[0]=periods[0]; box[4]=box[8]=periods[1]; } + else if( lperiod && dim==3 ) { box[0]=periods[0]; box[4]=periods[1]; box[8]=periods[2]; } + else if( lperiod ) error("invalid dimension for periodic potential must be 1, 2 or 3"); // Create plumed object and initialize auto plumed=Tools::make_unique(); int s=sizeof(double); plumed->cmd("setRealPrecision",&s); - if(Communicator::initialized()) { - plumed->cmd("setMPIComm",&pc.Get_comm()); - } + if(Communicator::initialized()) plumed->cmd("setMPIComm",&pc.Get_comm()); plumed->cmd("setNoVirial"); int natoms=( std::floor(dim/3) + 2 ); plumed->cmd("setNatoms",&natoms); @@ -224,44 +198,30 @@ class PesMD : public PLMD::CLTool { std::vector masses( 1+nat, 1 ); std::vector velocities( nat ), positions( nat+1 ), forces( nat+1 ); // Will set these properly eventually - int k=0; - positions[0].zero(); // Atom zero is fixed at origin - for(int i=0; idim-1 ) { - break; - } + if( 3*i+j>dim-1 ) break; tke += 0.5*velocities[i][j]*velocities[i][j]; } } // Now call plumed to get initial forces - int istep=0; - double zero=0; + int istep=0; double zero=0; plumed->cmd("setStep",&istep); plumed->cmd("setMasses",&masses[0]); Tools::set_to_zero(forces); plumed->cmd("setForces",&forces[0][0]); plumed->cmd("setEnergy",&zero); - if( lperiod ) { - plumed->cmd("setBox",&box[0]); - } + if( lperiod ) plumed->cmd("setBox",&box[0]); plumed->cmd("setPositions",&positions[0][0]); plumed->cmd("calc"); @@ -271,18 +231,14 @@ class PesMD : public PLMD::CLTool { for(int istep=0; istepdim-1 ) { - break; - } + if( 3*j+k>dim-1 ) break; therm_eng=therm_eng+0.5*velocities[j][k]*velocities[j][k]; velocities[j][k]=lscale*velocities[j][k]+lrand*random.Gaussian(); therm_eng=therm_eng-0.5*velocities[j][k]*velocities[0][k]; @@ -292,9 +248,7 @@ class PesMD : public PLMD::CLTool { // First step of velocity verlet for(int j=0; jdim-1 ) { - break; - } + if( 3*j+k>dim-1 ) break; velocities[j][k] = velocities[j][k] + 0.5*tstep*forces[1+j][k]; positions[1+j][k] = positions[1+j][k] + tstep*velocities[j][k]; } @@ -312,16 +266,12 @@ class PesMD : public PLMD::CLTool { plumed->cmd("setStopFlag",&plumedWantsToStop); plumed->cmd("calc"); // if(istep%2000==0) plumed->cmd("writeCheckPointFile"); - if(plumedWantsToStop) { - nsteps=istep; - } + if(plumedWantsToStop) nsteps=istep; // Second step of velocity verlet for(int j=0; jdim-1 ) { - break; - } + if( 3*j+k>dim-1 ) break; velocities[j][k] = velocities[j][k] + 0.5*tstep*forces[1+j][k]; } } @@ -331,9 +281,7 @@ class PesMD : public PLMD::CLTool { lrand=std::sqrt((1.-lscale*lscale)*temp); for(int j=0; jdim-1) { - break; - } + if( 3*j+k>dim-1) break; therm_eng=therm_eng+0.5*velocities[j][k]*velocities[j][k]; velocities[j][k]=lscale*velocities[j][k]+lrand*random.Gaussian(); therm_eng=therm_eng-0.5*velocities[j][k]*velocities[j][k]; @@ -343,18 +291,14 @@ class PesMD : public PLMD::CLTool { tke=0; for(int i=0; idim-1 ) { - break; - } + if( 3*i+j>dim-1 ) break; tke += 0.5*velocities[i][j]*velocities[i][j]; } } // Print everything // conserved = potential+1.5*ttt+therm_eng; - if( pc.Get_rank()==0 ) { - std::fprintf(fp,"%i %f %f %f \n", istep, istep*tstep, tke, therm_eng ); - } + if( pc.Get_rank()==0 ) std::fprintf(fp,"%i %f %f %f \n", istep, istep*tstep, tke, therm_eng ); } fclose(fp); diff --git a/src/colvar/Angle.cpp b/src/colvar/Angle.cpp index ca1f0107fb..97ff219730 100644 --- a/src/colvar/Angle.cpp +++ b/src/colvar/Angle.cpp @@ -97,7 +97,8 @@ void Angle::registerKeywords( Keywords& keys ) { Angle::Angle(const ActionOptions&ao): PLUMED_COLVAR_INIT(ao), - pbc(true) { + pbc(true) +{ std::vector atoms; parseAtomList("ATOMS",atoms); bool nopbc=!pbc; @@ -111,18 +112,12 @@ Angle::Angle(const ActionOptions&ao): atoms[2]=atoms[1]; } else if(atoms.size()==4) { log.printf(" between lines %d-%d and %d-%d\n",atoms[0].serial(),atoms[1].serial(),atoms[2].serial(),atoms[3].serial()); - } else { - error("Number of specified atoms should be either 3 or 4"); - } - - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } - - addValueWithDerivatives(); - setNotPeriodic(); + } else error("Number of specified atoms should be either 3 or 4"); + + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); + + addValueWithDerivatives(); setNotPeriodic(); requestAtoms(atoms); checkRead(); } @@ -130,9 +125,7 @@ Angle::Angle(const ActionOptions&ao): // calculator void Angle::calculate() { - if(pbc) { - makeWhole(); - } + if(pbc) makeWhole(); Vector dij,dik; dij=delta(getPosition(2),getPosition(3)); diff --git a/src/colvar/Cell.cpp b/src/colvar/Cell.cpp index 4b8913284f..c6c447ac7e 100644 --- a/src/colvar/Cell.cpp +++ b/src/colvar/Cell.cpp @@ -58,37 +58,20 @@ class Cell : public Colvar { PLUMED_REGISTER_ACTION(Cell,"CELL") Cell::Cell(const ActionOptions&ao): - PLUMED_COLVAR_INIT(ao) { + PLUMED_COLVAR_INIT(ao) +{ std::vector atoms; checkRead(); - addComponentWithDerivatives("ax"); - componentIsNotPeriodic("ax"); - components[0][0]=getPntrToComponent("ax"); - addComponentWithDerivatives("ay"); - componentIsNotPeriodic("ay"); - components[0][1]=getPntrToComponent("ay"); - addComponentWithDerivatives("az"); - componentIsNotPeriodic("az"); - components[0][2]=getPntrToComponent("az"); - addComponentWithDerivatives("bx"); - componentIsNotPeriodic("bx"); - components[1][0]=getPntrToComponent("bx"); - addComponentWithDerivatives("by"); - componentIsNotPeriodic("by"); - components[1][1]=getPntrToComponent("by"); - addComponentWithDerivatives("bz"); - componentIsNotPeriodic("bz"); - components[1][2]=getPntrToComponent("bz"); - addComponentWithDerivatives("cx"); - componentIsNotPeriodic("cx"); - components[2][0]=getPntrToComponent("cx"); - addComponentWithDerivatives("cy"); - componentIsNotPeriodic("cy"); - components[2][1]=getPntrToComponent("cy"); - addComponentWithDerivatives("cz"); - componentIsNotPeriodic("cz"); - components[2][2]=getPntrToComponent("cz"); + addComponentWithDerivatives("ax"); componentIsNotPeriodic("ax"); components[0][0]=getPntrToComponent("ax"); + addComponentWithDerivatives("ay"); componentIsNotPeriodic("ay"); components[0][1]=getPntrToComponent("ay"); + addComponentWithDerivatives("az"); componentIsNotPeriodic("az"); components[0][2]=getPntrToComponent("az"); + addComponentWithDerivatives("bx"); componentIsNotPeriodic("bx"); components[1][0]=getPntrToComponent("bx"); + addComponentWithDerivatives("by"); componentIsNotPeriodic("by"); components[1][1]=getPntrToComponent("by"); + addComponentWithDerivatives("bz"); componentIsNotPeriodic("bz"); components[1][2]=getPntrToComponent("bz"); + addComponentWithDerivatives("cx"); componentIsNotPeriodic("cx"); components[2][0]=getPntrToComponent("cx"); + addComponentWithDerivatives("cy"); componentIsNotPeriodic("cy"); components[2][1]=getPntrToComponent("cy"); + addComponentWithDerivatives("cz"); componentIsNotPeriodic("cz"); components[2][2]=getPntrToComponent("cz"); requestAtoms(atoms); } @@ -112,16 +95,9 @@ void Cell::registerKeywords( Keywords& keys ) { // calculator void Cell::calculate() { - for(int i=0; i<3; i++) - for(int j=0; j<3; j++) { - components[i][j]->set(getBox()[i][j]); - } - for(int l=0; l<3; l++) - for(int m=0; m<3; m++) { - Tensor der; - for(int i=0; i<3; i++) { - der[i][m]=getBox()[l][i]; - } + for(int i=0; i<3; i++) for(int j=0; j<3; j++) components[i][j]->set(getBox()[i][j]); + for(int l=0; l<3; l++) for(int m=0; m<3; m++) { + Tensor der; for(int i=0; i<3; i++) der[i][m]=getBox()[l][i]; setBoxDerivatives(components[l][m],-der); } } diff --git a/src/colvar/Constant.cpp b/src/colvar/Constant.cpp index fd0c1b82f5..ea8de35ac3 100644 --- a/src/colvar/Constant.cpp +++ b/src/colvar/Constant.cpp @@ -69,43 +69,31 @@ class Constant : public Colvar { PLUMED_REGISTER_ACTION(Constant,"CONSTANT") Constant::Constant(const ActionOptions&ao): - PLUMED_COLVAR_INIT(ao) { + PLUMED_COLVAR_INIT(ao) +{ bool noderiv=false; parseFlag("NODERIV",noderiv); parseVector("VALUES",values); std::vector value; parseVector("VALUE",value); - if(values.size()==0&&value.size()==0) { - error("One should use either VALUE or VALUES"); - } - if(values.size()!=0&&value.size()!=0) { - error("One should use either VALUE or VALUES"); - } - if(value.size()>1) { - error("VALUE cannot take more than one number"); - } + if(values.size()==0&&value.size()==0) error("One should use either VALUE or VALUES"); + if(values.size()!=0&&value.size()!=0) error("One should use either VALUE or VALUES"); + if(value.size()>1) error("VALUE cannot take more than one number"); if(values.size()==0) { values.resize(1); values[0]=value[0]; } checkRead(); if(values.size()==1) { - if(!noderiv) { - addValueWithDerivatives(); - } else { - addValue(); - } + if(!noderiv) addValueWithDerivatives(); + else addValue(); setNotPeriodic(); setValue(values[0]); } else if(values.size()>1) { for(unsigned i=0; iset(values[i]); diff --git a/src/colvar/ContactMap.cpp b/src/colvar/ContactMap.cpp index 1075d3c4d9..c82075f88f 100644 --- a/src/colvar/ContactMap.cpp +++ b/src/colvar/ContactMap.cpp @@ -146,13 +146,12 @@ ContactMap::ContactMap(const ActionOptions&ao): serial(false), docomp(true), dosum(false), - docmdist(false) { + docmdist(false) +{ parseFlag("SERIAL",serial); parseFlag("SUM",dosum); parseFlag("CMDIST",docmdist); - if(docmdist==true&&dosum==true) { - error("You cannot use SUM and CMDIST together"); - } + if(docmdist==true&&dosum==true) error("You cannot use SUM and CMDIST together"); bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; @@ -161,61 +160,39 @@ ContactMap::ContactMap(const ActionOptions&ao): std::vector t, ga_lista, gb_lista; for(int i=1;; ++i ) { parseAtomList("ATOMS", i, t ); - if( t.empty() ) { - break; - } + if( t.empty() ) break; if( t.size()!=2 ) { - std::string ss; - Tools::convert(i,ss); + std::string ss; Tools::convert(i,ss); error("ATOMS" + ss + " keyword has the wrong number of atoms"); } - ga_lista.push_back(t[0]); - gb_lista.push_back(t[1]); + ga_lista.push_back(t[0]); gb_lista.push_back(t[1]); t.resize(0); // Add a value for this contact - std::string num; - Tools::convert(i,num); - if(!dosum&&!docmdist) { - addComponentWithDerivatives("contact-"+num); - componentIsNotPeriodic("contact-"+num); - } + std::string num; Tools::convert(i,num); + if(!dosum&&!docmdist) {addComponentWithDerivatives("contact-"+num); componentIsNotPeriodic("contact-"+num);} } // Create neighbour lists nl=Tools::make_unique(ga_lista,gb_lista,serial,true,pbc,getPbc(),comm); // Read in switching functions - std::string errors; - sfs.resize( ga_lista.size() ); - unsigned nswitch=0; + std::string errors; sfs.resize( ga_lista.size() ); unsigned nswitch=0; for(unsigned i=0; i0) { switchingFunction.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); } else { int nn=6; int mm=0; double d0=0.0; double r0=0.0; parse("R_0",r0); - if(r0<=0.0) { - error("R_0 should be explicitly specified and positive"); - } + if(r0<=0.0) error("R_0 should be explicitly specified and positive"); parse("D_0",d0); parse("NN",nn); parse("MM",mm); diff --git a/src/colvar/CoordinationBase.cpp b/src/colvar/CoordinationBase.cpp index e56c6fbfb0..e7ab51611c 100644 --- a/src/colvar/CoordinationBase.cpp +++ b/src/colvar/CoordinationBase.cpp @@ -43,7 +43,8 @@ CoordinationBase::CoordinationBase(const ActionOptions&ao): pbc(true), serial(false), invalidateList(true), - firsttime(true) { + firsttime(true) +{ parseFlag("SERIAL",serial); @@ -66,29 +67,18 @@ CoordinationBase::CoordinationBase(const ActionOptions&ao): parseFlag("NLIST",doneigh); if(doneigh) { parse("NL_CUTOFF",nl_cut); - if(nl_cut<=0.0) { - error("NL_CUTOFF should be explicitly specified and positive"); - } + if(nl_cut<=0.0) error("NL_CUTOFF should be explicitly specified and positive"); parse("NL_STRIDE",nl_st); - if(nl_st<=0) { - error("NL_STRIDE should be explicitly specified and positive"); - } + if(nl_st<=0) error("NL_STRIDE should be explicitly specified and positive"); } - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); if(gb_lista.size()>0) { - if(doneigh) { - nl=Tools::make_unique(ga_lista,gb_lista,serial,dopair,pbc,getPbc(),comm,nl_cut,nl_st); - } else { - nl=Tools::make_unique(ga_lista,gb_lista,serial,dopair,pbc,getPbc(),comm); - } + if(doneigh) nl=Tools::make_unique(ga_lista,gb_lista,serial,dopair,pbc,getPbc(),comm,nl_cut,nl_st); + else nl=Tools::make_unique(ga_lista,gb_lista,serial,dopair,pbc,getPbc(),comm); } else { - if(doneigh) { - nl=Tools::make_unique(ga_lista,serial,pbc,getPbc(),comm,nl_cut,nl_st); - } else { - nl=Tools::make_unique(ga_lista,serial,pbc,getPbc(),comm); - } + if(doneigh) nl=Tools::make_unique(ga_lista,serial,pbc,getPbc(),comm,nl_cut,nl_st); + else nl=Tools::make_unique(ga_lista,serial,pbc,getPbc(),comm); } requestAtoms(nl->getFullAtomList()); @@ -96,27 +86,18 @@ CoordinationBase::CoordinationBase(const ActionOptions&ao): log.printf(" between two groups of %u and %u atoms\n",static_cast(ga_lista.size()),static_cast(gb_lista.size())); log.printf(" first group:\n"); for(unsigned int i=0; igetReducedAtomList()); invalidateList=false; - if(getExchangeStep()) { - error("Neighbor lists should be updated on exchange steps - choose a NL_STRIDE which divides the exchange stride!"); - } - } - if(getExchangeStep()) { - firsttime=true; + if(getExchangeStep()) error("Neighbor lists should be updated on exchange steps - choose a NL_STRIDE which divides the exchange stride!"); } + if(getExchangeStep()) firsttime=true; } } // calculator -void CoordinationBase::calculate() { +void CoordinationBase::calculate() +{ double ncoord=0.; Tensor virial; @@ -169,9 +147,7 @@ void CoordinationBase::calculate() { unsigned nt=OpenMP::getNumThreads(); const unsigned nn=nl->size(); - if(nt*stride*10>nn) { - nt=1; - } + if(nt*stride*10>nn) nt=1; const unsigned elementsPerRank = std::ceil(double(nn)/stride); const unsigned int start= rank*elementsPerRank; @@ -189,9 +165,7 @@ void CoordinationBase::calculate() { const unsigned i0=nl->getClosePair(i).first; const unsigned i1=nl->getClosePair(i).second; - if(getAbsoluteIndex(i0)==getAbsoluteIndex(i1)) { - continue; - } + if(getAbsoluteIndex(i0)==getAbsoluteIndex(i1)) continue; if(pbc) { distance=pbcDistance(getPosition(i0),getPosition(i1)); @@ -217,24 +191,19 @@ void CoordinationBase::calculate() { } #pragma omp critical if(nt>1) { - for(unsigned i=0; i( type ); drmsd_->setBoundsOnDistances( !nopbc, lcutoff, ucutoff ); drmsd_->read( pdb ); @@ -167,19 +165,14 @@ DRMSD::DRMSD(const ActionOptions&ao): requestAtoms( atoms ); // Setup the derivative pack - myvals.resize( 1, 3*atoms.size()+9 ); - mypack.resize( 0, atoms.size() ); - for(unsigned i=0; icalculate(getPositions(), getPbc(), mypack, false); setValue(drmsd); - for(unsigned i=0; i derivatives; std::vector my_pos=getPositions(); int atms = my_pos.size(); std::vector der_b2; - for(int i=0; i1) { + if(qexp<0.5 || qexp>1) warning("Dimer CV is meant to be used with q-exponents between 0.5 and 1. We are not responsible for any black hole. :-)"); - } - if(dsigma<0) { + if(dsigma<0) error("Please use positive sigma values for the Dimer strength constant"); - } - if(temperature<0) { + if(temperature<0) error("Please, use a positive value for the temperature..."); - } // if dsigmas has only one element means that either // you are using different plumed.x.dat files or a plumed.dat with a single replica - if(dsigmas.size()!=nranks && dsigmas.size()!=1) { + if(dsigmas.size()!=nranks && dsigmas.size()!=1) error("Mismatch between provided sigmas and number of replicas"); - } } diff --git a/src/colvar/Dipole.cpp b/src/colvar/Dipole.cpp index 90c61545c2..5e985e3c5b 100644 --- a/src/colvar/Dipole.cpp +++ b/src/colvar/Dipole.cpp @@ -81,21 +81,18 @@ void Dipole::registerKeywords(Keywords& keys) { Dipole::Dipole(const ActionOptions&ao): PLUMED_COLVAR_INIT(ao), - components(false) { + components(false) +{ parseAtomList("GROUP",ga_lista); parseFlag("COMPONENTS",components); parseFlag("NOPBC",nopbc); checkRead(); if(components) { - addComponentWithDerivatives("x"); - componentIsNotPeriodic("x"); - addComponentWithDerivatives("y"); - componentIsNotPeriodic("y"); - addComponentWithDerivatives("z"); - componentIsNotPeriodic("z"); + addComponentWithDerivatives("x"); componentIsNotPeriodic("x"); + addComponentWithDerivatives("y"); componentIsNotPeriodic("y"); + addComponentWithDerivatives("z"); componentIsNotPeriodic("z"); } else { - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); } log.printf(" of %u atoms\n",static_cast(ga_lista.size())); @@ -103,20 +100,16 @@ Dipole::Dipole(const ActionOptions&ao): log.printf(" %d", ga_lista[i].serial()); } log.printf(" \n"); - if(nopbc) { - log.printf(" without periodic boundary conditions\n"); - } else { - log.printf(" using periodic boundary conditions\n"); - } + if(nopbc) log.printf(" without periodic boundary conditions\n"); + else log.printf(" using periodic boundary conditions\n"); requestAtoms(ga_lista); } // calculator -void Dipole::calculate() { - if(!nopbc) { - makeWhole(); - } +void Dipole::calculate() +{ + if(!nopbc) makeWhole(); double ctot=0.; unsigned N=getNumberOfAtoms(); std::vector charges(N); diff --git a/src/colvar/Distance.cpp b/src/colvar/Distance.cpp index 94576cf3d7..bf901435f9 100644 --- a/src/colvar/Distance.cpp +++ b/src/colvar/Distance.cpp @@ -134,12 +134,12 @@ Distance::Distance(const ActionOptions&ao): PLUMED_COLVAR_INIT(ao), components(false), scaled_components(false), - pbc(true) { + pbc(true) +{ std::vector atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()!=2) { + if(atoms.size()!=2) error("Number of specified atoms should be 2"); - } parseFlag("COMPONENTS",components); parseFlag("SCALED_COMPONENTS",scaled_components); bool nopbc=!pbc; @@ -148,34 +148,22 @@ Distance::Distance(const ActionOptions&ao): checkRead(); log.printf(" between atoms %d %d\n",atoms[0].serial(),atoms[1].serial()); - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); - if(components && scaled_components) { - error("COMPONENTS and SCALED_COMPONENTS are not compatible"); - } + if(components && scaled_components) error("COMPONENTS and SCALED_COMPONENTS are not compatible"); if(components) { - addComponentWithDerivatives("x"); - componentIsNotPeriodic("x"); - addComponentWithDerivatives("y"); - componentIsNotPeriodic("y"); - addComponentWithDerivatives("z"); - componentIsNotPeriodic("z"); + addComponentWithDerivatives("x"); componentIsNotPeriodic("x"); + addComponentWithDerivatives("y"); componentIsNotPeriodic("y"); + addComponentWithDerivatives("z"); componentIsNotPeriodic("z"); log<<" WARNING: components will not have the proper periodicity - see manual\n"; } else if(scaled_components) { - addComponentWithDerivatives("a"); - componentIsPeriodic("a","-0.5","+0.5"); - addComponentWithDerivatives("b"); - componentIsPeriodic("b","-0.5","+0.5"); - addComponentWithDerivatives("c"); - componentIsPeriodic("c","-0.5","+0.5"); + addComponentWithDerivatives("a"); componentIsPeriodic("a","-0.5","+0.5"); + addComponentWithDerivatives("b"); componentIsPeriodic("b","-0.5","+0.5"); + addComponentWithDerivatives("c"); componentIsPeriodic("c","-0.5","+0.5"); } else { - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); } @@ -186,9 +174,7 @@ Distance::Distance(const ActionOptions&ao): // calculator void Distance::calculate() { - if(pbc) { - makeWhole(); - } + if(pbc) makeWhole(); Vector distance=delta(getPosition(0),getPosition(1)); const double value=distance.modulo(); diff --git a/src/colvar/EEFSolv.cpp b/src/colvar/EEFSolv.cpp index 9e752fa123..7cf1a1e07e 100644 --- a/src/colvar/EEFSolv.cpp +++ b/src/colvar/EEFSolv.cpp @@ -117,7 +117,8 @@ EEFSolv::EEFSolv(const ActionOptions&ao): delta_g_ref(0.), nl_buffer(0.1), nl_stride(40), - nl_update(0) { + nl_update(0) +{ std::vector atoms; parseAtomList("ATOMS", atoms); const unsigned size = atoms.size(); @@ -134,8 +135,7 @@ EEFSolv::EEFSolv(const ActionOptions&ao): checkRead(); - log << " Bibliography " << plumed.cite("Lazaridis T, Karplus M, Proteins Struct. Funct. Genet. 35, 133 (1999)"); - log << "\n"; + log << " Bibliography " << plumed.cite("Lazaridis T, Karplus M, Proteins Struct. Funct. Genet. 35, 133 (1999)"); log << "\n"; nl.resize(size); nlexpo.resize(size); @@ -157,9 +157,7 @@ void EEFSolv::update_neighb() { const Vector posi = getPosition(i); // Loop through neighboring atoms, add the ones below cutoff for (unsigned j=i+1; j mlambda) { - mlambda = 1./parameter[j][2]; - } + if (1./parameter[j][2] > mlambda) mlambda = 1./parameter[j][2]; const double c2 = (2. * mlambda + nl_buffer) * (2. * mlambda + nl_buffer); if (d2 < c2 ) { nl[i].push_back(j); if(parameter[i][2] == parameter[j][2] && parameter[i][3] == parameter[j][3]) { nlexpo[i].push_back(true); - } else { - nlexpo[i].push_back(false); - } + } else nlexpo[i].push_back(false); } } } } void EEFSolv::calculate() { - if(pbc) { - makeWhole(); - } - if(getExchangeStep()) { - nl_update = 0; - } - if(nl_update==0) { - update_neighb(); - } + if(pbc) makeWhole(); + if(getExchangeStep()) nl_update = 0; + if(nl_update==0) update_neighb(); const unsigned size=getNumberOfAtoms(); double bias = 0.0; @@ -210,9 +198,7 @@ void EEFSolv::calculate() { } unsigned nt=OpenMP::getNumThreads(); - if(nt*stride*10>size) { - nt=1; - } + if(nt*stride*10>size) nt=1; #pragma omp parallel num_threads(nt) { @@ -245,7 +231,8 @@ void EEFSolv::calculate() { // in this case we can calculate a single exponential if(!nlexpo[i][i_nl]) { // i-j interaction - if(inv_rij > 0.5*inv_lambda_i && delta_g_free_i!=0.) { + if(inv_rij > 0.5*inv_lambda_i && delta_g_free_i!=0.) + { const double e_arg = (rij - vdw_radius_i)*inv_lambda_i; const double expo = std::exp(-e_arg*e_arg); const double fact = expo*fact_ij; @@ -253,15 +240,13 @@ void EEFSolv::calculate() { const Vector dd = e_deriv*dist; fedensity += fact; deriv_i += dd; - if(nt>1) { - deriv_omp[j] -= dd; - } else { - deriv[j] -= dd; - } + if(nt>1) deriv_omp[j] -= dd; + else deriv[j] -= dd; } // j-i interaction - if(inv_rij > 0.5*inv_lambda_j && delta_g_free_j!=0.) { + if(inv_rij > 0.5*inv_lambda_j && delta_g_free_j!=0.) + { const double e_arg = (rij - vdw_radius_j)*inv_lambda_j; const double expo = std::exp(-e_arg*e_arg); const double fact = expo*fact_ji; @@ -269,15 +254,13 @@ void EEFSolv::calculate() { const Vector dd = e_deriv*dist; fedensity += fact; deriv_i += dd; - if(nt>1) { - deriv_omp[j] -= dd; - } else { - deriv[j] -= dd; - } + if(nt>1) deriv_omp[j] -= dd; + else deriv[j] -= dd; } } else { // i-j interaction - if(inv_rij > 0.5*inv_lambda_i) { + if(inv_rij > 0.5*inv_lambda_i) + { const double e_arg = (rij - vdw_radius_i)*inv_lambda_i; const double expo = std::exp(-e_arg*e_arg); const double fact = expo*(fact_ij + fact_ji); @@ -285,34 +268,23 @@ void EEFSolv::calculate() { const Vector dd = e_deriv*dist; fedensity += fact; deriv_i += dd; - if(nt>1) { - deriv_omp[j] -= dd; - } else { - deriv[j] -= dd; - } + if(nt>1) deriv_omp[j] -= dd; + else deriv[j] -= dd; } } } - if(nt>1) { - deriv_omp[i] += deriv_i; - } else { - deriv[i] += deriv_i; - } + if(nt>1) deriv_omp[i] += deriv_i; + else deriv[i] += deriv_i; bias += 0.5*fedensity; } #pragma omp critical - if(nt>1) - for(unsigned i=0; i1) for(unsigned i=0; i &atoms, std::vector > EEFSolv::setupTypeMap() { diff --git a/src/colvar/ERMSD.cpp b/src/colvar/ERMSD.cpp index a67c16db49..5ce858b23c 100644 --- a/src/colvar/ERMSD.cpp +++ b/src/colvar/ERMSD.cpp @@ -126,7 +126,8 @@ void ERMSD::registerKeywords(Keywords& keys) { } ERMSD::ERMSD(const ActionOptions&ao): - PLUMED_COLVAR_INIT(ao), pbc(true) { + PLUMED_COLVAR_INIT(ao), pbc(true) +{ std::string reference; parse("REFERENCE",reference); double cutoff=2.4; @@ -144,18 +145,11 @@ ERMSD::ERMSD(const ActionOptions&ao): parseVector("PAIRS",pairs_); checkRead(); - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); - if(atoms_.size()<6) { - error("at least six atoms should be specified"); - } - if(atoms_.size()%3!=0) { - error("Atoms are not multiple of 3"); - } - if(pairs_.size()%2!=0) { - error("pairs are not multiple of 2"); - } + if(atoms_.size()<6) error("at least six atoms should be specified"); + if(atoms_.size()%3!=0) error("Atoms are not multiple of 3"); + if(pairs_.size()%2!=0) error("pairs are not multiple of 2"); //checkRead(); @@ -165,9 +159,8 @@ ERMSD::ERMSD(const ActionOptions&ao): // read everything in ang and transform to nm if we are not in natural units PDB pdb; - if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) { + if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) error("missing input file " + reference ); - } // store target_ distance std::vector reference_positions; unsigned natoms = atoms_.size(); @@ -180,9 +173,7 @@ ERMSD::ERMSD(const ActionOptions&ao): } // shift to count from zero - for(unsigned i=0; iresizeDerivatives(1); log<<" Bibliography "; log<resizeDerivatives(1); parse("NAME",name); log<<" name: "< atoms; parseAtomList("ATOMS",atoms); diff --git a/src/colvar/GHBFIX.cpp b/src/colvar/GHBFIX.cpp index 6bcb6e19e8..a8fea5304f 100644 --- a/src/colvar/GHBFIX.cpp +++ b/src/colvar/GHBFIX.cpp @@ -97,7 +97,8 @@ void GHBFIX::registerKeywords( Keywords& keys ) { GHBFIX::GHBFIX(const ActionOptions&ao): Action(ao), - CoordinationBase(ao) { + CoordinationBase(ao) +{ std::string types; std::string params; std::string energy_units ="plumed" ; @@ -129,7 +130,8 @@ GHBFIX::GHBFIX(const ActionOptions&ao): if (MapTypesTable.empty()) { MapTypesTable.insert({itype, 0}); - } else if (MapTypesTable.count(itype) == 0) { + } + else if (MapTypesTable.count(itype) == 0) { unsigned currentMax = 0; for(auto it = MapTypesTable.cbegin(); it != MapTypesTable.cend(); ++it ) { if (it ->second > currentMax) { @@ -160,9 +162,7 @@ GHBFIX::GHBFIX(const ActionOptions&ao): if(energy_units!="plumed") { Units units; units.setEnergy(energy_units); - for(auto i=0; i atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()==0) { - error("no atoms specified"); - } + if(atoms.size()==0) error("no atoms specified"); parseFlag("MASS_WEIGHTED",use_masses); std::string Type; parse("TYPE",Type); parseFlag("NOPBC",nopbc); checkRead(); - if(Type=="RADIUS") { - rg_type=RADIUS; - } else if(Type=="TRACE") { - rg_type=TRACE; - } else if(Type=="GTPC_1") { - rg_type=GTPC_1; - } else if(Type=="GTPC_2") { - rg_type=GTPC_2; - } else if(Type=="GTPC_3") { - rg_type=GTPC_3; - } else if(Type=="ASPHERICITY") { - rg_type=ASPHERICITY; - } else if(Type=="ACYLINDRICITY") { - rg_type=ACYLINDRICITY; - } else if(Type=="KAPPA2") { - rg_type=KAPPA2; - } else if(Type=="RGYR_3") { - rg_type=GYRATION_3; - } else if(Type=="RGYR_2") { - rg_type=GYRATION_2; - } else if(Type=="RGYR_1") { - rg_type=GYRATION_1; - } else { - error("Unknown GYRATION type"); - } - - switch(rg_type) { - case RADIUS: - log.printf(" GYRATION RADIUS (Rg);"); - break; - case TRACE: - log.printf(" TRACE OF THE GYRATION TENSOR;"); - break; - case GTPC_1: - log.printf(" THE LARGEST PRINCIPAL MOMENT OF THE GYRATION TENSOR (S'_1);"); - break; - case GTPC_2: - log.printf(" THE MIDDLE PRINCIPAL MOMENT OF THE GYRATION TENSOR (S'_2);"); - break; - case GTPC_3: - log.printf(" THE SMALLEST PRINCIPAL MOMENT OF THE GYRATION TENSOR (S'_3);"); - break; - case ASPHERICITY: - log.printf(" THE ASPHERICITY (b');"); - break; - case ACYLINDRICITY: - log.printf(" THE ACYLINDRICITY (c');"); - break; - case KAPPA2: - log.printf(" THE RELATIVE SHAPE ANISOTROPY (kappa^2);"); - break; - case GYRATION_3: - log.printf(" THE SMALLEST PRINCIPAL RADIUS OF GYRATION (r_g3);"); - break; - case GYRATION_2: - log.printf(" THE MIDDLE PRINCIPAL RADIUS OF GYRATION (r_g2);"); - break; - case GYRATION_1: - log.printf(" THE LARGEST PRINCIPAL RADIUS OF GYRATION (r_g1);"); - break; - } - if(rg_type>TRACE) { - log<<" Bibliography "<TRACE) log<<" Bibliography "<0.0001) { - error("Plumed Error: Cannot diagonalize gyration tensor\n"); - } + if(std::abs(det-1.)>0.0001) error("Plumed Error: Cannot diagonalize gyration tensor\n"); switch(rg_type) { case GTPC_1: case GTPC_2: - case GTPC_3: { + case GTPC_3: + { int pc_index = rg_type-2; //index of principal component rgyr=std::sqrt(princ_comp[pc_index]/totmass); double rm = rgyr*totmass; - if(rm>1e-6) { - prefactor[pc_index]=1.0/rm; //some parts of derivate - } + if(rm>1e-6) prefactor[pc_index]=1.0/rm; //some parts of derivate break; } - case GYRATION_3: { //the smallest principal radius of gyration + case GYRATION_3: //the smallest principal radius of gyration + { rgyr=std::sqrt((princ_comp[1]+princ_comp[2])/totmass); double rm = rgyr*totmass; if (rm>1e-6) { @@ -351,7 +285,8 @@ void Gyration::calculate() { } break; } - case GYRATION_2: { //the midle principal radius of gyration + case GYRATION_2: //the midle principal radius of gyration + { rgyr=std::sqrt((princ_comp[0]+princ_comp[2])/totmass); double rm = rgyr*totmass; if (rm>1e-6) { @@ -360,7 +295,8 @@ void Gyration::calculate() { } break; } - case GYRATION_1: { //the largest principal radius of gyration + case GYRATION_1: //the largest principal radius of gyration + { rgyr=std::sqrt((princ_comp[0]+princ_comp[1])/totmass); double rm = rgyr*totmass; if (rm>1e-6) { @@ -369,7 +305,8 @@ void Gyration::calculate() { } break; } - case ASPHERICITY: { + case ASPHERICITY: + { rgyr=std::sqrt((princ_comp[0]-0.5*(princ_comp[1]+princ_comp[2]))/totmass); double rm = rgyr*totmass; if (rm>1e-6) { @@ -379,7 +316,8 @@ void Gyration::calculate() { } break; } - case ACYLINDRICITY: { + case ACYLINDRICITY: + { rgyr=std::sqrt((princ_comp[1]-princ_comp[2])/totmass); double rm = rgyr*totmass; if (rm>1e-6) { //avoid division by zero @@ -388,7 +326,8 @@ void Gyration::calculate() { } break; } - case KAPPA2: { // relative shape anisotropy + case KAPPA2: // relative shape anisotropy + { double trace = princ_comp[0]+princ_comp[1]+princ_comp[2]; double tmp=princ_comp[0]*princ_comp[1]+ princ_comp[1]*princ_comp[2]+ princ_comp[0]*princ_comp[2]; rgyr=1.0-3*(tmp/(trace*trace)); @@ -406,13 +345,10 @@ void Gyration::calculate() { Vector tX; const Vector diff=delta( com,getPosition(i) ); //project atomic postional vectors to diagonalized frame - for(unsigned j=0; j<3; j++) { - tX[j]=transf[0][j]*diff[0]+transf[1][j]*diff[1]+transf[2][j]*diff[2]; - } - for(unsigned j=0; j<3; j++) - derivatives[i][j]=getMass(i)*(prefactor[0]*transf[j][0]*tX[0]+ - prefactor[1]*transf[j][1]*tX[1]+ - prefactor[2]*transf[j][2]*tX[2]); + for(unsigned j=0; j<3; j++) tX[j]=transf[0][j]*diff[0]+transf[1][j]*diff[1]+transf[2][j]*diff[2]; + for(unsigned j=0; j<3; j++) derivatives[i][j]=getMass(i)*(prefactor[0]*transf[j][0]*tX[0]+ + prefactor[1]*transf[j][1]*tX[1]+ + prefactor[2]*transf[j][2]*tX[2]); setAtomsDerivatives(i,derivatives[i]); } } else { @@ -420,13 +356,10 @@ void Gyration::calculate() { Vector tX; const Vector diff=delta( com,getPosition(i) ); //project atomic postional vectors to diagonalized frame - for(unsigned j=0; j<3; j++) { - tX[j]=transf[0][j]*diff[0]+transf[1][j]*diff[1]+transf[2][j]*diff[2]; - } - for(unsigned j=0; j<3; j++) - derivatives[i][j]=prefactor[0]*transf[j][0]*tX[0]+ - prefactor[1]*transf[j][1]*tX[1]+ - prefactor[2]*transf[j][2]*tX[2]; + for(unsigned j=0; j<3; j++) tX[j]=transf[0][j]*diff[0]+transf[1][j]*diff[1]+transf[2][j]*diff[2]; + for(unsigned j=0; j<3; j++) derivatives[i][j]=prefactor[0]*transf[j][0]*tX[0]+ + prefactor[1]*transf[j][1]*tX[1]+ + prefactor[2]*transf[j][2]*tX[2]; setAtomsDerivatives(i,derivatives[i]); } } diff --git a/src/colvar/MultiRMSD.cpp b/src/colvar/MultiRMSD.cpp index 20141b25bd..24e94eb5e6 100644 --- a/src/colvar/MultiRMSD.cpp +++ b/src/colvar/MultiRMSD.cpp @@ -150,7 +150,8 @@ void MultiRMSD::registerKeywords(Keywords& keys) { } MultiRMSD::MultiRMSD(const ActionOptions&ao): - PLUMED_COLVAR_INIT(ao),squared(false),myvals(1,0), mypack(0,0,myvals),nopbc(false) { + PLUMED_COLVAR_INIT(ao),squared(false),myvals(1,0), mypack(0,0,myvals),nopbc(false) +{ std::string reference; parse("REFERENCE",reference); std::string type; @@ -160,64 +161,46 @@ MultiRMSD::MultiRMSD(const ActionOptions&ao): parseFlag("NOPBC",nopbc); checkRead(); - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); PDB pdb; // read everything in ang and transform to nm if we are not in natural units - if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) { + if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) error("missing input file " + reference ); - } rmsd=metricRegister().create(type,pdb); // Do not align molecule if we are doing DRMSD for domains and NOPBC has been specified in input - if( pdb.hasFlag("NOPBC") ) { - nopbc=true; - } + if( pdb.hasFlag("NOPBC") ) nopbc=true; std::vector atoms; rmsd->getAtomRequests( atoms ); requestAtoms( atoms ); - myvals.resize( 1, 3*atoms.size()+9 ); - mypack.resize( 0, atoms.size() ); - for(unsigned i=0; icalculate( getPositions(), getPbc(), mypack, squared ); setValue(r); - for(unsigned i=0; i(); bool remove_com=true; bool normalize_weights=true; // here align and displace are a simple vector of ones - std::vector align; - align=pdb.getOccupancy(); - for(unsigned i=0; i displace; - displace=pdb.getBeta(); - for(unsigned i=0; i align; align=pdb.getOccupancy(); for(unsigned i=0; i displace; displace=pdb.getBeta(); for(unsigned i=0; iset(align,displace,pdb.getPositions(),type,remove_com,normalize_weights); requestAtoms( pdb.getAtomNumbers() ); - addComponentWithDerivatives("residual"); - componentIsNotPeriodic("residual"); + addComponentWithDerivatives("residual"); componentIsNotPeriodic("residual"); log.printf(" average from file %s\n",f_average.c_str()); log.printf(" which contains %d atoms\n",getNumberOfAtoms()); log.printf(" with indices : "); for(unsigned i=0; ifopen(f_eigenvectors.c_str(),"r")) { + if (FILE* fp=this->fopen(f_eigenvectors.c_str(),"r")) + { // call fclose when exiting this block - auto deleter=[this](FILE* f) { - this->fclose(f); - }; + auto deleter=[this](FILE* f) { this->fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); std::vector aaa; @@ -198,42 +180,25 @@ PCARMSD::PCARMSD(const ActionOptions&ao): do_read=mypdb.readFromFilepointer(fp,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()); if(do_read) { neigenvects++; - if(mypdb.getAtomNumbers().size()==0) { - error("number of atoms in a frame should be more than zero"); - } - if(nat==0) { - nat=mypdb.getAtomNumbers().size(); - } - if(nat!=mypdb.getAtomNumbers().size()) { - error("frames should have the same number of atoms"); - } - if(aaa.empty()) { - aaa=mypdb.getAtomNumbers(); - } - if(aaa!=mypdb.getAtomNumbers()) { - error("frames should contain same atoms in same order"); - } + if(mypdb.getAtomNumbers().size()==0) error("number of atoms in a frame should be more than zero"); + if(nat==0) nat=mypdb.getAtomNumbers().size(); + if(nat!=mypdb.getAtomNumbers().size()) error("frames should have the same number of atoms"); + if(aaa.empty()) aaa=mypdb.getAtomNumbers(); + if(aaa!=mypdb.getAtomNumbers()) error("frames should contain same atoms in same order"); log<<" Found eigenvector: "< > drotdpos(3,3); std::vector alignedpos; @@ -265,11 +228,9 @@ void PCARMSD::calculate() { for(unsigned i=0; iset(val); // here the loop is reversed to better suit the structure of the derivative of the rotation matrix @@ -295,9 +256,7 @@ void PCARMSD::calculate() { } } - for(int i=0; i v; - v.push_back(i); - indexvec.push_back(v); - i+=1.; + std::vector v; v.push_back(i); + indexvec.push_back(v); i+=1.; } } diff --git a/src/colvar/PathMSDBase.cpp b/src/colvar/PathMSDBase.cpp index acc2b8ac6c..013874eabb 100644 --- a/src/colvar/PathMSDBase.cpp +++ b/src/colvar/PathMSDBase.cpp @@ -51,7 +51,8 @@ PathMSDBase::PathMSDBase(const ActionOptions&ao): debugClose(0), logClose(0), computeRefClose(false), - nframes(0) { + nframes(0) +{ parse("LAMBDA",lambda); parse("NEIGH_SIZE",neigh_size); parse("NEIGH_STRIDE",neigh_stride); @@ -62,11 +63,10 @@ PathMSDBase::PathMSDBase(const ActionOptions&ao): parseFlag("NOPBC",nopbc); // open the file - if (FILE* fp=this->fopen(reference.c_str(),"r")) { + if (FILE* fp=this->fopen(reference.c_str(),"r")) + { // call fclose when exiting this block - auto deleter=[this](FILE* f) { - this->fclose(f); - }; + auto deleter=[this](FILE* f) { this->fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); std::vector aaa; @@ -79,44 +79,30 @@ PathMSDBase::PathMSDBase(const ActionOptions&ao): do_read=mypdb.readFromFilepointer(fp,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()); if(do_read) { nframes++; - if(mypdb.getAtomNumbers().size()==0) { - error("number of atoms in a frame should be more than zero"); - } - if(nat==0) { - nat=mypdb.getAtomNumbers().size(); - } - if(nat!=mypdb.getAtomNumbers().size()) { - error("frames should have the same number of atoms"); - } + if(mypdb.getAtomNumbers().size()==0) error("number of atoms in a frame should be more than zero"); + if(nat==0) nat=mypdb.getAtomNumbers().size(); + if(nat!=mypdb.getAtomNumbers().size()) error("frames should have the same number of atoms"); if(aaa.empty()) { aaa=mypdb.getAtomNumbers(); log.printf(" found %zu atoms in input \n",aaa.size()); log.printf(" with indices : "); for(unsigned i=0; i 0) { log.printf(" Computing with the close structure, epsilon = %lf\n", epsilonClose); log << " Bibliography " << plumed.cite("Pazurikova J, Krenek A, Spiwok V, Simkova M J. Chem. Phys. 146, 115101 (2017)") << "\n"; - } else { + } + else { debugClose = 0; logClose = 0; } - if (debugClose) { + if (debugClose) log.printf(" Extensive debug info regarding close structure turned on\n"); - } rotationRefClose.resize(nframes); savedIndices = std::vector(nframes); - if(nopbc) { - log.printf(" without periodic boundary conditions\n"); - } else { - log.printf(" using periodic boundary conditions\n"); - } + if(nopbc) log.printf(" without periodic boundary conditions\n"); + else log.printf(" using periodic boundary conditions\n"); } @@ -159,15 +142,11 @@ PathMSDBase::~PathMSDBase() { void PathMSDBase::calculate() { - if(neigh_size>0 && getExchangeStep()) { - error("Neighbor lists for this collective variable are not compatible with replica exchange, sorry for that!"); - } + if(neigh_size>0 && getExchangeStep()) error("Neighbor lists for this collective variable are not compatible with replica exchange, sorry for that!"); //log.printf("NOW CALCULATE! \n"); - if(!nopbc) { - makeWhole(); - } + if(!nopbc) makeWhole(); // resize the list to full @@ -196,9 +175,8 @@ void PathMSDBase::calculate() { //if we compute for the first time or the existing close structure is too far from current structure if (firstPosClose || (posclose > epsilonClose)) { //set the current structure as close one for a few next steps - if (logClose) { + if (logClose) log << "PLUMED_CLOSE: new close structure, rmsd pos close " << posclose << "\n"; - } rmsdPosClose.clear(); rmsdPosClose.setReference(getPositions()); //as this is a new close structure, we need to save the rotation matrices fitted to the reference structures @@ -210,11 +188,11 @@ void PathMSDBase::calculate() { imgVec[i].index=i; } firstPosClose = false; - } else { + } + else { //the current structure is pretty close to the close structure, so we use saved rotation matrices to decrease the complexity of rmsd comuptation - if (debugClose) { + if (debugClose) log << "PLUMED-CLOSE: old close structure, rmsd pos close " << posclose << "\n"; - } computeRefClose = false; } } @@ -232,19 +210,16 @@ void PathMSDBase::calculate() { tmp_distances[i] = msdv[imgVec[i].index].calc_Rot(getPositions(), tmp_derivs, tmp_rotationRefClose[imgVec[i].index], true); plumed_assert(tmp_derivs.size()==nat); #pragma omp simd - for(unsigned j=0; j val_s_path; if(labels.size()>0) { - for(unsigned i=0; i s_path(val_s_path.size()); - for(unsigned i=0; i s_path(val_s_path.size()); for(unsigned i=0; iset(s_path[i]) ; - } + for(unsigned i=0; iset(s_path[i]) ;} val_z_path->set(-(1./lambda)*std::log(partition)); for(unsigned j=0; j atoms; parseAtomList("ATOM",atoms); - if(atoms.size()!=1) { + if(atoms.size()!=1) error("Number of specified atoms should be 1"); - } parseFlag("SCALED_COMPONENTS",scaled_components); bool nopbc=!pbc; parseFlag("NOPBC",nopbc); @@ -112,26 +112,17 @@ Position::Position(const ActionOptions&ao): checkRead(); log.printf(" for atom %d\n",atoms[0].serial()); - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); if(scaled_components) { - addComponentWithDerivatives("a"); - componentIsPeriodic("a","-0.5","+0.5"); - addComponentWithDerivatives("b"); - componentIsPeriodic("b","-0.5","+0.5"); - addComponentWithDerivatives("c"); - componentIsPeriodic("c","-0.5","+0.5"); + addComponentWithDerivatives("a"); componentIsPeriodic("a","-0.5","+0.5"); + addComponentWithDerivatives("b"); componentIsPeriodic("b","-0.5","+0.5"); + addComponentWithDerivatives("c"); componentIsPeriodic("c","-0.5","+0.5"); } else { - addComponentWithDerivatives("x"); - componentIsNotPeriodic("x"); - addComponentWithDerivatives("y"); - componentIsNotPeriodic("y"); - addComponentWithDerivatives("z"); - componentIsNotPeriodic("z"); + addComponentWithDerivatives("x"); componentIsNotPeriodic("x"); + addComponentWithDerivatives("y"); componentIsNotPeriodic("y"); + addComponentWithDerivatives("z"); componentIsNotPeriodic("z"); log<<" WARNING: components will not have the proper periodicity - see manual\n"; } diff --git a/src/colvar/ProjectionOnAxis.cpp b/src/colvar/ProjectionOnAxis.cpp index 4c1083b0e0..705d18c8a8 100644 --- a/src/colvar/ProjectionOnAxis.cpp +++ b/src/colvar/ProjectionOnAxis.cpp @@ -88,34 +88,26 @@ void ProjectionOnAxis::registerKeywords( Keywords& keys ) { ProjectionOnAxis::ProjectionOnAxis(const ActionOptions&ao): PLUMED_COLVAR_INIT(ao), - pbc(true) { + pbc(true) +{ std::vector axis_atoms; parseAtomList("AXIS_ATOMS",axis_atoms); - if( axis_atoms.size()!=2 ) { - error("There should only be two atoms specified to AXIS_ATOMS keyword"); - } + if( axis_atoms.size()!=2 ) error("There should only be two atoms specified to AXIS_ATOMS keyword"); std::vector atom; parseAtomList("ATOM",atom); - if( atom.size()!=1 ) { - error("There should only be one atom specified to ATOM keyword"); - } + if( atom.size()!=1 ) error("There should only be one atom specified to ATOM keyword"); log.printf(" calculating projection of vector connecting atom %d and atom %d on vector connecting atom %d and atom %d \n", axis_atoms[0].serial(), atom[0].serial(), axis_atoms[0].serial(), axis_atoms[1].serial() ); bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" not using periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" not using periodic boundary conditions\n"); // Add values to store data - addComponentWithDerivatives("proj"); - componentIsNotPeriodic("proj"); - addComponentWithDerivatives("ext"); - componentIsNotPeriodic("ext"); + addComponentWithDerivatives("proj"); componentIsNotPeriodic("proj"); + addComponentWithDerivatives("ext"); componentIsNotPeriodic("ext"); // Get all the atom positions axis_atoms.push_back( atom[0] ); requestAtoms(axis_atoms); @@ -133,10 +125,8 @@ void ProjectionOnAxis::calculate() { rik = delta( getPosition(2), getPosition(0) ); rjk = delta( getPosition(2), getPosition(1) ); } - Vector rij = delta( rik, rjk ); - double dij = rij.modulo(); - Vector nij = (1.0/dij)*rij; - Tensor dij_a1; + Vector rij = delta( rik, rjk ); double dij = rij.modulo(); + Vector nij = (1.0/dij)*rij; Tensor dij_a1; // Derivative of director connecting atom1 - atom2 wrt the position of atom 1 dij_a1(0,0) = ( -(nij[1]*nij[1]+nij[2]*nij[2])/dij ); // dx/dx dij_a1(0,1) = ( nij[0]*nij[1]/dij ); // dx/dy @@ -153,22 +143,19 @@ void ProjectionOnAxis::calculate() { Vector dd1 = matmul(-rik, dij_a1) - nij; Vector dd2 = matmul(rik, dij_a1); Vector dd3 = nij; - Value* pval=getPntrToComponent("proj"); - pval->set( d ); + Value* pval=getPntrToComponent("proj"); pval->set( d ); setAtomsDerivatives( pval, 0, dd1 ); setAtomsDerivatives( pval, 1, dd2 ); setAtomsDerivatives( pval, 2, dd3 ); setBoxDerivatives( pval, -Tensor( rik, dd1 ) - Tensor( rjk, dd2 ) ); // Calculate derivatives of perpendicular distance from axis - double c = std::sqrt( rik.modulo2() - d*d ); - double invc = (1.0/c); + double c = std::sqrt( rik.modulo2() - d*d ); double invc = (1.0/c); // Calculate derivatives of the other thing Vector der1 = invc*(rik - d*dd1); Vector der2 = invc*(-d*dd2); Vector der3 = invc*(-rik - d*dd3); - Value* cval=getPntrToComponent("ext"); - cval->set( c ); + Value* cval=getPntrToComponent("ext"); cval->set( c ); setAtomsDerivatives( cval, 0, der1 ); setAtomsDerivatives( cval, 1, der2 ); setAtomsDerivatives( cval, 2, der3 ); diff --git a/src/colvar/PropertyMap.cpp b/src/colvar/PropertyMap.cpp index 2a97bc83ac..2c6bde5d7b 100644 --- a/src/colvar/PropertyMap.cpp +++ b/src/colvar/PropertyMap.cpp @@ -105,7 +105,8 @@ void PropertyMap::registerKeywords(Keywords& keys) { PropertyMap::PropertyMap(const ActionOptions&ao): Action(ao), - PathMSDBase(ao) { + PathMSDBase(ao) +{ // this is the only additional keyword needed parseVector("PROPERTY",labels); checkRead(); @@ -120,21 +121,18 @@ PropertyMap::PropertyMap(const ActionOptions&ao): } else { for(unsigned i=0; i labelvals; for(unsigned j=0; j atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()!=5 && atoms.size()!=6) { - error("only for 5 or 6-membered rings"); - } + if(atoms.size()!=5 && atoms.size()!=6) error("only for 5 or 6-membered rings"); checkRead(); if(atoms.size()==5) { log.printf(" between atoms %d %d %d %d %d\n",atoms[0].serial(),atoms[1].serial(),atoms[2].serial(),atoms[3].serial(),atoms[4].serial()); } else if(atoms.size()==6) { log.printf(" between atoms %d %d %d %d %d %d\n",atoms[0].serial(),atoms[1].serial(),atoms[2].serial(),atoms[3].serial(),atoms[4].serial(),atoms[5].serial()); - } else { - error("ATOMS should specify 5 atoms"); - } + } else error("ATOMS should specify 5 atoms"); if(atoms.size()==5) { - addComponentWithDerivatives("phs"); - componentIsPeriodic("phs","-pi","pi"); - addComponentWithDerivatives("amp"); - componentIsNotPeriodic("amp"); - addComponentWithDerivatives("Zx"); - componentIsNotPeriodic("Zx"); - addComponentWithDerivatives("Zy"); - componentIsNotPeriodic("Zy"); + addComponentWithDerivatives("phs"); componentIsPeriodic("phs","-pi","pi"); + addComponentWithDerivatives("amp"); componentIsNotPeriodic("amp"); + addComponentWithDerivatives("Zx"); componentIsNotPeriodic("Zx"); + addComponentWithDerivatives("Zy"); componentIsNotPeriodic("Zy"); } else if(atoms.size()==6) { - addComponentWithDerivatives("qx"); - componentIsNotPeriodic("qx"); - addComponentWithDerivatives("qy"); - componentIsNotPeriodic("qy"); - addComponentWithDerivatives("qz"); - componentIsNotPeriodic("qz"); - addComponentWithDerivatives("phi"); - componentIsPeriodic("phi","0","2pi"); - addComponentWithDerivatives("theta"); - componentIsNotPeriodic("theta"); - addComponentWithDerivatives("amplitude"); - componentIsNotPeriodic("amplitude"); + addComponentWithDerivatives("qx"); componentIsNotPeriodic("qx"); + addComponentWithDerivatives("qy"); componentIsNotPeriodic("qy"); + addComponentWithDerivatives("qz"); componentIsNotPeriodic("qz"); + addComponentWithDerivatives("phi"); componentIsPeriodic("phi","0","2pi"); + addComponentWithDerivatives("theta"); componentIsNotPeriodic("theta"); + addComponentWithDerivatives("amplitude"); componentIsNotPeriodic("amplitude"); } log<<" Bibliography "; - if(atoms.size()==5) { - log<set(Zx); @@ -257,26 +229,16 @@ void Puckering::calculate5m() { void Puckering::calculate6m() { std::vector r(6); - for(unsigned i=0; i<6; i++) { - r[i]=getPosition(i); - } + for(unsigned i=0; i<6; i++) r[i]=getPosition(i); std::vector R(6); Vector center; - for(unsigned j=0; j<6; j++) { - center+=r[j]/6.0; - } - for(unsigned j=0; j<6; j++) { - R[j]=(r[j]-center); - } + for(unsigned j=0; j<6; j++) center+=r[j]/6.0; + for(unsigned j=0; j<6; j++) R[j]=(r[j]-center); Vector Rp,Rpp; - for(unsigned j=0; j<6; j++) { - Rp +=R[j]*std::sin(2.0/6.0*pi*j); - } - for(unsigned j=0; j<6; j++) { - Rpp+=R[j]*std::cos(2.0/6.0*pi*j); - } + for(unsigned j=0; j<6; j++) Rp +=R[j]*std::sin(2.0/6.0*pi*j); + for(unsigned j=0; j<6; j++) Rpp+=R[j]*std::cos(2.0/6.0*pi*j); Vector n=crossProduct(Rp,Rpp); Vector nhat=n/modulo(n); @@ -289,78 +251,50 @@ void Puckering::calculate6m() { Tensor dnhat_dRpp=matmul(dnhat_dn,dn_dRpp); std::vector z(6); - for(unsigned j=0; j<6; j++) { - z[j]=dotProduct(R[j],nhat); - } + for(unsigned j=0; j<6; j++) z[j]=dotProduct(R[j],nhat); std::vector > dz_dR(6); - for(unsigned j=0; j<6; j++) { - dz_dR[j].resize(6); - } + for(unsigned j=0; j<6; j++) dz_dR[j].resize(6); - for(unsigned i=0; i<6; i++) - for(unsigned j=0; j<6; j++) { - if(i==j) { - dz_dR[i][j]+=nhat; - } + for(unsigned i=0; i<6; i++) for(unsigned j=0; j<6; j++) { + if(i==j) dz_dR[i][j]+=nhat; dz_dR[i][j]+=matmul(R[i],dnhat_dRp)*std::sin(2.0/6.0*pi*j); dz_dR[i][j]+=matmul(R[i],dnhat_dRpp)*std::cos(2.0/6.0*pi*j); } double B=0.0; - for(unsigned j=0; j<6; j++) { - B+=z[j]*std::cos(4.0/6.0*pi*j); - } + for(unsigned j=0; j<6; j++) B+=z[j]*std::cos(4.0/6.0*pi*j); std::vector dB_dR(6); - for(unsigned i=0; i<6; i++) - for(unsigned j=0; j<6; j++) { + for(unsigned i=0; i<6; i++) for(unsigned j=0; j<6; j++) { dB_dR[i]+=dz_dR[j][i]*std::cos(4.0/6.0*pi*j); } Vector Bsum; - for(unsigned j=0; j<6; j++) { - Bsum+=dB_dR[j]; - } - for(unsigned j=0; j<6; j++) { - dB_dR[j]-=Bsum/6.0; - }; + for(unsigned j=0; j<6; j++) Bsum+=dB_dR[j]; + for(unsigned j=0; j<6; j++) dB_dR[j]-=Bsum/6.0;; double A=0.0; - for(unsigned j=0; j<6; j++) { - A+=z[j]*std::sin(4.0/6.0*pi*j); - } + for(unsigned j=0; j<6; j++) A+=z[j]*std::sin(4.0/6.0*pi*j); std::vector dA_dR(6); - for(unsigned i=0; i<6; i++) - for(unsigned j=0; j<6; j++) { + for(unsigned i=0; i<6; i++) for(unsigned j=0; j<6; j++) { dA_dR[i]+=dz_dR[j][i]*std::sin(4.0/6.0*pi*j); } Vector Asum; - for(unsigned j=0; j<6; j++) { - Asum+=dA_dR[j]; - } - for(unsigned j=0; j<6; j++) { - dA_dR[j]-=Asum/6.0; - }; + for(unsigned j=0; j<6; j++) Asum+=dA_dR[j]; + for(unsigned j=0; j<6; j++) dA_dR[j]-=Asum/6.0;; double C=0.0; - for(unsigned j=0; j<6; j++) { - C+=z[j]*Tools::fastpow(-1.0,(j)); - } + for(unsigned j=0; j<6; j++) C+=z[j]*Tools::fastpow(-1.0,(j)); std::vector dC_dR(6); - for(unsigned i=0; i<6; i++) - for(unsigned j=0; j<6; j++) { + for(unsigned i=0; i<6; i++) for(unsigned j=0; j<6; j++) { dC_dR[i]+=dz_dR[j][i]*Tools::fastpow(-1.0,(j)); } Vector Csum; - for(unsigned j=0; j<6; j++) { - Csum+=dC_dR[j]; - } - for(unsigned j=0; j<6; j++) { - dC_dR[j]-=Csum/6.0; - }; + for(unsigned j=0; j<6; j++) Csum+=dC_dR[j]; + for(unsigned j=0; j<6; j++) dC_dR[j]-=Csum/6.0;; // qx diff --git a/src/colvar/RMSD.cpp b/src/colvar/RMSD.cpp index 67af1f0870..5aa710a5d4 100644 --- a/src/colvar/RMSD.cpp +++ b/src/colvar/RMSD.cpp @@ -173,7 +173,8 @@ RMSD::RMSD(const ActionOptions&ao): myvals(1,0), mypack(0,0,myvals), squared(false), - nopbc(false) { + nopbc(false) +{ std::string reference; parse("REFERENCE",reference); std::string type; @@ -185,14 +186,12 @@ RMSD::RMSD(const ActionOptions&ao): checkRead(); - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); PDB pdb; // read everything in ang and transform to nm if we are not in natural units - if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) { + if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) error("missing input file " + reference ); - } rmsd=metricRegister().create(type,pdb); @@ -202,48 +201,33 @@ RMSD::RMSD(const ActionOptions&ao): requestAtoms( atoms ); // Setup the derivative pack - myvals.resize( 1, 3*atoms.size()+9 ); - mypack.resize( 0, atoms.size() ); - for(unsigned i=0; icalculate( getPositions(), mypack, squared ); setValue(r); - for(unsigned i=0; i atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()!=2) { + if(atoms.size()!=2) error("Number of specified atoms should be 2"); - } bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; checkRead(); log.printf(" between atoms %d %d\n",atoms[0].serial(),atoms[1].serial()); - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); requestAtoms(atoms); } diff --git a/src/colvar/Torsion.cpp b/src/colvar/Torsion.cpp index 9a8062691a..955c5eb5ae 100644 --- a/src/colvar/Torsion.cpp +++ b/src/colvar/Torsion.cpp @@ -111,7 +111,8 @@ void Torsion::registerKeywords(Keywords& keys) { Torsion::Torsion(const ActionOptions&ao): PLUMED_COLVAR_INIT(ao), pbc(true), - do_cosine(false) { + do_cosine(false) +{ std::vector atoms,v1,v2,axis; parseAtomList("ATOMS",atoms); parseAtomList("VECTOR1",v1); @@ -126,9 +127,8 @@ Torsion::Torsion(const ActionOptions&ao): checkRead(); if(atoms.size()==4) { - if(!(v1.empty() && v2.empty() && axis.empty())) { + if(!(v1.empty() && v2.empty() && axis.empty())) error("ATOMS keyword is not compatible with VECTOR1, VECTOR2 and AXIS keywords"); - } log.printf(" between atoms %d %d %d %d\n",atoms[0].serial(),atoms[1].serial(),atoms[2].serial(),atoms[3].serial()); atoms.resize(6); atoms[5]=atoms[3]; @@ -136,9 +136,8 @@ Torsion::Torsion(const ActionOptions&ao): atoms[3]=atoms[2]; atoms[2]=atoms[1]; } else if(atoms.empty()) { - if(!(v1.size()==2 && v2.size()==2 && axis.size()==2)) { + if(!(v1.size()==2 && v2.size()==2 && axis.size()==2)) error("VECTOR1, VECTOR2 and AXIS should specify 2 atoms each"); - } log.printf(" between lines %d-%d and %d-%d, projected on the plane orthogonal to line %d-%d\n", v1[0].serial(),v1[1].serial(),v2[0].serial(),v2[1].serial(),axis[0].serial(),axis[1].serial()); atoms.resize(6); @@ -148,26 +147,16 @@ Torsion::Torsion(const ActionOptions&ao): atoms[3]=axis[1]; atoms[4]=v2[0]; atoms[5]=v2[1]; - } else { - error("ATOMS should specify 4 atoms"); - } + } else error("ATOMS should specify 4 atoms"); - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); - if(do_cosine) { - log.printf(" calculating cosine instead of torsion\n"); - } + if(do_cosine) log.printf(" calculating cosine instead of torsion\n"); addValueWithDerivatives(); - if(!do_cosine) { - setPeriodic("-pi","pi"); - } else { - setNotPeriodic(); - } + if(!do_cosine) setPeriodic("-pi","pi"); + else setNotPeriodic(); requestAtoms(atoms); } @@ -175,9 +164,7 @@ Torsion::Torsion(const ActionOptions&ao): void Torsion::calculate() { Vector d0,d1,d2; - if(pbc) { - makeWhole(); - } + if(pbc) makeWhole(); d0=delta(getPosition(1),getPosition(0)); d1=delta(getPosition(3),getPosition(2)); d2=delta(getPosition(5),getPosition(4)); diff --git a/src/colvar/Volume.cpp b/src/colvar/Volume.cpp index 956d0db351..9da5e497ac 100644 --- a/src/colvar/Volume.cpp +++ b/src/colvar/Volume.cpp @@ -54,12 +54,12 @@ class Volume : public Colvar { PLUMED_REGISTER_ACTION(Volume,"VOLUME") Volume::Volume(const ActionOptions&ao): - PLUMED_COLVAR_INIT(ao) { + PLUMED_COLVAR_INIT(ao) +{ std::vector atoms; checkRead(); - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); requestAtoms(atoms); } diff --git a/src/config/Config.inc.in b/src/config/Config.inc.in index 725b142067..9c55128e68 100644 --- a/src/config/Config.inc.in +++ b/src/config/Config.inc.in @@ -47,21 +47,11 @@ std::string escapeForSingleQuote(const std::string& input) { // This is a fix to allow conda to correctly replace paths in binary files. // These functions should not be static or they will be optimized away! -const char* plumed_root() { - return "@PLUMED_ROOT@"; -} -const char* plumed_soext() { - return "@SOEXT@"; -} -const char* plumed_htmldir() { - return "@htmldir@"; -} -const char* plumed_includedir() { - return "@includedir@"; -} -const char* plumed_program_name() { - return "@program_name@"; -} +const char* plumed_root() {return "@PLUMED_ROOT@";} +const char* plumed_soext() {return "@SOEXT@";} +const char* plumed_htmldir() {return "@htmldir@";} +const char* plumed_includedir() {return "@includedir@";} +const char* plumed_program_name() {return "@program_name@";} std::string getSoExt() { return plumed_soext(); @@ -83,9 +73,7 @@ std::string getPlumedRoot() { } std::string getPlumedHtmldir() { - if(!isInstalled()) { - return getPlumedRoot(); - } + if(!isInstalled()) return getPlumedRoot(); char *env = std::getenv("PLUMED_HTMLDIR"); std::string ss; if( env == NULL) { @@ -97,9 +85,7 @@ std::string getPlumedHtmldir() { } std::string getPlumedIncludedir() { - if(!isInstalled()) { - return getPlumedRoot()+"/src/include"; - } + if(!isInstalled()) return getPlumedRoot()+"/src/include"; char *env = std::getenv("PLUMED_INCLUDEDIR"); std::string ss; if( env == NULL) { @@ -111,9 +97,7 @@ std::string getPlumedIncludedir() { } std::string getPlumedProgramName() { - if(!isInstalled()) { - return "plumed"; - } + if(!isInstalled()) return "plumed"; char *env = std::getenv("PLUMED_PROGRAM_NAME"); std::string ss; if( env == NULL) { diff --git a/src/core/Action.cpp b/src/core/Action.cpp index def24f097d..7fca31e000 100644 --- a/src/core/Action.cpp +++ b/src/core/Action.cpp @@ -35,13 +35,15 @@ Keywords ActionOptions::emptyKeys; ActionOptions::ActionOptions(PlumedMain&p,const std::vector&l): plumed(p), line(l), - keys(emptyKeys) { + keys(emptyKeys) +{ } ActionOptions::ActionOptions(const ActionOptions&ao,const Keywords&keys): plumed(ao.plumed), line(ao.line), - keys(keys) { + keys(keys) +{ } void Action::registerKeywords( Keywords& keys ) { @@ -64,7 +66,8 @@ Action::Action(const ActionOptions&ao): log(plumed.getLog()), comm(plumed.comm), multi_sim_comm(plumed.multi_sim_comm), - keywords(ao.keys) { + keywords(ao.keys) +{ line.erase(line.begin()); log.printf("Action %s\n",name.c_str()); @@ -73,45 +76,27 @@ Action::Action(const ActionOptions&ao): } comm.Bcast(replica_index,0); - if ( keywords.exists("LABEL") ) { - parse("LABEL",label); - } + if ( keywords.exists("LABEL") ) { parse("LABEL",label); } if(label.length()==0) { - std::string s; - Tools::convert(plumed.getActionSet().size(),s); + std::string s; Tools::convert(plumed.getActionSet().size(),s); label="@"+s; } - if( plumed.getActionSet().selectWithLabel(label) ) { - error("label " + label + " has been already used"); - } + if( plumed.getActionSet().selectWithLabel(label) ) error("label " + label + " has been already used"); log.printf(" with label %s\n",label.c_str()); - if ( keywords.exists("UPDATE_FROM") ) { - parse("UPDATE_FROM",update_from); - } - if(update_from!=std::numeric_limits::max()) { - log.printf(" only update from time %f\n",update_from); - } - if ( keywords.exists("UPDATE_UNTIL") ) { - parse("UPDATE_UNTIL",update_until); - } - if(update_until!=std::numeric_limits::max()) { - log.printf(" only update until time %f\n",update_until); - } + if ( keywords.exists("UPDATE_FROM") ) parse("UPDATE_FROM",update_from); + if(update_from!=std::numeric_limits::max()) log.printf(" only update from time %f\n",update_from); + if ( keywords.exists("UPDATE_UNTIL") ) parse("UPDATE_UNTIL",update_until); + if(update_until!=std::numeric_limits::max()) log.printf(" only update until time %f\n",update_until); if ( keywords.exists("RESTART") ) { std::string srestart="AUTO"; parse("RESTART",srestart); - if( plumed.parseOnlyMode() ) { - restart=false; - } else if(srestart=="YES") { - restart=true; - } else if(srestart=="NO") { - restart=false; - } else if(srestart=="AUTO") { + if( plumed.parseOnlyMode() ) restart=false; + else if(srestart=="YES") restart=true; + else if(srestart=="NO") restart=false; + else if(srestart=="AUTO") { // do nothing, this is the default - } else { - error("RESTART should be either YES, NO, or AUTO"); - } + } else error("RESTART should be either YES, NO, or AUTO"); } } @@ -123,16 +108,10 @@ Action::~Action() { FILE* Action::fopen(const char *path, const char *mode) { bool write(false); - for(const char*p=mode; *p; p++) - if(*p=='w' || *p=='a' || *p=='+') { - write=true; - } + for(const char*p=mode; *p; p++) if(*p=='w' || *p=='a' || *p=='+') write=true; FILE* fp; - if(write && comm.Get_rank()!=0) { - fp=plumed.fopen("/dev/null",mode); - } else { - fp=plumed.fopen(path,mode); - } + if(write && comm.Get_rank()!=0) fp=plumed.fopen("/dev/null",mode); + else fp=plumed.fopen(path,mode); files.insert(fp); return fp; } @@ -153,15 +132,11 @@ std::string Action::getKeyword(const std::string& key) { plumed_massert(keywords.exists(key), "keyword " + key + " has not been registered"); std::string outkey; - if( Tools::getKey(line,key,outkey ) ) { - return key + outkey; - } + if( Tools::getKey(line,key,outkey ) ) return key + outkey; if( keywords.style(key,"compulsory") ) { if( keywords.getDefaultValue(key,outkey) ) { - if( outkey.length()==0 ) { - error("keyword " + key + " has weird default value"); - } + if( outkey.length()==0 ) error("keyword " + key + " has weird default value"); return key + "=" + outkey; } else { error("keyword " + key + " is compulsory for this action"); @@ -202,21 +177,15 @@ void Action::activate() { this->unlockRequests(); prepare(); this->lockRequests(); - } else { - return; - } - for(const auto & p : after) { - p->activate(); - } + } else return; + for(const auto & p : after) p->activate(); active=true; } void Action::setOption(const std::string &s) { // This overloads the action and activate some options options.insert(s); - for(const auto & p : after) { - p->setOption(s); - } + for(const auto & p : after) p->setOption(s); } void Action::clearOptions() { @@ -233,9 +202,7 @@ void Action::checkRead() { if(!line.empty()) { std::string msg="cannot understand the following words from the input line : "; for(unsigned i=0; i0) { - msg = msg + ", "; - } + if(i>0) msg = msg + ", "; msg = msg + line[i]; } error(msg); @@ -281,10 +248,7 @@ void Action::calculateFromPDB( const PDB& pdb ) { activate(); for(const auto & p : after) { ActionWithValue*av=dynamic_cast(p); - if(av) { - av->clearInputForces(); - av->clearDerivatives(); - } + if(av) { av->clearInputForces(); av->clearDerivatives(); } p->readAtomsFromPDB( pdb ); p->calculate(); } @@ -303,11 +267,8 @@ std::string Action::cite(const std::string&s) { /// Check if action should be updated. bool Action::checkUpdate()const { double t=getTime(); - if(t::max() || t>=update_from)) { - return true; - } else { - return false; - } + if(t::max() || t>=update_from)) return true; + else return false; } bool Action::getCPT()const { diff --git a/src/core/Action.h b/src/core/Action.h index 94ec925f5a..ffbf75cb77 100644 --- a/src/core/Action.h +++ b/src/core/Action.h @@ -254,19 +254,13 @@ class Action { bool isOptionOn(const std::string &s)const; /// Return dependencies - const Dependencies & getDependencies()const { - return after; - } + const Dependencies & getDependencies()const {return after;} /// Check if numerical derivatives should be performed - virtual bool checkNumericalDerivatives()const { - return false; - } + virtual bool checkNumericalDerivatives()const {return false;} /// Check if the action needs gradient - virtual bool checkNeedsGradients()const { - return false; - } + virtual bool checkNeedsGradients()const {return false;} /// Perform calculation using numerical derivatives /// N.B. only pass an ActionWithValue to this routine if you know exactly what you @@ -320,9 +314,7 @@ void Action::parse(const std::string&key,T&t) { std::string def; bool present=Tools::findKeyword(line,key); bool found=Tools::parse(line,key,t,replica_index); - if(present && !found) { - error("keyword " + key +" could not be read correctly"); - } + if(present && !found) error("keyword " + key +" could not be read correctly"); // If it isn't read and it is compulsory see if a default value was specified if ( !found && (keywords.style(key,"compulsory") || keywords.style(key,"hidden")) ) { @@ -341,13 +333,10 @@ template bool Action::parseNumbered(const std::string&key, const int no, T&t) { // Check keyword has been registered plumed_massert(keywords.exists(key),"keyword " + key + " has not been registered"); - if( !keywords.numbered(key) ) { - error("numbered keywords are not allowed for " + key ); - } + if( !keywords.numbered(key) ) error("numbered keywords are not allowed for " + key ); // Now try to read the keyword - std::string num; - Tools::convert(no,num); + std::string num; Tools::convert(no,num); return Tools::parse(line,key+num,t,replica_index); } @@ -355,28 +344,20 @@ template void Action::parseVector(const std::string&key,std::vector&t) { // Check keyword has been registered plumed_massert(keywords.exists(key), "keyword " + key + " has not been registered"); - unsigned size=t.size(); - bool skipcheck=false; - if(size==0) { - skipcheck=true; - } + unsigned size=t.size(); bool skipcheck=false; + if(size==0) skipcheck=true; // Now try to read the keyword - std::string def; - T val; + std::string def; T val; bool present=Tools::findKeyword(line,key); bool found=Tools::parseVector(line,key,t,replica_index); - if(present && !found) { - error("keyword " + key +" could not be read correctly"); - } + if(present && !found) error("keyword " + key +" could not be read correctly"); // Check vectors size is correct (not if this is atoms or ARG) if( !keywords.style(key,"atoms") && found ) { // bool skipcheck=false; // if( keywords.style(key,"compulsory") ){ keywords.getDefaultValue(key,def); skipcheck=(def=="nosize"); } - if( !skipcheck && t.size()!=size ) { - error("vector read in for keyword " + key + " has the wrong size"); - } + if( !skipcheck && t.size()!=size ) error("vector read in for keyword " + key + " has the wrong size"); } // If it isn't read and it is compulsory see if a default value was specified @@ -386,17 +367,9 @@ void Action::parseVector(const std::string&key,std::vector&t) { plumed_error() <<"ERROR in action "<0) { - for(unsigned i=0; i&t) { template bool Action::parseNumberedVector(const std::string&key, const int no, std::vector&t) { plumed_massert(keywords.exists(key),"keyword " + key + " has not been registered"); - if( !keywords.numbered(key) ) { - error("numbered keywords are not allowed for " + key ); - } + if( !keywords.numbered(key) ) error("numbered keywords are not allowed for " + key ); - unsigned size=t.size(); - bool skipcheck=false; - if(size==0) { - skipcheck=true; - } - std::string num; - Tools::convert(no,num); + unsigned size=t.size(); bool skipcheck=false; + if(size==0) skipcheck=true; + std::string num; Tools::convert(no,num); bool present=Tools::findKeyword(line,key); bool found=Tools::parseVector(line,key+num,t,replica_index); - if(present && !found) { - error("keyword " + key +" could not be read correctly"); - } + if(present && !found) error("keyword " + key +" could not be read correctly"); if( keywords.style(key,"compulsory") ) { - if (!skipcheck && found && t.size()!=size ) { - error("vector read in for keyword " + key + num + " has the wrong size"); - } + if (!skipcheck && found && t.size()!=size ) error("vector read in for keyword " + key + num + " has the wrong size"); } else if ( !found ) { t.resize(0); } diff --git a/src/core/ActionAnyorder.cpp b/src/core/ActionAnyorder.cpp index ed7d8a528f..b9b9991208 100644 --- a/src/core/ActionAnyorder.cpp +++ b/src/core/ActionAnyorder.cpp @@ -27,7 +27,8 @@ namespace PLMD { ActionAnyorder::ActionAnyorder(const ActionOptions&ao): - Action(ao) { + Action(ao) +{ } void ActionAnyorder::registerKeywords( Keywords& keys ) { diff --git a/src/core/ActionAtomistic.cpp b/src/core/ActionAtomistic.cpp index ad3bb9f232..9b409bfea5 100644 --- a/src/core/ActionAtomistic.cpp +++ b/src/core/ActionAtomistic.cpp @@ -45,7 +45,8 @@ ActionAtomistic::ActionAtomistic(const ActionOptions&ao): lockRequestAtoms(false), donotretrieve(false), donotforce(false), - atoms(plumed.getAtoms()) { + atoms(plumed.getAtoms()) +{ atoms.add(this); // if(atoms.getNatoms()==0) error("Cannot perform calculations involving atoms without atoms"); } @@ -64,23 +65,13 @@ void ActionAtomistic::requestAtoms(const std::vector & a, const bool masses.resize(nat); charges.resize(nat); int n=atoms.positions.size(); - if(clearDep) { - clearDependencies(); - } + if(clearDep) clearDependencies(); unique.clear(); for(unsigned i=0; i=n) { - std::string num; - Tools::convert( indexes[i].serial(),num ); - error("atom " + num + " out of range"); - } - if(atoms.isVirtualAtom(indexes[i])) { - addDependency(atoms.getVirtualAtomsAction(indexes[i])); - } + if(indexes[i].index()>=n) { std::string num; Tools::convert( indexes[i].serial(),num ); error("atom " + num + " out of range"); } + if(atoms.isVirtualAtom(indexes[i])) addDependency(atoms.getVirtualAtomsAction(indexes[i])); // only real atoms are requested to lower level Atoms class - else { - unique.push_back(indexes[i]); - } + else unique.push_back(indexes[i]); } Tools::removeDuplicates(unique); updateUniqueLocal(); @@ -116,8 +107,7 @@ void ActionAtomistic::calculateAtomicNumericalDerivatives( ActionWithValue* a, c std::vector savedPositions(natoms); const double delta=std::sqrt(epsilon); - for(int i=0; icalculate(); @@ -127,26 +117,17 @@ void ActionAtomistic::calculateAtomicNumericalDerivatives( ActionWithValue* a, c } } Tensor box(pbc.getBox()); - for(int i=0; i<3; i++) - for(int k=0; k<3; k++) { + for(int i=0; i<3; i++) for(int k=0; k<3; k++) { double arg0=box(i,k); - for(int j=0; jcalculate(); box(i,k)=arg0; pbc.setBox(box); - for(int j=0; jgetOutputQuantity(j); - } + for(int j=0; jgetOutputQuantity(j); } a->calculate(); @@ -155,22 +136,15 @@ void ActionAtomistic::calculateAtomicNumericalDerivatives( ActionWithValue* a, c Value* v=a->copyOutput(j); double ref=v->get(); if(v->hasDerivatives()) { - for(int i=0; iaddDerivative(startnum+3*i+k,d); } Tensor virial; - for(int i=0; i<3; i++) - for(int k=0; k<3; k++) { - virial(i,k)= (valuebox[j](i,k)-ref)/delta; - } + for(int i=0; i<3; i++) for(int k=0; k<3; k++)virial(i,k)= (valuebox[j](i,k)-ref)/delta; // BE CAREFUL WITH NON ORTHOROMBIC CELL virial=-matmul(box.transpose(),virial); - for(int i=0; i<3; i++) - for(int k=0; k<3; k++) { - v->addDerivative(startnum+3*natoms+3*k+i,virial(k,i)); - } + for(int i=0; i<3; i++) for(int k=0; k<3; k++) v->addDerivative(startnum+3*natoms+3*k+i,virial(k,i)); } } } @@ -184,54 +158,38 @@ void ActionAtomistic::parseAtomList(const std::string&key,const int num, std::ve std::vector strings; if( num<0 ) { parseVector(key,strings); - if(strings.empty()) { - return; - } + if(strings.empty()) return; } else { - if ( !parseNumberedVector(key,num,strings) ) { - return; - } + if ( !parseNumberedVector(key,num,strings) ) return; } interpretAtomList( strings, t ); } void ActionAtomistic::interpretAtomList(std::vector& strings, std::vector &t) { - Tools::interpretRanges(strings); - t.resize(0); + Tools::interpretRanges(strings); t.resize(0); for(unsigned i=0; i(this); if( moldat ) { - std::vector atom_list; - moldat->interpretSymbol( symbol, atom_list ); - if( atom_list.size()>0 ) { - ok=true; - t.insert(t.end(),atom_list.begin(),atom_list.end()); - } else { - error(strings[i] + " is not a label plumed knows"); - } + std::vector atom_list; moldat->interpretSymbol( symbol, atom_list ); + if( atom_list.size()>0 ) { ok=true; t.insert(t.end(),atom_list.begin(),atom_list.end()); } + else { error(strings[i] + " is not a label plumed knows"); } } else { error("atoms specified using @ symbol but no MOLINFO was available"); } @@ -250,17 +208,14 @@ void ActionAtomistic::interpretAtomList(std::vector& strings, std:: const ActionSet&actionSet(plumed.getActionSet()); for(const auto & a : actionSet) { ActionWithVirtualAtom* c=dynamic_cast(a.get()); - if(c) - if(c->getLabel()==strings[i]) { + if(c) if(c->getLabel()==strings[i]) { ok=true; t.push_back(c->getIndex()); break; } } } - if(!ok) { - error("it was not possible to interpret atom name " + strings[i]); - } + if(!ok) error("it was not possible to interpret atom name " + strings[i]); // plumed_massert(ok,"it was not possible to interpret atom name " + strings[i]); } } @@ -268,80 +223,49 @@ void ActionAtomistic::interpretAtomList(std::vector& strings, std:: void ActionAtomistic::retrieveAtoms() { pbc=atoms.pbc; Colvar*cc=dynamic_cast(this); - if(cc && cc->checkIsEnergy()) { - energy=atoms.getEnergy(); - } - if(donotretrieve) { - return; - } + if(cc && cc->checkIsEnergy()) energy=atoms.getEnergy(); + if(donotretrieve) return; chargesWereSet=atoms.chargesWereSet(); const std::vector & p(atoms.positions); const std::vector & c(atoms.charges); const std::vector & m(atoms.masses); - for(unsigned j=0; j& forcesToApply, unsigned ind) { - if(donotforce) { - return; - } + if(donotforce) return; for(unsigned i=0; i& f(atoms.forces); Tensor& v(atoms.virial); - for(unsigned j=0; j0) { - atoms.updateExtraCVForce(extraCV,forceOnExtraCV); - } + if(extraCV.length()>0) atoms.updateExtraCVForce(extraCV,forceOnExtraCV); } void ActionAtomistic::clearOutputForces() { virial.zero(); - if(donotforce) { - return; - } + if(donotforce) return; Tools::set_to_zero(forces); forceOnEnergy=0.0; forceOnExtraCV=0.0; @@ -350,25 +274,15 @@ void ActionAtomistic::clearOutputForces() { void ActionAtomistic::readAtomsFromPDB(const PDB& pdb) { Colvar*cc=dynamic_cast(this); - if(cc && cc->checkIsEnergy()) { - error("can't read energies from pdb files"); - } + if(cc && cc->checkIsEnergy()) error("can't read energies from pdb files"); for(unsigned j=0; jpdb.size() ) { - error("there are not enough atoms in the input pdb file"); - } - if( pdb.getAtomNumbers()[j].index()!=indexes[j].index() ) { - error("there are atoms missing in the pdb file"); - } + if( indexes[j].index()>pdb.size() ) error("there are not enough atoms in the input pdb file"); + if( pdb.getAtomNumbers()[j].index()!=indexes[j].index() ) error("there are atoms missing in the pdb file"); positions[j]=pdb.getPositions()[indexes[j].index()]; } - for(unsigned j=0; j0) { unique_local.clear(); for(auto pp=unique.begin(); pp!=unique.end(); ++pp) { - if(atoms.g2l[pp->index()]>=0) { - unique_local.push_back(*pp); // already sorted - } + if(atoms.g2l[pp->index()]>=0) unique_local.push_back(*pp); // already sorted } } else { unique_local=unique; // copy diff --git a/src/core/ActionAtomistic.h b/src/core/ActionAtomistic.h index b83eab468a..714fe911c7 100644 --- a/src/core/ActionAtomistic.h +++ b/src/core/ActionAtomistic.h @@ -38,7 +38,8 @@ class PDB; /// \ingroup MULTIINHERIT /// Action used to create objects that access the positions of the atoms from the MD code class ActionAtomistic : - virtual public Action { + virtual public Action +{ std::vector indexes; // the set of needed atoms /// unique should be an ordered set since we later create a vector containing the corresponding indexes @@ -126,9 +127,7 @@ class ActionAtomistic : /// Get a reference to force on extraCV double & modifyForceOnExtraCV(); /// Get number of available atoms - unsigned getNumberOfAtoms()const { - return indexes.size(); - } + unsigned getNumberOfAtoms()const {return indexes.size();} /// Compute the pbc distance between two positions Vector pbcDistance(const Vector&,const Vector&)const; /// Applies PBCs to a seriens of positions or distances @@ -154,21 +153,15 @@ class ActionAtomistic : /// not going to be retrieved. Can be used for optimization. Notice that /// calling getPosition(int) in an Action where DoNotRetrieve() was called might /// lead to undefined behavior. - void doNotRetrieve() { - donotretrieve=true; - } + void doNotRetrieve() {donotretrieve=true;} /// Skip atom forces - use with care. /// If this function is called during initialization, then forces are /// not going to be propagated. Can be used for optimization. - void doNotForce() { - donotforce=true; - } + void doNotForce() {donotforce=true;} /// Make atoms whole, assuming they are in the proper order void makeWhole(); /// Allow calls to modifyGlobalForce() - void allowToAccessGlobalForces() { - atoms.zeroallforces=true; - } + void allowToAccessGlobalForces() {atoms.zeroallforces=true;} /// updates local unique atoms void updateUniqueLocal(); public: @@ -232,9 +225,7 @@ double ActionAtomistic::getMass(int i)const { inline double ActionAtomistic::getCharge(int i) const { - if( !chargesWereSet ) { - error("charges were not passed to plumed"); - } + if( !chargesWereSet ) error("charges were not passed to plumed"); return charges[i]; } diff --git a/src/core/ActionPilot.cpp b/src/core/ActionPilot.cpp index 762dda9a78..69643eb70a 100644 --- a/src/core/ActionPilot.cpp +++ b/src/core/ActionPilot.cpp @@ -27,21 +27,18 @@ void ActionPilot::registerKeywords(Keywords& keys) {} ActionPilot::ActionPilot(const ActionOptions&ao): Action(ao), - stride(1) { + stride(1) +{ if( keywords.exists("STRIDE") ) { parse("STRIDE",stride); - if( !keywords.style("STRIDE","hidden") ) { - log.printf(" with stride %d\n",stride); - } + if( !keywords.style("STRIDE","hidden") ) log.printf(" with stride %d\n",stride); } else { stride=0; } } bool ActionPilot::onStep()const { - if( stride>0 ) { - return getStep()%stride==0; - } + if( stride>0 ) return getStep()%stride==0; return false; } diff --git a/src/core/ActionPilot.h b/src/core/ActionPilot.h index 27b9610be1..6c6c458a90 100644 --- a/src/core/ActionPilot.h +++ b/src/core/ActionPilot.h @@ -37,7 +37,8 @@ it in order to run. This class is used in PLMD::Bias which is specified on the directive line with a STRIDE= keyword */ class ActionPilot: - public virtual Action { + public virtual Action +{ int stride; // multiple time step public: explicit ActionPilot(const ActionOptions&); diff --git a/src/core/ActionRegister.cpp b/src/core/ActionRegister.cpp index 62ace3d17f..0eb01fdbf1 100644 --- a/src/core/ActionRegister.cpp +++ b/src/core/ActionRegister.cpp @@ -30,9 +30,7 @@ namespace PLMD { ActionRegister::~ActionRegister() { if(m.size()>0) { std::string names=""; - for(const auto & p : m) { - names+=p.first+" "; - } + for(const auto & p : m) names+=p.first+" "; std::cerr<<"WARNING: Directive "+ names +" has not been properly unregistered. This might lead to memory leak!!\n"; } } @@ -45,18 +43,14 @@ ActionRegister& actionRegister() { void ActionRegister::remove(creator_pointer f) { for(auto p=m.begin(); p!=m.end(); ++p) { if((*p).second==f) { - m.erase(p); - break; + m.erase(p); break; } } } void ActionRegister::add(std::string key,creator_pointer f,keywords_pointer k) { // this force each action to be registered as an uppercase string - if ( std::any_of( std::begin( key ), std::end( key ), []( char c ) { - return ( std::islower( c ) ) - ; - } ) ) plumed_error() << "Action: " + key + " cannot be registered, use only UPPERCASE characters"; + if ( std::any_of( std::begin( key ), std::end( key ), []( char c ) { return ( std::islower( c ) ); } ) ) plumed_error() << "Action: " + key + " cannot be registered, use only UPPERCASE characters"; if(m.count(key)) { m.erase(key); disabled.insert(key); @@ -70,16 +64,12 @@ void ActionRegister::add(std::string key,creator_pointer f,keywords_pointer k) { } bool ActionRegister::check(const std::string & key) { - if(m.count(key)>0 && mk.count(key)>0) { - return true; - } + if(m.count(key)>0 && mk.count(key)>0) return true; return false; } std::unique_ptr ActionRegister::create(const ActionOptions&ao) { - if(ao.line.size()<1) { - return NULL; - } + if(ao.line.size()<1)return NULL; // Create a copy of the manual locally. The manual is // then added to the ActionOptions. This allows us to // ensure during construction that all the keywords for @@ -88,8 +78,7 @@ std::unique_ptr ActionRegister::create(const ActionOptions&ao) { // in the input. std::unique_ptr action; if( check(ao.line[0]) ) { - Keywords keys; - mk[ao.line[0]](keys); + Keywords keys; mk[ao.line[0]](keys); ActionOptions nao( ao,keys ); action=m[ao.line[0]](nao); } @@ -97,21 +86,15 @@ std::unique_ptr ActionRegister::create(const ActionOptions&ao) { } bool ActionRegister::getKeywords(const std::string& action, Keywords& keys) { - if ( check(action) ) { - mk[action](keys); - return true; - } + if ( check(action) ) { mk[action](keys); return true; } return false; } bool ActionRegister::printManual(const std::string& action, const bool& vimout, const bool& spellout) { if ( check(action) ) { - Keywords keys; - getKeywords( action, keys ); + Keywords keys; getKeywords( action, keys ); if( vimout ) { - printf("%s",action.c_str()); - keys.print_vim(); - printf("\n"); + printf("%s",action.c_str()); keys.print_vim(); printf("\n"); } else if( spellout ) { keys.print_spelling(); } else { @@ -125,8 +108,7 @@ bool ActionRegister::printManual(const std::string& action, const bool& vimout, bool ActionRegister::printTemplate(const std::string& action, bool include_optional) { if( check(action) ) { - Keywords keys; - mk[action](keys); + Keywords keys; mk[action](keys); keys.print_template(action, include_optional); return true; } else { @@ -136,27 +118,21 @@ bool ActionRegister::printTemplate(const std::string& action, bool include_optio std::vector ActionRegister::getActionNames() const { std::vector s; - for(const auto & it : m) { - s.push_back(it.first); - } + for(const auto & it : m) s.push_back(it.first); std::sort(s.begin(),s.end()); return s; } std::ostream & operator<<(std::ostream &log,const ActionRegister&ar) { std::vector s(ar.getActionNames()); - for(unsigned i=0; i=0; i--) { - (*this)[i].reset(); - } + for(int i=size()-1; i>=0; i--) (*this)[i].reset(); } void ActionSet::clearDelete() { - for(int i=size()-1; i>=0; i--) { - (*this)[i].reset(); - } + for(int i=size()-1; i>=0; i--) (*this)[i].reset(); clear(); } diff --git a/src/core/ActionSet.h b/src/core/ActionSet.h index 0954fb4806..a6193fd100 100644 --- a/src/core/ActionSet.h +++ b/src/core/ActionSet.h @@ -37,7 +37,8 @@ class PlumedMain; /// Finally, since it holds pointers, there is a clearDelete() function /// which deletes the pointers before deleting the vector class ActionSet: - public std::vector> { + public std::vector> +{ PlumedMain& plumed; public: explicit ActionSet(PlumedMain&p); @@ -84,9 +85,7 @@ std::vector ActionSet::select()const { std::vector ret; for(const auto & p : (*this)) { T t=dynamic_cast(p.get()); - if(t) { - ret.push_back(t); - } + if(t) ret.push_back(t); }; return ret; } @@ -95,9 +94,7 @@ template T ActionSet::selectWithLabel(const std::string&s)const { for(const auto & p : (*this)) { T t=dynamic_cast(p.get()); - if(t && dynamic_cast(t)->getLabel()==s) { - return t; - } + if(t && dynamic_cast(t)->getLabel()==s) return t; }; return NULL; } @@ -107,9 +104,7 @@ std::vector ActionSet::selectNot()const { std::vector ret; for(const auto & p : (*this)) { T t=dynamic_cast(p); - if(!t) { - ret.push_back(p.get()); - } + if(!t) ret.push_back(p.get()); }; return ret; } @@ -118,9 +113,7 @@ template std::string ActionSet::getLabelList() const { std::string outlist; for(const auto & p : (*this)) { - if(dynamic_cast(p.get())) { - outlist+=p->getLabel()+" "; - } + if(dynamic_cast(p.get())) outlist+=p->getLabel()+" "; }; return outlist; } @@ -130,9 +123,7 @@ template std::vector ActionSet::getLabelVector() const { std::vector outlist; for(const auto & p : (*this)) { - if(dynamic_cast(p.get())) { - outlist.push_back(p->getLabel()); - } + if(dynamic_cast(p.get())) outlist.push_back(p->getLabel()); }; return outlist; } @@ -141,13 +132,9 @@ template T ActionSet::selectLatest(const Action*action) const { T t=nullptr; for(const auto & p : (*this)) { - if(p.get()==action) { - return t; - } + if(p.get()==action) return t; T r=dynamic_cast(p.get()); - if(r) { - t=r; - } + if(r) t=r; } return t; } diff --git a/src/core/ActionSetup.cpp b/src/core/ActionSetup.cpp index dc5ddde1f6..eef278fc1f 100644 --- a/src/core/ActionSetup.cpp +++ b/src/core/ActionSetup.cpp @@ -28,13 +28,12 @@ namespace PLMD { ActionSetup::ActionSetup(const ActionOptions&ao): - Action(ao) { + Action(ao) +{ const ActionSet& actionset(plumed.getActionSet()); for(const auto & p : actionset) { // check that all the preceding actions are ActionSetup - if( !dynamic_cast(p.get()) && !dynamic_cast(p.get()) ) { - error("Action " + getLabel() + " is a setup action, and should be only preceded by other setup actions or by actions that can be used in any order."); - } + if( !dynamic_cast(p.get()) && !dynamic_cast(p.get()) ) error("Action " + getLabel() + " is a setup action, and should be only preceded by other setup actions or by actions that can be used in any order."); } } diff --git a/src/core/ActionShortcut.cpp b/src/core/ActionShortcut.cpp index a35aa648f6..da873f5c55 100644 --- a/src/core/ActionShortcut.cpp +++ b/src/core/ActionShortcut.cpp @@ -32,38 +32,26 @@ void ActionShortcut::registerKeywords( Keywords& keys ) { ActionShortcut::ActionShortcut(const ActionOptions&ao): Action(ao), - shortcutlabel(label) { - std::string s; - Tools::convert(plumed.getActionSet().size(),s); + shortcutlabel(label) +{ + std::string s; Tools::convert(plumed.getActionSet().size(),s); if( shortcutlabel==("@" + s) ) { - std::string t; - Tools::convert(plumed.getActionSet().size()+1,t); + std::string t; Tools::convert(plumed.getActionSet().size()+1,t); shortcutlabel="@" + t; - } else { - label = ("@" + s); - } + } else label = ("@" + s); } void ActionShortcut::readInputLine( const std::string& input ) { - std::string f_input = input; - savedInputLines.push_back( input ); + std::string f_input = input; savedInputLines.push_back( input ); if( update_from!=std::numeric_limits::max() ) { - std::string ufrom; - Tools::convert( update_from, ufrom ); - f_input += " UPDATE_FROM=" + ufrom; + std::string ufrom; Tools::convert( update_from, ufrom ); f_input += " UPDATE_FROM=" + ufrom; } if( update_until!=std::numeric_limits::max() ) { - std::string util; - Tools::convert( update_until, util ); - f_input += " UPDATE_UNTIL=" + util; + std::string util; Tools::convert( update_until, util ); f_input += " UPDATE_UNTIL=" + util; } if( keywords.exists("RESTART") ) { - if( restart ) { - f_input += " RESTART=YES"; - } - if( !restart ) { - f_input += " RESTART=NO"; - } + if( restart ) f_input += " RESTART=YES"; + if( !restart ) f_input += " RESTART=NO"; } plumed.readInputLine( f_input ); } diff --git a/src/core/ActionWithArguments.cpp b/src/core/ActionWithArguments.cpp index 6f1e9b4deb..56e1acc345 100644 --- a/src/core/ActionWithArguments.cpp +++ b/src/core/ActionWithArguments.cpp @@ -46,16 +46,10 @@ void ActionWithArguments::registerKeywords(Keywords& keys) { } void ActionWithArguments::parseArgumentList(const std::string&key,std::vector&arg) { - std::string def; - std::vector c; - arg.clear(); - parseVector(key,c); + std::string def; std::vector c; arg.clear(); parseVector(key,c); if( c.size()==0 && (keywords.style(key,"compulsory") || keywords.style(key,"hidden")) ) { - if( keywords.getDefaultValue(key,def) ) { - c.push_back( def ); - } else { - return; - } + if( keywords.getDefaultValue(key,def) ) c.push_back( def ); + else return; } interpretArgumentList(c,arg); } @@ -66,9 +60,7 @@ bool ActionWithArguments::parseArgumentList(const std::string&key,int i,std::vec if(parseNumberedVector(key,i,c)) { interpretArgumentList(c,arg); return true; - } else { - return false; - } + } else return false; } void ActionWithArguments::interpretArgumentList(const std::vector& c, std::vector&arg) { @@ -95,18 +87,14 @@ void ActionWithArguments::interpretArgumentList(const std::vector& } // call regfree when reg goes out of scope - auto deleter=[](regex_t* r) { - regfree(r); - }; + auto deleter=[](regex_t* r) { regfree(r); }; std::unique_ptr reg_deleter(®,deleter); plumed_massert(reg.re_nsub==1,"I can parse with only one subexpression"); regmatch_t match; // select all the actions that have a value std::vector all=plumed.getActionSet().select(); - if( all.empty() ) { - error("your input file is not telling plumed to calculate anything"); - } + if( all.empty() ) error("your input file is not telling plumed to calculate anything"); bool found_something=false; for(unsigned j=0; j ss=all[j]->getComponentsVector(); @@ -137,9 +125,7 @@ void ActionWithArguments::interpretArgumentList(const std::vector& } } } - if(!found_something) { - plumed_error()<<"There isn't any action matching your regex " << myregex; - } + if(!found_something) plumed_error()<<"There isn't any action matching your regex " << myregex; #else plumed_merror("Regexp support not compiled!"); #endif @@ -154,13 +140,9 @@ void ActionWithArguments::interpretArgumentList(const std::vector& if(a=="*" && name=="*") { // Take all values from all actions std::vector all=plumed.getActionSet().select(); - if( all.empty() ) { - error("your input file is not telling plumed to calculate anything"); - } + if( all.empty() ) error("your input file is not telling plumed to calculate anything"); for(unsigned j=0; jgetNumberOfComponents(); ++k) { - arg.push_back(all[j]->copyOutput(k)); - } + for(int k=0; kgetNumberOfComponents(); ++k) arg.push_back(all[j]->copyOutput(k)); } } else if ( name=="*") { // Take all the values from an action with a specific name @@ -170,30 +152,18 @@ void ActionWithArguments::interpretArgumentList(const std::vector& str+=plumed.getActionSet().getLabelList()+")"; error("cannot find action named " + a + str); } - if( action->getNumberOfComponents()==0 ) { - error("found " + a +".* indicating use all components calculated by action with label " + a + " but this action has no components"); - } - for(int k=0; kgetNumberOfComponents(); ++k) { - arg.push_back(action->copyOutput(k)); - } + if( action->getNumberOfComponents()==0 ) error("found " + a +".* indicating use all components calculated by action with label " + a + " but this action has no components"); + for(int k=0; kgetNumberOfComponents(); ++k) arg.push_back(action->copyOutput(k)); } else if ( a=="*" ) { // Take components from all actions with a specific name std::vector all=plumed.getActionSet().select(); - if( all.empty() ) { - error("your input file is not telling plumed to calculate anything"); - } + if( all.empty() ) error("your input file is not telling plumed to calculate anything"); unsigned nval=0; for(unsigned j=0; jgetLabel() + "." + name; - if( all[j]->exists(flab) ) { - arg.push_back(all[j]->copyOutput(flab)); - nval++; - } - } - if(nval==0) { - error("found no actions with a component called " + name ); + std::string flab; flab=all[j]->getLabel() + "." + name; + if( all[j]->exists(flab) ) { arg.push_back(all[j]->copyOutput(flab)); nval++; } } + if(nval==0) error("found no actions with a component called " + name ); } else { // Take values with a specific name ActionWithValue* action=plumed.getActionSet().selectWithLabel(a); @@ -213,13 +183,9 @@ void ActionWithArguments::interpretArgumentList(const std::vector& if(c[i]=="*") { // Take all values from all actions std::vector all=plumed.getActionSet().select(); - if( all.empty() ) { - error("your input file is not telling plumed to calculate anything"); - } + if( all.empty() ) error("your input file is not telling plumed to calculate anything"); for(unsigned j=0; jgetNumberOfComponents(); ++k) { - arg.push_back(all[j]->copyOutput(k)); - } + for(int k=0; kgetNumberOfComponents(); ++k) arg.push_back(all[j]->copyOutput(k)); } } else { ActionWithValue* action=plumed.getActionSet().selectWithLabel(c[i]); @@ -288,16 +254,15 @@ void ActionWithArguments::requestExtraDependencies(const std::vector &ex ActionWithArguments::ActionWithArguments(const ActionOptions&ao): Action(ao), - lockRequestArguments(false) { + lockRequestArguments(false) +{ if( keywords.exists("ARG") ) { std::vector arg; parseArgumentList("ARG",arg); if(!arg.empty()) { log.printf(" with arguments"); - for(unsigned i=0; igetName().c_str()); - } + for(unsigned i=0; igetName().c_str()); log.printf("\n"); } requestArguments(arg); @@ -326,10 +291,7 @@ void ActionWithArguments::calculateNumericalDerivatives( ActionWithValue* a ) { a->clearDerivatives(); for(int j=0; jcopyOutput(j); - if( v->hasDerivatives() ) - for(int i=0; iaddDerivative(i,(value[i*nval+j]-a->getOutputQuantity(j))/std::sqrt(epsilon)); - } + if( v->hasDerivatives() ) for(int i=0; iaddDerivative(i,(value[i*nval+j]-a->getOutputQuantity(j))/std::sqrt(epsilon)); } } @@ -342,9 +304,7 @@ double ActionWithArguments::getProjection(unsigned i,unsigned j)const { } void ActionWithArguments::addForcesOnArguments( const std::vector& forces ) { - for(unsigned i=0; iaddForce( forces[i] ); - } + for(unsigned i=0; iaddForce( forces[i] ); } } diff --git a/src/core/ActionWithArguments.h b/src/core/ActionWithArguments.h index 9cc7da7f8f..4ed915f3a7 100644 --- a/src/core/ActionWithArguments.h +++ b/src/core/ActionWithArguments.h @@ -40,7 +40,8 @@ This is used in PLMD::Function and PLMD::Bias */ class ActionWithArguments: - public virtual Action { + public virtual Action +{ std::vector arguments; bool lockRequestArguments; protected: diff --git a/src/core/ActionWithValue.cpp b/src/core/ActionWithValue.cpp index a6e3243fa3..e29fe0928e 100644 --- a/src/core/ActionWithValue.cpp +++ b/src/core/ActionWithValue.cpp @@ -55,13 +55,10 @@ void ActionWithValue::useCustomisableComponents(Keywords& keys) { ActionWithValue::ActionWithValue(const ActionOptions&ao): Action(ao), noderiv(true), - numericalDerivatives(false) { - if( keywords.exists("NUMERICAL_DERIVATIVES") ) { - parseFlag("NUMERICAL_DERIVATIVES",numericalDerivatives); - } - if(numericalDerivatives) { - log.printf(" using numerical derivatives\n"); - } + numericalDerivatives(false) +{ + if( keywords.exists("NUMERICAL_DERIVATIVES") ) parseFlag("NUMERICAL_DERIVATIVES",numericalDerivatives); + if(numericalDerivatives) log.printf(" using numerical derivatives\n"); } ActionWithValue::~ActionWithValue() { @@ -69,9 +66,7 @@ ActionWithValue::~ActionWithValue() { } void ActionWithValue::clearInputForces() { - for(unsigned i=0; iclearInputForce(); - } + for(unsigned i=0; iclearInputForce(); } void ActionWithValue::clearDerivatives() { @@ -79,9 +74,7 @@ void ActionWithValue::clearDerivatives() { #pragma omp parallel num_threads(nt) { #pragma omp for - for(unsigned i=0; iclearDerivatives(); - } + for(unsigned i=0; iclearDerivatives(); } } @@ -89,18 +82,14 @@ void ActionWithValue::clearDerivatives() { bool ActionWithValue::exists( const std::string& name ) const { for(unsigned i=0; iname==name) { - return true; - } + if (values[i]->name==name) return true; } return false; } Value* ActionWithValue::copyOutput( const std::string& name ) const { for(unsigned i=0; iname==name) { - return values[i].get(); - } + if (values[i]->name==name) return values[i].get(); } plumed_merror("there is no pointer with name " + name); } @@ -125,8 +114,7 @@ void ActionWithValue::addValueWithDerivatives() { void ActionWithValue::setNotPeriodic() { plumed_massert(values.size()==1,"The number of components is not equal to one"); plumed_massert(values[0]->name==getLabel(), "The value you are trying to set is not the default"); - values[0]->min=0; - values[0]->max=0; + values[0]->min=0; values[0]->max=0; values[0]->setupPeriodicity(); } @@ -149,8 +137,7 @@ void ActionWithValue::addComponent( const std::string& name ) { plumed_merror("a description of component " + name + " has not been added to the manual. Components should be registered like keywords in " "registerKeywords as described in the developer docs."); } - std::string thename; - thename=getLabel() + "." + name; + std::string thename; thename=getLabel() + "." + name; for(unsigned i=0; iname!=getLabel(),"Cannot mix single values with components"); plumed_massert(values[i]->name!=thename,"there is already a value with this name: "+thename); @@ -167,8 +154,7 @@ void ActionWithValue::addComponentWithDerivatives( const std::string& name ) { plumed_merror("a description of component " + name + " has not been added to the manual. Components should be registered like keywords in " "registerKeywords as described in the developer doc."); } - std::string thename; - thename=getLabel() + "." + name; + std::string thename; thename=getLabel() + "." + name; for(unsigned i=0; iname!=getLabel(),"Cannot mix single values with components"); plumed_massert(values[i]->name!=thename,"there is already a value with this name: "+thename); @@ -182,12 +168,9 @@ void ActionWithValue::addComponentWithDerivatives( const std::string& name ) { int ActionWithValue::getComponent( const std::string& name ) const { plumed_massert( !exists( getLabel() ), "You should not be calling this routine if you are using a value"); - std::string thename; - thename=getLabel() + "." + name; + std::string thename; thename=getLabel() + "." + name; for(unsigned i=0; iname==thename) { - return i; - } + if (values[i]->name==thename) return i; } plumed_merror("there is no component with name " + name); } @@ -210,8 +193,7 @@ std::vector ActionWithValue::getComponentsVector( ) const { void ActionWithValue::componentIsNotPeriodic( const std::string& name ) { int kk=getComponent(name); - values[kk]->min=0; - values[kk]->max=0; + values[kk]->min=0; values[kk]->max=0; values[kk]->setupPeriodicity(); } @@ -222,9 +204,7 @@ void ActionWithValue::componentIsPeriodic( const std::string& name, const std::s void ActionWithValue::setGradientsIfNeeded() { if(isOptionOn("GRADIENTS")) { - for(unsigned i=0; isetGradients(); - } + for(unsigned i=0; isetGradients(); } } @@ -232,15 +212,11 @@ void ActionWithValue::turnOnDerivatives() { // Turn on the derivatives noderiv=false; // Resize the derivatives - for(unsigned i=0; iresizeDerivatives( getNumberOfDerivatives() ); - } + for(unsigned i=0; iresizeDerivatives( getNumberOfDerivatives() ); // And turn on the derivatives in all actions on which we are dependent for(unsigned i=0; i( getDependencies()[i] ); - if(vv) { - vv->turnOnDerivatives(); - } + if(vv) vv->turnOnDerivatives(); } } diff --git a/src/core/ActionWithValue.h b/src/core/ActionWithValue.h index 2115a30ffb..7474f86704 100644 --- a/src/core/ActionWithValue.h +++ b/src/core/ActionWithValue.h @@ -64,7 +64,8 @@ PLMD::Action you should use the routines with the word component in the name */ class ActionWithValue : - public virtual Action { + public virtual Action +{ private: /// An array containing the values for this action std::vector> values; @@ -163,9 +164,7 @@ class ActionWithValue : /// This forces the class to use numerical derivatives void useNumericalDerivatives(); // These are things for using vectors of values as fields - virtual void checkFieldsAllowed() { - error("cannot use this action as a field"); - } + virtual void checkFieldsAllowed() { error("cannot use this action as a field"); } virtual unsigned getNumberOfDerivatives()=0; /// Activate the calculation of derivatives virtual void turnOnDerivatives(); @@ -179,12 +178,9 @@ double ActionWithValue::getOutputQuantity(const unsigned j) const { inline double ActionWithValue::getOutputQuantity( const std::string& name ) const { - std::string thename; - thename=getLabel() + "." + name; + std::string thename; thename=getLabel() + "." + name; for(unsigned i=0; iname==thename ) { - return values[i]->value; - } + if( values[i]->name==thename ) return values[i]->value; } return 0.0; } diff --git a/src/core/ActionWithVirtualAtom.cpp b/src/core/ActionWithVirtualAtom.cpp index 8a8536e8d7..72d56dd110 100644 --- a/src/core/ActionWithVirtualAtom.cpp +++ b/src/core/ActionWithVirtualAtom.cpp @@ -33,7 +33,8 @@ void ActionWithVirtualAtom::registerKeywords(Keywords& keys) { ActionWithVirtualAtom::ActionWithVirtualAtom(const ActionOptions&ao): Action(ao), ActionAtomistic(ao), - index(atoms.addVirtualAtom(this)) { + index(atoms.addVirtualAtom(this)) +{ log<<" serial associated to this virtual atom is "< &d) { // Notice that this part alone should exactly cancel the already accumulated virial // due to forces on this atom. Vector pos=atoms.positions[index.index()]; - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<3; j++) { - boxDerivatives[j][i][j]+=pos[i]; - } + for(unsigned i=0; i<3; i++) for(unsigned j=0; j<3; j++) boxDerivatives[j][i][j]+=pos[i]; } void ActionWithVirtualAtom::setBoxDerivativesNoPbc() { std::array bd; - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<3; j++) - for(unsigned k=0; k<3; k++) { + for(unsigned i=0; i<3; i++) for(unsigned j=0; j<3; j++) for(unsigned k=0; k<3; k++) { // Notice that this expression is very similar to the one used in Colvar::setBoxDerivativesNoPbc(). // Indeed, we have the negative of a sum over dependent atoms (l) of the external product between positions // and derivatives. Notice that this only works only when Pbc have not been used to compute diff --git a/src/core/ActionWithVirtualAtom.h b/src/core/ActionWithVirtualAtom.h index e79cba9d45..aebbed5866 100644 --- a/src/core/ActionWithVirtualAtom.h +++ b/src/core/ActionWithVirtualAtom.h @@ -39,7 +39,8 @@ Inherit from here if you are calculating the position of a virtual atom (eg a ce /// Class to add a single virtual atom to the system. /// (it might be extended to add multiple virtual atoms). class ActionWithVirtualAtom: - public ActionAtomistic { + public ActionAtomistic +{ const AtomNumber index; std::vector derivatives; std::array boxDerivatives; diff --git a/src/core/Atoms.cpp b/src/core/Atoms.cpp index 369bb0da15..a7f006b464 100644 --- a/src/core/Atoms.cpp +++ b/src/core/Atoms.cpp @@ -86,7 +86,8 @@ Atoms::Atoms(PlumedMain&plumed): kbT(0.0), asyncSent(false), atomsNeeded(false), - ddStep(0) { + ddStep(0) +{ } Atoms::~Atoms() { @@ -96,51 +97,39 @@ Atoms::~Atoms() { } void Atoms::startStep() { - collectEnergy=false; - energyHasBeenSet=false; - positionsHaveBeenSet=0; - massesHaveBeenSet=false; - chargesHaveBeenSet=false; - boxHasBeenSet=false; - forcesHaveBeenSet=0; - virialHasBeenSet=false; - dataCanBeSet=true; + collectEnergy=false; energyHasBeenSet=false; positionsHaveBeenSet=0; + massesHaveBeenSet=false; chargesHaveBeenSet=false; boxHasBeenSet=false; + forcesHaveBeenSet=0; virialHasBeenSet=false; dataCanBeSet=true; resetExtraCVNeeded(); } void Atoms::setBox(const TypesafePtr & p) { mdatoms->setBox(p); - Tensor b; - mdatoms->getBox(b); - boxHasBeenSet=true; + Tensor b; mdatoms->getBox(b); boxHasBeenSet=true; } void Atoms::setPositions(const TypesafePtr & p) { plumed_massert( dataCanBeSet,"setPositions must be called after setStep in MD code interface"); plumed_massert( p || gatindex.size()==0, "NULL position pointer with non-zero local atoms"); - mdatoms->setp(p); - positionsHaveBeenSet=3; + mdatoms->setp(p); positionsHaveBeenSet=3; } void Atoms::setMasses(const TypesafePtr & p) { plumed_massert( dataCanBeSet,"setMasses must be called after setStep in MD code interface"); plumed_massert( p || gatindex.size()==0, "NULL mass pointer with non-zero local atoms"); - mdatoms->setm(p); - massesHaveBeenSet=true; + mdatoms->setm(p); massesHaveBeenSet=true; } void Atoms::setCharges(const TypesafePtr & p) { plumed_massert( dataCanBeSet, "setCharges must be called after setStep in MD code interface"); plumed_massert( p || gatindex.size()==0, "NULL charges pointer with non-zero local atoms"); - mdatoms->setc(p); - chargesHaveBeenSet=true; + mdatoms->setc(p); chargesHaveBeenSet=true; } void Atoms::setVirial(const TypesafePtr & p) { plumed_massert( dataCanBeSet,"setVirial must be called after setStep in MD code interface"); - mdatoms->setVirial(p); - virialHasBeenSet=true; + mdatoms->setVirial(p); virialHasBeenSet=true; } void Atoms::setEnergy(const TypesafePtr & p) { @@ -160,15 +149,13 @@ void Atoms::setForces(const TypesafePtr & p) { void Atoms::setPositions(const TypesafePtr & p,int i) { plumed_massert( dataCanBeSet,"setPositions must be called after setStep in MD code interface"); plumed_massert( p || gatindex.size()==0, "NULL positions pointer with non-zero local atoms"); - mdatoms->setp(p,i); - positionsHaveBeenSet++; + mdatoms->setp(p,i); positionsHaveBeenSet++; } void Atoms::setForces(const TypesafePtr & p,int i) { plumed_massert( dataCanBeSet,"setForces must be called after setStep in MD code interface"); plumed_massert( p || gatindex.size()==0, "NULL force pointer with non-zero local atoms"); - mdatoms->setf(p,i); - forcesHaveBeenSet++; + mdatoms->setf(p,i); forcesHaveBeenSet++; } void Atoms::share() { @@ -185,16 +172,11 @@ void Atoms::share() { for(unsigned i=0; iisActive()) { auto l=actions[i]->getUnique().size(); - if(l>largest) { - largest=l; - } + if(l>largest) largest=l; } } - if(largest*20) { - for(int i=0; i=0) { - unique.push_back(AtomNumber::index(i)); // already sorted - } + for(int i=0; i=0) unique.push_back(AtomNumber::index(i)); // already sorted } else { unique.resize(natoms); - for(int i=0; i& unique) { if(zeroallforces || (int(gatindex.size())==natoms && !unique_serial)) { Tools::set_to_zero(forces); } else { - for(const auto & p : unique) { - forces[p.index()].zero(); - } - for(unsigned i=getNatoms(); igetBox(box); - if(!atomsNeeded) { - return; - } + if(!atomsNeeded) return; atomsNeeded=false; if(!(int(gatindex.size())==natoms && shuffledAtoms==0)) { uniq_index.resize(unique.size()); - for(unsigned i=0; igetPositions(unique,uniq_index,positions); } else if(unique_serial) { uniq_index.resize(unique.size()); - for(unsigned i=0; igetPositions(unique,uniq_index,positions); } else { // faster version, which retrieves all atoms @@ -303,12 +268,8 @@ void Atoms::share(const std::vector& unique) { if(dd && shuffledAtoms>0) { if(dd.async) { - for(unsigned i=0; i& unique) { std::vector displ5(n); dd.Allgather(count,counts); displ[0]=0; - for(int i=1; i0) { // receive toBeReceived @@ -402,15 +353,11 @@ void Atoms::wait() { } asyncSent=false; } - if(collectEnergy) { - dd.Sum(energy); - } + if(collectEnergy) dd.Sum(energy); } // I take note that masses and charges have been set once for all // at the beginning of the simulation. - if(shareMassAndChargeOnlyAtFirstStep) { - massAndChargeOK=true; - } + if(shareMassAndChargeOnlyAtFirstStep) massAndChargeOK=true; } void Atoms::updateForces() { @@ -420,11 +367,8 @@ void Atoms::updateForces() { mdatoms->rescaleForces(gatindex,alpha); mdatoms->updateForces(gatindex,forces); } else { - if(!unique_serial && int(gatindex.size())==natoms && shuffledAtoms==0) { - mdatoms->updateForces(gatindex,forces); - } else { - mdatoms->updateForces(unique,uniq_index,forces); - } + if(!unique_serial && int(gatindex.size())==natoms && shuffledAtoms==0) mdatoms->updateForces(gatindex,forces); + else mdatoms->updateForces(unique,uniq_index,forces); } if( !plumed.novirial && dd.Get_rank()==0 ) { plumed_assert( virialHasBeenSet ); @@ -439,9 +383,7 @@ void Atoms::setNatoms(int n) { masses.resize(n); charges.resize(n); gatindex.resize(n); - for(unsigned i=0; i(gatindex.size()); ddStep=plumed.getStep(); if(fortran) { - for(unsigned i=0; iupdateUniqueLocal(); @@ -561,12 +478,10 @@ int Atoms::getRealPrecision()const { } void Atoms::MD2double(const TypesafePtr & m,double&d)const { - plumed_assert(mdatoms); - mdatoms->MD2double(m,d); + plumed_assert(mdatoms); mdatoms->MD2double(m,d); } void Atoms::double2MD(const double&d,const TypesafePtr & m)const { - plumed_assert(mdatoms); - mdatoms->double2MD(d,m); + plumed_assert(mdatoms); mdatoms->double2MD(d,m); } void Atoms::updateUnits() { @@ -601,9 +516,7 @@ void Atoms::createFullList(const TypesafePtr & n) { if(!massAndChargeOK && shareMassAndChargeOnlyAtFirstStep) { n.set(int(natoms)); fullList.resize(natoms); - for(unsigned i=0; i(); - if(!fullList.empty()) { - *xx=&fullList[0]; - } else { - *xx=NULL; - } + if(!fullList.empty()) *xx=&fullList[0]; + else *xx=NULL; } void Atoms::clearFullList() { @@ -701,26 +609,18 @@ void Atoms::readBinary(std::istream&i) { } double Atoms::getKBoltzmann()const { - if(naturalUnits || MDnaturalUnits) { - return 1.0; - } else { - return kBoltzmann/units.getEnergy(); - } + if(naturalUnits || MDnaturalUnits) return 1.0; + else return kBoltzmann/units.getEnergy(); } double Atoms::getMDKBoltzmann()const { - if(naturalUnits || MDnaturalUnits) { - return 1.0; - } else { - return kBoltzmann/MDUnits.getEnergy(); - } + if(naturalUnits || MDnaturalUnits) return 1.0; + else return kBoltzmann/MDUnits.getEnergy(); } void Atoms::getLocalMasses(std::vector& localMasses) { localMasses.resize(gatindex.size()); - for(unsigned i=0; i& localPositions) { @@ -730,9 +630,7 @@ void Atoms::getLocalPositions(std::vector& localPositions) { void Atoms::getLocalForces(std::vector& localForces) { localForces.resize(gatindex.size()); - for(unsigned i=0; i& localForces) { diff --git a/src/core/Atoms.h b/src/core/Atoms.h index b83fc5b1a2..d1b2796167 100644 --- a/src/core/Atoms.h +++ b/src/core/Atoms.h @@ -44,7 +44,8 @@ class Pbc; /// Class containing atom related quantities from the MD code. /// IT IS STILL UNDOCUMENTED. IT PROBABLY NEEDS A STRONG CLEANUP -class Atoms { +class Atoms +{ friend class ActionAtomistic; friend class ActionWithVirtualAtom; int natoms; @@ -116,7 +117,8 @@ class Atoms { bool atomsNeeded; class DomainDecomposition: - public Communicator { + public Communicator + { public: bool on; bool async; @@ -128,9 +130,7 @@ class Atoms { std::vector positionsToBeReceived; std::vector indexToBeSent; std::vector indexToBeReceived; - operator bool() const { - return on; - } + operator bool() const {return on;} DomainDecomposition(): on(false), async(false) {} @@ -176,9 +176,7 @@ class Atoms { void getLocalMDForces(std::vector&); const Tensor& getVirial()const; - void setCollectEnergy(bool b) { - collectEnergy=b; - } + void setCollectEnergy(bool b) { collectEnergy=b; } void setDomainDecomposition(Communicator&); void setAtomsGatindex(const TypesafePtr &,bool); @@ -208,39 +206,18 @@ class Atoms { void add(ActionAtomistic*); void remove(ActionAtomistic*); - double getEnergy()const { - plumed_assert(collectEnergy && energyHasBeenSet); - return energy; - } - - bool isEnergyNeeded()const { - return collectEnergy; - } - - void setMDEnergyUnits(double d) { - MDUnits.setEnergy(d); - } - void setMDLengthUnits(double d) { - MDUnits.setLength(d); - } - void setMDTimeUnits(double d) { - MDUnits.setTime(d); - } - void setMDChargeUnits(double d) { - MDUnits.setCharge(d); - } - void setMDMassUnits(double d) { - MDUnits.setMass(d); - } - const Units& getMDUnits() { - return MDUnits; - } - void setUnits(const Units&u) { - units=u; - } - const Units& getUnits() { - return units; - } + double getEnergy()const {plumed_assert(collectEnergy && energyHasBeenSet); return energy;} + + bool isEnergyNeeded()const {return collectEnergy;} + + void setMDEnergyUnits(double d) {MDUnits.setEnergy(d);} + void setMDLengthUnits(double d) {MDUnits.setLength(d);} + void setMDTimeUnits(double d) {MDUnits.setTime(d);} + void setMDChargeUnits(double d) {MDUnits.setCharge(d);} + void setMDMassUnits(double d) {MDUnits.setMass(d);} + const Units& getMDUnits() {return MDUnits;} + void setUnits(const Units&u) {units=u;} + const Units& getUnits() {return units;} void updateUnits(); AtomNumber addVirtualAtom(ActionWithVirtualAtom*); @@ -254,12 +231,8 @@ class Atoms { double getKBoltzmann()const; double getMDKBoltzmann()const; bool usingNaturalUnits()const; - void setNaturalUnits(bool n) { - naturalUnits=n; - } - void setMDNaturalUnits(bool n) { - MDnaturalUnits=n; - } + void setNaturalUnits(bool n) {naturalUnits=n;} + void setMDNaturalUnits(bool n) {MDnaturalUnits=n;} void setExtraCV(const std::string &name,const TypesafePtr & p); void setExtraCVForce(const std::string &name,const TypesafePtr & p); diff --git a/src/core/CLTool.cpp b/src/core/CLTool.cpp index 81ffee0640..c04b7a6cfe 100644 --- a/src/core/CLTool.cpp +++ b/src/core/CLTool.cpp @@ -27,12 +27,14 @@ Keywords CLToolOptions::emptyKeys; CLToolOptions::CLToolOptions(const std::string &name): line(1,name), - keys(emptyKeys) { + keys(emptyKeys) +{ } CLToolOptions::CLToolOptions(const CLToolOptions& co, const Keywords& k): line(co.line), - keys(k) { + keys(k) +{ } void CLTool::registerKeywords( Keywords& keys ) { @@ -42,20 +44,17 @@ void CLTool::registerKeywords( Keywords& keys ) { CLTool::CLTool(const CLToolOptions& co ): name(co.line[0]), keywords(co.keys), - inputdata(unset) { + inputdata(unset) +{ } void CLTool::parseFlag( const std::string&key, bool&t ) { plumed_massert(keywords.exists(key),"keyword " + key + " has not been registered"); plumed_massert(keywords.style(key,"flag"),"keyword " + key + " has not been registered as a flag"); plumed_assert(inputData.count(key)>0); - if( inputData[key]=="true") { - t=true; - } else if( inputData[key]=="false") { - t=false; - } else { - plumed_error(); - } + if( inputData[key]=="true") t=true; + else if( inputData[key]=="false") t=false; + else plumed_error(); } bool CLTool::readInput( int argc, char**argv, FILE* in, FILE*out ) { @@ -63,12 +62,8 @@ bool CLTool::readInput( int argc, char**argv, FILE* in, FILE*out ) { "If it is from the command line (like driver) add inputdata=commandline to the " "tools constructor. If it reads everything from an input file (like simplemd) " "add inputdata=ifile to the tools constructor"); - if(inputdata==commandline) { - return readCommandLineArgs( argc, argv, out ); - } - if(inputdata==ifile) { - return readInputFile( argc, argv, in, out ); - } + if(inputdata==commandline) return readCommandLineArgs( argc, argv, out ); + if(inputdata==ifile) return readInputFile( argc, argv, in, out ); return true; } @@ -79,18 +74,14 @@ bool CLTool::readCommandLineArgs( int argc, char**argv, FILE*out ) { // Set all flags to default false for(unsigned k=0; k(thiskey,"false")); - } + if( keywords.style(thiskey,"flag") ) inputData.insert(std::pair(thiskey,"false")); } // Read command line arguments bool printhelp=false; for(int i=1; i(thiskey,"")); } else if(Tools::startWith(a,thiskey+"=")) { - a.erase(0,a.find("=")+1); - prefix=""; - found=true; + a.erase(0,a.find("=")+1); prefix=""; found=true; if(inputData.count(thiskey)==0) { inputData.insert(std::pair(thiskey,a)); } else { @@ -127,14 +112,10 @@ bool CLTool::readCommandLineArgs( int argc, char**argv, FILE*out ) { printhelp=true; } } - if(printhelp) { - break; - } + if(printhelp) break; } - if(!printhelp) { - setRemainingToDefault(out); - } + if(!printhelp) setRemainingToDefault(out); if(printhelp) { std::fprintf(out,"Usage: %s [options] \n\n", name.c_str() ); @@ -169,9 +150,7 @@ bool CLTool::readInputFile( int argc, char**argv, FILE* in, FILE*out ) { std::string a; for(int i=1; i fp_deleter(nullptr,deleter); if(argc==2) { @@ -201,22 +178,14 @@ bool CLTool::readInputFile( int argc, char**argv, FILE* in, FILE*out ) { plumed_assert(mystdin); - char buffer[256]; - std::string line; - line.resize(256); + char buffer[256]; std::string line; line.resize(256); while(fgets(buffer,256,mystdin)) { line=buffer; - for(unsigned i=0; i bool CLTool::parse(const std::string&key,T&t) { plumed_massert(keywords.exists(key),"keyword " + key + " has not been registered"); if(keywords.style(key,"compulsory") ) { - if(inputData.count(key)==0) { - error("missing data for keyword " + key); - } + if(inputData.count(key)==0) error("missing data for keyword " + key); bool check=Tools::convertNoexcept(inputData[key],t); - if(!check) { - error("data input for keyword " + key + " has wrong type"); - } + if(!check) error("data input for keyword " + key + " has wrong type"); return true; } - if( inputData.count(key)==0 ) { - return false; - } + if( inputData.count(key)==0 ) return false; Tools::convert(inputData[key],t); return true; } @@ -129,18 +121,14 @@ bool CLTool::parseVector(const std::string&key,std::vector&t) { // initial size unsigned size=t.size(); bool skipcheck=false; - if(size==0) { - skipcheck=true; // if the vector in input has size zero, skip the check if size of input vector is the same of argument read - } + if(size==0) skipcheck=true; // if the vector in input has size zero, skip the check if size of input vector is the same of argument read // check if there is some value plumed_massert(inputData[key]!="false","compulsory keyword "+std::string(key)+"has no data"); std::vector words=Tools::getWords(inputData[key],"\t\n ,"); t.resize(0); - if(words.size()==0) { - return false; - } + if(words.size()==0)return false; for(unsigned i=0; isecond; - } + if(it!=word_map.end()) iword=it->second; switch(iword) { case cmd_setArgc: CHECK_NULL(val,word); @@ -81,9 +80,7 @@ void CLToolMain::cmd(const std::string& word,const TypesafePtr & val) { case cmd_setArgv: CHECK_NULL(val,word); v=val.get(argc); - for(int i=0; i args(n); std::vector vvv(argc); char* ptr=&args[0]; for(int i=0; i0) { - availableShell.push_back(tmp[j]); - } + for(unsigned j=0; j0) availableShell.push_back(tmp[j]); } if(printhelp) { @@ -264,9 +243,7 @@ int CLToolMain::run(int argc, char **argv,FILE*in,FILE*out,Communicator& pc) { std::string cmd=config::getEnvCommand()+" \""+root+"/scripts/"+availableShell[j]+".sh\" --description"; FILE *fp=popen(cmd.c_str(),"r"); std::string line; - while(Tools::getline(fp,line)) { - manual+=line; - } + while(Tools::getline(fp,line))manual+=line; pclose(fp); #else manual="(doc not avail)"; @@ -288,9 +265,7 @@ int CLToolMain::run(int argc, char **argv,FILE*in,FILE*out,Communicator& pc) { auto cl=cltoolRegister().create(CLToolOptions(command)); plumed_assert(cl); // Read the command line options (returns false if we are just printing help) - if( !cl->readInput( argc-i,&argv[i],in,out ) ) { - return 0; - } + if( !cl->readInput( argc-i,&argv[i],in,out ) ) { return 0; } int ret=cl->main(in,out,pc); return ret; } @@ -299,18 +274,13 @@ int CLToolMain::run(int argc, char **argv,FILE*in,FILE*out,Communicator& pc) { plumed_massert(in==stdin,"shell tools can only work on stdin"); plumed_massert(out==stdout,"shell tools can only work on stdin"); std::string cmd=config::getEnvCommand()+" \""+root+"/scripts/"+command+".sh\""; - for(int j=i+1; j0) { std::string names=""; - for(const auto & p : m) { - names+=p.first+" "; - } + for(const auto & p : m) names+=p.first+" "; std::cerr<<"WARNING: CLTools "+ names +" has not been properly unregistered. This might lead to memory leak!!\n"; } } @@ -46,8 +44,7 @@ CLToolRegister& cltoolRegister() { void CLToolRegister::remove(creator_pointer f) { for(auto p=m.begin(); p!=m.end(); ++p) { if((*p).second==f) { - m.erase(p); - break; + m.erase(p); break; } } } @@ -58,23 +55,18 @@ void CLToolRegister::add(std::string key,creator_pointer f,keywords_pointer kf) disabled.insert(key); } else { m.insert(std::pair(key,f)); - Keywords keys; - kf(keys); + Keywords keys; kf(keys); mk.insert(std::pair(key,keys)); }; } bool CLToolRegister::check(const std::string & key)const { - if(m.count(key)>0) { - return true; - } + if(m.count(key)>0) return true; return false; } std::unique_ptr CLToolRegister::create(const CLToolOptions&ao) { - if(ao.line.size()<1) { - return NULL; - } + if(ao.line.size()<1)return NULL; std::unique_ptr cltool; if(check(ao.line[0])) { CLToolOptions nao( ao,mk[ao.line[0]] ); @@ -86,18 +78,14 @@ std::unique_ptr CLToolRegister::create(const CLToolOptions&ao) { std::ostream & operator<<(std::ostream &log,const CLToolRegister&ar) { std::vector s(ar.list()); - for(unsigned i=0; i CLToolRegister::getKeys(const std::string& cltool)const std::vector CLToolRegister::list()const { std::vector s; - for(const auto & it : m) { - s.push_back(it.first); - } + for(const auto & it : m) s.push_back(it.first); std::sort(s.begin(),s.end()); return s; } diff --git a/src/core/Colvar.cpp b/src/core/Colvar.cpp index 5d6f725112..8744a42848 100644 --- a/src/core/Colvar.cpp +++ b/src/core/Colvar.cpp @@ -31,7 +31,8 @@ Colvar::Colvar(const ActionOptions&ao): ActionAtomistic(ao), ActionWithValue(ao), isEnergy(false), - isExtraCV(false) { + isExtraCV(false) +{ } void Colvar::registerKeywords( Keywords& keys ) { @@ -46,9 +47,7 @@ void Colvar::requestAtoms(const std::vector & a) { // Tell actionAtomistic what atoms we are getting ActionAtomistic::requestAtoms(a); // Resize the derivatives of all atoms - for(int i=0; iresizeDerivatives(3*a.size()+9); - } + for(int i=0; iresizeDerivatives(3*a.size()+9); } void Colvar::apply() { @@ -66,9 +65,7 @@ void Colvar::apply() { } unsigned nt=OpenMP::getNumThreads(); - if(nt>ncp/(4*stride)) { - nt=1; - } + if(nt>ncp/(4*stride)) nt=1; if(!isEnergy && !isExtraCV) { #pragma omp parallel num_threads(nt) @@ -97,41 +94,32 @@ void Colvar::apply() { } #pragma omp critical { - for(unsigned j=0; j4*comm.Get_size()) { - if(fsz>0) { - comm.Sum(&f[0][0],3*fsz); - } + if(fsz>0) comm.Sum(&f[0][0],3*fsz); comm.Sum(&v[0][0],9); } } else if( isEnergy ) { std::vector forces(1); - if(getPntrToComponent(0)->applyForce(forces)) { - modifyForceOnEnergy()+=forces[0]; - } + if(getPntrToComponent(0)->applyForce(forces)) modifyForceOnEnergy()+=forces[0]; } else if( isExtraCV ) { std::vector forces(1); - if(getPntrToComponent(0)->applyForce(forces)) { - modifyForceOnExtraCV()+=forces[0]; - } + if(getPntrToComponent(0)->applyForce(forces)) modifyForceOnExtraCV()+=forces[0]; } } void Colvar::setBoxDerivativesNoPbc(Value* v) { Tensor virial; unsigned nat=getNumberOfAtoms(); - for(unsigned i=0; igetDerivative(3*i+0), - v->getDerivative(3*i+1), - v->getDerivative(3*i+2))); + for(unsigned i=0; igetDerivative(3*i+0), + v->getDerivative(3*i+1), + v->getDerivative(3*i+2))); setBoxDerivatives(v,virial); } } diff --git a/src/core/Colvar.h b/src/core/Colvar.h index 2a41f67cd9..ba221ff4ca 100644 --- a/src/core/Colvar.h +++ b/src/core/Colvar.h @@ -38,7 +38,8 @@ This is the abstract base class to use for implementing new collective variables class Colvar : public ActionAtomistic, - public ActionWithValue { + public ActionWithValue +{ private: protected: bool isEnergy; @@ -63,9 +64,7 @@ class Colvar : void setBoxDerivativesNoPbc(); void setBoxDerivativesNoPbc(Value*); public: - bool checkIsEnergy() { - return isEnergy; - } + bool checkIsEnergy() {return isEnergy;} explicit Colvar(const ActionOptions&); ~Colvar() {} static void registerKeywords( Keywords& keys ); diff --git a/src/core/DataFetchingObject.cpp b/src/core/DataFetchingObject.cpp index f5438ea924..d321a81106 100644 --- a/src/core/DataFetchingObject.cpp +++ b/src/core/DataFetchingObject.cpp @@ -48,31 +48,24 @@ std::unique_ptr DataFetchingObject::create(unsigned n, Plume } else if(n==sizeof(float)) { return Tools::make_unique>(p); } - std::string pp; - Tools::convert(n,pp); + std::string pp; Tools::convert(n,pp); plumed_merror("cannot create an MD interface with sizeof(real)=="+ pp); } DataFetchingObject::DataFetchingObject(PlumedMain&p): - plumed(p) { + plumed(p) +{ } bool DataFetchingObject::activate() const { - for(unsigned j=0; jactivate(); - } - if( myactions.size()>0 ) { - return true; - } + for(unsigned j=0; jactivate(); + if( myactions.size()>0 ) return true; return false; } ActionWithValue* DataFetchingObject::findAction( const ActionSet& a, const std::string& key ) { - std::string aname = key; - std::size_t dot = key.find("."); - if( dot!=std::string::npos ) { - aname = key.substr(0,dot); - } + std::string aname = key; std::size_t dot = key.find("."); + if( dot!=std::string::npos ) aname = key.substr(0,dot); return a.selectWithLabel( aname ); } @@ -120,7 +113,8 @@ void DataFetchingObject::get_shape( const ActionSet& a, const std::string& key, template DataFetchingObjectTyped::DataFetchingObjectTyped(PlumedMain&p): - DataFetchingObject(p) { + DataFetchingObject(p) +{ } template @@ -137,14 +131,9 @@ void DataFetchingObjectTyped::setData( const std::string& key, const std::str // Store the action if not already stored bool found=false; for(const auto & p : myactions) { - if( p->getLabel()==myv->getLabel() ) { - found=true; - break; - } - } - if( !found ) { - myactions.push_back( myv ); + if( p->getLabel()==myv->getLabel() ) { found=true; break; } } + if( !found ) myactions.push_back( myv ); // Store the value myvalues.push_back( myv->copyOutput( key ) ); } diff --git a/src/core/ExchangePatterns.cpp b/src/core/ExchangePatterns.cpp index 8ea743086d..e47afa313c 100644 --- a/src/core/ExchangePatterns.cpp +++ b/src/core/ExchangePatterns.cpp @@ -43,30 +43,28 @@ void ExchangePatterns::getFlag(int &flag) { flag=PatternFlag; } -void ExchangePatterns::setSeed(const int seed) { +void ExchangePatterns::setSeed(const int seed) +{ random.setSeed(seed); } -void ExchangePatterns::getList(const TypesafePtr & ind) { +void ExchangePatterns::getList(const TypesafePtr & ind) +{ auto iind=ind.get(NumberOfReplicas); - switch(PatternFlag) { + switch(PatternFlag) + { case RANDOM: for(int i=0; igetNumberOfArguments(); @@ -68,7 +69,8 @@ FlexibleBin::FlexibleBin(int type, ActionWithArguments *paction, double const &d /// Constructure for 1D FB for PBMETAD FlexibleBin::FlexibleBin(int type, ActionWithArguments *paction, unsigned iarg, double const &d, std::vector &smin, const std::vector &smax): - type(type),paction(paction),sigma(d),sigmamin(smin),sigmamax(smax) { + type(type),paction(paction),sigma(d),sigmamin(smin),sigmamax(smax) +{ // initialize the averages and the variance matrices if(type==diffusion) { std::vector average(1); @@ -115,14 +117,10 @@ void FlexibleBin::update(bool nowAddAHill) { // THE AVERAGE VALUE // beware: the pbc delta.resize(ncv); - for(unsigned i=0; igetArgument(i)); - } + for(unsigned i=0; igetArgument(i)); if(average.size()==0) { // initial time: just set the initial vector average.resize(ncv); - for(unsigned i=0; idifference(i,average[i],cv[i]); @@ -241,9 +239,7 @@ std::vector FlexibleBin::getInverseMatrix() const { std::vector eigenvals(ncv); //eigenvecs: first is eigenvec number, second is eigenvec component - if(diagMat( matrix, eigenvals, eigenvecs )!=0) { - plumed_merror("diagonalization in FlexibleBin failed! This matrix is weird\n"); - }; + if(diagMat( matrix, eigenvals, eigenvecs )!=0) {plumed_merror("diagonalization in FlexibleBin failed! This matrix is weird\n");}; for (i=0; i FlexibleBin::getInverseMatrix() const { for (j=0; jfmax) { - fmax=fact; - imax=j; + fmax=fact; imax=j; } } if(fmax FlexibleBin::getInverseMatrix() const { for(unsigned l=0; lsecond; - } + if(it!=word_map.end()) iword=it->second; switch(iword) { case cmd_initialized: CHECK_NOTNULL(val,key); @@ -108,9 +107,7 @@ void GREX::cmd(const std::string&key,const TypesafePtr & val) { break; case cmd_prepare: CHECK_INIT(initialized,key); - if(intracomm.Get_rank()==0) { - return; - } + if(intracomm.Get_rank()==0) return; intracomm.Bcast(partner,0); calculate(); break; @@ -124,9 +121,7 @@ void GREX::cmd(const std::string&key,const TypesafePtr & val) { break; case cmd_calculate: CHECK_INIT(initialized,key); - if(intracomm.Get_rank()!=0) { - return; - } + if(intracomm.Get_rank()!=0) return; intracomm.Bcast(partner,0); calculate(); break; @@ -162,9 +157,7 @@ void GREX::cmd(const std::string&key,const TypesafePtr & val) { break; case cmd_shareAllDeltaBias: CHECK_INIT(initialized,key); - if(intracomm.Get_rank()!=0) { - return; - } + if(intracomm.Get_rank()!=0) return; allDeltaBias.assign(intercomm.Get_size(),0.0); allDeltaBias[intercomm.Get_rank()]=localDeltaBias; intercomm.Sum(allDeltaBias); diff --git a/src/core/GREX.h b/src/core/GREX.h index d4a38a4ba5..2c3b35637c 100644 --- a/src/core/GREX.h +++ b/src/core/GREX.h @@ -34,7 +34,8 @@ class Atoms; class Communicator; class GREX: - public WithCmd { + public WithCmd +{ bool initialized; ForwardDecl intracomm_fwd; Communicator& intracomm=*intracomm_fwd; diff --git a/src/core/GenericMolInfo.cpp b/src/core/GenericMolInfo.cpp index 7ab75f40c7..93d381084f 100644 --- a/src/core/GenericMolInfo.cpp +++ b/src/core/GenericMolInfo.cpp @@ -59,7 +59,8 @@ GenericMolInfo::GenericMolInfo( const ActionOptions&ao ): ActionAnyorder(ao), ActionPilot(ao), ActionAtomistic(ao), - iswhole_(false) { + iswhole_(false) +{ plumed_assert(getStride()==1); // Read what is contained in the pdb file parse("MOLTYPE",mytype); @@ -68,18 +69,14 @@ GenericMolInfo::GenericMolInfo( const ActionOptions&ao ): parseFlag("WHOLE", iswhole_); auto* moldat=plumed.getActionSet().selectLatest(this); - if( moldat ) { - log<<" overriding last MOLINFO with label " << moldat->getLabel()<<"\n"; - } + if( moldat ) log<<" overriding last MOLINFO with label " << moldat->getLabel()<<"\n"; std::vector backbone; parseAtomList("CHAIN",backbone); if( read_backbone.size()==0 ) { for(unsigned i=1;; ++i) { parseAtomList("CHAIN",i,backbone); - if( backbone.size()==0 ) { - break; - } + if( backbone.size()==0 ) break; read_backbone.push_back(backbone); backbone.resize(0); } @@ -89,25 +86,17 @@ GenericMolInfo::GenericMolInfo( const ActionOptions&ao ): if( read_backbone.size()==0 ) { parse("STRUCTURE",reference); - if( ! pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/plumed.getAtoms().getUnits().getLength())) { - plumed_merror("missing input file " + reference ); - } + if( ! pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/plumed.getAtoms().getUnits().getLength()))plumed_merror("missing input file " + reference ); - std::vector chains; - pdb.getChainNames( chains ); + std::vector chains; pdb.getChainNames( chains ); log.printf(" pdb file named %s contains %u chains \n",reference.c_str(), static_cast(chains.size())); for(unsigned i=0; i GenericMolInfo::getSpecialKeywords() { } void GenericMolInfo::getBackbone( std::vector& restrings, const std::string& fortype, std::vector< std::vector >& backbone ) { - if( fortype!=mytype ) { - error("cannot calculate a variable designed for " + fortype + " molecules for molecule type " + mytype ); - } - if( MolDataClass::numberOfAtomsPerResidueInBackbone( mytype )==0 ) { - error("backbone is not defined for molecule type " + mytype ); - } + if( fortype!=mytype ) error("cannot calculate a variable designed for " + fortype + " molecules for molecule type " + mytype ); + if( MolDataClass::numberOfAtomsPerResidueInBackbone( mytype )==0 ) error("backbone is not defined for molecule type " + mytype ); if( read_backbone.size()!=0 ) { - if( restrings.size()!=1 ) { - error("cannot interpret anything other than all for residues when using CHAIN keywords"); - } - if( restrings[0]!="all" ) { - error("cannot interpret anything other than all for residues when using CHAIN keywords"); - } + if( restrings.size()!=1 ) error("cannot interpret anything other than all for residues when using CHAIN keywords"); + if( restrings[0]!="all" ) error("cannot interpret anything other than all for residues when using CHAIN keywords"); backbone.resize( read_backbone.size() ); for(unsigned i=0; i chains; - pdb.getChainNames( chains ); + std::vector chains; pdb.getChainNames( chains ); for(unsigned i=0; i > segments; + int nk, nj; std::vector< std::vector > segments; std::vector thissegment; - Tools::convert(restrings[0],nk); - thissegment.push_back(nk); + Tools::convert(restrings[0],nk); thissegment.push_back(nk); for(unsigned i=1; i& restrings, const std for(unsigned j=0; jgetline(res); words=Tools::getWords(res); - if(!words.empty() && words[0]=="Error") { - plumed_error()< class MDAtomsTyped: - public MDAtomsBase { + public MDAtomsBase +{ T scalep=1.0; // factor to scale positions T scalef=1.0; // factor to scale forces T scaleb=1.0; // factor to scale box @@ -111,16 +112,12 @@ class MDAtomsTyped: bool isExtraCVNeeded(const std::string &name) const override { auto search=extraCVNeeded.find(name); - if(search != extraCVNeeded.end()) { - return search->second; - } + if(search != extraCVNeeded.end()) return search->second; return false; } void resetExtraCVNeeded() override { - for(auto & i : extraCVNeeded) { - i.second=false; - } + for(auto & i : extraCVNeeded) i.second=false; } void MD2double(const TypesafePtr & m,double&d)const override { @@ -172,13 +169,8 @@ void MDAtomsTyped::setUnits(const Units& units,const Units& MDUnits) { template void MDAtomsTyped::getBox(Tensor&box)const { auto b=this->box.template get({3,3}); - if(b) - for(int i=0; i<3; i++) - for(int j=0; j<3; j++) { - box(i,j)=b[3*i+j]*scaleb; - } else { - box.zero(); - } + if(b) for(int i=0; i<3; i++)for(int j=0; j<3; j++) box(i,j)=b[3*i+j]*scaleb; + else box.zero(); } template @@ -258,35 +250,21 @@ void MDAtomsTyped::getLocalPositions(std::vector&positions)const { template void MDAtomsTyped::getMasses(const std::vector&index,std::vector&masses)const { auto mm=m.get(index.size()); - if(mm) - for(unsigned i=0; i void MDAtomsTyped::getCharges(const std::vector&index,std::vector&charges)const { auto cc=c.get(index.size()); - if(cc) - for(unsigned i=0; i void MDAtomsTyped::updateVirial(const Tensor&virial)const { auto v=this->virial.template get({3,3}); - if(v) - for(int i=0; i<3; i++) - for(int j=0; j<3; j++) { - v[3*i+j]+=T(virial(i,j)*scalev); - } + if(v) for(int i=0; i<3; i++)for(int j=0; j<3; j++) v[3*i+j]+=T(virial(i,j)*scalev); } template @@ -337,11 +315,7 @@ void MDAtomsTyped::rescaleForces(const std::vector&index,double factor) getPointers(f,fx,fy,fz,index.size(),ffx,ffy,ffz,stride); plumed_assert(index.size()==0 || (ffx && ffy && ffz)); auto v=virial.get({3,3}); - if(v) - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<3; j++) { - v[3*i+j]*=T(factor); - } + if(v) for(unsigned i=0; i<3; i++)for(unsigned j=0; j<3; j++) v[3*i+j]*=T(factor); #pragma omp parallel for num_threads(OpenMP::getGoodNumThreads(ffx,stride*index.size())) for(unsigned i=0; i void MDAtomsTyped::setp(const TypesafePtr & pp,int i) { p=TypesafePtr(); pp.get(); // just check type and discard pointer - if(i==0) { - px=pp.copy(); - } - if(i==1) { - py=pp.copy(); - } - if(i==2) { - pz=pp.copy(); - } + if(i==0)px=pp.copy(); + if(i==1)py=pp.copy(); + if(i==2)pz=pp.copy(); } template @@ -406,15 +374,9 @@ template void MDAtomsTyped::setf(const TypesafePtr & ff,int i) { f=TypesafePtr();; ff.get(); // just check type and discard pointer - if(i==0) { - fx=ff.copy(); - } - if(i==1) { - fy=ff.copy(); - } - if(i==2) { - fz=ff.copy(); - } + if(i==0)fx=ff.copy(); + if(i==1)fy=ff.copy(); + if(i==2)fz=ff.copy(); } template diff --git a/src/core/MDAtoms.h b/src/core/MDAtoms.h index 1688e31175..dd69a05035 100644 --- a/src/core/MDAtoms.h +++ b/src/core/MDAtoms.h @@ -47,7 +47,8 @@ create(n), where n is the actual size of MD-reals e.g. std::unique_ptr mdatoms=MDAtomsBase::create(sizeof(float)); \endverbatim */ -class MDAtomsBase { +class MDAtomsBase +{ public: /// Creates an MDAtomsTyped object such that sizeof(T)==n static std::unique_ptr create(unsigned n); diff --git a/src/core/PlumedMain.cpp b/src/core/PlumedMain.cpp index 0c3f5e7deb..35b75222c8 100644 --- a/src/core/PlumedMain.cpp +++ b/src/core/PlumedMain.cpp @@ -101,48 +101,28 @@ namespace PLMD { plumed_assert(words.size()>2); int error_code; Tools::convert(words[2],error_code); - if(words[1]=="std::generic_category") { - throw std::system_error(error_code,std::generic_category(),what); - } - if(words[1]=="std::system_category") { - throw std::system_error(error_code,std::system_category(),what); - } - if(words[1]=="std::iostream_category") { - throw std::system_error(error_code,std::iostream_category(),what); - } - if(words[1]=="std::future_category") { - throw std::system_error(error_code,std::future_category(),what); - } + if(words[1]=="std::generic_category") throw std::system_error(error_code,std::generic_category(),what); + if(words[1]=="std::system_category") throw std::system_error(error_code,std::system_category(),what); + if(words[1]=="std::iostream_category") throw std::system_error(error_code,std::iostream_category(),what); + if(words[1]=="std::future_category") throw std::system_error(error_code,std::future_category(),what); } #endif if(words[0]=="std::ios_base::failure") { #ifdef __PLUMED_LIBCXX11 int error_code=0; - if(words.size()>2) { - Tools::convert(words[2],error_code); - } - if(words.size()>1 && words[1]=="std::generic_category") { - throw std::ios_base::failure(what,std::error_code(error_code,std::generic_category())); - } - if(words.size()>1 && words[1]=="std::system_category") { - throw std::ios_base::failure(what,std::error_code(error_code,std::system_category())); - } - if(words.size()>1 && words[1]=="std::iostream_category") { - throw std::ios_base::failure(what,std::error_code(error_code,std::iostream_category())); - } - if(words.size()>1 && words[1]=="std::future_category") { - throw std::ios_base::failure(what,std::error_code(error_code,std::future_category())); - } + if(words.size()>2) Tools::convert(words[2],error_code); + if(words.size()>1 && words[1]=="std::generic_category") throw std::ios_base::failure(what,std::error_code(error_code,std::generic_category())); + if(words.size()>1 && words[1]=="std::system_category") throw std::ios_base::failure(what,std::error_code(error_code,std::system_category())); + if(words.size()>1 && words[1]=="std::iostream_category") throw std::ios_base::failure(what,std::error_code(error_code,std::iostream_category())); + if(words.size()>1 && words[1]=="std::future_category") throw std::ios_base::failure(what,std::error_code(error_code,std::future_category())); #endif throw std::ios_base::failure(what); } if(words[0]=="int") { int value=0; - if(words.size()>1) { - Tools::convert(words[1],value); - } + if(words.size()>1) Tools::convert(words[1],value); throw value; } @@ -231,7 +211,8 @@ PlumedMain::PlumedMain(): stopNow(false), novirial(false), detailedTimers(false), - gpuDeviceId(-1) { + gpuDeviceId(-1) +{ increaseReferenceCounter(); log.link(comm); log.setLinePrefix("PLUMED: "); @@ -276,9 +257,7 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { int iword=-1; double d; const auto it=word_map.find(words[0]); - if(it!=word_map.end()) { - iword=it->second; - } + if(it!=word_map.end()) iword=it->second; switch(iword) { case cmd_setBox: CHECK_INIT(initialized,word); @@ -420,50 +399,33 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { break; /* ADDED WITH API==6 */ case cmd_getDataRank: - CHECK_INIT(initialized,words[0]); - plumed_assert(nw==2 || nw==3); - if( nw==2 ) { - DataFetchingObject::get_rank( actionSet, words[1], "", val); - } else { - DataFetchingObject::get_rank( actionSet, words[1], words[2], val); - } + CHECK_INIT(initialized,words[0]); plumed_assert(nw==2 || nw==3); + if( nw==2 ) DataFetchingObject::get_rank( actionSet, words[1], "", val); + else DataFetchingObject::get_rank( actionSet, words[1], words[2], val); break; /* ADDED WITH API==6 */ case cmd_getDataShape: - CHECK_INIT(initialized,words[0]); - plumed_assert(nw==2 || nw==3); - if( nw==2 ) { - DataFetchingObject::get_shape( actionSet, words[1], "", val ); - } else { - DataFetchingObject::get_shape( actionSet, words[1], words[2], val ); - } + CHECK_INIT(initialized,words[0]); plumed_assert(nw==2 || nw==3); + if( nw==2 ) DataFetchingObject::get_shape( actionSet, words[1], "", val ); + else DataFetchingObject::get_shape( actionSet, words[1], words[2], val ); break; /* ADDED WITH API==6 */ case cmd_setMemoryForData: - CHECK_INIT(initialized,words[0]); - plumed_assert(nw==2 || nw==3); - if( nw==2 ) { - mydatafetcher->setData( words[1], "", val ); - } else { - mydatafetcher->setData( words[1], words[2], val ); - } + CHECK_INIT(initialized,words[0]); plumed_assert(nw==2 || nw==3); + if( nw==2 ) mydatafetcher->setData( words[1], "", val ); + else mydatafetcher->setData( words[1], words[2], val ); break; /* ADDED WITH API==6 */ - case cmd_setErrorHandler: { - if(val) { - error_handler=*static_cast(val.get()); - } else { - error_handler.handler=NULL; - } + case cmd_setErrorHandler: + { + if(val) error_handler=*static_cast(val.get()); + else error_handler.handler=NULL; } break; case cmd_read: CHECK_INIT(initialized,word); - if(val) { - readInputFile(val.get()); - } else { - readInputFile("plumed.dat"); - } + if(val)readInputFile(val.get()); + else readInputFile("plumed.dat"); break; case cmd_readInputLine: CHECK_INIT(initialized,word); @@ -574,27 +536,21 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { case cmd_setRestart: CHECK_NOTINIT(initialized,word); CHECK_NOTNULL(val,word); - if(val.get()!=0) { - restart=true; - } + if(val.get()!=0) restart=true; break; /* ADDED WITH API==4 */ case cmd_doCheckPoint: CHECK_INIT(initialized,word); CHECK_NOTNULL(val,word); doCheckPoint = false; - if(val.get()!=0) { - doCheckPoint = true; - } + if(val.get()!=0) doCheckPoint = true; break; /* ADDED WITH API==6 */ case cmd_setNumOMPthreads: CHECK_NOTNULL(val,word); { auto nt=val.get(); - if(nt==0) { - nt=1; - } + if(nt==0) nt=1; OpenMP::setNumThreads(nt); } break; @@ -603,9 +559,7 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { CHECK_NOTNULL(val,word); { auto id=val.get(); - if(id>=0) { - gpuDeviceId=id; - } + if(id>=0) gpuDeviceId=id; } break; /* ADDED WITH API==6 */ @@ -616,11 +570,8 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { /* ADDED WITH API==10 */ case cmd_setNestedExceptions: CHECK_NOTNULL(val,word); - if(val.get()!=0) { - nestedExceptions=true; - } else { - nestedExceptions=false; - } + if(val.get()!=0) nestedExceptions=true; + else nestedExceptions=false; break; /* STOP API */ case cmd_setMDEngine: @@ -671,11 +622,8 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { case cmd_isEnergyNeeded: CHECK_INIT(initialized,word); CHECK_NOTNULL(val,word); - if(atoms.isEnergyNeeded()) { - val.set(int(1)); - } else { - val.set(int(0)); - } + if(atoms.isEnergyNeeded()) val.set(int(1)); + else val.set(int(0)); break; case cmd_getBias: CHECK_INIT(initialized,word); @@ -701,45 +649,33 @@ void PlumedMain::cmd(const std::string & word,const TypesafePtr & val) { case cmd_isExtraCVNeeded: CHECK_NOTNULL(val,word); plumed_assert(nw==2); - if(atoms.isExtraCVNeeded(words[1])) { - val.set(int(1)); - } else { - val.set(int(0)); - } + if(atoms.isExtraCVNeeded(words[1])) val.set(int(1)); + else val.set(int(0)); break; case cmd_GREX: - if(!grex) { - grex=Tools::make_unique(*this); - } + if(!grex) grex=Tools::make_unique(*this); plumed_massert(grex,"error allocating grex"); { std::string kk=words[1]; - for(unsigned i=2; icmd(kk.c_str(),val); } break; case cmd_CLTool: CHECK_NOTINIT(initialized,word); - if(!cltool) { - cltool=Tools::make_unique(); - } + if(!cltool) cltool=Tools::make_unique(); { std::string kk=words[1]; - for(unsigned i=2; icmd(kk.c_str(),val); } break; /* ADDED WITH API==7 */ - case cmd_convert: { + case cmd_convert: + { double v; plumed_assert(words.size()==2); - if(Tools::convertNoexcept(words[1],v)) { - atoms.double2MD(v,val); - } + if(Tools::convertNoexcept(words[1],v)) atoms.double2MD(v,val); } break; default: @@ -770,9 +706,7 @@ void PlumedMain::init() { // check that initialization just happens once initialized=true; atoms.init(); - if(!log.isOpen()) { - log.link(stdout); - } + if(!log.isOpen()) log.link(stdout); log<<"PLUMED is starting\n"; log<<"Version: "<0) { readInputFile(plumedDat); @@ -799,9 +731,9 @@ void PlumedMain::init() { } atoms.updateUnits(); log.printf("Timestep: %f\n",atoms.getTimeStep()); - if(atoms.getKbT()>0.0) { + if(atoms.getKbT()>0.0) log.printf("KbT: %f\n",atoms.getKbT()); - } else { + else { log.printf("KbT has not been set by the MD engine\n"); log.printf("It should be set by hand where needed\n"); } @@ -826,18 +758,14 @@ void PlumedMain::readInputFile(const std::string & str) { void PlumedMain::readInputFile(IFile & ifile) { std::vector words; - while(Tools::getParsedLine(ifile,words) && !endPlumed) { - readInputWords(words); - } + while(Tools::getParsedLine(ifile,words) && !endPlumed) readInputWords(words); endPlumed=false; pilots=actionSet.select(); } void PlumedMain::readInputLine(const std::string & str) { plumed_assert(initialized); - if(str.empty()) { - return; - } + if(str.empty()) return; std::vector words=Tools::getWords(str); citations.clear(); readInputWords(words); @@ -850,9 +778,7 @@ void PlumedMain::readInputLine(const std::string & str) { void PlumedMain::readInputLines(const std::string & str) { plumed_assert(initialized); - if(str.empty()) { - return; - } + if(str.empty()) return; log<<"FILE: (temporary)\n"; @@ -861,9 +787,7 @@ void PlumedMain::readInputLines(const std::string & str) { plumed_assert(fp); // make sure file is closed (and thus deleted) also if an exception occurs - auto deleter=[](FILE* fp) { - std::fclose(fp); - }; + auto deleter=[](FILE* fp) { std::fclose(fp); }; std::unique_ptr fp_deleter(fp,deleter); auto ret=std::fputs(str.c_str(),fp); @@ -882,9 +806,8 @@ void PlumedMain::readInputLines(const std::string & str) { void PlumedMain::readInputWords(const std::vector & words) { plumed_assert(initialized); - if(words.empty()) { - return; - } else if(words[0]=="_SET_SUFFIX") { + if(words.empty())return; + else if(words[0]=="_SET_SUFFIX") { plumed_assert(words.size()==2); setSuffix(words[1]); } else { @@ -894,9 +817,7 @@ void PlumedMain::readInputWords(const std::vector & words) { if(!action) { std::string msg; msg ="ERROR\nI cannot understand line:"; - for(unsigned i=0; iisActive()) { - if(p->checkNeedsGradients()) { - p->setOption("GRADIENTS"); - } + if(p->checkNeedsGradients()) p->setOption("GRADIENTS"); } } @@ -971,14 +890,10 @@ void PlumedMain::prepareDependencies() { void PlumedMain::shareData() { // atom positions are shared (but only if there is something to do) - if(!active) { - return; - } + if(!active)return; // Stopwatch is stopped when sw goes out of scope auto sw=stopwatch.startStop("2 Sharing data"); - if(atoms.getNatoms()>0) { - atoms.share(); - } + if(atoms.getNatoms()>0) atoms.share(); } void PlumedMain::performCalcNoUpdate() { @@ -1001,20 +916,14 @@ void PlumedMain::performCalc() { } void PlumedMain::waitData() { - if(!active) { - return; - } + if(!active)return; // Stopwatch is stopped when sw goes out of scope auto sw=stopwatch.startStop("3 Waiting for data"); - if(atoms.getNatoms()>0) { - atoms.wait(); - } + if(atoms.getNatoms()>0) atoms.wait(); } void PlumedMain::justCalculate() { - if(!active) { - return; - } + if(!active)return; // Stopwatch is stopped when sw goes out of scope auto sw=stopwatch.startStop("4 Calculating (forward loop)"); bias=0.0; @@ -1033,42 +942,23 @@ void PlumedMain::justCalculate() { std::string actionNumberLabel; Tools::convert(iaction,actionNumberLabel); const unsigned m=actionSet.size(); - unsigned k=0; - unsigned n=1; - while(ngetLabel()); } ActionWithValue*av=dynamic_cast(p); ActionAtomistic*aa=dynamic_cast(p); { - if(av) { - av->clearInputForces(); - } - if(av) { - av->clearDerivatives(); - } + if(av) av->clearInputForces(); + if(av) av->clearDerivatives(); } { - if(aa) { - aa->clearOutputForces(); - } - if(aa) - if(aa->isActive()) { - aa->retrieveAtoms(); - } - } - if(p->checkNumericalDerivatives()) { - p->calculateNumericalDerivatives(); - } else { - p->calculate(); + if(aa) aa->clearOutputForces(); + if(aa) if(aa->isActive()) aa->retrieveAtoms(); } + if(p->checkNumericalDerivatives()) p->calculateNumericalDerivatives(); + else p->calculate(); // This retrieves components called bias if(av) { bias+=av->getOutputQuantity("bias"); @@ -1076,9 +966,7 @@ void PlumedMain::justCalculate() { av->setGradientsIfNeeded(); } ActionWithVirtualAtom*avv=dynamic_cast(p); - if(avv) { - avv->setGradientsIfNeeded(); - } + if(avv)avv->setGradientsIfNeeded(); } } catch(...) { plumed_error_nested() << "An error happened while calculating " << p->getLabel(); @@ -1093,9 +981,7 @@ void PlumedMain::justApply() { } void PlumedMain::backwardPropagate() { - if(!active) { - return; - } + if(!active)return; int iaction=0; // Stopwatch is stopped when sw goes out of scope auto sw=stopwatch.startStop("5 Applying (backward loop)"); @@ -1111,25 +997,16 @@ void PlumedMain::backwardPropagate() { std::string actionNumberLabel; Tools::convert(iaction,actionNumberLabel); const unsigned m=actionSet.size(); - unsigned k=0; - unsigned n=1; - while(ngetLabel()); } p->apply(); ActionAtomistic*a=dynamic_cast(p); // still ActionAtomistic has a special treatment, since they may need to add forces on atoms - if(a) { - a->applyForces(); - } + if(a) a->applyForces(); } iaction++; @@ -1138,19 +1015,13 @@ void PlumedMain::backwardPropagate() { // Stopwatch is stopped when sw goes out of scope. // We explicitly declare a Stopwatch::Handler here to allow for conditional initialization. Stopwatch::Handler sw1; - if(detailedTimers) { - sw1=stopwatch.startStop("5B Update forces"); - } + if(detailedTimers) sw1=stopwatch.startStop("5B Update forces"); // this is updating the MD copy of the forces - if(atoms.getNatoms()>0) { - atoms.updateForces(); - } + if(atoms.getNatoms()>0) atoms.updateForces(); } void PlumedMain::update() { - if(!active) { - return; - } + if(!active)return; // Stopwatch is stopped when sw goes out of scope auto sw=stopwatch.startStop("6 Update"); @@ -1159,23 +1030,14 @@ void PlumedMain::update() { updateFlags.push(true); for(const auto & p : actionSet) { p->beforeUpdate(); - if(p->isActive() && p->checkUpdate() && updateFlagsTop()) { - p->update(); - } - } - while(!updateFlags.empty()) { - updateFlags.pop(); - } - if(!updateFlags.empty()) { - plumed_merror("non matching changes in the update flags"); + if(p->isActive() && p->checkUpdate() && updateFlagsTop()) p->update(); } + while(!updateFlags.empty()) updateFlags.pop(); + if(!updateFlags.empty()) plumed_merror("non matching changes in the update flags"); // Check that no action has told the calculation to stop if(stopNow) { - if(stopFlag) { - stopFlag.set(int(1)); - } else { - plumed_merror("your md code cannot handle plumed stop events - add a call to plumed.comm(stopFlag,stopCondition)"); - } + if(stopFlag) stopFlag.set(int(1)); + else plumed_merror("your md code cannot handle plumed stop events - add a call to plumed.comm(stopFlag,stopCondition)"); } // flush by default every 10000 steps @@ -1184,9 +1046,7 @@ void PlumedMain::update() { if(step%10000==0||doCheckPoint) { fflush(); log.flush(); - for(const auto & p : actionSet) { - p->fflush(); - } + for(const auto & p : actionSet) p->fflush(); } } @@ -1196,27 +1056,19 @@ void PlumedMain::load(const std::string& ss) { size_t n=s.find_last_of("."); std::string extension=""; std::string base=s; - if(n!=std::string::npos && n0) { - log<<" (only on master node)"; - } + if(comm.Get_size()>0) log<<" (only on master node)"; log<<"\n"; if(comm.Get_rank()==0) { int ret=std::system(cmd.c_str()); - if(ret!=0) { - plumed_error() <<"An error happened while executing command "<(ppathsuf.c_str()),const_cast(mmode.c_str())); - if(!fp) { - fp=std::fopen(const_cast(ppath.c_str()),const_cast(mmode.c_str())); - } + if(!fp) fp=std::fopen(const_cast(ppath.c_str()),const_cast(mmode.c_str())); plumed_massert(fp,"file " + ppath + " cannot be found"); return fp; } diff --git a/src/core/PlumedMain.h b/src/core/PlumedMain.h index 8213d7c024..c24529edea 100644 --- a/src/core/PlumedMain.h +++ b/src/core/PlumedMain.h @@ -76,7 +76,8 @@ which defines completely the external plumed interface. It does not contain any static data. */ class PlumedMain: - public WithCmd { + public WithCmd +{ /// Pointers to files opened in actions associated to this object. /// Notice that with the current implementation this should be at the top of this /// structure. Indeed, this should be destroyed *after* all the actions allocated @@ -375,9 +376,7 @@ class PlumedMain: /// Referenge to the log stream Log & getLog(); /// Return the number of the step - long long int getStep()const { - return step; - } + long long int getStep()const {return step;} /// Stop the run void exit(int c=0); /// Load a shared library @@ -405,11 +404,7 @@ class PlumedMain: /// Check if restarting bool getRestart()const; /// Set restart flag - void setRestart(bool f) { - if(!doParseOnly) { - restart=f; - } - } + void setRestart(bool f) {if(!doParseOnly) restart=f;} /// Check if checkpointing bool getCPT()const; /// Set exchangeStep flag @@ -426,9 +421,7 @@ class PlumedMain: void resetActive(bool active); /// Access to exchange patterns - ExchangePatterns& getExchangePatterns() { - return exchangePatterns; - } + ExchangePatterns& getExchangePatterns() {return exchangePatterns;} /// Push a state to update flags void updateFlagsPush(bool); @@ -544,9 +537,7 @@ bool PlumedMain::callErrorHandler(int code,const char* msg)const { if(error_handler.handler) { error_handler.handler(error_handler.ptr,code,msg); return true; - } else { - return false; - } + } else return false; } diff --git a/src/core/PlumedMainInitializer.cpp b/src/core/PlumedMainInitializer.cpp index 91984ec7aa..a65225de08 100644 --- a/src/core/PlumedMainInitializer.cpp +++ b/src/core/PlumedMainInitializer.cpp @@ -109,9 +109,7 @@ extern "C" { static void plumed_plumedmain_cmd_safe(void*plumed,const char*key,plumed_safeptr_x safe) { plumed_massert(plumed,"trying to use a plumed object which is not initialized"); auto p=static_cast(plumed); - if(getenvTypesafeDebug()) { - typesafeDebug(key,safe); - } + if(getenvTypesafeDebug()) typesafeDebug(key,safe); p->cmd(key,PLMD::TypesafePtr::fromSafePtr(&safe)); } } @@ -128,179 +126,116 @@ static void translate_current(plumed_nothrow_handler_x nothrow,void**nested=null // cppcheck-suppress rethrowNoCurrentException throw; } catch(const PLMD::ExceptionTypeError & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,20300,msg,opt); } catch(const PLMD::ExceptionError & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,20200,msg,opt); } catch(const PLMD::ExceptionDebug & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,20100,msg,opt); } catch(const PLMD::Exception & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,20000,msg,opt); } catch(const PLMD::lepton::Exception & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,19900,msg,opt); // 11000 to 12000 are "bad exceptions". message will be copied without new allocations } catch(const std::bad_exception & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11500,msg,opt); #ifdef __PLUMED_LIBCXX11 } catch(const std::bad_array_new_length & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11410,msg,opt); #endif } catch(const std::bad_alloc & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11400,msg,opt); #ifdef __PLUMED_LIBCXX11 } catch(const std::bad_function_call & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11300,msg,opt); } catch(const std::bad_weak_ptr & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11200,msg,opt); #endif } catch(const std::bad_cast & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11100,msg,opt); } catch(const std::bad_typeid & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,11000,msg,opt); // not implemented yet: std::regex_error // we do not allow regex yet due to portability problems with gcc 4.8 // as soon as we transition to using it should be straightforward to add } catch(const std::ios_base::failure & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); #ifdef __PLUMED_LIBCXX11 int value=e.code().value(); opt[2]="c"; // "c" passes the error code. opt[3]=&value; - if(e.code().category()==std::generic_category()) { - nothrow.handler(nothrow.ptr,10230,msg,opt); - } else if(e.code().category()==std::system_category()) { - nothrow.handler(nothrow.ptr,10231,msg,opt); - } else if(e.code().category()==std::iostream_category()) { - nothrow.handler(nothrow.ptr,10232,msg,opt); - } else if(e.code().category()==std::future_category()) { - nothrow.handler(nothrow.ptr,10233,msg,opt); - } else + if(e.code().category()==std::generic_category()) nothrow.handler(nothrow.ptr,10230,msg,opt); + else if(e.code().category()==std::system_category()) nothrow.handler(nothrow.ptr,10231,msg,opt); + else if(e.code().category()==std::iostream_category()) nothrow.handler(nothrow.ptr,10232,msg,opt); + else if(e.code().category()==std::future_category()) nothrow.handler(nothrow.ptr,10233,msg,opt); + else #endif // 10239 represents std::ios_base::failure with default constructur nothrow.handler(nothrow.ptr,10239,msg,opt); #ifdef __PLUMED_LIBCXX11 } catch(const std::system_error & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); int value=e.code().value(); opt[2]="c"; // "c" passes the error code. opt[3]=&value; - if(e.code().category()==std::generic_category()) { - nothrow.handler(nothrow.ptr,10220,msg,opt); - } else if(e.code().category()==std::system_category()) { - nothrow.handler(nothrow.ptr,10221,msg,opt); - } else if(e.code().category()==std::iostream_category()) { - nothrow.handler(nothrow.ptr,10222,msg,opt); - } else if(e.code().category()==std::future_category()) { - nothrow.handler(nothrow.ptr,10223,msg,opt); - } + if(e.code().category()==std::generic_category()) nothrow.handler(nothrow.ptr,10220,msg,opt); + else if(e.code().category()==std::system_category()) nothrow.handler(nothrow.ptr,10221,msg,opt); + else if(e.code().category()==std::iostream_category()) nothrow.handler(nothrow.ptr,10222,msg,opt); + else if(e.code().category()==std::future_category()) nothrow.handler(nothrow.ptr,10223,msg,opt); // fallback to generic runtime_error - else { - nothrow.handler(nothrow.ptr,10200,msg,opt); - } + else nothrow.handler(nothrow.ptr,10200,msg,opt); #endif } catch(const std::underflow_error &e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10215,msg,opt); } catch(const std::overflow_error &e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10210,msg,opt); } catch(const std::range_error &e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10205,msg,opt); } catch(const std::runtime_error & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10200,msg,opt); // not implemented yet: std::future_error // not clear how useful it would be. } catch(const std::out_of_range & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10120,msg,opt); } catch(const std::length_error & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10115,msg,opt); } catch(const std::domain_error & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10110,msg,opt); } catch(const std::invalid_argument & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10105,msg,opt); } catch(const std::logic_error & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10100,msg,opt); // generic exception. message will be copied without new allocations // reports all non caught exceptions that are derived from std::exception // for instance, boost exceptions would end up here } catch(const std::exception & e) { - if(!msg) { - msg=e.what(); - } + if(!msg) msg=e.what(); nothrow.handler(nothrow.ptr,10000,msg,opt); } catch(const char* m) { - if(!msg) { - msg=m; - } + if(!msg) msg=m; nothrow.handler(nothrow.ptr,10000,msg,opt); } catch(const std::string & s) { - if(!msg) { - msg=s.c_str(); - } + if(!msg) msg=s.c_str(); nothrow.handler(nothrow.ptr,10000,msg,opt); } catch (...) { // if exception cannot be translated, we add a bad_exception to the stack @@ -350,9 +285,7 @@ extern "C" { // was linked against a different C++ library try { plumed_massert(plumed,"trying to use a plumed object which is not initialized"); - if(getenvTypesafeDebug()) { - typesafeDebug(key,safe); - } + if(getenvTypesafeDebug()) typesafeDebug(key,safe); p->cmd(key,PLMD::TypesafePtr::fromSafePtr(&safe)); } catch(...) { if(p->getNestedExceptions()) { @@ -431,41 +364,33 @@ class PlumedMainInitializer { const bool debug; public: PlumedMainInitializer(): - debug(std::getenv("PLUMED_LOAD_DEBUG")) { + debug(std::getenv("PLUMED_LOAD_DEBUG")) + { // make sure static plumed_function_pointers is initialized here plumed_symbol_table_init(); - if(debug) { - std::fprintf(stderr,"+++ Initializing PLUMED with plumed_symbol_table version %i at %p\n",plumed_symbol_table.version,(void*)&plumed_symbol_table); - } + if(debug) std::fprintf(stderr,"+++ Initializing PLUMED with plumed_symbol_table version %i at %p\n",plumed_symbol_table.version,(void*)&plumed_symbol_table); #if defined(__PLUMED_HAS_DLOPEN) if(std::getenv("PLUMED_LOAD_SKIP_REGISTRATION")) { - if(debug) { - std::fprintf(stderr,"+++ Skipping registration +++\n"); - } + if(debug) std::fprintf(stderr,"+++ Skipping registration +++\n"); return; } typedef plumed_plumedmain_function_holder_x* (*plumed_kernel_register_type_x)(const plumed_plumedmain_function_holder_x*); plumed_kernel_register_type_x plumed_kernel_register=nullptr; void* handle=nullptr; #if defined(__PLUMED_HAS_RTLD_DEFAULT) - if(debug) { - std::fprintf(stderr,"+++ Registering functions. Looking in RTLD_DEFAULT +++\n"); - } + if(debug) std::fprintf(stderr,"+++ Registering functions. Looking in RTLD_DEFAULT +++\n"); void* dls=dlsym(RTLD_DEFAULT,"plumed_kernel_register"); #else handle=dlopen(NULL,RTLD_LOCAL); - if(debug) { - std::fprintf(stderr,"+++ Registering functions. dlopen handle at %p +++\n",handle); - } + if(debug) std::fprintf(stderr,"+++ Registering functions. dlopen handle at %p +++\n",handle); void* dls=dlsym(handle,"plumed_kernel_register"); #endif *(void **)(&plumed_kernel_register)=dls; if(debug) { if(plumed_kernel_register) { std::fprintf(stderr,"+++ plumed_kernel_register found at %p +++\n",dls); - } else { - std::fprintf(stderr,"+++ plumed_kernel_register not found +++\n"); } + else std::fprintf(stderr,"+++ plumed_kernel_register not found +++\n"); } void*createp; void*cmdp; @@ -473,24 +398,17 @@ class PlumedMainInitializer { plumed_convert_fptr(createp,plumed_symbol_table.functions.create); plumed_convert_fptr(cmdp,plumed_symbol_table.functions.cmd); plumed_convert_fptr(finalizep,plumed_symbol_table.functions.finalize); - if(plumed_kernel_register && debug) - std::fprintf(stderr,"+++ Registering functions at %p (%p,%p,%p) +++\n", - (void*)&plumed_symbol_table.functions,createp,cmdp,finalizep); - if(plumed_kernel_register) { - (*plumed_kernel_register)(&plumed_symbol_table.functions); - } + if(plumed_kernel_register && debug) std::fprintf(stderr,"+++ Registering functions at %p (%p,%p,%p) +++\n", + (void*)&plumed_symbol_table.functions,createp,cmdp,finalizep); + if(plumed_kernel_register) (*plumed_kernel_register)(&plumed_symbol_table.functions); // Notice that handle could be null in the following cases: // - if we use RTLD_DEFAULT // - on Linux if we don't use RTLD_DEFAULT, since dlopen(NULL,RTLD_LOCAL) returns a null pointer. - if(handle) { - dlclose(handle); - } + if(handle) dlclose(handle); #endif } ~PlumedMainInitializer() { - if(debug) { - std::fprintf(stderr,"+++ Finalizing PLUMED with plumed_symbol_table at %p\n",(void*)&plumed_symbol_table); - } + if(debug) std::fprintf(stderr,"+++ Finalizing PLUMED with plumed_symbol_table at %p\n",(void*)&plumed_symbol_table); } } PlumedMainInitializerRegisterMe; } diff --git a/src/core/TargetDist.cpp b/src/core/TargetDist.cpp index 413b75018e..a617e99fa7 100644 --- a/src/core/TargetDist.cpp +++ b/src/core/TargetDist.cpp @@ -50,14 +50,9 @@ void TargetDist::read( const PDB& pdb, std::vector ar ) { void TargetDist::read( const std::vector& targ, std::vector ar ) { plumed_assert( targ.size()==ar.size() ); - target.resize( ar.size() ); - args.resize( ar.size() ); + target.resize( ar.size() ); args.resize( ar.size() ); log.printf(" distance from this point in cv space : "); - for(unsigned i=0; i& derivs ) { double dist=0; for(unsigned i=0; idifference( target[i], args[i]->get() ); - derivs[i]=tmp; - dist+=tmp*tmp; + derivs[i]=tmp; dist+=tmp*tmp; } dist=std::sqrt(dist); - for(unsigned i=0; i& forces ) const { - if( !hasForce ) { - return false; - } + if( !hasForce ) return false; plumed_dbg_massert( derivatives.size()==forces.size()," forces array has wrong size" ); const unsigned N=derivatives.size(); - for(unsigned i=0; ierror("could not convert period string " + str_min + " to real"); - } + if( !Tools::convertNoexcept(str_min,min) ) action->error("could not convert period string " + str_min + " to real"); str_max=pmax; - if( !Tools::convertNoexcept(str_max,max) ) { - action->error("could not convert period string " + str_max + " to read"); - } + if( !Tools::convertNoexcept(str_max,max) ) action->error("could not convert period string " + str_max + " to read"); setupPeriodicity(); } @@ -134,9 +127,7 @@ void Value::getDomain(double&minout,double&maxout) const { void Value::setGradients() { // Can't do gradients if we don't have derivatives - if( !hasDeriv ) { - return; - } + if( !hasDeriv ) return; gradients.clear(); ActionAtomistic*aa=dynamic_cast(action); ActionWithArguments*aw=dynamic_cast(action); @@ -151,9 +142,7 @@ void Value::setGradients() { gradients[p.first]+=matmul(Vector(derivatives[3*j],derivatives[3*j+1],derivatives[3*j+2]),p.second); } } else { - for(unsigned i=0; i<3; i++) { - gradients[an][i]+=derivatives[3*j+i]; - } + for(unsigned i=0; i<3; i++) gradients[an][i]+=derivatives[3*j+i]; } } } else if(aw) { @@ -164,9 +153,7 @@ void Value::setGradients() { gradients[iatom]+=p.second*derivatives[j]; } } - } else { - plumed_error(); - } + } else plumed_error(); } double Value::projection(const Value& v1,const Value&v2) { @@ -190,33 +177,23 @@ ActionWithValue* Value::getPntrToAction() { void copy( const Value& val1, Value& val2 ) { unsigned nder=val1.getNumberOfDerivatives(); - if( nder!=val2.getNumberOfDerivatives() ) { - val2.resizeDerivatives( nder ); - } + if( nder!=val2.getNumberOfDerivatives() ) { val2.resizeDerivatives( nder ); } val2.clearDerivatives(); - for(unsigned i=0; igetNumberOfDerivatives() ) { - val2->resizeDerivatives( nder ); - } + if( nder!=val2->getNumberOfDerivatives() ) { val2->resizeDerivatives( nder ); } val2->clearDerivatives(); - for(unsigned i=0; iaddDerivative( i, val1.getDerivative(i) ); - } + for(unsigned i=0; iaddDerivative( i, val1.getDerivative(i) ); val2->set( val1.get() ); } void add( const Value& val1, Value* val2 ) { plumed_assert( val1.getNumberOfDerivatives()==val2->getNumberOfDerivatives() ); - for(unsigned i=0; iaddDerivative( i, val1.getDerivative(i) ); - } + for(unsigned i=0; iaddDerivative( i, val1.getDerivative(i) ); val2->set( val1.get() + val2->get() ); } diff --git a/src/core/Value.h b/src/core/Value.h index cd604d279d..be8495116f 100644 --- a/src/core/Value.h +++ b/src/core/Value.h @@ -158,18 +158,14 @@ inline void Value::applyPeriodicity() { if(periodicity==periodic) { value=min+difference(min,value); - if(valuederivatives.size()!=val1.derivatives.size() ) { - valout->resizeDerivatives( val1.derivatives.size() ); - } + if( valout->derivatives.size()!=val1.derivatives.size() ) valout->resizeDerivatives( val1.derivatives.size() ); valout->value_set=false; valout->clearDerivatives(); double u=val1.get(); @@ -193,8 +187,7 @@ void quotient( const Value& val1, const Value& val2, Value* valout ) { for(unsigned i=0; iaddDerivative(i, v*val1.getDerivative(i) - u*val2.getDerivative(i) ); } - valout->chainRule( 1/(v*v) ); - valout->set( u / v ); + valout->chainRule( 1/(v*v) ); valout->set( u / v ); } inline @@ -245,9 +238,7 @@ bool Value::hasDerivatives() const { inline void Value::resizeDerivatives(int n) { - if(hasDeriv) { - derivatives.resize(n); - } + if(hasDeriv) derivatives.resize(n); } inline @@ -264,9 +255,7 @@ void Value::setDerivative(unsigned i, double d) { inline void Value::chainRule(double df) { - for(unsigned i=0; i all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); setupMultiColvarBase( all_atoms ); // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { switchingFunction.set(sw,errors); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } log.printf(" orientation of those bonds with lengths are less than %s\n",( switchingFunction.description() ).c_str() ); // Set the link cell cutoff setLinkCellCutoff( switchingFunction.get_dmax() ); - double rcut = switchingFunction.get_dmax(); - rcut2 = rcut*rcut; + double rcut = switchingFunction.get_dmax(); rcut2 = rcut*rcut; // Set the dimensionality of the vectors setVectorDimensionality(3); } double BondOrientation::calculateWeight( const unsigned& current, const double& weight, multicolvar::AtomValuePack& myatoms ) const { - Vector distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - double distm=distance.modulo2(); - if( distm>rcut2 ) { - return 0.0; - } + Vector distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); double distm=distance.modulo2(); + if( distm>rcut2 ) return 0.0; double df, ww=switchingFunction.calculateSqr( distm, df ); // Derivatives of weights addAtomDerivatives( 0, 0, -df*weight*distance, myatoms ); diff --git a/src/crystallization/CubicHarmonicBase.cpp b/src/crystallization/CubicHarmonicBase.cpp index eae9de8f7e..dd6c939a55 100644 --- a/src/crystallization/CubicHarmonicBase.cpp +++ b/src/crystallization/CubicHarmonicBase.cpp @@ -32,9 +32,7 @@ namespace crystallization { void CubicHarmonicBase::registerKeywords( Keywords& keys ) { multicolvar::MultiColvarBase::registerKeywords( keys ); - keys.use("SPECIES"); - keys.use("SPECIESA"); - keys.use("SPECIESB"); + keys.use("SPECIES"); keys.use("SPECIESA"); keys.use("SPECIESB"); keys.add("compulsory","NN","6","The n parameter of the switching function "); keys.add("compulsory","MM","0","The m parameter of the switching function; 0 implies 2*NN"); keys.add("compulsory","D_0","0.0","The d_0 parameter of the switching function"); @@ -47,47 +45,29 @@ void CubicHarmonicBase::registerKeywords( Keywords& keys ) { keys.add("compulsory","PSI","0.0","The Euler rotational angle psi"); keys.addFlag("UNORMALIZED",false,"calculate the sum of the components of the vector rather than the mean"); // Use actionWithDistributionKeywords - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("LESS_THAN"); - keys.use("MAX"); - keys.use("MIN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); - keys.use("ALT_MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("LESS_THAN"); keys.use("MAX"); + keys.use("MIN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); + keys.use("ALT_MIN"); keys.use("LOWEST"); keys.use("HIGHEST"); } CubicHarmonicBase::CubicHarmonicBase(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { switchingFunction.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } - double phi, theta, psi; - parse("PHI",phi); - parse("THETA",theta); - parse("PSI",psi); + double phi, theta, psi; parse("PHI",phi); parse("THETA",theta); parse("PSI",psi); log.printf(" creating rotation matrix with Euler angles phi=%f, theta=%f and psi=%f\n",phi,theta,psi); // Calculate the rotation matrix http://mathworld.wolfram.com/EulerAngles.html rotationmatrix[0][0]=std::cos(psi)*std::cos(phi)-std::cos(theta)*std::sin(phi)*std::sin(psi); @@ -105,26 +85,20 @@ CubicHarmonicBase::CubicHarmonicBase(const ActionOptions&ao): log.printf(" measure crystallinity around central atom. Includes those atoms within %s\n",( switchingFunction.description() ).c_str() ); parseFlag("UNORMALIZED",unormalized); - if( unormalized ) { - log.printf(" output sum of vector functions \n"); - } else { - log.printf(" output mean of vector functions \n"); - } + if( unormalized ) log.printf(" output sum of vector functions \n"); + else log.printf(" output mean of vector functions \n"); // Set the link cell cutoff rcut2 = switchingFunction.get_dmax()*switchingFunction.get_dmax(); setLinkCellCutoff( switchingFunction.get_dmax() ); // And setup the ActionWithVessel - std::vector all_atoms; - setupMultiColvarBase( all_atoms ); + std::vector all_atoms; setupMultiColvarBase( all_atoms ); } double CubicHarmonicBase::compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const { - double dfunc; - Vector rotatedis; + double dfunc; Vector rotatedis; // Calculate the coordination number - Vector myder, rotateder, fder; - unsigned nat=myatoms.getNumberOfAtoms(); + Vector myder, rotateder, fder; unsigned nat=myatoms.getNumberOfAtoms(); for(unsigned i=1; i der of... value [0], weight[1], x coord [2], y, z... [more magic] updateActiveAtoms( myatoms ); - if( !unormalized ) { - myatoms.getUnderlyingMultiValue().quotientRule( 1, 1 ); - } + if( !unormalized ) myatoms.getUnderlyingMultiValue().quotientRule( 1, 1 ); return myatoms.getValue(1); // this is equivalent to getting an "atomic" CV } diff --git a/src/crystallization/CubicHarmonicBase.h b/src/crystallization/CubicHarmonicBase.h index faf03d492b..d1f24d8120 100644 --- a/src/crystallization/CubicHarmonicBase.h +++ b/src/crystallization/CubicHarmonicBase.h @@ -43,9 +43,7 @@ class CubicHarmonicBase : public multicolvar::MultiColvarBase { double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const ; virtual double calculateCubicHarmonic( const Vector& distance, const double& d2, Vector& myder ) const = 0; /// Returns the number of coordinates of the field - bool isPeriodic() { - return false; - } + bool isPeriodic() { return false; } }; } diff --git a/src/crystallization/EnvironmentSimilarity.cpp b/src/crystallization/EnvironmentSimilarity.cpp index f5fa4200a9..695eb45bc8 100644 --- a/src/crystallization/EnvironmentSimilarity.cpp +++ b/src/crystallization/EnvironmentSimilarity.cpp @@ -203,9 +203,7 @@ class EnvironmentSimilarity : public multicolvar::MultiColvarBase { // active methods: virtual double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const ; // Returns the number of coordinates of the field - bool isPeriodic() { - return false; - } + bool isPeriodic() { return false; } // Calculates maximum distance in an environment double maxDistance(std::vector environment); // Parse everything connected to the definition of the reference environments @@ -220,9 +218,7 @@ PLUMED_REGISTER_ACTION(EnvironmentSimilarity,"ENVIRONMENTSIMILARITY") void EnvironmentSimilarity::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("SPECIES"); - keys.use("SPECIESA"); - keys.use("SPECIESB"); + keys.use("SPECIES"); keys.use("SPECIESA"); keys.use("SPECIESB"); keys.add("compulsory","SIGMA","0.1","Broadening parameter"); keys.add("compulsory","CRYSTAL_STRUCTURE","FCC","Targeted crystal structure. Options are: " "SC: simple cubic, " @@ -243,22 +239,15 @@ void EnvironmentSimilarity::registerKeywords( Keywords& keys ) { keys.add("optional","ATOM_NAMES_FILE","PDB file with atom names for all atoms in SPECIES." " Atoms in reference environments will be compared only if atom names match."); // Use actionWithDistributionKeywords - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("LESS_THAN"); - keys.use("MAX"); - keys.use("MIN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); - keys.use("ALT_MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("LESS_THAN"); keys.use("MAX"); + keys.use("MIN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); + keys.use("ALT_MIN"); keys.use("LOWEST"); keys.use("HIGHEST"); } EnvironmentSimilarity::EnvironmentSimilarity(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ log.printf(" Please read and cite "); log << plumed.cite("Piaggi and Parrinello, J. Chem. Phys. 150 (24), 244119 (2019)"); log.printf("\n"); @@ -274,9 +263,7 @@ EnvironmentSimilarity::EnvironmentSimilarity(const ActionOptions&ao): lambda_=100; parse("LAMBDA", lambda_); - if (environments_.size()>1) { - log.printf(" using a soft max function with lambda %f\n",lambda_); - } + if (environments_.size()>1) log.printf(" using a soft max function with lambda %f\n",lambda_); // Set the link cell cutoff double rcut = max_dist_ref_vector + 3*sigma; @@ -284,9 +271,7 @@ EnvironmentSimilarity::EnvironmentSimilarity(const ActionOptions&ao): rcut2_ = rcut * rcut; // And setup the ActionWithVessel - std::vector all_atoms; - setupMultiColvarBase( all_atoms ); - checkRead(); + std::vector all_atoms; setupMultiColvarBase( all_atoms ); checkRead(); plumed_massert(atomNames_.empty() || atomNames_.size()==getNumberOfAtoms(),"mismatch between atoms in SPECIES and ATOM_NAMES_FILE"); } @@ -413,9 +398,7 @@ double EnvironmentSimilarity::maxDistance( std::vector environment ) { double max_dist = 0.0; for(unsigned i=0; imax_dist) { - max_dist=norm; - } + if (norm>max_dist) max_dist=norm; } return max_dist; } @@ -427,9 +410,7 @@ void EnvironmentSimilarity::parseReferenceEnvironments( std::vector environment; - std::vector environmentAtomNames; - environment.resize( natoms ); - environmentAtomNames.resize( natoms); - for(unsigned i=0; i environment; std::vector environmentAtomNames; + environment.resize( natoms ); environmentAtomNames.resize( natoms); + for(unsigned i=0; imax_dist) { - max_dist=norm; - } + if (norm>max_dist) max_dist=norm; log.printf(" Reference environment %d : reading %d reference vectors from %s \n", i, natoms, reffile.c_str() ); } } - if (environments.size()==0) - error("No environments have been found! Please specify a PDB file in the REFERENCE " - "or in the REFERENCE_1, REFERENCE_2, etc keywords"); + if (environments.size()==0) error("No environments have been found! Please specify a PDB file in the REFERENCE " + "or in the REFERENCE_1, REFERENCE_2, etc keywords"); log.printf(" Number of reference environments is %lu\n",environments.size() ); log.printf(" Number of vectors per reference environment is %lu\n",environments[0].size() ); std::string atomNamesFile; parse("ATOM_NAMES_FILE",atomNamesFile); if (!atomNamesFile.empty()) { PDB pdb; - if( !pdb.read(atomNamesFile,plumed.getAtoms().usingNaturalUnits(),0.1/plumed.getAtoms().getUnits().getLength()) ) { + if( !pdb.read(atomNamesFile,plumed.getAtoms().usingNaturalUnits(),0.1/plumed.getAtoms().getUnits().getLength()) ) error("missing input file " + atomNamesFile); - } unsigned natoms=pdb.getPositions().size(); atomNames_.resize( natoms ); - for(unsigned i=0; i0) { - log.printf(" with lattice constants %f\n",lattice_constants[0]); - } else { - log.printf("\n"); - } + if (lattice_constants.size()>0) log.printf(" with lattice constants %f\n",lattice_constants[0]); + else log.printf("\n"); log.printf(" maximum distance in the reference environment is %f\n",max_dist); } diff --git a/src/crystallization/Fccubic.cpp b/src/crystallization/Fccubic.cpp index 2d8062c430..8763087087 100644 --- a/src/crystallization/Fccubic.cpp +++ b/src/crystallization/Fccubic.cpp @@ -90,12 +90,12 @@ void Fccubic::registerKeywords( Keywords& keys ) { Fccubic::Fccubic(const ActionOptions&ao): Action(ao), - CubicHarmonicBase(ao) { + CubicHarmonicBase(ao) +{ // Scaling factors such that '1' corresponds to fcc lattice // and '0' corresponds to isotropic (liquid) parse("ALPHA",alpha); - a1 = 80080. / (2717. + 16*alpha); - b1 = 16.*(alpha-143)/(2717+16*alpha); + a1 = 80080. / (2717. + 16*alpha); b1 = 16.*(alpha-143)/(2717+16*alpha); log.printf(" setting alpha parameter equal to %f \n",alpha); // And setup the ActionWithVessel checkRead(); diff --git a/src/crystallization/Gradient.cpp b/src/crystallization/Gradient.cpp index 9da2b08b62..22ff2c7739 100644 --- a/src/crystallization/Gradient.cpp +++ b/src/crystallization/Gradient.cpp @@ -73,103 +73,61 @@ void Gradient::registerKeywords( Keywords& keys ) { Gradient::Gradient(const ActionOptions&ao): Action(ao), VolumeGradientBase(ao), - nbins(3) { + nbins(3) +{ std::vector atom; parseAtomList("ORIGIN",atom); - if( atom.size()!=1 ) { - error("should only be one atom specified"); - } + if( atom.size()!=1 ) error("should only be one atom specified"); log.printf(" origin is at position of atom : %d\n",atom[0].serial() ); - std::string direction; - parse("DIR",direction); - std::vector tbins; - parseVector("NBINS",tbins); + std::string direction; parse("DIR",direction); + std::vector tbins; parseVector("NBINS",tbins); for(unsigned i=0; iisDensity() ) { - vend=2; - } else if( getPntrToMultiColvar()->getNumberOfQuantities()==2 ) { - vend=2; - } else { - vend = getPntrToMultiColvar()->getNumberOfQuantities(); - } + if( getPntrToMultiColvar()->isDensity() ) vend=2; + else if( getPntrToMultiColvar()->getNumberOfQuantities()==2 ) vend=2; + else vend = getPntrToMultiColvar()->getNumberOfQuantities(); nquantities = vend + nbins[0] + nbins[1] + nbins[2]; // Output some nice information std::string functype=getPntrToMultiColvar()->getName(); - std::transform( functype.begin(), functype.end(), functype.begin(), [](unsigned char c) { - return std::tolower(c); - } ); + std::transform( functype.begin(), functype.end(), functype.begin(), [](unsigned char c) { return std::tolower(c); } ); log.printf(" calculating gradient of %s in %s direction \n",functype.c_str(), direction.c_str() ); log<<" Bibliography:"<getCentralAtomPos( curr ) ); // Note we use the pbc from base multicolvar so that we get numerical derivatives correct Vector oderiv, fpos = (getPntrToMultiColvar()->getPbc()).realToScaled( cpos ); - Vector deriv; - unsigned nbase=vend; - std::vector refder(1); - Tensor vir; - vir.zero(); + Vector deriv; unsigned nbase=vend; std::vector refder(1); Tensor vir; vir.zero(); for(unsigned idir=0; idir<3; ++idir) { deriv[0]=deriv[1]=deriv[2]=0.0; double delx = 1.0 / static_cast( nbins[idir] ); diff --git a/src/crystallization/GradientVessel.cpp b/src/crystallization/GradientVessel.cpp index 373f4e6c0d..6d5389fc4f 100644 --- a/src/crystallization/GradientVessel.cpp +++ b/src/crystallization/GradientVessel.cpp @@ -56,10 +56,10 @@ void GradientVessel::reserveKeyword( Keywords& keys ) { } GradientVessel::GradientVessel( const vesselbase::VesselOptions& da ) : - FunctionVessel(da) { + FunctionVessel(da) +{ Gradient* vg=dynamic_cast( getAction() ); - plumed_assert( vg ); - isdens=(vg->getPntrToMultiColvar())->isDensity(); + plumed_assert( vg ); isdens=(vg->getPntrToMultiColvar())->isDensity(); nweights = vg->nbins[0] + vg->nbins[1] + vg->nbins[2]; if( (vg->getPntrToMultiColvar())->getNumberOfQuantities()>2 ) { ncomponents = (vg->getPntrToMultiColvar())->getNumberOfQuantities() - 2; @@ -72,17 +72,13 @@ GradientVessel::GradientVessel( const vesselbase::VesselOptions& da ) : starts.push_back( vg->nbins[0] ); if( vg->nbins[1]>0 ) { starts.push_back( vg->nbins[0] + vg->nbins[1] ); - if( vg->nbins[2]>0 ) { - starts.push_back( nweights ); - } + if( vg->nbins[2]>0 ) starts.push_back( nweights ); } else if( vg->nbins[2]>0 ) { starts.push_back( nweights ); } } else if( vg->nbins[1]>0 ) { starts.push_back( vg->nbins[1] ); - if( vg->nbins[2]>0 ) { - starts.push_back( nweights ); - } + if( vg->nbins[2]>0 ) starts.push_back( nweights ); } else if( vg->nbins[2]>0 ) { starts.push_back( nweights ); } @@ -104,19 +100,9 @@ void GradientVessel::resize() { void GradientVessel::calculate( const unsigned& current, MultiValue& myvals, std::vector& buffer, std::vector& der_list ) const { unsigned nder; - if( getAction()->derivativesAreRequired() ) { - nder=getAction()->getNumberOfDerivatives(); - } else { - nder=0; - } - unsigned wstart, cstart; - if( ncomponents==1 ) { - cstart=1; - wstart=2; - } else { - cstart=2; - wstart=2+ncomponents; - } + if( getAction()->derivativesAreRequired() ) nder=getAction()->getNumberOfDerivatives(); + else nder=0; + unsigned wstart, cstart; if( ncomponents==1 ) { cstart=1; wstart=2; } else { cstart=2; wstart=2+ncomponents; } for(unsigned iw=0; iw& buffer ) { std::vector val_interm( ncomponents*nweights ); unsigned nder; - if( getAction()->derivativesAreRequired() ) { - nder=getAction()->getNumberOfDerivatives(); - } else { - nder=0; - } - Matrix der_interm( ncomponents*nweights, nder ); - der_interm=0; + if( getAction()->derivativesAreRequired() ) nder=getAction()->getNumberOfDerivatives(); + else nder=0; + Matrix der_interm( ncomponents*nweights, nder ); der_interm=0; if( isdens ) { for(unsigned iw=0; iwderivativesAreRequired() ) { unsigned wstart = bufstart + 2*iw*(nder+1) + 1; - for(unsigned jder=0; jderderivativesAreRequired() ) { unsigned wstart = bufstart + xx*(nder+1) + 1; for(unsigned jc=0; jc& buffer ) { for(unsigned j=0; jgetNumberOfQuantities()!=5 ) { - error("input multicolvar does not calculate molecular orientations"); - } + if( getBaseMultiColvar(i)->getNumberOfQuantities()!=5 ) error("input multicolvar does not calculate molecular orientations"); } // The weight of this does have derivatives weightHasDerivatives=true; // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { switchingFunction.set(sw,errors); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } log.printf(" calculating number of links with atoms separation of %s\n",( switchingFunction.description() ).c_str() ); - std::vector all_atoms; - readTwoGroups( "MOLS", "MOLSA", "MOLSB", all_atoms ); - setupMultiColvarBase( all_atoms ); - setLinkCellCutoff( switchingFunction.get_dmax() ); + std::vector all_atoms; readTwoGroups( "MOLS", "MOLSA", "MOLSB", all_atoms ); + setupMultiColvarBase( all_atoms ); setLinkCellCutoff( switchingFunction.get_dmax() ); for(unsigned i=0; ihasDifferentiableOrientation() ) { - error("cannot use multicolvar of type " + getBaseMultiColvar(i)->getName() ); - } + if( !getBaseMultiColvar(i)->hasDifferentiableOrientation() ) error("cannot use multicolvar of type " + getBaseMultiColvar(i)->getName() ); } // Create holders for the collective variable readVesselKeywords(); plumed_assert( getNumberOfVessels()==0 ); - std::string input; - addVessel( "SUM", input, -1 ); + std::string input; addVessel( "SUM", input, -1 ); readVesselKeywords(); } @@ -186,21 +169,12 @@ double InterMolecularTorsions::compute( const unsigned& tindex, multicolvar::Ato std::vector orient0( 5 ), orient1( 5 ); getInputData( 0, true, myatoms, orient0 ); getInputData( 1, true, myatoms, orient1 ); - for(unsigned i=0; i<3; ++i) { - v1[i]=orient0[2+i]; - v2[i]=orient1[2+i]; - } - if( getBaseMultiColvar(0)->getNumberOfQuantities()<3 ) { - return 1.0; - } + for(unsigned i=0; i<3; ++i) { v1[i]=orient0[2+i]; v2[i]=orient1[2+i]; } + if( getBaseMultiColvar(0)->getNumberOfQuantities()<3 ) return 1.0; // Evaluate angle - Torsion t; - double angle = t.compute( v1, conn, v2, dv1, dconn, dv2 ); - for(unsigned i=0; i<3; ++i) { - orient0[i+2]=dv1[i]; - orient1[i+2]=dv2[i]; - } + Torsion t; double angle = t.compute( v1, conn, v2, dv1, dconn, dv2 ); + for(unsigned i=0; i<3; ++i) { orient0[i+2]=dv1[i]; orient1[i+2]=dv2[i]; } // And accumulate derivatives if( !doNotCalculateDerivatives() ) { @@ -208,8 +182,7 @@ double InterMolecularTorsions::compute( const unsigned& tindex, multicolvar::Ato mergeInputDerivatives( 1, 2, orient1.size(), 0, orient0, myder0, myatoms ); MultiValue& myder1=getInputDerivatives( 1, true, myatoms ); mergeInputDerivatives( 1, 2, orient0.size(), 1, orient1, myder1, myatoms ); - addAtomDerivatives( 1, 0, -dconn, myatoms ); - addAtomDerivatives( 1, 1, dconn, myatoms ); + addAtomDerivatives( 1, 0, -dconn, myatoms ); addAtomDerivatives( 1, 1, dconn, myatoms ); myatoms.addBoxDerivatives( 1, -extProduct( conn, dconn ) ); } diff --git a/src/crystallization/LocalSteinhardt.h b/src/crystallization/LocalSteinhardt.h index 63942c9730..693fcb6a8e 100644 --- a/src/crystallization/LocalSteinhardt.h +++ b/src/crystallization/LocalSteinhardt.h @@ -32,7 +32,8 @@ class LocalSteinhardt : public OrientationSphere { static void registerKeywords( Keywords& keys ) { OrientationSphere::registerKeywords(keys); } - explicit LocalSteinhardt(const ActionOptions& ao): Action(ao), OrientationSphere(ao) { + explicit LocalSteinhardt(const ActionOptions& ao): Action(ao), OrientationSphere(ao) + { for(unsigned i=0; i( getBaseMultiColvar(i) ); if(!mc) { @@ -41,21 +42,16 @@ class LocalSteinhardt : public OrientationSphere { } for(unsigned j=0; jgetNumberOfBaseMultiColvars(); ++j) { T* mmc=dynamic_cast( getBaseMultiColvar(i)->getBaseMultiColvar(j) ); - if( !mmc ) { - error("input action is not calculating the correct vectors"); - } + if( !mmc ) error("input action is not calculating the correct vectors"); } } } } double computeVectorFunction( const Vector& conn, const std::vector& vec1, const std::vector& vec2, Vector& dconn, std::vector& dvec1, std::vector& dvec2 ) const override { - double dot=0; - dconn.zero(); + double dot=0; dconn.zero(); for(unsigned k=2; k all_atoms; readAtomsLikeKeyword("MOL",-1,all_atoms); nvectors = std::floor( ablocks.size() / 2 ); - if( ablocks.size()%2!=0 && 2*nvectors+1!=ablocks.size() ) { - error("number of atoms in molecule specification is wrong. Should be two or three."); - } + if( ablocks.size()%2!=0 && 2*nvectors+1!=ablocks.size() ) error("number of atoms in molecule specification is wrong. Should be two or three."); - if( all_atoms.size()==0 ) { - error("No atoms were specified"); - } - setVectorDimensionality( 3*nvectors ); - setupMultiColvarBase( all_atoms ); + if( all_atoms.size()==0 ) error("No atoms were specified"); + setVectorDimensionality( 3*nvectors ); setupMultiColvarBase( all_atoms ); if( ablocks.size()==2*nvectors+1 ) { - std::vector catom_ind(ablocks.size(), false); - catom_ind[ablocks.size()-1]=true; + std::vector catom_ind(ablocks.size(), false); catom_ind[ablocks.size()-1]=true; setAtomsForCentralAtom( catom_ind ); } } @@ -105,8 +98,7 @@ AtomNumber MoleculeOrientation::getAbsoluteIndexOfCentralAtom( const unsigned& i void MoleculeOrientation::calculateVector( multicolvar::AtomValuePack& myatoms ) const { for(unsigned i=0; i& vals ) const { for(unsigned i=0; iepsilon ) { - inorm = 1.0 / norm; - } - for(unsigned j=0; j<3; ++j) { - vals[2+3*i+j] = inorm*vals[2+3*i+j]; - } + double inorm = 1.0; if( norm>epsilon ) inorm = 1.0 / norm; + for(unsigned j=0; j<3; ++j) vals[2+3*i+j] = inorm*vals[2+3*i+j]; } } void MoleculeOrientation::normalizeVectorDerivatives( MultiValue& myvals ) const { std::vector weight( nvectors ), wdf( nvectors ); for(unsigned ivec=0; ivecepsilon ) { - weight[ivec] = 1.0 / v; - wdf[ivec] = 1.0 / ( v*v*v ); - } + double v=0; for(unsigned jcomp=0; jcomp<3; ++jcomp) v += myvals.get( 2+3*ivec+jcomp )*myvals.get( 2+3*ivec+jcomp ); + v=sqrt(v); weight[ivec]=1.0; wdf[ivec]=1.0; + if( v>epsilon ) { weight[ivec] = 1.0 / v; wdf[ivec] = 1.0 / ( v*v*v ); } } for(unsigned j=0; j all_atoms; readAtomsLikeKeyword("MOL",-1,all_atoms); - if( ablocks.size()!=3 && ablocks.size()!=4 ) { - error("number of atoms in molecule specification is wrong. Should be three or four."); - } + if( ablocks.size()!=3 && ablocks.size()!=4 ) error("number of atoms in molecule specification is wrong. Should be three or four."); - if( all_atoms.size()==0 ) { - error("No atoms were specified"); - } - setVectorDimensionality( 3 ); - setupMultiColvarBase( all_atoms ); + if( all_atoms.size()==0 ) error("No atoms were specified"); + setVectorDimensionality( 3 ); setupMultiColvarBase( all_atoms ); } AtomNumber MoleculePlane::getAbsoluteIndexOfCentralAtom( const unsigned& iatom ) const { diff --git a/src/crystallization/OrientationSphere.cpp b/src/crystallization/OrientationSphere.cpp index 6998e61f79..c95493b7e4 100644 --- a/src/crystallization/OrientationSphere.cpp +++ b/src/crystallization/OrientationSphere.cpp @@ -38,41 +38,26 @@ void OrientationSphere::registerKeywords( Keywords& keys ) { "The following provides information on the \\ref switchingfunction that are available. " "When this keyword is present you no longer need the NN, MM, D_0 and R_0 keywords."); // Use actionWithDistributionKeywords - keys.use("SPECIES"); - keys.use("SPECIESA"); - keys.use("SPECIESB"); - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("LESS_THAN"); - keys.use("MIN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); - keys.use("LOWEST"); - keys.use("HIGHEST"); + keys.use("SPECIES"); keys.use("SPECIESA"); keys.use("SPECIESB"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("LESS_THAN"); + keys.use("MIN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); + keys.use("LOWEST"); keys.use("HIGHEST"); } OrientationSphere::OrientationSphere(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { - if( getNumberOfBaseMultiColvars()>1 ) { - warning("not sure if orientation sphere works with more than one base multicolvar - check numerical derivatives"); - } + MultiColvarBase(ao) +{ + if( getNumberOfBaseMultiColvars()>1 ) warning("not sure if orientation sphere works with more than one base multicolvar - check numerical derivatives"); // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { switchingFunction.set(sw,errors); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } log.printf(" degree of overlap in orientation between central molecule and those within %s\n",( switchingFunction.description() ).c_str() ); @@ -80,13 +65,11 @@ OrientationSphere::OrientationSphere(const ActionOptions&ao): // Set the link cell cutoff rcut2 = switchingFunction.get_dmax()*switchingFunction.get_dmax(); setLinkCellCutoff( switchingFunction.get_dmax() ); - std::vector all_atoms; - setupMultiColvarBase( all_atoms ); + std::vector all_atoms; setupMultiColvarBase( all_atoms ); } double OrientationSphere::compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const { - double sw, value=0, denom=0, dfunc; - Vector ddistance; + double sw, value=0, denom=0, dfunc; Vector ddistance; unsigned ncomponents=getBaseMultiColvar(0)->getNumberOfQuantities(); std::vector catom_orient( ncomponents ), this_orient( ncomponents ); std::vector this_der( ncomponents ), catom_der( ncomponents ); @@ -109,10 +92,7 @@ double OrientationSphere::compute( const unsigned& tindex, multicolvar::AtomValu double f_dot = computeVectorFunction( distance, catom_orient, this_orient, ddistance, catom_der, this_der ); if( !doNotCalculateDerivatives() ) { - for(unsigned k=2; kepsilon ) { - rdenom = 1.0 / denom; - } else { - plumed_assert(std::fabs(value)epsilon ) { rdenom = 1.0 / denom; } + else { plumed_assert(std::fabs(value)& vec1, const std::vector& vec2, Vector& dconn, std::vector& dvec1, std::vector& dvec2 ) const = 0; virtual double calculateCoordinationPrefactor( const double& coord, double& df ) const ; - bool isPeriodic() { - return false; - } + bool isPeriodic() { return false; } }; inline double OrientationSphere::calculateCoordinationPrefactor( const double& coord, double& df ) const { - df=0.0; - return 1.0; + df=0.0; return 1.0; } } diff --git a/src/crystallization/PolymerAngles.cpp b/src/crystallization/PolymerAngles.cpp index df2a9c9d5e..b11e90309b 100644 --- a/src/crystallization/PolymerAngles.cpp +++ b/src/crystallization/PolymerAngles.cpp @@ -81,14 +81,11 @@ void PolymerAngles::registerKeywords( Keywords& keys ) { PolymerAngles::PolymerAngles(const ActionOptions& ao): Action(ao), - OrientationSphere(ao) { - if( mybasemulticolvars.size()==0 ) { - error("SMAC must take multicolvar as input"); - } + OrientationSphere(ao) +{ + if( mybasemulticolvars.size()==0 ) error("SMAC must take multicolvar as input"); for(unsigned i=0; igetNumberOfQuantities()-2)%3!=0 ) { - error("POLYMER_ANGLES is only possible with three dimensional vectors"); - } + if( (mybasemulticolvars[i]->getNumberOfQuantities()-2)%3!=0 ) error("POLYMER_ANGLES is only possible with three dimensional vectors"); } } @@ -96,15 +93,8 @@ double PolymerAngles::computeVectorFunction( const Vector& conn, const std::vect Vector& dconn, std::vector& dvec1, std::vector& dvec2 ) const { plumed_assert( (vec1.size()-2)==3 ); - double dot = 0; - for(unsigned k=0; k<3; ++k) { - dot += vec1[2+k]*vec2[2+k]; - } - double ans = 1.5*dot*dot - 0.5; - for(unsigned k=0; k<3; ++k) { - dvec1[2+k]=3*dot*vec2[2+k]; - dvec2[2+k]=3*dot*vec1[2+k]; - } + double dot = 0; for(unsigned k=0; k<3; ++k) dot += vec1[2+k]*vec2[2+k]; + double ans = 1.5*dot*dot - 0.5; for(unsigned k=0; k<3; ++k) { dvec1[2+k]=3*dot*vec2[2+k]; dvec2[2+k]=3*dot*vec1[2+k]; } return ans; } diff --git a/src/crystallization/Q3.cpp b/src/crystallization/Q3.cpp index 375e148e60..88131cc46e 100644 --- a/src/crystallization/Q3.cpp +++ b/src/crystallization/Q3.cpp @@ -194,7 +194,8 @@ void Q3::registerKeywords( Keywords& keys ) { Q3::Q3(const ActionOptions& ao ): Action(ao), - Steinhardt(ao) { + Steinhardt(ao) +{ setAngularMomentum(3); // Spherical harmonics normalization: diff --git a/src/crystallization/Q4.cpp b/src/crystallization/Q4.cpp index bb3c2737bb..3f13d0201e 100644 --- a/src/crystallization/Q4.cpp +++ b/src/crystallization/Q4.cpp @@ -193,7 +193,8 @@ void Q4::registerKeywords( Keywords& keys ) { Q4::Q4(const ActionOptions& ao ): Action(ao), - Steinhardt(ao) { + Steinhardt(ao) +{ setAngularMomentum(4); normaliz.resize( 5 ); @@ -204,10 +205,8 @@ Q4::Q4(const ActionOptions& ao ): normaliz[4] = sqrt( (9.0*1) / (4.0*pi*40320.0) ); coeff_poly.resize( 5 ); - coeff_poly[0]=0.375; - coeff_poly[1]=0.0; - coeff_poly[2]=-3.75; - coeff_poly[3]=0.0; + coeff_poly[0]=0.375; coeff_poly[1]=0.0; + coeff_poly[2]=-3.75; coeff_poly[3]=0.0; coeff_poly[4]=4.375; } diff --git a/src/crystallization/Q6.cpp b/src/crystallization/Q6.cpp index ad1d2f41c9..d66aa2cdf6 100644 --- a/src/crystallization/Q6.cpp +++ b/src/crystallization/Q6.cpp @@ -193,7 +193,8 @@ void Q6::registerKeywords( Keywords& keys ) { Q6::Q6(const ActionOptions& ao ): Action(ao), - Steinhardt(ao) { + Steinhardt(ao) +{ setAngularMomentum(6); normaliz.resize( 7 ); @@ -206,12 +207,9 @@ Q6::Q6(const ActionOptions& ao ): normaliz[6] = sqrt( (13.0*1) / (4.0*pi*479001600) ); coeff_poly.resize( 7 ); - coeff_poly[0]=-0.3125; - coeff_poly[1]=0.0; - coeff_poly[2]=6.5625; - coeff_poly[3]=0.0; - coeff_poly[4]=-19.6875; - coeff_poly[5]=0.0; + coeff_poly[0]=-0.3125; coeff_poly[1]=0.0; + coeff_poly[2]=6.5625; coeff_poly[3]=0.0; + coeff_poly[4]=-19.6875; coeff_poly[5]=0.0; coeff_poly[6]=14.4375; } diff --git a/src/crystallization/SMAC.cpp b/src/crystallization/SMAC.cpp index d73dce7dd7..585bb8e16d 100644 --- a/src/crystallization/SMAC.cpp +++ b/src/crystallization/SMAC.cpp @@ -147,58 +147,39 @@ void SMAC::registerKeywords( Keywords& keys ) { SMAC::SMAC(const ActionOptions& ao): Action(ao), - OrientationSphere(ao) { - if( mybasemulticolvars.size()==0 ) { - error("SMAC must take multicolvar as input"); - } + OrientationSphere(ao) +{ + if( mybasemulticolvars.size()==0 ) error("SMAC must take multicolvar as input"); for(unsigned i=0; igetNumberOfQuantities()-2)%3!=0 ) { - error("SMAC is only possible with three dimensional vectors"); - } + if( (mybasemulticolvars[i]->getNumberOfQuantities()-2)%3!=0 ) error("SMAC is only possible with three dimensional vectors"); } std::string kernelinpt; for(int i=1;; i++) { - if( !parseNumbered("KERNEL",i,kernelinpt) ) { - break; - } + if( !parseNumbered("KERNEL",i,kernelinpt) ) break; KernelFunctions mykernel( kernelinpt ); kernels.push_back( mykernel ); } - if( kernels.size()==0 ) { - error("no kernels defined"); - } + if( kernels.size()==0 ) error("no kernels defined"); - std::string sw, errors; - parse("SWITCH_COORD",sw); - if(sw.length()==0) { - error("SWITCH_COORD keyword is missing"); - } + std::string sw, errors; parse("SWITCH_COORD",sw); + if(sw.length()==0) error("SWITCH_COORD keyword is missing"); coord_switch.set(sw,errors); - if(errors.length()>0) { - error("the following errors were found in input to SWITCH_COORD : " + errors ); - } + if(errors.length()>0) error("the following errors were found in input to SWITCH_COORD : " + errors ); } double SMAC::computeVectorFunction( const Vector& conn, const std::vector& vec1, const std::vector& vec2, Vector& dconn, std::vector& dvec1, std::vector& dvec2 ) const { - unsigned nvectors = ( vec1.size() - 2 ) / 3; - plumed_assert( (vec1.size()-2)%3==0 ); - std::vector dv1(nvectors), dv2(nvectors), tdconn(nvectors); - Torsion t; - std::vector v1(nvectors), v2(nvectors); + unsigned nvectors = ( vec1.size() - 2 ) / 3; plumed_assert( (vec1.size()-2)%3==0 ); + std::vector dv1(nvectors), dv2(nvectors), tdconn(nvectors); Torsion t; std::vector v1(nvectors), v2(nvectors); std::vector> pos; - for(unsigned i=0; i() ); - pos[i]->setDomain( "-pi", "pi" ); - } + for(unsigned i=0; i() ); pos[i]->setDomain( "-pi", "pi" ); } for(unsigned j=0; jset( angle ); @@ -206,31 +187,20 @@ double SMAC::computeVectorFunction( const Vector& conn, const std::vector deriv( nvectors ), df( nvectors, 0 ); + double ans=0; std::vector deriv( nvectors ), df( nvectors, 0 ); for(unsigned i=0; i0) { switchingFunction.set(sw,errors); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } log.printf(" Steinhardt parameter of central atom and those within %s\n",( switchingFunction.description() ).c_str() ); log<<" Bibliography "< all_atoms; - setupMultiColvarBase( all_atoms ); + rcut = switchingFunction.get_dmax(); rcut2 = rcut*rcut; + std::vector all_atoms; setupMultiColvarBase( all_atoms ); } void Steinhardt::setAngularMomentum( const unsigned& ang ) { - tmom=ang; - setVectorDimensionality( 2*(2*ang + 1) ); + tmom=ang; setVectorDimensionality( 2*(2*ang + 1) ); } void Steinhardt::calculateVector( multicolvar::AtomValuePack& myatoms ) const { @@ -94,8 +76,7 @@ void Steinhardt::calculateVector( multicolvar::AtomValuePack& myatoms ) const { std::complex ii( 0.0, 1.0 ), dp_x, dp_y, dp_z; unsigned ncomp=2*tmom+1; - double sw, poly_ass, dlen; - std::complex powered; + double sw, poly_ass, dlen; std::complex powered; for(unsigned i=1; i(1.,0); // else powered = std::complex(0.,0.); // Real and imaginary parts of z - real_z = real(com1*powered); - imag_z = imag(com1*powered ); + real_z = real(com1*powered); imag_z = imag(com1*powered ); // Calculate steinhardt parameter tq6=poly_ass*real_z; // Real part of steinhardt parameter @@ -145,12 +124,8 @@ void Steinhardt::calculateVector( multicolvar::AtomValuePack& myatoms ) const { dp_z = md*powered*( -(distance[0]*distance[2])/dlen3-ii*(distance[1]*distance[2])/dlen3 ); // Derivatives of real and imaginary parts of above - real_dz[0] = real( dp_x ); - real_dz[1] = real( dp_y ); - real_dz[2] = real( dp_z ); - imag_dz[0] = imag( dp_x ); - imag_dz[1] = imag( dp_y ); - imag_dz[2] = imag( dp_z ); + real_dz[0] = real( dp_x ); real_dz[1] = real( dp_y ); real_dz[2] = real( dp_z ); + imag_dz[0] = imag( dp_x ); imag_dz[1] = imag( dp_y ); imag_dz[2] = imag( dp_z ); // Complete derivative of steinhardt parameter myrealvec = (+sw)*dpoly_ass*real_z*dz + (+dfunc)*distance*tq6 + (+sw)*poly_ass*real_dz; @@ -176,30 +151,21 @@ void Steinhardt::calculateVector( multicolvar::AtomValuePack& myatoms ) const { // Normalize updateActiveAtoms( myatoms ); - for(unsigned i=0; iderivativesAreRequired() ) { nder=getAction()->getNumberOfDerivatives(); - resizeBuffer( (1+nder)*(ncomp+1) ); - getFinalValue()->resizeDerivatives( nder ); + resizeBuffer( (1+nder)*(ncomp+1) ); getFinalValue()->resizeDerivatives( nder ); } else { - nder=0; - resizeBuffer(ncomp+1); + nder=0; resizeBuffer(ncomp+1); } } void VectorMean::calculate( const unsigned& current, MultiValue& myvals, std::vector& buffer, std::vector& der_list ) const { unsigned ncomp=getAction()->getNumberOfQuantities()-2; - double weight=myvals.get(0); - plumed_dbg_assert( weight>=getTolerance() ); + double weight=myvals.get(0); plumed_dbg_assert( weight>=getTolerance() ); buffer[bufstart] += weight; - for(unsigned i=0; iderivativesAreRequired() ) { - return; - } + for(unsigned i=0; iderivativesAreRequired() ) return; - if( diffweight ) { - myvals.chainRule( 0, 0, 1, 0, 1.0, bufstart, buffer ); - } + if( diffweight ) myvals.chainRule( 0, 0, 1, 0, 1.0, bufstart, buffer ); for(unsigned i=0; i& buffer ) { sum+=tmp*tmp; } setOutputValue( sqrt(sum) ); - if( !getAction()->derivativesAreRequired() ) { - return; - } + if( !getAction()->derivativesAreRequired() ) return; - Value* fval=getFinalValue(); - double tw = 1.0 / sqrt(sum); + Value* fval=getFinalValue(); double tw = 1.0 / sqrt(sum); for(unsigned icomp=0; icompaddDerivative( jder, (tw*tmp/ww)*( buffer[bstart + jder] - tmp*buffer[bufstart + 1 + jder] ) ); - } + for(unsigned jder=0; jderaddDerivative( jder, (tw*tmp/ww)*( buffer[bstart + jder] - tmp*buffer[bufstart + 1 + jder] ) ); } } diff --git a/src/crystallization/VectorMultiColvar.cpp b/src/crystallization/VectorMultiColvar.cpp index 692258edd4..7c016ac26c 100644 --- a/src/crystallization/VectorMultiColvar.cpp +++ b/src/crystallization/VectorMultiColvar.cpp @@ -49,13 +49,13 @@ void VectorMultiColvar::registerKeywords( Keywords& keys ) { VectorMultiColvar::VectorMultiColvar(const ActionOptions& ao): Action(ao), MultiColvarBase(ao), - store_director(true) { + store_director(true) +{ setLowMemOption(true); } void VectorMultiColvar::setVectorDimensionality( const unsigned& ncomp ) { - ncomponents = ncomp; - resizeFunctions(); // This resize needs to be here to ensure buffers are set to correct size in base + ncomponents = ncomp; resizeFunctions(); // This resize needs to be here to ensure buffers are set to correct size in base } void VectorMultiColvar::doNotCalculateDirector() { @@ -70,24 +70,17 @@ double VectorMultiColvar::compute( const unsigned& taskIndex, multicolvar::AtomV // Now calculate the norm of the vector (this is what we return here) double norm=0; - for(unsigned i=0; i dervec( ncomponents ); - for(unsigned i=0; i dervec( ncomponents ); + for(unsigned i=0; i& vals ) const { double inorm = 1.0; - if( vals[1]>epsilon ) { - inorm = 1.0 / vals[1]; - } - for(unsigned i=2; iepsilon ) inorm = 1.0 / vals[1]; + for(unsigned i=2; i& inforces ) plumed_dbg_assert( inforces.size()==getNumberOfDerivatives() ); std::vector oldforces( getNumberOfDerivatives() ); getForcesFromVessels( oldforces ); - for(unsigned i=0; iderivativesAreRequired() ) { nder=getAction()->getNumberOfDerivatives(); - resizeBuffer( (1+nder)*ncomp ); - getFinalValue()->resizeDerivatives( nder ); + resizeBuffer( (1+nder)*ncomp ); getFinalValue()->resizeDerivatives( nder ); } else { - nder=0; - resizeBuffer(ncomp); + nder=0; resizeBuffer(ncomp); } } @@ -80,19 +79,13 @@ void VectorSum::calculate( const unsigned& current, MultiValue& myvals, std::vec double weight=myvals.get(0); plumed_dbg_assert( weight>=getTolerance() ); - for(unsigned i=0; iderivativesAreRequired() ) { - return; - } + for(unsigned i=0; iderivativesAreRequired() ) return; for(unsigned i=0; i& buffer ) { } double tw = 1.0 / sqrt(sum); setOutputValue( sqrt(sum) ); - if( !getAction()->derivativesAreRequired() ) { - return; - } + if( !getAction()->derivativesAreRequired() ) return; Value* fval=getFinalValue(); for(unsigned icomp=0; icompaddDerivative( jder, tw*tmp*buffer[bstart + jder] ); - } + for(unsigned jder=0; jderaddDerivative( jder, tw*tmp*buffer[bstart + jder] ); } } diff --git a/src/dimred/ClassicalMultiDimensionalScaling.cpp b/src/dimred/ClassicalMultiDimensionalScaling.cpp index 1713b814ab..0135ae811e 100644 --- a/src/dimred/ClassicalMultiDimensionalScaling.cpp +++ b/src/dimred/ClassicalMultiDimensionalScaling.cpp @@ -174,51 +174,35 @@ void ClassicalMultiDimensionalScaling::registerKeywords( Keywords& keys ) { ClassicalMultiDimensionalScaling::ClassicalMultiDimensionalScaling( const ActionOptions& ao): Action(ao), - DimensionalityReductionBase(ao) { - if( dimredbase ) { - error("input to CLASSICAL_MDS should not be output from dimensionality reduction object"); - } + DimensionalityReductionBase(ao) +{ + if( dimredbase ) error("input to CLASSICAL_MDS should not be output from dimensionality reduction object"); } void ClassicalMultiDimensionalScaling::calculateProjections( const Matrix& targets, Matrix& projections ) { // Retrieve the distances from the dimensionality reduction object - double half=(-0.5); - Matrix distances( half*targets ); + double half=(-0.5); Matrix distances( half*targets ); // Apply centering transtion - unsigned n=distances.nrows(); - double sum; + unsigned n=distances.nrows(); double sum; // First HM for(unsigned i=0; i eigval(n); - Matrix eigvec(n,n); + std::vector eigval(n); Matrix eigvec(n,n); diagMat( distances, eigval, eigvec ); // Pass final projections to map object for(unsigned i=0; i( my_input_data ); } @@ -53,36 +52,25 @@ DimensionalityReductionBase::DimensionalityReductionBase( const ActionOptions& a log.printf(" projecting in %u dimensional space \n",nlow); } else if( keywords.exists("NLOW_DIM") ) { parse("NLOW_DIM",nlow); - if( nlow<1 ) { - error("dimensionality of low dimensional space must be at least one"); - } + if( nlow<1 ) error("dimensionality of low dimensional space must be at least one"); log.printf(" projecting in %u dimensional space \n",nlow); } // Now add fake components to the underlying ActionWithValue for the arguments std::string num; for(unsigned i=0; i DimensionalityReductionBase::getArgumentList() { std::vector arglist( analysis::AnalysisBase::getArgumentList() ); - for(unsigned i=0; i& point, double& weight ) { - if( point.size()!=nlow ) { - point.resize( nlow ); - } - weight = getWeight(idata); - for(unsigned i=0; i newp( nlow ); - double w; + std::vector newp( nlow ); double w; for(unsigned i=0; igetProjection( i, newp, w ); - plumed_dbg_assert( newp.size()==nlow ); - for(unsigned j=0; jgetProjection( i, newp, w ); plumed_dbg_assert( newp.size()==nlow ); + for(unsigned j=0; j targets( getNumberOfDataPoints(), getNumberOfDataPoints() ); - targets=0; + Matrix targets( getNumberOfDataPoints(), getNumberOfDataPoints() ); targets=0; for(unsigned i=1; i& p, std::vector& d ) { // Zero derivative and stress accumulators - for(unsigned i=0; i dtmp( p.size() ); + for(unsigned i=0; i dtmp( p.size() ); // Now accumulate total stress on system for(unsigned i=0; i& // Calculate derivatives double pref = 2.*getWeight(i) / dd; - for(unsigned j=0; j& pp, std::vector& der ); /// Overwrite virtual function in ActionWithVessel - void performTask( const unsigned&, const unsigned&, MultiValue& ) const { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const { plumed_error(); } }; inline diff --git a/src/dimred/OutputPCAProjections.cpp b/src/dimred/OutputPCAProjections.cpp index cdb267bc4e..7b8caf60b7 100644 --- a/src/dimred/OutputPCAProjections.cpp +++ b/src/dimred/OutputPCAProjections.cpp @@ -51,9 +51,7 @@ class OutputPCAProjection : public analysis::AnalysisBase { public: static void registerKeywords( Keywords& keys ); explicit OutputPCAProjection( const ActionOptions& ); - void performTask( const unsigned&, const unsigned&, MultiValue& ) const { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const { plumed_error(); } void performAnalysis(); }; @@ -69,12 +67,11 @@ void OutputPCAProjection::registerKeywords( Keywords& keys ) { OutputPCAProjection::OutputPCAProjection( const ActionOptions& ao ): Action(ao), analysis::AnalysisBase(ao), - fmt("%f") { + fmt("%f") +{ // Setup the PCA object mypca = dynamic_cast( my_input_data ); - if( !mypca ) { - error("input must be a PCA object"); - } + if( !mypca ) error("input must be a PCA object"); // Get setup the pdb mypdb.setAtomNumbers( my_input_data->getAtomIndexes() ); @@ -82,18 +79,10 @@ OutputPCAProjection::OutputPCAProjection( const ActionOptions& ao ): // Find a moldata object auto* moldat=plumed.getActionSet().selectLatest(this); - if( moldat ) { - warning("PDB output files do not have atom types unless you use MOLDATA"); - } + if( moldat ) warning("PDB output files do not have atom types unless you use MOLDATA"); - parse("FILE",filename); - parse("FMT",fmt); - if( !getRestart() ) { - OFile ofile; - ofile.link(*this); - ofile.setBackupString("analysis"); - ofile.backupAllFiles(filename); - } + parse("FILE",filename); parse("FMT",fmt); + if( !getRestart() ) { OFile ofile; ofile.link(*this); ofile.setBackupString("analysis"); ofile.backupAllFiles(filename); } log.printf(" printing data to file named %s \n",filename.c_str() ); } @@ -101,33 +90,20 @@ void OutputPCAProjection::performAnalysis() { // Find a moldata object auto* mymoldat=plumed.getActionSet().selectLatest(this); // Output the embedding in plumed pdb format - OFile afile; - afile.link(*this); - afile.setBackupString("analysis"); + OFile afile; afile.link(*this); afile.setBackupString("analysis"); mypdb.setAtomPositions( (mypca->myref)->getReferencePositions() ); - for(unsigned j=0; jgetArguments().size(); ++j) { - mypdb.setArgumentValue( (mypca->getArguments()[j])->getName(), (mypca->myref)->getReferenceArgument(j) ); - } + for(unsigned j=0; jgetArguments().size(); ++j) mypdb.setArgumentValue( (mypca->getArguments()[j])->getName(), (mypca->myref)->getReferenceArgument(j) ); // And output the first frame - afile.open( filename ); - afile.printf("REMARK TYPE=%s \n", mypca->mtype.c_str() ); - if( plumed.getAtoms().usingNaturalUnits() ) { - mypdb.print( 1.0, mymoldat, afile, fmt ); - } else { - mypdb.print( atoms.getUnits().getLength()/0.1, mymoldat, afile, fmt ); - } + afile.open( filename ); afile.printf("REMARK TYPE=%s \n", mypca->mtype.c_str() ); + if( plumed.getAtoms().usingNaturalUnits() ) mypdb.print( 1.0, mymoldat, afile, fmt ); + else mypdb.print( atoms.getUnits().getLength()/0.1, mymoldat, afile, fmt ); // And now output the eigenvectors for(unsigned dim=0; dimnlow; ++dim) { afile.printf("REMARK TYPE=DIRECTION \n"); mypdb.setAtomPositions( mypca->directions[dim].getReferencePositions() ); - for(unsigned j=0; jgetArguments().size(); ++j) { - mypdb.setArgumentValue( (mypca->getArguments()[j])->getName(), mypca->directions[dim].getReferenceArgument(j) ); - } - if( plumed.getAtoms().usingNaturalUnits() ) { - mypdb.print( 1.0, mymoldat, afile, fmt ); - } else { - mypdb.print( atoms.getUnits().getLength()/0.1, mymoldat, afile, fmt ); - } + for(unsigned j=0; jgetArguments().size(); ++j) mypdb.setArgumentValue( (mypca->getArguments()[j])->getName(), mypca->directions[dim].getReferenceArgument(j) ); + if( plumed.getAtoms().usingNaturalUnits() ) mypdb.print( 1.0, mymoldat, afile, fmt ); + else mypdb.print( atoms.getUnits().getLength()/0.1, mymoldat, afile, fmt ); } afile.close(); } diff --git a/src/dimred/PCA.cpp b/src/dimred/PCA.cpp index 1e9750f80d..d7bcf24191 100644 --- a/src/dimred/PCA.cpp +++ b/src/dimred/PCA.cpp @@ -100,23 +100,19 @@ namespace dimred { PLUMED_REGISTER_ACTION(PCA,"PCA") void PCA::registerKeywords( Keywords& keys ) { - DimensionalityReductionBase::registerKeywords( keys ); - keys.use("ARG"); - keys.reset_style("ARG","optional"); + DimensionalityReductionBase::registerKeywords( keys ); keys.use("ARG"); keys.reset_style("ARG","optional"); keys.add("compulsory","METRIC","EUCLIDEAN","the method that you are going to use to measure the distances between points"); keys.add("atoms","ATOMS","the list of atoms that you are going to use in the measure of distance that you are using"); } PCA::PCA(const ActionOptions&ao): Action(ao), - DimensionalityReductionBase(ao) { + DimensionalityReductionBase(ao) +{ // Get the input PDB file from the underlying ReadAnalysisFrames object analysis::ReadAnalysisFrames* myframes = dynamic_cast( my_input_data ); - if( !myframes ) { - error("input to PCA should be ReadAnalysisFrames object"); - } - parse("METRIC",mtype); - std::vector atoms; + if( !myframes ) error("input to PCA should be ReadAnalysisFrames object"); + parse("METRIC",mtype); std::vector atoms; log.printf(" performing PCA analysis using %s metric \n", mtype.c_str() ); if( my_input_data->getNumberOfAtoms()>0 ) { parseAtomList("ATOMS",atoms); @@ -125,14 +121,10 @@ PCA::PCA(const ActionOptions&ao): for(unsigned i=0; igetAtomIndexes().size(); ++j) { - if( my_input_data->getAtomIndexes()[j]==atoms[i] ) { - found=true; - break; - } + if( my_input_data->getAtomIndexes()[j]==atoms[i] ) { found=true; break; } } if( !found ) { - std::string num; - Tools::convert( atoms[i].serial(), num ); + std::string num; Tools::convert( atoms[i].serial(), num ); error("atom number " + num + " is not stored in any action that has been input"); } } @@ -140,16 +132,13 @@ PCA::PCA(const ActionOptions&ao): } else if( getNumberOfArguments()==0 ) { mypdb.setAtomNumbers( my_input_data->getAtomIndexes() ); mypdb.addBlockEnd( my_input_data->getAtomIndexes().size() ); - if( mtype=="EUCLIDEAN" ) { - mtype="OPTIMAL"; - } + if( mtype=="EUCLIDEAN" ) mtype="OPTIMAL"; } } if( my_input_data->getArgumentNames().size()>0 ) { if( getNumberOfArguments()==0 && atoms.size()==0 ) { std::vector argnames( my_input_data->getArgumentNames() ); - mypdb.setArgumentNames( argnames ); - requestArguments( my_input_data->getArgumentList() ); + mypdb.setArgumentNames( argnames ); requestArguments( my_input_data->getArgumentList() ); } else { std::vector myargs( getArguments() ); std::vector inargnames( my_input_data->getArgumentNames() ); @@ -158,22 +147,14 @@ PCA::PCA(const ActionOptions&ao): argnames[i]=myargs[i]->getName(); bool found=false; for(unsigned j=0; jgetLabel() + " does not store/calculate quantity named " + argnames[i] ); + if( argnames[i]==inargnames[j] ) { found=true; break; } } + if( !found ) error("input named " + my_input_data->getLabel() + " does not store/calculate quantity named " + argnames[i] ); } - mypdb.setArgumentNames( argnames ); - requestArguments( myargs ); + mypdb.setArgumentNames( argnames ); requestArguments( myargs ); } } - if( nlow==0 ) { - error("dimensionality of output not set"); - } + if( nlow==0 ) error("dimensionality of output not set"); checkRead(); } @@ -183,9 +164,7 @@ void PCA::performAnalysis() { auto myconf0=metricRegister().create(mtype, mypdb); MultiValue myval( 1, myconf0->getNumberOfReferenceArguments() + 3*myconf0->getNumberOfReferencePositions() + 9 ); ReferenceValuePack mypack( myconf0->getNumberOfReferenceArguments(), myconf0->getNumberOfReferencePositions(), myval ); - for(unsigned i=0; igetNumberOfReferencePositions(); ++i) { - mypack.setAtomIndex( i, i ); - } + for(unsigned i=0; igetNumberOfReferencePositions(); ++i) mypack.setAtomIndex( i, i ); // Setup some PCA storage myconf0->setupPCAStorage ( mypack ); std::vector displace( myconf0->getNumberOfReferencePositions() ); @@ -197,46 +176,30 @@ void PCA::performAnalysis() { // Create some arrays to store the average position std::vector sarg( myconf0->getNumberOfReferenceArguments(), 0 ); std::vector spos( myconf0->getNumberOfReferencePositions() ); - for(unsigned i=0; igetNumberOfReferencePositions(); ++i) { - spos[i].zero(); - } + for(unsigned i=0; igetNumberOfReferencePositions(); ++i) spos[i].zero(); // Calculate the average displacement from the first frame - double norm=getWeight(0); - std::vector args( getNumberOfArguments() ); + double norm=getWeight(0); std::vector args( getNumberOfArguments() ); for(unsigned i=1; igetStoredData( i, false ).transferDataToPDB( mypdb ); - for(unsigned j=0; jgetName(), args[j] ); - } + for(unsigned j=0; jgetName(), args[j] ); myconf0->calc( mypdb.getPositions(), getPbc(), getArguments(), args, mypack, true ); // Accumulate average displacement of arguments (Here PBC could do fucked up things - really needs Berry Phase ) GAT - for(unsigned j=0; jgetNumberOfReferenceArguments(); ++j) { - sarg[j] += 0.5*getWeight(i)*mypack.getArgumentDerivative(j); - } + for(unsigned j=0; jgetNumberOfReferenceArguments(); ++j) sarg[j] += 0.5*getWeight(i)*mypack.getArgumentDerivative(j); // Accumulate average displacement of position - for(unsigned j=0; jgetNumberOfReferencePositions(); ++j) { - spos[j] += getWeight(i)*mypack.getAtomsDisplacementVector()[j] / displace[j]; - } + for(unsigned j=0; jgetNumberOfReferencePositions(); ++j) spos[j] += getWeight(i)*mypack.getAtomsDisplacementVector()[j] / displace[j]; norm += getWeight(i); } // Now normalise the displacements to get the average and add these to the first frame double inorm = 1.0 / norm ; - for(unsigned j=0; jgetNumberOfReferenceArguments(); ++j) { - sarg[j] = inorm*sarg[j] + myconf0->getReferenceArguments()[j]; - } - for(unsigned j=0; jgetNumberOfReferencePositions(); ++j) { - spos[j] = inorm*spos[j] + myconf0->getReferencePositions()[j]; - } + for(unsigned j=0; jgetNumberOfReferenceArguments(); ++j) sarg[j] = inorm*sarg[j] + myconf0->getReferenceArguments()[j]; + for(unsigned j=0; jgetNumberOfReferencePositions(); ++j) spos[j] = inorm*spos[j] + myconf0->getReferencePositions()[j]; // Now accumulate the covariance unsigned narg=myconf0->getNumberOfReferenceArguments(), natoms=myconf0->getNumberOfReferencePositions(); - Matrix covar( narg+3*natoms, narg+3*natoms ); - covar=0; + Matrix covar( narg+3*natoms, narg+3*natoms ); covar=0; for(unsigned i=0; igetStoredData( i, false ).transferDataToPDB( mypdb ); - for(unsigned j=0; jgetName(), args[j] ); - } + for(unsigned j=0; jgetName(), args[j] ); myconf0->calc( mypdb.getPositions(), getPbc(), getArguments(), args, mypack, true ); for(unsigned jarg=0; jarggetName(), sarg[j] ); - } + for(unsigned j=0; jgetName(), sarg[j] ); // Reset the reference configuration myref = metricRegister().create( mtype, mypdb ); @@ -283,13 +242,9 @@ void PCA::performAnalysis() { std::vector tmp_atoms( natoms ); for(unsigned dim=0; dimgetName(), eigvec(idim,i) ); - } + for(unsigned i=0; igetName(), eigvec(idim,i) ); for(unsigned i=0; i& point, double& weight ) { - if( point.size()!=nlow ) { - point.resize( nlow ); - } + if( point.size()!=nlow ) point.resize( nlow ); // Retrieve the weight weight = getWeight(idata); // Retrieve the data point @@ -309,23 +262,16 @@ void PCA::getProjection( const unsigned& idata, std::vector& point, doub } void PCA::getProjection( analysis::DataCollectionObject& myidata, std::vector& point ) { - myidata.transferDataToPDB( mypdb ); - std::vector args( getArguments().size() ); - for(unsigned j=0; jgetName(), args[j] ); - } + myidata.transferDataToPDB( mypdb ); std::vector args( getArguments().size() ); + for(unsigned j=0; jgetName(), args[j] ); // Create some storage space MultiValue myval( 1, 3*mypdb.getPositions().size() + args.size() + 9); ReferenceValuePack mypack( args.size(), mypdb.getPositions().size(), myval ); - for(unsigned i=0; isetupPCAStorage( mypack ); // And calculate myref->calculate( mypdb.getPositions(), getPbc(), getArguments(), mypack, true ); - for(unsigned i=0; iprojectDisplacementOnVector( directions[i], getArguments(), args, mypack ); - } + for(unsigned i=0; iprojectDisplacementOnVector( directions[i], getArguments(), args, mypack ); } } diff --git a/src/dimred/PCA.h b/src/dimred/PCA.h index c232848c5b..cba38049a3 100644 --- a/src/dimred/PCA.h +++ b/src/dimred/PCA.h @@ -48,15 +48,9 @@ class PCA : public DimensionalityReductionBase { void performAnalysis() override; void getProjection( const unsigned& idata, std::vector& point, double& weight ) override; void getProjection( analysis::DataCollectionObject& myidata, std::vector& point ); - void calculateProjections( const Matrix&, Matrix& ) override { - plumed_error(); - } - void setTargetDistance( const unsigned&, const double& ) override { - plumed_error(); - } - double calculateStress( const std::vector& pp, std::vector& der ) override { - plumed_error(); - } + void calculateProjections( const Matrix&, Matrix& ) override { plumed_error(); } + void setTargetDistance( const unsigned&, const double& ) override { plumed_error(); } + double calculateStress( const std::vector& pp, std::vector& der ) override { plumed_error(); } }; } diff --git a/src/dimred/ProjectNonLandmarkPoints.cpp b/src/dimred/ProjectNonLandmarkPoints.cpp index a17eb66768..4c71fa42a3 100644 --- a/src/dimred/ProjectNonLandmarkPoints.cpp +++ b/src/dimred/ProjectNonLandmarkPoints.cpp @@ -63,9 +63,7 @@ class ProjectNonLandmarkPoints : public analysis::AnalysisBase { /// This just calls calculate stress in the underlying projection object double calculateStress( const std::vector& pp, std::vector& der ); /// Overwrite virtual function in ActionWithVessel - void performTask( const unsigned&, const unsigned&, MultiValue& ) const { - plumed_error(); - } + void performTask( const unsigned&, const unsigned&, MultiValue& ) const { plumed_error(); } }; PLUMED_REGISTER_ACTION(ProjectNonLandmarkPoints,"PROJECT_ALL_ANALYSIS_DATA") @@ -80,22 +78,17 @@ void ProjectNonLandmarkPoints::registerKeywords( Keywords& keys ) { ProjectNonLandmarkPoints::ProjectNonLandmarkPoints( const ActionOptions& ao ): Action(ao), analysis::AnalysisBase(ao), - mybase(NULL) { - std::string myproj; - parse("PROJECTION",myproj); + mybase(NULL) +{ + std::string myproj; parse("PROJECTION",myproj); mybase = plumed.getActionSet().selectWithLabel( myproj ); - if( !mybase ) { - error("could not find projection of data named " + myproj ); - } + if( !mybase ) error("could not find projection of data named " + myproj ); // Add the dependency and set the dimensionality - addDependency( mybase ); - nlow = mybase->nlow; + addDependency( mybase ); nlow = mybase->nlow; // Add fake components to the underlying ActionWithValue for the arguments std::string num; for(unsigned i=0; i ProjectNonLandmarkPoints::getArgumentList() { std::vector arglist( analysis::AnalysisBase::getArgumentList() ); - for(unsigned i=0; igetProjection( my_input_data->getStoredData(idat,false), point ); } else { ConjugateGradient myminimiser( this ); - unsigned closest=0; - double mindist = std::sqrt( getDissimilarity( mybase->getDataPointIndexInBase(0), idat ) ); + unsigned closest=0; double mindist = std::sqrt( getDissimilarity( mybase->getDataPointIndexInBase(0), idat ) ); mybase->setTargetDistance( 0, mindist ); for(unsigned i=1; igetNumberOfDataPoints(); ++i) { double dist = std::sqrt( getDissimilarity( mybase->getDataPointIndexInBase(i), idat ) ); mybase->setTargetDistance( i, dist ); - if( distprojections(closest,j) + (random.RandU01() - 0.5)*0.01; - } + Random random; random.setSeed(-1234); + for(unsigned j=0; jprojections(closest,j) + (random.RandU01() - 0.5)*0.01; myminimiser.minimise( cgtol, point, &ProjectNonLandmarkPoints::calculateStress ); } } analysis::DataCollectionObject& ProjectNonLandmarkPoints::getStoredData( const unsigned& idat, const bool& calcdist ) { - std::vector pp(nlow); - generateProjection( idat, pp ); - std::string num; + std::vector pp(nlow); generateProjection( idat, pp ); std::string num; analysis::DataCollectionObject& myref=AnalysisBase::getStoredData(idat,calcdist); - for(unsigned i=0; i& Weights, const Matrix& Distances unsigned M = Distances.nrows(); // Calculate V - Matrix V(M,M); - double totalWeight=0.; + Matrix V(M,M); double totalWeight=0.; for(unsigned i=0; i mypseudo(M, M); - pseudoInvert(V, mypseudo); - Matrix dists( M, M ); - double myfirstsig = calculateSigma( Weights, Distances, InitialZ, dists ) / totalWeight; + Matrix mypseudo(M, M); pseudoInvert(V, mypseudo); + Matrix dists( M, M ); double myfirstsig = calculateSigma( Weights, Distances, InitialZ, dists ) / totalWeight; // initial sigma is made up of the original distances minus the distances between the projections all squared. Matrix temp( M, M ), BZ( M, M ), newZ( M, InitialZ.ncols() ); for(unsigned n=0; n0 ) { - BZ(i,j) = -Weights(i,j)*Distances(i,j) / dists(i,j); - } else { - BZ(i,j)=0.; - } + if( dists(i,j)>0 ) BZ(i,j) = -Weights(i,j)*Distances(i,j) / dists(i,j); + else BZ(i,j)=0.; } //the diagonal elements are -off diagonal elements BZ(i,i)-=BZ(i,j) (Equation 8.25) BZ(i,i)=0; //create the space memory for the diagonal elements which are scalars for(unsigned j=0; j& Weights, const Matrix& Distances, const Matrix& InitialZ, Matrix& dists ) { - unsigned M = Distances.nrows(); - double sigma=0; + unsigned M = Distances.nrows(); double sigma=0; for(unsigned i=1; i1 ) { - double smear; - parse("ANNEAL_RATE", smear); - double old_mix = 1.0; - double new_mix = old_mix*smear; + double smear; parse("ANNEAL_RATE", smear); double old_mix = 1.0; double new_mix = old_mix*smear; for(unsigned i=0; i( dimredbase ); - } + if( dimredbase ) smapbase = dynamic_cast( dimredbase ); // Read in the switching functions std::string linput,hinput, errors; parse("HIGH_DIM_FUNCTION",hinput); if( hinput=="as in input action" ) { - if( !smapbase ) { - error("high dimensional switching function has not been set - use HIGH_DIM_FUNCTION"); - } + if( !smapbase ) error("high dimensional switching function has not been set - use HIGH_DIM_FUNCTION"); reuse_hd=true; log.printf(" reusing high dimensional filter function defined in previous sketch-map action\n"); } else { reuse_hd=false; highdf.set(hinput,errors); - if(errors.length()>0) { - error(errors); - } + if(errors.length()>0) error(errors); log.printf(" filter function for dissimilarities in high dimensional space has cutoff %s \n",highdf.description().c_str() ); } parse("LOW_DIM_FUNCTION",linput); if( linput=="as in input action" ) { - if( !smapbase ) { - error("low dimensional switching function has not been set - use LOW_DIM_FUNCTION"); - } + if( !smapbase ) error("low dimensional switching function has not been set - use LOW_DIM_FUNCTION"); reuse_ld=true; log.printf(" reusing low dimensional filter function defined in previous sketch-map action\n"); } else { reuse_ld=false; lowdf.set(linput,errors); - if(errors.length()>0) { - error(errors); - } + if(errors.length()>0) error(errors); log.printf(" filter function for distances in low dimensionality space has cutoff %s \n",lowdf.description().c_str() ); } // Read the mixing parameter parse("MIXPARAM",mixparam); - if( mixparam<0 || mixparam>1 ) { - error("mixing parameter must be between 0 and 1"); - } + if( mixparam<0 || mixparam>1 ) error("mixing parameter must be between 0 and 1"); log.printf(" mixing %f of pure distances with %f of filtered distances \n",mixparam,1.-mixparam); } void SketchMapBase::calculateProjections( const Matrix& targets, Matrix& projections ) { if( dtargets.size()!=targets.nrows() ) { // These hold data so that we can do stress calculations - dtargets.resize( targets.nrows() ); - ftargets.resize( targets.nrows() ); - pweights.resize( targets.nrows() ); + dtargets.resize( targets.nrows() ); ftargets.resize( targets.nrows() ); pweights.resize( targets.nrows() ); // Matrices for storing input data transformed.resize( targets.nrows(), targets.ncols() ); distances.resize( targets.nrows(), targets.ncols() ); @@ -97,16 +84,11 @@ void SketchMapBase::calculateProjections( const Matrix& targets, Matrix< // Stores the weights in an array for faster access, as well as the normalization normw=0; - for(unsigned i=0; i& targets, Matrix< double SketchMapBase::calculateStress( const std::vector& p, std::vector& d ) { // Zero derivative and stress accumulators - for(unsigned i=0; i dtmp( p.size() ); + for(unsigned i=0; i dtmp( p.size() ); // Now accumulate total stress on system for(unsigned i=0; i& p, std::vector // Calculate derivatives double pref = 2.*getWeight(i) / dd ; - for(unsigned j=0; j& p, std::vector double SketchMapBase::calculateFullStress( const std::vector& p, std::vector& d ) { // Zero derivative and stress accumulators - for(unsigned i=0; i dtmp( nlow ); + for(unsigned i=0; i dtmp( nlow ); for(unsigned i=1; i& p, std::ve double jweight = pweights[j]; // Calculate distance in low dimensional space double dd=0; - for(unsigned k=0; k& p, std::ve // Calculate derivatives double pref = 2.*iweight*jweight*( (1-mixparam)*fdiff*df + mixparam*ddiff ) / dd; for(unsigned k=0; ktransformLowDimensionalDistance( val, df ); - } - double ans=1.0 - lowdf.calculate( val, df ); - df*=-val; - return ans; + if( reuse_ld ) return smapbase->transformLowDimensionalDistance( val, df ); + double ans=1.0 - lowdf.calculate( val, df ); df*=-val; return ans; } inline double SketchMapBase::transformHighDimensionalDistance( const double& val, double& df ) const { - if( reuse_hd ) { - return smapbase->transformHighDimensionalDistance( val, df ); - } - double ans=1.0 - highdf.calculate( val, df ); - df*=-val; - return ans; + if( reuse_hd ) return smapbase->transformHighDimensionalDistance( val, df ); + double ans=1.0 - highdf.calculate( val, df ); df*=-val; return ans; } inline void SketchMapBase::setTargetDistance( const unsigned& idata, const double& dist ) { - double df; - dtargets[idata]=dist; - ftargets[idata]=transformHighDimensionalDistance( dist, df ); + double df; dtargets[idata]=dist; ftargets[idata]=transformHighDimensionalDistance( dist, df ); } } diff --git a/src/dimred/SketchMapConjGrad.cpp b/src/dimred/SketchMapConjGrad.cpp index 65192612ca..b336e49f1a 100644 --- a/src/dimred/SketchMapConjGrad.cpp +++ b/src/dimred/SketchMapConjGrad.cpp @@ -53,7 +53,8 @@ void SketchMapConjGrad::registerKeywords( Keywords& keys ) { SketchMapConjGrad::SketchMapConjGrad( const ActionOptions& ao ): Action(ao), - SketchMapBase(ao) { + SketchMapBase(ao) +{ parse("CGTOL",cgtol); log.printf(" tolerance for conjugate gradient algorithm equals %f \n",cgtol); } diff --git a/src/dimred/SketchMapPointwise.cpp b/src/dimred/SketchMapPointwise.cpp index 4bd1777741..3cc80639d2 100644 --- a/src/dimred/SketchMapPointwise.cpp +++ b/src/dimred/SketchMapPointwise.cpp @@ -62,31 +62,22 @@ SketchMapPointwise::SketchMapPointwise( const ActionOptions& ao ): Action(ao), SketchMapBase(ao), npoints(nlow), - nfgrid(nlow) { - parseVector("CGRID_SIZE",npoints); - parse("BUFFER",gbuf); - if( npoints.size()!=nlow ) { - error("vector giving number of grid point in each direction has wrong size"); - } - parse("NCYCLES",ncycles); - parse("CGTOL",cgtol); + nfgrid(nlow) +{ + parseVector("CGRID_SIZE",npoints); parse("BUFFER",gbuf); + if( npoints.size()!=nlow ) error("vector giving number of grid point in each direction has wrong size"); + parse("NCYCLES",ncycles); parse("CGTOL",cgtol); parseVector("FGRID_SIZE",nfgrid); - if( nfgrid[0]!=0 && nlow!=2 ) { - error("interpolation only works in two dimensions"); - } + if( nfgrid[0]!=0 && nlow!=2 ) error("interpolation only works in two dimensions"); log.printf(" doing %u cycles of global optimization sweeps\n",ncycles); log.printf(" using coarse grid of points that is %u",npoints[0]); log.printf(" and that is %f larger than the difference between the position of the minimum and maximum projection \n",gbuf); - for(unsigned j=1; j0 ) { log.printf(" interpolating stress onto grid of points that is %u",nfgrid[0]); - for(unsigned j=1; j& projections ) { std::vector gmin( nlow ), gmax( nlow ), mypoint( nlow ); // Find the extent of the grid - for(unsigned j=0; j gmax[j] ) { - gmax[j] = projections(i,j); - } + if( projections(i,j) < gmin[j] ) gmin[j] = projections(i,j); + if( projections(i,j) > gmax[j] ) gmax[j] = projections(i,j); } } for(unsigned j=0; j& projections ) { for(unsigned i=0; i propnames; - parseVector("PROPERTY",propnames); - if(propnames.size()==0) { - error("no properties were specified"); - } + SketchMapBase(ao) +{ + std::vector propnames; parseVector("PROPERTY",propnames); + if(propnames.size()==0) error("no properties were specified"); nlow=propnames.size(); for(unsigned i=0; i >( propnames[i], std::vector() ) ); } log.printf(" mapped properties are %s ",propnames[0].c_str() ); - for(unsigned i=1; ifopen(ifilename.c_str(),"r"); - if(!fp) { - error("could not open reference file " + ifilename ); - } + if(!fp) error("could not open reference file " + ifilename ); // call fclose when fp goes out of scope - auto deleter=[this](FILE* f) { - this->fclose(f); - }; + auto deleter=[this](FILE* f) { this->fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); // Read in the embedding - bool do_read=true; - double val, ww, wnorm=0, prop; - unsigned nfram=0; + bool do_read=true; double val, ww, wnorm=0, prop; unsigned nfram=0; while (do_read) { PDB inpdb; // Read the pdb file do_read=inpdb.readFromFilepointer(fp,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()); // Break if we are done - if( !do_read ) { - break ; - } + if( !do_read ) break ; // Check for required properties for(std::map >::iterator it=property.begin(); it!=property.end(); ++it) { - if( !inpdb.getArgumentValue( it->first, prop ) ) { - error("pdb input does not have contain property named " + it->first ); - } + if( !inpdb.getArgumentValue( it->first, prop ) ) error("pdb input does not have contain property named " + it->first ); it->second.push_back(prop); } // And read the frame ( create a measure ) myframes.emplace_back( metricRegister().create( mtype, inpdb ) ); - if( !inpdb.getArgumentValue( "WEIGHT", ww ) ) { - error("could not find weights in input pdb"); - } - weights.push_back( ww ); - wnorm += ww; - nfram++; + if( !inpdb.getArgumentValue( "WEIGHT", ww ) ) error("could not find weights in input pdb"); + weights.push_back( ww ); wnorm += ww; nfram++; // And create a data collection object - analysis::DataCollectionObject new_data; - new_data.setAtomNumbersAndArgumentNames( getLabel(), inpdb.getAtomNumbers(), inpdb.getArgumentNames() ); + analysis::DataCollectionObject new_data; new_data.setAtomNumbersAndArgumentNames( getLabel(), inpdb.getAtomNumbers(), inpdb.getArgumentNames() ); new_data.setAtomPositions( inpdb.getPositions() ); for(unsigned i=0; i atoms; - std::vector args; - for(unsigned i=0; igetAtomRequests( atoms, skipchecks ); - myframes[i]->getArgumentRequests( args, skipchecks ); - } - requestAtoms( atoms ); - std::vector req_args; - std::vector fargs; + std::vector atoms; std::vector args; + for(unsigned i=0; igetAtomRequests( atoms, skipchecks ); myframes[i]->getArgumentRequests( args, skipchecks ); } + requestAtoms( atoms ); std::vector req_args; std::vector fargs; for(unsigned i=0; i >::iterator it=property.begin(); it!=property.end(); ++it) { - if( args[i]==it->first ) { - found=true; - break; - } - } - if( !found ) { - fargs.push_back( args[i] ); + if( args[i]==it->first ) { found=true; break; } } + if( !found ) { fargs.push_back( args[i] ); } } - interpretArgumentList( fargs, req_args ); - mypdb.setArgumentNames( fargs ); - requestArguments( req_args ); + interpretArgumentList( fargs, req_args ); mypdb.setArgumentNames( fargs ); requestArguments( req_args ); - if(nfram==0 ) { - error("no reference configurations were specified"); - } + if(nfram==0 ) error("no reference configurations were specified"); log.printf(" found %u configurations in file %s\n",nfram,ifilename.c_str() ); } void SketchMapRead::minimise( Matrix& projections ) { unsigned j=0; for(std::map >::iterator it=property.begin(); it!=property.end(); ++it) { - for(unsigned i=0; isecond[i]; - } + for(unsigned i=0; isecond[i]; j++; } } @@ -217,9 +169,7 @@ unsigned SketchMapRead::getDataPointIndexInBase( const unsigned& idata ) const { std::vector SketchMapRead::getArgumentList() { std::vector arglist( ActionWithArguments::getArguments() ); - for(unsigned i=0; i& projections ) { - Matrix weights( distances.nrows(), distances.ncols() ); - weights=0.; + Matrix weights( distances.nrows(), distances.ncols() ); weights=0.; double filt = recalculateWeights( projections, weights ); for(unsigned i=0; i& projections ) { // Recalculate weights matrix and sigma double newsig = recalculateWeights( projections, weights ); // Test whether or not the algorithm has converged - if( std::fabs( newsig - filt )& projections, Matrix& weights ) { - double filt=0, totalWeight=0.;; - double dr; + double filt=0, totalWeight=0.;; double dr; for(unsigned i=1; i& projections, M double filter=transformed(i,j)-fij; double diff=distances(i,j) - dij; - if( std::fabs(diff) max) { + if (x < min || x > max) return false; - } else { + else return true; - } } bool DRRAxis::isRealPeriodic() const { @@ -80,16 +79,13 @@ void DRRForceGrid::fillTable(const vector> &in) { table.resize(ndims, vector(sampleSize, 0)); for (size_t i = 0; i < ndims; ++i) { size_t repeatAll = 1, repeatOne = 1; - for (size_t j = i + 1; j < ndims; ++j) { + for (size_t j = i + 1; j < ndims; ++j) repeatOne *= in[j].size(); - } - for (size_t j = 0; j < i; ++j) { + for (size_t j = 0; j < i; ++j) repeatAll *= in[j].size(); - } size_t in_i_sz = in[i].size(); - for (size_t l = 0; l < in_i_sz; ++l) { + for (size_t l = 0; l < in_i_sz; ++l) std::fill_n(begin(table[i]) + l * repeatOne, repeatOne, in[i][l]); - } for (size_t k = 0; k < repeatAll - 1; ++k) std::copy_n(begin(table[i]), repeatOne * in_i_sz, begin(table[i]) + repeatOne * in_i_sz * (k + 1)); @@ -119,16 +115,14 @@ DRRForceGrid::DRRForceGrid(const vector &p_dimensions, ss.precision(std::numeric_limits::max_digits10); ss << std::fixed << "# " << dimensions[i].min << ' ' << dimensions[i].binWidth << ' ' << dimensions[i].nbins; - if (dimensions[i].isPeriodic()) { + if (dimensions[i].isPeriodic()) ss << " 1" << '\n'; - } else { + else ss << " 0" << '\n'; - } } headers = ss.str(); - if (initializeTable) { + if (initializeTable) fillTable(mp); - } forces.resize(sampleSize * ndims, 0.0); samples.resize(sampleSize, 0); outputunit = 1.0; @@ -147,9 +141,8 @@ DRRForceGrid::DRRForceGrid(const vector &p_dimensions, bool DRRForceGrid::isInBoundary(const vector &pos) const { bool result = true; for (size_t i = 0; i < ndims; ++i) { - if (pos[i] < dimensions[i].min || pos[i] > dimensions[i].max) { + if (pos[i] < dimensions[i].min || pos[i] > dimensions[i].max) return false; - } } return result; } @@ -165,9 +158,8 @@ size_t DRRForceGrid::sampleAddress(const vector &pos) const { bool DRRForceGrid::store(const vector &pos, const vector &f, unsigned long int nsamples) { if (isInBoundary(pos)) { - if (nsamples == 0) { + if (nsamples == 0) return true; - } const size_t baseaddr = sampleAddress(pos); samples[baseaddr] += nsamples; auto it_fa = begin(forces) + baseaddr * ndims; @@ -188,9 +180,8 @@ vector DRRForceGrid::merge(const vector &dA, vector DRRForceGrid::getAccumulatedForces(const vector &pos) const { vector result(ndims, 0); - if (!isInBoundary(pos)) { + if (!isInBoundary(pos)) return result; - } const size_t force_addr = sampleAddress(pos) * ndims; std::copy(begin(forces) + force_addr, begin(forces) + force_addr + ndims, begin(result)); @@ -217,14 +208,11 @@ vector DRRForceGrid::getGradient(const vector &pos, } const size_t baseaddr = sampleAddress(pos); const unsigned long int &count = samples[baseaddr]; - if (count == 0) { + if (count == 0) return result; - } auto it_fa = begin(forces) + baseaddr * ndims; std::transform(it_fa, it_fa + ndims, begin(result), - [&count](double fa) { - return (-1.0) * fa / count; - }); + [&count](double fa) { return (-1.0) * fa / count; }); return result; } @@ -489,9 +477,8 @@ vector CZAR::getGradient(const vector &pos, const size_t baseaddr = sampleAddress(pos); const vector log_deriv(getCountsLogDerivative(pos)); const unsigned long int &count = samples[baseaddr]; - if (count == 0) { + if (count == 0) return result; - } auto it_fa = begin(forces) + baseaddr * ndims; std::transform(it_fa, it_fa + ndims, begin(log_deriv), begin(result), [&count, this](double fa, double ld) { diff --git a/src/drr/DRR.h b/src/drr/DRR.h index 6c789f1ad0..6db4de7c4b 100644 --- a/src/drr/DRR.h +++ b/src/drr/DRR.h @@ -84,29 +84,15 @@ class DRRAxis { periodic = true; } /// Getters - double getMin() const { - return this->min; - } - double getMax() const { - return this->max; - } - double getWidth() const { - return binWidth; - } - double getDomainMax() const { - return this->domainMax; - } - double getDomainMin() const { - return this->domainMin; - } - size_t getBins() const { - return this->nbins; - } + double getMin() const { return this->min; } + double getMax() const { return this->max; } + double getWidth() const { return binWidth; } + double getDomainMax() const { return this->domainMax; } + double getDomainMin() const { return this->domainMin; } + size_t getBins() const { return this->nbins; } /// Check periodicity - bool isPeriodic() const { - return this->periodic; - } + bool isPeriodic() const { return this->periodic; } /// Check real periodicity, i.e. the maximum == the domain maximum bool isRealPeriodic() const; @@ -212,13 +198,9 @@ class DRRForceGrid { static vector merge(const vector &dA, const vector &dB); /// Get suffix - string getSuffix() const { - return suffix; - } + string getSuffix() const { return suffix; } /// Set unit for .grad output - void setOutputUnit(double unit) { - outputunit = unit; - } + void setOutputUnit(double unit) { outputunit = unit; } /// Destructor virtual ~DRRForceGrid() {} @@ -284,11 +266,10 @@ class DRRForceGrid { ss.precision(std::numeric_limits::max_digits10); ss << std::fixed << "# " << dimensions[i].min << ' ' << dimensions[i].binWidth << ' ' << dimensions[i].nbins; - if (dimensions[i].isPeriodic()) { + if (dimensions[i].isPeriodic()) ss << " 1" << '\n'; - } else { + else ss << " 0" << '\n'; - } } fillTable(mp); headers = ss.str(); @@ -355,12 +336,8 @@ class CZAR : public DRRForceGrid { : DRRForceGrid(p_dimensions, p_suffix, initializeTable), kbt(p_kbt) {} vector getGradient(const vector &pos, bool SkipCheck = false) const; - double getkbt() const { - return kbt; - } - void setkbt(double p_kbt) { - kbt = p_kbt; - } + double getkbt() const { return kbt; } + void setkbt(double p_kbt) { kbt = p_kbt; } static CZAR mergewindow(const CZAR &cWA, const CZAR &cWB); void writeZCountZGrad(const string &filename, bool addition = false) const; ~CZAR() {} diff --git a/src/drr/DynamicReferenceRestraining.cpp b/src/drr/DynamicReferenceRestraining.cpp index 7f39752813..7a500964c3 100644 --- a/src/drr/DynamicReferenceRestraining.cpp +++ b/src/drr/DynamicReferenceRestraining.cpp @@ -357,7 +357,8 @@ DynamicReferenceRestraining::DynamicReferenceRestraining( useCZARestimator(true), useUIestimator(false), mergeHistoryFiles(false), textoutput(false), withExternalForce(false), withExternalFict(false), reflectingWall(getNumberOfArguments(), 0), - maxFactors(getNumberOfArguments(), 1.0) { + maxFactors(getNumberOfArguments(), 1.0) +{ log << "eABF/DRR: You now are using the extended adaptive biasing " "force(eABF) method." << '\n'; @@ -426,9 +427,9 @@ DynamicReferenceRestraining::DynamicReferenceRestraining( withExternalFict = true; } } - if (temp >= 0.0) { + if (temp >= 0.0) kbt = plumed.getAtoms().getKBoltzmann() * temp; - } else { + else { kbt = plumed.getAtoms().getKbT(); if (kbt <= std::numeric_limits::epsilon()) { error("eABF/DRR: It seems the MD engine does not setup the temperature correctly for PLUMED." @@ -458,9 +459,8 @@ DynamicReferenceRestraining::DynamicReferenceRestraining( vector zgmin(ndims); parseVector("GRID_MIN", gmin); parseVector("ZGRID_MIN", zgmin); - if (gmin.size() != ndims) { + if (gmin.size() != ndims) error("eABF/DRR: not enough values for GRID_MIN"); - } if (zgmin.size() != ndims) { log << "eABF/DRR: You didn't specify ZGRID_MIN. " << '\n' << "eABF/DRR: The GRID_MIN will be used instead."; @@ -470,9 +470,8 @@ DynamicReferenceRestraining::DynamicReferenceRestraining( vector zgmax(ndims); parseVector("GRID_MAX", gmax); parseVector("ZGRID_MAX", zgmax); - if (gmax.size() != ndims) { + if (gmax.size() != ndims) error("eABF/DRR: not enough values for GRID_MAX"); - } if (zgmax.size() != ndims) { log << "eABF/DRR: You didn't specify ZGRID_MAX. " << '\n' << "eABF/DRR: The GRID_MAX will be used instead."; @@ -620,9 +619,8 @@ DynamicReferenceRestraining::DynamicReferenceRestraining( componentIsPeriodic(comp, a, b); delim[i].setPeriodicity(c, d); zdelim[i].setPeriodicity(c, d); - } else { + } else componentIsNotPeriodic(comp); - } fictValue[i] = getPntrToComponent(comp); // Velocity output comp = getPntrToArgument(i)->getName() + "_vfict"; diff --git a/src/drr/colvar_UIestimator.h b/src/drr/colvar_UIestimator.h index 18ebbb1c73..bbc74a0b12 100644 --- a/src/drr/colvar_UIestimator.h +++ b/src/drr/colvar_UIestimator.h @@ -40,41 +40,47 @@ namespace PLMD { namespace drr { -namespace UIestimator { +namespace UIestimator +{ const int Y_SIZE = 21; const int HALF_Y_SIZE = 10; const double BOLTZMANN = 0.0083144621; const int EXTENDED_X_SIZE = HALF_Y_SIZE; -class n_matrix { // spare matrix, stores the distribution matrix of n(x,y) +class n_matrix // spare matrix, stores the distribution matrix of n(x,y) +{ public: n_matrix() {} n_matrix(const std::vector & lowerboundary_p, // lowerboundary of x const std::vector & upperboundary_p, // upperboundary of const std::vector & width_p, // width of x const int y_size) // size of y, for example, ysize=7, then when x=1, the distribution of y in [-2,4] is considered - : lowerboundary(lowerboundary_p), upperboundary(upperboundary_p), width(width_p) { + : lowerboundary(lowerboundary_p), upperboundary(upperboundary_p), width(width_p) + { this->dimension = lowerboundary.size(); this->y_size = y_size; // keep in mind the internal (spare) matrix is stored in diagonal form this->y_total_size = int(pow(y_size, dimension) + 0.000001); // the range of the matrix is [lowerboundary, upperboundary] x_total_size = 1; - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { x_size.push_back(int((upperboundary[i] - lowerboundary[i]) / width[i] + 0.000001)); x_total_size *= x_size[i]; } // initialize the internal matrix matrix.reserve(x_total_size); - for (int i = 0; i < x_total_size; i++) { + for (int i = 0; i < x_total_size; i++) + { matrix.push_back(std::vector(y_total_size, 0)); } temp.resize(dimension); } - int inline get_value(const std::vector & x, const std::vector & y) { + int inline get_value(const std::vector & x, const std::vector & y) + { //if (matrix[convert_x(x)][convert_y(x, y)]!=0) //{ //std::cout< & x, const std::vector & y, const int value) { + void inline set_value(const std::vector & x, const std::vector & y, const int value) + { matrix[convert_x(x)][convert_y(x,y)] = value; } - void inline increase_value(const std::vector & x, const std::vector & y, const int value) { + void inline increase_value(const std::vector & x, const std::vector & y, const int value) + { matrix[convert_x(x)][convert_y(x,y)] += value; } @@ -105,50 +113,57 @@ class n_matrix { // spare matrix, stores the distribution matrix of n(x,y) std::vector temp; // this vector is used in convert_x and convert_y to save computational resource - int convert_x(const std::vector & x) { // convert real x value to its interal index - for (int i = 0; i < dimension; i++) { + int convert_x(const std::vector & x) // convert real x value to its interal index + { + for (int i = 0; i < dimension; i++) + { temp[i] = int((x[i] - lowerboundary[i]) / width[i] + 0.000001); } int index = 0; - for (int i = 0; i < dimension; i++) { - if (i + 1 < dimension) { + for (int i = 0; i < dimension; i++) + { + if (i + 1 < dimension) + { int x_temp = 1; - for (int j = i + 1; j < dimension; j++) { + for (int j = i + 1; j < dimension; j++) x_temp *= x_size[j]; - } index += temp[i] * x_temp; - } else { - index += temp[i]; } + else + index += temp[i]; } return index; } - int convert_y(const std::vector & x, const std::vector & y) { // convert real y value to its interal index - for (int i = 0; i < dimension; i++) { + int convert_y(const std::vector & x, const std::vector & y) // convert real y value to its interal index + { + for (int i = 0; i < dimension; i++) + { temp[i] = round((round(y[i] / width[i] + 0.000001) - round(x[i] / width[i] + 0.000001)) + (y_size - 1) / 2 + 0.000001); } int index = 0; - for (int i = 0; i < dimension; i++) { - if (i + 1 < dimension) { + for (int i = 0; i < dimension; i++) + { + if (i + 1 < dimension) index += temp[i] * int(pow(y_size, dimension - i - 1) + 0.000001); - } else { + else index += temp[i]; - } } return index; } - double round(double r) { + double round(double r) + { return (r > 0.0) ? floor(r + 0.5) : ceil(r - 0.5); } }; // vector, store the sum_x, sum_x_square, count_y template -class n_vector { +class n_vector +{ public: n_vector() {} n_vector(const std::vector & lowerboundary, // lowerboundary of x @@ -156,11 +171,13 @@ class n_vector { const std::vector & width_p, // width of x const int y_size, // size of y, for example, ysize=7, then when x=1, the distribution of y in [-2,4] is considered const T & default_value) // the default value of T - :width(width_p) { + :width(width_p) + { this->dimension = lowerboundary.size(); x_total_size = 1; - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { this->lowerboundary.push_back(lowerboundary[i] - (y_size - 1) / 2 * width[i] - 0.000001); this->upperboundary.push_back(upperboundary[i] + (y_size - 1) / 2 * width[i] + 0.000001); @@ -174,15 +191,18 @@ class n_vector { temp.resize(dimension); } - T inline get_value(const std::vector & x) { + T inline get_value(const std::vector & x) + { return vector[convert_x(x)]; } - void inline set_value(const std::vector & x, const T & value) { + void inline set_value(const std::vector & x, const T & value) + { vector[convert_x(x)] = value; } - void inline increase_value(const std::vector & x, const T & value) { + void inline increase_value(const std::vector & x, const T & value) + { vector[convert_x(x)] += value; } private: @@ -197,28 +217,32 @@ class n_vector { std::vector temp; // this vector is used in convert_x and convert_y to save computational resource - int convert_x(const std::vector & x) { // convert real x value to its interal index - for (int i = 0; i < dimension; i++) { + int convert_x(const std::vector & x) // convert real x value to its interal index + { + for (int i = 0; i < dimension; i++) + { temp[i] = int((x[i] - lowerboundary[i]) / width[i] + 0.000001); } int index = 0; - for (int i = 0; i < dimension; i++) { - if (i + 1 < dimension) { + for (int i = 0; i < dimension; i++) + { + if (i + 1 < dimension) + { int x_temp = 1; - for (int j = i + 1; j < dimension; j++) { + for (int j = i + 1; j < dimension; j++) x_temp *= x_size[j]; - } index += temp[i] * x_temp; - } else { - index += temp[i]; } + else + index += temp[i]; } return index; } }; -class UIestimator { // the implemension of UI estimator +class UIestimator // the implemension of UI estimator +{ public: UIestimator() {} @@ -236,11 +260,13 @@ class UIestimator { // the implemension of UI estimator width(width_p), krestr(krestr_p), output_filename(output_filename_p), output_freq(output_freq_p), restart(restart_p), input_filename(input_filename_p), - temperature(temperature_p) { + temperature(temperature_p) + { dimension = lowerboundary.size(); - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { sum_x.push_back(n_vector(lowerboundary, upperboundary, width, Y_SIZE, 0.0)); sum_x_square.push_back(n_vector(lowerboundary, upperboundary, width, Y_SIZE, 0.0)); @@ -257,40 +283,46 @@ class UIestimator { // the implemension of UI estimator written = false; written_1D = false; - if (dimension == 1) { + if (dimension == 1) + { std::vector upperboundary_temp = upperboundary; upperboundary_temp[0] = upperboundary[0] + width[0]; oneD_pmf = n_vector(lowerboundary, upperboundary_temp, width, 1, 0.0); } - if (restart == true) { + if (restart == true) + { input_grad = n_vector >(lowerboundary, upperboundary, width, 1, std::vector(dimension, 0.0)); input_count = n_vector(lowerboundary, upperboundary, width, 1, 0); // initialize input_Grad and input_count std::vector loop_flag(dimension, 0); - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { loop_flag[i] = lowerboundary[i]; } - while (true) { - for (int i = 0; i < dimension; i++) { + while (true) + { + for (int i = 0; i < dimension; i++) + { input_grad.set_value(loop_flag, std::vector(dimension,0)); } input_count.set_value(loop_flag, 0); // iterate over any dimensions int i = dimension - 1; - while (true) { + while (true) + { loop_flag[i] += width[i]; - if (loop_flag[i] > upperboundary[i] - width[i] + 0.00001) { + if (loop_flag[i] > upperboundary[i] - width[i] + 0.00001) + { loop_flag[i] = lowerboundary[i]; i--; - if (i < 0) { + if (i < 0) goto INITIAL_LOOPEND; - } - } else { - break; } + else + break; } } INITIAL_LOOPEND: @@ -301,7 +333,8 @@ class UIestimator { // the implemension of UI estimator ~UIestimator() {} // called from MD engine every step - bool update(const int step, std::vector x, std::vector y) { + bool update(const int step, std::vector x, std::vector y) + { //std::cout<<"weeeee: :"< 150 && y[i] < -150) { + if (x[i] > 150 && y[i] < -150) + { //std::vector x_temp(x); //x_temp[i] -= 360; //update(7, x_temp, y); y[i] += 360; } - if (x[i] < -150 && y[i] > 150) { + if (x[i] < -150 && y[i] > 150) + { //std::vector x_temp(x); //x_temp[i] += 360; //update(7, x_temp, y); @@ -334,9 +371,8 @@ class UIestimator { // the implemension of UI estimator if (x[i] < lowerboundary[i] - EXTENDED_X_SIZE * width[i] + 0.00001 || x[i] > upperboundary[i] + EXTENDED_X_SIZE * width[i] - 0.00001 \ || y[i] - x[i] < -HALF_Y_SIZE * width[i] + 0.00001 || y[i] - x[i] > HALF_Y_SIZE * width[i] - 0.00001 \ - || y[i] - lowerboundary[i] < -HALF_Y_SIZE * width[i] + 0.00001 || y[i] - upperboundary[i] > HALF_Y_SIZE * width[i] - 0.00001) { + || y[i] - lowerboundary[i] < -HALF_Y_SIZE * width[i] + 0.00001 || y[i] - upperboundary[i] > HALF_Y_SIZE * width[i] - 0.00001) return false; - } } //for (int i = 0; i < dimension; i++) @@ -345,18 +381,19 @@ class UIestimator { // the implemension of UI estimator //} //std::cout< upperboundary[i] - 0.000001) // adapt colvars precision - if (x[i] < lowerboundary[i] + 0.00001 || x[i] > upperboundary[i] - 0.00001) { + if (x[i] < lowerboundary[i] + 0.00001 || x[i] > upperboundary[i] - 0.00001) return false; - } } distribution_x_y.increase_value(x, y, 1); @@ -364,7 +401,8 @@ class UIestimator { // the implemension of UI estimator } // update the output_filename - void update_output_filename(const std::string& filename) { + void update_output_filename(const std::string& filename) + { output_filename = filename; } @@ -402,34 +440,39 @@ class UIestimator { // the implemension of UI estimator bool written_1D; // calculate gradients from the internal variables - void calc_pmf() { + void calc_pmf() + { int norm; std::vector loop_flag(dimension, 0); - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { loop_flag[i] = lowerboundary[i] - HALF_Y_SIZE * width[i]; } - while (true) { + while (true) + { norm = count_y.get_value(loop_flag) > 0 ? count_y.get_value(loop_flag) : 1; - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { x_av[i].set_value(loop_flag, sum_x[i].get_value(loop_flag) / norm); sigma_square[i].set_value(loop_flag, sum_x_square[i].get_value(loop_flag) / norm - x_av[i].get_value(loop_flag) * x_av[i].get_value(loop_flag)); } // iterate over any dimensions int i = dimension - 1; - while (true) { + while (true) + { loop_flag[i] += width[i]; - if (loop_flag[i] > upperboundary[i] + HALF_Y_SIZE * width[i] - width[i] + 0.00001) { + if (loop_flag[i] > upperboundary[i] + HALF_Y_SIZE * width[i] - width[i] + 0.00001) + { loop_flag[i] = lowerboundary[i] - HALF_Y_SIZE * width[i]; i--; - if (i < 0) { + if (i < 0) goto LOOPEND; - } - } else { - break; } + else + break; } } LOOPEND: @@ -440,49 +483,55 @@ class UIestimator { // the implemension of UI estimator std::vector loop_flag_x(dimension, 0); std::vector loop_flag_y(dimension, 0); - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { loop_flag_x[i] = lowerboundary[i]; loop_flag_y[i] = loop_flag_x[i] - HALF_Y_SIZE * width[i]; } - while (true) { + while (true) + { norm = 0; - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { av[i] = 0; diff_av[i] = 0; loop_flag_y[i] = loop_flag_x[i] - HALF_Y_SIZE * width[i]; } - while (true) { + while (true) + { //std::cout<<"pppppppppppppppppppppp "< 0.00001 || sigma_square[i].get_value(loop_flag_y) < -0.00001) { + for (int i = 0; i < dimension; i++) + { + if (sigma_square[i].get_value(loop_flag_y) > 0.00001 || sigma_square[i].get_value(loop_flag_y) < -0.00001) av[i] += distribution_x_y.get_value(loop_flag_x, loop_flag_y) * ( (loop_flag_x[i] + 0.5 * width[i]) - x_av[i].get_value(loop_flag_y)) / sigma_square[i].get_value(loop_flag_y); - } diff_av[i] += distribution_x_y.get_value(loop_flag_x, loop_flag_y) * (loop_flag_x[i] - loop_flag_y[i]); } // iterate over any dimensions int i = dimension - 1; - while (true) { + while (true) + { loop_flag_y[i] += width[i]; - if (loop_flag_y[i] > loop_flag_x[i] + HALF_Y_SIZE * width[i] - width[i] + 0.00001) { + if (loop_flag_y[i] > loop_flag_x[i] + HALF_Y_SIZE * width[i] - width[i] + 0.00001) + { loop_flag_y[i] = loop_flag_x[i] - HALF_Y_SIZE * width[i]; i--; - if (i < 0) { + if (i < 0) goto LOOPEND2; - } - } else { - break; } + else + break; } } LOOPEND2: std::vector grad_temp(dimension, 0); - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { diff_av[i] /= (norm > 0 ? norm : 1); av[i] = BOLTZMANN * temperature * av[i] / (norm > 0 ? norm : 1); grad_temp[i] = av[i] - krestr[i] * diff_av[i]; @@ -492,26 +541,27 @@ class UIestimator { // the implemension of UI estimator // iterate over any dimensions int i = dimension - 1; - while (true) { + while (true) + { loop_flag_x[i] += width[i]; - if (loop_flag_x[i] > upperboundary[i] - width[i] + 0.00001) { + if (loop_flag_x[i] > upperboundary[i] - width[i] + 0.00001) + { loop_flag_x[i] = lowerboundary[i]; i--; - if (i < 0) { + if (i < 0) goto LOOPEND3; - } - } else { - break; } + else + break; } } -LOOPEND3: - ; +LOOPEND3:; } // calculate 1D pmf - void calc_1D_pmf() { + void calc_1D_pmf() + { std::vector last_position(1, 0); std::vector position(1, 0); @@ -520,28 +570,33 @@ class UIestimator { // the implemension of UI estimator oneD_pmf.set_value(lowerboundary, 0); last_position = lowerboundary; - for (double i = lowerboundary[0] + width[0]; i < upperboundary[0] + 0.000001; i += width[0]) { + for (double i = lowerboundary[0] + width[0]; i < upperboundary[0] + 0.000001; i += width[0]) + { position[0] = i + 0.000001; - if (restart == false || input_count.get_value(last_position) == 0) { + if (restart == false || input_count.get_value(last_position) == 0) + { dG = oneD_pmf.get_value(last_position) + grad.get_value(last_position)[0] * width[0]; - } else { + } + else + { dG = oneD_pmf.get_value(last_position) + ((grad.get_value(last_position)[0] * count.get_value(last_position) + input_grad.get_value(last_position)[0] * input_count.get_value(last_position)) / (count.get_value(last_position) + input_count.get_value(last_position))) * width[0]; } - if (dG < min) { + if (dG < min) min = dG; - } oneD_pmf.set_value(position, dG); last_position[0] = i + 0.000001; } - for (double i = lowerboundary[0]; i < upperboundary[0] + 0.000001; i += width[0]) { + for (double i = lowerboundary[0]; i < upperboundary[0] + 0.000001; i += width[0]) + { position[0] = i + 0.000001; oneD_pmf.set_value(position, oneD_pmf.get_value(position) - min); } } // write 1D pmf - void write_1D_pmf() { + void write_1D_pmf() + { std::string pmf_filename = output_filename + ".UI.pmf"; // only for colvars module! @@ -550,7 +605,8 @@ class UIestimator { // the implemension of UI estimator std::ofstream ofile_pmf(pmf_filename.c_str()); std::vector position(1, 0); - for (double i = lowerboundary[0]; i < upperboundary[0] + 0.000001; i += width[0]) { + for (double i = lowerboundary[0]; i < upperboundary[0] + 0.000001; i += width[0]) + { ofile_pmf << i << " "; position[0] = i + 0.000001; ofile_pmf << oneD_pmf.get_value(position) << std::endl; @@ -561,9 +617,11 @@ class UIestimator { // the implemension of UI estimator } // write heads of the output files - void writehead(std::ofstream& os) const { + void writehead(std::ofstream& os) const + { os << "# " << dimension << std::endl; - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { os.precision(std::numeric_limits::max_digits10); os << "# " << std::fixed << lowerboundary[i] << " " << width[i] << " " << int((upperboundary[i] - lowerboundary[i]) / width[i] + 0.000001) << " " << 0 << std::endl; } @@ -627,7 +685,8 @@ class UIestimator { // the implemension of UI estimator // } // write output files - void write_files() { + void write_files() + { std::string grad_filename = output_filename + ".UI.grad"; std::string hist_filename = output_filename + ".UI.hist.grad"; std::string count_filename = output_filename + ".UI.count"; @@ -645,39 +704,47 @@ class UIestimator { // the implemension of UI estimator writehead(ofile_hist); writehead(ofile_count); - if (dimension == 1) { + if (dimension == 1) + { calc_1D_pmf(); write_1D_pmf(); } std::vector loop_flag(dimension, 0); - for (int i = 0; i < dimension; i++) { + for (int i = 0; i < dimension; i++) + { loop_flag[i] = lowerboundary[i]; } - while (true) { - for (int i = 0; i < dimension; i++) { + while (true) + { + for (int i = 0; i < dimension; i++) + { ofile << std::fixed << std::setprecision(9) << loop_flag[i] + 0.5 * width[i] << " "; ofile_hist << std::fixed << std::setprecision(9) << loop_flag[i] + 0.5 * width[i] << " "; ofile_count << std::fixed << std::setprecision(9) << loop_flag[i] + 0.5 * width[i] << " "; } - if (restart == false) { - for (int i = 0; i < dimension; i++) { + if (restart == false) + { + for (int i = 0; i < dimension; i++) + { ofile << std::fixed << std::setprecision(9) << grad.get_value(loop_flag)[i] << " "; ofile_hist << std::fixed << std::setprecision(9) << grad.get_value(loop_flag)[i] << " "; } ofile << std::endl; ofile_hist << std::endl; ofile_count << count.get_value(loop_flag) << " " < upperboundary[i] - width[i] + 0.00001) { + if (loop_flag[i] > upperboundary[i] - width[i] + 0.00001) + { loop_flag[i] = lowerboundary[i]; i--; ofile << std::endl; ofile_hist << std::endl; ofile_count << std::endl; - if (i < 0) { + if (i < 0) goto LOOPEND4; - } - } else { - break; } + else + break; } } LOOPEND4: @@ -713,7 +781,8 @@ class UIestimator { // the implemension of UI estimator } // read input files - void read_inputfiles(const std::vector& input_filename) { + void read_inputfiles(const std::vector& input_filename) + { char sharp; double nothing; int dimension_temp; @@ -722,7 +791,8 @@ class UIestimator { // the implemension of UI estimator std::vector position_temp(dimension, 0); std::vector grad_temp(dimension, 0); int count_temp = 0; - for (unsigned int i = 0; i < input_filename.size(); i++) { + for (unsigned int i = 0; i < input_filename.size(); i++) + { int size = 1, size_temp = 0; std::string count_filename = input_filename[i] + ".UI.count"; @@ -734,30 +804,38 @@ class UIestimator { // the implemension of UI estimator count_file >> sharp >> dimension_temp; grad_file >> sharp >> dimension_temp; - for (int j = 0; j < dimension; j++) { + for (int j = 0; j < dimension; j++) + { count_file >> sharp >> nothing >> nothing >> size_temp >> nothing; grad_file >> sharp >> nothing >> nothing >> nothing >> nothing; size *= size_temp; } - for (int j = 0; j < size; j++) { - do { - for (int k = 0; k < dimension; k++) { + for (int j = 0; j < size; j++) + { + do + { + for (int k = 0; k < dimension; k++) + { count_file >> position_temp[k]; grad_file >> nothing; } - for (int l = 0; l < dimension; l++) { + for (int l = 0; l < dimension; l++) + { grad_file >> grad_temp[l]; } count_file >> count_temp; - } while (position_temp[i] < lowerboundary[i] - 0.000001 || position_temp[i] > upperboundary[i] + 0.000001); + } + while (position_temp[i] < lowerboundary[i] - 0.000001 || position_temp[i] > upperboundary[i] + 0.000001); - if (count_temp == 0) { + if (count_temp == 0) + { continue; } - for (int m = 0; m < dimension; m++) { + for (int m = 0; m < dimension; m++) + { grad_temp[m] = (grad_temp[m] * count_temp + input_grad.get_value(position_temp)[m] * input_count.get_value(position_temp)) / (count_temp + input_count.get_value(position_temp)); } input_grad.set_value(position_temp, grad_temp); diff --git a/src/drr/drrtool.cpp b/src/drr/drrtool.cpp index b50589a76e..62c574dcd3 100644 --- a/src/drr/drrtool.cpp +++ b/src/drr/drrtool.cpp @@ -78,9 +78,7 @@ class drrtool : public CLTool { void extractdrr(const vector &filename); void mergewindows(const vector &filename, string outputname); void calcDivergence(const vector &filename); - string description() const { - return "Extract or merge the drrstate files."; - } + string description() const { return "Extract or merge the drrstate files."; } private: bool verbosity; @@ -163,13 +161,11 @@ void drrtool::extractdrr(const vector &filename) { } string outputname(filename[j]); outputname.resize(outputname.length() - suffix.length()); - if (verbosity) { + if (verbosity) std::cout << "Writing ABF(naive) estimator files..." << '\n'; - } abfgrid.writeAll(outputname); - if (verbosity) { + if (verbosity) std::cout << "Writing CZAR estimator files..." << '\n'; - } czarestimator.writeAll(outputname); czarestimator.writeZCountZGrad(outputname); } @@ -212,13 +208,9 @@ void drrtool::mergewindows(const vector &filename, string outputname) { // Generate new file name for merged grad and count vector tmp_name = filename; std::transform(std::begin(tmp_name), std::end(tmp_name), std::begin(tmp_name), - [&](string s) { - return s.substr(0, s.find(suffix)); - }); + [&](string s) {return s.substr(0, s.find(suffix));}); outputname = std::accumulate(std::begin(tmp_name), std::end(tmp_name), string(""), - [](const string & a, const string & b) { - return a + b + "+"; - }); + [](const string & a, const string & b) {return a + b + "+";}); outputname.resize(outputname.size() - 1); std::cerr << "You have not specified an output filename for the merged" << " result, so the default name \"" + outputname diff --git a/src/eds/EDS.cpp b/src/eds/EDS.cpp index eaf352aa5c..700b746bf7 100644 --- a/src/eds/EDS.cpp +++ b/src/eds/EDS.cpp @@ -32,8 +32,10 @@ using namespace bias; // namespace is lowercase to match // module names being all lowercase -namespace PLMD { -namespace eds { +namespace PLMD +{ +namespace eds +{ //+PLUMEDOC EDSMOD_BIAS EDS /* @@ -191,7 +193,8 @@ eds: EDS ARG=d1 CENTER=2.0 TEMP=1.0 IN_RESTART=restart.eds FREEZE MEAN */ //+ENDPLUMEDOC -class EDS : public Bias { +class EDS : public Bias +{ private: /*We will get this and store it once, since on-the-fly changing number of CVs will be fatal*/ @@ -276,7 +279,8 @@ class EDS : public Bias { PLUMED_REGISTER_ACTION(EDS, "EDS") -void EDS::registerKeywords(Keywords &keys) { +void EDS::registerKeywords(Keywords &keys) +{ Bias::registerKeywords(keys); keys.use("ARG"); keys.add("optional", "CENTER", "The desired centers (equilibrium values) which will be sought during the adaptive linear biasing. This is for fixed centers"); @@ -356,7 +360,8 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), pseudo_virial_sum_(0.0), max_logweight_(0.0), wsum_(0.0), - value_force2_(NULL) { + value_force2_(NULL) +{ double temp = -1.0; bool b_mean = false; std::vector wvalues; @@ -365,7 +370,8 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), componentIsNotPeriodic("force2"); value_force2_ = getPntrToComponent("force2"); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { std::string comp = getPntrToArgument(i)->getName() + "_coupling"; addComponent(comp); componentIsNotPeriodic(comp); @@ -403,60 +409,70 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), * 3. Reading Restarts */ - if (center_.size() == 0) { - if (center_values_.size() == 0) { + if (center_.size() == 0) + { + if (center_values_.size() == 0) error("Must set either CENTER or CENTER_ARG"); - } else if (center_values_.size() != ncvs_) { + else if (center_values_.size() != ncvs_) error("CENTER_ARG must contain the same number of variables as ARG"); - } b_c_values_ = true; center_.resize(ncvs_); log.printf(" EDS will use possibly varying centers\n"); - } else { - if (center_.size() != ncvs_) { + } + else + { + if (center_.size() != ncvs_) error("Must have same number of CENTER arguments as ARG arguments"); - } else if (center_values_.size() != 0) { + else if (center_values_.size() != 0) error("You can only set CENTER or CENTER_ARG. Not both"); - } b_c_values_ = false; log.printf(" EDS will use fixed centers\n"); } // check for weights - if (wvalues.size() > 1) { + if (wvalues.size() > 1) + { error("LOGWEIGHTS can only support one weight set. Please only pass one action"); - } else if (wvalues.size() == 1) { + } + else if (wvalues.size() == 1) + { logweights_ = dynamic_cast(wvalues[0]->getPntrToAction()); b_weights_ = true; } log.printf(" setting scaling:"); - if (scale_.size() > 0 && scale_.size() < ncvs_) { + if (scale_.size() > 0 && scale_.size() < ncvs_) + { error("the number of BIAS_SCALE values be the same as number of CVs"); - } else if (scale_.size() == 0 && b_c_values_) { + } + else if (scale_.size() == 0 && b_c_values_) + { log.printf(" Setting SCALE to be 1 for all CVs\n"); scale_.resize(ncvs_); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) scale_[i] = 1; - } - } else if (scale_.size() == 0 && !b_c_values_) { + } + else if (scale_.size() == 0 && !b_c_values_) + { log.printf(" (default) "); scale_.resize(ncvs_); - for (unsigned int i = 0; i < scale_.size(); ++i) { - if (center_[i] == 0) { + for (unsigned int i = 0; i < scale_.size(); ++i) + { + if (center_[i] == 0) error("BIAS_SCALE parameter has been set to CENTER value of 0 (as is default). This will divide by 0, so giving up. See doc for EDS bias"); - } scale_[i] = center_[i]; } - } else { - for (unsigned int i = 0; i < scale_.size(); ++i) { + } + else + { + for (unsigned int i = 0; i < scale_.size(); ++i) log.printf(" %f", scale_[i]); - } } log.printf("\n"); - if (b_lm_) { + if (b_lm_) + { log.printf(" EDS will perform Levenberg-Marquardt minimization with mixing parameter = %f\n", lm_mixing_par_); differences_.resize(ncvs_); alpha_vector_.resize(ncvs_); @@ -466,34 +482,36 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), lm_inv_.resize(ncvs_, ncvs_); covar2_ *= 0; lm_inv_ *= 0; - if (multi_prop_ != 1) { + if (multi_prop_ != 1) log.printf(" WARNING - doing LM minimization but MULTI_PROP!=1\n"); - } - } else if (b_covar_) { + } + else if (b_covar_) + { log.printf(" EDS will utilize covariance matrix for update steps\n"); covar_.resize(ncvs_, ncvs_); - } else { + } + else + { log.printf(" EDS will utilize variance for update steps\n"); ssds_.resize(ncvs_); } b_virial_ = virial_scaling_; - if (b_virial_) { - if (ncvs_ == 1) { + if (b_virial_) + { + if (ncvs_ == 1) error("Minimizing the virial is only valid with multiply correlated collective variables."); - } // check that the CVs can be used to compute pseudo-virial log.printf(" EDS will compute virials of CVs and penalize with scale of %f. Checking CVs are valid...", virial_scaling_); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { auto a = dynamic_cast(getPntrToArgument(i)->getPntrToAction()); - if (!a) { + if (!a) error("If using VIRIAL keyword, you must have normal CVs as arguments to EDS. Offending action: " + getPntrToArgument(i)->getPntrToAction()->getName()); - } // cppcheck-suppress nullPointerRedundantCheck - if (!(a->getPbc().isOrthorombic())) { + if (!(a->getPbc().isOrthorombic())) log.printf(" WARNING: EDS Virial should have a orthorombic cell\n"); - } } log.printf("done.\n"); addComponent("pressure"); @@ -501,24 +519,28 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), value_pressure_ = getPntrToComponent("pressure"); } - if (b_mean && !b_freeze_) { + if (b_mean && !b_freeze_) + { error("EDS keyword MEAN can only be used along with keyword FREEZE"); } - if (in_restart_name_ != "") { + if (in_restart_name_ != "") + { b_restart_ = true; log.printf(" reading simulation information from file: %s\n", in_restart_name_.c_str()); readInRestart(b_mean); - } else { + } + else + { - if (temp >= 0.0) { + if (temp >= 0.0) kbt_ = plumed.getAtoms().getKBoltzmann() * temp; - } else { + else kbt_ = plumed.getAtoms().getKbT(); - } // in driver, this results in kbt of 0 - if (kbt_ == 0) { + if (kbt_ == 0) + { error(" Unable to determine valid kBT. " "Could be because you are runnning from driver or MD didn't give temperature.\n" "Consider setting temperature manually with the TEMP keyword."); @@ -528,14 +550,19 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), log.printf(" kBT = %f\n", kbt_); log.printf(" Updating every %i steps\n", update_period_); - if (!b_c_values_) { + if (!b_c_values_) + { log.printf(" with centers:"); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { log.printf(" %f ", center_[i]); } - } else { + } + else + { log.printf(" with actions centers:"); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { log.printf(" %s ", center_values_[i]->getName().c_str()); // add dependency on these actions addDependency(center_values_[i]->getPntrToAction()); @@ -543,7 +570,8 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), } log.printf("\n with initial ranges / rates:\n"); - for (unsigned int i = 0; i < max_coupling_range_.size(); ++i) { + for (unsigned int i = 0; i < max_coupling_range_.size(); ++i) + { // this is just an empirical guess. Bigger range, bigger grads. Less frequent updates, bigger changes // // using the current maxing out scheme, max_coupling_range is the biggest step that can be taken in any given interval @@ -552,68 +580,79 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), log.printf(" %f / %f\n", max_coupling_range_[i], max_coupling_grad_[i]); } - if (seed_ > 0) { + if (seed_ > 0) + { log.printf(" setting random seed = %i", seed_); rand_.setSeed(seed_); } for (unsigned int i = 0; i < ncvs_; ++i) - if (target_coupling_[i] != 0.0) { + if (target_coupling_[i] != 0.0) b_adaptive_ = false; - } - if (!b_adaptive_) { - if (b_ramp_) { + if (!b_adaptive_) + { + if (b_ramp_) + { log.printf(" ramping up coupling constants over %i steps\n", update_period_); } log.printf(" with starting coupling constants"); - for (unsigned int i = 0; i < set_coupling_.size(); ++i) { + for (unsigned int i = 0; i < set_coupling_.size(); ++i) log.printf(" %f", set_coupling_[i]); - } log.printf("\n"); log.printf(" and final coupling constants"); - for (unsigned int i = 0; i < target_coupling_.size(); ++i) { + for (unsigned int i = 0; i < target_coupling_.size(); ++i) log.printf(" %f", target_coupling_[i]); - } log.printf("\n"); } // now do setup - if (b_ramp_) { + if (b_ramp_) + { update_period_ *= -1; } - for (unsigned int i = 0; i < set_coupling_.size(); ++i) { + for (unsigned int i = 0; i < set_coupling_.size(); ++i) current_coupling_[i] = set_coupling_[i]; - } // if b_adaptive_, then first half will be used for equilibrating and second half for statistics - if (update_period_ > 0) { + if (update_period_ > 0) + { update_period_ /= 2; } } - if (b_freeze_) { + if (b_freeze_) + { b_adaptive_ = false; update_period_ = 0; - if (b_mean) { + if (b_mean) + { log.printf(" freezing bias at the average level from the restart file\n"); - } else { + } + else + { log.printf(" freezing bias at current level\n"); } } - if (multi_prop_ == -1.0) { + if (multi_prop_ == -1.0) + { log.printf(" Will update each dimension stochastically with probability 1 / number of CVs\n"); multi_prop_ = 1.0 / ncvs_; - } else if (multi_prop_ > 0 && multi_prop_ <= 1.0) { + } + else if (multi_prop_ > 0 && multi_prop_ <= 1.0) + { log.printf(" Will update each dimension stochastically with probability %f\n", multi_prop_); - } else { + } + else + { error(" MULTI_PROP must be between 0 and 1\n"); } - if (out_restart_name_.length() > 0) { + if (out_restart_name_.length() > 0) + { log.printf(" writing restart information every %i steps to file %s with format %s\n", abs(update_period_), out_restart_name_.c_str(), fmt_.c_str()); b_write_restart_ = true; setupOutRestart(); @@ -623,39 +662,53 @@ EDS::EDS(const ActionOptions &ao) : PLUMED_BIAS_INIT(ao), log << " Bibliography " << plumed.cite("G. M. Hocky, T. Dannenhoffer-Lafage, G. A. Voth, J. Chem. Theory Comput. 13 (9), 4593-4603 (2017)") << "\n"; } -void EDS::readInRestart(const bool b_mean) { +void EDS::readInRestart(const bool b_mean) +{ int adaptive_i = 0; in_restart_.open(in_restart_name_); - if (in_restart_.FieldExist("kbt")) { + if (in_restart_.FieldExist("kbt")) + { in_restart_.scanField("kbt", kbt_); - } else { + } + else + { error("No field 'kbt' in restart file"); } log.printf(" with kBT = %f\n", kbt_); - if (in_restart_.FieldExist("update_period")) { + if (in_restart_.FieldExist("update_period")) + { in_restart_.scanField("update_period", update_period_); - } else { + } + else + { error("No field 'update_period' in restart file"); } log.printf(" Updating every %i steps\n", update_period_); - if (in_restart_.FieldExist("adaptive")) { + if (in_restart_.FieldExist("adaptive")) + { // note, no version of scanField for boolean in_restart_.scanField("adaptive", adaptive_i); - } else { + } + else + { error("No field 'adaptive' in restart file"); } b_adaptive_ = bool(adaptive_i); - if (in_restart_.FieldExist("seed")) { + if (in_restart_.FieldExist("seed")) + { in_restart_.scanField("seed", seed_); - } else { + } + else + { error("No field 'seed' in restart file"); } - if (seed_ > 0) { + if (seed_ > 0) + { log.printf(" setting random seed = %i", seed_); rand_.setSeed(seed_); } @@ -665,9 +718,11 @@ void EDS::readInRestart(const bool b_mean) { unsigned int N = 0; std::string cv_name; - while (in_restart_.scanField("time", time)) { + while (in_restart_.scanField("time", time)) + { - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { cv_name = getPntrToArgument(i)->getName(); in_restart_.scanField(cv_name + "_center", set_coupling_[i]); in_restart_.scanField(cv_name + "_set", set_coupling_[i]); @@ -677,12 +732,12 @@ void EDS::readInRestart(const bool b_mean) { in_restart_.scanField(cv_name + "_maxgrad", max_coupling_grad_[i]); in_restart_.scanField(cv_name + "_accum", coupling_accum_[i]); in_restart_.scanField(cv_name + "_mean", means_[i]); - if (in_restart_.FieldExist(cv_name + "_pseudovirial")) { - if (b_virial_) { + if (in_restart_.FieldExist(cv_name + "_pseudovirial")) + { + if (b_virial_) in_restart_.scanField(cv_name + "_pseudovirial", pseudo_virial_[i]); - } else { // discard the field + else // discard the field in_restart_.scanField(cv_name + "_pseudovirial", tmp); - } } // unused due to difference between covar/nocovar in_restart_.scanField(cv_name + "_std", tmp); @@ -695,53 +750,54 @@ void EDS::readInRestart(const bool b_mean) { } log.printf(" with centers:"); - for (unsigned int i = 0; i < center_.size(); ++i) { + for (unsigned int i = 0; i < center_.size(); ++i) + { log.printf(" %f", center_[i]); } log.printf("\n and scaling:"); - for (unsigned int i = 0; i < scale_.size(); ++i) { + for (unsigned int i = 0; i < scale_.size(); ++i) + { log.printf(" %f", scale_[i]); } log.printf("\n with initial ranges / rates:\n"); - for (unsigned int i = 0; i < max_coupling_range_.size(); ++i) { + for (unsigned int i = 0; i < max_coupling_range_.size(); ++i) + { log.printf(" %f / %f\n", max_coupling_range_[i], max_coupling_grad_[i]); } - if (!b_adaptive_ && update_period_ < 0) { + if (!b_adaptive_ && update_period_ < 0) + { log.printf(" ramping up coupling constants over %i steps\n", -update_period_); } - if (b_mean) { + if (b_mean) + { log.printf("Loaded in averages for coupling constants...\n"); - for (unsigned int i = 0; i < current_coupling_.size(); ++i) { + for (unsigned int i = 0; i < current_coupling_.size(); ++i) current_coupling_[i] = avg_bias[i] / N; - } - for (unsigned int i = 0; i < current_coupling_.size(); ++i) { + for (unsigned int i = 0; i < current_coupling_.size(); ++i) set_coupling_[i] = avg_bias[i] / N; - } } log.printf(" with current coupling constants:\n "); - for (unsigned int i = 0; i < current_coupling_.size(); ++i) { + for (unsigned int i = 0; i < current_coupling_.size(); ++i) log.printf(" %f", current_coupling_[i]); - } log.printf("\n"); log.printf(" with initial coupling constants:\n "); - for (unsigned int i = 0; i < set_coupling_.size(); ++i) { + for (unsigned int i = 0; i < set_coupling_.size(); ++i) log.printf(" %f", set_coupling_[i]); - } log.printf("\n"); log.printf(" and final coupling constants:\n "); - for (unsigned int i = 0; i < target_coupling_.size(); ++i) { + for (unsigned int i = 0; i < target_coupling_.size(); ++i) log.printf(" %f", target_coupling_[i]); - } log.printf("\n"); in_restart_.close(); } -void EDS::setupOutRestart() { +void EDS::setupOutRestart() +{ out_restart_.link(*this); out_restart_.fmtField(fmt_); out_restart_.open(out_restart_name_); @@ -753,11 +809,13 @@ void EDS::setupOutRestart() { out_restart_.addConstantField("kbt").printField("kbt", kbt_); } -void EDS::writeOutRestart() { +void EDS::writeOutRestart() +{ std::string cv_name; out_restart_.printField("time", getTimeStep() * getStep()); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { cv_name = getPntrToArgument(i)->getName(); out_restart_.printField(cv_name + "_center", center_[i]); out_restart_.printField(cv_name + "_set", set_coupling_[i]); @@ -767,34 +825,34 @@ void EDS::writeOutRestart() { out_restart_.printField(cv_name + "_maxgrad", max_coupling_grad_[i]); out_restart_.printField(cv_name + "_accum", coupling_accum_[i]); out_restart_.printField(cv_name + "_mean", means_[i]); - if (b_virial_) { + if (b_virial_) out_restart_.printField(cv_name + "_pseudovirial", pseudo_virial_[i]); - } - if (!b_covar_ && !b_lm_) { + if (!b_covar_ && !b_lm_) out_restart_.printField(cv_name + "_std", ssds_[i] / (fmax(1, update_calls_ - 1))); - } else { + else out_restart_.printField(cv_name + "_std", covar_(i, i) / (fmax(1, update_calls_ - 1))); - } } out_restart_.printField(); } -void EDS::calculate() { +void EDS::calculate() +{ // get center values from action if necessary if (b_c_values_) - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) center_[i] = center_values_[i]->get(); - } apply_bias(); } -void EDS::apply_bias() { +void EDS::apply_bias() +{ // Compute linear force as in "restraint" double ene = 0, totf2 = 0, cv, m, f; - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { cv = difference(i, center_[i], getArgument(i)); m = current_coupling_[i]; f = -m; @@ -807,14 +865,17 @@ void EDS::apply_bias() { value_force2_->set(totf2); } -void EDS::update_statistics() { +void EDS::update_statistics() +{ double s, N, w = 1.0; std::vector deltas(ncvs_); // update weight max, if necessary - if (b_weights_) { + if (b_weights_) + { w = logweights_->getLogWeight(); - if (max_logweight_ < w) { + if (max_logweight_ < w) + { // we have new max. Need to shift existing values wsum_ *= exp(max_logweight_ - w); max_logweight_ = w; @@ -823,22 +884,27 @@ void EDS::update_statistics() { w = exp(w - max_logweight_); wsum_ += w; N = wsum_; - } else { + } + else + { N = fmax(1, update_calls_); } // Welford, West, and Hanso online variance method // with weights (default = 1.0) - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { deltas[i] = difference(i, means_[i], getArgument(i)) * w; means_[i] += deltas[i] / N; - if (!b_covar_ && !b_lm_) { + if (!b_covar_ && !b_lm_) ssds_[i] += deltas[i] * difference(i, means_[i], getArgument(i)); - } } - if (b_covar_ || b_lm_) { - for (unsigned int i = 0; i < ncvs_; ++i) { - for (unsigned int j = i; j < ncvs_; ++j) { + if (b_covar_ || b_lm_) + { + for (unsigned int i = 0; i < ncvs_; ++i) + { + for (unsigned int j = i; j < ncvs_; ++j) + { s = (N - 1) * deltas[i] * deltas[j] / N / N - covar_(i, j) / N; covar_(i, j) += s; // do this so we don't double count @@ -846,41 +912,43 @@ void EDS::update_statistics() { } } } - if (b_virial_) { + if (b_virial_) update_pseudo_virial(); - } } -void EDS::reset_statistics() { - for (unsigned int i = 0; i < ncvs_; ++i) { +void EDS::reset_statistics() +{ + for (unsigned int i = 0; i < ncvs_; ++i) + { means_[i] = 0; - if (!b_covar_ && !b_lm_) { + if (!b_covar_ && !b_lm_) ssds_[i] = 0; - } } if (b_covar_ || b_lm_) for (unsigned int i = 0; i < ncvs_; ++i) - for (unsigned int j = 0; j < ncvs_; ++j) { + for (unsigned int j = 0; j < ncvs_; ++j) covar_(i, j) = 0; - } - if (b_virial_) { - for (unsigned int i = 0; i < ncvs_; ++i) { + if (b_virial_) + { + for (unsigned int i = 0; i < ncvs_; ++i) pseudo_virial_[i] = 0; - } pseudo_virial_sum_ = 0; } - if (b_weights_) { + if (b_weights_) + { wsum_ = 0; max_logweight_ = 0; } } -void EDS::calc_lm_step_size() { +void EDS::calc_lm_step_size() +{ // calulcate step size // uses scale here, which by default is center mult(covar_, covar_, covar2_); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { differences_[i] = difference(i, center_[i], means_[i]); covar2_[i][i] += lm_mixing_par_ * covar2_[i][i]; } @@ -890,46 +958,51 @@ void EDS::calc_lm_step_size() { Invert(covar2_, lm_inv_); mult(lm_inv_, alpha_vector_, alpha_vector_2_); - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { step_size_[i] = 2 * alpha_vector_2_[i] / kbt_ / scale_[i]; } } -void EDS::calc_covar_step_size() { +void EDS::calc_covar_step_size() +{ // calulcate step size // uses scale here, which by default is center double tmp; - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { tmp = 0; - for (unsigned int j = 0; j < ncvs_; ++j) { + for (unsigned int j = 0; j < ncvs_; ++j) tmp += difference(i, center_[i], means_[i]) * covar_(i, j); - } step_size_[i] = 2 * tmp / kbt_ / scale_[i] * update_calls_ / fmax(1, update_calls_ - 1); } } -void EDS::calc_ssd_step_size() { +void EDS::calc_ssd_step_size() +{ double tmp; - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { tmp = 2. * difference(i, center_[i], means_[i]) * ssds_[i] / fmax(1, update_calls_ - 1); step_size_[i] = tmp / kbt_ / scale_[i]; } } -void EDS::update_pseudo_virial() { +void EDS::update_pseudo_virial() +{ // We want to compute the bias force on each atom times the position // of the atoms. double p, netp = 0, netpv = 0; double volume = 0; - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { // checked in setup to ensure this cast is valid. ActionAtomistic *cv = dynamic_cast(getPntrToArgument(i)->getPntrToAction()); Tensor &v(cv->modifyVirial()); Tensor box(cv->getBox()); const unsigned int natoms = cv->getNumberOfAtoms(); - if (!volume) { + if (!volume) volume = box.determinant(); - } // pressure contribution is -dBias / dV // dBias / dV = alpha / w * dCV / dV @@ -947,11 +1020,10 @@ void EDS::update_pseudo_virial() { p *= (volume) / (kbt_ * natoms); // compute running mean of scaled - if (set_coupling_[i] != 0) { + if (set_coupling_[i] != 0) pseudo_virial_[i] = (p - pseudo_virial_[i]) / (fmax(1, update_calls_)); - } else { + else pseudo_virial_[i] = 0; - } // update net pressure netpv += pseudo_virial_[i]; } @@ -960,35 +1032,35 @@ void EDS::update_pseudo_virial() { pseudo_virial_sum_ = netpv; } -void EDS::update_bias() { +void EDS::update_bias() +{ log.flush(); - if (b_lm_) { + if (b_lm_) calc_lm_step_size(); - } else if (b_covar_) { + else if (b_covar_) calc_covar_step_size(); - } else { + else calc_ssd_step_size(); - } - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { // multidimesional stochastic step - if (ncvs_ == 1 || (rand_.RandU01() < (multi_prop_))) { + if (ncvs_ == 1 || (rand_.RandU01() < (multi_prop_))) + { - if (b_virial_) { + if (b_virial_) + { // apply virial regularization // P * dP/dcoupling // coupling is already included in virial term due to plumed propogating from bias to forces // thus we need to divide by it to get the derivative (since force is linear in coupling) if (fabs(set_coupling_[i]) > 0.000000001) // my heuristic for if EDS has started to prevent / 0 // scale^2 here is to align units - { step_size_[i] -= 2 * scale_[i] * scale_[i] * virial_scaling_ * pseudo_virial_sum_ * pseudo_virial_sum_ / set_coupling_[i]; - } } - if (step_size_[i] == 0) { + if (step_size_[i] == 0) continue; - } // clip gradient step_size_[i] = copysign(fmin(fabs(step_size_[i]), max_coupling_grad_[i]), step_size_[i]); @@ -998,7 +1070,9 @@ void EDS::update_bias() { // no negative sign because it's in step_size set_coupling_[i] += step_size_[i] * max_coupling_range_[i] / sqrt(coupling_accum_[i]); coupling_rate_[i] = (set_coupling_[i] - current_coupling_[i]) / update_period_; - } else { + } + else + { // do not change the bias coupling_rate_[i] = 0; } @@ -1008,51 +1082,59 @@ void EDS::update_bias() { reset_statistics(); } -void EDS::update() { +void EDS::update() +{ // adjust parameters according to EDS recipe update_calls_++; // if we aren't wating for the bias to equilibrate, set flag to collect data // want statistics before writing restart - if (!b_equil_ && update_period_ > 0) { + if (!b_equil_ && update_period_ > 0) update_statistics(); - } // write restart with correct statistics before bias update // check if we're ramping or doing normal updates and then restart if needed. The ramping check // is complicated because we could be frozen, finished ramping or not ramping. // The + 2 is so we have an extra line showing that the bias isn't changing (for my sanity and yours) - if (b_write_restart_) { + if (b_write_restart_) + { if (getStep() == 0 || ((update_period_ < 0 && !b_freeze_ && update_calls_ <= fabs(update_period_) + 2) || - (update_period_ > 0 && update_calls_ % update_period_ == 0))) { + (update_period_ > 0 && update_calls_ % update_period_ == 0))) writeOutRestart(); - } } int b_finished_equil_flag = 1; // assume forces already applied and saved // are we ramping to a constant value and not done equilibrating? - if (update_period_ < 0) { - if (update_calls_ <= fabs(update_period_) && !b_freeze_) { - for (unsigned int i = 0; i < ncvs_; ++i) { + if (update_period_ < 0) + { + if (update_calls_ <= fabs(update_period_) && !b_freeze_) + { + for (unsigned int i = 0; i < ncvs_; ++i) current_coupling_[i] += (target_coupling_[i] - set_coupling_[i]) / fabs(update_period_); - } } // make sure we don't reset update calls b_finished_equil_flag = 0; - } else if (update_period_ == 0) { - // do we have a no-update case? + } + else if (update_period_ == 0) + { // do we have a no-update case? // not updating // pass - } else if (b_equil_) { + } + else if (b_equil_) + { // equilibrating // check if we've reached the setpoint - for (unsigned int i = 0; i < ncvs_; ++i) { - if (coupling_rate_[i] == 0 || pow(current_coupling_[i] - set_coupling_[i], 2) < pow(coupling_rate_[i], 2)) { + for (unsigned int i = 0; i < ncvs_; ++i) + { + if (coupling_rate_[i] == 0 || pow(current_coupling_[i] - set_coupling_[i], 2) < pow(coupling_rate_[i], 2)) + { b_finished_equil_flag &= 1; - } else { + } + else + { current_coupling_[i] += coupling_rate_[i]; b_finished_equil_flag = 0; } @@ -1060,13 +1142,15 @@ void EDS::update() { } // reduce all the flags - if (b_equil_ && b_finished_equil_flag) { + if (b_equil_ && b_finished_equil_flag) + { b_equil_ = false; update_calls_ = 0; } // Now we update coupling constant, if necessary - if (!b_equil_ && update_period_ > 0 && update_calls_ == update_period_ && !b_freeze_) { + if (!b_equil_ && update_period_ > 0 && update_calls_ == update_period_ && !b_freeze_) + { update_bias(); update_calls_ = 0; avg_coupling_count_++; @@ -1074,16 +1158,19 @@ void EDS::update() { } // close update if // pass couplings out so they are accessible - for (unsigned int i = 0; i < ncvs_; ++i) { + for (unsigned int i = 0; i < ncvs_; ++i) + { out_coupling_[i]->set(current_coupling_[i]); } } -EDS::~EDS() { +EDS::~EDS() +{ out_restart_.close(); } -void EDS::turnOnDerivatives() { +void EDS::turnOnDerivatives() +{ // do nothing // this is to avoid errors triggered when a bias is used as a CV // (This is done in ExtendedLagrangian.cpp) diff --git a/src/fisst/FISST.cpp b/src/fisst/FISST.cpp index fb330b003c..70bcfd124f 100644 --- a/src/fisst/FISST.cpp +++ b/src/fisst/FISST.cpp @@ -222,15 +222,14 @@ FISST::FISST(const ActionOptions&ao): reset_period_(0), observable_freq_(0), kbt_(0.0), - value_force2_(NULL) { - if(ncvs_==0) { + value_force2_(NULL) +{ + if(ncvs_==0) error("Must specify at least one CV with ARG"); - } //temporary - if(ncvs_>1) { + if(ncvs_>1) error("FISST only supports using one CV right now"); - } addComponent("force2"); componentIsNotPeriodic("force2"); @@ -261,9 +260,8 @@ FISST::FISST(const ActionOptions&ao): parse("IN_RESTART",in_restart_name_); checkRead(); - if(center_.size() != ncvs_) { + if(center_.size() != ncvs_) error("Must have same number of CENTER arguments as ARG arguments"); - } if(in_restart_name_ != "") { b_restart_ = true; @@ -271,9 +269,8 @@ FISST::FISST(const ActionOptions&ao): readInRestart(); } else { - if(! kbt_ > 0.0) { + if(! kbt_ > 0.0) kbt_ = plumed.getAtoms().getKbT(); - } //in driver, this results in kbt of 0 if(kbt_ == 0) { @@ -291,9 +288,7 @@ FISST::FISST(const ActionOptions&ao): } log.printf("\n"); observable_weight_.resize(n_interpolation_); - for(unsigned int i = 0; i0) { - if(observable_freq_==0) { - observable_freq_ = period_; - } + if(observable_freq_==0) observable_freq_ = period_; log.printf(" writing observable information every %i steps to file %s with format %s\n",observable_freq_,out_observable_name_.c_str(), fmt_.c_str()); b_write_observable_ = true; setupOutObservable(); @@ -361,13 +351,11 @@ FISST::FISST(const ActionOptions&ao): void FISST::NormalizeForceWeights() { double denom = 0.0; - for(unsigned i=0; i0) { - out_restart_.addConstantField("reset_period").printField("reset_period",reset_period_); - } + if(reset_period_>0) out_restart_.addConstantField("reset_period").printField("reset_period",reset_period_); out_restart_.addConstantField("min_force").printField("min_force",min_force_); out_restart_.addConstantField("max_force").printField("max_force",max_force_); } @@ -524,19 +500,16 @@ void FISST::writeOutObservable() { void FISST::calculate() { if(getStep() == 0 ) { - if(b_write_restart_) { - writeOutRestart(); - } - if(b_write_observable_) { - writeOutObservable(); - } + if(b_write_restart_) writeOutRestart(); + if(b_write_observable_) writeOutObservable(); } if(! b_freeze_) { if(b_restart_ && b_first_restart_sample_) { //dont' update statistics if restarting and first sample b_first_restart_sample_ = false; - } else { + } + else { update_statistics(); } } @@ -545,9 +518,7 @@ void FISST::calculate() { //check about writing restart file if(getStep()>0 && getStep()%period_==0) { - if(b_write_restart_) { - writeOutRestart(); - } + if(b_write_restart_) writeOutRestart(); } if(getStep()>0 && getStep()%observable_freq_==0) { if(b_write_observable_) { @@ -588,14 +559,16 @@ void FISST::update_statistics() { int step = getStep(); if(reset_period_>0 && step>0 && step%reset_period_==0) { n_samples_=1; - } else { + } + else { n_samples_++; } double d_n_samples = (double)n_samples_; for(unsigned int i = 0; i < ncvs_; ++i) { double Q_i = difference(i, center_[i], getArgument(i)); - for(unsigned int j=0; j coefficients; std::vector parameters; @@ -90,8 +91,7 @@ PLUMED_REGISTER_ACTION(Combine,"COMBINE") void Combine::registerKeywords(Keywords& keys) { Function::registerKeywords(keys); - keys.use("ARG"); - keys.use("PERIODIC"); + keys.use("ARG"); keys.use("PERIODIC"); keys.add("compulsory","COEFFICIENTS","1.0","the coefficients of the arguments in your function"); keys.add("compulsory","PARAMETERS","0.0","the parameters of the arguments in your function"); keys.add("compulsory","POWERS","1.0","the powers to which you are raising each of the arguments in your function"); @@ -104,51 +104,39 @@ Combine::Combine(const ActionOptions&ao): normalize(false), coefficients(getNumberOfArguments(),1.0), parameters(getNumberOfArguments(),0.0), - powers(getNumberOfArguments(),1.0) { + powers(getNumberOfArguments(),1.0) +{ parseVector("COEFFICIENTS",coefficients); - if(coefficients.size()!=static_cast(getNumberOfArguments())) { + if(coefficients.size()!=static_cast(getNumberOfArguments())) error("Size of COEFFICIENTS array should be the same as number for arguments"); - } parseVector("PARAMETERS",parameters); - if(parameters.size()!=static_cast(getNumberOfArguments())) { + if(parameters.size()!=static_cast(getNumberOfArguments())) error("Size of PARAMETERS array should be the same as number for arguments"); - } parseVector("POWERS",powers); - if(powers.size()!=static_cast(getNumberOfArguments())) { + if(powers.size()!=static_cast(getNumberOfArguments())) error("Size of POWERS array should be the same as number for arguments"); - } parseFlag("NORMALIZE",normalize); if(normalize) { double n=0.0; - for(unsigned i=0; i expression_deriv; std::vector var; @@ -211,8 +212,7 @@ PLUMED_REGISTER_ACTION(Custom,"MATHEVAL") void Custom::registerKeywords(Keywords& keys) { Function::registerKeywords(keys); - keys.use("ARG"); - keys.use("PERIODIC"); + keys.use("ARG"); keys.use("PERIODIC"); keys.add("compulsory","FUNC","the function you wish to evaluate"); keys.add("optional","VAR","the names to give each of the arguments in the function. If you have up to three arguments in your function you can use x, y and z to refer to them. Otherwise you must use this flag to give your variables names."); } @@ -224,35 +224,26 @@ Custom::Custom(const ActionOptions&ao): values(getNumberOfArguments()), names(getNumberOfArguments()), lepton_ref(getNumberOfArguments(),nullptr), - lepton_ref_deriv(getNumberOfArguments()*getNumberOfArguments(),nullptr) { + lepton_ref_deriv(getNumberOfArguments()*getNumberOfArguments(),nullptr) +{ parseVector("VAR",var); if(var.size()==0) { var.resize(getNumberOfArguments()); - if(getNumberOfArguments()>3) { + if(getNumberOfArguments()>3) error("Using more than 3 arguments you should explicitly write their names with VAR"); - } - if(var.size()>0) { - var[0]="x"; - } - if(var.size()>1) { - var[1]="y"; - } - if(var.size()>2) { - var[2]="z"; - } + if(var.size()>0) var[0]="x"; + if(var.size()>1) var[1]="y"; + if(var.size()>2) var[2]="z"; } - if(var.size()!=getNumberOfArguments()) { + if(var.size()!=getNumberOfArguments()) error("Size of VAR array should be the same as number of arguments"); - } parse("FUNC",func); addValueWithDerivatives(); checkRead(); log.printf(" with function : %s\n",func.c_str()); log.printf(" with variables :"); - for(unsigned i=0; i0.0) { - kbt=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt=plumed.getAtoms().getKbT(); - } - if(kbt==0.0) { - error("Unless the MD engine passes the temperature to plumed, with REWEIGHT you must specify TEMP"); - } + if(temp>0.0) kbt=plumed.getAtoms().getKBoltzmann()*temp; + else kbt=plumed.getAtoms().getKbT(); + if(kbt==0.0) error("Unless the MD engine passes the temperature to plumed, with REWEIGHT you must specify TEMP"); } parse("MOMENT",moment); - if(moment==1) { - error("MOMENT can be any number but for 0 and 1"); - } - if(moment!=0) { - do_moments=true; - } + if(moment==1) error("MOMENT can be any number but for 0 and 1"); + if(moment!=0) do_moments=true; parseFlag("CENTRAL", do_central); - if(!do_moments&&do_central) { - error("To calculate a CENTRAL moment you need to define for which MOMENT"); - } + if(!do_moments&&do_central) error("To calculate a CENTRAL moment you need to define for which MOMENT"); parse("POWER",power); - if(power==1) { - error("POWER can be any number but for 0 and 1"); - } - if(power!=0) { - do_powers=true; - } + if(power==1) error("POWER can be any number but for 0 and 1"); + if(power!=0) do_powers=true; checkRead(); @@ -135,15 +122,11 @@ Ensemble::Ensemble(const ActionOptions&ao): } comm.Bcast(ens_dim,0); comm.Bcast(my_repl,0); - if(ens_dim<2) { - log.printf("WARNING: ENSEMBLE with one replica is not doing any averaging!\n"); - } + if(ens_dim<2) log.printf("WARNING: ENSEMBLE with one replica is not doing any averaging!\n"); // prepare output components, the number depending on reweighing or not narg = getNumberOfArguments(); - if(do_reweight) { - narg--; - } + if(do_reweight) narg--; // these are the averages for(unsigned i=0; i1) { - multi_sim_comm.Sum(&bias[0], ens_dim); - } + if(ens_dim>1) multi_sim_comm.Sum(&bias[0], ens_dim); } comm.Sum(&bias[0], ens_dim); const double maxbias = *(std::max_element(bias.begin(), bias.end())); @@ -208,12 +181,8 @@ void Ensemble::calculate() { std::vector dmean(narg,fact); // calculate the mean if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&mean[0], narg); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&mean[0], narg); } comm.Sum(&mean[0], narg); @@ -230,9 +199,7 @@ void Ensemble::calculate() { v_moment[i] = tmp*getArgument(i); dv_moment[i] = moment*tmp; } - if(ens_dim>1) { - multi_sim_comm.Sum(&v_moment[0], narg); - } + if(ens_dim>1) multi_sim_comm.Sum(&v_moment[0], narg); } else { for(unsigned i=0; i1) { - multi_sim_comm.Sum(&v_moment[0], narg); - } + if(ens_dim>1) multi_sim_comm.Sum(&v_moment[0], narg); } else { for(unsigned i=0; i strings; Tools::getParsedLine(input, strings); - if (strings.empty()) { + if (strings.empty()) continue; - } std::vector colvarLine; double value; int max = columns.empty() ? strings.size() : columns.size(); - for (int i = 0; i < max; ++i) { + for (int i = 0; i < max; ++i) + { int col = columns.empty() ? i : columns[i]; // If no columns have been entered, ignore the first (time) and take the rest - if (columns.empty() && i == 0) { + if (columns.empty() && i == 0) continue; - } Tools::convert(strings[col], value); colvarLine.push_back(value); @@ -172,7 +171,8 @@ FuncPathGeneral::FuncPathGeneral(const ActionOptions&ao): Action(ao), Function(ao), neigh_size(-1), - neigh_stride(-1.) { + neigh_stride(-1.) +{ parse("LAMBDA", lambda); parse("NEIGH_SIZE", neigh_size); parse("NEIGH_STRIDE", neigh_stride); @@ -181,13 +181,11 @@ FuncPathGeneral::FuncPathGeneral(const ActionOptions&ao): parseVector("COLUMNS", columns); checkRead(); log.printf(" lambda is %f\n", lambda); - if (getNumberOfArguments() != coefficients.size()) { + if (getNumberOfArguments() != coefficients.size()) plumed_merror("The numbers of coefficients and CVs are different!"); - } if (!columns.empty()) { - if (columns.size() != coefficients.size()) { + if (columns.size() != coefficients.size()) plumed_merror("The numbers of coefficients and columns are different!"); - } } log.printf(" Consistency check completed! Your path cvs look good!\n"); @@ -207,10 +205,8 @@ FuncPathGeneral::FuncPathGeneral(const ActionOptions&ao): log.printf(" Neighbour list NOT enabled \n"); } - addComponentWithDerivatives("s"); - componentIsNotPeriodic("s"); - addComponentWithDerivatives("z"); - componentIsNotPeriodic("z"); + addComponentWithDerivatives("s"); componentIsNotPeriodic("s"); + addComponentWithDerivatives("z"); componentIsNotPeriodic("z"); // Initialise vectors std::vector temp (coefficients.size()); @@ -222,9 +218,8 @@ FuncPathGeneral::FuncPathGeneral(const ActionOptions&ao): } // Store the arguments - for (unsigned i=0; igetDomain(min_lim, max_lim); domains.push_back((max_lim - min_lim) / 2); - } else { - domains.push_back(-1.); } + else + domains.push_back(-1.); } } @@ -254,9 +249,8 @@ void FuncPathGeneral::calculate() { if (neighpair.empty()) { // Resize at the first step neighpair.resize(path_cv_values.size()); - for (unsigned i = 0; i < path_cv_values.size(); ++i) { + for (unsigned i = 0; i < path_cv_values.size(); ++i) neighpair[i].first = i; - } } Value* val_s_path=getPntrToComponent("s"); @@ -267,12 +261,10 @@ void FuncPathGeneral::calculate() { for (pairiter it = neighpair.begin(); it != neighpair.end(); ++it) { diff = (value - path_cv_values[(*it).first][j]); if (domains[j] > 0) { - if (diff > domains[j]) { + if (diff > domains[j]) diff -= 2 * domains[j]; - } - if (diff < -domains[j]) { + if (diff < -domains[j]) diff += 2 * domains[j]; - } } (*it).second += Tools::fastpow(coefficients[j] * diff, 2); numerators[(*it).first][j] = 2 * Tools::fastpow(coefficients[j], 2) * diff; @@ -286,9 +278,7 @@ void FuncPathGeneral::calculate() { partition += expdist; } - if(partition==0.0) { - partition=std::numeric_limits::min(); - } + if(partition==0.0) partition=std::numeric_limits::min(); s_path /= partition; val_s_path->set(s_path); @@ -331,17 +321,15 @@ void FuncPathGeneral::prepare() { // Resize the effective list neighpair.resize(neigh_size); log.printf(" NEIGHBOUR LIST NOW INCLUDES INDICES: "); - for (int i = 0; i < neigh_size; ++i) { + for (int i = 0; i < neigh_size; ++i) log.printf(" %i ",neighpair[i].first); - } log.printf(" \n"); } else { if (int(getStep()) % int(neigh_stride / getTimeStep()) == 0) { log.printf(" Time %f : recalculating full neighbour list \n", getStep() * getTimeStep()); neighpair.resize(path_cv_values.size()); - for (unsigned i = 0; i < path_cv_values.size(); ++i) { + for (unsigned i = 0; i < path_cv_values.size(); ++i) neighpair[i].first = i; - } } } } diff --git a/src/function/FuncPathMSD.cpp b/src/function/FuncPathMSD.cpp index 09bb3edaae..901fd1d869 100644 --- a/src/function/FuncPathMSD.cpp +++ b/src/function/FuncPathMSD.cpp @@ -192,11 +192,9 @@ class FuncPathMSD : public Function { } // now sort according the second value std::sort(order.begin(), order.end(), ordering()); - std::vector vv(v.size()); - n=0; + std::vector vv(v.size()); n=0; for (const auto & it : order) { - vv[n]=it.first; - n++; + vv[n]=it.first; n++; } return vv; } @@ -233,7 +231,8 @@ FuncPathMSD::FuncPathMSD(const ActionOptions&ao): Action(ao), Function(ao), neigh_size(-1), - neigh_stride(-1.) { + neigh_stride(-1.) +{ parse("LAMBDA",lambda); parse("NEIGH_SIZE",neigh_size); @@ -242,14 +241,10 @@ FuncPathMSD::FuncPathMSD(const ActionOptions&ao): log.printf(" lambda is %f\n",lambda); // list the action involved and check the type std::string myname=getPntrToArgument(0)->getPntrToAction()->getName(); - if(myname!="RMSD"&&myname!="CONTACTMAP"&&myname!="DISTANCE"&&myname!="PIV") { - error("One or more of your arguments is not of RMSD/CONTACTMAP/DISTANCE/PIV type!!!"); - } + if(myname!="RMSD"&&myname!="CONTACTMAP"&&myname!="DISTANCE"&&myname!="PIV") error("One or more of your arguments is not of RMSD/CONTACTMAP/DISTANCE/PIV type!!!"); for(unsigned i=1; igetPntrToAction()->getName()!=myname ) { - error("mismatch between the types of arguments"); - } + if( getPntrToArgument(i)->getPntrToAction()->getName()!=myname ) error("mismatch between the types of arguments"); } log.printf(" Consistency check completed! Your path cvs look good!\n"); // do some neighbor printout @@ -265,19 +260,14 @@ FuncPathMSD::FuncPathMSD(const ActionOptions&ao): log.printf(" Neighbor list NOT enabled \n"); } - addComponentWithDerivatives("s"); - componentIsNotPeriodic("s"); - addComponentWithDerivatives("z"); - componentIsNotPeriodic("z"); + addComponentWithDerivatives("s"); componentIsNotPeriodic("s"); + addComponentWithDerivatives("z"); componentIsNotPeriodic("z"); // now backup the arguments - for(unsigned i=0; i argstocall; diff --git a/src/function/FuncSumHills.cpp b/src/function/FuncSumHills.cpp index 299f9c32ec..e2ec20f658 100644 --- a/src/function/FuncSumHills.cpp +++ b/src/function/FuncSumHills.cpp @@ -77,8 +77,7 @@ FilesHandler::FilesHandler(const std::vector &filenames, const bool // note that the FileHandler is completely transparent respect to the biasrepresentation // no check are made at this level bool FilesHandler::readBunch(BiasRepresentation *br, int stride = -1) { - bool morefiles; - morefiles=true; + bool morefiles; morefiles=true; if(parallelread) { (*log)<<" doing parallelread \n"; plumed_merror("parallelread is not yet implemented !!!"); @@ -90,8 +89,7 @@ bool FilesHandler::readBunch(BiasRepresentation *br, int stride = -1) { ff=ifiles[beingread].get(); if(!isopen) { (*log)<<" opening file "<open(filenames[beingread]); - isopen=true; + ff->open(filenames[beingread]); isopen=true; } int n=0; while(true) { @@ -112,8 +110,7 @@ bool FilesHandler::readBunch(BiasRepresentation *br, int stride = -1) { (*log)<<" now total "<getNumberOfKernels()<<" kernels \n"; beingread++; if(beingreadopen(filenames[beingread]); + ff=ifiles[beingread].get(); ff->open(filenames[beingread]); (*log)<<" opening file "<scanField("time",dummy)) { //(*log)<<" scanning one hill: "<FieldExist("biasf")) { - ifile->scanField("biasf",dummy); - } - if(ifile->FieldExist("clock")) { - ifile->scanField("clock",dummy); - } + if(ifile->FieldExist("biasf")) ifile->scanField("biasf",dummy); + if(ifile->FieldExist("clock")) ifile->scanField("clock",dummy); // keep this intermediate function in case you need to parse more data in the future br->pushKernel(ifile); //(*log)<<" read hill\n"; - if(br->hasSigmaInInput()) { - ifile->allowIgnoredFields(); - } + if(br->hasSigmaInInput())ifile->allowIgnoredFields(); ifile->scanField(); return true; } else { @@ -186,7 +173,8 @@ double mylogder( double v1 ) { class FuncSumHills : - public Function { + public Function +{ std::vector hillsFiles,histoFiles; std::vector proj; int initstride; @@ -250,7 +238,8 @@ FuncSumHills::FuncSumHills(const ActionOptions&ao): lowI_(-1.), uppI_(-1.), beta(-1.), - fmt("%14.9f") { + fmt("%14.9f") +{ // format parse("FMT",fmt); @@ -259,62 +248,44 @@ FuncSumHills::FuncSumHills(const ActionOptions&ao): // Grid Stuff std::vector gmin; parseVector("GRID_MIN",gmin); - if(gmin.size()!=getNumberOfArguments() && gmin.size()!=0) { - error("not enough values for GRID_MIN"); - } + if(gmin.size()!=getNumberOfArguments() && gmin.size()!=0) error("not enough values for GRID_MIN"); plumed_massert(gmin.size()==getNumberOfArguments() || gmin.size()==0,"need GRID_MIN argument for this") ; std::vector gmax; parseVector("GRID_MAX",gmax); - if(gmax.size()!=getNumberOfArguments() && gmax.size()!=0) { - error("not enough values for GRID_MAX"); - } + if(gmax.size()!=getNumberOfArguments() && gmax.size()!=0) error("not enough values for GRID_MAX"); plumed_massert(gmax.size()==getNumberOfArguments() || gmax.size()==0,"need GRID_MAX argument for this") ; std::vector gbin; std::vector gspacing; parseVector("GRID_BIN",gbin); plumed_massert(gbin.size()==getNumberOfArguments() || gbin.size()==0,"need GRID_BIN argument for this") ; - if(gbin.size()!=getNumberOfArguments() && gbin.size()!=0) { - error("not enough values for GRID_BIN"); - } + if(gbin.size()!=getNumberOfArguments() && gbin.size()!=0) error("not enough values for GRID_BIN"); parseVector("GRID_SPACING",gspacing); plumed_massert(gspacing.size()==getNumberOfArguments() || gspacing.size()==0,"need GRID_SPACING argument for this") ; - if(gspacing.size()!=getNumberOfArguments() && gspacing.size()!=0) { - error("not enough values for GRID_SPACING"); - } + if(gspacing.size()!=getNumberOfArguments() && gspacing.size()!=0) error("not enough values for GRID_SPACING"); if(gspacing.size()!=0 && gbin.size()==0) { log<<" The number of bins will be estimated from GRID_SPACING\n"; } else if(gspacing.size()!=0 && gbin.size()!=0) { log<<" You specified both GRID_BIN and GRID_SPACING\n"; log<<" The more conservative (highest) number of bins will be used for each variable\n"; } - if(gspacing.size()!=0) - for(unsigned i=0; i tmpI(2); parseVector("INTERVAL",tmpI); - if(tmpI.size()!=2&&tmpI.size()!=0) { - error("both a lower and an upper limits must be provided with INTERVAL"); - } else if(tmpI.size()==2) { + if(tmpI.size()!=2&&tmpI.size()!=0) error("both a lower and an upper limits must be provided with INTERVAL"); + else if(tmpI.size()==2) { lowI_=tmpI.at(0); uppI_=tmpI.at(1); - if(getNumberOfArguments()!=1) { - error("INTERVAL limits correction works only for monodimensional metadynamics!"); - } - if(uppI_ histoSigma; if(integratehisto) { parseVector("HISTOSIGMA",histoSigma); - for(unsigned i=0; igetName()); - } + for(unsigned i=0; igetName()); } // add some automatic hills width: not in case stride is defined @@ -385,17 +342,13 @@ FuncSumHills::FuncSumHills(const ActionOptions&ao): log<<" No boundaries defined: need to do a prescreening of hills \n"; std::vector tmphillsvalues, tmphistovalues; if(integratehills) { - for(unsigned i=0; igetName(); for(unsigned j=0; j0.,"if you make a projection or a histogram correction then you need KT flag!"); beta=1./beta; @@ -465,21 +416,16 @@ FuncSumHills::FuncSumHills(const ActionOptions&ao): // output suffix or names if(initstride<0) { log<<" Doing only one integration: no stride \n"; - outhills="fes.dat"; - outhisto="histo.dat"; - } else { - outhills="fes_"; - outhisto="histo_"; + outhills="fes.dat"; outhisto="histo.dat"; + } + else { + outhills="fes_"; outhisto="histo_"; log<<" Doing integration slices every "<getName(); for(unsigned j=0; jsetRescaledToBias(true); log<<" required the -bias instead of the free energy \n"; - if(initstride<0) { - outhills="negativebias.dat"; - } else { - outhills="negativebias_"; - } + if(initstride<0) {outhills="negativebias.dat";} + else {outhills="negativebias_";} } } parse("OUTHILLS",outhills); parse("OUTHISTO",outhisto); - if(integratehills) { - log<<" output file for fes/bias is : "< hillsHandler; std::unique_ptr histoHandler; - if(integratehills) { - hillsHandler=Tools::make_unique(hillsFiles,parallelread,*this, log); - } - if(integratehisto) { - histoHandler=Tools::make_unique(histoFiles,parallelread,*this, log); - } + if(integratehills) hillsHandler=Tools::make_unique(hillsFiles,parallelread,*this, log); + if(integratehisto) histoHandler=Tools::make_unique(histoFiles,parallelread,*this, log); // Stopwatch is logged when it goes out of scope Stopwatch sw(log); @@ -568,27 +501,18 @@ FuncSumHills::FuncSumHills(const ActionOptions&ao): // read a number of hills and put in the bias representation int nfiles=0; - bool ibias=integratehills; - bool ihisto=integratehisto; + bool ibias=integratehills; bool ihisto=integratehisto; while(true) { if( integratehills && ibias ) { - if(nohistory) { - biasrep->clear(); - log<<" clearing history before reading a new block\n"; - }; + if(nohistory) {biasrep->clear(); log<<" clearing history before reading a new block\n";}; log<<" reading hills: \n"; - ibias=hillsHandler->readBunch(biasrep.get(),initstride) ; - log<<"\n"; + ibias=hillsHandler->readBunch(biasrep.get(),initstride) ; log<<"\n"; } if( integratehisto && ihisto ) { - if(nohistory) { - historep->clear(); - log<<" clearing history before reading a new block\n"; - }; + if(nohistory) {historep->clear(); log<<" clearing history before reading a new block\n";}; log<<" reading histogram: \n"; - ihisto=histoHandler->readBunch(historep.get(),initstride) ; - log<<"\n"; + ihisto=histoHandler->readBunch(historep.get(),initstride) ; log<<"\n"; } // dump: need to project? @@ -600,27 +524,17 @@ FuncSumHills::FuncSumHills(const ActionOptions&ao): BiasWeight Bw(beta); Grid biasGrid=*(biasrep->getGridPtr()); Grid smallGrid=biasGrid.project(proj,&Bw); - OFile gridfile; - gridfile.link(*this); - std::ostringstream ostr; - ostr<0) { - myout=outhills+ostr.str()+".dat" ; - } else { - myout=outhills; - } + if(initstride>0) { myout=outhills+ostr.str()+".dat" ;} else {myout=outhills;} log<<" Bias: Writing subgrid on file "<getGridPtr()); - OFile gridfile; - gridfile.link(*this); - std::ostringstream ostr; - ostr<0) { - myout=outhisto+ostr.str()+".dat" ; - } else { - myout=outhisto; - } + if(initstride>0) { myout=outhisto+ostr.str()+".dat" ;} else {myout=outhisto;} log<<" Histo: Writing subgrid on file "<getGridPtr()); biasGrid.scaleAllValuesAndDerivatives(-1.); - OFile gridfile; - gridfile.link(*this); - std::ostringstream ostr; - ostr<0) { - myout=outhills+ostr.str()+".dat" ; - } else { - myout=outhills; - } + if(initstride>0) { myout=outhills+ostr.str()+".dat" ;} else {myout=outhills;} log<<" Writing full grid on file "<0) { - myout=outhisto+ostr.str()+".dat" ; - } else { - myout=outhisto; - } + if(initstride>0) { myout=outhisto+ostr.str()+".dat" ;} else {myout=outhisto;} log<<" Writing full grid on file "<resizeDerivatives(getNumberOfArguments()); } -void Function::apply() { +void Function::apply() +{ const unsigned noa=getNumberOfArguments(); const unsigned ncp=getNumberOfComponents(); const unsigned cgs=comm.Get_size(); @@ -86,26 +86,16 @@ void Function::apply() { for(unsigned i=rank; iapplyForce(forces)) { at_least_one_forced+=1; - for(unsigned j=0; j0&&ncp>4*cgs) { - comm.Sum(&f[0],noa); - comm.Sum(at_least_one_forced); - } + if(noa>0&&ncp>4*cgs) { comm.Sum(&f[0],noa); comm.Sum(at_least_one_forced); } - if(at_least_one_forced>0) - for(unsigned i=0; iaddForce(f[i]); - } + if(at_least_one_forced>0) for(unsigned i=0; iaddForce(f[i]); } } diff --git a/src/function/Function.h b/src/function/Function.h index 39ebd4b532..51dce83612 100644 --- a/src/function/Function.h +++ b/src/function/Function.h @@ -36,7 +36,8 @@ This is the abstract base class to use for implementing new CV function, within class Function: public ActionWithValue, - public ActionWithArguments { + public ActionWithArguments +{ protected: void setDerivative(int,double); void setDerivative(Value*,int,double); diff --git a/src/function/LocalEnsemble.cpp b/src/function/LocalEnsemble.cpp index 7ffc062a27..2aa79547c6 100644 --- a/src/function/LocalEnsemble.cpp +++ b/src/function/LocalEnsemble.cpp @@ -74,7 +74,8 @@ res: RESTRAINT ARG=stca.*,stcb.*,stco.*,sthn.*,stnh.* AT=0.,0.,0.,0.,0. KAPPA=0. class LocalEnsemble : - public Function { + public Function +{ unsigned ens_dim; unsigned narg; public: @@ -96,31 +97,22 @@ void LocalEnsemble::registerKeywords(Keywords& keys) { LocalEnsemble::LocalEnsemble(const ActionOptions&ao): Action(ao), Function(ao), - ens_dim(0) { + ens_dim(0) +{ parse("NUM",ens_dim); - if(ens_dim==0) { - error("NUM should be greater or equal to 1"); - } + if(ens_dim==0) error("NUM should be greater or equal to 1"); std::vector arg; int oldsize=-1; for(unsigned i=1; i<=ens_dim; ++i ) { std::vector larg; - if(!parseArgumentList("ARG",i,larg)) { - break; - } - for(unsigned j=0; j(larg.size())) { - error("In LOCALENSEMBLE you should have the same number of arguments for each ARG keyword"); - } + if(!parseArgumentList("ARG",i,larg)) break; + for(unsigned j=0; j(larg.size())) error("In LOCALENSEMBLE you should have the same number of arguments for each ARG keyword"); oldsize = larg.size(); if(!larg.empty()) { log.printf(" with arguments %u: ", i); - for(unsigned j=0; jgetName().c_str()); - } + for(unsigned j=0; jgetName().c_str()); log.printf("\n"); } } @@ -137,7 +129,8 @@ LocalEnsemble::LocalEnsemble(const ActionOptions&ao): log.printf(" averaging over %u replicas.\n", ens_dim); } -void LocalEnsemble::calculate() { +void LocalEnsemble::calculate() +{ const double fact = 1.0/static_cast(ens_dim); #pragma omp parallel for num_threads(OpenMP::getNumThreads()) for(unsigned i=0; i > points; public: explicit Piecewise(const ActionOptions&); @@ -91,25 +92,19 @@ void Piecewise::registerKeywords(Keywords& keys) { Piecewise::Piecewise(const ActionOptions&ao): Action(ao), - Function(ao) { + Function(ao) +{ for(int i=0;; i++) { std::vector pp; - if(!parseNumberedVector("POINT",i,pp) ) { - break; - } - if(pp.size()!=2) { - error("points should be in x,y format"); - } + if(!parseNumberedVector("POINT",i,pp) ) break; + if(pp.size()!=2) error("points should be in x,y format"); points.push_back(std::pair(pp[0],pp[1])); - if(i>0 && points[i].first<=points[i-1].first) { - error("points abscissas should be monotonously increasing"); - } + if(i>0 && points[i].first<=points[i-1].first) error("points abscissas should be monotonously increasing"); } for(unsigned i=0; iisPeriodic()) { + if(getPntrToArgument(i)->isPeriodic()) error("Cannot use PIECEWISE on periodic arguments"); - } if(getNumberOfArguments()==1) { addValueWithDerivatives(); @@ -123,9 +118,7 @@ Piecewise::Piecewise(const ActionOptions&ao): checkRead(); log.printf(" on points:"); - for(unsigned i=0; iisPeriodic()) { + if(getPntrToArgument(i)->isPeriodic()) error("Cannot sort periodic values (check argument "+s+")"); - } addComponentWithDerivatives(s); getPntrToComponent(i)->setNotPeriodic(); } diff --git a/src/function/Stats.cpp b/src/function/Stats.cpp index 8a33e0941e..11dc0f2fa3 100644 --- a/src/function/Stats.cpp +++ b/src/function/Stats.cpp @@ -54,7 +54,8 @@ PRINT ARG=d1,d2,d3,st.* class Stats : - public Function { + public Function +{ std::vector parameters; bool sqdonly; bool components; @@ -88,65 +89,46 @@ Stats::Stats(const ActionOptions&ao): Function(ao), sqdonly(false), components(false), - upperd(false) { + upperd(false) +{ parseVector("PARAMETERS",parameters); - if(parameters.size()!=static_cast(getNumberOfArguments())&&!parameters.empty()) { + if(parameters.size()!=static_cast(getNumberOfArguments())&&!parameters.empty()) error("Size of PARAMETERS array should be either 0 or the same as of the number of arguments in ARG1"); - } std::vector arg2; parseArgumentList("PARARG",arg2); if(!arg2.empty()) { - if(parameters.size()>0) { - error("It is not possible to use PARARG and PARAMETERS together"); - } - if(arg2.size()!=getNumberOfArguments()) { - error("Size of PARARG array should be the same as number for arguments in ARG"); - } + if(parameters.size()>0) error("It is not possible to use PARARG and PARAMETERS together"); + if(arg2.size()!=getNumberOfArguments()) error("Size of PARARG array should be the same as number for arguments in ARG"); for(unsigned i=0; iget()); - if(arg2[i]->hasDerivatives()==true) { - error("PARARG can only accept arguments without derivatives"); - } + if(arg2[i]->hasDerivatives()==true) error("PARARG can only accept arguments without derivatives"); } } - if(parameters.size()!=getNumberOfArguments()) { + if(parameters.size()!=getNumberOfArguments()) error("PARARG or PARAMETERS arrays should include the same number of elements as the arguments in ARG"); - } - if(getNumberOfArguments()<2) { - error("STATS need at least two arguments to be used"); - } + if(getNumberOfArguments()<2) error("STATS need at least two arguments to be used"); parseFlag("SQDEVSUM",sqdonly); parseFlag("SQDEV",components); parseFlag("UPPERDISTS",upperd); - if(sqdonly&&components) { - error("You cannot used SQDEVSUM and SQDEV at the sametime"); - } + if(sqdonly&&components) error("You cannot used SQDEVSUM and SQDEV at the sametime"); - if(components) { - sqdonly = true; - } + if(components) sqdonly = true; - if(!arg2.empty()) { - log.printf(" using %zu parameters from inactive actions:", arg2.size()); - } else { - log.printf(" using %zu parameters:", arg2.size()); - } - for(unsigned i=0; iset(dev*dev); @@ -189,9 +168,7 @@ void Stats::calculate() { } setDerivative(val,i,2.*dev); } - if(!components) { - val->set(nsqd); - } + if(!components) val->set(nsqd); } else { diff --git a/src/function/Target.cpp b/src/function/Target.cpp index 8d7cb21b13..7d5985f18b 100644 --- a/src/function/Target.cpp +++ b/src/function/Target.cpp @@ -121,16 +121,13 @@ Target::Target(const ActionOptions&ao): Action(ao), Function(ao), myvals(1,0), - mypack(0,0,myvals) { - std::string type; - parse("TYPE",type); - std::string reference; - parse("REFERENCE",reference); - checkRead(); - PDB pdb; - if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/plumed.getAtoms().getUnits().getLength()) ) { + mypack(0,0,myvals) +{ + std::string type; parse("TYPE",type); + std::string reference; parse("REFERENCE",reference); + checkRead(); PDB pdb; + if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/plumed.getAtoms().getUnits().getLength()) ) error("missing input file " + reference); - } // Use the base ActionWithArguments to expand things like a1.* expandArgKeywordInPDB( pdb ); @@ -152,17 +149,12 @@ Target::Target(const ActionOptions&ao): mypack.resize( myargs.size(), 0 ); // Create the value - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); } void Target::calculate() { - mypack.clear(); - double r=target->calculate( getArguments(), mypack, false ); - setValue(r); - for(unsigned i=0; icalculate( getArguments(), mypack, false ); setValue(r); + for(unsigned i=0; i > drotdpos(3,3); diff --git a/src/funnel/Funnel.cpp b/src/funnel/Funnel.cpp index 6e03d5baa0..bb696f88a3 100644 --- a/src/funnel/Funnel.cpp +++ b/src/funnel/Funnel.cpp @@ -202,9 +202,7 @@ Funnel::Funnel(const ActionOptions& ao): parse("SAFETY",safety); string file; parse("FILE",file); - if( file.length()==0 ) { - error("No funnel file name was specified"); - } + if( file.length()==0 ) error("No funnel file name was specified"); parse("SCALE",scale_); //Reading optional arguments @@ -277,18 +275,12 @@ Funnel::Funnel(const ActionOptions& ao): gridfile.open(file); BiasGrid_=Grid::create(funcl,getArguments(),gridfile,sparsegrid,spline,true); //not necessary anymore? gridfile.close(); - if(BiasGrid_->getDimension()!=getNumberOfArguments()) { - error("mismatch between dimensionality of input grid and number of arguments"); - } + if(BiasGrid_->getDimension()!=getNumberOfArguments()) error("mismatch between dimensionality of input grid and number of arguments"); for(unsigned i=0; iisPeriodic()!=BiasGrid_->getIsPeriodic()[i] ) { - error("periodicity mismatch between arguments and input bias"); - } + if( getPntrToArgument(i)->isPeriodic()!=BiasGrid_->getIsPeriodic()[i] ) error("periodicity mismatch between arguments and input bias"); } comm.Barrier(); - if(comm.Get_rank()==0 && walkers_mpi) { - multi_sim_comm.Barrier(); - } + if(comm.Get_rank()==0 && walkers_mpi) multi_sim_comm.Barrier(); log<<" Bibliography "<getName().c_str(), getPntrToArgument(1)->getName().c_str(), funcl.c_str(), getPntrToArgument(0)->getName().c_str(), getPntrToArgument(1)->getName().c_str()); - if (sphere==false) { - pof.printf("#! SET min_%s %f\n", getPntrToArgument(0)->getName().c_str(), MIN_S); - } else { - pof.printf("#! SET min_%s %f\n", getPntrToArgument(0)->getName().c_str(), -z_cc-safety); - } + if (sphere==false) pof.printf("#! SET min_%s %f\n", getPntrToArgument(0)->getName().c_str(), MIN_S); + else pof.printf("#! SET min_%s %f\n", getPntrToArgument(0)->getName().c_str(), -z_cc-safety); pof.printf("#! SET max_%s %f\n", getPntrToArgument(0)->getName().c_str(), MAX_S); pof.printf("#! SET nbins_%s %f\n", getPntrToArgument(0)->getName().c_str(), NBIN_S); pof.printf("#! SET periodic_%s false\n", getPntrToArgument(0)->getName().c_str()); @@ -349,75 +340,76 @@ void Funnel::createBIAS(const double& R_cyl, const double& z_cc, const double& a for(int is=0; is <= NBIN_S; is++) { if (sphere==false) { SS = MIN_S + is * DX_S; - } else { + } + else { SS = - z_cc - safety + is * DX_S; } bool cone = false; if (sphere==false) { - if(SS <= z_cc) { - cone = true; - } - } else { - if (SS <= sqrt(pow(z_cc,2)-pow(R_cyl,2))) { - cone = true; - } + if(SS <= z_cc) cone = true; + } + else { + if (SS <= sqrt(pow(z_cc,2)-pow(R_cyl,2))) cone = true; } //Set wall boundaries properly if(cone == true) { if(sphere==false) { Zmax = R_cyl + (z_cc - SS) * tg_alpha; - } else { + } + else { if (SS > -z_cc) { Zmax = sqrt(pow(z_cc,2) - pow(SS,2)); - } else { + } + else { Zmax = 0; } } - } else { - Zmax = R_cyl; } + else Zmax = R_cyl; for(int iz=0; iz <= NBIN_Z; iz++) { ZZ = MIN_Z + iz * DX_Z; //Inside or outside? bool inside; - if(ZZ < Zmax) { - inside = true; - } else { - inside = false; - } + if(ZZ < Zmax) inside = true; + else inside = false; if(inside == true) { POT = 0; FS = 0; FZ = 0; - } else { + } + else { if(cone == true) { if(sphere==false) { POT = 0.5 * KAPPA * (ZZ - Zmax) * (ZZ - Zmax); FZ = - KAPPA * (ZZ - Zmax); FS = - KAPPA * (ZZ - Zmax) * tg_alpha; - } else { + } + else { D = sqrt(pow(ZZ,2)+pow(SS,2)); d = D - z_cc; POT = 0.5 * KAPPA * pow(d,2); FZ = - KAPPA * d * ZZ / D; FS = - KAPPA * d * SS / D; } - } else { + } + else { if(sphere==false) { POT = 0.5 * KAPPA * (ZZ - Zmax) * (ZZ - Zmax); FZ = - KAPPA * (ZZ - Zmax); FS = 0; - } else { + } + else { D = sqrt(pow(ZZ,2)+pow(SS,2)); d = D - z_cc; if(ZZ>=R_cyl+slope*(SS-z_cc)) { POT = 0.5 * KAPPA * pow(d,2); FZ = - KAPPA * d * ZZ / D; FS = - KAPPA * d * SS / D; - } else { + } + else { POT = 0.5 * KAPPA * pow(sqrt(pow((ZZ+slope*z_cc-R_cyl)/slope,2)+pow(ZZ,2))- z_cc,2); FZ = - KAPPA*(sqrt(pow((ZZ+slope*z_cc-R_cyl)/slope,2)+pow(ZZ,2))-z_cc)* @@ -434,7 +426,8 @@ void Funnel::createBIAS(const double& R_cyl, const double& z_cc, const double& a pof.close(); } -void Funnel::calculate() { +void Funnel::calculate() +{ unsigned ncv=getNumberOfArguments(); vector cv(ncv), der(ncv); diff --git a/src/generic/Debug.cpp b/src/generic/Debug.cpp index 722d665e3e..e7fe458ef8 100644 --- a/src/generic/Debug.cpp +++ b/src/generic/Debug.cpp @@ -45,7 +45,8 @@ DEBUG logRequestedAtoms STRIDE=2 */ //+ENDPLUMEDOC class Debug: - public ActionPilot { + public ActionPilot +{ OFile ofile; bool logActivity; bool logRequestedAtoms; @@ -79,20 +80,12 @@ Debug::Debug(const ActionOptions&ao): logRequestedAtoms(false), novirial(false) { parseFlag("logActivity",logActivity); - if(logActivity) { - log.printf(" logging activity\n"); - } + if(logActivity) log.printf(" logging activity\n"); parseFlag("logRequestedAtoms",logRequestedAtoms); - if(logRequestedAtoms) { - log.printf(" logging requested atoms\n"); - } + if(logRequestedAtoms) log.printf(" logging requested atoms\n"); parseFlag("NOVIRIAL",novirial); - if(novirial) { - log.printf(" Switching off virial contribution\n"); - } - if(novirial) { - plumed.novirial=true; - } + if(novirial) log.printf(" Switching off virial contribution\n"); + if(novirial) plumed.novirial=true; parseFlag("DETAILED_TIMERS",detailedTimers); if(detailedTimers) { log.printf(" Detailed timing on\n"); @@ -116,24 +109,15 @@ void Debug::apply() { const ActionSet&actionSet(plumed.getActionSet()); int a=0; for(const auto & p : actionSet) { - if(dynamic_cast(p.get())) { - continue; - } - if(p->isActive()) { - a++; - } + if(dynamic_cast(p.get()))continue; + if(p->isActive()) a++; }; if(a>0) { ofile<<"activity at step "<(p.get())) { - continue; - } - if(p->isActive()) { - ofile.printf("+"); - } else { - ofile.printf("-"); - } + if(dynamic_cast(p.get()))continue; + if(p->isActive()) ofile.printf("+"); + else ofile.printf("-"); }; ofile.printf("\n"); }; @@ -144,9 +128,7 @@ void Debug::apply() { int n; plumed.cmd("createFullList",&n); plumed.cmd("getFullList",&l); - for(int i=0; i atoms; std::string file; parse("FILE",file); - if(file.length()==0) { - error("name out output file was not specified"); - } + if(file.length()==0) error("name out output file was not specified"); type=Tools::extension(file); log<<" file name "<0) { if(ntype!="xyz" && ntype!="gro" && ntype!="xtc" && ntype!="trr" - ) { - error("TYPE cannot be understood"); - } + ) error("TYPE cannot be understood"); log<<" file type enforced to be "<(this); if( moldat ) { log<<" MOLINFO DATA found with label " <getLabel()<<", using proper atom names\n"; names.resize(atoms.size()); - for(unsigned i=0; igetPDBsize()) { - names[i]=moldat->getAtomName(atoms[i]); - } + for(unsigned i=0; igetPDBsize()) names[i]=moldat->getAtomName(atoms[i]); residueNumbers.resize(atoms.size()); - for(unsigned i=0; igetPDBsize()) { - residueNumbers[i]=moldat->getResidueNumber(atoms[i]); - } + for(unsigned i=0; igetPDBsize()) residueNumbers[i]=moldat->getResidueNumber(atoms[i]); residueNames.resize(atoms.size()); - for(unsigned i=0; igetPDBsize()) { - residueNames[i]=moldat->getResidueName(atoms[i]); - } + for(unsigned i=0; igetPDBsize()) residueNames[i]=moldat->getResidueName(atoms[i]); } } @@ -281,10 +258,7 @@ void DumpAtoms::update() { for(unsigned i=0; i0) - if(names[i].length()>0) { - name=names[i].c_str(); - } + if(names.size()>0) if(names[i].length()>0) name=names[i].c_str(); of.printf(("%s "+fmt_xyz+" "+fmt_xyz+" "+fmt_xyz+"\n").c_str(),name,lenunit*getPosition(i)(0),lenunit*getPosition(i)(1),lenunit*getPosition(i)(2)); } } else if(type=="gro") { @@ -295,17 +269,10 @@ void DumpAtoms::update() { const char* defname="X"; const char* name=defname; unsigned residueNumber=0; - if(names.size()>0) - if(names[i].length()>0) { - name=names[i].c_str(); - } - if(residueNumbers.size()>0) { - residueNumber=residueNumbers[i]; - } + if(names.size()>0) if(names[i].length()>0) name=names[i].c_str(); + if(residueNumbers.size()>0) residueNumber=residueNumbers[i]; std::string resname=""; - if(residueNames.size()>0) { - resname=residueNames[i]; - } + if(residueNames.size()>0) resname=residueNames[i]; of.printf(("%5u%-5s%5s%5d"+fmt_gro_pos+fmt_gro_pos+fmt_gro_pos+"\n").c_str(), residueNumber%100000,resname.c_str(),name,getAbsoluteIndex(i).serial()%100000, lenunit*getPosition(i)(0),lenunit*getPosition(i)(1),lenunit*getPosition(i)(2)); @@ -321,25 +288,17 @@ void DumpAtoms::update() { int step=getStep(); float time=getTime()/plumed.getAtoms().getUnits().getTime(); float precision=Tools::fastpow(10.0,iprecision); - for(int i=0; i<3; i++) - for(int j=0; j<3; j++) { - box[i][j]=lenunit*t(i,j); - } + for(int i=0; i<3; i++) for(int j=0; j<3; j++) box[i][j]=lenunit*t(i,j); // here we cannot use a std::vector since it does not compile. // we thus use a std::unique_ptr auto pos = Tools::make_unique(natoms); - for(int i=0; igetPntrToAction())->turnOnDerivatives(); unsigned npar=getPntrToArgument(0)->getNumberOfDerivatives(); - if( npar==0 ) { - error("one or more arguments has no derivatives"); - } + if( npar==0 ) error("one or more arguments has no derivatives"); for(unsigned i=1; igetPntrToAction())->turnOnDerivatives(); - if( npar!=getPntrToArgument(i)->getNumberOfDerivatives() ) { - error("the number of derivatives must be the same in all values being dumped"); - } + if( npar!=getPntrToArgument(i)->getNumberOfDerivatives() ) error("the number of derivatives must be the same in all values being dumped"); } checkRead(); } diff --git a/src/generic/DumpForces.cpp b/src/generic/DumpForces.cpp index b3ba3ab13c..8fc1411f63 100644 --- a/src/generic/DumpForces.cpp +++ b/src/generic/DumpForces.cpp @@ -52,7 +52,8 @@ DUMPFORCES ARG=distance STRIDE=1 FILE=forces class DumpForces : public ActionPilot, - public ActionWithArguments { + public ActionWithArguments +{ std::string file; std::string fmt; OFile of; @@ -84,20 +85,17 @@ DumpForces::DumpForces(const ActionOptions&ao): Action(ao), ActionPilot(ao), ActionWithArguments(ao), - fmt("%15.10f") { + fmt("%15.10f") +{ parse("FILE",file); - if( file.length()==0 ) { - error("name of file was not specified"); - } + if( file.length()==0 ) error("name of file was not specified"); parse("FMT",fmt); fmt=" "+fmt; of.link(*this); of.open(file); log.printf(" on file %s\n",file.c_str()); log.printf(" with format %s\n",fmt.c_str()); - if( getNumberOfArguments()==0 ) { - error("no arguments have been specified"); - } + if( getNumberOfArguments()==0 ) error("no arguments have been specified"); checkRead(); } diff --git a/src/generic/DumpMassCharge.cpp b/src/generic/DumpMassCharge.cpp index 4b27d3a940..660c44412c 100644 --- a/src/generic/DumpMassCharge.cpp +++ b/src/generic/DumpMassCharge.cpp @@ -26,7 +26,8 @@ #include "core/PlumedMain.h" #include "core/Atoms.h" -namespace PLMD { +namespace PLMD +{ namespace generic { //+PLUMEDOC PRINTANALYSIS DUMPMASSCHARGE @@ -75,7 +76,8 @@ DUMPMASSCHARGE FILE=mcfile ATOMS=solute_ions class DumpMassCharge: public ActionAtomistic, - public ActionPilot { + public ActionPilot +{ std::string file; bool first; bool second; @@ -111,12 +113,11 @@ DumpMassCharge::DumpMassCharge(const ActionOptions&ao): first(true), second(true), print_masses(true), - print_charges(true) { + print_charges(true) +{ std::vector atoms; parse("FILE",file); - if(file.length()==0) { - error("name of output file was not specified"); - } + if(file.length()==0) error("name of output file was not specified"); log.printf(" output written to file %s\n",file.c_str()); parseAtomList("ATOMS",atoms); @@ -145,9 +146,7 @@ DumpMassCharge::DumpMassCharge(const ActionOptions&ao): checkRead(); log.printf(" printing the following atoms:" ); - for(unsigned i=0; i tmpActions=plumed.getActionSet().select(); - for(unsigned i=0; iexists(tmpActions[i]->getLabel()+".bias")) { - biases.push_back(tmpActions[i]); - } + for(unsigned i=0; iexists(tmpActions[i]->getLabel()+".bias")) biases.push_back(tmpActions[i]); //resize counters and displacements useful to communicate with MPI_Allgatherv indexCnt.resize(nProc); @@ -258,9 +250,7 @@ void EffectiveEnergyDrift::update() { for(int i=0; igetOutputQuantity("bias"); - } + for(unsigned i=0; igetOutputQuantity("bias"); plumed.comm.Sum(&eedSum,1); double effective = eedSum+bias-initialBias-plumed.getWork(); // this is to take into account ensemble averaging if(ensemble) { - if(plumed.comm.Get_rank()==0) { - plumed.multi_sim_comm.Sum(&effective,1); - } else { - effective=0.; - } + if(plumed.comm.Get_rank()==0) plumed.multi_sim_comm.Sum(&effective,1); + else effective=0.; plumed.comm.Sum(&effective,1); } output.fmtField(" %f"); diff --git a/src/generic/EndPlumed.cpp b/src/generic/EndPlumed.cpp index a3d5331bc0..8323d34599 100644 --- a/src/generic/EndPlumed.cpp +++ b/src/generic/EndPlumed.cpp @@ -52,7 +52,8 @@ PRINT ARG=d FILE=COLVAR STRIDE=1 */ //+ENDPLUMEDOC class EndPlumed: - public Action { + public Action +{ public: explicit EndPlumed(const ActionOptions&ao); /// Register all the relevant keywords for the action @@ -68,7 +69,8 @@ void EndPlumed::registerKeywords( Keywords& keys ) { } EndPlumed::EndPlumed(const ActionOptions&ao): - Action(ao) { + Action(ao) +{ checkRead(); plumed.setEndPlumed(); } diff --git a/src/generic/FitToTemplate.cpp b/src/generic/FitToTemplate.cpp index c5c7a1d3c5..7d3e63ff4e 100644 --- a/src/generic/FitToTemplate.cpp +++ b/src/generic/FitToTemplate.cpp @@ -170,7 +170,8 @@ the ligand. class FitToTemplate: public ActionPilot, public ActionAtomistic, - public ActionWithValue { + public ActionWithValue +{ std::string type; bool nopbc; std::vector weights; @@ -194,9 +195,7 @@ class FitToTemplate: static void registerKeywords( Keywords& keys ); void calculate() override; void apply() override; - unsigned getNumberOfDerivatives() override { - plumed_merror("You should not call this function"); - }; + unsigned getNumberOfDerivatives() override {plumed_merror("You should not call this function");}; }; PLUMED_REGISTER_ACTION(FitToTemplate,"FIT_TO_TEMPLATE") @@ -215,7 +214,8 @@ FitToTemplate::FitToTemplate(const ActionOptions&ao): ActionPilot(ao), ActionAtomistic(ao), ActionWithValue(ao), - nopbc(false) { + nopbc(false) +{ std::string reference; parse("REFERENCE",reference); type.assign("SIMPLE"); @@ -229,17 +229,14 @@ FitToTemplate::FitToTemplate(const ActionOptions&ao): PDB pdb; // read everything in ang and transform to nm if we are not in natural units - if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) { + if( !pdb.read(reference,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()) ) error("missing input file " + reference ); - } requestAtoms(pdb.getAtomNumbers()); log.printf(" found %zu atoms in input \n",pdb.getAtomNumbers().size()); log.printf(" with indices : "); for(unsigned i=0; i weights_measure=pdb.getBeta(); - n=0.0; - for(unsigned i=0; i(); @@ -290,8 +272,7 @@ FitToTemplate::FitToTemplate(const ActionOptions&ao): log<<" Ignoring PBCs when doing alignment, make sure your molecule is whole!calc_FitElements( getPositions(), rotation, drotdpos, centeredpositions, center_positions); setValue(r); diff --git a/src/generic/Flush.cpp b/src/generic/Flush.cpp index eddbd64897..374ba30c8f 100644 --- a/src/generic/Flush.cpp +++ b/src/generic/Flush.cpp @@ -55,11 +55,13 @@ PRINT ARG=d2 STRIDE=10 FILE=colvar2 //+ENDPLUMEDOC class Flush: - public ActionPilot { + public ActionPilot +{ public: explicit Flush(const ActionOptions&ao): Action(ao), - ActionPilot(ao) { + ActionPilot(ao) + { checkRead(); } static void registerKeywords( Keywords& keys ); @@ -69,9 +71,8 @@ class Flush: plumed.fflush(); log.flush(); const ActionSet & actionSet(plumed.getActionSet()); - for(const auto & p : actionSet) { + for(const auto & p : actionSet) p->fflush(); - } } }; diff --git a/src/generic/Group.cpp b/src/generic/Group.cpp index 8fac220f81..45e5288957 100644 --- a/src/generic/Group.cpp +++ b/src/generic/Group.cpp @@ -129,7 +129,8 @@ DUMPATOMS ATOMS=hy FILE=hy.gro //+ENDPLUMEDOC class Group: - public ActionAtomistic { + public ActionAtomistic +{ public: explicit Group(const ActionOptions&ao); @@ -143,25 +144,19 @@ PLUMED_REGISTER_ACTION(Group,"GROUP") Group::Group(const ActionOptions&ao): Action(ao), - ActionAtomistic(ao) { + ActionAtomistic(ao) +{ std::vector atoms; parseAtomList("ATOMS",atoms); std::string ndxfile,ndxgroup; parse("NDX_FILE",ndxfile); parse("NDX_GROUP",ndxgroup); - if(ndxfile.length()>0 && atoms.size()>0) { - error("either use explicit atom list or import from index file"); - } - if(ndxfile.length()==0 && ndxgroup.size()>0) { - error("NDX_GROUP can be only used is NDX_FILE is also used"); - } + if(ndxfile.length()>0 && atoms.size()>0) error("either use explicit atom list or import from index file"); + if(ndxfile.length()==0 && ndxgroup.size()>0) error("NDX_GROUP can be only used is NDX_FILE is also used"); if(ndxfile.length()>0) { - if(ndxgroup.size()>0) { - log<<" importing group '"+ndxgroup+"'"; - } else { - log<<" importing first group"; - } + if(ndxgroup.size()>0) log<<" importing group '"+ndxgroup+"'"; + else log<<" importing first group"; log<<" from index file "< words=Tools::getWords(line); if(words.size()>=3 && words[0]=="[" && words[2]=="]") { - if(groupname.length()>0) { - firstgroup=false; - } + if(groupname.length()>0) firstgroup=false; groupname=words[1]; - if(groupname==ndxgroup || ndxgroup.length()==0) { - groupfound=true; - } + if(groupname==ndxgroup || ndxgroup.length()==0) groupfound=true; } else if(groupname==ndxgroup || (firstgroup && ndxgroup.length()==0)) { for(unsigned i=0; i remove; @@ -202,22 +190,16 @@ Group::Group(const ActionOptions&ao): for(unsigned i=0; i0) { log<<" the following atoms were not found:"; - for(unsigned i=0; iatoms.insertGroup(getLabel(),atoms); log.printf(" list of atoms:"); for(unsigned i=0; i3) << "API>3 is required for the PLUMED action to work correctly\n"; return api; -}()) { +}()) +{ Tools::DirectoryChanger directoryChanger(directory.c_str()); bool noreplicas; parseFlag("NOREPLICAS",noreplicas); int nreps; - if(root) { - nreps=multi_sim_comm.Get_size(); - } + if(root) nreps=multi_sim_comm.Get_size(); comm.Bcast(nreps,0); if(nreps>1) { if(noreplicas) { @@ -254,133 +254,76 @@ API([&]() { parse("FILE",file); if(file.length()>0) { log<<" with input file "<0) { log<<" with log file "< numbers; numbers.reserve(index.size()); - for(auto i : index) { - numbers.emplace_back(AtomNumber::index(i)); - } + for(auto i : index) numbers.emplace_back(AtomNumber::index(i)); requestAtoms(numbers); } } void Plumed::calculate() { Tools::DirectoryChanger directoryChanger(directory.c_str()); - if(root) { - p.cmd("setStopFlag",&stop); - } + if(root) p.cmd("setStopFlag",&stop); Tensor box=getPbc().getBox(); - if(root) { - p.cmd("setBox",&box[0][0],9); - } + if(root) p.cmd("setBox",&box[0][0],9); virial.zero(); - for(int i=0; iset(bias); } @@ -499,9 +407,7 @@ void Plumed::apply() { void Plumed::update() { Tools::DirectoryChanger directoryChanger(directory.c_str()); - if(root) { - p.cmd("update"); - } + if(root) p.cmd("update"); comm.Bcast(stop,0); if(stop) { log<<" Action " << getLabel()<<" asked to stop\n"; diff --git a/src/generic/Print.cpp b/src/generic/Print.cpp index 644bc6cdbf..f1356646f9 100644 --- a/src/generic/Print.cpp +++ b/src/generic/Print.cpp @@ -67,7 +67,8 @@ only when required. class Print : public ActionPilot, - public ActionWithArguments { + public ActionWithArguments +{ std::string file; OFile ofile; std::string fmt; @@ -112,7 +113,8 @@ Print::Print(const ActionOptions&ao): ActionPilot(ao), ActionWithArguments(ao), fmt("%f"), - rotate(0) { + rotate(0) +{ ofile.link(*this); parse("FILE",file); if(file.length()>0) { @@ -125,9 +127,7 @@ Print::Print(const ActionOptions&ao): parse("FMT",fmt); fmt=" "+fmt; log.printf(" with format %s\n",fmt.c_str()); - for(unsigned i=0; i0) { rotateCountdown=rotate; - for(unsigned i=0; i a(1,rotateArguments[0]); requestArguments(std::vector(1,rotateArguments[0])); rotateLast=0; diff --git a/src/generic/RandomExchanges.cpp b/src/generic/RandomExchanges.cpp index 3d0a571ab5..027e8e0a88 100644 --- a/src/generic/RandomExchanges.cpp +++ b/src/generic/RandomExchanges.cpp @@ -71,7 +71,8 @@ should be the same in all input files. //+ENDPLUMEDOC class RandomExchanges: - public Action { + public Action +{ public: static void registerKeywords( Keywords& keys ); explicit RandomExchanges(const ActionOptions&ao); @@ -87,14 +88,13 @@ void RandomExchanges::registerKeywords( Keywords& keys ) { } RandomExchanges::RandomExchanges(const ActionOptions&ao): - Action(ao) { + Action(ao) +{ plumed.getExchangePatterns().setFlag(ExchangePatterns::RANDOM); // I convert the seed to -seed because I think it is more general to use a positive seed in input int seed=-1; parse("SEED",seed); - if(seed>=0) { - plumed.getExchangePatterns().setSeed(-seed); - } + if(seed>=0) plumed.getExchangePatterns().setSeed(-seed); } } diff --git a/src/generic/Read.cpp b/src/generic/Read.cpp index d4f589aafe..d90c6852e5 100644 --- a/src/generic/Read.cpp +++ b/src/generic/Read.cpp @@ -77,7 +77,8 @@ The file input_colvar.data is just a normal colvar file as shown below class Read : public ActionPilot, - public ActionWithValue { + public ActionWithValue +{ private: bool ignore_time; bool ignore_forces; @@ -130,7 +131,8 @@ Read::Read(const ActionOptions&ao): ActionWithValue(ao), ignore_time(false), ignore_forces(false), - nlinesPerStep(1) { + nlinesPerStep(1) +{ // Read the file name from the input line parse("FILE",filename); // Check if time is to be ignored @@ -149,80 +151,50 @@ Read::Read(const ActionOptions&ao): if( !cloned_file ) { ifile_ptr=Tools::make_unique(); ifile=ifile_ptr.get(); - if( !ifile->FileExist(filename) ) { - error("could not find file named " + filename); - } + if( !ifile->FileExist(filename) ) error("could not find file named " + filename); ifile->link(*this); ifile->open(filename); ifile->allowIgnoredFields(); } parse("EVERY",nlinesPerStep); - if(nlinesPerStep>1) { - log.printf(" only reading every %uth line of file %s\n",nlinesPerStep,filename.c_str() ); - } else { - log.printf(" reading data from file %s\n",filename.c_str() ); - } + if(nlinesPerStep>1) log.printf(" only reading every %uth line of file %s\n",nlinesPerStep,filename.c_str() ); + else log.printf(" reading data from file %s\n",filename.c_str() ); // Find out what we are reading - std::vector valread; - parseVector("VALUES",valread); + std::vector valread; parseVector("VALUES",valread); - if(nlinesPerStep>1 && cloned_file) { - error("Opening a file multiple times and using EVERY is not allowed"); - } + if(nlinesPerStep>1 && cloned_file) error("Opening a file multiple times and using EVERY is not allowed"); std::size_t dot=valread[0].find_first_of('.'); if( valread[0].find(".")!=std::string::npos ) { std::string label=valread[0].substr(0,dot); std::string name=valread[0].substr(dot+1); if( name=="*" ) { - if( valread.size()>1 ) { - error("all values must be from the same Action when using READ"); - } + if( valread.size()>1 ) error("all values must be from the same Action when using READ"); std::vector fieldnames; ifile->scanFieldList( fieldnames ); for(unsigned i=0; i(this, fieldnames[i], false) ); - addComponentWithDerivatives( fieldnames[i].substr(dot+1) ); - if( ifile->FieldExist("min_" + fieldnames[i]) ) { - componentIsPeriodic( fieldnames[i].substr(dot+1), "-pi","pi" ); - } else { - componentIsNotPeriodic( fieldnames[i].substr(dot+1) ); - } + readvals.emplace_back(Tools::make_unique(this, fieldnames[i], false) ); addComponentWithDerivatives( fieldnames[i].substr(dot+1) ); + if( ifile->FieldExist("min_" + fieldnames[i]) ) componentIsPeriodic( fieldnames[i].substr(dot+1), "-pi","pi" ); + else componentIsNotPeriodic( fieldnames[i].substr(dot+1) ); } } } else { - readvals.emplace_back(Tools::make_unique(this, valread[0], false) ); - addComponentWithDerivatives( name ); - if( ifile->FieldExist("min_" + valread[0]) ) { - componentIsPeriodic( valread[0].substr(dot+1), "-pi", "pi" ); - } else { - componentIsNotPeriodic( valread[0].substr(dot+1) ); - } + readvals.emplace_back(Tools::make_unique(this, valread[0], false) ); addComponentWithDerivatives( name ); + if( ifile->FieldExist("min_" + valread[0]) ) componentIsPeriodic( valread[0].substr(dot+1), "-pi", "pi" ); + else componentIsNotPeriodic( valread[0].substr(dot+1) ); for(unsigned i=1; i(this, valread[i], false) ); - addComponentWithDerivatives( valread[i].substr(dot+1) ); - if( ifile->FieldExist("min_" + valread[i]) ) { - componentIsPeriodic( valread[i].substr(dot+1), "-pi", "pi" ); - } else { - componentIsNotPeriodic( valread[i].substr(dot+1) ); - } + if( valread[i].substr(0,dot)!=label ) error("all values must be from the same Action when using READ");; + readvals.emplace_back(Tools::make_unique(this, valread[i], false) ); addComponentWithDerivatives( valread[i].substr(dot+1) ); + if( ifile->FieldExist("min_" + valread[i]) ) componentIsPeriodic( valread[i].substr(dot+1), "-pi", "pi" ); + else componentIsNotPeriodic( valread[i].substr(dot+1) ); } } } else { - if( valread.size()!=1 ) { - error("all values must be from the same Action when using READ"); - } - readvals.emplace_back(Tools::make_unique(this, valread[0], false) ); - addValueWithDerivatives(); - if( ifile->FieldExist("min_" + valread[0]) ) { - setPeriodic( "-pi", "pi" ); - } else { - setNotPeriodic(); - } + if( valread.size()!=1 ) error("all values must be from the same Action when using READ"); + readvals.emplace_back(Tools::make_unique(this, valread[0], false) ); addValueWithDerivatives(); + if( ifile->FieldExist("min_" + valread[0]) ) setPeriodic( "-pi", "pi" ); + else setNotPeriodic(); log.printf(" reading value %s and storing as %s\n",valread[0].c_str(),getLabel().c_str() ); } checkRead(); @@ -241,9 +213,8 @@ unsigned Read::getNumberOfDerivatives() { } void Read::turnOnDerivatives() { - if( !ignore_forces ) - error("cannot calculate derivatives for colvars that are read in from a file. If you are postprocessing and " - "these forces do not matter add the flag IGNORE_FORCES to all READ actions"); + if( !ignore_forces ) error("cannot calculate derivatives for colvars that are read in from a file. If you are postprocessing and " + "these forces do not matter add the flag IGNORE_FORCES to all READ actions"); } void Read::prepare() { @@ -252,9 +223,7 @@ void Read::prepare() { if( !ifile->scanField("time",du_time) ) { error("Reached end of file " + filename + " before end of trajectory"); } else if( std::abs( du_time-getTime() )>plumed.getAtoms().getTimeStep() && !ignore_time ) { - std::string str_dutime,str_ptime; - Tools::convert(du_time,str_dutime); - Tools::convert(getTime(),str_ptime); + std::string str_dutime,str_ptime; Tools::convert(du_time,str_dutime); Tools::convert(getTime(),str_ptime); error("mismatched times in colvar files : colvar time=" + str_dutime + " plumed time=" + str_ptime + ". Add IGNORE_TIME to ignore error."); } } @@ -277,11 +246,8 @@ void Read::calculate() { void Read::update() { if( !cloned_file ) { for(unsigned i=0; iscanField(); - double du_time; - if( !ifile->scanField("time",du_time) && plumed.getAtoms().getNatoms()==0 ) { - plumed.stop(); - } + ifile->scanField(); double du_time; + if( !ifile->scanField("time",du_time) && plumed.getAtoms().getNatoms()==0 ) plumed.stop(); } } } diff --git a/src/generic/ResetCell.cpp b/src/generic/ResetCell.cpp index 7e05dbcaa5..98b76f09b8 100644 --- a/src/generic/ResetCell.cpp +++ b/src/generic/ResetCell.cpp @@ -91,7 +91,8 @@ END class ResetCell: public ActionPilot, - public ActionAtomistic { + public ActionAtomistic +{ std::string type; Tensor rotation,newbox; @@ -114,14 +115,13 @@ void ResetCell::registerKeywords( Keywords& keys ) { ResetCell::ResetCell(const ActionOptions&ao): Action(ao), ActionPilot(ao), - ActionAtomistic(ao) { + ActionAtomistic(ao) +{ type.assign("TRIANGULAR"); parse("TYPE",type); log<<" type: "<resizeDerivatives(1); } diff --git a/src/generic/UpdateIf.cpp b/src/generic/UpdateIf.cpp index b3854282b1..a7abb36d04 100644 --- a/src/generic/UpdateIf.cpp +++ b/src/generic/UpdateIf.cpp @@ -78,7 +78,8 @@ UPDATE_IF ARG=coord END class UpdateIf: public ActionPilot, - public ActionWithArguments { + public ActionWithArguments +{ std::vector lower; std::vector upper; bool on; @@ -111,28 +112,17 @@ UpdateIf::UpdateIf(const ActionOptions&ao): ActionPilot(ao), ActionWithArguments(ao), on(false), - end(false) { + end(false) +{ parseFlag("END",end); parseVector("LESS_THAN",upper); parseVector("MORE_THAN",lower); - if(end && upper.size()!=0) { - error("END and LESS_THAN are not compatible"); - } - if(end && lower.size()!=0) { - error("END and MORE_THAN are not compatible"); - } - if(upper.size()==0) { - upper.assign(getNumberOfArguments(),+std::numeric_limits::max()); - } - if(lower.size()==0) { - lower.assign(getNumberOfArguments(),-std::numeric_limits::max()); - } - if(upper.size()!=getNumberOfArguments()) { - error("LESS_THAN should have the same size as ARG"); - } - if(lower.size()!=getNumberOfArguments()) { - error("MORE_THAN should have the same size as ARG"); - } + if(end && upper.size()!=0) error("END and LESS_THAN are not compatible"); + if(end && lower.size()!=0) error("END and MORE_THAN are not compatible"); + if(upper.size()==0) upper.assign(getNumberOfArguments(),+std::numeric_limits::max()); + if(lower.size()==0) lower.assign(getNumberOfArguments(),-std::numeric_limits::max()); + if(upper.size()!=getNumberOfArguments()) error("LESS_THAN should have the same size as ARG"); + if(lower.size()!=getNumberOfArguments()) error("MORE_THAN should have the same size as ARG"); for(unsigned i=0; i=upper[i] || getArgument(i)<=lower[i]) { - on=false; - } + if(getArgument(i)>=upper[i] || getArgument(i)<=lower[i]) on=false; } } void UpdateIf::beforeUpdate() { - if(end) { - plumed.updateFlagsPop(); - } else { - if(on) { - plumed.updateFlagsPush(plumed.updateFlagsTop()); - } else { - plumed.updateFlagsPush(false); - } + if(end) plumed.updateFlagsPop(); + else { + if(on) plumed.updateFlagsPush(plumed.updateFlagsTop()); + else plumed.updateFlagsPush(false); } } diff --git a/src/generic/WholeMolecules.cpp b/src/generic/WholeMolecules.cpp index 8d0c81f3fa..c7ac2a45ae 100644 --- a/src/generic/WholeMolecules.cpp +++ b/src/generic/WholeMolecules.cpp @@ -102,7 +102,8 @@ WHOLEMOLECULES RESIDUES=all MOLTYPE=protein class WholeMolecules: public ActionPilot, - public ActionAtomistic { + public ActionAtomistic +{ std::vector > groups; std::vector > roots; std::vector refs; @@ -136,7 +137,8 @@ WholeMolecules::WholeMolecules(const ActionOptions&ao): Action(ao), ActionPilot(ao), ActionAtomistic(ao), - doemst(false), addref(false) { + doemst(false), addref(false) +{ // parse optional flags parseFlag("EMST", doemst); parseFlag("ADDREFERENCE", addref); @@ -145,30 +147,20 @@ WholeMolecules::WholeMolecules(const ActionOptions&ao): for(int i=0;; i++) { std::vector group; parseAtomList("ENTITY",i,group); - if( group.empty() ) { - break; - } + if( group.empty() ) break; groups.push_back(group); } // Read residues to align from MOLINFO - std::vector resstrings; - parseVector("RESIDUES",resstrings); + std::vector resstrings; parseVector("RESIDUES",resstrings); if( resstrings.size()>0 ) { if( resstrings.size()==1 ) { - if( resstrings[0]=="all" ) { - resstrings[0]="all-ter"; // Include terminal groups in alignment - } - } - std::string moltype; - parse("MOLTYPE",moltype); - if(moltype.length()==0) { - error("Found RESIDUES keyword without specification of the molecule - use MOLTYPE"); + if( resstrings[0]=="all" ) resstrings[0]="all-ter"; // Include terminal groups in alignment } + std::string moltype; parse("MOLTYPE",moltype); + if(moltype.length()==0) error("Found RESIDUES keyword without specification of the molecule - use MOLTYPE"); auto* moldat=plumed.getActionSet().selectLatest(this); - if( !moldat ) { - error("MOLINFO is required to use RESIDUES"); - } + if( !moldat ) error("MOLINFO is required to use RESIDUES"); std::vector< std::vector > backatoms; moldat->getBackbone( resstrings, moltype, backatoms ); for(unsigned i=0; i(this); - if( !moldat ) { - error("MOLINFO is required to use EMST"); - } + if( !moldat ) error("MOLINFO is required to use EMST"); // initialize tree Tree tree = Tree(moldat); // cycle on groups and reorder atoms @@ -199,9 +187,7 @@ WholeMolecules::WholeMolecules(const ActionOptions&ao): // fill root vector with previous atom in groups for(unsigned i=0; i root; - for(unsigned j=0; j(this); - if( !moldat ) { - error("MOLINFO is required to use ADDREFERENCE"); - } + if( !moldat ) error("MOLINFO is required to use ADDREFERENCE"); for(unsigned i=0; igetPosition(groups[i][0])); @@ -222,13 +206,9 @@ WholeMolecules::WholeMolecules(const ActionOptions&ao): // print out info for(unsigned i=0; i atoms; std::vector reference; @@ -177,44 +178,31 @@ WrapAround::WrapAround(const ActionOptions&ao): ActionPilot(ao), ActionAtomistic(ao), groupby(1), - pair_(false) { + pair_(false) +{ parseAtomList("ATOMS",atoms); parseAtomList("AROUND",reference); parse("GROUPBY",groupby); parseFlag("PAIR", pair_); log.printf(" atoms in reference :"); - for(unsigned j=0; j1) { - log<<" atoms will be grouped by "<1) log<<" atoms will be grouped by "< ActionWithGrid::createGrid( const std::string& type, const std::string& inputstr ) { // Start creating the input for the grid std::string vstring = inputstr; if( keywords.exists("KERNEL") ) { - std::string vconc; - parse("CONCENTRATION",vconc); + std::string vconc; parse("CONCENTRATION",vconc); if( vconc.length()>0 ) { vstring += " TYPE=fibonacci CONCENTRATION=" + vconc; } else { - std::string kstring; - parse("KERNEL",kstring); - if( kstring=="DISCRETE" ) { - vstring += " KERNEL=" + kstring; - } else { - vstring += " KERNEL=" + kstring + " " + getKeyword("BANDWIDTH"); - } + std::string kstring; parse("KERNEL",kstring); + if( kstring=="DISCRETE" ) vstring += " KERNEL=" + kstring; + else vstring += " KERNEL=" + kstring + " " + getKeyword("BANDWIDTH"); } } vesselbase::VesselOptions da("mygrid","",-1,vstring,this); - Keywords keys; - gridtools::AverageOnGrid::registerKeywords( keys ); + Keywords keys; gridtools::AverageOnGrid::registerKeywords( keys ); vesselbase::VesselOptions dar( da, keys ); std::unique_ptr grid; if( type=="histogram" ) { @@ -78,59 +73,37 @@ std::unique_ptr ActionWithGrid::createGrid( const std::string& type, } void ActionWithGrid::turnOnDerivatives() { - needsDerivatives(); - ActionWithValue::turnOnDerivatives(); - if( getStride()==1 ) { - setStride(0); - } else if( getStride()!=0 ) { - error("conflicting instructions for grid - stride was set but must be evaluated on every step for derivatives - remove STRIDE keyword"); - } - if( clearstride>1 ) { - error("conflicting instructions for grid - CLEAR was set but grid must be reset on every step for derivatives - remove CLEAR keyword" ); - } - if( weights.size()>0 ) { - error("conflicting instructions for grid - LOGWEIGHTS was set but weights are not considered when derivatives of grid are evaluated - remove LOGWEIGHTS keyword"); - } + needsDerivatives(); ActionWithValue::turnOnDerivatives(); + if( getStride()==1 ) setStride(0); + else if( getStride()!=0 ) error("conflicting instructions for grid - stride was set but must be evaluated on every step for derivatives - remove STRIDE keyword"); + if( clearstride>1 ) error("conflicting instructions for grid - CLEAR was set but grid must be reset on every step for derivatives - remove CLEAR keyword" ); + if( weights.size()>0 ) error("conflicting instructions for grid - LOGWEIGHTS was set but weights are not considered when derivatives of grid are evaluated - remove LOGWEIGHTS keyword"); } void ActionWithGrid::calculate() { // Do nothing if derivatives are not required - if( doNotCalculateDerivatives() ) { - return; - } + if( doNotCalculateDerivatives() ) return; // Clear on every step - if( mygrid ) { - clearAverage(); - } + if( mygrid ) clearAverage(); // Should not be any reweighting so just set these accordingly - lweight=0; - cweight=1.0; + lweight=0; cweight=1.0; // Prepare to do the averaging prepareForAveraging(); // Run all the tasks (if required - if( useRunAllTasks ) { - runAllTasks(); - } + if( useRunAllTasks ) runAllTasks(); // This the averaging if it is not done using task list - else { - performOperations( true ); - } + else performOperations( true ); // Update the norm - if( mygrid ) { - mygrid->setNorm( cweight ); - } + if( mygrid ) mygrid->setNorm( cweight ); // Finish the averaging finishAveraging(); // And reset for next step - if( mygrid ) { - mygrid->reset(); - } + if( mygrid ) mygrid->reset(); } void ActionWithGrid::runTask( const unsigned& current, MultiValue& myvals ) const { // Set the weight of this point - myvals.setValue( 0, cweight ); - compute( current, myvals ); + myvals.setValue( 0, cweight ); compute( current, myvals ); } } diff --git a/src/gridtools/ActionWithInputGrid.cpp b/src/gridtools/ActionWithInputGrid.cpp index bedebe45c4..30d018052c 100644 --- a/src/gridtools/ActionWithInputGrid.cpp +++ b/src/gridtools/ActionWithInputGrid.cpp @@ -35,58 +35,44 @@ void ActionWithInputGrid::registerKeywords( Keywords& keys ) { ActionWithInputGrid::ActionWithInputGrid(const ActionOptions&ao): Action(ao), ActionWithGrid(ao), - ingrid(NULL) { - std::string mlab; - parse("GRID",mlab); + ingrid(NULL) +{ + std::string mlab; parse("GRID",mlab); vesselbase::ActionWithVessel* mves= plumed.getActionSet().selectWithLabel(mlab); - if(!mves) { - error("action labelled " + mlab + " does not exist or does not have vessels"); - } + if(!mves) error("action labelled " + mlab + " does not exist or does not have vessels"); addDependency(mves); for(unsigned i=0; igetNumberOfVessels(); ++i) { ingrid=dynamic_cast( mves->getPntrToVessel(i) ); - if( ingrid ) { - break; - } - } - if( !ingrid ) { - error("input action does not calculate a grid"); + if( ingrid ) break; } + if( !ingrid ) error("input action does not calculate a grid"); if( ingrid->getNumberOfComponents()==1 ) { mycomp=0; } else { - int tcomp=-1; - parse("COMPONENT",tcomp); - if( tcomp<0 ) { - error("component of vector field was not specified - use COMPONENT keyword"); - } + int tcomp=-1; parse("COMPONENT",tcomp); + if( tcomp<0 ) error("component of vector field was not specified - use COMPONENT keyword"); mycomp=tcomp; } log.printf(" using %uth component of grid calculated by action %s \n",mycomp,mves->getLabel().c_str() ); } void ActionWithInputGrid::clearAverage() { - if( mygrid->getType()=="flat" ) { - mygrid->setBounds( ingrid->getMin(), ingrid->getMax(), mygrid->getNbin(), mygrid->getGridSpacing() ); - } + if( mygrid->getType()=="flat" ) mygrid->setBounds( ingrid->getMin(), ingrid->getMax(), mygrid->getNbin(), mygrid->getGridSpacing() ); ActionWithAveraging::clearAverage(); } void ActionWithInputGrid::prepareForAveraging() { if( checkAllActive() ) { for(unsigned i=0; igetNumberOfPoints(); ++i) { - if( ingrid->inactive(i) ) { - error("if FIND_CONTOUR is used with BUFFER option then other actions cannot be performed with grid"); - } + if( ingrid->inactive(i) ) error("if FIND_CONTOUR is used with BUFFER option then other actions cannot be performed with grid"); } } } void ActionWithInputGrid::performOperations( const bool& from_update ) { - prepareForAveraging(); - runAllTasks(); + prepareForAveraging(); runAllTasks(); } } diff --git a/src/gridtools/ActionWithInputGrid.h b/src/gridtools/ActionWithInputGrid.h index f65faf3f73..49aa7a80c4 100644 --- a/src/gridtools/ActionWithInputGrid.h +++ b/src/gridtools/ActionWithInputGrid.h @@ -42,19 +42,14 @@ class ActionWithInputGrid : public ActionWithGrid { explicit ActionWithInputGrid(const ActionOptions&ao); void clearAverage() override; void prepareForAveraging() override; - virtual bool checkAllActive() const { - return true; - } + virtual bool checkAllActive() const { return true; } void performOperations( const bool& from_update ) override; void apply() override {}; }; inline double ActionWithInputGrid::getFunctionValue( const unsigned& ipoint ) const { - unsigned dim=ingrid->getDimension(); - if( ingrid->noderiv ) { - dim=0; - } + unsigned dim=ingrid->getDimension(); if( ingrid->noderiv ) dim=0; return ingrid->getGridElement( ipoint, mycomp*(1+dim) ); } diff --git a/src/gridtools/ActionWithIntegral.cpp b/src/gridtools/ActionWithIntegral.cpp index 869618c82e..d3097cee03 100644 --- a/src/gridtools/ActionWithIntegral.cpp +++ b/src/gridtools/ActionWithIntegral.cpp @@ -26,33 +26,26 @@ namespace gridtools { void ActionWithIntegral::registerKeywords( Keywords& keys ) { ActionWithInputGrid::registerKeywords( keys ); - keys.remove("KERNEL"); - keys.remove("BANDWIDTH"); - keys.remove("CLEAR"); - keys.add("compulsory","CLEAR","1","the frequency with which to clear all the accumulated data."); + keys.remove("KERNEL"); keys.remove("BANDWIDTH"); + keys.remove("CLEAR"); keys.add("compulsory","CLEAR","1","the frequency with which to clear all the accumulated data."); } ActionWithIntegral::ActionWithIntegral(const ActionOptions&ao): Action(ao), - ActionWithInputGrid(ao) { + ActionWithInputGrid(ao) +{ plumed_assert( ingrid->getNumberOfComponents()==1 ); // Retrieve the volume of the grid (for integration) volume = ingrid->getCellVolume(); // Create something that is going to calculate the sum of all the values // at the various grid points - this is going to be the integral - std::string fake_input; - addVessel( "SUM", fake_input, -1 ); - readVesselKeywords(); + std::string fake_input; addVessel( "SUM", fake_input, -1 ); readVesselKeywords(); // Now create task list - number of tasks is equal to the number of grid points // as we have to evaluate the function at each grid points - for(unsigned i=0; igetNumberOfPoints(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetNumberOfPoints(); ++i) addTaskToList(i); // And activate all tasks deactivateAllTasks(); - for(unsigned i=0; igetNumberOfPoints(); ++i) { - taskFlags[i]=1; - } + for(unsigned i=0; igetNumberOfPoints(); ++i) taskFlags[i]=1; lockContributors(); } @@ -62,9 +55,7 @@ void ActionWithIntegral::turnOnDerivatives() { } void ActionWithIntegral::apply() { - if( getForcesFromVessels( forcesToApply ) ) { - ingrid->setForce( forcesToApply ); - } + if( getForcesFromVessels( forcesToApply ) ) ingrid->setForce( forcesToApply ); } } diff --git a/src/gridtools/ActionWithIntegral.h b/src/gridtools/ActionWithIntegral.h index dae5659612..f7dc3597f1 100644 --- a/src/gridtools/ActionWithIntegral.h +++ b/src/gridtools/ActionWithIntegral.h @@ -40,9 +40,7 @@ class ActionWithIntegral : public ActionWithInputGrid { unsigned getNumberOfDerivatives() override; void turnOnDerivatives() override; /// Unless I am mistaken an integral should never be a periodic function - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } void apply() override; }; diff --git a/src/gridtools/AverageOnGrid.cpp b/src/gridtools/AverageOnGrid.cpp index b8cfadddc6..704ad5a3c2 100644 --- a/src/gridtools/AverageOnGrid.cpp +++ b/src/gridtools/AverageOnGrid.cpp @@ -29,12 +29,11 @@ void AverageOnGrid::registerKeywords( Keywords& keys ) { } AverageOnGrid::AverageOnGrid( const vesselbase::VesselOptions& da ): - HistogramOnGrid(da) { + HistogramOnGrid(da) +{ arg_names.push_back( "density" ); if( !discrete ) { - for(unsigned i=0; i& der, std::vector& buffer ) const { - buffer[bufstart+nper*ipoint] += weight*dens; - buffer[ bufstart+nper*(ipoint+1) - (dimension+1) ] += dens; + buffer[bufstart+nper*ipoint] += weight*dens; buffer[ bufstart+nper*(ipoint+1) - (dimension+1) ] += dens; if( der.size()>0 ) { - for(unsigned j=0; j=(nper-(dimension+1)) ) { - return getDataElement( nper*ipoint + jelement ); - } + if( jelement>=(nper-(dimension+1)) ) return getDataElement( nper*ipoint + jelement ); - if( noderiv ) { - return getDataElement( nper*ipoint+jelement ) / getDataElement( nper*(1+ipoint) - 1); - } + if( noderiv ) return getDataElement( nper*ipoint+jelement ) / getDataElement( nper*(1+ipoint) - 1); double rdenom = 1.0; - if( std::fabs(getDataElement( nper*(ipoint+1) -(dimension+1) ))>epsilon ) { - rdenom = 1. / getDataElement( nper*(ipoint+1) - (dimension+1) ); - } + if( std::fabs(getDataElement( nper*(ipoint+1) -(dimension+1) ))>epsilon ) rdenom = 1. / getDataElement( nper*(ipoint+1) - (dimension+1) ); unsigned jderiv = jelement%(1+dimension); - if( jderiv==0 ) { - return rdenom*getDataElement( nper*ipoint+jelement ); - } + if( jderiv==0 ) return rdenom*getDataElement( nper*ipoint+jelement ); unsigned jfloor = std::floor( jelement / (1+dimension) ); return rdenom*getDataElement( nper*ipoint+jelement ) - rdenom*rdenom*getDataElement(nper*ipoint+jfloor)*getDataElement(nper*(ipoint+1) - (dimension+1) + jderiv); diff --git a/src/gridtools/AverageOnGrid.h b/src/gridtools/AverageOnGrid.h index 6796039df3..067a0bb1ed 100644 --- a/src/gridtools/AverageOnGrid.h +++ b/src/gridtools/AverageOnGrid.h @@ -32,21 +32,15 @@ class AverageOnGrid : public HistogramOnGrid { static void registerKeywords( Keywords& keys ); explicit AverageOnGrid( const vesselbase::VesselOptions& da ); void accumulate( const unsigned& ipoint, const double& weight, const double& dens, const std::vector& der, std::vector& buffer ) const override; - void accumulateForce( const unsigned& ipoint, const double& weight, const std::vector& der, std::vector& intforce ) const override { - plumed_error(); - } + void accumulateForce( const unsigned& ipoint, const double& weight, const std::vector& der, std::vector& intforce ) const override { plumed_error(); } double getGridElement( const unsigned& ipoint, const unsigned& jelement ) const override; unsigned getNumberOfComponents() const override; - void getFinalForces( const std::vector& buffer, std::vector& finalForces ) override { - plumed_error(); - } + void getFinalForces( const std::vector& buffer, std::vector& finalForces ) override { plumed_error(); } }; inline unsigned AverageOnGrid::getNumberOfComponents() const { - if( noderiv ) { - return nper - 1; - } + if( noderiv ) return nper - 1; return nper / ( dimension + 1 ) - 1; } diff --git a/src/gridtools/ContourFindingBase.cpp b/src/gridtools/ContourFindingBase.cpp index d20c82f9bc..2adea414d0 100644 --- a/src/gridtools/ContourFindingBase.cpp +++ b/src/gridtools/ContourFindingBase.cpp @@ -27,17 +27,15 @@ namespace gridtools { void ContourFindingBase::registerKeywords( Keywords& keys ) { ActionWithInputGrid::registerKeywords( keys ); keys.add("compulsory","CONTOUR","the value we would like to draw the contour at in the space"); - keys.remove("KERNEL"); - keys.remove("BANDWIDTH"); + keys.remove("KERNEL"); keys.remove("BANDWIDTH"); } ContourFindingBase::ContourFindingBase(const ActionOptions&ao): Action(ao), ActionWithInputGrid(ao), - mymin(this) { - if( ingrid->noDerivatives() ) { - error("cannot find contours if input grid has no derivatives"); - } + mymin(this) +{ + if( ingrid->noDerivatives() ) error("cannot find contours if input grid has no derivatives"); parse("CONTOUR",contour); log.printf(" calculating dividing surface along which function equals %f \n", contour); } diff --git a/src/gridtools/ContourFindingBase.h b/src/gridtools/ContourFindingBase.h index 5ae2a7f947..6161709351 100644 --- a/src/gridtools/ContourFindingBase.h +++ b/src/gridtools/ContourFindingBase.h @@ -43,13 +43,9 @@ class ContourFindingBase : public ActionWithInputGrid { /// Get the contour value double getDifferenceFromContour( const std::vector& x, std::vector& der ) const ; /// Overwrite not needed stuff - unsigned getNumberOfDerivatives() override { - return 0; - } + unsigned getNumberOfDerivatives() override { return 0; } /// This is not periodic - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; inline diff --git a/src/gridtools/ConvertToFES.cpp b/src/gridtools/ConvertToFES.cpp index 477766ea2c..bfc45887c3 100644 --- a/src/gridtools/ConvertToFES.cpp +++ b/src/gridtools/ConvertToFES.cpp @@ -68,24 +68,13 @@ class ConvertToFES : public ActionWithInputGrid { static void registerKeywords( Keywords& keys ); explicit ConvertToFES(const ActionOptions&ao); unsigned getNumberOfQuantities() const override; - bool ignoreNormalization() const override { - return true; - } - void prepare() override { - activated=true; - } - void prepareForAveraging() override { - ActionWithInputGrid::prepareForAveraging(); - activated=false; - } + bool ignoreNormalization() const override { return true; } + void prepare() override { activated=true; } + void prepareForAveraging() override { ActionWithInputGrid::prepareForAveraging(); activated=false; } void compute( const unsigned& current, MultiValue& myvals ) const override; void finishComputations( const std::vector& buffer ) override; - bool isPeriodic() override { - return false; - } - bool onStep() const override { - return activated; - } + bool isPeriodic() override { return false; } + bool onStep() const override { return activated; } void runFinalJobs() override; }; @@ -95,91 +84,63 @@ void ConvertToFES::registerKeywords( Keywords& keys ) { ActionWithInputGrid::registerKeywords( keys ); keys.add("optional","TEMP","the temperature at which you are operating"); keys.addFlag("MINTOZERO",false,"set the minimum in the free energy to be equal to zero"); - keys.remove("STRIDE"); - keys.remove("KERNEL"); - keys.remove("BANDWIDTH"); - keys.remove("LOGWEIGHTS"); - keys.remove("CLEAR"); - keys.remove("NORMALIZATION"); + keys.remove("STRIDE"); keys.remove("KERNEL"); keys.remove("BANDWIDTH"); + keys.remove("LOGWEIGHTS"); keys.remove("CLEAR"); keys.remove("NORMALIZATION"); } ConvertToFES::ConvertToFES(const ActionOptions&ao): Action(ao), ActionWithInputGrid(ao), - activated(false) { + activated(false) +{ plumed_assert( ingrid->getNumberOfComponents()==1 ); // Create a grid auto grid=createGrid( "grid", "COMPONENTS=" + getLabel() + " " + ingrid->getInputString() ); - if( ingrid->noDerivatives() ) { - grid->setNoDerivatives(); - } + if( ingrid->noDerivatives() ) grid->setNoDerivatives(); std::vector fspacing; grid->setBounds( ingrid->getMin(), ingrid->getMax(), ingrid->getNbin(), fspacing); setAveragingAction( std::move(grid), true ); - simtemp=0.; - parse("TEMP",simtemp); - parseFlag("MINTOZERO",mintozero); - if(simtemp>0) { - simtemp*=plumed.getAtoms().getKBoltzmann(); - } else { - simtemp=plumed.getAtoms().getKbT(); - } - if( simtemp==0 ) { - error("TEMP not set - use keyword TEMP"); - } + simtemp=0.; parse("TEMP",simtemp); parseFlag("MINTOZERO",mintozero); + if(simtemp>0) simtemp*=plumed.getAtoms().getKBoltzmann(); + else simtemp=plumed.getAtoms().getKbT(); + if( simtemp==0 ) error("TEMP not set - use keyword TEMP"); // Now create task list - for(unsigned i=0; igetNumberOfPoints(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetNumberOfPoints(); ++i) addTaskToList(i); // And activate all tasks deactivateAllTasks(); - for(unsigned i=0; igetNumberOfPoints(); ++i) { - taskFlags[i]=1; - } + for(unsigned i=0; igetNumberOfPoints(); ++i) taskFlags[i]=1; lockContributors(); } unsigned ConvertToFES::getNumberOfQuantities() const { - if( mygrid->noDerivatives() ) { - return 2; - } + if( mygrid->noDerivatives() ) return 2; return 2 + mygrid->getDimension(); } void ConvertToFES::compute( const unsigned& current, MultiValue& myvals ) const { - double val=getFunctionValue( current ); - myvals.setValue(1, -simtemp*std::log(val) ); + double val=getFunctionValue( current ); myvals.setValue(1, -simtemp*std::log(val) ); if( !mygrid->noDerivatives() && val>0 ) { - for(unsigned i=0; igetDimension(); ++i) { - myvals.setValue( 2+i, -(simtemp/val)*ingrid->getGridElement(current,i+1) ); - } + for(unsigned i=0; igetDimension(); ++i) myvals.setValue( 2+i, -(simtemp/val)*ingrid->getGridElement(current,i+1) ); } } void ConvertToFES::finishComputations( const std::vector& buffer ) { ActionWithVessel::finishComputations( buffer ); - if(!mintozero) { - return; - } + if(!mintozero) return; double optval = mygrid->getGridElement( 0, 0 ); for(unsigned i=0; igetNumberOfPoints(); ++i) { double tval = mygrid->getGridElement( i, 0 ); - if( tvalgetNumberOfPoints(); ++i) { - mygrid->addToGridElement( i, 0, -optval ); + if( tvalgetNumberOfPoints(); ++i) mygrid->addToGridElement( i, 0, -optval ); } void ConvertToFES::runFinalJobs() { - activated=true; - update(); + activated=true; update(); } } diff --git a/src/gridtools/DumpCube.cpp b/src/gridtools/DumpCube.cpp index 3d6af5d4af..071cb6414e 100644 --- a/src/gridtools/DumpCube.cpp +++ b/src/gridtools/DumpCube.cpp @@ -79,27 +79,18 @@ void DumpCube::registerKeywords( Keywords& keys ) { DumpCube::DumpCube(const ActionOptions&ao): Action(ao), - GridPrintingBase(ao) { + GridPrintingBase(ao) +{ fmt = fmt + " "; - if( ingrid->getType()!="flat" ) { - error("cannot dump grid of type " + ingrid->getType() + " using DUMPCUBE"); - } - if( ingrid->getDimension()!=3 ) { - error("cannot print cube file if grid does not contain three dimensional data"); - } + if( ingrid->getType()!="flat" ) error("cannot dump grid of type " + ingrid->getType() + " using DUMPCUBE"); + if( ingrid->getDimension()!=3 ) error("cannot print cube file if grid does not contain three dimensional data"); if( ingrid->getNumberOfComponents()==1 ) { mycomp=0; } else { - int tcomp=-1; - parse("COMPONENT",tcomp); - if( tcomp<0 ) { - error("component of vector field was not specified - use COMPONENT keyword"); - } - mycomp=tcomp*(1+ingrid->getDimension()); - if( ingrid->noDerivatives() ) { - mycomp=tcomp; - } + int tcomp=-1; parse("COMPONENT",tcomp); + if( tcomp<0 ) error("component of vector field was not specified - use COMPONENT keyword"); + mycomp=tcomp*(1+ingrid->getDimension()); if( ingrid->noDerivatives() ) mycomp=tcomp; log.printf(" using %dth component of grid \n",tcomp ); } @@ -118,15 +109,12 @@ void DumpCube::printGrid( OFile& ofile ) const { ofile.printf(ostr.c_str(),ingrid->getNbin()[1],0.0,lunit*ingrid->getGridSpacing()[1],0.0); // shape of voxel ofile.printf(ostr.c_str(),ingrid->getNbin()[2],0.0,0.0,lunit*ingrid->getGridSpacing()[2]); ofile.printf(ostr.c_str(),1,0.0,0.0,0.0); // Fake atom otherwise VMD doesn't work - std::vector pp(3); - std::vector nbin( ingrid->getNbin() ); + std::vector pp(3); std::vector nbin( ingrid->getNbin() ); for(pp[0]=0; pp[0]getGridElement( ingrid->getIndex(pp), mycomp ) ); - if(pp[2]%6==5) { - ofile.printf("\n"); - } + if(pp[2]%6==5) ofile.printf("\n"); } ofile.printf("\n"); } diff --git a/src/gridtools/DumpGrid.cpp b/src/gridtools/DumpGrid.cpp index 416c13edd4..3551332269 100644 --- a/src/gridtools/DumpGrid.cpp +++ b/src/gridtools/DumpGrid.cpp @@ -154,12 +154,10 @@ void DumpGrid::registerKeywords( Keywords& keys ) { DumpGrid::DumpGrid(const ActionOptions&ao): Action(ao), - GridPrintingBase(ao) { - if( ingrid->getType()!="flat" ) { - error("cannot dump grid of type " + ingrid->getType() + " using DUMPGRID"); - } - fmt = " " + fmt; - checkRead(); + GridPrintingBase(ao) +{ + if( ingrid->getType()!="flat" ) error("cannot dump grid of type " + ingrid->getType() + " using DUMPGRID"); + fmt = " " + fmt; checkRead(); } void DumpGrid::printGrid( OFile& ofile ) const { @@ -175,30 +173,20 @@ void DumpGrid::printGrid( OFile& ofile ) const { std::vector ind( ingrid->getDimension() ); for(unsigned i=0; igetNumberOfPoints(); ++i) { ingrid->getIndices( i, ind ); - if(i>0 && ingrid->getDimension()==2 && ind[ingrid->getDimension()-2]==0) { - ofile.printf("\n"); - } - ofile.fmtField(fmt); - ofile.printField("normalisation", ingrid->getNorm() ); + if(i>0 && ingrid->getDimension()==2 && ind[ingrid->getDimension()-2]==0) ofile.printf("\n"); + ofile.fmtField(fmt); ofile.printField("normalisation", ingrid->getNorm() ); for(unsigned j=0; jgetDimension(); ++j) { ofile.printField("min_" + ingrid->getComponentName(j), ingrid->getMin()[j] ); ofile.printField("max_" + ingrid->getComponentName(j), ingrid->getMax()[j] ); ofile.printField("nbins_" + ingrid->getComponentName(j), static_cast(ingrid->getNbin()[j]) ); - if( ingrid->isPeriodic(j) ) { - ofile.printField("periodic_" + ingrid->getComponentName(j), "true" ); - } else { - ofile.printField("periodic_" + ingrid->getComponentName(j), "false" ); - } + if( ingrid->isPeriodic(j) ) ofile.printField("periodic_" + ingrid->getComponentName(j), "true" ); + else ofile.printField("periodic_" + ingrid->getComponentName(j), "false" ); } // Retrieve and print the grid coordinates ingrid->getGridPointCoordinates(i, xx ); - for(unsigned j=0; jgetDimension(); ++j) { - ofile.fmtField(fmt); - ofile.printField(ingrid->getComponentName(j),xx[j]); - } + for(unsigned j=0; jgetDimension(); ++j) { ofile.fmtField(fmt); ofile.printField(ingrid->getComponentName(j),xx[j]); } for(unsigned j=0; jgetNumberOfQuantities(); ++j) { - ofile.fmtField(fmt); - ofile.printField(ingrid->arg_names[ingrid->dimension+j], ingrid->getGridElement( i, j ) ); + ofile.fmtField(fmt); ofile.printField(ingrid->arg_names[ingrid->dimension+j], ingrid->getGridElement( i, j ) ); } ofile.printField(); } diff --git a/src/gridtools/FindContour.cpp b/src/gridtools/FindContour.cpp index f16e758931..ca74268b33 100644 --- a/src/gridtools/FindContour.cpp +++ b/src/gridtools/FindContour.cpp @@ -102,16 +102,10 @@ class FindContour : public ContourFindingBase { public: static void registerKeywords( Keywords& keys ); explicit FindContour(const ActionOptions&ao); - bool checkAllActive() const override { - return gbuffer==0; - } + bool checkAllActive() const override { return gbuffer==0; } void prepareForAveraging() override; - bool isPeriodic() override { - return false; - } - unsigned getNumberOfQuantities() const override { - return 1 + ingrid->getDimension(); - } + bool isPeriodic() override { return false; } + unsigned getNumberOfQuantities() const override { return 1 + ingrid->getDimension(); } void compute( const unsigned& current, MultiValue& myvals ) const override; void finishAveraging() override; }; @@ -130,110 +124,75 @@ void FindContour::registerKeywords( Keywords& keys ) { FindContour::FindContour(const ActionOptions&ao): Action(ao), ContourFindingBase(ao), - firsttime(true) { + firsttime(true) +{ parse("BUFFER",gbuffer); - if( gbuffer>0 ) { - log.printf(" after first step a subset of only %u grid points around where the countour was found will be checked\n",gbuffer); - } + if( gbuffer>0 ) log.printf(" after first step a subset of only %u grid points around where the countour was found will be checked\n",gbuffer); - std::string file; - parse("FILE",file); - if( file.length()==0 ) { - error("name out output file was not specified"); - } + std::string file; parse("FILE",file); + if( file.length()==0 ) error("name out output file was not specified"); std::string type=Tools::extension(file); log<<" file name "<0) { - int p; - Tools::convert(precision,p); + int p; Tools::convert(precision,p); log<<" with precision "<getDimension()*ingrid->getNumberOfPoints(); ++i) { - addTaskToList( i ); - } + for(unsigned i=0; igetDimension()*ingrid->getNumberOfPoints(); ++i) addTaskToList( i ); } - firsttime=false; - deactivateAllTasks(); + firsttime=false; deactivateAllTasks(); // We now need to identify the grid points that we need to search through std::vector nbin( ingrid->getNbin() ); std::vector ind( ingrid->getDimension() ); std::vector ones( ingrid->getDimension(), 1 ); - unsigned num_neighbours; - std::vector neighbours; + unsigned num_neighbours; std::vector neighbours; for(unsigned i=0; igetNumberOfPoints(); ++i) { // Ensure inactive grid points are ignored - if( ingrid->inactive(i) ) { - continue; - } + if( ingrid->inactive(i) ) continue; // Get the index of the current grid point ingrid->getIndices( i, ind ); ingrid->getNeighbors( ind, ones, num_neighbours, neighbours ); bool cycle=false; for(unsigned j=0; jinactive( neighbours[j]) ) { - cycle=true; - break; - } - } - if( cycle ) { - continue; + if( ingrid->inactive( neighbours[j]) ) { cycle=true; break; } } + if( cycle ) continue; // Get the value of a point on the grid double val1=getFunctionValue( i ) - contour; bool edge=false; for(unsigned j=0; jgetDimension(); ++j) { // Make sure we don't search at the edge of the grid - if( !ingrid->isPeriodic(j) && (ind[j]+1)==nbin[j] ) { - continue; - } else if( (ind[j]+1)==nbin[j] ) { - edge=true; - ind[j]=0; - } else { - ind[j]+=1; - } + if( !ingrid->isPeriodic(j) && (ind[j]+1)==nbin[j] ) continue; + else if( (ind[j]+1)==nbin[j] ) { edge=true; ind[j]=0; } + else ind[j]+=1; double val2=getFunctionValue( ind ) - contour; - if( val1*val2<0 ) { - taskFlags[ ingrid->getDimension()*i + j ] = 1; - } - if( ingrid->isPeriodic(j) && edge ) { - edge=false; - ind[j]=nbin[j]-1; - } else { - ind[j]-=1; - } + if( val1*val2<0 ) taskFlags[ ingrid->getDimension()*i + j ] = 1; + if( ingrid->isPeriodic(j) && edge ) { edge=false; ind[j]=nbin[j]-1; } + else ind[j]-=1; } } lockContributors(); @@ -253,16 +212,13 @@ void FindContour::compute( const unsigned& current, MultiValue& myvals ) const { // Now find the contour findContour( direction, point ); // And transfer to the store data vessel - for(unsigned i=0; igetDimension(); ++i) { - myvals.setValue( 1+i, point[i] ); - } + for(unsigned i=0; igetDimension(); ++i) myvals.setValue( 1+i, point[i] ); } void FindContour::finishAveraging() { // And update the list of active grid points if( gbuffer>0 ) { - std::vector neighbours; - unsigned num_neighbours; + std::vector neighbours; unsigned num_neighbours; std::vector ugrid_indices( ingrid->getDimension() ); std::vector active( ingrid->getNumberOfPoints(), false ); std::vector gbuffer_vec( ingrid->getDimension(), gbuffer ); @@ -273,9 +229,7 @@ void FindContour::finishAveraging() { ingrid->getIndices( ipoint, ugrid_indices ); // Now activate buffer region ingrid->getNeighbors( ugrid_indices, gbuffer_vec, num_neighbours, neighbours ); - for(unsigned n=0; nactivateThesePoints( active ); } @@ -283,11 +237,8 @@ void FindContour::finishAveraging() { of.printf("%u\n",mydata->getNumberOfStoredValues()); of.printf("Points found on isocontour\n"); for(unsigned i=0; igetNumberOfStoredValues(); ++i) { - mydata->retrieveSequentialValue( i, false, point ); - of.printf("X"); - for(unsigned j=0; jgetDimension(); ++j) { - of.printf( (" " + fmt_xyz).c_str(), lenunit*point[1+j] ); - } + mydata->retrieveSequentialValue( i, false, point ); of.printf("X"); + for(unsigned j=0; jgetDimension(); ++j) of.printf( (" " + fmt_xyz).c_str(), lenunit*point[1+j] ); of.printf("\n"); } } diff --git a/src/gridtools/FindContourSurface.cpp b/src/gridtools/FindContourSurface.cpp index 2f67a23809..cf2e375fab 100644 --- a/src/gridtools/FindContourSurface.cpp +++ b/src/gridtools/FindContourSurface.cpp @@ -95,12 +95,8 @@ class FindContourSurface : public ContourFindingBase { public: static void registerKeywords( Keywords& keys ); explicit FindContourSurface(const ActionOptions&ao); - unsigned getNumberOfQuantities() const override { - return 2; - } - bool checkAllActive() const override { - return gbuffer==0; - } + unsigned getNumberOfQuantities() const override { return 2; } + bool checkAllActive() const override { return gbuffer==0; } void clearAverage() override; void prepareForAveraging() override; void compute( const unsigned& current, MultiValue& myvals ) const override; @@ -119,72 +115,48 @@ FindContourSurface::FindContourSurface(const ActionOptions&ao): Action(ao), ContourFindingBase(ao), firsttime(true), - ones(ingrid->getDimension(),1) { - if( ingrid->getDimension()<2 ) { - error("cannot find dividing surface if input grid is one dimensional"); - } + ones(ingrid->getDimension(),1) +{ + if( ingrid->getDimension()<2 ) error("cannot find dividing surface if input grid is one dimensional"); - std::string dir; - parse("SEARCHDIR",dir); - parse("BUFFER",gbuffer); + std::string dir; parse("SEARCHDIR",dir); parse("BUFFER",gbuffer); log.printf(" calculating location of contour on %d dimensional grid \n", ingrid->getDimension()-1 ); - if( gbuffer>0 ) { - log.printf(" after first step a subset of only %u grid points around where the countour was found will be checked\n",gbuffer); - } + if( gbuffer>0 ) log.printf(" after first step a subset of only %u grid points around where the countour was found will be checked\n",gbuffer); checkRead(); - unsigned n=0; - gdirs.resize( ingrid->getDimension()-1 ); + unsigned n=0; gdirs.resize( ingrid->getDimension()-1 ); for(unsigned i=0; igetDimension(); ++i) { if( ingrid->getComponentName(i)==dir ) { dir_n=i; } else { - if( n==gdirs.size() ) { - error("could not find " + dir + " direction in input grid"); - } - gdirs[n]=i; - n++; + if( n==gdirs.size() ) error("could not find " + dir + " direction in input grid"); + gdirs[n]=i; n++; } } - if( n!=(ingrid->getDimension()-1) ) { - error("output of grid is not understood"); - } + if( n!=(ingrid->getDimension()-1) ) error("output of grid is not understood"); // Create the input from the old string std::string vstring = "COMPONENTS=" + getLabel() + " COORDINATES=" + ingrid->getComponentName( gdirs[0] ); - for(unsigned i=1; igetComponentName( gdirs[i] ); - } + for(unsigned i=1; igetComponentName( gdirs[i] ); vstring += " PBC="; - if( ingrid->isPeriodic(gdirs[0]) ) { - vstring+="T"; - } else { - vstring+="F"; - } + if( ingrid->isPeriodic(gdirs[0]) ) vstring+="T"; + else vstring+="F"; for(unsigned i=1; iisPeriodic(gdirs[i]) ) { - vstring+=",T"; - } else { - vstring+=",F"; - } + if( ingrid->isPeriodic(gdirs[i]) ) vstring+=",T"; else vstring+=",F"; } - auto grid=createGrid( "grid", vstring ); - grid->setNoDerivatives(); + auto grid=createGrid( "grid", vstring ); grid->setNoDerivatives(); setAveragingAction( std::move(grid), true ); } void FindContourSurface::clearAverage() { // Set the boundaries of the output grid - std::vector fspacing; - std::vector snbins( ingrid->getDimension()-1 ); + std::vector fspacing; std::vector snbins( ingrid->getDimension()-1 ); std::vector smin( ingrid->getDimension()-1 ), smax( ingrid->getDimension()-1 ); for(unsigned i=0; igetMin()[gdirs[i]]; - smax[i]=ingrid->getMax()[gdirs[i]]; + smin[i]=ingrid->getMin()[gdirs[i]]; smax[i]=ingrid->getMax()[gdirs[i]]; snbins[i]=ingrid->getNbin()[gdirs[i]]; } - mygrid->setBounds( smin, smax, snbins, fspacing); - resizeFunctions(); + mygrid->setBounds( smin, smax, snbins, fspacing); resizeFunctions(); ActionWithAveraging::clearAverage(); } @@ -194,19 +166,14 @@ void FindContourSurface::prepareForAveraging() { std::vector find( ingrid->getDimension() ); std::vector ind( mygrid->getDimension() ); for(unsigned i=0; igetNumberOfPoints(); ++i) { - find.assign( find.size(), 0 ); - mygrid->getIndices( i, ind ); - for(unsigned j=0; jgetIndices( i, ind ); + for(unsigned j=0; jgetIndex(find) ); } // And prepare the task list deactivateAllTasks(); - for(unsigned i=0; igetDimension(), 0 ); @@ -221,8 +188,7 @@ void FindContourSurface::finishAveraging() { std::vector dx( ingrid->getGridSpacing() ); std::vector point( ingrid->getDimension() ); std::vector lpoint( mygrid->getDimension() ); - std::vector neighbours; - unsigned num_neighbours; + std::vector neighbours; unsigned num_neighbours; std::vector ugrid_indices( ingrid->getDimension() ); std::vector active( ingrid->getNumberOfPoints(), false ); std::vector gbuffer_vec( ingrid->getDimension(), gbuffer ); @@ -231,15 +197,11 @@ void FindContourSurface::finishAveraging() { mygrid->getGridPointCoordinates( i, lpoint ); point[dir_n] = mygrid->getGridElement( i, 0 ); // 0.5*dx added here to prevent problems with flooring of grid points - for(unsigned j=0; jgetIndices( point, ugrid_indices ); // Now activate buffer region ingrid->getNeighbors( ugrid_indices, gbuffer_vec, num_neighbours, neighbours ); - for(unsigned n=0; nactivateThesePoints( active ); } @@ -247,69 +209,43 @@ void FindContourSurface::finishAveraging() { } void FindContourSurface::compute( const unsigned& current, MultiValue& myvals ) const { - std::vector neighbours; - unsigned num_neighbours; - unsigned nfound=0; - double minp=0; - std::vector bins_n( ingrid->getNbin() ); - unsigned shiftn=current; - std::vector ind( ingrid->getDimension() ); - std::vector point( ingrid->getDimension() ); + std::vector neighbours; unsigned num_neighbours; unsigned nfound=0; double minp=0; + std::vector bins_n( ingrid->getNbin() ); unsigned shiftn=current; + std::vector ind( ingrid->getDimension() ); std::vector point( ingrid->getDimension() ); #ifndef NDEBUG - std::vector oind( mygrid->getDimension() ); - mygrid->getIndices( current, oind ); + std::vector oind( mygrid->getDimension() ); mygrid->getIndices( current, oind ); #endif for(unsigned i=0; i base_ind( ingrid->getDimension() ); - ingrid->getIndices( shiftn, base_ind ); - for(unsigned j=0; j base_ind( ingrid->getDimension() ); ingrid->getIndices( shiftn, base_ind ); + for(unsigned j=0; jinactive( shiftn ) ) { - shiftn += ingrid->getStride()[dir_n]; - continue; - } + if( ingrid->inactive( shiftn ) ) { shiftn += ingrid->getStride()[dir_n]; continue; } // Get the index of the current grid point ingrid->getIndices( shiftn, ind ); // Exit if we are at the edge of the grid if( !ingrid->isPeriodic(dir_n) && (ind[dir_n]+1)==bins_n[dir_n] ) { - shiftn += ingrid->getStride()[dir_n]; - continue; + shiftn += ingrid->getStride()[dir_n]; continue; } // Ensure points with inactive neighbours are ignored ingrid->getNeighbors( ind, ones, num_neighbours, neighbours ); bool cycle=false; for(unsigned j=0; jinactive( neighbours[j]) ) { - cycle=true; - break; - } - } - if( cycle ) { - shiftn += ingrid->getStride()[dir_n]; - continue; + if( ingrid->inactive( neighbours[j]) ) { cycle=true; break; } } + if( cycle ) { shiftn += ingrid->getStride()[dir_n]; continue; } // Now get the function value at two points - double val1=getFunctionValue( shiftn ) - contour; - double val2; - if( (ind[dir_n]+1)==bins_n[dir_n] ) { - val2 = getFunctionValue( current ) - contour; - } else { - val2=getFunctionValue( shiftn + ingrid->getStride()[dir_n] ) - contour; - } + double val1=getFunctionValue( shiftn ) - contour; double val2; + if( (ind[dir_n]+1)==bins_n[dir_n] ) val2 = getFunctionValue( current ) - contour; + else val2=getFunctionValue( shiftn + ingrid->getStride()[dir_n] ) - contour; // Check if the minimum is bracketed if( val1*val2<0 ) { - ingrid->getGridPointCoordinates( shiftn, point ); - findContour( direction, point ); - minp=point[dir_n]; - nfound++; - break; + ingrid->getGridPointCoordinates( shiftn, point ); findContour( direction, point ); + minp=point[dir_n]; nfound++; break; } @@ -317,8 +253,7 @@ void FindContourSurface::compute( const unsigned& current, MultiValue& myvals ) shiftn += ingrid->getStride()[dir_n]; } if( nfound==0 ) { - std::string num; - Tools::convert( getStep(), num ); + std::string num; Tools::convert( getStep(), num ); error("On step " + num + " failed to find required grid point"); } myvals.setValue( 1, minp ); diff --git a/src/gridtools/FindSphericalContour.cpp b/src/gridtools/FindSphericalContour.cpp index 9f2d3802dc..5d51ca2274 100644 --- a/src/gridtools/FindSphericalContour.cpp +++ b/src/gridtools/FindSphericalContour.cpp @@ -115,9 +115,7 @@ class FindSphericalContour : public ContourFindingBase { public: static void registerKeywords( Keywords& keys ); explicit FindSphericalContour(const ActionOptions&ao); - unsigned getNumberOfQuantities() const override { - return 2; - } + unsigned getNumberOfQuantities() const override { return 2; } void compute( const unsigned& current, MultiValue& myvals ) const override; }; @@ -133,36 +131,27 @@ void FindSphericalContour::registerKeywords( Keywords& keys ) { FindSphericalContour::FindSphericalContour(const ActionOptions&ao): Action(ao), - ContourFindingBase(ao) { - if( ingrid->getDimension()!=3 ) { - error("input grid must be three dimensional"); - } + ContourFindingBase(ao) +{ + if( ingrid->getDimension()!=3 ) error("input grid must be three dimensional"); - unsigned npoints; - parse("NPOINTS",npoints); + unsigned npoints; parse("NPOINTS",npoints); log.printf(" searching for %u points on dividing surface \n",npoints); - parse("INNER_RADIUS",min); - parse("OUTER_RADIUS",max); - parse("NBINS",nbins); + parse("INNER_RADIUS",min); parse("OUTER_RADIUS",max); parse("NBINS",nbins); log.printf(" expecting to find dividing surface at radii between %f and %f \n",min,max); log.printf(" looking for contour in windows of length %f \n", (max-min)/nbins); // Set this here so the same set of grid points are used on every turn std::string vstring = "TYPE=fibonacci COMPONENTS=" + getLabel() + " COORDINATES=x,y,z PBC=F,F,F"; - auto grid=createGrid( "grid", vstring ); - grid->setNoDerivatives(); + auto grid=createGrid( "grid", vstring ); grid->setNoDerivatives(); setAveragingAction( std::move(grid), true ); // use mygrid, since at this point grid has been moved mygrid->setupFibonacciGrid( npoints ); checkRead(); // Create a task list - for(unsigned i=0; igetDimension()!=2 ) { - error("fourier transform currently only works with two dimensional grids"); - } + if( ingrid->getDimension()!=2 ) error("fourier transform currently only works with two dimensional grids"); // Get the type of FT parse("FT_TYPE",output_type); @@ -123,26 +118,19 @@ FourierTransform::FourierTransform(const ActionOptions&ao): } else if ( output_type=="COMPLEX" || output_type=="complex" ) { log<<" keyword FT_TYPE is '"<< output_type <<"' : output grid will contain the COMPLEX Fourier coefficients\n"; real_output=false; - } else { - error("keyword FT_TYPE unrecognized!"); - } + } else error("keyword FT_TYPE unrecognized!"); // Normalize output? - std::string params_str; - parse("FOURIER_PARAMETERS",params_str); + std::string params_str; parse("FOURIER_PARAMETERS",params_str); if (params_str=="default") { fourier_params.assign( fourier_params.size(), 1 ); log.printf(" default values of Fourier parameters A=%i, B=%i : the output will NOT be normalized and BACKWARD Fourier transform is computed \n", fourier_params[0],fourier_params[1]); } else { std::vector fourier_str = Tools::getWords(params_str, "\t\n ,"); - if (fourier_str.size()>2) { - error("FOURIER_PARAMETERS can take just two values"); - } + if (fourier_str.size()>2) error("FOURIER_PARAMETERS can take just two values"); for (unsigned i=0; i1 || fourier_params[i]<-1) { - error("values accepted for FOURIER_PARAMETERS are only -1, 1 or 0"); - } + if (fourier_params[i]>1 || fourier_params[i]<-1) error("values accepted for FOURIER_PARAMETERS are only -1, 1 or 0"); } log.printf(" Fourier parameters are A=%i, B=%i \n", fourier_params[0],fourier_params[1]); } @@ -151,42 +139,25 @@ FourierTransform::FourierTransform(const ActionOptions&ao): // Create the input from the old string std::string vstring; if (real_output) { - if (!store_norm) { - vstring="COMPONENTS=" + getLabel() + "_abs"; - } else { - vstring="COMPONENTS=" + getLabel() + "_norm"; - } - } else { - vstring="COMPONENTS=" + getLabel() + "_real," + getLabel() + "_imag"; - } + if (!store_norm) vstring="COMPONENTS=" + getLabel() + "_abs"; + else vstring="COMPONENTS=" + getLabel() + "_norm"; + } else vstring="COMPONENTS=" + getLabel() + "_real," + getLabel() + "_imag"; // Set COORDINATES keyword vstring += " COORDINATES=" + ingrid->getComponentName( 0 ); - for(unsigned i=1; igetDimension(); ++i) { - vstring += "," + ingrid->getComponentName( i ); - } + for(unsigned i=1; igetDimension(); ++i) vstring += "," + ingrid->getComponentName( i ); // Set PBC keyword vstring += " PBC="; - if( ingrid->isPeriodic(0) ) { - vstring+="T"; - } else { - vstring+="F"; - } + if( ingrid->isPeriodic(0) ) vstring+="T"; else vstring+="F"; for(unsigned i=1; igetDimension(); ++i) { - if( ingrid->isPeriodic(i) ) { - vstring+=",T"; - } else { - vstring+=",F"; - } + if( ingrid->isPeriodic(i) ) vstring+=",T"; else vstring+=",F"; } // Create a grid on which to store the fourier transform of the input grid auto grid=createGrid( "grid", vstring ); - if( ingrid->noDerivatives() ) { - grid->setNoDerivatives(); - } + if( ingrid->noDerivatives() ) grid->setNoDerivatives(); setAveragingAction( std::move(grid), false ); checkRead(); @@ -197,11 +168,9 @@ void FourierTransform::clearAverage() { std::vector fspacing; std::vector ft_min( ingrid->getMin() ), ft_max( ingrid->getMax() ); for(unsigned i=0; igetDimension(); ++i) { - Tools::convert( 0.0, ft_min[i] ); - Tools::convert( 2.0*pi*ingrid->getNbin()[i]/ ingrid->getGridExtent(i), ft_max[i] ); + Tools::convert( 0.0, ft_min[i] ); Tools::convert( 2.0*pi*ingrid->getNbin()[i]/ ingrid->getGridExtent(i), ft_max[i] ); } - mygrid->setBounds( ft_min, ft_max, ingrid->getNbin(), fspacing); - resizeFunctions(); + mygrid->setBounds( ft_min, ft_max, ingrid->getNbin(), fspacing); resizeFunctions(); ActionWithAveraging::clearAverage(); } @@ -222,10 +191,7 @@ void FourierTransform::performOperations( const bool& from_update ) { // Get the size of the input data arrays (to allocate FFT data) size_t fft_dimension=static_cast( ingrid->getNumberOfPoints() ); std::vector N_input_data( ingrid->getNbin() ); - for(unsigned i=0; iisPeriodic(i) ) { - N_input_data[i]++; - } + for(unsigned i=0; iisPeriodic(i) ) N_input_data[i]++; // size_t fft_dimension=1; for(unsigned i=0; i( N_input_data[i] ); // FFT arrays @@ -262,11 +228,8 @@ void FourierTransform::performOperations( const bool& from_update ) { if (real_output) { double ft_value; // Compute abs/norm and fix normalization - if (!store_norm) { - ft_value=std::abs( fft_data[out_ind[0]*N_out_data[0]+out_ind[1]] / norm ); - } else { - ft_value=std::norm( fft_data[out_ind[0]*N_out_data[0]+out_ind[1]] / norm ); - } + if (!store_norm) ft_value=std::abs( fft_data[out_ind[0]*N_out_data[0]+out_ind[1]] / norm ); + else ft_value=std::norm( fft_data[out_ind[0]*N_out_data[0]+out_ind[1]] / norm ); // Set the value mygrid->setGridElement( i, 0, ft_value ); } else { diff --git a/src/gridtools/GridPrintingBase.cpp b/src/gridtools/GridPrintingBase.cpp index 4e227bfb6e..75ae61ca6b 100644 --- a/src/gridtools/GridPrintingBase.cpp +++ b/src/gridtools/GridPrintingBase.cpp @@ -28,8 +28,7 @@ namespace PLMD { namespace gridtools { void GridPrintingBase::registerKeywords( Keywords& keys ) { - Action::registerKeywords( keys ); - ActionPilot::registerKeywords( keys ); + Action::registerKeywords( keys ); ActionPilot::registerKeywords( keys ); keys.add("compulsory","GRID","the action that creates the grid you would like to output"); keys.add("compulsory","STRIDE","0","the frequency with which the grid should be output to the file. The default " "value of 0 ensures that the grid is only output at the end of the trajectory"); @@ -42,101 +41,64 @@ GridPrintingBase::GridPrintingBase(const ActionOptions&ao): Action(ao), ActionPilot(ao), fmt("%f"), - output_for_all_replicas(false) { - std::string mlab; - parse("GRID",mlab); + output_for_all_replicas(false) +{ + std::string mlab; parse("GRID",mlab); vesselbase::ActionWithVessel* mves= plumed.getActionSet().selectWithLabel(mlab); - if(!mves) { - error("action labelled " + mlab + " does not exist or does not have vessels"); - } + if(!mves) error("action labelled " + mlab + " does not exist or does not have vessels"); addDependency(mves); for(unsigned i=0; igetNumberOfVessels(); ++i) { ingrid=dynamic_cast( mves->getPntrToVessel(i) ); - if( ingrid ) { - break; - } - } - if( !ingrid ) { - error("input action does not calculate a grid"); + if( ingrid ) break; } + if( !ingrid ) error("input action does not calculate a grid"); parse("FILE",filename); - if(filename.length()==0) { - error("name out output file was not specified"); - } + if(filename.length()==0) error("name out output file was not specified"); log.printf(" outputting grid calculated by action %s to file named %s",mves->getLabel().c_str(), filename.c_str() ); if( keywords.exists("FMT") ) { - parse("FMT",fmt); - log.printf(" with format %s \n", fmt.c_str() ); + parse("FMT",fmt); log.printf(" with format %s \n", fmt.c_str() ); } else { log.printf("\n"); } - std::string rep_data; - parse("REPLICA",rep_data); - if( rep_data=="all" ) { - output_for_all_replicas=true; - } else { - preps.resize(1); - Tools::convert( rep_data, preps[0] ); - } - if( output_for_all_replicas ) { - log.printf(" outputting files for all replicas \n"); - } else { + std::string rep_data; parse("REPLICA",rep_data); + if( rep_data=="all" ) output_for_all_replicas=true; + else { preps.resize(1); Tools::convert( rep_data, preps[0] ); } + if( output_for_all_replicas ) log.printf(" outputting files for all replicas \n"); + else { log.printf(" outputting data for replicas "); - for(unsigned i=0; i0 ) { - return; - } + if( getStride()>0 ) return; - OFile ofile; - ofile.link(*this); - ofile.open( filename ); - printGrid( ofile ); + OFile ofile; ofile.link(*this); + ofile.open( filename ); printGrid( ofile ); } } diff --git a/src/gridtools/GridSearch.h b/src/gridtools/GridSearch.h index dbe0367f51..1f4276eabf 100644 --- a/src/gridtools/GridSearch.h +++ b/src/gridtools/GridSearch.h @@ -41,74 +41,50 @@ class GridSearch { std::unique_ptr myfgrid; public: GridSearch( const std::vector& mmin, const std::vector& mmax, const std::vector& ng, const std::vector& nfg, FCLASS* funcc ) : - myclass_func( funcc ) { + myclass_func( funcc ) + { // Create the grid objects std::string nstr, vstring="COMPONENTS=func COORDINATES=x1"; - for(unsigned i=1; i(dar); - if( nfg[0]>0 ) { - myfgrid=Tools::make_unique(dar); - } + if( nfg[0]>0 ) myfgrid=Tools::make_unique(dar); // Now setup the min and max values for the grid - std::vector gmin( nfg.size() ), gmax( nfg.size() ); - std::vector dummy_spacing; - for(unsigned i=0; isetBounds( gmin, gmax, ng, dummy_spacing ); - mygrid->resize(); - if( myfgrid ) { - myfgrid->setBounds( gmin, gmax, nfg, dummy_spacing ); - } + std::vector gmin( nfg.size() ), gmax( nfg.size() ); std::vector dummy_spacing; + for(unsigned i=0; isetBounds( gmin, gmax, ng, dummy_spacing ); mygrid->resize(); + if( myfgrid ) myfgrid->setBounds( gmin, gmax, nfg, dummy_spacing ); } bool minimise( std::vector& p, engf_pointer myfunc ); }; template bool GridSearch::minimise( std::vector& p, engf_pointer myfunc ) { - std::vector der( p.size() ); - std::vector coords( p.size() ); + std::vector der( p.size() ); std::vector coords( p.size() ); double initial_eng = (myclass_func->*myfunc)( p, der ); mygrid->getGridPointCoordinates( 0, coords ); double emin=(myclass_func->*myfunc)( coords, der ); - mygrid->setValueAndDerivatives( 0, 0, emin, der ); - unsigned pmin=0; + mygrid->setValueAndDerivatives( 0, 0, emin, der ); unsigned pmin=0; for(unsigned i=1; igetNumberOfPoints(); ++i) { mygrid->getGridPointCoordinates( i, coords ); double eng = (myclass_func->*myfunc)( coords, der ); mygrid->setValueAndDerivatives( i, 0, eng, der ); - if( engsetNorm( 1.0 ); if( myfgrid ) { - myfgrid->getGridPointCoordinates( 0, coords ); - pmin=0; + myfgrid->getGridPointCoordinates( 0, coords ); pmin=0; double emin=mygrid->getValueAndDerivatives( coords, 0, der ); for(unsigned i=1; igetNumberOfPoints(); ++i) { myfgrid->getGridPointCoordinates( i, coords ); double eng = mygrid->getValueAndDerivatives( coords, 0, der ); - if( enggetGridPointCoordinates( pmin, coords ); double checkEng = (myclass_func->*myfunc)( coords, der ); diff --git a/src/gridtools/GridToXYZ.cpp b/src/gridtools/GridToXYZ.cpp index 9b3e7595b8..033f7ac68b 100644 --- a/src/gridtools/GridToXYZ.cpp +++ b/src/gridtools/GridToXYZ.cpp @@ -59,47 +59,35 @@ void GridToXYZ::registerKeywords( Keywords& keys ) { GridToXYZ::GridToXYZ(const ActionOptions&ao): Action(ao), - GridPrintingBase(ao) { - if( ingrid->getDimension()!=3 ) { - error("cannot print grid xyz file if grid does not contain three dimensional data"); - } + GridPrintingBase(ao) +{ + if( ingrid->getDimension()!=3 ) error("cannot print grid xyz file if grid does not contain three dimensional data"); fmt = " " + fmt; if( ingrid->getNumberOfComponents()==1 ) { mycomp=0; } else { - int tcomp=-1; - parse("COMPONENT",tcomp); - if( tcomp<0 ) { - error("component of vector field was not specified - use COMPONENT keyword"); - } - mycomp=tcomp*(1+ingrid->getDimension()); - if( ingrid->noDerivatives() ) { - mycomp=tcomp; - } + int tcomp=-1; parse("COMPONENT",tcomp); + if( tcomp<0 ) error("component of vector field was not specified - use COMPONENT keyword"); + mycomp=tcomp*(1+ingrid->getDimension()); if( ingrid->noDerivatives() ) mycomp=tcomp; log.printf(" using %dth component of grid \n",tcomp ); } fmt="%f"; - std::string precision; - parse("PRECISION",precision); + std::string precision; parse("PRECISION",precision); if(precision.length()>0) { - int p; - Tools::convert(precision,p); + int p; Tools::convert(precision,p); log<<" with precision "<getGridPointCoordinates( i, point ); ofile.printf("X"); double val; - if( ingrid->getType()=="flat" ) { - val=1.0; - } else { - val=ingrid->getGridElement( i, 0 ); - } - for(unsigned j=0; j<3; ++j) { - ofile.printf( (" " + fmt).c_str(), val*lenunit*point[j] ); - } + if( ingrid->getType()=="flat" ) val=1.0; + else val=ingrid->getGridElement( i, 0 ); + for(unsigned j=0; j<3; ++j) { ofile.printf( (" " + fmt).c_str(), val*lenunit*point[j] ); } ofile.printf("\n"); } } diff --git a/src/gridtools/GridVessel.cpp b/src/gridtools/GridVessel.cpp index 864481e254..f51ddbecec 100644 --- a/src/gridtools/GridVessel.cpp +++ b/src/gridtools/GridVessel.cpp @@ -41,84 +41,47 @@ GridVessel::GridVessel( const vesselbase::VesselOptions& da ): npoints(0), cube_units(1.0), wasforced(false), - noderiv(false) { - std::string geom; - parse("TYPE",geom); - if( geom=="flat" ) { - gtype=flat; - } else if( geom=="fibonacci" ) { - gtype=fibonacci; - } else { - plumed_merror( geom + " is invalid geometry type"); - } - std::vector compnames; - parseVector("COMPONENTS",compnames); - std::vector coordnames; - parseVector("COORDINATES",coordnames); + noderiv(false) +{ + std::string geom; parse("TYPE",geom); + if( geom=="flat" ) gtype=flat; + else if( geom=="fibonacci" ) gtype=fibonacci; + else plumed_merror( geom + " is invalid geometry type"); + std::vector compnames; parseVector("COMPONENTS",compnames); + std::vector coordnames; parseVector("COORDINATES",coordnames); if( gtype==flat ) { dimension=coordnames.size(); - str_min.resize( dimension); - str_max.resize( dimension ); - stride.resize( dimension ); - max.resize( dimension ); - dx.resize( dimension ); - nbin.resize( dimension ); - min.resize( dimension ); + str_min.resize( dimension); str_max.resize( dimension ); stride.resize( dimension ); + max.resize( dimension ); dx.resize( dimension ); nbin.resize( dimension ); min.resize( dimension ); } else if( gtype==fibonacci ) { - if( coordnames.size()!=3 ) { - error("cannot generate fibonacci grid points on surface of sphere if not 3 input coordinates"); - } + if( coordnames.size()!=3 ) error("cannot generate fibonacci grid points on surface of sphere if not 3 input coordinates"); dimension=3; } - unsigned n=0; - nper=compnames.size()*( 1 + coordnames.size() ); + unsigned n=0; nper=compnames.size()*( 1 + coordnames.size() ); arg_names.resize( coordnames.size() + compnames.size()*( 1 + coordnames.size() ) ); - for(unsigned i=0; i spbc( dimension ); - parseVector("PBC",spbc); + std::vector spbc( dimension ); parseVector("PBC",spbc); for(unsigned i=0; i tnames( dimension ), cnames(nper); - for(unsigned i=0; i& smin, const std::vector& smax, @@ -126,11 +89,9 @@ void GridVessel::setBounds( const std::vector& smin, const std::vec plumed_dbg_assert( smin.size()==dimension && smax.size()==dimension ); plumed_assert( gtype==flat && (spacing.size()==dimension || binsin.size()==dimension) ); - npoints=1; - bounds_set=true; + npoints=1; bounds_set=true; for(unsigned i=0; i& smin, const std::vec Tools::convertNoexcept( str_max[i], max[i] ); if( spacing.size()==dimension && binsin.size()==dimension ) { - if( spacing[i]==0 ) { - nbin[i] = binsin[i]; - } else { - double range = max[i] - min[i]; - nbin[i] = std::round( range / spacing[i]); + if( spacing[i]==0 ) nbin[i] = binsin[i]; + else { + double range = max[i] - min[i]; nbin[i] = std::round( range / spacing[i]); // This check ensures that nbins is set correctly if spacing is set the same as the number of bins - if( nbin[i]!=binsin[i] ) { - plumed_merror("mismatch between input spacing and input number of bins"); - } + if( nbin[i]!=binsin[i] ) plumed_merror("mismatch between input spacing and input number of bins"); } - } else if( binsin.size()==dimension ) { - nbin[i]=binsin[i]; - } else if( spacing.size()==dimension ) { - nbin[i] = std::floor(( max[i] - min[i] ) / spacing[i]) + 1; - } else { - plumed_error(); - } + } else if( binsin.size()==dimension ) nbin[i]=binsin[i]; + else if( spacing.size()==dimension ) nbin[i] = std::floor(( max[i] - min[i] ) / spacing[i]) + 1; + else plumed_error(); dx[i] = ( max[i] - min[i] ) / static_cast( nbin[i] ); - if( !pbc[i] ) { - max[i] +=dx[i]; - nbin[i]+=1; - } + if( !pbc[i] ) { max[i] +=dx[i]; nbin[i]+=1; } stride[i]=npoints; npoints*=nbin[i]; } @@ -167,13 +117,9 @@ void GridVessel::setBounds( const std::vector& smin, const std::vec } void GridVessel::setupFibonacciGrid( const unsigned& np ) { - bounds_set=true; - root5 = std::sqrt(5); - npoints = np; - golden = ( 1 + std::sqrt(5) ) / 2.0; - igolden = golden - 1; - fib_increment = 2*pi*igolden; - log_golden2 = std::log( golden*golden ); + bounds_set=true; root5 = std::sqrt(5); + npoints = np; golden = ( 1 + std::sqrt(5) ) / 2.0; igolden = golden - 1; + fib_increment = 2*pi*igolden; log_golden2 = std::log( golden*golden ); fib_offset = 2 / static_cast( npoints ); fib_shift = fib_offset/2 - 1; resize(); @@ -182,85 +128,57 @@ void GridVessel::setupFibonacciGrid( const unsigned& np ) { // Find minimum distance between each pair of points std::vector mindists( npoints ); for(unsigned i=0; imindists[i] ) { - mindists[i]=dot; - } + double dot=0; for(unsigned k=0; kmindists[i] ) mindists[i]=dot; } } // And now take minimum of dot products double min=mindists[0]; for(unsigned i=1; ifinal_cutoff ) { - fib_nlist[i].push_back(j); - } + double dot=0; for(unsigned k=0; kfinal_cutoff ) { fib_nlist[i].push_back(j); } } } } std::string GridVessel::description() { - if( !bounds_set ) { - return ""; - } + if( !bounds_set ) return ""; std::string des; if( gtype==flat ) { - des="grid of "; - std::string num; + des="grid of "; std::string num; for(unsigned i=0; i0, "Number of datapoints at each grid point has not been set"); - if( getAction() ) { - resizeBuffer( getNumberOfBufferPoints()*nper + 1 + 2*getAction()->getNumberOfDerivatives() ); - } - setDataSize( npoints*nper ); - forces.resize( npoints ); - if( active.size()!=npoints) { - active.resize( npoints, true ); - } + if( getAction() ) resizeBuffer( getNumberOfBufferPoints()*nper + 1 + 2*getAction()->getNumberOfDerivatives() ); + setDataSize( npoints*nper ); forces.resize( npoints ); + if( active.size()!=npoints) active.resize( npoints, true ); } unsigned GridVessel::getIndex( const std::vector& indices ) const { @@ -292,15 +205,10 @@ void GridVessel::getIndices( const std::vector& point, std::vectornbin[i] ) { - std::string pp, num; - Tools::convert( point[0], pp ); - for(unsigned j=1; jnbin[i] ) { + std::string pp, num; Tools::convert( point[0], pp ); + for(unsigned j=1; j& point, std::vector& point ) const { plumed_dbg_assert( gtype==flat && bounds_set && point.size()==dimension ); if( gtype==flat ) { - std::vector indices(dimension); - getIndices( point, indices ); + std::vector indices(dimension); getIndices( point, indices ); return getIndex( indices ); } else if( gtype==fibonacci ) { return getFibonacciIndex( point ); @@ -322,63 +229,34 @@ unsigned GridVessel::getIndex( const std::vector& point ) const { unsigned GridVessel::getFibonacciIndex( const std::vector& p ) const { plumed_dbg_assert( gtype==fibonacci ); // Convert input point to coordinates on cylinder - int k=2; - double phi = std::atan2( p[2], p[0] ), sinthet2 = 1 - p[1]*p[1]; + int k=2; double phi = std::atan2( p[2], p[0] ), sinthet2 = 1 - p[1]*p[1]; // Calculate power to raise golden ratio - if( sinthet2 B(2,2), invB(2,2); - std::vector thisp(3); + Matrix B(2,2), invB(2,2); std::vector thisp(3); B(0,0) = 2*pi*((F0+1)*igolden - std::floor((F0+1)*igolden)) - fib_increment; B(0,1) = 2*pi*((F1+1)*igolden - std::floor((F1+1)*igolden)) - fib_increment; - B(1,0) = -2*F0/npoints; - B(1,1) = -2*F1/npoints; - Invert( B, invB ); - std::vector vv(2), rc(2); - vv[0]=-phi; - vv[1] = p[1] - fib_shift; - mult( invB, vv, rc ); - std::vector c(2); - c[0]=std::floor(rc[0]); - c[1]=std::floor(rc[1]); - unsigned outind=0; - double mindist = 10000000.; + B(1,0) = -2*F0/npoints; B(1,1) = -2*F1/npoints; Invert( B, invB ); + std::vector vv(2), rc(2); vv[0]=-phi; vv[1] = p[1] - fib_shift; + mult( invB, vv, rc ); std::vector c(2); c[0]=std::floor(rc[0]); c[1]=std::floor(rc[1]); + unsigned outind=0; double mindist = 10000000.; for(int s=0; s<4; ++s) { double ttt, costheta = B(1,0)*( c[0] + s%2 ) + B(1,1)*( c[1] + s/2 ) + fib_shift; - if( costheta>1 ) { - ttt=1; - } else if( costheta<-1 ) { - ttt=-1; - } else { - ttt=costheta; - } + if( costheta>1 ) ttt=1; else if( costheta<-1 ) ttt=-1; else ttt=costheta; costheta = 2*ttt - costheta; - unsigned i = std::floor( 0.5*npoints*(1+costheta) ); - getFibonacciCoordinates( i, thisp ); - double dist=0; - for(unsigned j=0; j<3; ++j) { - double tmp=thisp[j]-p[j]; - dist += tmp*tmp; - } - if( dist& nnbin, std::vector& indices ) const { - plumed_dbg_assert( gtype==flat ); - unsigned kk=index; - indices[0]=index%nnbin[0]; + plumed_dbg_assert( gtype==flat ); unsigned kk=index; indices[0]=index%nnbin[0]; for(unsigned i=1; i& indices ) const { - plumed_dbg_assert( gtype==flat ); - convertIndexToIndices( index, nbin, indices ); + plumed_dbg_assert( gtype==flat ); convertIndexToIndices( index, nbin, indices ); } void GridVessel::getGridPointCoordinates( const unsigned& ipoint, std::vector& x ) const { - std::vector tindices( dimension ); - getGridPointCoordinates( ipoint, tindices, x ); + std::vector tindices( dimension ); getGridPointCoordinates( ipoint, tindices, x ); } void GridVessel::getGridPointCoordinates( const unsigned& ipoint, std::vector& tindices, std::vector& x ) const { @@ -410,54 +286,32 @@ void GridVessel::getGridPointCoordinates( const unsigned& ipoint, std::vector& tindices, std::vector& x ) const { - plumed_dbg_assert( gtype==flat ); - getIndices( ipoint, tindices ); - for(unsigned i=0; i& x ) const { plumed_dbg_assert( gtype==fibonacci ); - x[1] = (ipoint*fib_offset) + fib_shift; - double r = std::sqrt( 1 - x[1]*x[1] ); - double phi = ipoint*fib_increment; - x[0] = r*std::cos(phi); - x[2] = r*std::sin(phi); - double norm=0; - for(unsigned j=0; j<3; ++j) { - norm+=x[j]*x[j]; - } - norm = std::sqrt(norm); - for(unsigned j=0; j<3; ++j) { - x[j] = x[j] / norm; - } + x[1] = (ipoint*fib_offset) + fib_shift; double r = std::sqrt( 1 - x[1]*x[1] ); + double phi = ipoint*fib_increment; x[0] = r*std::cos(phi); x[2] = r*std::sin(phi); + double norm=0; for(unsigned j=0; j<3; ++j) norm+=x[j]*x[j]; + norm = std::sqrt(norm); for(unsigned j=0; j<3; ++j) x[j] = x[j] / norm; } void GridVessel::getSplineNeighbors( const unsigned& mybox, unsigned& nneighbors, std::vector& mysneigh ) const { - plumed_dbg_assert( gtype==flat ); - unsigned nneigh=unsigned(pow(2.0,int(dimension))); - if( mysneigh.size()!=nneigh ) { - mysneigh.resize(nneigh); - } + plumed_dbg_assert( gtype==flat ); unsigned nneigh=unsigned(pow(2.0,int(dimension))); + if( mysneigh.size()!=nneigh ) mysneigh.resize(nneigh); - unsigned inind; - nneighbors = 0; + unsigned inind; nneighbors = 0; std::vector tmp_indices( dimension ); std::vector my_indices( dimension ); getIndices( mybox, my_indices ); for(unsigned i=0; i& der ) { plumed_dbg_assert( !noderiv && jelement& buffer, std::vector& der_list ) const { plumed_dbg_assert( myvals.getNumberOfValues()==(nper+1) ); - for(unsigned i=0; i& buffer ) { - if( wasforced ) { - getFinalForces( buffer, finalForces ); - } else { - AveragingVessel::finish( buffer ); - } + if( wasforced ) getFinalForces( buffer, finalForces ); + else AveragingVessel::finish( buffer ); } double GridVessel::getGridElement( const std::vector& indices, const unsigned& jelement ) const { @@ -515,24 +361,19 @@ void GridVessel::setGridElement( const std::vector& indices, const uns } std::vector GridVessel::getMin() const { - plumed_dbg_assert( gtype==flat ); - return str_min; + plumed_dbg_assert( gtype==flat ); return str_min; } std::vector GridVessel::getMax() const { - plumed_dbg_assert( gtype==flat ); - return str_max; + plumed_dbg_assert( gtype==flat ); return str_max; } std::vector GridVessel::getNbin() const { plumed_dbg_assert( gtype==flat && bounds_set ); std::vector ngrid( dimension ); for(unsigned i=0; i& pp, const std::vector< if( gtype == flat ) { plumed_dbg_assert( nneigh.size()==dimension ); std::vector indices( dimension ); - for(unsigned i=0; i& indices, const std:: unsigned& num_neighbors, std::vector& neighbors ) const { plumed_dbg_assert( gtype==flat && bounds_set && nneigh.size()==dimension ); - unsigned num_neigh=1; - std::vector small_bin( dimension ); + unsigned num_neigh=1; std::vector small_bin( dimension ); for(unsigned i=0; i s_indices(dimension), t_indices(dimension); @@ -584,18 +415,10 @@ void GridVessel::getNeighbors( const std::vector& indices, const std:: convertIndexToIndices( index, small_bin, s_indices ); for(unsigned i=0; i=nbin[i]) { - found=false; - } - if( pbc[i] && i0<0) { - i0=nbin[i]-(-i0)%nbin[i]; - } - if( pbc[i] && i0>=nbin[i]) { - i0%=nbin[i]; - } + if(!pbc[i] && i0<0) found=false; + if(!pbc[i] && i0>=nbin[i]) found=false; + if( pbc[i] && i0<0) i0=nbin[i]-(-i0)%nbin[i]; + if( pbc[i] && i0>=nbin[i]) i0%=nbin[i]; t_indices[i]=static_cast(i0); } if( found ) { @@ -606,33 +429,23 @@ void GridVessel::getNeighbors( const std::vector& indices, const std:: } void GridVessel::setCubeUnits( const double& units ) { - plumed_dbg_assert( gtype==flat ); - cube_units=units; + plumed_dbg_assert( gtype==flat ); cube_units=units; } double GridVessel::getCubeUnits() const { - plumed_dbg_assert( gtype==flat ); - return cube_units; + plumed_dbg_assert( gtype==flat ); return cube_units; } std::string GridVessel::getInputString() const { std::string mstring="COORDINATES="+arg_names[0]; - for(unsigned i=1; i& x, const unsigned& ind, std::vector& der ) const { plumed_dbg_assert( gtype==flat && der.size()==dimension && !noderiv && ind fd(dimension); std::vector C(dimension); std::vector D(dimension); std::vector dder(dimension); - std::vector nindices(dimension); - unsigned n_neigh; - std::vector indices(dimension); - getIndices( x, indices ); - std::vector neigh; - getSplineNeighbors( getIndex(indices), n_neigh, neigh ); - std::vector xfloor(dimension); - getFlatGridCoordinates( getIndex(x), nindices, xfloor ); + std::vector nindices(dimension); unsigned n_neigh; + std::vector indices(dimension); getIndices( x, indices ); + std::vector neigh; getSplineNeighbors( getIndex(indices), n_neigh, neigh ); + std::vector xfloor(dimension); getFlatGridCoordinates( getIndex(x), nindices, xfloor ); // loop over neighbors for(unsigned int ipoint=0; ipoint& x, const u } for(unsigned j=0; j& to_activate ) { plumed_dbg_assert( to_activate.size()==npoints ); - for(unsigned i=0; i& inforces ) { plumed_dbg_assert( inforces.size()==npoints ); - wasforced=true; - for(unsigned i=0; i& fforces ) { plumed_dbg_assert( fforces.size()==finalForces.size() ); - if( !wasforced ) { - return false; - } - for(unsigned i=0; i& buffer, std::vector& finalForces ) { - plumed_error(); - } + virtual void getFinalForces( const std::vector& buffer, std::vector& finalForces ) { plumed_error(); } /// Apply the forces void setForce( const std::vector& inforces ); /// Was a force added to the grid @@ -208,19 +206,14 @@ unsigned GridVessel::getNumberOfPoints() const { inline const std::vector& GridVessel::getGridSpacing() const { - if( gtype==flat ) { - return dx; - } + if( gtype==flat ) return dx; plumed_merror("dont understand what spacing means for spherical grids"); } inline double GridVessel::getCellVolume() const { if( gtype==flat ) { - double myvol=1.0; - for(unsigned i=0; i( getNumberOfPoints() ); @@ -245,9 +238,7 @@ std::string GridVessel::getComponentName( const unsigned& i ) const { inline unsigned GridVessel::getNumberOfComponents() const { - if( noderiv ) { - return nper; - } + if( noderiv ) return nper; return nper / ( dimension + 1 ); } @@ -281,11 +272,8 @@ unsigned GridVessel::getNumberOfBufferPoints() const { inline std::string GridVessel::getType() const { - if( gtype==flat ) { - return "flat"; - } else if( gtype==fibonacci ) { - return "fibonacci"; - } + if( gtype==flat ) return "flat"; + else if( gtype==fibonacci ) return "fibonacci"; plumed_error(); } diff --git a/src/gridtools/HistogramOnGrid.cpp b/src/gridtools/HistogramOnGrid.cpp index 48881a9bf3..23be915151 100644 --- a/src/gridtools/HistogramOnGrid.cpp +++ b/src/gridtools/HistogramOnGrid.cpp @@ -37,12 +37,12 @@ HistogramOnGrid::HistogramOnGrid( const vesselbase::VesselOptions& da ): neigh_tot(0), addOneKernelAtATime(false), bandwidths(dimension), - discrete(false) { + discrete(false) +{ if( getType()=="flat" ) { parse("KERNEL",kerneltype); if( kerneltype=="discrete" || kerneltype=="DISCRETE" ) { - discrete=true; - setNoDerivatives(); + discrete=true; setNoDerivatives(); } else { parseVector("BANDWIDTH",bandwidths); } @@ -65,14 +65,10 @@ void HistogramOnGrid::setBounds( const std::vector& smin, const std GridVessel::setBounds( smin, smax, nbins, spacing ); if( !discrete ) { std::vector point(dimension,0); - KernelFunctions kernel( point, bandwidths, kerneltype, "DIAGONAL", 1.0 ); - neigh_tot=1; - nneigh=kernel.getSupport( dx ); - std::vector support( kernel.getContinuousSupport() ); + KernelFunctions kernel( point, bandwidths, kerneltype, "DIAGONAL", 1.0 ); neigh_tot=1; + nneigh=kernel.getSupport( dx ); std::vector support( kernel.getContinuousSupport() ); for(unsigned i=0; igetGridExtent(i) ) { - error("bandwidth is too large for periodic grid"); - } + if( pbc[i] && 2*support[i]>getGridExtent(i) ) error("bandwidth is too large for periodic grid"); neigh_tot *= (2*nneigh[i]+1); } } @@ -81,19 +77,14 @@ void HistogramOnGrid::setBounds( const std::vector& smin, const std std::unique_ptr HistogramOnGrid::getKernelAndNeighbors( std::vector& point, unsigned& num_neigh, std::vector& neighbors ) const { if( discrete ) { plumed_assert( getType()=="flat" ); - num_neigh=1; - for(unsigned i=0; i( point, bandwidths, kerneltype, "DIAGONAL", 1.0 ); // GB: Now values is destroyed when exiting this function. // I think before there was a leak std::vector> values=getVectorOfValues(); - kernel->normalize( Tools::unique2raw(values) ); - getNeighbors( kernel->getCenter(), nneigh, num_neigh, neighbors ); + kernel->normalize( Tools::unique2raw(values) ); getNeighbors( kernel->getCenter(), nneigh, num_neigh, neighbors ); return kernel; } else if( getType()=="fibonacci" ) { getNeighbors( point, nneigh, num_neigh, neighbors ); @@ -108,11 +99,8 @@ std::vector> HistogramOnGrid::getVectorOfValues() const { std::vector> vv; for(unsigned i=0; i()); - if( pbc[i] ) { - vv[i]->setDomain( str_min[i], str_max[i] ); - } else { - vv[i]->setNotPeriodic(); - } + if( pbc[i] ) vv[i]->setDomain( str_min[i], str_max[i] ); + else vv[i]->setNotPeriodic(); } return vv; } @@ -121,59 +109,40 @@ void HistogramOnGrid::calculate( const unsigned& current, MultiValue& myvals, st if( addOneKernelAtATime ) { plumed_dbg_assert( myvals.getNumberOfValues()==2 && !wasforced ); std::vector der( dimension ); - for(unsigned i=0; igetPositionInCurrentTaskList(current), myvals.get(0), myvals.get(1), der, buffer ); } else { plumed_dbg_assert( myvals.getNumberOfValues()==dimension+2 ); - std::vector point( dimension ); - double weight=myvals.get(0)*myvals.get( 1+dimension ); - for(unsigned i=0; i point( dimension ); double weight=myvals.get(0)*myvals.get( 1+dimension ); + for(unsigned i=0; i neighbors(1); + unsigned num_neigh; std::vector neighbors(1); std::vector der( dimension ); std::unique_ptr kernel=getKernelAndNeighbors( point, num_neigh, neighbors ); if( !kernel && getType()=="flat" ) { - plumed_dbg_assert( num_neigh==1 ); - der.resize(0); + plumed_dbg_assert( num_neigh==1 ); der.resize(0); accumulate( neighbors[0], weight, 1.0, der, buffer ); } else { double totwforce=0.0; std::vector intforce( 2*dimension, 0.0 ); std::vector> vv( getVectorOfValues() ); - double newval; - std::vector tindices( dimension ); - std::vector xx( dimension ); + double newval; std::vector tindices( dimension ); std::vector xx( dimension ); for(unsigned i=0; iset(xx[j]); - } + for(unsigned j=0; jset(xx[j]); newval = kernel->evaluate( Tools::unique2raw(vv), der, true ); } else { // Evalulate dot product - double dot=0; - for(unsigned j=0; jgetNumberOfDerivatives(); unsigned gridbuf = getNumberOfBufferPoints()*getNumberOfQuantities(); for(unsigned j=0; j& der, std::vector& buffer ) const { buffer[bufstart+nper*ipoint] += weight*dens; - if( der.size()>0 ) - for(unsigned j=0; j0 ) for(unsigned j=0; j& der, std::vector& intforce ) const { - for(unsigned j=0; j& buffer, std::vector& finalForces ) { - if( finalForces.size()!=getAction()->getNumberOfDerivatives() ) { - finalForces.resize( getAction()->getNumberOfDerivatives() ); - } + if( finalForces.size()!=getAction()->getNumberOfDerivatives() ) finalForces.resize( getAction()->getNumberOfDerivatives() ); // And the final force unsigned nder = getAction()->getNumberOfDerivatives(); // Derivatives due to normalization unsigned gridbuf = getNumberOfBufferPoints()*getNumberOfQuantities(); - for(unsigned i=0; i& buffer ) { if( addOneKernelAtATime ) { for(unsigned i=0; igetCurrentNumberOfActiveTasks(); ++i) { - for(unsigned j=0; jgetActiveTask(i)+j, buffer[bufstart+i*nper+j] ); - } + for(unsigned j=0; jgetActiveTask(i)+j, buffer[bufstart+i*nper+j] ); } } else { GridVessel::finish( buffer ); diff --git a/src/gridtools/HistogramOnGrid.h b/src/gridtools/HistogramOnGrid.h index 7c5fd39186..a60b3080bd 100644 --- a/src/gridtools/HistogramOnGrid.h +++ b/src/gridtools/HistogramOnGrid.h @@ -54,9 +54,7 @@ class HistogramOnGrid : public GridVessel { unsigned getNumberOfBufferPoints() const override; std::unique_ptr getKernelAndNeighbors( std::vector& point, unsigned& num_neigh, std::vector& neighbors ) const; std::vector> getVectorOfValues() const ; - void addOneKernelEachTimeOnly() { - addOneKernelAtATime=true; - } + void addOneKernelEachTimeOnly() { addOneKernelAtATime=true; } void getFinalForces( const std::vector& buffer, std::vector& finalForces ) override; bool noDiscreteKernels() const ; double getFibonacciCutoff() const override; @@ -64,9 +62,7 @@ class HistogramOnGrid : public GridVessel { inline unsigned HistogramOnGrid::getNumberOfBufferPoints() const { - if( addOneKernelAtATime ) { - return neigh_tot; - } + if( addOneKernelAtATime ) return neigh_tot; return GridVessel::getNumberOfBufferPoints(); } diff --git a/src/gridtools/IntegrateGrid.cpp b/src/gridtools/IntegrateGrid.cpp index e3fa22c71e..e3abba97c2 100644 --- a/src/gridtools/IntegrateGrid.cpp +++ b/src/gridtools/IntegrateGrid.cpp @@ -49,15 +49,13 @@ void IntegrateGrid::registerKeywords( Keywords& keys ) { IntegrateGrid::IntegrateGrid(const ActionOptions&ao): Action(ao), - ActionWithIntegral(ao) { + ActionWithIntegral(ao) +{ } void IntegrateGrid::compute( const unsigned& current, MultiValue& myvals ) const { - myvals.setValue( 0, 1.0 ); - myvals.setValue( 1, getVolume()*getFunctionValue( current ) ); - if( !doNotCalculateDerivatives() ) { - myvals.addDerivative( 1, current, getVolume() ); - } + myvals.setValue( 0, 1.0 ); myvals.setValue( 1, getVolume()*getFunctionValue( current ) ); + if( !doNotCalculateDerivatives() ) myvals.addDerivative( 1, current, getVolume() ); } } diff --git a/src/gridtools/InterpolateGrid.cpp b/src/gridtools/InterpolateGrid.cpp index 72a825935f..e0335b53ba 100644 --- a/src/gridtools/InterpolateGrid.cpp +++ b/src/gridtools/InterpolateGrid.cpp @@ -56,9 +56,7 @@ class InterpolateGrid : public ActionWithInputGrid { explicit InterpolateGrid(const ActionOptions&ao); unsigned getNumberOfQuantities() const override; void compute( const unsigned& current, MultiValue& myvals ) const override; - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(InterpolateGrid,"INTERPOLATE_GRID") @@ -67,25 +65,21 @@ void InterpolateGrid::registerKeywords( Keywords& keys ) { ActionWithInputGrid::registerKeywords( keys ); keys.add("optional","GRID_BIN","the number of bins for the grid"); keys.add("optional","GRID_SPACING","the approximate grid spacing (to be used as an alternative or together with GRID_BIN)"); - keys.remove("KERNEL"); - keys.remove("BANDWIDTH"); + keys.remove("KERNEL"); keys.remove("BANDWIDTH"); } InterpolateGrid::InterpolateGrid(const ActionOptions&ao): Action(ao), - ActionWithInputGrid(ao) { + ActionWithInputGrid(ao) +{ plumed_assert( ingrid->getNumberOfComponents()==1 ); - if( ingrid->noDerivatives() ) { - error("cannot interpolate a grid that does not have derivatives"); - } + if( ingrid->noDerivatives() ) error("cannot interpolate a grid that does not have derivatives"); // Create the input from the old string auto grid=createGrid( "grid", "COMPONENTS=" + getLabel() + " " + ingrid->getInputString() ); // notice that createGrid also sets mygrid=grid.get() - std::vector nbin; - parseVector("GRID_BIN",nbin); - std::vector gspacing; - parseVector("GRID_SPACING",gspacing); + std::vector nbin; parseVector("GRID_BIN",nbin); + std::vector gspacing; parseVector("GRID_SPACING",gspacing); if( nbin.size()!=ingrid->getDimension() && gspacing.size()!=ingrid->getDimension() ) { error("GRID_BIN or GRID_SPACING must be set"); } @@ -95,14 +89,10 @@ InterpolateGrid::InterpolateGrid(const ActionOptions&ao): setAveragingAction( std::move(grid), true ); // Now create task list - for(unsigned i=0; igetNumberOfPoints(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetNumberOfPoints(); ++i) addTaskToList(i); // And activate all tasks deactivateAllTasks(); - for(unsigned i=0; igetNumberOfPoints(); ++i) { - taskFlags[i]=1; - } + for(unsigned i=0; igetNumberOfPoints(); ++i) taskFlags[i]=1; lockContributors(); } @@ -111,15 +101,10 @@ unsigned InterpolateGrid::getNumberOfQuantities() const { } void InterpolateGrid::compute( const unsigned& current, MultiValue& myvals ) const { - std::vector pos( mygrid->getDimension() ); - mygrid->getGridPointCoordinates( current, pos ); - std::vector der( mygrid->getDimension() ); - double val = getFunctionValueAndDerivatives( pos, der ); - myvals.setValue( 0, 1.0 ); - myvals.setValue(1, val ); - for(unsigned i=0; igetDimension(); ++i) { - myvals.setValue( 2+i, der[i] ); - } + std::vector pos( mygrid->getDimension() ); mygrid->getGridPointCoordinates( current, pos ); + std::vector der( mygrid->getDimension() ); double val = getFunctionValueAndDerivatives( pos, der ); + myvals.setValue( 0, 1.0 ); myvals.setValue(1, val ); + for(unsigned i=0; igetDimension(); ++i) myvals.setValue( 2+i, der[i] ); } } diff --git a/src/isdb/CS2Backbone.cpp b/src/isdb/CS2Backbone.cpp index 12b1eb4a49..f6e40be6b2 100644 --- a/src/isdb/CS2Backbone.cpp +++ b/src/isdb/CS2Backbone.cpp @@ -175,193 +175,160 @@ class CS2BackboneDB { public: inline unsigned kind(const std::string &s) { - if(s=="GLY") { - return GLY; - } else if(s=="PRO") { - return PRO; - } + if(s=="GLY") return GLY; + else if(s=="PRO") return PRO; return STD; } inline unsigned atom_kind(const std::string &s) { - if(s=="HA") { - return HA_ATOM; - } else if(s=="H") { - return H_ATOM; - } else if(s=="N") { - return N_ATOM; - } else if(s=="CA") { - return CA_ATOM; - } else if(s=="CB") { - return CB_ATOM; - } else if(s=="C") { - return C_ATOM; - } + if(s=="HA")return HA_ATOM; + else if(s=="H") return H_ATOM; + else if(s=="N") return N_ATOM; + else if(s=="CA")return CA_ATOM; + else if(s=="CB")return CB_ATOM; + else if(s=="C") return C_ATOM; return -1; } - unsigned get_numXtraDists() { - return numXtraDists; - } + unsigned get_numXtraDists() {return numXtraDists;} //PARAMETERS - inline double * CONSTAACURR(const unsigned a_kind, const unsigned at_kind) { - return c_aa[a_kind][at_kind]; - } - inline double * CONSTAANEXT(const unsigned a_kind, const unsigned at_kind) { - return c_aa_succ[a_kind][at_kind]; - } - inline double * CONSTAAPREV(const unsigned a_kind, const unsigned at_kind) { - return c_aa_prev[a_kind][at_kind]; - } - inline double * CONST_BB2(const unsigned a_kind, const unsigned at_kind) { - return co_bb[a_kind][at_kind]; - } - inline double * CONST_SC2(const unsigned a_kind, const unsigned at_kind, unsigned res_type) { - return co_sc_[a_kind][at_kind][res_type]; - } - inline double * CONST_XD(const unsigned a_kind, const unsigned at_kind) { - return co_xd[a_kind][at_kind]; - } - inline double * CO_SPHERE(const unsigned a_kind, const unsigned at_kind, unsigned exp_type) { - return co_sphere[a_kind][at_kind][exp_type]; - } - inline double * CO_RING(const unsigned a_kind, const unsigned at_kind) { - return co_ring[a_kind][at_kind]; - } - inline double * CO_DA(const unsigned a_kind, const unsigned at_kind) { - return co_da[a_kind][at_kind]; - } - inline double * PARS_DA(const unsigned a_kind, const unsigned at_kind, const unsigned ang_kind) { - return pars_da[a_kind][at_kind][ang_kind]; - } + inline double * CONSTAACURR(const unsigned a_kind, const unsigned at_kind) {return c_aa[a_kind][at_kind];} + inline double * CONSTAANEXT(const unsigned a_kind, const unsigned at_kind) {return c_aa_succ[a_kind][at_kind];} + inline double * CONSTAAPREV(const unsigned a_kind, const unsigned at_kind) {return c_aa_prev[a_kind][at_kind];} + inline double * CONST_BB2(const unsigned a_kind, const unsigned at_kind) {return co_bb[a_kind][at_kind];} + inline double * CONST_SC2(const unsigned a_kind, const unsigned at_kind, unsigned res_type) { return co_sc_[a_kind][at_kind][res_type];} + inline double * CONST_XD(const unsigned a_kind, const unsigned at_kind) { return co_xd[a_kind][at_kind];} + inline double * CO_SPHERE(const unsigned a_kind, const unsigned at_kind, unsigned exp_type) { return co_sphere[a_kind][at_kind][exp_type];} + inline double * CO_RING(const unsigned a_kind, const unsigned at_kind) { return co_ring[a_kind][at_kind];} + inline double * CO_DA(const unsigned a_kind, const unsigned at_kind) { return co_da[a_kind][at_kind];} + inline double * PARS_DA(const unsigned a_kind, const unsigned at_kind, const unsigned ang_kind) { return pars_da[a_kind][at_kind][ang_kind];} void parse(const std::string &file, const double dscale) { std::ifstream in; in.open(file.c_str()); - if(!in) { - plumed_merror("Unable to open DB file: " + file); - } + if(!in) plumed_merror("Unable to open DB file: " + file); unsigned c_kind = 0; unsigned c_atom = 0; unsigned nline = 0; - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<6; j++) { + for(unsigned i=0; i<3; i++) for(unsigned j=0; j<6; j++) { for(unsigned k=0; k<20; k++) { c_aa[i][j][k]=0.; c_aa_prev[i][j][k]=0.; c_aa_succ[i][j][k]=0.; - for(unsigned m=0; m<20; m++) { - co_sc_[i][j][k][m]=0.; - } - } - for(unsigned k=0; k<16; k++) { - co_bb[i][j][k]=0.; - } - for(unsigned k=0; k<8; k++) { - co_sphere[i][j][0][k]=0.; - co_sphere[i][j][1][k]=0.; + for(unsigned m=0; m<20; m++) co_sc_[i][j][k][m]=0.; } + for(unsigned k=0; k<16; k++) {co_bb[i][j][k]=0.; } + for(unsigned k=0; k<8; k++) { co_sphere[i][j][0][k]=0.; co_sphere[i][j][1][k]=0.; } for(unsigned k=0; k<3; k++) { co_da[i][j][k]=0.; - for(unsigned l=0; l<5; l++) { - pars_da[i][j][k][l]=0.; - } - } - for(unsigned k=0; k<5; k++) { - co_ring[i][j][k]=0.; - } - for(unsigned k=0; k tok; std::vector tmp; tok = split(line,' '); for(unsigned q=0; q & v, const double scale) { for(unsigned i=1; i used_atoms; parseAtomList("ATOMS",used_atoms); parseFlag("CAMSHIFT",camshift); - if(camshift&&getDoScore()) { - plumed_merror("It is not possible to use CAMSHIFT and DOSCORE at the same time"); - } + if(camshift&&getDoScore()) plumed_merror("It is not possible to use CAMSHIFT and DOSCORE at the same time"); bool nopbc=!pbc; parseFlag("NOPBC",nopbc); @@ -608,13 +567,10 @@ CS2Backbone::CS2Backbone(const ActionOptions&ao): db.parse(stringadb,scale); PDB pdb; - if( !pdb.read(stringapdb,plumed.getAtoms().usingNaturalUnits(),1./scale) ) { - plumed_merror("missing input file " + stringapdb); - } + if( !pdb.read(stringapdb,plumed.getAtoms().usingNaturalUnits(),1./scale) ) plumed_merror("missing input file " + stringapdb); // first of all we build the list of chemical shifts we want to predict - log.printf(" Reading experimental data ...\n"); - log.flush(); + log.printf(" Reading experimental data ...\n"); log.flush(); stringadb = stringa_data + std::string("/CAshifts.dat"); log.printf(" Initializing CA shifts %s\n", stringadb.c_str()); init_cs(stringadb, "CA", pdb); @@ -634,20 +590,15 @@ CS2Backbone::CS2Backbone(const ActionOptions&ao): log.printf(" Initializing N shifts %s\n", stringadb.c_str()); init_cs(stringadb, "N", pdb); - if(chemicalshifts.size()==0) { - plumed_merror("There are no chemical shifts to calculate, there must be at least a not empty file (CA|CB|C|HA|H|N|shifts.dat)"); - } + if(chemicalshifts.size()==0) plumed_merror("There are no chemical shifts to calculate, there must be at least a not empty file (CA|CB|C|HA|H|N|shifts.dat)"); init_types(pdb); init_rings(pdb); log<<" Bibliography " < iter(in), end; unsigned begin=0; @@ -717,73 +660,42 @@ void CS2Backbone::init_cs(const std::string &file, const std::string &nucl, cons if(begin==1) { begin=0; ichain++; - } else { - begin=1; - } + } else begin=1; continue; } int ro = atoi(tok.c_str()); - if(ro<0) { - plumed_merror("Residue numbers should be positive\n"); - } + if(ro<0) plumed_merror("Residue numbers should be positive\n"); unsigned resnum = static_cast (ro); tok = *iter; ++iter; double cs = atof(tok.c_str()); - if(cs==0) { - continue; - } + if(cs==0) continue; unsigned fres, lres; std::string errmsg; pdb.getResidueRange(chains[ichain], fres, lres, errmsg); - if(resnum==fres||resnum==lres) { - plumed_merror("First and Last residue of each chain should be annotated as # in " + file + " Remember that residue numbers should match"); - } + if(resnum==fres||resnum==lres) plumed_merror("First and Last residue of each chain should be annotated as # in " + file + " Remember that residue numbers should match"); // check in the PDB for the chain/residue/atom and enable the chemical shift std::string RES = pdb.getResidueName(resnum, chains[ichain]); - if(RES=="HIE"||RES=="HIP"||RES=="HIS"||RES=="HSP"||RES=="HSE"||RES=="CYS"||RES=="GLH"||RES=="ASH"||RES=="UNK") { - continue; - } - if(RES=="GLN"&&nucl=="CB") { - continue; - } - if(RES=="ILE"&&nucl=="CB") { - continue; - } - if(RES=="PRO"&&nucl=="N") { - continue; - } - if(RES=="PRO"&&nucl=="H") { - continue; - } - if(RES=="PRO"&&nucl=="CB") { - continue; - } - if(RES=="GLY"&&nucl=="HA") { - continue; - } - if(RES=="GLY"&&nucl=="CB") { - continue; - } + if(RES=="HIE"||RES=="HIP"||RES=="HIS"||RES=="HSP"||RES=="HSE"||RES=="CYS"||RES=="GLH"||RES=="ASH"||RES=="UNK") continue; + if(RES=="GLN"&&nucl=="CB") continue; + if(RES=="ILE"&&nucl=="CB") continue; + if(RES=="PRO"&&nucl=="N") continue; + if(RES=="PRO"&&nucl=="H") continue; + if(RES=="PRO"&&nucl=="CB") continue; + if(RES=="GLY"&&nucl=="HA") continue; + if(RES=="GLY"&&nucl=="CB") continue; ChemicalShift tmp_cs; tmp_cs.exp_cs = cs; - if(nucl=="CA") { - tmp_cs.nucleus = "ca-"; - } else if(nucl=="CB") { - tmp_cs.nucleus = "cb-"; - } else if(nucl=="C") { - tmp_cs.nucleus = "co-"; - } else if(nucl=="HA") { - tmp_cs.nucleus = "ha-"; - } else if(nucl=="H") { - tmp_cs.nucleus = "hn-"; - } else if(nucl=="N") { - tmp_cs.nucleus = "nh-"; - } + if(nucl=="CA") tmp_cs.nucleus = "ca-"; + else if(nucl=="CB") tmp_cs.nucleus = "cb-"; + else if(nucl=="C") tmp_cs.nucleus = "co-"; + else if(nucl=="HA") tmp_cs.nucleus = "ha-"; + else if(nucl=="H") tmp_cs.nucleus = "hn-"; + else if(nucl=="N") tmp_cs.nucleus = "nh-"; tmp_cs.chain = ichain; tmp_cs.res_num = resnum; tmp_cs.res_type_curr = frag2enum(RES); @@ -792,73 +704,44 @@ void CS2Backbone::init_cs(const std::string &file, const std::string &nucl, cons tmp_cs.res_name = RES; tmp_cs.res_kind = db.kind(RES); tmp_cs.atm_kind = db.atom_kind(nucl); - if(RES!="ALA"&&RES!="GLY") { - tmp_cs.bb.resize(18); - tmp_cs.has_chi1=true; - } else { - tmp_cs.bb.resize(16); - tmp_cs.has_chi1=false; - } + if(RES!="ALA"&&RES!="GLY") {tmp_cs.bb.resize(18); tmp_cs.has_chi1=true;} + else {tmp_cs.bb.resize(16); tmp_cs.has_chi1=false;} std::vector res_atoms = pdb.getAtomsInResidue(resnum, chains[ichain]); // find the position of the nucleus and of the other backbone atoms as well as for phi/psi/chi for(unsigned a=0; a prev_res_atoms = pdb.getAtomsInResidue(resnum-1, chains[ichain]); // find the position of the previous residues backbone atoms for(unsigned a=0; a at1; - if(resOffsetP1[q]== 0) { - at1 = res_atoms; - } - if(resOffsetP1[q]==-1) { - at1 = prev_res_atoms; - } - if(resOffsetP1[q]==+1) { - at1 = next_res_atoms; - } + if(resOffsetP1[q]== 0) at1 = res_atoms; + if(resOffsetP1[q]==-1) at1 = prev_res_atoms; + if(resOffsetP1[q]==+1) at1 = next_res_atoms; std::vector at2; - if(resOffsetP2[q]== 0) { - at2 = res_atoms; - } - if(resOffsetP2[q]==-1) { - at2 = prev_res_atoms; - } - if(resOffsetP2[q]==+1) { - at2 = next_res_atoms; - } + if(resOffsetP2[q]== 0) at2 = res_atoms; + if(resOffsetP2[q]==-1) at2 = prev_res_atoms; + if(resOffsetP2[q]==+1) at2 = next_res_atoms; int tmp1 = -1; for(unsigned a=0; a frg_atoms = pdb.getAtomsInResidue(res,chains[i]); @@ -1042,12 +890,8 @@ void CS2Backbone::init_rings(const PDB &pdb) { } ri.numAtoms = 6; total_rings_atoms += 6; - if(frg=="PHE") { - ri.rtype = RingInfo::R_PHE; - } - if(frg=="TYR") { - ri.rtype = RingInfo::R_TYR; - } + if(frg=="PHE") ri.rtype = RingInfo::R_PHE; + if(frg=="TYR") ri.rtype = RingInfo::R_TYR; ringInfo.push_back(ri); } else if(frg=="TRP") { @@ -1105,21 +949,14 @@ void CS2Backbone::init_rings(const PDB &pdb) { } } - for(unsigned cs=0; cs camshift_sigma2(6); @@ -1138,9 +975,7 @@ void CS2Backbone::calculate() { cs_derivs.resize(chemicalshifts.size()*max_cs_atoms,Vector(0,0,0)); cs_atoms.resize(chemicalshifts.size()*max_cs_atoms,0); all_shifts.resize(chemicalshifts.size(),0); - if(camshift||getDoScore()) { - aa_derivs.resize(getNumberOfAtoms(),Vector(0,0,0)); - } + if(camshift||getDoScore()) aa_derivs.resize(getNumberOfAtoms(),Vector(0,0,0)); unsigned stride = comm.Get_size(); unsigned rank = comm.Get_rank(); @@ -1150,9 +985,7 @@ void CS2Backbone::calculate() { } unsigned nt=OpenMP::getNumThreads(); - if(nt*stride*2>chemicalshifts.size()) { - nt=1; - } + if(nt*stride*2>chemicalshifts.size()) nt=1; // a single loop over all chemical shifts #pragma omp parallel num_threads(nt) @@ -1177,13 +1010,9 @@ void CS2Backbone::calculate() { const unsigned bbsize = 16; for(unsigned q=0; qbb[q]; - if(ipos==jpos) { - continue; - } + if(ipos==jpos) continue; const Vector distance = delta(getPosition(jpos),getPosition(ipos)); const double d = distance.modulo(); const double fact = cb2q/d; @@ -1280,13 +1109,9 @@ void CS2Backbone::calculate() { const unsigned sidsize = myfrag->side_chain.size(); for(unsigned q=0; qside_chain[q]; - if(ipos==jpos) { - continue; - } + if(ipos==jpos) continue; const Vector distance = delta(getPosition(jpos),getPosition(ipos)); const double d = distance.modulo(); const double fact = cs2q/d; @@ -1305,12 +1130,8 @@ void CS2Backbone::calculate() { const unsigned xdsize=myfrag->xd1.size(); for(unsigned q=0; qxd1[q]==-1||myfrag->xd2[q]==-1) { - continue; - } + if(cxdq==0.) continue; + if(myfrag->xd1[q]==-1||myfrag->xd2[q]==-1) continue; const Vector distance = delta(getPosition(myfrag->xd1[q]),getPosition(myfrag->xd2[q])); const double d = distance.modulo(); const double fact = cxdq/d; @@ -1362,9 +1183,7 @@ void CS2Backbone::calculate() { const double fU = fUU/nL; double OneOverN = 1./6.; - if(ringInfo[q].numAtoms==5) { - OneOverN=1./3.; - } + if(ringInfo[q].numAtoms==5) OneOverN=1./3.; const Vector factor2 = OneOverN*n; const Vector factor4 = (OneOverN/dL_nL)*d; @@ -1454,9 +1273,7 @@ void CS2Backbone::calculate() { } ++box_count; - if(box_count == box_nupdate) { - box_count = 0; - } + if(box_count == box_nupdate) box_count = 0; if(!camshift) { if(!serial) { @@ -1469,9 +1286,8 @@ void CS2Backbone::calculate() { for(unsigned cs=0; csset(all_shifts[cs]); - if(getDoScore()) { - setCalcData(cs, all_shifts[cs]); - } else { + if(getDoScore()) setCalcData(cs, all_shifts[cs]); + else { const unsigned kdx=cs*max_cs_atoms; Tensor csvirial; for(unsigned i=0; i(res_curr-res_num[bat])); - if(res_dist<2) { - continue; - } + if(res_dist<2) continue; const Vector distance = delta(getPosition(bat),getPosition(chemicalshifts[cs].ipos)); const double d2=distance.modulo2(); - if(d2max_cs_atoms) { - max_cs_atoms = chemicalshifts[cs].totcsatoms; - } + if(chemicalshifts[cs].totcsatoms>max_cs_atoms) max_cs_atoms = chemicalshifts[cs].totcsatoms; } } @@ -1587,9 +1391,7 @@ void CS2Backbone::compute_ring_parameters() { ringInfo[i].g[5] = delta(getPosition(ringInfo[i].atom[3]),getPosition(ringInfo[i].atom[1])); // ring center Vector midP = getPosition(ringInfo[i].atom[0]); - for(unsigned j=1; j CS2Backbone::side_chain_atoms(const std::string &s) { sc.push_back( "2HG2" ); sc.push_back( "3HG2" ); return sc; - } else { - plumed_merror("Sidechain atoms unknown: " + s); - } + } else plumed_merror("Sidechain atoms unknown: " + s); } bool CS2Backbone::isSP2(const std::string & resType, const std::string & atomName) { bool sp2 = false; - if (atomName == "C") { - return true; - } - if (atomName == "O") { - return true; - } + if (atomName == "C") return true; + if (atomName == "O") return true; if(resType == "TRP") { - if (atomName == "CG") { - sp2 = true; - } else if (atomName == "CD1") { - sp2 = true; - } else if (atomName == "CD2") { - sp2 = true; - } else if (atomName == "CE2") { - sp2 = true; - } else if (atomName == "CE3") { - sp2 = true; - } else if (atomName == "CZ2") { - sp2 = true; - } else if (atomName == "CZ3") { - sp2 = true; - } else if (atomName == "CH2") { - sp2 = true; - } + if (atomName == "CG") sp2 = true; + else if (atomName == "CD1") sp2 = true; + else if (atomName == "CD2") sp2 = true; + else if (atomName == "CE2") sp2 = true; + else if (atomName == "CE3") sp2 = true; + else if (atomName == "CZ2") sp2 = true; + else if (atomName == "CZ3") sp2 = true; + else if (atomName == "CH2") sp2 = true; } else if (resType == "ASP") { - if (atomName == "CG") { - sp2 = true; - } else if (atomName == "OD1") { - sp2 = true; - } else if (atomName == "OD2") { - sp2 = true; - } + if (atomName == "CG") sp2 = true; + else if (atomName == "OD1") sp2 = true; + else if (atomName == "OD2") sp2 = true; } else if (resType == "GLU") { - if (atomName == "CD") { - sp2 = true; - } else if (atomName == "OE1") { - sp2 = true; - } else if (atomName == "OE2") { - sp2 = true; - } + if (atomName == "CD") sp2 = true; + else if (atomName == "OE1") sp2 = true; + else if (atomName == "OE2") sp2 = true; } else if (resType == "ARG") { - if (atomName == "CZ") { - sp2 = true; - } + if (atomName == "CZ") sp2 = true; } else if (resType == "HIS") { - if (atomName == "CG") { - sp2 = true; - } else if (atomName == "ND1") { - sp2 = true; - } else if (atomName == "CD2") { - sp2 = true; - } else if (atomName == "CE1") { - sp2 = true; - } else if (atomName == "NE2") { - sp2 = true; - } + if (atomName == "CG") sp2 = true; + else if (atomName == "ND1") sp2 = true; + else if (atomName == "CD2") sp2 = true; + else if (atomName == "CE1") sp2 = true; + else if (atomName == "NE2") sp2 = true; } else if (resType == "PHE") { - if (atomName == "CG") { - sp2 = true; - } else if (atomName == "CD1") { - sp2 = true; - } else if (atomName == "CD2") { - sp2 = true; - } else if (atomName == "CE1") { - sp2 = true; - } else if (atomName == "CE2") { - sp2 = true; - } else if (atomName == "CZ") { - sp2 = true; - } + if (atomName == "CG") sp2 = true; + else if (atomName == "CD1") sp2 = true; + else if (atomName == "CD2") sp2 = true; + else if (atomName == "CE1") sp2 = true; + else if (atomName == "CE2") sp2 = true; + else if (atomName == "CZ") sp2 = true; } else if (resType == "TYR") { - if (atomName == "CG") { - sp2 = true; - } else if (atomName == "CD1") { - sp2 = true; - } else if (atomName == "CD2") { - sp2 = true; - } else if (atomName == "CE1") { - sp2 = true; - } else if (atomName == "CE2") { - sp2 = true; - } else if (atomName == "CZ") { - sp2 = true; - } + if (atomName == "CG") sp2 = true; + else if (atomName == "CD1") sp2 = true; + else if (atomName == "CD2") sp2 = true; + else if (atomName == "CE1") sp2 = true; + else if (atomName == "CE2") sp2 = true; + else if (atomName == "CZ") sp2 = true; } else if (resType == "ASN") { - if (atomName == "CG") { - sp2 = true; - } else if (atomName == "OD1") { - sp2 = true; - } + if (atomName == "CG") sp2 = true; + else if (atomName == "OD1") sp2 = true; } else if (resType == "GLN") { - if (atomName == "CD") { - sp2 = true; - } else if (atomName == "OE1") { - sp2 = true; - } + if (atomName == "CD") sp2 = true; + else if (atomName == "OE1") sp2 = true; } return sp2; } bool CS2Backbone::is_chi1_cx(const std::string & frg, const std::string & atm) { - if(atm=="CG") { - return true; - } - if((frg == "CYS")&&(atm =="SG")) { - return true; - } - if(((frg == "ILE")||(frg == "VAL"))&&(atm == "CG1")) { - return true; - } - if((frg == "SER")&&(atm == "OG")) { - return true; - } - if((frg == "THR")&&(atm == "OG1")) { - return true; - } + if(atm=="CG") return true; + if((frg == "CYS")&&(atm =="SG")) return true; + if(((frg == "ILE")||(frg == "VAL"))&&(atm == "CG1")) return true; + if((frg == "SER")&&(atm == "OG")) return true; + if((frg == "THR")&&(atm == "OG1")) return true; return false; } void CS2Backbone::xdist_name_map(std::string & name) { - if((name == "OT1")||(name == "OC1")) { - name = "O"; - } else if ((name == "HN") || (name == "HT1") || (name == "H1")) { - name = "H"; - } else if ((name == "CG1")|| (name == "OG")|| - (name == "SG") || (name == "OG1")) { - name = "CG"; - } else if ((name == "HA1")|| (name == "HA3")) { - name = "HA"; - } + if((name == "OT1")||(name == "OC1")) name = "O"; + else if ((name == "HN") || (name == "HT1") || (name == "H1")) name = "H"; + else if ((name == "CG1")|| (name == "OG")|| + (name == "SG") || (name == "OG1")) name = "CG"; + else if ((name == "HA1")|| (name == "HA3")) name = "HA"; } void CS2Backbone::update() { // write status file - if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) { - writeStatus(); - } + if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) writeStatus(); } } diff --git a/src/isdb/Caliber.cpp b/src/isdb/Caliber.cpp index 6dca3326bf..e6e78c3331 100644 --- a/src/isdb/Caliber.cpp +++ b/src/isdb/Caliber.cpp @@ -144,27 +144,20 @@ Caliber::Caliber(const ActionOptions&ao): scale_(1), doregres_zero_(false), nregres_zero_(0), - optsigmamean_stride_(0) { + optsigmamean_stride_(0) +{ parse("KAPPA",mult); std::string filename; parse("FILE",filename); - if( filename.length()==0 ) { - error("No external variable file was specified"); - } + if( filename.length()==0 ) error("No external variable file was specified"); unsigned averaging=0; parse("AVERAGING", averaging); - if(averaging>0) { - optsigmamean_stride_ = averaging; - } + if(averaging>0) optsigmamean_stride_ = averaging; double tscale=1.0; parse("TSCALE", tscale); - if(tscale<=0.) { - error("The time scale factor must be greater than 0."); - } + if(tscale<=0.) error("The time scale factor must be greater than 0."); parse("SCALE", scale_); - if(scale_==0.) { - error("The time scale factor cannot be 0."); - } + if(scale_==0.) error("The time scale factor cannot be 0."); // regression with zero intercept parse("REGRES_ZERO", nregres_zero_); if(nregres_zero_>0) { @@ -184,9 +177,7 @@ Caliber::Caliber(const ActionOptions&ao): if(master) { nrep_ = multi_sim_comm.Get_size(); replica_ = multi_sim_comm.Get_rank(); - if(noensemble) { - nrep_ = 1; - } + if(noensemble) nrep_ = 1; } else { nrep_ = 0; replica_ = 0; @@ -197,15 +188,11 @@ Caliber::Caliber(const ActionOptions&ao): const unsigned narg = getNumberOfArguments(); sigma_mean2_.resize(narg,1); sigma_mean2_last_.resize(narg); - for(unsigned j=0; j &mean) { +void Caliber::get_sigma_mean(const double fact, const std::vector &mean) +{ const unsigned narg = getNumberOfArguments(); const double dnrep = static_cast(nrep_); - if(sigma_mean2_last_[0].size()==optsigmamean_stride_) - for(unsigned i=0; i sigma_mean2_now(narg,0); if(master) { for(unsigned i=0; i1) { - multi_sim_comm.Sum(&sigma_mean2_now[0], narg); - } + if(nrep_>1) multi_sim_comm.Sum(&sigma_mean2_now[0], narg); } comm.Sum(&sigma_mean2_now[0], narg); @@ -281,44 +253,35 @@ void Caliber::get_sigma_mean(const double fact, const std::vector &mean) } } -void Caliber::replica_averaging(const double fact, std::vector &mean) { +void Caliber::replica_averaging(const double fact, std::vector &mean) +{ const unsigned narg = getNumberOfArguments(); if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&mean[0], narg); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&mean[0], narg); } comm.Sum(&mean[0], narg); } -double Caliber::getSpline(const unsigned iarg) { +double Caliber::getSpline(const unsigned iarg) +{ const double deltat = time[1] - time[0]; const int tindex = static_cast(getTime()/deltat); unsigned start, end; start=tindex; - if(tindex+10.0000001) { - yy=-dder/grid; - } + if(std::abs(grid)>0.0000001) yy=-dder/grid; int x0=1; - if(ipoint==tindex) { - x0=0; - } + if(ipoint==tindex) x0=0; double X=std::abs((getTime()-time[tindex])/deltat-(double)x0); double X2=X*X; @@ -330,7 +293,8 @@ double Caliber::getSpline(const unsigned iarg) { return value; } -void Caliber::do_regression_zero(const std::vector &mean) { +void Caliber::do_regression_zero(const std::vector &mean) +{ // parameters[i] = scale_ * mean[i]: find scale_ with linear regression double num = 0.0; double den = 0.0; @@ -345,7 +309,8 @@ void Caliber::do_regression_zero(const std::vector &mean) { } } -void Caliber::calculate() { +void Caliber::calculate() +{ const unsigned narg = getNumberOfArguments(); const double dnrep = static_cast(nrep_); const double fact = 1.0/dnrep; @@ -353,14 +318,10 @@ void Caliber::calculate() { std::vector mean(narg,0); std::vector dmean_x(narg,fact); replica_averaging(fact, mean); - if(optsigmamean_stride_>0) { - get_sigma_mean(fact, mean); - } + if(optsigmamean_stride_>0) get_sigma_mean(fact, mean); // in case of regression with zero intercept, calculate scale - if(doregres_zero_ && getStep()%nregres_zero_==0) { - do_regression_zero(mean); - } + if(doregres_zero_ && getStep()%nregres_zero_==0) do_regression_zero(mean); double ene=0; for(unsigned i=0; iset(mean[i]); } - if(doregres_zero_) { - valueScale->set(scale_); - } + if(doregres_zero_) valueScale->set(scale_); setBias(ene); } diff --git a/src/isdb/EMMI.cpp b/src/isdb/EMMI.cpp index f8d099c12c..bf64240334 100644 --- a/src/isdb/EMMI.cpp +++ b/src/isdb/EMMI.cpp @@ -109,7 +109,8 @@ PRINT ARG=emr.* FILE=COLVAR STRIDE=500 FMT=%20.10f class EMMI : public ActionAtomistic, public ActionWithArguments, - public ActionWithValue { + public ActionWithValue +{ private: // temperature in kbt @@ -291,11 +292,8 @@ void EMMI::setDerivatives() { } // Resize all derivative arrays - forces.resize( nder ); - forcesToApply.resize( nder ); - for(int i=0; iresizeDerivatives(nder); - } + forces.resize( nder ); forcesToApply.resize( nder ); + for(int i=0; iresizeDerivatives(nder); } inline @@ -331,38 +329,27 @@ void EMMI::calculateNumericalDerivatives( ActionWithValue* a=NULL ) { if( getNumberOfAtoms()>0 ) { Matrix save_derivatives( getNumberOfComponents(), getNumberOfArguments() ); for(int j=0; jhasDerivatives()) { - save_derivatives(j,i)=getPntrToComponent(j)->getDerivative(i); - } + for(unsigned i=0; ihasDerivatives()) save_derivatives(j,i)=getPntrToComponent(j)->getDerivative(i); } calculateAtomicNumericalDerivatives( a, getNumberOfArguments() ); for(int j=0; jhasDerivatives()) { - getPntrToComponent(j)->addDerivative( i, save_derivatives(j,i) ); - } + for(unsigned i=0; ihasDerivatives()) getPntrToComponent(j)->addDerivative( i, save_derivatives(j,i) ); } } } inline void EMMI::apply() { - bool wasforced=false; - forcesToApply.assign(forcesToApply.size(),0.0); + bool wasforced=false; forcesToApply.assign(forcesToApply.size(),0.0); for(int i=0; iapplyForce( forces ) ) { wasforced=true; - for(unsigned i=0; i0 ) { - setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); - } + if( getNumberOfAtoms()>0 ) setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); } } @@ -458,7 +445,8 @@ EMMI::EMMI(const ActionOptions&ao): nregres_(0), scale_(1.), dpcutoff_(15.0), nexp_(1000000), nanneal_(0), kanneal_(0.), anneal_(1.), prior_(1.), ovstride_(0), - do_reweight_(false), first_time_w_(true), decay_w_(1.) { + do_reweight_(false), first_time_w_(true), decay_w_(1.) +{ // periodic boundary conditions bool nopbc=!pbc_; parseFlag("NOPBC",nopbc); @@ -475,51 +463,33 @@ EMMI::EMMI(const ActionOptions&ao): // type of data noise std::string noise; parse("NOISETYPE",noise); - if (noise=="GAUSS") { - noise_ = 0; - } else if(noise=="OUTLIERS") { - noise_ = 1; - } else if(noise=="MARGINAL") { - noise_ = 2; - } else { - error("Unknown noise type!"); - } + if (noise=="GAUSS") noise_ = 0; + else if(noise=="OUTLIERS") noise_ = 1; + else if(noise=="MARGINAL") noise_ = 2; + else error("Unknown noise type!"); // minimum value for error double sigma_min; parse("SIGMA_MIN", sigma_min); - if(sigma_min<0) { - error("SIGMA_MIN should be greater or equal to zero"); - } + if(sigma_min<0) error("SIGMA_MIN should be greater or equal to zero"); // the following parameters must be specified with noise type 0 and 1 double sigma_ini, dsigma; if(noise_!=2) { // initial value of the uncertainty parse("SIGMA0", sigma_ini); - if(sigma_ini<=0) { - error("you must specify a positive SIGMA0"); - } + if(sigma_ini<=0) error("you must specify a positive SIGMA0"); // MC parameters parse("DSIGMA", dsigma); - if(dsigma<0) { - error("you must specify a positive DSIGMA"); - } + if(dsigma<0) error("you must specify a positive DSIGMA"); parse("MC_STRIDE", MCstride_); - if(dsigma>0 && MCstride_<=0) { - error("you must specify a positive MC_STRIDE"); - } + if(dsigma>0 && MCstride_<=0) error("you must specify a positive MC_STRIDE"); // status file parameters parse("WRITE_STRIDE", statusstride_); - if(statusstride_==0) { - error("you must specify a positive WRITE_STRIDE"); - } + if(statusstride_==0) error("you must specify a positive WRITE_STRIDE"); parse("STATUS_FILE", statusfilename_); - if(statusfilename_=="") { - statusfilename_ = "MISTATUS"+getLabel(); - } else { - statusfilename_ = statusfilename_+getLabel(); - } + if(statusfilename_=="") statusfilename_ = "MISTATUS"+getLabel(); + else statusfilename_ = statusfilename_+getLabel(); } // error file @@ -538,11 +508,8 @@ EMMI::EMMI(const ActionOptions&ao): double temp=0.0; parse("TEMP",temp); // convert temp to kbt - if(temp>0.0) { - kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt_=plumed.getAtoms().getKbT(); - } + if(temp>0.0) kbt_=plumed.getAtoms().getKBoltzmann()*temp; + else kbt_=plumed.getAtoms().getKbT(); // exponent of uncertainty prior parse("PRIOR",prior_); @@ -550,9 +517,7 @@ EMMI::EMMI(const ActionOptions&ao): // simulated annealing stuff parse("ANNEAL", nanneal_); parse("ANNEAL_FACT", kanneal_); - if(nanneal_>0 && kanneal_<=1.0) { - error("with ANNEAL, ANNEAL_FACT must be greater than 1"); - } + if(nanneal_>0 && kanneal_<=1.0) error("with ANNEAL, ANNEAL_FACT must be greater than 1"); // regression stride parse("REGRESSION",nregres_); @@ -562,12 +527,8 @@ EMMI::EMMI(const ActionOptions&ao): parse("REG_SCALE_MAX",scale_max_); parse("REG_DSCALE",dscale_); // checks - if(scale_max_<=scale_min_) { - error("with REGRESSION, REG_SCALE_MAX must be greater than REG_SCALE_MIN"); - } - if(dscale_<=0.) { - error("with REGRESSION, REG_DSCALE must be positive"); - } + if(scale_max_<=scale_min_) error("with REGRESSION, REG_SCALE_MAX must be greater than REG_SCALE_MIN"); + if(dscale_<=0.) error("with REGRESSION, REG_DSCALE must be positive"); } // scale factor @@ -576,19 +537,13 @@ EMMI::EMMI(const ActionOptions&ao): // read map resolution double reso; parse("RESOLUTION", reso); - if(reso<=0.) { - error("RESOLUTION should be strictly positive"); - } + if(reso<=0.) error("RESOLUTION should be strictly positive"); // neighbor list stuff parse("NL_CUTOFF",nl_cutoff_); - if(nl_cutoff_<=0.0) { - error("NL_CUTOFF should be explicitly specified and positive"); - } + if(nl_cutoff_<=0.0) error("NL_CUTOFF should be explicitly specified and positive"); parse("NL_STRIDE",nl_stride_); - if(nl_stride_==0) { - error("NL_STRIDE should be explicitly specified and positive"); - } + if(nl_stride_==0) error("NL_STRIDE should be explicitly specified and positive"); // averaging or not parseFlag("NO_AVER",no_aver_); @@ -596,9 +551,7 @@ EMMI::EMMI(const ActionOptions&ao): // write overlap file parse("WRITE_OV_STRIDE", ovstride_); parse("WRITE_OV", ovfilename_); - if(ovstride_>0 && ovfilename_=="") { - error("With WRITE_OV_STRIDE you must specify WRITE_OV"); - } + if(ovstride_>0 && ovfilename_=="") error("With WRITE_OV_STRIDE you must specify WRITE_OV"); // set parallel stuff size_=comm.Get_size(); @@ -621,20 +574,11 @@ EMMI::EMMI(const ActionOptions&ao): // Reweighting flag parseFlag("REWEIGHT", do_reweight_); - if(do_reweight_&&getNumberOfArguments()!=1) { - error("To REWEIGHT one must provide one single bias as an argument"); - } - if(do_reweight_&&no_aver_) { - error("REWEIGHT cannot be used with NO_AVER"); - } - if(do_reweight_&&nrep_<2) { - error("REWEIGHT can only be used in parallel with 2 or more replicas"); - } - if(!getRestart()) { - average_weights_.resize(nrep_, 1./static_cast(nrep_)); - } else { - average_weights_.resize(nrep_, 0.); - } + if(do_reweight_&&getNumberOfArguments()!=1) error("To REWEIGHT one must provide one single bias as an argument"); + if(do_reweight_&&no_aver_) error("REWEIGHT cannot be used with NO_AVER"); + if(do_reweight_&&nrep_<2) error("REWEIGHT can only be used in parallel with 2 or more replicas"); + if(!getRestart()) average_weights_.resize(nrep_, 1./static_cast(nrep_)); + else average_weights_.resize(nrep_, 0.); unsigned averaging=0; parse("AVERAGING", averaging); @@ -645,14 +589,10 @@ EMMI::EMMI(const ActionOptions&ao): checkRead(); log.printf(" atoms involved : "); - for(unsigned i=0; i0) { - log.printf(" reading experimental errors from file : %s\n", errfile.c_str()); - } - if(ovfile.size()>0) { - log.printf(" reading experimental overlaps from file : %s\n", ovfile.c_str()); - } + if(errfile.size()>0) log.printf(" reading experimental errors from file : %s\n", errfile.c_str()); + if(ovfile.size()>0) log.printf(" reading experimental overlaps from file : %s\n", ovfile.c_str()); log.printf(" temperature of the system in energy unit : %f\n",kbt_); log.printf(" prior exponent : %f\n",prior_); log.printf(" number of replicas for averaging: %u\n",nrep_); @@ -701,20 +637,14 @@ EMMI::EMMI(const ActionOptions&ao): log.printf(" number of GMM components : %u\n", static_cast(GMM_d_m_.size())); // normalize atom weight map - if(norm_d <= 0.0) { - norm_d = accumulate(GMM_d_w_.begin(), GMM_d_w_.end(), 0.0); - } + if(norm_d <= 0.0) norm_d = accumulate(GMM_d_w_.begin(), GMM_d_w_.end(), 0.0); double norm_m = accumulate(GMM_m_w.begin(), GMM_m_w.end(), 0.0); // renormalization - for(unsigned i=0; i exp_err; - if(errfile.size()>0) { - exp_err = read_exp_errors(errfile); - } + if(errfile.size()>0) exp_err = read_exp_errors(errfile); // get self overlaps between data GMM components if(ovfile.size()>0) { @@ -738,11 +668,8 @@ EMMI::EMMI(const ActionOptions&ao): // GMM id int GMMid = GMM_d_grps_[Gid][i]; // add to experimental error - if(errfile.size()>0) { - err.push_back(exp_err[GMMid]); - } else { - err.push_back(0.); - } + if(errfile.size()>0) err.push_back(exp_err[GMMid]); + else err.push_back(0.); // add to GMM overlap ovdd.push_back(ovdd_[GMMid]); } @@ -767,9 +694,7 @@ EMMI::EMMI(const ActionOptions&ao): } // read status file if restarting - if(getRestart() && noise_!=2) { - read_status(); - } + if(getRestart() && noise_!=2) read_status(); // calculate auxiliary stuff calculate_useful_stuff(reso); @@ -784,27 +709,17 @@ EMMI::EMMI(const ActionOptions&ao): GMM_d_cov_.clear(); // add components - addComponentWithDerivatives("scoreb"); - componentIsNotPeriodic("scoreb"); + addComponentWithDerivatives("scoreb"); componentIsNotPeriodic("scoreb"); - if(noise_!=2) { - addComponent("acc"); - componentIsNotPeriodic("acc"); - } + if(noise_!=2) {addComponent("acc"); componentIsNotPeriodic("acc");} if(nregres_>0) { - addComponent("scale"); - componentIsNotPeriodic("scale"); - addComponent("accscale"); - componentIsNotPeriodic("accscale"); - addComponent("enescale"); - componentIsNotPeriodic("enescale"); + addComponent("scale"); componentIsNotPeriodic("scale"); + addComponent("accscale"); componentIsNotPeriodic("accscale"); + addComponent("enescale"); componentIsNotPeriodic("enescale"); } - if(nanneal_>0) { - addComponent("anneal"); - componentIsNotPeriodic("anneal"); - } + if(nanneal_>0) {addComponent("anneal"); componentIsNotPeriodic("anneal");} if(do_reweight_) { addComponent("biasDer"); @@ -817,20 +732,15 @@ EMMI::EMMI(const ActionOptions&ao): componentIsNotPeriodic("neff"); for(unsigned i=0; iset(sigma_[i]); } // initialize random seed unsigned iseed; - if(rank_==0) { - iseed = time(NULL)+replica_; - } else { - iseed = 0; - } + if(rank_==0) iseed = time(NULL)+replica_; + else iseed = 0; comm.Sum(&iseed, 1); random_.setSeed(-iseed); @@ -842,20 +752,16 @@ EMMI::EMMI(const ActionOptions&ao): log<<" Bibliography "<1) { - log<1)log< &v) { +double EMMI::get_median(std::vector &v) +{ // dimension of std::vector unsigned size = v.size(); // in case of only one entry @@ -888,7 +795,8 @@ double EMMI::get_median(std::vector &v) { } } -void EMMI::read_status() { +void EMMI::read_status() +{ double MDtime; // open file auto ifile = Tools::make_unique(); @@ -898,8 +806,7 @@ void EMMI::read_status() { while(ifile->scanField("MD_time", MDtime)) { for(unsigned i=0; iscanField("s"+num, sigma_[i]); } @@ -912,7 +819,8 @@ void EMMI::read_status() { } } -void EMMI::print_status(long long int step) { +void EMMI::print_status(long long int step) +{ // if first time open the file if(first_status_) { first_status_ = false; @@ -926,8 +834,7 @@ void EMMI::print_status(long long int step) { statusfile_.printField("MD_time", MDtime); for(unsigned i=0; i(std::floor(random_.RandU01()*static_cast(GMM_d_grps_.size()))); - if(nGMM==GMM_d_grps_.size()) { - nGMM -= 1; - } + if(nGMM==GMM_d_grps_.size()) nGMM -= 1; // generate random move double shift = dsigma_[nGMM] * ( 2.0 * random_.RandU01() - 1.0 ); // new sigma double new_s = sigma_[nGMM] + shift; // check boundaries - if(new_s > sigma_max_[nGMM]) { - new_s = 2.0 * sigma_max_[nGMM] - new_s; - } - if(new_s < sigma_min_[nGMM]) { - new_s = 2.0 * sigma_min_[nGMM] - new_s; - } + if(new_s > sigma_max_[nGMM]) {new_s = 2.0 * sigma_max_[nGMM] - new_s;} + if(new_s < sigma_min_[nGMM]) {new_s = 2.0 * sigma_min_[nGMM] - new_s;} // old s2 double old_inv_s2 = 1.0 / sigma_[nGMM] / sigma_[nGMM]; // new s2 @@ -1022,9 +922,7 @@ void EMMI::doMonteCarlo() { } // local communication if(rank_!=0) { - for(unsigned i=0; i1) { @@ -1033,12 +931,12 @@ void EMMI::doMonteCarlo() { } // update sigma output - std::string num; - Tools::convert(nGMM, num); + std::string num; Tools::convert(nGMM, num); getPntrToComponent("sigma-"+num)->set(sigma_[nGMM]); } -std::vector EMMI::read_exp_errors(const std::string & errfile) { +std::vector EMMI::read_exp_errors(const std::string & errfile) +{ int nexp, idcomp; double err; std::vector exp_err; @@ -1054,8 +952,7 @@ std::vector EMMI::read_exp_errors(const std::string & errfile) { double err_tot = 0.0; // cycle on number of experimental overlaps for(unsigned i=0; iscanField("Err"+ss, err); // add to total error err_tot += err*err; @@ -1074,7 +971,8 @@ std::vector EMMI::read_exp_errors(const std::string & errfile) { return exp_err; } -std::vector EMMI::read_exp_overlaps(const std::string & ovfile) { +std::vector EMMI::read_exp_overlaps(const std::string & ovfile) +{ int idcomp; double ov; std::vector ovdd; @@ -1098,7 +996,8 @@ std::vector EMMI::read_exp_overlaps(const std::string & ovfile) { return ovdd; } -std::vector EMMI::get_GMM_m(std::vector &atoms) { +std::vector EMMI::get_GMM_m(std::vector &atoms) +{ // list of weights - one per atom std::vector GMM_m_w; @@ -1156,25 +1055,24 @@ std::vector EMMI::get_GMM_m(std::vector &atoms) { return GMM_m_w; } -void EMMI::check_GMM_d(const VectorGeneric<6> &cov, double w) { +void EMMI::check_GMM_d(const VectorGeneric<6> &cov, double w) +{ // check if positive defined, by calculating the 3 leading principal minors double pm1 = cov[0]; double pm2 = cov[0]*cov[3]-cov[1]*cov[1]; double pm3 = cov[0]*(cov[3]*cov[5]-cov[4]*cov[4])-cov[1]*(cov[1]*cov[5]-cov[4]*cov[2])+cov[2]*(cov[1]*cov[4]-cov[3]*cov[2]); // apply Sylvester’s criterion - if(pm1<=0.0 || pm2<=0.0 || pm3<=0.0) { + if(pm1<=0.0 || pm2<=0.0 || pm3<=0.0) error("check data GMM: covariance matrix is not positive defined"); - } // check if weight is positive - if(w<=0) { - error("check data GMM: weight must be positive"); - } + if(w<=0) error("check data GMM: weight must be positive"); } // read GMM data file in PLUMED format: -void EMMI::get_GMM_d(std::string GMM_file) { +void EMMI::get_GMM_d(std::string GMM_file) +{ VectorGeneric<6> cov; // open file @@ -1199,9 +1097,7 @@ void EMMI::get_GMM_d(std::string GMM_file) { // check input check_GMM_d(cov, w); // check beta - if(beta<0) { - error("Beta must be positive!"); - } + if(beta<0) error("Beta must be positive!"); // center of the Gaussian GMM_d_m_.push_back(Vector(m0,m1,m2)); // covariance matrix @@ -1222,14 +1118,13 @@ void EMMI::get_GMM_d(std::string GMM_file) { GMM_d_grps_.resize(bu.size()); // and fill it in for(unsigned i=0; i=GMM_d_grps_.size()) { - error("Check Beta values"); - } + if(GMM_d_beta_[i]>=GMM_d_grps_.size()) error("Check Beta values"); GMM_d_grps_[GMM_d_beta_[i]].push_back(i); } } -void EMMI::calculate_useful_stuff(double reso) { +void EMMI::calculate_useful_stuff(double reso) +{ // We use the following definition for resolution: // the Fourier transform of the density distribution in real space // f(s) falls to 1/e of its maximum value at wavenumber 1/resolution @@ -1242,15 +1137,10 @@ void EMMI::calculate_useful_stuff(double reso) { Bave /= static_cast(GMM_m_type_.size()); // calculate blur factor double blur = 0.0; - if(reso*reso>Bave) { - blur = reso*reso-Bave; - } else { - warning("PLUMED should not be used with maps at resolution better than 0.3 nm"); - } + if(reso*reso>Bave) blur = reso*reso-Bave; + else warning("PLUMED should not be used with maps at resolution better than 0.3 nm"); // add blur to B - for(unsigned i=0; i &GMM_cov_0, const VectorGeneric<6> &GMM_cov_1, double GMM_w_0, double GMM_w_1, - VectorGeneric<6> &sum, VectorGeneric<6> &inv_sum) { + VectorGeneric<6> &sum, VectorGeneric<6> &inv_sum) +{ // we need the sum of the covariance matrices - for(unsigned k=0; k<6; ++k) { - sum[k] = GMM_cov_0[k] + GMM_cov_1[k]; - } + for(unsigned k=0; k<6; ++k) sum[k] = GMM_cov_0[k] + GMM_cov_1[k]; // and to calculate its determinant double det = sum[0]*(sum[3]*sum[5]-sum[4]*sum[4]); @@ -1336,7 +1220,8 @@ double EMMI::get_prefactor_inverse return pre_fact; } -double EMMI::get_self_overlap(unsigned id) { +double EMMI::get_self_overlap(unsigned id) +{ double ov_tot = 0.0; VectorGeneric<6> sum, inv_sum; Vector ov_der; @@ -1354,14 +1239,12 @@ double EMMI::get_self_overlap(unsigned id) { // get overlap and derivatives double EMMI::get_overlap(const Vector &m_m, const Vector &d_m, double pre_fact, - const VectorGeneric<6> &inv_cov_md, Vector &ov_der) { + const VectorGeneric<6> &inv_cov_md, Vector &ov_der) +{ Vector md; // calculate std::vector difference m_m-d_m with/without pbc - if(pbc_) { - md = pbcDistance(d_m, m_m); - } else { - md = delta(d_m, m_m); - } + if(pbc_) md = pbcDistance(d_m, m_m); + else md = delta(d_m, m_m); // calculate product of transpose of md and inv_cov_md double p_x = md[0]*inv_cov_md[0]+md[1]*inv_cov_md[1]+md[2]*inv_cov_md[2]; double p_y = md[0]*inv_cov_md[1]+md[1]*inv_cov_md[3]+md[2]*inv_cov_md[4]; @@ -1377,14 +1260,12 @@ double EMMI::get_overlap(const Vector &m_m, const Vector &d_m, double pre_fact, // get the exponent of the overlap double EMMI::get_exp_overlap(const Vector &m_m, const Vector &d_m, - const VectorGeneric<6> &inv_cov_md) { + const VectorGeneric<6> &inv_cov_md) +{ Vector md; // calculate std::vector difference m_m-d_m with/without pbc - if(pbc_) { - md = pbcDistance(d_m, m_m); - } else { - md = delta(d_m, m_m); - } + if(pbc_) md = pbcDistance(d_m, m_m); + else md = delta(d_m, m_m); // calculate product of transpose of md and inv_cov_md double p_x = md[0]*inv_cov_md[0]+md[1]*inv_cov_md[1]+md[2]*inv_cov_md[2]; double p_y = md[0]*inv_cov_md[1]+md[1]*inv_cov_md[3]+md[2]*inv_cov_md[4]; @@ -1394,7 +1275,8 @@ double EMMI::get_exp_overlap(const Vector &m_m, const Vector &d_m, return ov; } -void EMMI::update_neighbor_list() { +void EMMI::update_neighbor_list() +{ // dimension of GMM and atom std::vectors unsigned GMM_d_size = GMM_d_m_.size(); unsigned GMM_m_size = GMM_m_type_.size(); @@ -1419,9 +1301,7 @@ void EMMI::update_neighbor_list() { // get index of 0.5*expov in tabulated exponential unsigned itab = static_cast (round( 0.5*expov/dexp_ )); // check boundaries and skip atom in case - if(itab >= tab_exp_.size()) { - continue; - } + if(itab >= tab_exp_.size()) continue; // in case calculate overlap double ov = pre_fact_[kaux] * tab_exp_[itab]; // add to list @@ -1432,9 +1312,7 @@ void EMMI::update_neighbor_list() { ov_tot += ov; } // check if zero size -> ov_tot = 0 - if(ov_l.size()==0) { - continue; - } + if(ov_l.size()==0) continue; // define cutoff double ov_cut = ov_tot * nl_cutoff_; // sort ov_l in ascending order @@ -1444,16 +1322,12 @@ void EMMI::update_neighbor_list() { for(unsigned i=0; i= ov_cut) { - break; - } else { - ov_m.erase(ov_l[i]); - } + if(res >= ov_cut) break; + else ov_m.erase(ov_l[i]); } // now add atoms to neighborlist - for(std::map::iterator it=ov_m.begin(); it!=ov_m.end(); ++it) { + for(std::map::iterator it=ov_m.begin(); it!=ov_m.end(); ++it) nl_l.push_back(id*GMM_m_size+it->second); - } // end cycle on GMM components in parallel } // find total dimension of neighborlist @@ -1477,10 +1351,9 @@ void EMMI::update_neighbor_list() { ovmd_der_.resize(tot_size); } -void EMMI::prepare() { - if(getExchangeStep()) { - first_time_=true; - } +void EMMI::prepare() +{ + if(getExchangeStep()) first_time_=true; } // overlap calculator @@ -1492,12 +1365,8 @@ void EMMI::calculate_overlap() { } // clean temporary std::vectors - for(unsigned i=0; i scale_max_) { - new_scale = 2.0 * scale_max_ - new_scale; - } - if(new_scale < scale_min_) { - new_scale = 2.0 * scale_min_ - new_scale; - } + if(new_scale > scale_max_) {new_scale = 2.0 * scale_max_ - new_scale;} + if(new_scale < scale_min_) {new_scale = 2.0 * scale_min_ - new_scale;} // new energy double new_ene = scaleEnergy(new_scale); // accept or reject @@ -1610,7 +1474,8 @@ double EMMI::doRegression() { return scale_best; } -double EMMI::get_annealing(long long int step) { +double EMMI::get_annealing(long long int step) +{ // default no annealing double fact = 1.0; // position in annealing cycle @@ -1619,28 +1484,21 @@ double EMMI::get_annealing(long long int step) { double ncd = static_cast(nc); double nn = static_cast(nanneal_); // set fact - if(nc>=nanneal_ && nc<2*nanneal_) { - fact = (kanneal_-1.0) / nn * ( ncd - nn ) + 1.0; - } - if(nc>=2*nanneal_ && nc<3*nanneal_) { - fact = kanneal_; - } - if(nc>=3*nanneal_) { - fact = (1.0-kanneal_) / nn * ( ncd - 3.0*nn) + kanneal_; - } + if(nc>=nanneal_ && nc<2*nanneal_) fact = (kanneal_-1.0) / nn * ( ncd - nn ) + 1.0; + if(nc>=2*nanneal_ && nc<3*nanneal_) fact = kanneal_; + if(nc>=3*nanneal_) fact = (1.0-kanneal_) / nn * ( ncd - 3.0*nn) + kanneal_; return fact; } -void EMMI::get_weights(double &weight, double &norm, double &neff) { +void EMMI::get_weights(double &weight, double &norm, double &neff) +{ const double dnrep = static_cast(nrep_); // calculate the weights either from BIAS if(do_reweight_) { std::vector bias(nrep_,0); if(rank_==0) { bias[replica_] = getArgument(0); - if(nrep_>1) { - multi_sim_comm.Sum(&bias[0], nrep_); - } + if(nrep_>1) multi_sim_comm.Sum(&bias[0], nrep_); } comm.Sum(&bias[0], nrep_); @@ -1655,16 +1513,12 @@ void EMMI::get_weights(double &weight, double &norm, double &neff) { } } else { first_time_w_ = false; - for(unsigned i=0; iset(neff); } -void EMMI::calculate() { +void EMMI::calculate() +{ // calculate CV calculate_overlap(); @@ -1698,23 +1553,15 @@ void EMMI::calculate() { if(!no_aver_ && nrep_>1) { // if master node, calculate average across replicas if(rank_==0) { - for(unsigned i=0; i1) { - comm.Sum(&ovmd_ave_[0], ovmd_ave_.size()); - } + if(size_>1) comm.Sum(&ovmd_ave_[0], ovmd_ave_.size()); } else { - for(unsigned i=0; i0) { - if(step%nregres_==0 && !getExchangeStep()) { - scale_ = doRegression(); - } + if(step%nregres_==0 && !getExchangeStep()) scale_ = doRegression(); // set scale component getPntrToComponent("scale")->set(scale_); } // write model overlap to file - if(ovstride_>0 && step%ovstride_==0) { - write_model_overlap(step); - } + if(ovstride_>0 && step%ovstride_==0) write_model_overlap(step); // clear energy and virial ene_ = 0.0; virial_.zero(); // Gaussian noise - if(noise_==0) { - calculate_Gauss(); - } + if(noise_==0) calculate_Gauss(); // Outliers noise - if(noise_==1) { - calculate_Outliers(); - } + if(noise_==1) calculate_Outliers(); // Marginal noise - if(noise_==2) { - calculate_Marginal(); - } + if(noise_==2) calculate_Marginal(); // get annealing rescale factor if(nanneal_>0) { @@ -1774,9 +1611,7 @@ void EMMI::calculate() { multi_sim_comm.Sum(&ene_, 1); } else { // set der_GMMid derivatives and energy to zero - for(unsigned i=0; iset(ene_); @@ -1841,14 +1669,10 @@ void EMMI::calculate() { if(noise_!=2) { // do Montecarlo - if(dsigma_[0]>0 && step%MCstride_==0 && !getExchangeStep()) { - doMonteCarlo(); - } + if(dsigma_[0]>0 && step%MCstride_==0 && !getExchangeStep()) doMonteCarlo(); // print status - if(step%statusstride_==0) { - print_status(step); - } + if(step%statusstride_==0) print_status(step); // calculate acceptance ratio double acc = MCaccept_ / MCtrials_; @@ -1860,7 +1684,8 @@ void EMMI::calculate() { } -void EMMI::calculate_Gauss() { +void EMMI::calculate_Gauss() +{ // cycle on all the GMM groups for(unsigned i=0; i atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()!=2) { + if(atoms.size()!=2) error("Number of specified atoms should be 2"); - } parse("R0",R0_); bool nopbc=!pbc; parseFlag("NOPBC",nopbc); @@ -115,11 +115,8 @@ FretEfficiency::FretEfficiency(const ActionOptions&ao): log.printf(" between atoms %d %d\n",atoms[0].serial(),atoms[1].serial()); log.printf(" with Forster radius set to %lf\n",R0_); - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); log << " Bibliography" << plumed.cite("Bonomi, Camilloni, Bioinformatics, 33, 3999 (2017)") << "\n"; @@ -133,9 +130,7 @@ FretEfficiency::FretEfficiency(const ActionOptions&ao): // calculator void FretEfficiency::calculate() { - if(pbc) { - makeWhole(); - } + if(pbc) makeWhole(); Vector distance=delta(getPosition(0),getPosition(1)); const double dist_mod=distance.modulo(); diff --git a/src/isdb/Jcoupling.cpp b/src/isdb/Jcoupling.cpp index 0a97686da2..8c3bd4e6e4 100644 --- a/src/isdb/Jcoupling.cpp +++ b/src/isdb/Jcoupling.cpp @@ -85,7 +85,8 @@ PRINT ARG=jhanst.*,jhan.* FILE=COLVAR STRIDE=100 //+ENDPLUMEDOC class JCoupling : - public MetainferenceBase { + public MetainferenceBase +{ private: bool pbc; enum { HAN, HAHN, CCG, NCG, CUSTOM }; @@ -124,7 +125,8 @@ void JCoupling::registerKeywords(Keywords& keys) { JCoupling::JCoupling(const ActionOptions&ao): PLUMED_METAINF_INIT(ao), - pbc(true) { + pbc(true) +{ bool nopbc = !pbc; parseFlag("NOPBC", nopbc); pbc =! nopbc; @@ -179,21 +181,13 @@ JCoupling::JCoupling(const ActionOptions&ao): coupl.resize( ncoupl_ ); unsigned ntarget=0; for(unsigned i=0; i deriv(ncoupl_*6); std::vector j(ncoupl_,0.); @@ -337,9 +327,7 @@ void JCoupling::calculate() { dd1 *= derj; dd2 *= derj; - if(getDoScore()) { - setCalcData(r, j[r]); - } + if(getDoScore()) setCalcData(r, j[r]); deriv[a0] = dd0; deriv[a0+1] = -dd0; deriv[a0+2] = dd1; @@ -376,8 +364,7 @@ void JCoupling::calculate() { } else { for (unsigned r=0; rset(j[r]); setAtomsDerivatives(val, a0, deriv[a0]); @@ -400,9 +387,7 @@ void JCoupling::calculate() { void JCoupling::update() { // write status file - if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) { - writeStatus(); - } + if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) writeStatus(); } } diff --git a/src/isdb/Metainference.cpp b/src/isdb/Metainference.cpp index 9bdcb88594..c9b81317d8 100644 --- a/src/isdb/Metainference.cpp +++ b/src/isdb/Metainference.cpp @@ -154,7 +154,8 @@ LABEL=spe */ //+ENDPLUMEDOC -class Metainference : public bias::Bias { +class Metainference : public bias::Bias +{ // experimental values std::vector parameters; // noise type @@ -367,7 +368,8 @@ Metainference::Metainference(const ActionOptions&ao): N_optimized_step_(0), optimized_step_(0), sigmamax_opt_done_(false), - average_weights_stride_(1) { + average_weights_stride_(1) +{ bool noensemble = false; parseFlag("NOENSEMBLE", noensemble); @@ -376,9 +378,7 @@ Metainference::Metainference(const ActionOptions&ao): if(master) { nrep_ = multi_sim_comm.Get_size(); replica_ = multi_sim_comm.Get_rank(); - if(noensemble) { - nrep_ = 1; - } + if(noensemble) nrep_ = 1; } else { nrep_ = 0; replica_ = 0; @@ -390,30 +390,19 @@ Metainference::Metainference(const ActionOptions&ao): parse("SELECTOR", selector_); parse("NSELECT", nsel); // do checks - if(selector_.length()>0 && nsel<=1) { - error("With SELECTOR active, NSELECT must be greater than 1"); - } - if(selector_.length()==0 && nsel>1) { - error("With NSELECT greater than 1, you must specify SELECTOR"); - } + if(selector_.length()>0 && nsel<=1) error("With SELECTOR active, NSELECT must be greater than 1"); + if(selector_.length()==0 && nsel>1) error("With NSELECT greater than 1, you must specify SELECTOR"); // initialise firstTimeW firstTimeW.resize(nsel, true); // reweight implies a different number of arguments (the latest one must always be the bias) parseFlag("REWEIGHT", do_reweight_); - if(do_reweight_&&nrep_<2) { - error("REWEIGHT can only be used in parallel with 2 or more replicas"); - } - if(!getRestart()) { - average_weights_.resize(nsel, std::vector (nrep_, 1./static_cast(nrep_))); - } else { - average_weights_.resize(nsel, std::vector (nrep_, 0.)); - } + if(do_reweight_&&nrep_<2) error("REWEIGHT can only be used in parallel with 2 or more replicas"); + if(!getRestart()) average_weights_.resize(nsel, std::vector (nrep_, 1./static_cast(nrep_))); + else average_weights_.resize(nsel, std::vector (nrep_, 0.)); narg = getNumberOfArguments(); - if(do_reweight_) { - narg--; - } + if(do_reweight_) narg--; unsigned averaging=0; parse("AVERAGING", averaging); @@ -423,57 +412,38 @@ Metainference::Metainference(const ActionOptions&ao): } parseVector("PARAMETERS",parameters); - if(parameters.size()!=static_cast(narg)&&!parameters.empty()) { + if(parameters.size()!=static_cast(narg)&&!parameters.empty()) error("Size of PARAMETERS array should be either 0 or the same as of the number of arguments in ARG1"); - } std::vector arg2; parseArgumentList("PARARG",arg2); if(!arg2.empty()) { - if(parameters.size()>0) { - error("It is not possible to use PARARG and PARAMETERS together"); - } - if(arg2.size()!=narg) { - error("Size of PARARG array should be the same as number for arguments in ARG"); - } + if(parameters.size()>0) error("It is not possible to use PARARG and PARAMETERS together"); + if(arg2.size()!=narg) error("Size of PARARG array should be the same as number for arguments in ARG"); for(unsigned i=0; iget()); - if(arg2[i]->hasDerivatives()==true) { - error("PARARG can only accept arguments without derivatives"); - } + if(arg2[i]->hasDerivatives()==true) error("PARARG can only accept arguments without derivatives"); } } - if(parameters.size()!=narg) { + if(parameters.size()!=narg) error("PARARG or PARAMETERS arrays should include the same number of elements as the arguments in ARG"); - } std::string stringa_noise; parse("NOISETYPE",stringa_noise); - if(stringa_noise=="GAUSS") { - noise_type_ = GAUSS; - } else if(stringa_noise=="MGAUSS") { - noise_type_ = MGAUSS; - } else if(stringa_noise=="OUTLIERS") { - noise_type_ = OUTLIERS; - } else if(stringa_noise=="MOUTLIERS") { - noise_type_ = MOUTLIERS; - } else if(stringa_noise=="GENERIC") { - noise_type_ = GENERIC; - } else { - error("Unknown noise type!"); - } + if(stringa_noise=="GAUSS") noise_type_ = GAUSS; + else if(stringa_noise=="MGAUSS") noise_type_ = MGAUSS; + else if(stringa_noise=="OUTLIERS") noise_type_ = OUTLIERS; + else if(stringa_noise=="MOUTLIERS") noise_type_ = MOUTLIERS; + else if(stringa_noise=="GENERIC") noise_type_ = GENERIC; + else error("Unknown noise type!"); if(noise_type_== GENERIC) { std::string stringa_like; parse("LIKELIHOOD",stringa_like); - if(stringa_like=="GAUSS") { - gen_likelihood_ = LIKE_GAUSS; - } else if(stringa_like=="LOGN") { - gen_likelihood_ = LIKE_LOGN; - } else { - error("Unknown likelihood type!"); - } + if(stringa_like=="GAUSS") gen_likelihood_ = LIKE_GAUSS; + else if(stringa_like=="LOGN") gen_likelihood_ = LIKE_LOGN; + else error("Unknown likelihood type!"); parse("DFTILDE",Dftilde_); } @@ -481,55 +451,35 @@ Metainference::Metainference(const ActionOptions&ao): parse("WRITE_STRIDE",write_stride_); std::string status_file_name_; parse("STATUS_FILE",status_file_name_); - if(status_file_name_=="") { - status_file_name_ = "MISTATUS"+getLabel(); - } else { - status_file_name_ = status_file_name_+getLabel(); - } + if(status_file_name_=="") status_file_name_ = "MISTATUS"+getLabel(); + else status_file_name_ = status_file_name_+getLabel(); std::string stringa_optsigma; parse("OPTSIGMAMEAN", stringa_optsigma); - if(stringa_optsigma=="NONE") { - do_optsigmamean_=0; - } else if(stringa_optsigma=="SEM") { - do_optsigmamean_=1; - } else if(stringa_optsigma=="SEM_MAX") { - do_optsigmamean_=2; - } + if(stringa_optsigma=="NONE") do_optsigmamean_=0; + else if(stringa_optsigma=="SEM") do_optsigmamean_=1; + else if(stringa_optsigma=="SEM_MAX") do_optsigmamean_=2; unsigned aver_max_steps=0; parse("SIGMA_MAX_STEPS", aver_max_steps); - if(aver_max_steps==0&&do_optsigmamean_==2) { - aver_max_steps=averaging*2000; - } - if(aver_max_steps>0&&do_optsigmamean_<2) { - error("SIGMA_MAX_STEPS can only be used together with OPTSIGMAMEAN=SEM_MAX"); - } - if(aver_max_steps>0&&do_optsigmamean_==2) { - N_optimized_step_=aver_max_steps; - } - if(aver_max_steps>0&&aver_max_steps0&&do_optsigmamean_<2) error("SIGMA_MAX_STEPS can only be used together with OPTSIGMAMEAN=SEM_MAX"); + if(aver_max_steps>0&&do_optsigmamean_==2) N_optimized_step_=aver_max_steps; + if(aver_max_steps>0&&aver_max_steps read_sigma_mean_; parseVector("SIGMA_MEAN0",read_sigma_mean_); - if(do_optsigmamean_==0 && read_sigma_mean_.size()==0 && !getRestart()) { + if(do_optsigmamean_==0 && read_sigma_mean_.size()==0 && !getRestart()) error("If you don't use OPTSIGMAMEAN and you are not RESTARTING then you MUST SET SIGMA_MEAN0"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { if(read_sigma_mean_.size()==narg) { sigma_mean2_.resize(narg); - for(unsigned i=0; i readsigma; parseVector("SIGMA0",readsigma); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { sigma_.resize(readsigma.size()); sigma_=readsigma; - } else { - sigma_.resize(1, readsigma[0]); - } + } else sigma_.resize(1, readsigma[0]); std::vector readsigma_min; parseVector("SIGMA_MIN",readsigma_min); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_min.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_min.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { sigma_min_.resize(readsigma_min.size()); sigma_min_=readsigma_min; - } else { - sigma_min_.resize(1, readsigma_min[0]); - } + } else sigma_min_.resize(1, readsigma_min[0]); std::vector readsigma_max; parseVector("SIGMA_MAX",readsigma_max); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { sigma_max_.resize(readsigma_max.size()); sigma_max_=readsigma_max; - } else { - sigma_max_.resize(1, readsigma_max[0]); - } + } else sigma_max_.resize(1, readsigma_max[0]); - if(sigma_max_.size()!=sigma_min_.size()) { - error("The number of values for SIGMA_MIN and SIGMA_MAX must be the same"); - } + if(sigma_max_.size()!=sigma_min_.size()) error("The number of values for SIGMA_MIN and SIGMA_MAX must be the same"); std::vector read_dsigma; parseVector("DSIGMA",read_dsigma); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(read_dsigma.size()>0) { Dsigma_.resize(read_dsigma.size()); Dsigma_=read_dsigma; @@ -687,14 +597,9 @@ Metainference::Metainference(const ActionOptions&ao): // get temperature double temp=0.0; parse("TEMP",temp); - if(temp>0.0) { - kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt_=plumed.getAtoms().getKbT(); - } - if(kbt_==0.0) { - error("Unless the MD engine passes the temperature to plumed, you must specify it using TEMP"); - } + if(temp>0.0) kbt_=plumed.getAtoms().getKBoltzmann()*temp; + else kbt_=plumed.getAtoms().getKbT(); + if(kbt_==0.0) error("Unless the MD engine passes the temperature to plumed, you must specify it using TEMP"); checkRead(); @@ -732,9 +637,7 @@ Metainference::Metainference(const ActionOptions&ao): restart_sfile.link(*this); if(getRestart()&&restart_sfile.FileExist(status_file_name_)) { firstTime = false; - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&average_weights_[i][0], nrep_); - } + if(nrep_>1) multi_sim_comm.Sum(&average_weights_[i][0], nrep_); } comm.Sum(&average_weights_[i][0], nrep_); } @@ -820,19 +717,13 @@ Metainference::Metainference(const ActionOptions&ao): } /* If DSIGMA is not yet initialised do it now */ - for(unsigned i=0; iset(std::sqrt(sigma_mean2_[i])); - addComponent("sigma-"+num); - componentIsNotPeriodic("sigma-"+num); + addComponent("sigma-"+num); componentIsNotPeriodic("sigma-"+num); valueSigma.push_back(getPntrToComponent("sigma-"+num)); getPntrToComponent("sigma-"+num)->set(sigma_[i]); if(noise_type_==GENERIC) { - addComponent("ftilde-"+num); - componentIsNotPeriodic("ftilde-"+num); + addComponent("ftilde-"+num); componentIsNotPeriodic("ftilde-"+num); valueFtilde.push_back(getPntrToComponent("ftilde-"+num)); } } } else { - addComponent("sigmaMean"); - componentIsNotPeriodic("sigmaMean"); + addComponent("sigmaMean"); componentIsNotPeriodic("sigmaMean"); valueSigmaMean.push_back(getPntrToComponent("sigmaMean")); getPntrToComponent("sigmaMean")->set(std::sqrt(sigma_mean2_[0])); - addComponent("sigma"); - componentIsNotPeriodic("sigma"); + addComponent("sigma"); componentIsNotPeriodic("sigma"); valueSigma.push_back(getPntrToComponent("sigma")); getPntrToComponent("sigma")->set(sigma_[0]); } @@ -1016,9 +886,7 @@ Metainference::Metainference(const ActionOptions&ao): // in this case we want the same seed everywhere auto ts = std::chrono::time_point_cast(std::chrono::steady_clock::now()).time_since_epoch().count(); iseed = static_cast(ts); - if(master&&nrep_>1) { - multi_sim_comm.Bcast(iseed,0); - } + if(master&&nrep_>1) multi_sim_comm.Bcast(iseed,0); comm.Bcast(iseed,0); // this is used for scale and offset sampling and acceptance random[1].setSeed(-iseed); @@ -1040,24 +908,20 @@ Metainference::Metainference(const ActionOptions&ao): } log<<" Bibliography "<0) { - log<0) log< &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; const double sm2 = sigma_mean2_[0]; const double ss2 = sigma[0]*sigma[0] + scale2*sm2; @@ -1072,24 +936,22 @@ double Metainference::getEnergySP(const std::vector &mean, const std::ve const double a2 = 0.5*dev*dev + ss2; if(sm2 > 0.0) { ene += std::log(2.0*a2/(1.0-std::exp(-a2/sm2))); - } else { + } + else { ene += std::log(2.0*a2); } } } // add one single Jeffrey's prior and one normalisation per data point ene += 0.5*std::log(sss) + static_cast(narg)*0.5*std::log(0.5*M_PI*M_PI/ss2); - if(doscale_ || doregres_zero_) { - ene += 0.5*std::log(sss); - } - if(dooffset_) { - ene += 0.5*std::log(sss); - } + if(doscale_ || doregres_zero_) ene += 0.5*std::log(sss); + if(dooffset_) ene += 0.5*std::log(sss); return kbt_ * ene; } double Metainference::getEnergySPE(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; double ene = 0.0; #pragma omp parallel num_threads(OpenMP::getNumThreads()) shared(ene) @@ -1103,22 +965,20 @@ double Metainference::getEnergySPE(const std::vector &mean, const std::v const double a2 = 0.5*dev*dev + ss2; if(sm2 > 0.0) { ene += 0.5*std::log(sss) + 0.5*std::log(0.5*M_PI*M_PI/ss2) + std::log(2.0*a2/(1.0-std::exp(-a2/sm2))); - } else { - ene += 0.5*std::log(sss) + 0.5*std::log(0.5*M_PI*M_PI/ss2) + std::log(2.0*a2); } - if(doscale_ || doregres_zero_) { - ene += 0.5*std::log(sss); - } - if(dooffset_) { - ene += 0.5*std::log(sss); + else { + ene += 0.5*std::log(sss) + 0.5*std::log(0.5*M_PI*M_PI/ss2) + std::log(2.0*a2); } + if(doscale_ || doregres_zero_) ene += 0.5*std::log(sss); + if(dooffset_) ene += 0.5*std::log(sss); } } return kbt_ * ene; } double Metainference::getEnergyMIGEN(const std::vector &mean, const std::vector &ftilde, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ double ene = 0.0; #pragma omp parallel num_threads(OpenMP::getNumThreads()) shared(ene) { @@ -1127,35 +987,26 @@ double Metainference::getEnergyMIGEN(const std::vector &mean, const std: const double inv_sb2 = 1./(sigma[i]*sigma[i]); const double inv_sm2 = 1./sigma_mean2_[i]; double devb = 0; - if(gen_likelihood_==LIKE_GAUSS) { - devb = scale*ftilde[i]-parameters[i]+offset; - } else if(gen_likelihood_==LIKE_LOGN) { - devb = std::log(scale*ftilde[i]/parameters[i]); - } + if(gen_likelihood_==LIKE_GAUSS) devb = scale*ftilde[i]-parameters[i]+offset; + else if(gen_likelihood_==LIKE_LOGN) devb = std::log(scale*ftilde[i]/parameters[i]); double devm = mean[i] - ftilde[i]; // deviation + normalisation + jeffrey double normb = 0.; - if(gen_likelihood_==LIKE_GAUSS) { - normb = -0.5*std::log(0.5/M_PI*inv_sb2); - } else if(gen_likelihood_==LIKE_LOGN) { - normb = -0.5*std::log(0.5/M_PI*inv_sb2/(parameters[i]*parameters[i])); - } + if(gen_likelihood_==LIKE_GAUSS) normb = -0.5*std::log(0.5/M_PI*inv_sb2); + else if(gen_likelihood_==LIKE_LOGN) normb = -0.5*std::log(0.5/M_PI*inv_sb2/(parameters[i]*parameters[i])); const double normm = -0.5*std::log(0.5/M_PI*inv_sm2); const double jeffreys = -0.5*std::log(2.*inv_sb2); ene += 0.5*devb*devb*inv_sb2 + 0.5*devm*devm*inv_sm2 + normb + normm + jeffreys; - if(doscale_ || doregres_zero_) { - ene += jeffreys; - } - if(dooffset_) { - ene += jeffreys; - } + if(doscale_ || doregres_zero_) ene += jeffreys; + if(dooffset_) ene += jeffreys; } } return kbt_ * ene; } double Metainference::getEnergyGJ(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; const double inv_s2 = 1./(sigma[0]*sigma[0] + scale2*sigma_mean2_[0]); const double inv_sss = 1./(sigma[0]*sigma[0] + sigma_mean2_[0]); @@ -1173,18 +1024,15 @@ double Metainference::getEnergyGJ(const std::vector &mean, const std::ve const double jeffreys = -0.5*std::log(2.*inv_sss); // add Jeffrey's prior in case one sigma for all data points + one normalisation per datapoint ene += jeffreys + static_cast(narg)*normalisation; - if(doscale_ || doregres_zero_) { - ene += jeffreys; - } - if(dooffset_) { - ene += jeffreys; - } + if(doscale_ || doregres_zero_) ene += jeffreys; + if(dooffset_) ene += jeffreys; return kbt_ * ene; } double Metainference::getEnergyGJE(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; double ene = 0.0; @@ -1199,18 +1047,15 @@ double Metainference::getEnergyGJE(const std::vector &mean, const std::v const double normalisation = -0.5*std::log(0.5/M_PI*inv_s2); const double jeffreys = -0.5*std::log(2.*inv_sss); ene += 0.5*dev*dev*inv_s2 + normalisation + jeffreys; - if(doscale_ || doregres_zero_) { - ene += jeffreys; - } - if(dooffset_) { - ene += jeffreys; - } + if(doscale_ || doregres_zero_) ene += jeffreys; + if(dooffset_) ene += jeffreys; } } return kbt_ * ene; } -void Metainference::moveTilde(const std::vector &mean_, double &old_energy) { +void Metainference::moveTilde(const std::vector &mean_, double &old_energy) +{ std::vector new_ftilde(sigma_.size()); new_ftilde = ftilde_; @@ -1241,7 +1086,8 @@ void Metainference::moveTilde(const std::vector &mean_, double &old_ener } } -void Metainference::moveScaleOffset(const std::vector &mean_, double &old_energy) { +void Metainference::moveScaleOffset(const std::vector &mean_, double &old_energy) +{ double new_scale = scale_; if(doscale_) { @@ -1250,12 +1096,8 @@ void Metainference::moveScaleOffset(const std::vector &mean_, double &ol const double ds1 = Dscale_*r1; new_scale += ds1; // check boundaries - if(new_scale > scale_max_) { - new_scale = 2.0 * scale_max_ - new_scale; - } - if(new_scale < scale_min_) { - new_scale = 2.0 * scale_min_ - new_scale; - } + if(new_scale > scale_max_) {new_scale = 2.0 * scale_max_ - new_scale;} + if(new_scale < scale_min_) {new_scale = 2.0 * scale_min_ - new_scale;} } else { const double r1 = random[1].Gaussian(); const double ds1 = 0.5*(scale_mu_-new_scale)+Dscale_*std::exp(1)/M_PI*r1; @@ -1271,12 +1113,8 @@ void Metainference::moveScaleOffset(const std::vector &mean_, double &ol const double ds1 = Doffset_*r1; new_offset += ds1; // check boundaries - if(new_offset > offset_max_) { - new_offset = 2.0 * offset_max_ - new_offset; - } - if(new_offset < offset_min_) { - new_offset = 2.0 * offset_min_ - new_offset; - } + if(new_offset > offset_max_) {new_offset = 2.0 * offset_max_ - new_offset;} + if(new_offset < offset_min_) {new_offset = 2.0 * offset_min_ - new_offset;} } else { const double r1 = random[1].Gaussian(); const double ds1 = 0.5*(offset_mu_-new_offset)+Doffset_*std::exp(1)/M_PI*r1; @@ -1310,9 +1148,7 @@ void Metainference::moveScaleOffset(const std::vector &mean_, double &ol if(master) { totenergies[0] = old_energy; totenergies[1] = new_energy; - if(nrep_>1) { - multi_sim_comm.Sum(totenergies); - } + if(nrep_>1) multi_sim_comm.Sum(totenergies); } else { totenergies[0] = 0; totenergies[1] = 0; @@ -1339,7 +1175,8 @@ void Metainference::moveScaleOffset(const std::vector &mean_, double &ol } } -void Metainference::moveSigmas(const std::vector &mean_, double &old_energy, const unsigned i, const std::vector &indices, bool &breaknow) { +void Metainference::moveSigmas(const std::vector &mean_, double &old_energy, const unsigned i, const std::vector &indices, bool &breaknow) +{ std::vector new_sigma(sigma_.size()); new_sigma = sigma_; @@ -1362,12 +1199,8 @@ void Metainference::moveSigmas(const std::vector &mean_, double &old_ene const double ds2 = Dsigma_[index]*r2; new_sigma[index] = sigma_[index] + ds2; // check boundaries - if(new_sigma[index] > sigma_max_[index]) { - new_sigma[index] = 2.0 * sigma_max_[index] - new_sigma[index]; - } - if(new_sigma[index] < sigma_min_[index]) { - new_sigma[index] = 2.0 * sigma_min_[index] - new_sigma[index]; - } + if(new_sigma[index] > sigma_max_[index]) {new_sigma[index] = 2.0 * sigma_max_[index] - new_sigma[index];} + if(new_sigma[index] < sigma_min_[index]) {new_sigma[index] = 2.0 * sigma_min_[index] - new_sigma[index];} } } else { // change all sigmas @@ -1376,12 +1209,8 @@ void Metainference::moveSigmas(const std::vector &mean_, double &old_ene const double ds2 = Dsigma_[j]*r2; new_sigma[j] = sigma_[j] + ds2; // check boundaries - if(new_sigma[j] > sigma_max_[j]) { - new_sigma[j] = 2.0 * sigma_max_[j] - new_sigma[j]; - } - if(new_sigma[j] < sigma_min_[j]) { - new_sigma[j] = 2.0 * sigma_min_[j] - new_sigma[j]; - } + if(new_sigma[j] > sigma_max_[j]) {new_sigma[j] = 2.0 * sigma_max_[j] - new_sigma[j];} + if(new_sigma[j] < sigma_min_[j]) {new_sigma[j] = 2.0 * sigma_min_[j] - new_sigma[j];} } } @@ -1428,7 +1257,8 @@ void Metainference::moveSigmas(const std::vector &mean_, double &old_ene } } -double Metainference::doMonteCarlo(const std::vector &mean_) { +double Metainference::doMonteCarlo(const std::vector &mean_) +{ // calculate old energy with the updated coordinates double old_energy=0.; @@ -1467,19 +1297,13 @@ double Metainference::doMonteCarlo(const std::vector &mean_) { for(unsigned i=0; i &mean_) { if(noise_type_==GENERIC) { double accept = static_cast(MCacceptFT_) / static_cast(MCtrial_); valueAcceptFT->set(accept); - for(unsigned i=0; iset(ftilde_[i]); - } + for(unsigned i=0; iset(ftilde_[i]); } /* scale and offset */ - if(doscale_ || doregres_zero_) { - valueScale->set(scale_); - } - if(dooffset_) { - valueOffset->set(offset_); - } + if(doscale_ || doregres_zero_) valueScale->set(scale_); + if(dooffset_) valueOffset->set(offset_); if(doscale_||dooffset_) { double accept = static_cast(MCacceptScale_) / static_cast(MCtrial_); valueAcceptScale->set(accept); } /* sigmas */ - for(unsigned i=0; iset(sigma_[i]); - } + for(unsigned i=0; iset(sigma_[i]); double accept = static_cast(MCaccept_) / static_cast(MCtrial_); valueAccept->set(accept); } // here we sum the score over the replicas to get the full metainference score that we save as a bias if(master) { - if(nrep_>1) { - multi_sim_comm.Sum(old_energy); - } + if(nrep_>1) multi_sim_comm.Sum(old_energy); } else { old_energy=0; } @@ -1531,7 +1345,8 @@ double Metainference::doMonteCarlo(const std::vector &mean_) { */ void Metainference::getEnergyForceSP(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; const double sm2 = sigma_mean2_[0]; const double ss2 = sigma_[0]*sigma_[0] + scale2*sm2; @@ -1549,15 +1364,14 @@ void Metainference::getEnergyForceSP(const std::vector &mean, const std: const double dt = 1./t; const double dit = 1./(1.-dt); f[i] = -scale_*dev*(dit/sm2 + 1./a2); - } else { + } + else { f[i] = -scale_*dev*(1./a2); } } } // collect contribution to forces and energy from other replicas - if(nrep_>1) { - multi_sim_comm.Sum(&f[0],narg); - } + if(nrep_>1) multi_sim_comm.Sum(&f[0],narg); } // intra-replica summation comm.Sum(&f[0],narg); @@ -1575,7 +1389,8 @@ void Metainference::getEnergyForceSP(const std::vector &mean, const std: } void Metainference::getEnergyForceSPE(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; std::vector f(narg,0); @@ -1593,15 +1408,14 @@ void Metainference::getEnergyForceSPE(const std::vector &mean, const std const double dt = 1./t; const double dit = 1./(1.-dt); f[i] = -scale_*dev*(dit/sm2 + 1./a2); - } else { + } + else { f[i] = -scale_*dev*(1./a2); } } } // collect contribution to forces and energy from other replicas - if(nrep_>1) { - multi_sim_comm.Sum(&f[0],narg); - } + if(nrep_>1) multi_sim_comm.Sum(&f[0],narg); } comm.Sum(&f[0],narg); @@ -1618,15 +1432,14 @@ void Metainference::getEnergyForceSPE(const std::vector &mean, const std } void Metainference::getEnergyForceGJ(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; double inv_s2=0.; if(master) { inv_s2 = 1./(sigma_[0]*sigma_[0] + scale2*sigma_mean2_[0]); - if(nrep_>1) { - multi_sim_comm.Sum(inv_s2); - } + if(nrep_>1) multi_sim_comm.Sum(inv_s2); } comm.Sum(inv_s2); @@ -1649,17 +1462,14 @@ void Metainference::getEnergyForceGJ(const std::vector &mean, const std: } void Metainference::getEnergyForceGJE(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; std::vector inv_s2(sigma_.size(),0.); if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&inv_s2[0],sigma_.size()); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&inv_s2[0],sigma_.size()); } comm.Sum(&inv_s2[0],sigma_.size()); @@ -1681,7 +1491,8 @@ void Metainference::getEnergyForceGJE(const std::vector &mean, const std } } -void Metainference::getEnergyForceMIGEN(const std::vector &mean, const std::vector &dmean_x, const std::vector &dmean_b) { +void Metainference::getEnergyForceMIGEN(const std::vector &mean, const std::vector &dmean_x, const std::vector &dmean_b) +{ std::vector inv_s2(sigma_.size(),0.); std::vector dev(sigma_.size(),0.); std::vector dev2(sigma_.size(),0.); @@ -1717,16 +1528,15 @@ void Metainference::getEnergyForceMIGEN(const std::vector &mean, const s } } -void Metainference::get_weights(const unsigned iselect, double &weight, double &norm, double &neff) { +void Metainference::get_weights(const unsigned iselect, double &weight, double &norm, double &neff) +{ const double dnrep = static_cast(nrep_); // calculate the weights either from BIAS if(do_reweight_) { std::vector bias(nrep_,0); if(master) { bias[replica_] = getArgument(narg); - if(nrep_>1) { - multi_sim_comm.Sum(&bias[0], nrep_); - } + if(nrep_>1) multi_sim_comm.Sum(&bias[0], nrep_); } comm.Sum(&bias[0], nrep_); @@ -1739,16 +1549,12 @@ void Metainference::get_weights(const unsigned iselect, double &weight, double & } } else { firstTimeW[iselect] = false; - for(unsigned i=0; iset(neff); } -void Metainference::get_sigma_mean(const unsigned iselect, const double weight, const double norm, const double neff, const std::vector &mean) { +void Metainference::get_sigma_mean(const unsigned iselect, const double weight, const double norm, const double neff, const std::vector &mean) +{ const double dnrep = static_cast(nrep_); std::vector sigma_mean2_tmp(sigma_mean2_.size(), 0.); if(do_optsigmamean_>0) { // remove first entry of the history std::vector if(sigma_mean2_last_[iselect][0].size()==optsigmamean_stride_&&optsigmamean_stride_>0) - for(unsigned i=0; i sigma_mean2_now(narg,0); if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&sigma_mean2_now[0], narg); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&sigma_mean2_now[0], narg); } comm.Sum(&sigma_mean2_now[0], narg); - for(unsigned i=0; i0) { - for(unsigned i=0; i sigma_mean2_last_[iselect][i][0]) { - sigma_mean2_last_[iselect][i][0] = sigma_mean2_now[i]; - } + for(unsigned i=0; i sigma_mean2_last_[iselect][i][0]) sigma_mean2_last_[iselect][i][0] = sigma_mean2_now[i]; } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { @@ -1814,17 +1608,13 @@ void Metainference::get_sigma_mean(const unsigned iselect, const double weight, valueSigmaMean[i]->set(std::sqrt(sigma_mean2_tmp[i])); if(noise_type_==GENERIC) { sigma_min_[i] = std::sqrt(sigma_mean2_tmp[i]); - if(sigma_[i] < sigma_min_[i]) { - sigma_[i] = sigma_min_[i]; - } + if(sigma_[i] < sigma_min_[i]) sigma_[i] = sigma_min_[i]; } } } else if(noise_type_==GAUSS||noise_type_==OUTLIERS) { // find maximum for each data point std::vector max_values; - for(unsigned i=0; i1&&!sigmamax_opt_done_) { for(unsigned i=0; ioptsigmamean_stride_) { - sigma_max_est_[i]=sigma_mean2_tmp[i]; - } + if(sigma_max_est_[i]optsigmamean_stride_) sigma_max_est_[i]=sigma_mean2_tmp[i]; // ready to set once and for all the value of sigma_max if(optimized_step_==N_optimized_step_) { sigmamax_opt_done_=true; for(unsigned i=0; isigma_max_[i]) { - sigma_[i]=sigma_max_[i]; - } + if(sigma_[i]>sigma_max_[i]) sigma_[i]=sigma_max_[i]; } } } @@ -1868,29 +1654,22 @@ void Metainference::get_sigma_mean(const unsigned iselect, const double weight, sigma_mean2_ = sigma_mean2_tmp; } -void Metainference::replica_averaging(const double weight, const double norm, std::vector &mean, std::vector &dmean_b) { +void Metainference::replica_averaging(const double weight, const double norm, std::vector &mean, std::vector &dmean_b) +{ if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&mean[0], narg); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&mean[0], narg); } comm.Sum(&mean[0], narg); // set the derivative of the mean with respect to the bias - for(unsigned i=0; i(average_weights_stride_); - } + for(unsigned i=0; i(average_weights_stride_); // this is only for generic metainference - if(firstTime) { - ftilde_ = mean; - firstTime = false; - } + if(firstTime) {ftilde_ = mean; firstTime = false;} } -void Metainference::do_regression_zero(const std::vector &mean) { +void Metainference::do_regression_zero(const std::vector &mean) +{ // parameters[i] = scale_ * mean[i]: find scale_ with linear regression double num = 0.0; double den = 0.0; @@ -1905,15 +1684,14 @@ void Metainference::do_regression_zero(const std::vector &mean) { } } -void Metainference::calculate() { +void Metainference::calculate() +{ // get step const long long int step = getStep(); unsigned iselect = 0; // set the value of selector for REM-like stuff - if(selector_.length()>0) { - iselect = static_cast(plumed.passMap[selector_]); - } + if(selector_.length()>0) iselect = static_cast(plumed.passMap[selector_]); /* 1) collect weights */ double weight = 0.; @@ -1934,9 +1712,7 @@ void Metainference::calculate() { get_sigma_mean(iselect, weight, norm, neff, mean); // in case of regression with zero intercept, calculate scale - if(doregres_zero_ && step%nregres_zero_==0) { - do_regression_zero(mean); - } + if(doregres_zero_ && step%nregres_zero_==0) do_regression_zero(mean); /* 4) run monte carlo */ double ene = doMonteCarlo(mean); @@ -1963,7 +1739,8 @@ void Metainference::calculate() { setBias(ene); } -void Metainference::writeStatus() { +void Metainference::writeStatus() +{ sfile_.rewind(); sfile_.printField("time",getTimeStep()*getStep()); //nsel @@ -2020,9 +1797,7 @@ void Metainference::writeStatus() { void Metainference::update() { // write status file - if(write_stride_>0&& (getStep()%write_stride_==0 || getCPT()) ) { - writeStatus(); - } + if(write_stride_>0&& (getStep()%write_stride_==0 || getCPT()) ) writeStatus(); } } diff --git a/src/isdb/MetainferenceBase.cpp b/src/isdb/MetainferenceBase.cpp index a6fa2c2264..1fb434e3a1 100644 --- a/src/isdb/MetainferenceBase.cpp +++ b/src/isdb/MetainferenceBase.cpp @@ -126,7 +126,8 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): N_optimized_step_(0), optimized_step_(0), sigmamax_opt_done_(false), - decay_w_(1.) { + decay_w_(1.) +{ parseFlag("DOSCORE", doscore_); bool noensemble = false; @@ -137,9 +138,7 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): if(master) { nrep_ = multi_sim_comm.Get_size(); replica_ = multi_sim_comm.Get_rank(); - if(noensemble) { - nrep_ = 1; - } + if(noensemble) nrep_ = 1; } else { nrep_ = 0; replica_ = 0; @@ -150,29 +149,18 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): parse("SELECTOR", selector_); parse("NSELECT", nsel_); // do checks - if(selector_.length()>0 && nsel_<=1) { - error("With SELECTOR active, NSELECT must be greater than 1"); - } - if(selector_.length()==0 && nsel_>1) { - error("With NSELECT greater than 1, you must specify SELECTOR"); - } + if(selector_.length()>0 && nsel_<=1) error("With SELECTOR active, NSELECT must be greater than 1"); + if(selector_.length()==0 && nsel_>1) error("With NSELECT greater than 1, you must specify SELECTOR"); // initialise firstTimeW firstTimeW.resize(nsel_, true); // reweight implies a different number of arguments (the latest one must always be the bias) parseFlag("REWEIGHT", do_reweight_); - if(do_reweight_&&getNumberOfArguments()!=1) { - error("To REWEIGHT one must provide one single bias as an argument"); - } - if(do_reweight_&&nrep_<2) { - error("REWEIGHT can only be used in parallel with 2 or more replicas"); - } - if(!getRestart()) { - average_weights_.resize(nsel_, std::vector (nrep_, 1./static_cast(nrep_))); - } else { - average_weights_.resize(nsel_, std::vector (nrep_, 0.)); - } + if(do_reweight_&&getNumberOfArguments()!=1) error("To REWEIGHT one must provide one single bias as an argument"); + if(do_reweight_&&nrep_<2) error("REWEIGHT can only be used in parallel with 2 or more replicas"); + if(!getRestart()) average_weights_.resize(nsel_, std::vector (nrep_, 1./static_cast(nrep_))); + else average_weights_.resize(nsel_, std::vector (nrep_, 0.)); unsigned averaging=0; parse("AVERAGING", averaging); @@ -183,79 +171,50 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): std::string stringa_noise; parse("NOISETYPE",stringa_noise); - if(stringa_noise=="GAUSS") { - noise_type_ = GAUSS; - } else if(stringa_noise=="MGAUSS") { - noise_type_ = MGAUSS; - } else if(stringa_noise=="OUTLIERS") { - noise_type_ = OUTLIERS; - } else if(stringa_noise=="MOUTLIERS") { - noise_type_ = MOUTLIERS; - } else if(stringa_noise=="GENERIC") { - noise_type_ = GENERIC; - } else { - error("Unknown noise type!"); - } + if(stringa_noise=="GAUSS") noise_type_ = GAUSS; + else if(stringa_noise=="MGAUSS") noise_type_ = MGAUSS; + else if(stringa_noise=="OUTLIERS") noise_type_ = OUTLIERS; + else if(stringa_noise=="MOUTLIERS") noise_type_ = MOUTLIERS; + else if(stringa_noise=="GENERIC") noise_type_ = GENERIC; + else error("Unknown noise type!"); if(noise_type_== GENERIC) { std::string stringa_like; parse("LIKELIHOOD",stringa_like); - if(stringa_like=="GAUSS") { - gen_likelihood_ = LIKE_GAUSS; - } else if(stringa_like=="LOGN") { - gen_likelihood_ = LIKE_LOGN; - } else { - error("Unknown likelihood type!"); - } + if(stringa_like=="GAUSS") gen_likelihood_ = LIKE_GAUSS; + else if(stringa_like=="LOGN") gen_likelihood_ = LIKE_LOGN; + else error("Unknown likelihood type!"); parse("DFTILDE",Dftilde_); } parse("WRITE_STRIDE",write_stride_); parse("STATUS_FILE",status_file_name_); - if(status_file_name_=="") { - status_file_name_ = "MISTATUS"+getLabel(); - } else { - status_file_name_ = status_file_name_+getLabel(); - } + if(status_file_name_=="") status_file_name_ = "MISTATUS"+getLabel(); + else status_file_name_ = status_file_name_+getLabel(); std::string stringa_optsigma; parse("OPTSIGMAMEAN", stringa_optsigma); - if(stringa_optsigma=="NONE") { - do_optsigmamean_=0; - } else if(stringa_optsigma=="SEM") { - do_optsigmamean_=1; - } else if(stringa_optsigma=="SEM_MAX") { - do_optsigmamean_=2; - } + if(stringa_optsigma=="NONE") do_optsigmamean_=0; + else if(stringa_optsigma=="SEM") do_optsigmamean_=1; + else if(stringa_optsigma=="SEM_MAX") do_optsigmamean_=2; unsigned aver_max_steps=0; parse("SIGMA_MAX_STEPS", aver_max_steps); - if(aver_max_steps==0&&do_optsigmamean_==2) { - aver_max_steps=averaging*2000; - } - if(aver_max_steps>0&&do_optsigmamean_<2) { - error("SIGMA_MAX_STEPS can only be used together with OPTSIGMAMEAN=SEM_MAX"); - } - if(aver_max_steps>0&&do_optsigmamean_==2) { - N_optimized_step_=aver_max_steps; - } - if(aver_max_steps>0&&aver_max_steps0&&do_optsigmamean_<2) error("SIGMA_MAX_STEPS can only be used together with OPTSIGMAMEAN=SEM_MAX"); + if(aver_max_steps>0&&do_optsigmamean_==2) N_optimized_step_=aver_max_steps; + if(aver_max_steps>0&&aver_max_steps read_sigma_mean_; parseVector("SIGMA_MEAN0",read_sigma_mean_); - if(do_optsigmamean_==0 && read_sigma_mean_.size()==0 && !getRestart() && doscore_) { + if(do_optsigmamean_==0 && read_sigma_mean_.size()==0 && !getRestart() && doscore_) error("If you don't use OPTSIGMAMEAN and you are not RESTARTING then you MUST SET SIGMA_MEAN0"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { if(read_sigma_mean_.size()>0) { sigma_mean2_.resize(read_sigma_mean_.size()); - for(unsigned i=0; i readsigma; parseVector("SIGMA0",readsigma); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { sigma_.resize(readsigma.size()); sigma_=readsigma; - } else { - sigma_.resize(1, readsigma[0]); - } + } else sigma_.resize(1, readsigma[0]); std::vector readsigma_min; parseVector("SIGMA_MIN",readsigma_min); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_min.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_min.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { sigma_min_.resize(readsigma_min.size()); sigma_min_=readsigma_min; - } else { - sigma_min_.resize(1, readsigma_min[0]); - } + } else sigma_min_.resize(1, readsigma_min[0]); std::vector readsigma_max; parseVector("SIGMA_MAX",readsigma_max); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { sigma_max_.resize(readsigma_max.size()); sigma_max_=readsigma_max; - } else { - sigma_max_.resize(1, readsigma_max[0]); - } + } else sigma_max_.resize(1, readsigma_max[0]); - if(sigma_max_.size()!=sigma_min_.size()) { - error("The number of values for SIGMA_MIN and SIGMA_MAX must be the same"); - } + if(sigma_max_.size()!=sigma_min_.size()) error("The number of values for SIGMA_MIN and SIGMA_MAX must be the same"); std::vector read_dsigma; parseVector("DSIGMA",read_dsigma); - if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) { + if((noise_type_!=MGAUSS&&noise_type_!=MOUTLIERS&&noise_type_!=GENERIC)&&readsigma_max.size()>1) error("If you want to use more than one SIGMA you should use NOISETYPE=MGAUSS|MOUTLIERS|GENERIC"); - } if(read_dsigma.size()>0) { Dsigma_.resize(read_dsigma.size()); Dsigma_=read_dsigma; @@ -399,14 +324,9 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): // get temperature double temp=0.0; parse("TEMP",temp); - if(temp>0.0) { - kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt_=plumed.getAtoms().getKbT(); - } - if(kbt_==0.0&&doscore_) { - error("Unless the MD engine passes the temperature to plumed, you must specify it using TEMP"); - } + if(temp>0.0) kbt_=plumed.getAtoms().getKBoltzmann()*temp; + else kbt_=plumed.getAtoms().getKbT(); + if(kbt_==0.0&&doscore_) error("Unless the MD engine passes the temperature to plumed, you must specify it using TEMP"); // initialize random seed unsigned iseed; @@ -424,9 +344,7 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): // in this case we want the same seed everywhere auto ts = std::chrono::time_point_cast(std::chrono::steady_clock::now()).time_since_epoch().count(); iseed = static_cast(ts); - if(master&&nrep_>1) { - multi_sim_comm.Bcast(iseed,0); - } + if(master&&nrep_>1) multi_sim_comm.Bcast(iseed,0); comm.Bcast(iseed,0); // this is used for scale and offset sampling and acceptance random[1].setSeed(-iseed); @@ -449,28 +367,24 @@ MetainferenceBase::MetainferenceBase(const ActionOptions&ao): } -MetainferenceBase::~MetainferenceBase() { - if(sfile_.isOpen()) { - sfile_.close(); - } +MetainferenceBase::~MetainferenceBase() +{ + if(sfile_.isOpen()) sfile_.close(); } -void MetainferenceBase::Initialise(const unsigned input) { +void MetainferenceBase::Initialise(const unsigned input) +{ setNarg(input); if(narg!=parameters.size()) { - std::string num1; - Tools::convert(parameters.size(),num1); - std::string num2; - Tools::convert(narg,num2); + std::string num1; Tools::convert(parameters.size(),num1); + std::string num2; Tools::convert(narg,num2); std::string msg = "The number of experimental values " + num1 +" must be the same of the calculated values " + num2; error(msg); } // resize std::vector for sigma_mean history sigma_mean2_last_.resize(nsel_); - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&average_weights_[i][0], nrep_); - } + if(nrep_>1) multi_sim_comm.Sum(&average_weights_[i][0], nrep_); } comm.Sum(&average_weights_[i][0], nrep_); } @@ -613,10 +513,7 @@ void MetainferenceBase::Initialise(const unsigned input) { } /* If DSIGMA is not yet initialised do it now */ - for(unsigned i=0; iset(std::sqrt(sigma_mean2_[i])); - addComponent("sigma-"+num); - componentIsNotPeriodic("sigma-"+num); + addComponent("sigma-"+num); componentIsNotPeriodic("sigma-"+num); valueSigma.push_back(getPntrToComponent("sigma-"+num)); getPntrToComponent("sigma-"+num)->set(sigma_[i]); if(noise_type_==GENERIC) { - addComponent("ftilde-"+num); - componentIsNotPeriodic("ftilde-"+num); + addComponent("ftilde-"+num); componentIsNotPeriodic("ftilde-"+num); valueFtilde.push_back(getPntrToComponent("ftilde-"+num)); } } } else { - addComponent("sigmaMean"); - componentIsNotPeriodic("sigmaMean"); + addComponent("sigmaMean"); componentIsNotPeriodic("sigmaMean"); valueSigmaMean.push_back(getPntrToComponent("sigmaMean")); getPntrToComponent("sigmaMean")->set(std::sqrt(sigma_mean2_[0])); - addComponent("sigma"); - componentIsNotPeriodic("sigma"); + addComponent("sigma"); componentIsNotPeriodic("sigma"); valueSigma.push_back(getPntrToComponent("sigma")); getPntrToComponent("sigma")->set(sigma_[0]); } @@ -692,11 +583,8 @@ void MetainferenceBase::Initialise(const unsigned input) { switch(noise_type_) { case GENERIC: log.printf(" with general metainference "); - if(gen_likelihood_==LIKE_GAUSS) { - log.printf(" and a gaussian likelihood\n"); - } else if(gen_likelihood_==LIKE_LOGN) { - log.printf(" and a log-normal likelihood\n"); - } + if(gen_likelihood_==LIKE_GAUSS) log.printf(" and a gaussian likelihood\n"); + else if(gen_likelihood_==LIKE_LOGN) log.printf(" and a log-normal likelihood\n"); log.printf(" ensemble average parameter sampled with a step %lf of sigma_mean\n", Dftilde_); break; case GAUSS: @@ -723,9 +611,7 @@ void MetainferenceBase::Initialise(const unsigned input) { comm.Sum(dummy_scale); for(unsigned i=1; i0) { - log<0) log<0) { - iselect = static_cast(plumed.passMap[selector_]); - } + if(selector_.length()>0) iselect = static_cast(plumed.passMap[selector_]); } double MetainferenceBase::getEnergySP(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; const double sm2 = sigma_mean2_[0]; const double ss2 = sigma[0]*sigma[0] + scale2*sm2; @@ -836,24 +705,22 @@ double MetainferenceBase::getEnergySP(const std::vector &mean, const std const double a2 = 0.5*dev*dev + ss2; if(sm2 > 0.0) { ene += std::log(2.0*a2/(1.0-std::exp(-a2/sm2))); - } else { + } + else { ene += std::log(2.0*a2); } } } // add one single Jeffrey's prior and one normalisation per data point ene += 0.5*std::log(sss) + static_cast(narg)*0.5*std::log(0.5*M_PI*M_PI/ss2); - if(doscale_ || doregres_zero_) { - ene += 0.5*std::log(sss); - } - if(dooffset_) { - ene += 0.5*std::log(sss); - } + if(doscale_ || doregres_zero_) ene += 0.5*std::log(sss); + if(dooffset_) ene += 0.5*std::log(sss); return kbt_ * ene; } double MetainferenceBase::getEnergySPE(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; double ene = 0.0; #pragma omp parallel num_threads(OpenMP::getNumThreads()) shared(ene) @@ -867,22 +734,20 @@ double MetainferenceBase::getEnergySPE(const std::vector &mean, const st const double a2 = 0.5*dev*dev + ss2; if(sm2 > 0.0) { ene += 0.5*std::log(sss) + 0.5*std::log(0.5*M_PI*M_PI/ss2) + std::log(2.0*a2/(1.0-std::exp(-a2/sm2))); - } else { - ene += 0.5*std::log(sss) + 0.5*std::log(0.5*M_PI*M_PI/ss2) + std::log(2.0*a2); } - if(doscale_ || doregres_zero_) { - ene += 0.5*std::log(sss); - } - if(dooffset_) { - ene += 0.5*std::log(sss); + else { + ene += 0.5*std::log(sss) + 0.5*std::log(0.5*M_PI*M_PI/ss2) + std::log(2.0*a2); } + if(doscale_ || doregres_zero_) ene += 0.5*std::log(sss); + if(dooffset_) ene += 0.5*std::log(sss); } } return kbt_ * ene; } double MetainferenceBase::getEnergyMIGEN(const std::vector &mean, const std::vector &ftilde, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ double ene = 0.0; #pragma omp parallel num_threads(OpenMP::getNumThreads()) shared(ene) { @@ -891,35 +756,26 @@ double MetainferenceBase::getEnergyMIGEN(const std::vector &mean, const const double inv_sb2 = 1./(sigma[i]*sigma[i]); const double inv_sm2 = 1./sigma_mean2_[i]; double devb = 0; - if(gen_likelihood_==LIKE_GAUSS) { - devb = scale*ftilde[i]-parameters[i]+offset; - } else if(gen_likelihood_==LIKE_LOGN) { - devb = std::log(scale*ftilde[i]/parameters[i]); - } + if(gen_likelihood_==LIKE_GAUSS) devb = scale*ftilde[i]-parameters[i]+offset; + else if(gen_likelihood_==LIKE_LOGN) devb = std::log(scale*ftilde[i]/parameters[i]); double devm = mean[i] - ftilde[i]; // deviation + normalisation + jeffrey double normb = 0.; - if(gen_likelihood_==LIKE_GAUSS) { - normb = -0.5*std::log(0.5/M_PI*inv_sb2); - } else if(gen_likelihood_==LIKE_LOGN) { - normb = -0.5*std::log(0.5/M_PI*inv_sb2/(parameters[i]*parameters[i])); - } + if(gen_likelihood_==LIKE_GAUSS) normb = -0.5*std::log(0.5/M_PI*inv_sb2); + else if(gen_likelihood_==LIKE_LOGN) normb = -0.5*std::log(0.5/M_PI*inv_sb2/(parameters[i]*parameters[i])); const double normm = -0.5*std::log(0.5/M_PI*inv_sm2); const double jeffreys = -0.5*std::log(2.*inv_sb2); ene += 0.5*devb*devb*inv_sb2 + 0.5*devm*devm*inv_sm2 + normb + normm + jeffreys; - if(doscale_ || doregres_zero_) { - ene += jeffreys; - } - if(dooffset_) { - ene += jeffreys; - } + if(doscale_ || doregres_zero_) ene += jeffreys; + if(dooffset_) ene += jeffreys; } } return kbt_ * ene; } double MetainferenceBase::getEnergyGJ(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; const double inv_s2 = 1./(sigma[0]*sigma[0] + scale2*sigma_mean2_[0]); const double inv_sss = 1./(sigma[0]*sigma[0] + sigma_mean2_[0]); @@ -937,18 +793,15 @@ double MetainferenceBase::getEnergyGJ(const std::vector &mean, const std const double jeffreys = -0.5*std::log(2.*inv_sss); // add Jeffrey's prior in case one sigma for all data points + one normalisation per datapoint ene += jeffreys + static_cast(narg)*normalisation; - if(doscale_ || doregres_zero_) { - ene += jeffreys; - } - if(dooffset_) { - ene += jeffreys; - } + if(doscale_ || doregres_zero_) ene += jeffreys; + if(dooffset_) ene += jeffreys; return kbt_ * ene; } double MetainferenceBase::getEnergyGJE(const std::vector &mean, const std::vector &sigma, - const double scale, const double offset) { + const double scale, const double offset) +{ const double scale2 = scale*scale; double ene = 0.0; @@ -963,18 +816,15 @@ double MetainferenceBase::getEnergyGJE(const std::vector &mean, const st const double normalisation = -0.5*std::log(0.5/M_PI*inv_s2); const double jeffreys = -0.5*std::log(2.*inv_sss); ene += 0.5*dev*dev*inv_s2 + normalisation + jeffreys; - if(doscale_ || doregres_zero_) { - ene += jeffreys; - } - if(dooffset_) { - ene += jeffreys; - } + if(doscale_ || doregres_zero_) ene += jeffreys; + if(dooffset_) ene += jeffreys; } } return kbt_ * ene; } -void MetainferenceBase::moveTilde(const std::vector &mean_, double &old_energy) { +void MetainferenceBase::moveTilde(const std::vector &mean_, double &old_energy) +{ std::vector new_ftilde(sigma_.size()); new_ftilde = ftilde_; @@ -1005,7 +855,8 @@ void MetainferenceBase::moveTilde(const std::vector &mean_, double &old_ } } -void MetainferenceBase::moveScaleOffset(const std::vector &mean_, double &old_energy) { +void MetainferenceBase::moveScaleOffset(const std::vector &mean_, double &old_energy) +{ double new_scale = scale_; if(doscale_) { @@ -1014,12 +865,8 @@ void MetainferenceBase::moveScaleOffset(const std::vector &mean_, double const double ds1 = Dscale_*r1; new_scale += ds1; // check boundaries - if(new_scale > scale_max_) { - new_scale = 2.0 * scale_max_ - new_scale; - } - if(new_scale < scale_min_) { - new_scale = 2.0 * scale_min_ - new_scale; - } + if(new_scale > scale_max_) {new_scale = 2.0 * scale_max_ - new_scale;} + if(new_scale < scale_min_) {new_scale = 2.0 * scale_min_ - new_scale;} } else { const double r1 = random[1].Gaussian(); const double ds1 = 0.5*(scale_mu_-new_scale)+Dscale_*std::exp(1)/M_PI*r1; @@ -1035,12 +882,8 @@ void MetainferenceBase::moveScaleOffset(const std::vector &mean_, double const double ds1 = Doffset_*r1; new_offset += ds1; // check boundaries - if(new_offset > offset_max_) { - new_offset = 2.0 * offset_max_ - new_offset; - } - if(new_offset < offset_min_) { - new_offset = 2.0 * offset_min_ - new_offset; - } + if(new_offset > offset_max_) {new_offset = 2.0 * offset_max_ - new_offset;} + if(new_offset < offset_min_) {new_offset = 2.0 * offset_min_ - new_offset;} } else { const double r1 = random[1].Gaussian(); const double ds1 = 0.5*(offset_mu_-new_offset)+Doffset_*std::exp(1)/M_PI*r1; @@ -1074,9 +917,7 @@ void MetainferenceBase::moveScaleOffset(const std::vector &mean_, double if(master) { totenergies[0] = old_energy; totenergies[1] = new_energy; - if(nrep_>1) { - multi_sim_comm.Sum(totenergies); - } + if(nrep_>1) multi_sim_comm.Sum(totenergies); } else { totenergies[0] = 0; totenergies[1] = 0; @@ -1103,7 +944,8 @@ void MetainferenceBase::moveScaleOffset(const std::vector &mean_, double } } -void MetainferenceBase::moveSigmas(const std::vector &mean_, double &old_energy, const unsigned i, const std::vector &indices, bool &breaknow) { +void MetainferenceBase::moveSigmas(const std::vector &mean_, double &old_energy, const unsigned i, const std::vector &indices, bool &breaknow) +{ std::vector new_sigma(sigma_.size()); new_sigma = sigma_; @@ -1126,12 +968,8 @@ void MetainferenceBase::moveSigmas(const std::vector &mean_, double &old const double ds2 = Dsigma_[index]*r2; new_sigma[index] = sigma_[index] + ds2; // check boundaries - if(new_sigma[index] > sigma_max_[index]) { - new_sigma[index] = 2.0 * sigma_max_[index] - new_sigma[index]; - } - if(new_sigma[index] < sigma_min_[index]) { - new_sigma[index] = 2.0 * sigma_min_[index] - new_sigma[index]; - } + if(new_sigma[index] > sigma_max_[index]) {new_sigma[index] = 2.0 * sigma_max_[index] - new_sigma[index];} + if(new_sigma[index] < sigma_min_[index]) {new_sigma[index] = 2.0 * sigma_min_[index] - new_sigma[index];} } } else { // change all sigmas @@ -1140,12 +978,8 @@ void MetainferenceBase::moveSigmas(const std::vector &mean_, double &old const double ds2 = Dsigma_[j]*r2; new_sigma[j] = sigma_[j] + ds2; // check boundaries - if(new_sigma[j] > sigma_max_[j]) { - new_sigma[j] = 2.0 * sigma_max_[j] - new_sigma[j]; - } - if(new_sigma[j] < sigma_min_[j]) { - new_sigma[j] = 2.0 * sigma_min_[j] - new_sigma[j]; - } + if(new_sigma[j] > sigma_max_[j]) {new_sigma[j] = 2.0 * sigma_max_[j] - new_sigma[j];} + if(new_sigma[j] < sigma_min_[j]) {new_sigma[j] = 2.0 * sigma_min_[j] - new_sigma[j];} } } @@ -1192,7 +1026,8 @@ void MetainferenceBase::moveSigmas(const std::vector &mean_, double &old } } -double MetainferenceBase::doMonteCarlo(const std::vector &mean_) { +double MetainferenceBase::doMonteCarlo(const std::vector &mean_) +{ // calculate old energy with the updated coordinates double old_energy=0.; @@ -1231,19 +1066,13 @@ double MetainferenceBase::doMonteCarlo(const std::vector &mean_) { for(unsigned i=0; i &mean_) { if(noise_type_==GENERIC) { double accept = static_cast(MCacceptFT_) / static_cast(MCtrial_); valueAcceptFT->set(accept); - for(unsigned i=0; iset(ftilde_[i]); - } + for(unsigned i=0; iset(ftilde_[i]); } /* scale and offset */ - if(doscale_ || doregres_zero_) { - valueScale->set(scale_); - } - if(dooffset_) { - valueOffset->set(offset_); - } + if(doscale_ || doregres_zero_) valueScale->set(scale_); + if(dooffset_) valueOffset->set(offset_); if(doscale_||dooffset_) { double accept = static_cast(MCacceptScale_) / static_cast(MCtrial_); valueAcceptScale->set(accept); } /* sigmas */ - for(unsigned i=0; iset(sigma_[i]); - } + for(unsigned i=0; iset(sigma_[i]); double accept = static_cast(MCaccept_) / static_cast(MCtrial_); valueAccept->set(accept); } // here we sum the score over the replicas to get the full metainference score that we save as a bias if(master) { - if(nrep_>1) { - multi_sim_comm.Sum(old_energy); - } + if(nrep_>1) multi_sim_comm.Sum(old_energy); } else { old_energy=0; } @@ -1295,7 +1114,8 @@ double MetainferenceBase::doMonteCarlo(const std::vector &mean_) { */ void MetainferenceBase::getEnergyForceSP(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; const double sm2 = sigma_mean2_[0]; const double ss2 = sigma_[0]*sigma_[0] + scale2*sm2; @@ -1313,15 +1133,14 @@ void MetainferenceBase::getEnergyForceSP(const std::vector &mean, const const double dt = 1./t; const double dit = 1./(1.-dt); f[i] = -scale_*dev*(dit/sm2 + 1./a2); - } else { + } + else { f[i] = -scale_*dev*(1./a2); } } } // collect contribution to forces and energy from other replicas - if(nrep_>1) { - multi_sim_comm.Sum(&f[0],narg); - } + if(nrep_>1) multi_sim_comm.Sum(&f[0],narg); } // intra-replica summation comm.Sum(&f[0],narg); @@ -1339,7 +1158,8 @@ void MetainferenceBase::getEnergyForceSP(const std::vector &mean, const } void MetainferenceBase::getEnergyForceSPE(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; std::vector f(narg,0); @@ -1357,15 +1177,14 @@ void MetainferenceBase::getEnergyForceSPE(const std::vector &mean, const const double dt = 1./t; const double dit = 1./(1.-dt); f[i] = -scale_*dev*(dit/sm2 + 1./a2); - } else { + } + else { f[i] = -scale_*dev*(1./a2); } } } // collect contribution to forces and energy from other replicas - if(nrep_>1) { - multi_sim_comm.Sum(&f[0],narg); - } + if(nrep_>1) multi_sim_comm.Sum(&f[0],narg); } comm.Sum(&f[0],narg); @@ -1382,15 +1201,14 @@ void MetainferenceBase::getEnergyForceSPE(const std::vector &mean, const } void MetainferenceBase::getEnergyForceGJ(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; double inv_s2=0.; if(master) { inv_s2 = 1./(sigma_[0]*sigma_[0] + scale2*sigma_mean2_[0]); - if(nrep_>1) { - multi_sim_comm.Sum(inv_s2); - } + if(nrep_>1) multi_sim_comm.Sum(inv_s2); } comm.Sum(inv_s2); @@ -1413,17 +1231,14 @@ void MetainferenceBase::getEnergyForceGJ(const std::vector &mean, const } void MetainferenceBase::getEnergyForceGJE(const std::vector &mean, const std::vector &dmean_x, - const std::vector &dmean_b) { + const std::vector &dmean_b) +{ const double scale2 = scale_*scale_; std::vector inv_s2(sigma_.size(),0.); if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&inv_s2[0],sigma_.size()); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&inv_s2[0],sigma_.size()); } comm.Sum(&inv_s2[0],sigma_.size()); @@ -1445,7 +1260,8 @@ void MetainferenceBase::getEnergyForceGJE(const std::vector &mean, const } } -void MetainferenceBase::getEnergyForceMIGEN(const std::vector &mean, const std::vector &dmean_x, const std::vector &dmean_b) { +void MetainferenceBase::getEnergyForceMIGEN(const std::vector &mean, const std::vector &dmean_x, const std::vector &dmean_b) +{ std::vector inv_s2(sigma_.size(),0.); std::vector dev(sigma_.size(),0.); std::vector dev2(sigma_.size(),0.); @@ -1481,16 +1297,15 @@ void MetainferenceBase::getEnergyForceMIGEN(const std::vector &mean, con } } -void MetainferenceBase::get_weights(double &weight, double &norm, double &neff) { +void MetainferenceBase::get_weights(double &weight, double &norm, double &neff) +{ const double dnrep = static_cast(nrep_); // calculate the weights either from BIAS if(do_reweight_) { std::vector bias(nrep_,0); if(master) { bias[replica_] = getArgument(0); - if(nrep_>1) { - multi_sim_comm.Sum(&bias[0], nrep_); - } + if(nrep_>1) multi_sim_comm.Sum(&bias[0], nrep_); } comm.Sum(&bias[0], nrep_); @@ -1502,16 +1317,12 @@ void MetainferenceBase::get_weights(double &weight, double &norm, double &neff) } } else { firstTimeW[iselect] = false; - for(unsigned i=0; iset(neff); } -void MetainferenceBase::get_sigma_mean(const double weight, const double norm, const double neff, const std::vector &mean) { +void MetainferenceBase::get_sigma_mean(const double weight, const double norm, const double neff, const std::vector &mean) +{ const double dnrep = static_cast(nrep_); std::vector sigma_mean2_tmp(sigma_mean2_.size()); if(do_optsigmamean_>0) { // remove first entry of the history std::vector if(sigma_mean2_last_[iselect][0].size()==optsigmamean_stride_&&optsigmamean_stride_>0) - for(unsigned i=0; i sigma_mean2_now(narg,0); if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&sigma_mean2_now[0], narg); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&sigma_mean2_now[0], narg); } comm.Sum(&sigma_mean2_now[0], narg); - for(unsigned i=0; i0) { - for(unsigned i=0; i sigma_mean2_last_[iselect][i][0]) { - sigma_mean2_last_[iselect][i][0] = sigma_mean2_now[i]; - } + for(unsigned i=0; i sigma_mean2_last_[iselect][i][0]) sigma_mean2_last_[iselect][i][0] = sigma_mean2_now[i]; } if(noise_type_==MGAUSS||noise_type_==MOUTLIERS||noise_type_==GENERIC) { @@ -1577,17 +1376,13 @@ void MetainferenceBase::get_sigma_mean(const double weight, const double norm, c valueSigmaMean[i]->set(std::sqrt(sigma_mean2_tmp[i])); if(noise_type_==GENERIC) { sigma_min_[i] = std::sqrt(sigma_mean2_tmp[i]); - if(sigma_[i] < sigma_min_[i]) { - sigma_[i] = sigma_min_[i]; - } + if(sigma_[i] < sigma_min_[i]) sigma_[i] = sigma_min_[i]; } } } else if(noise_type_==GAUSS||noise_type_==OUTLIERS) { // find maximum for each data point std::vector max_values; - for(unsigned i=0; i1&&!sigmamax_opt_done_) { for(unsigned i=0; ioptsigmamean_stride_) { - sigma_max_est_[i]=sigma_mean2_tmp[i]; - } + if(sigma_max_est_[i]optsigmamean_stride_) sigma_max_est_[i]=sigma_mean2_tmp[i]; // ready to set once and for all the value of sigma_max if(optimized_step_==N_optimized_step_) { sigmamax_opt_done_=true; for(unsigned i=0; isigma_max_[i]) { - sigma_[i]=sigma_max_[i]; - } + if(sigma_[i]>sigma_max_[i]) sigma_[i]=sigma_max_[i]; } } } @@ -1631,29 +1422,22 @@ void MetainferenceBase::get_sigma_mean(const double weight, const double norm, c sigma_mean2_ = sigma_mean2_tmp; } -void MetainferenceBase::replica_averaging(const double weight, const double norm, std::vector &mean, std::vector &dmean_b) { +void MetainferenceBase::replica_averaging(const double weight, const double norm, std::vector &mean, std::vector &dmean_b) +{ if(master) { - for(unsigned i=0; i1) { - multi_sim_comm.Sum(&mean[0], narg); - } + for(unsigned i=0; i1) multi_sim_comm.Sum(&mean[0], narg); } comm.Sum(&mean[0], narg); // set the derivative of the mean with respect to the bias - for(unsigned i=0; i &mean) { +void MetainferenceBase::do_regression_zero(const std::vector &mean) +{ // parameters[i] = scale_ * mean[i]: find scale_ with linear regression double num = 0.0; double den = 0.0; @@ -1668,7 +1452,8 @@ void MetainferenceBase::do_regression_zero(const std::vector &mean) { } } -double MetainferenceBase::getScore() { +double MetainferenceBase::getScore() +{ /* Metainference */ /* 1) collect weights */ double weight = 0.; @@ -1689,9 +1474,7 @@ double MetainferenceBase::getScore() { get_sigma_mean(weight, norm, neff, mean); // in case of regression with zero intercept, calculate scale - if(doregres_zero_ && getStep()%nregres_zero_==0) { - do_regression_zero(mean); - } + if(doregres_zero_ && getStep()%nregres_zero_==0) do_regression_zero(mean); /* 4) run monte carlo */ double ene = doMonteCarlo(mean); @@ -1718,10 +1501,9 @@ double MetainferenceBase::getScore() { return ene; } -void MetainferenceBase::writeStatus() { - if(!doscore_) { - return; - } +void MetainferenceBase::writeStatus() +{ + if(!doscore_) return; sfile_.rewind(); sfile_.printField("time",getTimeStep()*getStep()); //nsel diff --git a/src/isdb/MetainferenceBase.h b/src/isdb/MetainferenceBase.h index 0ad5689492..f5cdee85b1 100644 --- a/src/isdb/MetainferenceBase.h +++ b/src/isdb/MetainferenceBase.h @@ -43,7 +43,8 @@ information as to how to go about implementing a new Metainference action. class MetainferenceBase : public ActionAtomistic, public ActionWithArguments, - public ActionWithValue { + public ActionWithValue +{ private: std::vector forces; std::vector forcesToApply; @@ -207,57 +208,62 @@ class MetainferenceBase : }; inline -void MetainferenceBase::setNarg(const unsigned input) { +void MetainferenceBase::setNarg(const unsigned input) +{ narg = input; } inline -bool MetainferenceBase::getDoScore() { +bool MetainferenceBase::getDoScore() +{ return doscore_; } inline -unsigned MetainferenceBase::getWstride() { +unsigned MetainferenceBase::getWstride() +{ return write_stride_; } inline -unsigned MetainferenceBase::getNarg() { +unsigned MetainferenceBase::getNarg() +{ return narg; } inline -void MetainferenceBase::setMetaDer(const unsigned index, const double der) { +void MetainferenceBase::setMetaDer(const unsigned index, const double der) +{ metader_[index] = der; } inline -double MetainferenceBase::getMetaDer(const unsigned index) { +double MetainferenceBase::getMetaDer(const unsigned index) +{ return metader_[index]; } inline -double MetainferenceBase::getCalcData(const unsigned index) { +double MetainferenceBase::getCalcData(const unsigned index) +{ return calc_data_[index]; } inline -void MetainferenceBase::setCalcData(const unsigned index, const double datum) { +void MetainferenceBase::setCalcData(const unsigned index, const double datum) +{ calc_data_[index] = datum; } inline -void MetainferenceBase::setCalcData(const std::vector& data) { - for(unsigned i=0; i& data) +{ + for(unsigned i=0; i& input) { - for(unsigned i=0; iresizeDerivatives(nder); - } + forces.resize( nder ); forcesToApply.resize( nder ); + for(int i=0; iresizeDerivatives(nder); } inline @@ -322,38 +325,27 @@ void MetainferenceBase::calculateNumericalDerivatives( ActionWithValue* a=NULL ) if( getNumberOfAtoms()>0 ) { Matrix save_derivatives( getNumberOfComponents(), getNumberOfArguments() ); for(int j=0; jhasDerivatives()) { - save_derivatives(j,i)=getPntrToComponent(j)->getDerivative(i); - } + for(unsigned i=0; ihasDerivatives()) save_derivatives(j,i)=getPntrToComponent(j)->getDerivative(i); } calculateAtomicNumericalDerivatives( a, getNumberOfArguments() ); for(int j=0; jhasDerivatives()) { - getPntrToComponent(j)->addDerivative( i, save_derivatives(j,i) ); - } + for(unsigned i=0; ihasDerivatives()) getPntrToComponent(j)->addDerivative( i, save_derivatives(j,i) ); } } } inline void MetainferenceBase::apply() { - bool wasforced=false; - forcesToApply.assign(forcesToApply.size(),0.0); + bool wasforced=false; forcesToApply.assign(forcesToApply.size(),0.0); for(int i=0; iapplyForce( forces ) ) { wasforced=true; - for(unsigned i=0; i0 ) { - setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); - } + if( getNumberOfAtoms()>0 ) setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); } } diff --git a/src/isdb/NOE.cpp b/src/isdb/NOE.cpp index fcb30ab1d2..cd86ed37f6 100644 --- a/src/isdb/NOE.cpp +++ b/src/isdb/NOE.cpp @@ -65,7 +65,8 @@ PRINT ARG=noes.* FILE=colvar //+ENDPLUMEDOC class NOE : - public MetainferenceBase { + public MetainferenceBase +{ private: bool pbc; std::vector nga; @@ -99,7 +100,8 @@ void NOE::registerKeywords( Keywords& keys ) { NOE::NOE(const ActionOptions&ao): PLUMED_METAINF_INIT(ao), - pbc(true) { + pbc(true) +{ bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; @@ -108,33 +110,21 @@ NOE::NOE(const ActionOptions&ao): std::vector t, ga_lista, gb_lista; for(int i=1;; ++i ) { parseAtomList("GROUPA", i, t ); - if( t.empty() ) { - break; - } - for(unsigned j=0; j ngb; for(int i=1;; ++i ) { parseAtomList("GROUPB", i, t ); - if( t.empty() ) { - break; - } - for(unsigned j=0; j(ga_lista,gb_lista,false,true,pbc,getPbc(),comm); @@ -143,21 +133,13 @@ NOE::NOE(const ActionOptions&ao): noedist.resize( nga.size() ); unsigned ntarget=0; for(unsigned i=0; i deriv(tot_size, Vector{0,0,0}); @@ -230,11 +206,8 @@ void NOE::calculate() { Tensor dervir; double noe=0; unsigned index=0; - for(unsigned k=0; kgetClosePair(index+j).second; Vector distance; - if(pbc) { - distance=pbcDistance(getPosition(i0),getPosition(i1)); - } else { - distance=delta(getPosition(i0),getPosition(i1)); - } + if(pbc) distance=pbcDistance(getPosition(i0),getPosition(i1)); + else distance=delta(getPosition(i0),getPosition(i1)); const double ir2=1./distance.modulo2(); const double ir6=ir2*ir2*ir2; @@ -263,9 +233,7 @@ void NOE::calculate() { val->set(noe); if(!getDoScore()) { setBoxDerivatives(val, dervir); - } else { - setCalcData(i, noe); - } + } else setCalcData(i, noe); } if(getDoScore()) { @@ -278,20 +246,15 @@ void NOE::calculate() { Value* val=getPntrToComponent("score"); for(unsigned i=0; igetClosePair(index+j).first; const unsigned i1=nl->getClosePair(index+j).second; Vector distance; - if(pbc) { - distance=pbcDistance(getPosition(i0),getPosition(i1)); - } else { - distance=delta(getPosition(i0),getPosition(i1)); - } + if(pbc) distance=pbcDistance(getPosition(i0),getPosition(i1)); + else distance=delta(getPosition(i0),getPosition(i1)); dervir += Tensor(distance,deriv[index+j]*getMetaDer(i)); setAtomsDerivatives(val, i0, deriv[index+j]*getMetaDer(i)); @@ -304,9 +267,7 @@ void NOE::calculate() { void NOE::update() { // write status file - if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) { - writeStatus(); - } + if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) writeStatus(); } } diff --git a/src/isdb/PRE.cpp b/src/isdb/PRE.cpp index f241d6f390..860cc21b2b 100644 --- a/src/isdb/PRE.cpp +++ b/src/isdb/PRE.cpp @@ -68,7 +68,8 @@ PRINT ARG=HN_pre.* FILE=PRE.dat STRIDE=1 //+ENDPLUMEDOC class PRE : - public MetainferenceBase { + public MetainferenceBase +{ private: bool pbc; bool doratio; @@ -110,7 +111,8 @@ void PRE::registerKeywords( Keywords& keys ) { PRE::PRE(const ActionOptions&ao): PLUMED_METAINF_INIT(ao), pbc(true), - doratio(true) { + doratio(true) +{ bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; @@ -121,21 +123,14 @@ PRE::PRE(const ActionOptions&ao): std::vector atom; parseAtomList("SPINLABEL",atom); - if(atom.size()!=1) { - error("Number of specified atom should be 1"); - } + if(atom.size()!=1) error("Number of specified atom should be 1"); // Read in the atoms std::vector t, ga_lista, gb_lista; for(int i=1;; ++i ) { parseAtomList("GROUPA", i, t ); - if( t.empty() ) { - break; - } - for(unsigned j=0; j(gb_lista,ga_lista,false,true,pbc,getPbc(),comm); @@ -227,25 +202,20 @@ PRE::PRE(const ActionOptions&ao): } tot_size = index; - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); log << " Bibliography" << plumed.cite("Bonomi, Camilloni, Bioinformatics, 33, 3999 (2017)") << "\n"; if(!getDoScore()) { for(unsigned i=0; i deriv(tot_size, Vector{0,0,0}); std::vector fact(nga.size(), 0.); @@ -288,12 +257,9 @@ void PRE::calculate() { Tensor dervir; double pre=0; unsigned index=0; - for(unsigned k=0; k(nga[i]); - std::string num; - Tools::convert(i,num); + std::string num; Tools::convert(i,num); Value* val=getPntrToComponent("pre-"+num); // cycle over equivalent atoms for(unsigned j=0; jgetClosePair(index+j).second; Vector distance; - if(pbc) { - distance=pbcDistance(getPosition(i0),getPosition(i1)); - } else { - distance=delta(getPosition(i0),getPosition(i1)); - } + if(pbc) distance=pbcDistance(getPosition(i0),getPosition(i1)); + else distance=delta(getPosition(i0),getPosition(i1)); const double r2=distance.modulo2(); const double r6=r2*r2*r2; @@ -316,9 +279,7 @@ void PRE::calculate() { pre += tmpir6; deriv[index+j] = -tmpir8*distance; - if(!getDoScore()) { - dervir += Tensor(distance,deriv[index+j]); - } + if(!getDoScore()) dervir += Tensor(distance,deriv[index+j]); } double tmpratio; if(!doratio) { @@ -338,9 +299,7 @@ void PRE::calculate() { setAtomsDerivatives(val, i0, fact[i]*deriv[index+j]); setAtomsDerivatives(val, i1, -fact[i]*deriv[index+j]); } - } else { - setCalcData(i, ratio); - } + } else setCalcData(i, ratio); } if(getDoScore()) { @@ -353,20 +312,15 @@ void PRE::calculate() { Value* val=getPntrToComponent("score"); for(unsigned i=0; igetClosePair(index+j).first; const unsigned i1=nl->getClosePair(index+j).second; Vector distance; - if(pbc) { - distance=pbcDistance(getPosition(i0),getPosition(i1)); - } else { - distance=delta(getPosition(i0),getPosition(i1)); - } + if(pbc) distance=pbcDistance(getPosition(i0),getPosition(i1)); + else distance=delta(getPosition(i0),getPosition(i1)); dervir += Tensor(distance,fact[i]*deriv[index+j]*getMetaDer(i)); setAtomsDerivatives(val, i0, fact[i]*deriv[index+j]*getMetaDer(i)); @@ -379,9 +333,7 @@ void PRE::calculate() { void PRE::update() { // write status file - if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) { - writeStatus(); - } + if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) writeStatus(); } } diff --git a/src/isdb/RDC.cpp b/src/isdb/RDC.cpp index 5702a6b3f2..7c4deae748 100644 --- a/src/isdb/RDC.cpp +++ b/src/isdb/RDC.cpp @@ -172,7 +172,8 @@ PRINT ARG=st.corr,pcse.bias FILE=colvar //+ENDPLUMEDOC class RDC : - public MetainferenceBase { + public MetainferenceBase +{ private: double Const; double mu_s; @@ -246,7 +247,8 @@ RDC::RDC(const ActionOptions&ao): Const(1.), mu_s(1.), scale(1.), - pbc(true) { + pbc(true) +{ bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; @@ -254,22 +256,16 @@ RDC::RDC(const ActionOptions&ao): const double RDCConst = 0.3356806; const double PCSConst = 1.0; - if( getName().find("RDC")!=std::string::npos) { - Const *= RDCConst; - } else if( getName().find("PCS")!=std::string::npos) { - Const *= PCSConst; - } + if( getName().find("RDC")!=std::string::npos) { Const *= RDCConst; } + else if( getName().find("PCS")!=std::string::npos) { Const *= PCSConst; } // Read in the atoms std::vector t, atoms; for(int i=1;; ++i ) { parseAtomList("ATOMS", i, t ); - if( t.empty() ) { - break; - } + if( t.empty() ) break; if( t.size()!=2 ) { - std::string ss; - Tools::convert(i,ss); + std::string ss; Tools::convert(i,ss); error("ATOMS" + ss + " keyword has the wrong number of atoms"); } atoms.push_back(t[0]); @@ -281,58 +277,38 @@ RDC::RDC(const ActionOptions&ao): // Read in GYROMAGNETIC constants parse("GYROM", mu_s); - if(mu_s==0.) { - error("GYROM cannot be 0"); - } + if(mu_s==0.) error("GYROM cannot be 0"); // Read in SCALING factors parse("SCALE", scale); - if(scale==0.) { - error("SCALE cannot be 0"); - } + if(scale==0.) error("SCALE cannot be 0"); svd=false; parseFlag("SVD",svd); #ifndef __PLUMED_HAS_GSL - if(svd) { - error("You CANNOT use SVD without GSL. Recompile PLUMED with GSL!\n"); - } + if(svd) error("You CANNOT use SVD without GSL. Recompile PLUMED with GSL!\n"); #endif - if(svd&&getDoScore()) { - error("It is not possible to use SVD and METAINFERENCE together"); - } + if(svd&&getDoScore()) error("It is not possible to use SVD and METAINFERENCE together"); // Optionally add an experimental value coupl.resize( ndata ); unsigned ntarget=0; for(unsigned i=0; i dmax(coupl.size()); for(unsigned r=0; rset(rdc); if(!getDoScore()) { setBoxDerivatives(val, Tensor(distance,dRDC[index])); setAtomsDerivatives(val, r, dRDC[index]); setAtomsDerivatives(val, r+1, -dRDC[index]); - } else { - setCalcData(index, rdc); - } + } else setCalcData(index, rdc); } } @@ -537,14 +497,12 @@ void RDC::calculate() { /* calculate final derivatives */ Value* val=getPntrToComponent("score"); - for(unsigned r=0; r0&& (getStep()%getWstride()==0 || getCPT()) ) { - writeStatus(); - } + if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) writeStatus(); } } diff --git a/src/isdb/Rescale.cpp b/src/isdb/Rescale.cpp index c38090a883..e0bfb09c7c 100644 --- a/src/isdb/Rescale.cpp +++ b/src/isdb/Rescale.cpp @@ -114,7 +114,8 @@ PRINT FILE=COLVAR ARG=* STRIDE=100 */ //+ENDPLUMEDOC -class Rescale : public bias::Bias { +class Rescale : public bias::Bias +{ // gamma parameter std::vector gamma_; double w0_; @@ -185,7 +186,8 @@ void Rescale::registerKeywords(Keywords& keys) { Rescale::Rescale(const ActionOptions&ao): PLUMED_BIAS_INIT(ao), nores_(0), Biaspace_(1), first_bias_(true), - MCsteps_(1), MCstride_(1), MCfirst_(-1), MCaccgamma_(0) { + MCsteps_(1), MCstride_(1), MCfirst_(-1), MCaccgamma_(0) +{ // set up replica stuff if(comm.Get_rank()==0) { nrep_ = multi_sim_comm.Get_size(); @@ -210,23 +212,19 @@ Rescale::Rescale(const ActionOptions&ao): // number of bias parse("NOT_RESCALED", nores_); - if(nores_>0 && nores_!=nbin) { - error("The number of non scaled arguments must be equal to either 0 or the number of bins"); - } + if(nores_>0 && nores_!=nbin) error("The number of non scaled arguments must be equal to either 0 or the number of bins"); // maximum value of rescale std::vector max_rescale; parseVector("MAX_RESCALE", max_rescale); // check dimension of max_rescale - if(max_rescale.size()!=(getNumberOfArguments()-nores_)) { + if(max_rescale.size()!=(getNumberOfArguments()-nores_)) error("Size of MAX_RESCALE array must be equal to the number of arguments that will to be scaled"); - } // calculate exponents double igamma_max = static_cast(nbin); - for(unsigned i=0; i not_shared; parseVector("NOT_SHARED", not_shared); // and change the non-shared for(unsigned i=0; i=(getNumberOfArguments()-nores_) && nrep_>1) { + if((not_shared[i]-1)>=(getNumberOfArguments()-nores_) && nrep_>1) error("NOT_RESCALED args must always be shared when using multiple replicas"); - } - if((not_shared[i]-1)>=getNumberOfArguments()) { + if((not_shared[i]-1)>=getNumberOfArguments()) error("NOT_SHARED args should be lower than total number of arguments"); - } shared_[not_shared[i]-1] = 0; } @@ -272,11 +266,8 @@ Rescale::Rescale(const ActionOptions&ao): // get temperature double temp=0.0; parse("TEMP",temp); - if(temp>0.0) { - kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { - kbt_=plumed.getAtoms().getKbT(); - } + if(temp>0.0) kbt_=plumed.getAtoms().getKBoltzmann()*temp; + else kbt_=plumed.getAtoms().getKbT(); checkRead(); @@ -284,9 +275,7 @@ Rescale::Rescale(const ActionOptions&ao): log.printf(" name of the SELECTOR use for this action %s\n",selector_.c_str()); log.printf(" number of bins in grid %u\n",nbin); log.printf(" number of arguments that will not be scaled %u\n",nores_); - if(nrep_>1) { - log<<" number of arguments that will not be summed across replicas "<1) log<<" number of arguments that will not be summed across replicas "<(); ifile->link(*this); @@ -347,29 +333,24 @@ void Rescale::read_bias() { } } -unsigned Rescale::proposeMove(unsigned x, unsigned xmin, unsigned xmax) { +unsigned Rescale::proposeMove(unsigned x, unsigned xmin, unsigned xmax) +{ int xmin_i = static_cast(xmin); int xmax_i = static_cast(xmax); int dx; int r = rand() % 2; - if( r % 2 == 0 ) { - dx = +1; - } else { - dx = -1; - } + if( r % 2 == 0 ) dx = +1; + else dx = -1; // new index, integer int x_new = static_cast(x) + dx; // check boundaries - if(x_new >= xmax_i) { - x_new = xmax_i-1; - } - if(x_new < xmin_i) { - x_new = xmin_i; - } + if(x_new >= xmax_i) x_new = xmax_i-1; + if(x_new < xmin_i) x_new = xmin_i; return static_cast(x_new); } -bool Rescale::doAccept(double oldE, double newE) { +bool Rescale::doAccept(double oldE, double newE) +{ bool accept = false; // calculate delta energy double delta = ( newE - oldE ) / kbt_; @@ -379,15 +360,14 @@ bool Rescale::doAccept(double oldE, double newE) { } else { // otherwise extract random number double s = static_cast(rand()) / RAND_MAX; - if( s < std::exp(-delta) ) { - accept = true; - } + if( s < std::exp(-delta) ) { accept = true; } } return accept; } void Rescale::doMonteCarlo(unsigned igamma, double oldE, - std::vector args, std::vector bargs) { + std::vector args, std::vector bargs) +{ double oldB, newB; // cycle on MC steps @@ -419,9 +399,7 @@ void Rescale::doMonteCarlo(unsigned igamma, double oldE, } // send values of gamma to all replicas if(comm.Get_rank()==0) { - if(multi_sim_comm.Get_rank()!=0) { - igamma = 0; - } + if(multi_sim_comm.Get_rank()!=0) igamma = 0; multi_sim_comm.Sum(&igamma, 1); } else { igamma = 0; @@ -433,7 +411,8 @@ void Rescale::doMonteCarlo(unsigned igamma, double oldE, plumed.passMap[selector_]=static_cast(igamma); } -void Rescale::print_bias(long long int step) { +void Rescale::print_bias(long long int step) +{ // if first time open the file if(first_bias_) { first_bias_ = false; @@ -458,7 +437,8 @@ void Rescale::print_bias(long long int step) { Biasfile_.printField(); } -void Rescale::calculate() { +void Rescale::calculate() +{ // get the current value of the selector unsigned igamma = static_cast(plumed.passMap[selector_]); @@ -469,14 +449,9 @@ void Rescale::calculate() { double arg = getArgument(i); // sum shared arguments across replicas if(shared_[i]==1) { - if(comm.Get_rank()==0) { - multi_sim_comm.Sum(arg); - } else { - arg = 0.0; - } - if(comm.Get_size()>1) { - comm.Sum(arg); - } + if(comm.Get_rank()==0) multi_sim_comm.Sum(arg); + else arg = 0.0; + if(comm.Get_size()>1) comm.Sum(arg); } // put into all_args all_args[i] = arg; @@ -484,20 +459,12 @@ void Rescale::calculate() { // now separate terms that should be rescaled std::vector args; - if(getNumberOfArguments()-nores_>0) { - args.resize(getNumberOfArguments()-nores_); - } - for(unsigned i=0; i0) args.resize(getNumberOfArguments()-nores_); + for(unsigned i=0; i bargs; - if(nores_>0) { - bargs.resize(nores_); - } - for(unsigned i=0; i0) bargs.resize(nores_); + for(unsigned i=0; iset(igamma); // get time step long long int step = getStep(); - if(MCfirst_==-1) { - MCfirst_=step; - } + if(MCfirst_==-1) MCfirst_=step; // calculate gamma acceptance double MCtrials = std::floor(static_cast(step-MCfirst_) / static_cast(MCstride_))+1.0; double accgamma = static_cast(MCaccgamma_) / static_cast(MCsteps_) / MCtrials; getPntrToComponent("accgamma")->set(accgamma); // do MC at the right time step - if(step%MCstride_==0&&!getExchangeStep()) { - doMonteCarlo(igamma, ene, args, bargs); - } + if(step%MCstride_==0&&!getExchangeStep()) doMonteCarlo(igamma, ene, args, bargs); // add well-tempered like bias if(step%Biaspace_==0) { @@ -545,9 +506,7 @@ void Rescale::calculate() { } // print bias - if(step%Biasstride_==0) { - print_bias(step); - } + if(step%Biasstride_==0) print_bias(step); } diff --git a/src/isdb/SAXS.cpp b/src/isdb/SAXS.cpp index 9894987f2b..2664474653 100644 --- a/src/isdb/SAXS.cpp +++ b/src/isdb/SAXS.cpp @@ -223,7 +223,8 @@ PRINT ARG=(SANS\.q-.*),(SANS\.exp-.*) FILE=sansdata STRIDE=1 //+ENDPLUMEDOC class SAXS : - public MetainferenceBase { + public MetainferenceBase +{ private: enum { H, C, N, O, P, S, NTT }; enum { ALA_BB, ARG_BB, ARG_SC1, ARG_SC2, ASN_BB, ASN_SC1, ASP_BB, ASP_SC1, CYS_BB, CYS_SC1, @@ -348,12 +349,10 @@ SAXS::SAXS(const ActionOptions&ao): gpu(false), onebead(false), isFirstStep(true), - deviceid(-1) { - if( getName().find("SAXS")!=std::string::npos) { - saxs=true; - } else if( getName().find("SANS")!=std::string::npos) { - saxs=false; - } + deviceid(-1) +{ + if( getName().find("SAXS")!=std::string::npos) { saxs=true; } + else if( getName().find("SANS")!=std::string::npos) { saxs=false; } std::vector atoms; parseAtomList("ATOMS",atoms); @@ -364,30 +363,21 @@ SAXS::SAXS(const ActionOptions&ao): bool nopbc=!pbc; parseFlag("NOPBC",nopbc); pbc=!nopbc; - if(pbc) { - log.printf(" using periodic boundary conditions\n"); - } else { - log.printf(" without periodic boundary conditions\n"); - } + if(pbc) log.printf(" using periodic boundary conditions\n"); + else log.printf(" without periodic boundary conditions\n"); parseFlag("GPU",gpu); #ifndef __PLUMED_HAS_ARRAYFIRE - if(gpu) { - error("To use the GPU mode PLUMED must be compiled with ARRAYFIRE"); - } + if(gpu) error("To use the GPU mode PLUMED must be compiled with ARRAYFIRE"); #endif parse("DEVICEID",deviceid); #ifdef __PLUMED_HAS_ARRAYFIRE if(gpu&&comm.Get_rank()==0) { // if not set try to check the one set by the API - if(deviceid==-1) { - deviceid=plumed.getGpuDeviceId(); - } + if(deviceid==-1) deviceid=plumed.getGpuDeviceId(); // if still not set use 0 - if(deviceid==-1) { - deviceid=0; - } + if(deviceid==-1) deviceid=0; #ifdef __PLUMED_HAS_ARRAYFIRE_CUDA af::setDevice(afcu::getNativeId(deviceid)); #elif __PLUMED_HAS_ARRAYFIRE_OCL @@ -401,60 +391,34 @@ SAXS::SAXS(const ActionOptions&ao): bool atomistic=false; parseFlag("ATOMISTIC",atomistic); - if(atomistic) { - log.printf(" using ATOMISTIC form factors\n"); - } + if(atomistic) log.printf(" using ATOMISTIC form factors\n"); bool martini=false; parseFlag("MARTINI",martini); - if(martini) { - log.printf(" using MARTINI form factors\n"); - } + if(martini) log.printf(" using MARTINI form factors\n"); onebead=false; parseFlag("ONEBEAD",onebead); - if(onebead) { - log.printf(" using ONEBEAD form factors\n"); - } + if(onebead) log.printf(" using ONEBEAD form factors\n"); - if(martini&&atomistic) { - error("You cannot use MARTINI and ATOMISTIC at the same time"); - } - if(martini&&onebead) { - error("You cannot use MARTINI and ONEBEAD at the same time"); - } - if(onebead&&atomistic) { - error("You cannot use ONEBEAD and ATOMISTIC at the same time"); - } - if((martini)&&(!saxs)) { - error("MARTINI cannot be used with SANS"); - } - if((!atomistic)&&(!martini)&&(!onebead)&&(!saxs)) { - error("External PARAMETERS cannot be used with SANS"); - } + if(martini&&atomistic) error("You cannot use MARTINI and ATOMISTIC at the same time"); + if(martini&&onebead) error("You cannot use MARTINI and ONEBEAD at the same time"); + if(onebead&&atomistic) error("You cannot use ONEBEAD and ATOMISTIC at the same time"); + if((martini)&&(!saxs)) error("MARTINI cannot be used with SANS"); + if((!atomistic)&&(!martini)&&(!onebead)&&(!saxs)) error("External PARAMETERS cannot be used with SANS"); unsigned ntarget=0; for(unsigned i=0;; ++i) { double t_list; - if( !parseNumbered( "QVALUE", i+1, t_list) ) { - break; - } - if(t_list<=0.) { - error("QVALUE cannot be less or equal to zero!\n"); - } - if(onebead&&t_list>0.3) { - error("ONEBEAD mapping QVALUE must be smaller or equal to 0.3"); - } + if( !parseNumbered( "QVALUE", i+1, t_list) ) break; + if(t_list<=0.) error("QVALUE cannot be less or equal to zero!\n"); + if(onebead&&t_list>0.3) error("ONEBEAD mapping QVALUE must be smaller or equal to 0.3"); q_list.push_back(t_list); ntarget++; } const unsigned numq = ntarget; for(unsigned i=0; i0&&q_list[i]0&&q_list[i] 1.) { - error("DEUTER_CONC must be in 0-1 range"); - } - if ((atomistic||onebead)&&(!saxs)) { - log.printf(" Solvent deuterium fraction: %lf/1.000000\n", deuter_conc); - } + if(deuter_conc < 0. || deuter_conc > 1.) error("DEUTER_CONC must be in 0-1 range"); + if ((atomistic||onebead)&&(!saxs)) log.printf(" Solvent deuterium fraction: %lf/1.000000\n", deuter_conc); PDB pdb; if(onebead) { std::string template_name; parse("TEMPLATE",template_name); log.printf(" Template for ONEBEAD mapping conversion: %s\n", template_name.c_str()); - if( !pdb.read(template_name,plumed.getAtoms().usingNaturalUnits(),1.) ) { - plumed_merror("missing input file " + template_name); - } + if( !pdb.read(template_name,plumed.getAtoms().usingNaturalUnits(),1.) ) plumed_merror("missing input file " + template_name); } // Here we perform the preliminary mapping for onebead representation @@ -549,14 +497,10 @@ SAXS::SAXS(const ActionOptions&ao): parameter.resize(size); ntarget=0; for(unsigned i=0; i(size)); for(unsigned i=0; i(NTT)); - if(saxs) { - Iq0=calculateAFF(atoms, FF_tmp, rho); - } else { - Iq0=calculateAFFsans(atoms, FF_tmp, deuter_conc); - } + if(saxs) Iq0=calculateAFF(atoms, FF_tmp, rho); + else Iq0=calculateAFFsans(atoms, FF_tmp, deuter_conc); Iq0 *= Iq0; } @@ -665,24 +602,14 @@ SAXS::SAXS(const ActionOptions&ao): expint.resize( numq ); ntarget=0; for(unsigned i=0; i(FF_tmp[k][atoi[i]])/(std::sqrt(Iq0)); - } - for(unsigned i=0; i(FF_tmp[k][atoi[i]])/(std::sqrt(Iq0)); + for(unsigned i=0; i > &Nlist) { +void SAXS::calcNlist(std::vector > &Nlist) +{ unsigned natoms = getNumberOfAtoms(); for(unsigned i = 0; i < natoms; ++i) { if (LCPOparam[i].size()>0) { @@ -856,7 +776,8 @@ void SAXS::calcNlist(std::vector > &Nlist) { } // calculates SASA according to LCPO algorithm -void SAXS::sasa_calculate(std::vector &solv_res) { +void SAXS::sasa_calculate(std::vector &solv_res) +{ unsigned natoms = getNumberOfAtoms(); std::vector > Nlist(natoms); calcNlist(Nlist); @@ -894,22 +815,17 @@ void SAXS::sasa_calculate(std::vector &solv_res) { } } for(unsigned i=0; isasa_cutoff) { - solv_res[i] = 1; - } else { - solv_res[i] = 0; - } + if(sasares[i]>sasa_cutoff) solv_res[i] = 1; + else solv_res[i] = 0; } } -void SAXS::calculate_gpu(std::vector &pos, std::vector &deriv) { +void SAXS::calculate_gpu(std::vector &pos, std::vector &deriv) +{ #ifdef __PLUMED_HAS_ARRAYFIRE unsigned size; - if(onebead) { - size = nres; - } else { - size = getNumberOfAtoms(); - } + if(onebead) size = nres; + else size = getNumberOfAtoms(); const unsigned numq = q_list.size(); std::vector sum; @@ -1009,13 +925,10 @@ void SAXS::calculate_gpu(std::vector &pos, std::vector &deriv) { comm.Bcast(sum, 0); for(unsigned k=0; kset(sum[k]); - if(getDoScore()) { - setCalcData(k, sum[k]); - } + if(getDoScore()) setCalcData(k, sum[k]); for(unsigned i=0; i &pos, std::vector &deriv) { #endif } -void SAXS::calculate_cpu(std::vector &pos, std::vector &deriv) { +void SAXS::calculate_cpu(std::vector &pos, std::vector &deriv) +{ unsigned size; - if(onebead) { - size = nres; - } else { - size = getNumberOfAtoms(); - } + if(onebead) size = nres; + else size = getNumberOfAtoms(); const unsigned numq = q_list.size(); unsigned stride = comm.Get_size(); @@ -1074,12 +985,8 @@ void SAXS::calculate_cpu(std::vector &pos, std::vector &deriv) { } #pragma omp critical if(nt>1) { - for(unsigned i=0; i &pos, std::vector &deriv) { for (unsigned k=0; kset(sum[k]); - if(getDoScore()) { - setCalcData(k, sum[k]); - } + if(getDoScore()) setCalcData(k, sum[k]); } } -void SAXS::calculate() { - if(pbc) { - makeWhole(); - } +void SAXS::calculate() +{ + if(pbc) makeWhole(); const size_t size = getNumberOfAtoms(); const size_t numq = q_list.size(); @@ -1112,9 +1015,7 @@ void SAXS::calculate() { std::vector aa_deriv(size); size_t beads_size = size; - if(onebead) { - beads_size = nres; - } + if(onebead) beads_size = nres; // these are the derivatives particle,q std::vector bd_deriv(numq*beads_size); @@ -1142,9 +1043,7 @@ void SAXS::calculate() { if(saxs) { if(getStep()%solv_stride == 0 || isFirstStep) { isFirstStep = 0; - if(rho_corr!=rho) { - sasa_calculate(solv_res); - } + if(rho_corr!=rho) sasa_calculate(solv_res); Iq0=0.; for(unsigned i=0; i(size,(Vector(1,1,1))); } - if(gpu) { - calculate_gpu(beads_pos, bd_deriv); - } else { - calculate_cpu(beads_pos, bd_deriv); - } + if(gpu) calculate_gpu(beads_pos, bd_deriv); + else calculate_cpu(beads_pos, bd_deriv); if(getDoScore()) { /* Metainference */ @@ -1264,8 +1158,7 @@ void SAXS::calculate() { Tensor deriv_box; Value* val; if(!getDoScore()) { - std::string num; - Tools::convert(k,num); + std::string num; Tools::convert(k,num); val=getPntrToComponent("q-"+num); if(onebead) { @@ -1323,14 +1216,11 @@ void SAXS::calculate() { void SAXS::update() { // write status file - if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) { - writeStatus(); - } + if(getWstride()>0&& (getStep()%getWstride()==0 || getCPT()) ) writeStatus(); } unsigned SAXS::getOnebeadMapping(const PDB &pdb, const std::vector &atoms) { - std::vector chains; - pdb.getChainNames( chains ); + std::vector chains; pdb.getChainNames( chains ); std::vector > AtomResidueName; atoms_masses.resize(atoms.size()); @@ -1348,8 +1238,7 @@ unsigned SAXS::getOnebeadMapping(const PDB &pdb, const std::vector & Rname.erase(std::remove_if(Rname.begin(), Rname.end(), ::isspace),Rname.end()); std::vector res_atoms = pdb.getAtomsInResidue(res, chains[i]); unsigned first_time=1; - std::vector > tmp_residue_atom; - tmp_residue_atom.resize(3); + std::vector > tmp_residue_atom; tmp_residue_atom.resize(3); // cycle over atoms for(unsigned a=0; a & } else { type = Aname.at(1); } - if (type == 'H') { - atoms_masses[res_atoms[a].index()] = 1.008; - } else if(type == 'C') { - atoms_masses[res_atoms[a].index()] = 12.011; - } else if(type == 'N') { - atoms_masses[res_atoms[a].index()] = 14.007; - } else if(type == 'O') { - atoms_masses[res_atoms[a].index()] = 15.999; - } else if(type == 'S') { - atoms_masses[res_atoms[a].index()] = 32.065; - } else if(type == 'P') { - atoms_masses[res_atoms[a].index()] = 30.974; - } else { + if (type == 'H') atoms_masses[res_atoms[a].index()] = 1.008; + else if(type == 'C') atoms_masses[res_atoms[a].index()] = 12.011; + else if(type == 'N') atoms_masses[res_atoms[a].index()] = 14.007; + else if(type == 'O') atoms_masses[res_atoms[a].index()] = 15.999; + else if(type == 'S') atoms_masses[res_atoms[a].index()] = 32.065; + else if(type == 'P') atoms_masses[res_atoms[a].index()] = 30.974; + else { error("Unknown element in mass extraction\n"); } if(pdb.allowedResidue("protein",Rname)) { @@ -1413,25 +1296,17 @@ unsigned SAXS::getOnebeadMapping(const PDB &pdb, const std::vector & tmp_residue_atom[2].push_back(res_atoms[a].index()); } // error - else { - error("Atom name "+Aname+" cannot be indexed to any bead. Check the PDB."); - } + else error("Atom name "+Aname+" cannot be indexed to any bead. Check the PDB."); } } if(!pdb.allowedResidue("protein",Rname)) { atoms_per_bead.push_back(tmp_residue_atom[0].size()); - for(unsigned tmp_i=0; tmp_i0) { atoms_per_bead.push_back(tmp_residue_atom[2].size()); - for(unsigned tmp_i=0; tmp_i & return atoms_per_bead.size(); } -void SAXS::getMartiniFFparam(const std::vector &atoms, std::vector > ¶meter) { +void SAXS::getMartiniFFparam(const std::vector &atoms, std::vector > ¶meter) +{ parameter[ALA_BB].push_back(9.045); parameter[ALA_BB].push_back(-0.098114); parameter[ALA_BB].push_back(7.54281); @@ -2513,9 +2389,7 @@ void SAXS::getMartiniFFparam(const std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector > ¶meter_vac, std::vector > ¶meter_mix, std::vector > ¶meter_solv, std::vector residue_atom) { +void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, std::vector > ¶meter_vac, std::vector > ¶meter_mix, std::vector > ¶meter_solv, std::vector residue_atom) +{ parameter_solv[TRP].push_back(60737.60249988003); parameter_solv[TRP].push_back(-77.75716755173752); @@ -3770,9 +3589,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - G3 } else if(Rname=="G3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3790,9 +3607,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - G5 } else if(Rname=="G5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -3807,9 +3622,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U } else if(Rname=="U") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3826,9 +3639,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U3 } else if(Rname=="U3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3845,9 +3656,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U5 } else if(Rname=="U5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -3861,9 +3670,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A } else if(Rname=="A") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3881,9 +3688,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A3 } else if(Rname=="A3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3901,9 +3706,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A5 } else if(Rname=="A5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -3918,9 +3721,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C } else if(Rname=="C") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3937,9 +3738,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C3 } else if(Rname=="C3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3956,9 +3755,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C5 } else if(Rname=="C5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -3972,9 +3769,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G } else if(Rname=="DG") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -3992,9 +3787,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G3 } else if(Rname=="DG3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4012,9 +3805,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G5 } else if(Rname=="DG5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -4029,9 +3820,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T } else if(Rname=="DT") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4049,9 +3838,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T3 } else if(Rname=="DT3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4069,9 +3856,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T5 } else if(Rname=="DT5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -4086,9 +3871,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A } else if(Rname=="DA") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4106,9 +3889,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A3 } else if(Rname=="DA3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4126,9 +3907,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A5 } else if(Rname=="DA5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -4143,9 +3922,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C } else if(Rname=="DC") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4162,9 +3939,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C3 } else if(Rname=="DC3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -4181,9 +3956,7 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C5 } else if(Rname=="DC5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -4197,16 +3970,13 @@ void SAXS::getOnebeadparam(const PDB &pdb, const std::vector &atoms, Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } - } else { - error("Residue not known: "+Rname); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); + } else error("Residue not known: "+Rname); } } -void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector &atoms, std::vector > ¶meter_vac_H, std::vector > ¶meter_mix_H, std::vector > ¶meter_solv_H) { +void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector &atoms, std::vector > ¶meter_vac_H, std::vector > ¶meter_mix_H, std::vector > ¶meter_solv_H) +{ parameter_solv_H[TRP].push_back(60737.60249988011); parameter_solv_H[TRP].push_back(-77.77344118516487); parameter_solv_H[TRP].push_back(-205962.80436572764); @@ -5078,9 +4848,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - G3 } else if(Rname=="G3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5098,9 +4866,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - G5 } else if(Rname=="G5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5115,9 +4881,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U } else if(Rname=="U") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5134,9 +4898,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U3 } else if(Rname=="U3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5153,9 +4915,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U5 } else if(Rname=="U5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5169,9 +4929,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A } else if(Rname=="A") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5189,9 +4947,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A3 } else if(Rname=="A3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5209,9 +4965,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A5 } else if(Rname=="A5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5226,9 +4980,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C } else if(Rname=="C") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5245,9 +4997,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C3 } else if(Rname=="C3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5264,9 +5014,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C5 } else if(Rname=="C5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5280,9 +5028,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G } else if(Rname=="DG") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5300,9 +5046,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G3 } else if(Rname=="DG3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5320,9 +5064,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G5 } else if(Rname=="DG5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5337,9 +5079,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T } else if(Rname=="DT") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5357,9 +5097,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T3 } else if(Rname=="DT3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5377,9 +5115,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T5 } else if(Rname=="DT5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5394,9 +5130,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A } else if(Rname=="DA") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5414,9 +5148,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A3 } else if(Rname=="DA3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5434,9 +5166,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A5 } else if(Rname=="DA5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5451,9 +5181,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C } else if(Rname=="DC") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5470,9 +5198,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C3 } else if(Rname=="DC3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -5489,9 +5215,7 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C5 } else if(Rname=="DC5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -5505,17 +5229,13 @@ void SAXS::getOnebeadparam_sansH(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } - } else { - error("Residue not known: "+Rname); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); + } else error("Residue not known: "+Rname); } } -void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector &atoms, std::vector > ¶meter_vac_D, std::vector > ¶meter_mix_D) { - // parameter_solv is identical in SAXS/SANS_H/SANS_D since it depends exclusively on param_v. For that reason we kept param_solv only in SAXS and SANS_H. +void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector &atoms, std::vector > ¶meter_vac_D, std::vector > ¶meter_mix_D) +{ // parameter_solv is identical in SAXS/SANS_H/SANS_D since it depends exclusively on param_v. For that reason we kept param_solv only in SAXS and SANS_H. parameter_mix_D[TRP].push_back(8105.740500119327); parameter_mix_D[TRP].push_back(-41.785616935469804); parameter_mix_D[TRP].push_back(-25456.92790554363); @@ -6123,9 +5843,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - G3 } else if(Rname=="G3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6143,9 +5861,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - G5 } else if(Rname=="G5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6160,9 +5876,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U } else if(Rname=="U") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6179,9 +5893,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U3 } else if(Rname=="U3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6198,9 +5910,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - U5 } else if(Rname=="U5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6214,9 +5924,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="O4" || Aname=="C5" || Aname=="C6" || Aname=="H3" || Aname=="H5" || Aname=="H6") { atoi[residue_atom[i]]=BASE_U; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A } else if(Rname=="A") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6234,9 +5942,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A3 } else if(Rname=="A3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6254,9 +5960,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - A5 } else if(Rname=="A5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6271,9 +5975,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C } else if(Rname=="C") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6290,9 +5992,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C3 } else if(Rname=="C3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6309,9 +6009,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // RNA - C5 } else if(Rname=="C5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6325,9 +6023,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G } else if(Rname=="DG") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6345,9 +6041,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G3 } else if(Rname=="DG3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6365,9 +6059,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - G5 } else if(Rname=="DG5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6382,9 +6074,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="N7" || Aname=="C8" || Aname=="N9" || Aname=="H1" || Aname=="H8" || Aname=="H21" || Aname=="H22" ) { atoi[residue_atom[i]]=BASE_G; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T } else if(Rname=="DT") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6402,9 +6092,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T3 } else if(Rname=="DT3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6422,9 +6110,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - T5 } else if(Rname=="DT5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6439,9 +6125,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C7" || Aname=="H3" || Aname=="H6" || Aname=="H71" || Aname=="H72" || Aname=="H73" ) { atoi[residue_atom[i]]=BASE_T; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A } else if(Rname=="DA") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6459,9 +6143,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A3 } else if(Rname=="DA3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6479,9 +6161,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - A5 } else if(Rname=="DA5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6496,9 +6176,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C8" || Aname=="N9" || Aname=="H2" || Aname=="H8" || Aname=="H61" || Aname=="H62" ) { atoi[residue_atom[i]]=BASE_A; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C } else if(Rname=="DC") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6515,9 +6193,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C3 } else if(Rname=="DC3") { if( Aname=="P" || Aname=="OP1" || Aname=="OP2" || Aname=="OP3" || @@ -6534,9 +6210,7 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); // DNA - C5 } else if(Rname=="DC5") { if( Aname=="O5'" || Aname=="C5'" || Aname=="O4'" || Aname=="C4'" || @@ -6550,16 +6224,13 @@ void SAXS::getOnebeadparam_sansD(const PDB &pdb, const std::vector & Aname=="C4" || Aname=="N4" || Aname=="C5" || Aname=="C6" || Aname=="H5" || Aname=="H6" || Aname=="H41" || Aname=="H42" ) { atoi[residue_atom[i]]=BASE_C; - } else { - error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); - } - } else { - error("Residue not known: "+Rname); - } + } else error("Atom name "+Aname+" is not defined for residue "+Rname+". Check the PDB."); + } else error("Residue not known: "+Rname); } } -double SAXS::calculateAFF(const std::vector &atoms, std::vector > &FF_tmp, const double rho) { +double SAXS::calculateAFF(const std::vector &atoms, std::vector > &FF_tmp, const double rho) +{ std::map AA_map; AA_map["H"] = H; AA_map["C"] = C; @@ -6578,83 +6249,41 @@ double SAXS::calculateAFF(const std::vector &atoms, std::vector(this); @@ -6694,9 +6323,7 @@ double SAXS::calculateAFF(const std::vector &atoms, std::vector &atoms, std::vector &atoms, std::vector > &FF_tmp, const double deuter_conc) { +double SAXS::calculateAFFsans(const std::vector &atoms, std::vector > &FF_tmp, const double deuter_conc) +{ std::map AA_map; AA_map["H"] = H; AA_map["C"] = C; @@ -6724,19 +6352,13 @@ double SAXS::calculateAFFsans(const std::vector &atoms, std::vector< param_b.resize(NTT); param_v.resize(NTT); - param_b[H] = -0.374; - param_v[H] = 5.15; + param_b[H] = -0.374; param_v[H] = 5.15; // param_b[D] = 0.667; - param_b[C] = 0.665; - param_v[C] = 16.44; - param_b[N] = 0.94; - param_v[N] = 2.49; - param_b[O] = 0.580; - param_v[O] = 9.13; - param_b[P] = 0.51; - param_v[P] = 5.73; - param_b[S] = 0.28; - param_v[S] = 19.86; + param_b[C] = 0.665; param_v[C] = 16.44; + param_b[N] = 0.94; param_v[N] = 2.49; + param_b[O] = 0.580; param_v[O] = 9.13; + param_b[P] = 0.51; param_v[P] = 5.73; + param_b[S] = 0.28; param_v[S] = 19.86; double solv_sc_length = 0.1*(param_b[O] + 2.*((1. - deuter_conc) * param_b[H] + deuter_conc * 0.667)); // per water electron (10 electrons) @@ -7787,10 +7409,12 @@ std::map > SAXS::setupLCPOparam() { } // assigns LCPO parameters to each atom reading from database -void SAXS::readLCPOparam(const std::vector > &AtomResidueName, unsigned natoms) { +void SAXS::readLCPOparam(const std::vector > &AtomResidueName, unsigned natoms) +{ std::map > lcpomap = setupLCPOparam(); - for(unsigned i=0; i LCPOparamVector = lcpomap.at(identifier); diff --git a/src/isdb/Select.cpp b/src/isdb/Select.cpp index 1191bea4e1..2c3f6843a6 100644 --- a/src/isdb/Select.cpp +++ b/src/isdb/Select.cpp @@ -66,7 +66,8 @@ PRINT ARG=pbactive STRIDE=100 FILE=COLVAR */ //+ENDPLUMEDOC -class Select : public function::Function { +class Select : public function::Function +{ std::string selector_; public: @@ -84,12 +85,12 @@ void Select::registerKeywords(Keywords& keys) { } Select::Select(const ActionOptions&ao): - Action(ao), Function(ao) { + Action(ao), Function(ao) +{ // name of selector parse("SELECTOR", selector_); - addValueWithDerivatives(); - setNotPeriodic(); + addValueWithDerivatives(); setNotPeriodic(); checkRead(); log.printf(" select based on %s\n",selector_.c_str()); @@ -97,18 +98,15 @@ Select::Select(const ActionOptions&ao): } -void Select::calculate() { +void Select::calculate() +{ unsigned iselect = static_cast(plumed.passMap[selector_]); // check if iselect is smaller than the number of arguments - if(iselect>=getNumberOfArguments()) { - error("the value of the SELECTOR is greater than the number of arguments!"); - } + if(iselect>=getNumberOfArguments()) error("the value of the SELECTOR is greater than the number of arguments!"); // put all the derivatives to zero - for(unsigned i=0; i=0.0 ) { kbt *= plumed.getAtoms().getKBoltzmann(); - } else { + } + else { kbt = plumed.getAtoms().getKbT(); } if( kbtpd>=0.0 ) { kbtpd *= plumed.getAtoms().getKBoltzmann(); - } else { + } + else { kbtpd = kbt; } @@ -651,9 +655,11 @@ LogMFD::LogMFD( const ActionOptions& ao ): if(alpha == 0.0 && gamma == 0.0) { alpha = 4.0; gamma = 1 / alpha; - } else if(alpha != 0.0 && gamma == 0.0) { + } + else if(alpha != 0.0 && gamma == 0.0) { gamma = 1 / alpha; - } else if(alpha == 0.0 && gamma != 0.0) { + } + else if(alpha == 0.0 && gamma != 0.0) { alpha = 1 / gamma; } @@ -663,22 +669,23 @@ LogMFD::LogMFD( const ActionOptions& ao ): if( multi_sim_comm.Get_size()>1 ) { if( TAMD ) { log.printf("TAMD-PD, replica parallel of TAMD, no logarithmic flattening.\n"); - } else { + } + else { log.printf("LogPD, replica parallel of LogMFD.\n"); } log.printf("number of replica : %d.\n", multi_sim_comm.Get_size() ); - } else { + } + else { if( TAMD ) { log.printf("TAMD, no logarithmic flattening.\n"); - } else { + } + else { log.printf("LogMFD, logarithmic flattening.\n"); } } log.printf(" with harmonic force constant "); - for(unsigned i=0; igetDomain(a,b); componentIsPeriodic(comp,a,b); - } else { + } + else { componentIsNotPeriodic(comp); } fictValue[i] = getPntrToComponent(comp); @@ -774,9 +772,7 @@ void LogMFD::calculate() { // set initial values of fictitious variables if they were not specified. for(unsigned i=0; i1 ) { fprintf(outlog, "# LogPD, replica parallel of LogMFD\n"); fprintf(outlog, "# number of replica : %d\n", multi_sim_comm.Get_size() ); - } else { + } + else { fprintf(outlog, "# LogMFD\n"); } @@ -932,9 +932,7 @@ void LogMFD::calculate() { bounces back variables, updates free energy, and record logs. */ void LogMFD::update() { - if( (getStep()-step_initial)%interval != interval-1 ) { - return; - } + if( (getStep()-step_initial)%interval != interval-1 ) return; for(unsigned i=0; i( getDependencies()[0] ); @@ -51,12 +52,9 @@ ManyRestraintsBase::ManyRestraintsBase(const ActionOptions& ao): aves->getName().c_str(),aves->getLabel().c_str()); // Add a task list in order to avoid problems - for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - addTaskToList( aves->getTaskCode(i) ); - } + for(unsigned i=0; igetFullNumberOfTasks(); ++i) addTaskToList( aves->getTaskCode(i) ); // And turn on the derivatives (note problems here because of ActionWithValue) - turnOnDerivatives(); - needsDerivatives(); + turnOnDerivatives(); needsDerivatives(); // Now create the vessel std::string fake_input="LABEL=bias"; @@ -83,9 +81,7 @@ void ManyRestraintsBase::transformBridgedDerivatives( const unsigned& current, M // Now update the outvals derivatives lists outvals.emptyActiveMembers(); - for(unsigned j=0; j& bb ) override { - plumed_assert( bb.size()==0 ); - } + void applyBridgeForces( const std::vector& bb ) override { plumed_assert( bb.size()==0 ); } }; inline diff --git a/src/manyrestraints/UWalls.cpp b/src/manyrestraints/UWalls.cpp index 9f4fbbc7a6..0749e5e2ad 100644 --- a/src/manyrestraints/UWalls.cpp +++ b/src/manyrestraints/UWalls.cpp @@ -85,7 +85,8 @@ void UWalls::registerKeywords( Keywords& keys ) { UWalls::UWalls(const ActionOptions& ao): Action(ao), - ManyRestraintsBase(ao) { + ManyRestraintsBase(ao) +{ parse("AT",at); parse("OFFSET",offset); parse("EPS",eps); diff --git a/src/mapping/AdaptivePath.cpp b/src/mapping/AdaptivePath.cpp index 69f97d096d..8754d88f77 100644 --- a/src/mapping/AdaptivePath.cpp +++ b/src/mapping/AdaptivePath.cpp @@ -105,9 +105,7 @@ class AdaptivePath : public Mapping { explicit AdaptivePath(const ActionOptions&); void calculate() override; void performTask( const unsigned&, const unsigned&, MultiValue& ) const override; - double getLambda() override { - return 0.0; - } + double getLambda() override { return 0.0; } double transformHD( const double& dist, double& df ) const override; void update() override; }; @@ -115,8 +113,7 @@ class AdaptivePath : public Mapping { PLUMED_REGISTER_ACTION(AdaptivePath,"ADAPTIVE_PATH") void AdaptivePath::registerKeywords( Keywords& keys ) { - Mapping::registerKeywords( keys ); - keys.remove("PROPERTY"); + Mapping::registerKeywords( keys ); keys.remove("PROPERTY"); keys.add("compulsory","FIXED","the positions in the list of input frames of the two path nodes whose positions remain fixed during the path optimization"); keys.add("compulsory","HALFLIFE","-1","the number of MD steps after which a previously measured path distance weighs only 50% in the average. This option may increase convergence by allowing to forget the memory of a bad initial guess path. The default is to set this to infinity"); keys.add("compulsory","UPDATE","the frequency with which the path should be updated"); @@ -131,64 +128,42 @@ AdaptivePath::AdaptivePath(const ActionOptions& ao): Mapping(ao), fixedn(2), displacement(ReferenceConfigurationOptions("DIRECTION")), - displacement2(ReferenceConfigurationOptions("DIRECTION")) { - setLowMemOption( true ); - parseVector("FIXED",fixedn); - if( fixedn[0]<1 || fixedn[1]>getNumberOfReferencePoints() ) { - error("fixed nodes must be in range from 0 to number of nodes"); - } - if( fixedn[0]>=fixedn[1] ) { - error("invalid selection for fixed nodes first index provided must be smaller than second index"); - } + displacement2(ReferenceConfigurationOptions("DIRECTION")) +{ + setLowMemOption( true ); parseVector("FIXED",fixedn); + if( fixedn[0]<1 || fixedn[1]>getNumberOfReferencePoints() ) error("fixed nodes must be in range from 0 to number of nodes"); + if( fixedn[0]>=fixedn[1] ) error("invalid selection for fixed nodes first index provided must be smaller than second index"); log.printf(" fixing position of frames numbered %u and %u \n",fixedn[0],fixedn[1]); - fixedn[0]--; - fixedn[1]--; // Set fixed notes with c++ indexing starting from zero - parse("UPDATE",update_str); - if( update_str<1 ) { - error("update frequency for path should be greater than or equal to one"); - } + fixedn[0]--; fixedn[1]--; // Set fixed notes with c++ indexing starting from zero + parse("UPDATE",update_str); if( update_str<1 ) error("update frequency for path should be greater than or equal to one"); log.printf(" updating path every %u MD steps \n",update_str); - double halflife; - parse("HALFLIFE",halflife); - if( halflife<0 ) { - fadefact=1.0; - } else { + double halflife; parse("HALFLIFE",halflife); + if( halflife<0 ) fadefact=1.0; + else { fadefact = exp( -0.693147180559945 / static_cast(halflife) ); log.printf(" weight of contribution to frame halves every %f steps \n",halflife); } // Create the list of tasks (and reset projections of frames) - PDB mypdb; - mypdb.setAtomNumbers( getAbsoluteIndexes() ); - mypdb.addBlockEnd( getAbsoluteIndexes().size() ); + PDB mypdb; mypdb.setAtomNumbers( getAbsoluteIndexes() ); mypdb.addBlockEnd( getAbsoluteIndexes().size() ); std::vector argument_names( getNumberOfArguments() ); - for(unsigned i=0; igetName(); - } - if( argument_names.size()>0 ) { - mypdb.setArgumentNames( argument_names ); - } - displacement.read( mypdb ); - displacement2.read( mypdb ); + for(unsigned i=0; igetName(); + if( argument_names.size()>0 ) mypdb.setArgumentNames( argument_names ); + displacement.read( mypdb ); displacement2.read( mypdb ); for(int i=0; isecond[i] = static_cast( i - static_cast(fixedn[0]) ) / static_cast( fixedn[1] - fixedn[0] ); - pdisplacements[i].read( mypdb ); - wsum.push_back( 0.0 ); + pdisplacements[i].read( mypdb ); wsum.push_back( 0.0 ); } plumed_assert( getPropertyValue( fixedn[0], "spath" )==0.0 && getPropertyValue( fixedn[1], "spath" )==1.0 ); // And activate them all deactivateAllTasks(); - for(unsigned i=0; i0 ) { - wstride=0; - parse("WSTRIDE",wstride); - parse("FMT",ofmt); - pathfile.link(*this); - pathfile.open( wfilename ); - pathfile.setHeavyFlush(); - if( wstridedx; double weight1 = 1.0 + mypathv->dx; if( weight1>1.0 ) { - weight1=1.0; - weight2=0.0; + weight1=1.0; weight2=0.0; } else if( weight2>1.0 ) { - weight1=0.0; - weight2=1.0; + weight1=0.0; weight2=1.0; } // Add projections to dispalcement accumulators ReferenceConfiguration* myref = getReferenceConfiguration( mypathv->iclose1 ); @@ -279,17 +243,12 @@ void AdaptivePath::update() { std::vector>& myconfs=getAllReferenceConfigurations(); auto* mymoldat=plumed.getActionSet().selectLatest(this); std::vector argument_names( getNumberOfArguments() ); - for(unsigned i=0; igetName(); - } - PDB mypdb; - mypdb.setArgumentNames( argument_names ); + for(unsigned i=0; igetName(); + PDB mypdb; mypdb.setArgumentNames( argument_names ); for(unsigned i=0; igetName().c_str() ); mypdb.setAtomPositions( myconfs[i]->getReferencePositions() ); - for(unsigned j=0; jgetName(), myconfs[i]->getReferenceArgument(j) ); - } + for(unsigned j=0; jgetName(), myconfs[i]->getReferenceArgument(j) ); mypdb.print( atoms.getUnits().getLength()/0.1, mymoldat, pathfile, ofmt ); } pathfile.flush(); diff --git a/src/mapping/Mapping.cpp b/src/mapping/Mapping.cpp index eb1cb5e96e..95eb1fd4f5 100644 --- a/src/mapping/Mapping.cpp +++ b/src/mapping/Mapping.cpp @@ -50,63 +50,44 @@ Mapping::Mapping(const ActionOptions&ao): ActionAtomistic(ao), ActionWithArguments(ao), ActionWithValue(ao), - ActionWithVessel(ao) { + ActionWithVessel(ao) +{ // Read the input - std::string mtype; - parse("TYPE",mtype); - bool skipchecks; - parseFlag("DISABLE_CHECKS",skipchecks); + std::string mtype; parse("TYPE",mtype); + bool skipchecks; parseFlag("DISABLE_CHECKS",skipchecks); // Read the properties we require bool ispath=false; if( keywords.exists("PROPERTY") ) { - std::vector propnames; - parseVector("PROPERTY",propnames); - if(propnames.size()==0) { - error("no properties were specified"); - } - for(unsigned i=0; i >( propnames[i], std::vector() ) ); - } + std::vector propnames; parseVector("PROPERTY",propnames); + if(propnames.size()==0) error("no properties were specified"); + for(unsigned i=0; i >( propnames[i], std::vector() ) ); } else { - property.insert( std::pair >( "spath", std::vector() ) ); - ispath=true; + property.insert( std::pair >( "spath", std::vector() ) ); ispath=true; } // Open reference file - std::string reference; - parse("REFERENCE",reference); + std::string reference; parse("REFERENCE",reference); FILE* fp=this->fopen(reference.c_str(),"r"); - if(!fp) { - error("could not open reference file " + reference ); - } + if(!fp) error("could not open reference file " + reference ); // call fclose when exiting this block - auto deleter=[this](FILE* f) { - this->fclose(f); - }; + auto deleter=[this](FILE* f) { this->fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); // Read all reference configurations - bool do_read=true; - unsigned nfram=0; - double wnorm=0., ww; + bool do_read=true; unsigned nfram=0; double wnorm=0., ww; while (do_read) { // Read the pdb file - PDB mypdb; - do_read=mypdb.readFromFilepointer(fp,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()); + PDB mypdb; do_read=mypdb.readFromFilepointer(fp,plumed.getAtoms().usingNaturalUnits(),0.1/atoms.getUnits().getLength()); // Break if we are done - if( !do_read ) { - break ; - } + if( !do_read ) break ; // Check for required properties if( !ispath ) { double prop; for(std::map >::iterator it=property.begin(); it!=property.end(); ++it) { - if( !mypdb.getArgumentValue( it->first, prop ) ) { - error("pdb input does not have contain property named " + it->first ); - } + if( !mypdb.getArgumentValue( it->first, prop ) ) error("pdb input does not have contain property named " + it->first ); it->second.push_back(prop); } } else { @@ -116,45 +97,26 @@ Mapping::Mapping(const ActionOptions&ao): expandArgKeywordInPDB( mypdb ); // And read the frame myframes.emplace_back( metricRegister().create( mtype, mypdb ) ); - if( !mypdb.getArgumentValue( "WEIGHT", ww ) ) { - ww=1.0; - } - weights.push_back( ww ); - wnorm+=ww; - nfram++; + if( !mypdb.getArgumentValue( "WEIGHT", ww ) ) ww=1.0; + weights.push_back( ww ); wnorm+=ww; nfram++; } - if(nfram==0 ) { - error("no reference configurations were specified"); - } + if(nfram==0 ) error("no reference configurations were specified"); log.printf(" found %u configurations in file %s\n",nfram,reference.c_str() ); - for(unsigned i=0; i atoms; - std::vector args; - for(unsigned i=0; igetAtomRequests( atoms, skipchecks ); - myframes[i]->getArgumentRequests( args, skipchecks ); - } - std::vector req_args; - interpretArgumentList( args, req_args ); - if( req_args.size()>0 && atoms.size()>0 ) { - error("cannot mix atoms and arguments"); - } - if( req_args.size()>0 ) { - requestArguments( req_args ); - } + std::vector atoms; std::vector args; + for(unsigned i=0; igetAtomRequests( atoms, skipchecks ); myframes[i]->getArgumentRequests( args, skipchecks ); } + std::vector req_args; interpretArgumentList( args, req_args ); + if( req_args.size()>0 && atoms.size()>0 ) error("cannot mix atoms and arguments"); + if( req_args.size()>0 ) requestArguments( req_args ); if( atoms.size()>0 ) { log.printf(" found %zu atoms in input \n",atoms.size()); log.printf(" with indices : "); for(unsigned i=0; igetName(); - } + if( iarg < getNumberOfArguments() ) return getPntrToArgument(iarg)->getName(); unsigned iatom=iarg - getNumberOfArguments(); - std::string atnum; - Tools::convert( getAbsoluteIndex(iatom).serial(),atnum); + std::string atnum; Tools::convert( getAbsoluteIndex(iatom).serial(),atnum); unsigned icomp=iatom%3; - if(icomp==0) { - return "pos" + atnum + "x"; - } - if(icomp==1) { - return "pos" + atnum + "y"; - } + if(icomp==0) return "pos" + atnum + "x"; + if(icomp==1) return "pos" + atnum + "y"; return "pos" + atnum + "z"; } @@ -204,15 +159,10 @@ void Mapping::finishPackSetup( const unsigned& ifunc, ReferenceValuePack& mypack mypack.setValIndex(0); unsigned nargs2=myframes[ifunc]->getNumberOfReferenceArguments(); unsigned nat2=myframes[ifunc]->getNumberOfReferencePositions(); - if( mypack.getNumberOfAtoms()!=nat2 || mypack.getNumberOfArguments()!=nargs2 ) { - mypack.resize( nargs2, nat2 ); - } + if( mypack.getNumberOfAtoms()!=nat2 || mypack.getNumberOfArguments()!=nargs2 ) mypack.resize( nargs2, nat2 ); if( nat2>0 ) { - ReferenceAtoms* myat2=dynamic_cast( myframes[ifunc].get() ); - plumed_dbg_assert( myat2 ); - for(unsigned i=0; igetAtomIndex(i) ); - } + ReferenceAtoms* myat2=dynamic_cast( myframes[ifunc].get() ); plumed_dbg_assert( myat2 ); + for(unsigned i=0; igetAtomIndex(i) ); } } @@ -220,15 +170,11 @@ double Mapping::calculateDistanceFunction( const unsigned& ifunc, ReferenceValue // Calculate the distance double dd = myframes[ifunc]->calculate( getPositions(), getPbc(), getArguments(), myder, squared ); // Transform distance by whatever - double df, ff=transformHD( dd, df ); - myder.scaleAllDerivatives( df ); + double df, ff=transformHD( dd, df ); myder.scaleAllDerivatives( df ); // And the virial if( getNumberOfAtoms()>0 && !myder.virialWasSet() ) { - Tensor tvir; - tvir.zero(); - for(unsigned i=0; i0 ) { Matrix save_derivatives( getNumberOfComponents(), getNumberOfArguments() ); for(int j=0; jgetDerivative(i); - } + for(unsigned i=0; igetDerivative(i); } calculateAtomicNumericalDerivatives( a, getNumberOfArguments() ); for(int j=0; jaddDerivative( i, save_derivatives(j,i) ); - } + for(unsigned i=0; iaddDerivative( i, save_derivatives(j,i) ); } } } @@ -261,9 +203,7 @@ void Mapping::calculateNumericalDerivatives( ActionWithValue* a ) { void Mapping::apply() { if( getForcesFromVessels( forcesToApply ) ) { addForcesOnArguments( forcesToApply ); - if( getNumberOfAtoms()>0 ) { - setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); - } + if( getNumberOfAtoms()>0 ) setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); } } diff --git a/src/mapping/Mapping.h b/src/mapping/Mapping.h index 79affd33ca..0fdd52a564 100644 --- a/src/mapping/Mapping.h +++ b/src/mapping/Mapping.h @@ -41,7 +41,8 @@ class Mapping : public ActionAtomistic, public ActionWithArguments, public ActionWithValue, - public vesselbase::ActionWithVessel { + public vesselbase::ActionWithVessel +{ friend class PropertyMap; friend class TrigonometricPathVessel; friend class AdaptivePath; @@ -80,9 +81,7 @@ class Mapping : void lockRequests() override; void unlockRequests() override; /// Distance from a point is never periodic - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } /// Get the number of derivatives for this action unsigned getNumberOfDerivatives() override; // N.B. This is replacing the virtual function in ActionWithValue /// Get the value of lambda for paths and property maps @@ -107,9 +106,7 @@ unsigned Mapping::getNumberOfReferencePoints() const { inline unsigned Mapping::getNumberOfDerivatives() { unsigned nat=getNumberOfAtoms(); - if(nat>0) { - return 3*nat + 9 + getNumberOfArguments(); - } + if(nat>0) return 3*nat + 9 + getNumberOfArguments(); return getNumberOfArguments(); } diff --git a/src/mapping/PCAVars.cpp b/src/mapping/PCAVars.cpp index 31d9059b39..9bef5ec738 100644 --- a/src/mapping/PCAVars.cpp +++ b/src/mapping/PCAVars.cpp @@ -170,7 +170,8 @@ namespace mapping { class PCAVars : public ActionWithValue, public ActionAtomistic, - public ActionWithArguments { + public ActionWithArguments +{ private: /// The holders for the derivatives MultiValue myvals; @@ -200,8 +201,7 @@ void PCAVars::registerKeywords( Keywords& keys ) { ActionWithValue::registerKeywords( keys ); ActionAtomistic::registerKeywords( keys ); ActionWithArguments::registerKeywords( keys ); - componentsAreNotOptional(keys); - keys.use("ARG"); + componentsAreNotOptional(keys); keys.use("ARG"); keys.addOutputComponent("eig","default","the projections on each eigenvalue are stored on values labeled eig-1, eig-2, ..."); keys.addOutputComponent("residual","default","the distance of the configuration from the linear subspace defined " "by the vectors, eig-1, eig2, ... that are contained in the rows of A."); @@ -217,33 +217,27 @@ PCAVars::PCAVars(const ActionOptions& ao): ActionWithArguments(ao), myvals(1,0), mypack(0,0,myvals), - nopbc(false) { + nopbc(false) +{ // What type of distance are we calculating - std::string mtype; - parse("TYPE",mtype); + std::string mtype; parse("TYPE",mtype); parseFlag("NOPBC",nopbc); // Open reference file - std::string reference; - parse("REFERENCE",reference); + std::string reference; parse("REFERENCE",reference); FILE* fp=this->fopen(reference.c_str(),"r"); - if(!fp) { - error("could not open reference file " + reference ); - } + if(!fp) error("could not open reference file " + reference ); // call fclose when exiting this block - auto deleter=[this](FILE* f) { - this->fclose(f); - }; + auto deleter=[this](FILE* f) { this->fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); // Read all reference configurations // MultiReferenceBase myframes( "", false ); std::vector > myframes; - bool do_read=true; - unsigned nfram=0; + bool do_read=true; unsigned nfram=0; while (do_read) { PDB mypdb; // Read the pdb file @@ -253,12 +247,8 @@ PCAVars::PCAVars(const ActionOptions& ao): if( nfram==0 ) { myref=metricRegister().create( mtype, mypdb ); Direction* tdir = dynamic_cast( myref.get() ); - if( tdir ) { - error("first frame should be reference configuration - not direction of vector"); - } - if( !myref->pcaIsEnabledForThisReference() ) { - error("can't do PCA with reference type " + mtype ); - } + if( tdir ) error("first frame should be reference configuration - not direction of vector"); + if( !myref->pcaIsEnabledForThisReference() ) error("can't do PCA with reference type " + mtype ); // std::vector remarks( mypdb.getRemark() ); std::string rtype; // bool found=Tools::parse( remarks, "TYPE", rtype ); // if(!found){ std::vector newrem(1); newrem[0]="TYPE="+mtype; mypdb.addRemark(newrem); } @@ -273,78 +263,52 @@ PCAVars::PCAVars(const ActionOptions& ao): } } - if( nfram<=1 ) { - error("no eigenvectors were specified"); - } + if( nfram<=1 ) error("no eigenvectors were specified"); log.printf(" found %u eigenvectors in file %s \n",nfram-1,reference.c_str() ); // Finish the setup of the mapping object // Get the arguments and atoms that are required - std::vector atoms; - myref->getAtomRequests( atoms, false ); - std::vector args; - myref->getArgumentRequests( args, false ); + std::vector atoms; myref->getAtomRequests( atoms, false ); + std::vector args; myref->getArgumentRequests( args, false ); if( atoms.size()>0 ) { log.printf(" found %zu atoms in input \n",atoms.size()); log.printf(" with indices : "); for(unsigned i=0; i req_args; - interpretArgumentList( args, req_args ); - requestArguments( req_args ); + requestAtoms( atoms ); std::vector req_args; + interpretArgumentList( args, req_args ); requestArguments( req_args ); // And now check that the atoms/arguments are the same in all the eigenvalues - for(unsigned i=0; igetAtomRequests( atoms, false ); - myframes[i]->getArgumentRequests( args, false ); - } + for(unsigned i=0; igetAtomRequests( atoms, false ); myframes[i]->getArgumentRequests( args, false ); } // Setup the derivative pack - if( atoms.size()>0 ) { - myvals.resize( 1, args.size() + 3*atoms.size() + 9 ); - } else { - myvals.resize( 1, args.size() ); - } + if( atoms.size()>0 ) myvals.resize( 1, args.size() + 3*atoms.size() + 9 ); + else myvals.resize( 1, args.size() ); mypack.resize( args.size(), atoms.size() ); - for(unsigned i=0; isetupPCAStorage( mypack ); // Check there are no periodic arguments for(unsigned i=0; iisPeriodic() ) { - error("cannot use periodic variables in pca projections"); - } + if( getPntrToArgument(i)->isPeriodic() ) error("cannot use periodic variables in pca projections"); } // Work out if the user wants to normalise the input vector checkRead(); - if(nopbc) { - log.printf(" without periodic boundary conditions\n"); - } else { - log.printf(" using periodic boundary conditions\n"); - } + if(nopbc) log.printf(" without periodic boundary conditions\n"); + else log.printf(" using periodic boundary conditions\n"); // Resize the matrices that will hold our eivenvectors - PDB mypdb; - mypdb.setAtomNumbers( atoms ); - mypdb.addBlockEnd( atoms.size() ); - if( args.size()>0 ) { - mypdb.setArgumentNames( args ); - } + PDB mypdb; mypdb.setAtomNumbers( atoms ); mypdb.addBlockEnd( atoms.size() ); + if( args.size()>0 ) mypdb.setArgumentNames( args ); // Resize the matrices that will hold our eivenvectors for(unsigned i=0; iextractDisplacementVector( myref->getReferencePositions(), getArguments(), myref->getReferenceArguments(), true, directions[i] ); // Create a component to store the output - std::string num; - Tools::convert( i+1, num ); - addComponentWithDerivatives("eig-"+num); - componentIsNotPeriodic("eig-"+num); + std::string num; Tools::convert( i+1, num ); + addComponentWithDerivatives("eig-"+num); componentIsNotPeriodic("eig-"+num); } - addComponentWithDerivatives("residual"); - componentIsNotPeriodic("residual"); + addComponentWithDerivatives("residual"); componentIsNotPeriodic("residual"); // Get appropriate number of derivatives unsigned nder; @@ -370,11 +331,8 @@ PCAVars::PCAVars(const ActionOptions& ao): } // Resize all derivative arrays - forces.resize( nder ); - forcesToApply.resize( nder ); - for(int i=0; iresizeDerivatives(nder); - } + forces.resize( nder ); forcesToApply.resize( nder ); + for(int i=0; iresizeDerivatives(nder); } unsigned PCAVars::getNumberOfDerivatives() { @@ -396,9 +354,7 @@ void PCAVars::unlockRequests() { void PCAVars::calculate() { - if(!nopbc && getNumberOfAtoms()>0) { - makeWhole(); - } + if(!nopbc && getNumberOfAtoms()>0) makeWhole(); // Clear the reference value pack mypack.clear(); @@ -406,33 +362,22 @@ void PCAVars::calculate() { double dist = myref->calculate( getPositions(), getPbc(), getArguments(), mypack, true ); // Start accumulating residual by adding derivatives of distance - Value* resid=getPntrToComponent( getNumberOfComponents()-1 ); - unsigned nargs=getNumberOfArguments(); - for(unsigned j=0; jaddDerivative( j, mypack.getArgumentDerivative(j) ); - } + Value* resid=getPntrToComponent( getNumberOfComponents()-1 ); unsigned nargs=getNumberOfArguments(); + for(unsigned j=0; jaddDerivative( j, mypack.getArgumentDerivative(j) ); for(unsigned j=0; jaddDerivative( nargs +3*j+k, ader[k] ); - } + for(unsigned k=0; k<3; ++k) resid->addDerivative( nargs +3*j+k, ader[k] ); } // Retrieve the values of all arguments - std::vector args( getNumberOfArguments() ); - for(unsigned i=0; i args( getNumberOfArguments() ); for(unsigned i=0; iprojectDisplacementOnVector( directions[i], getArguments(), args, mypack ); // And now accumulate derivatives Value* eid=getPntrToComponent(i); - for(unsigned j=0; jaddDerivative( j, mypack.getArgumentDerivative(j) ); - } + for(unsigned j=0; jaddDerivative( j, mypack.getArgumentDerivative(j) ); if( getNumberOfAtoms()>0 ) { tvir.zero(); for(unsigned j=0; jaddDerivative( nargs + 3*getNumberOfAtoms() + 3*j + k, tvir(j,k) ); - } + for(unsigned k=0; k<3; ++k) eid->addDerivative( nargs + 3*getNumberOfAtoms() + 3*j + k, tvir(j,k) ); } } dist -= proj*proj; // Subtract square from total squared distance to get residual squared // Derivatives of residual - for(unsigned j=0; jaddDerivative( j, -2*proj*eid->getDerivative(j) ); - } + for(unsigned j=0; jaddDerivative( j, -2*proj*eid->getDerivative(j) ); // for(unsigned j=0;jaddDerivative( j, -2*proj*arg_eigv(i,j) ); // And set final value getPntrToComponent(i)->set( proj ); @@ -463,29 +404,20 @@ void PCAVars::calculate() { // Take square root of residual derivatives double prefactor = 0.5 / dist; - for(unsigned j=0; jsetDerivative( j, prefactor*resid->getDerivative(j) ); - } + for(unsigned j=0; jsetDerivative( j, prefactor*resid->getDerivative(j) ); for(unsigned j=0; jsetDerivative( nargs + 3*j+k, prefactor*resid->getDerivative( nargs+3*j+k ) ); - } + for(unsigned k=0; k<3; ++k) resid->setDerivative( nargs + 3*j+k, prefactor*resid->getDerivative( nargs+3*j+k ) ); } // And finally virial for residual if( getNumberOfAtoms()>0 ) { tvir.zero(); for(unsigned j=0; jgetDerivative( nargs + 3*j+k ); - } + Vector ader; for(unsigned k=0; k<3; ++k) ader[k]=resid->getDerivative( nargs + 3*j+k ); tvir += -1.0*Tensor( getPosition(j), ader ); } for(unsigned j=0; j<3; ++j) { - for(unsigned k=0; k<3; ++k) { - resid->addDerivative( nargs + 3*getNumberOfAtoms() + 3*j + k, tvir(j,k) ); - } + for(unsigned k=0; k<3; ++k) resid->addDerivative( nargs + 3*getNumberOfAtoms() + 3*j + k, tvir(j,k) ); } } @@ -498,36 +430,27 @@ void PCAVars::calculateNumericalDerivatives( ActionWithValue* a ) { if( getNumberOfAtoms()>0 ) { Matrix save_derivatives( getNumberOfComponents(), getNumberOfArguments() ); for(int j=0; jgetDerivative(i); - } + for(unsigned i=0; igetDerivative(i); } calculateAtomicNumericalDerivatives( a, getNumberOfArguments() ); for(int j=0; jaddDerivative( i, save_derivatives(j,i) ); - } + for(unsigned i=0; iaddDerivative( i, save_derivatives(j,i) ); } } } void PCAVars::apply() { - bool wasforced=false; - forcesToApply.assign(forcesToApply.size(),0.0); + bool wasforced=false; forcesToApply.assign(forcesToApply.size(),0.0); for(int i=0; iapplyForce( forces ) ) { wasforced=true; - for(unsigned i=0; i0 ) { - setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); - } + if( getNumberOfAtoms()>0 ) setForcesOnAtoms( forcesToApply, getNumberOfArguments() ); } } diff --git a/src/mapping/Path.cpp b/src/mapping/Path.cpp index 2a1dacfe0e..345b334b27 100644 --- a/src/mapping/Path.cpp +++ b/src/mapping/Path.cpp @@ -139,25 +139,21 @@ class Path : public PathBase { PLUMED_REGISTER_ACTION(Path,"PATH") void Path::registerKeywords( Keywords& keys ) { - PathBase::registerKeywords( keys ); - keys.remove("PROPERTY"); + PathBase::registerKeywords( keys ); keys.remove("PROPERTY"); keys.addFlag("NOSPATH",false,"do not calculate the spath position"); - keys.remove("LOWMEM"); - keys.use("GPATH"); + keys.remove("LOWMEM"); keys.use("GPATH"); } Path::Path(const ActionOptions& ao): Action(ao), - PathBase(ao) { + PathBase(ao) +{ setLowMemOption( true ); - bool nos; - parseFlag("NOSPATH",nos); + bool nos; parseFlag("NOSPATH",nos); std::string empty; if(!nos) { - if( getLambda()==0 ) { - error("you must set LAMBDA parameter in order to calculate spath position. Use LAMBDA/NOSPATH keyword"); - } + if( getLambda()==0 ) error("you must set LAMBDA parameter in order to calculate spath position. Use LAMBDA/NOSPATH keyword"); empty="LABEL=spath"; addVessel("SPATH",empty,0); } diff --git a/src/mapping/PathBase.cpp b/src/mapping/PathBase.cpp index 0c2824cd25..dbff754df5 100644 --- a/src/mapping/PathBase.cpp +++ b/src/mapping/PathBase.cpp @@ -33,29 +33,23 @@ void PathBase::registerKeywords( Keywords& keys ) { PathBase::PathBase(const ActionOptions& ao): Action(ao), - Mapping(ao) { + Mapping(ao) +{ setLowMemOption( true ); weightHasDerivatives=true; - bool noz; - parseFlag("NOZPATH",noz); + bool noz; parseFlag("NOZPATH",noz); parse("LAMBDA",lambda); // Create the list of tasks - for(unsigned i=0; igetAbsoluteIndexes() ); - mypdb.addBlockEnd( pp[0]->getAbsoluteIndexes().size() ); - if( pp[0]->getArgumentNames().size()>0 ) { - mypdb.setArgumentNames( pp[0]->getArgumentNames() ); - } - mydir.read( mypdb ); - mydir.zeroDirection(); - pp[0]->setupPCAStorage( mypack ); + MAXCYCLES(100) +{ + mypdb.setAtomNumbers( pp[0]->getAbsoluteIndexes() ); mypdb.addBlockEnd( pp[0]->getAbsoluteIndexes().size() ); + if( pp[0]->getArgumentNames().size()>0 ) mypdb.setArgumentNames( pp[0]->getArgumentNames() ); + mydir.read( mypdb ); mydir.zeroDirection(); pp[0]->setupPCAStorage( mypack ); } bool PathReparameterization::loopEnd( const int& index, const int& end, const int& inc ) const { - if( inc>0 && indexend ) { - return false; - } + if( inc>0 && indexend ) return false; return true; } @@ -60,10 +53,7 @@ void PathReparameterization::calcCurrentPathSpacings( const int& istart, const i //printf("HELLO PATH SPACINGS ARE CURRENTLY \n"); // Get the spacings given we can go forward and backwards - int incr=1; - if( istart>iend ) { - incr=-1; - } + int incr=1; if( istart>iend ) { incr=-1; } for(int i=istart+incr; loopEnd(i,iend+incr,incr)==false; i+=incr) { len[i] = mypath[i-incr]->calc( mypath[i]->getReferencePositions(), pbc, args, mypath[i]->getReferenceArguments(), mypack, false ); @@ -73,23 +63,15 @@ void PathReparameterization::calcCurrentPathSpacings( const int& istart, const i } void PathReparameterization::reparameterizePart( const int& istart, const int& iend, const double& target, const double& TOL ) { - calcCurrentPathSpacings( istart, iend ); - unsigned cfin; + calcCurrentPathSpacings( istart, iend ); unsigned cfin; // If a target separation is set we fix where we want the nodes - int incr=1; - if( istart>iend ) { - incr=-1; - } + int incr=1; if( istart>iend ) { incr=-1; } if( target>0 ) { if( iend>istart ) { - for(unsigned i=istart; iiend-1; --i) { - sfrac[i]=target*(istart-i); - } + for(int i=istart-1; i>iend-1; --i) sfrac[i]=target*(istart-i); } cfin = iend+incr; } else { @@ -98,23 +80,18 @@ void PathReparameterization::reparameterizePart( const int& istart, const int& i std::vector newpath; for(unsigned i=0; i( iend - istart ); - for(unsigned i=istart; i=sfrac[i])) ) { k+=incr; - if( cfin==iend && k>= iend+1 ) { - plumed_merror("path reparameterization error"); - } else if( cfin==(iend+1) && k>=iend ) { - k=iend-1; - break; - } else if( cfin==(iend-1) && k<=iend ) { - k=iend+1; - break; - } + if( cfin==iend && k>= iend+1 ) plumed_merror("path reparameterization error"); + else if( cfin==(iend+1) && k>=iend ) { k=iend-1; break; } + else if( cfin==(iend-1) && k<=iend ) { k=iend+1; break; } } double dr = (sfrac[i]-sumlen[k])/len[k+incr]; // Calculate the displacement between the appropriate points @@ -148,9 +119,7 @@ void PathReparameterization::reparameterizePart( const int& istart, const int& i // Copy the positions of the new path to the new paths for(int i=istart+incr; loopEnd(i,cfin,incr)==false; i+=incr) { mypdb.setAtomPositions( newpath[i].getReferencePositions() ); - for(unsigned j=0; jgetArgumentNames()[j], newpath[i].getReferenceArgument(j) ); - } + for(unsigned j=0; jgetArgumentNames()[j], newpath[i].getReferenceArgument(j) ); mypath[i]->read( mypdb ); } @@ -168,12 +137,8 @@ void PathReparameterization::reparameterize( const int& ifix1, const int& ifix2, double target = sumlen[ifix2] / ( ifix2 - ifix1 ); // And reparameterize the beginning and end of the path - if( ifix1>0 ) { - reparameterizePart( ifix1, 0, target, TOL ); - } - if( ifix2<(mypath.size()-1) ) { - reparameterizePart( ifix2, mypath.size()-1, target, TOL ); - } + if( ifix1>0 ) reparameterizePart( ifix1, 0, target, TOL ); + if( ifix2<(mypath.size()-1) ) reparameterizePart( ifix2, mypath.size()-1, target, TOL ); // calcCurrentPathSpacings( 0, mypath.size()-1 ); } diff --git a/src/mapping/PathTools.cpp b/src/mapping/PathTools.cpp index 40d209363f..9fb98d2547 100644 --- a/src/mapping/PathTools.cpp +++ b/src/mapping/PathTools.cpp @@ -102,7 +102,8 @@ plumed pathtools --path inpath.pdb --metric EUCLIDEAN --out outpath.pdb --fixed //+ENDPLUMEDOC class PathTools : - public CLTool { + public CLTool +{ public: static void registerKeywords( Keywords& keys ); explicit PathTools(const CLToolOptions& co ); @@ -130,31 +131,23 @@ void PathTools::registerKeywords( Keywords& keys ) { } PathTools::PathTools(const CLToolOptions& co ): - CLTool(co) { + CLTool(co) +{ inputdata=commandline; } int PathTools::main(FILE* in, FILE*out,Communicator& pc) { - std::string mtype; - parse("--metric",mtype); - std::string ifilename; - parse("--path",ifilename); - std::string ofmt; - parse("--arg-fmt",ofmt); - std::string ofilename; - parse("--out",ofilename); + std::string mtype; parse("--metric",mtype); + std::string ifilename; parse("--path",ifilename); + std::string ofmt; parse("--arg-fmt",ofmt); + std::string ofilename; parse("--out",ofilename); if( ifilename.length()>0 ) { std::fprintf(out,"Reparameterising path in file named %s so that all frames are equally spaced \n",ifilename.c_str() ); FILE* fp=std::fopen(ifilename.c_str(),"r"); // call fclose when fp goes out of scope - auto deleter=[](FILE* f) { - if(f) { - std::fclose(f); - } - }; + auto deleter=[](FILE* f) { if(f) std::fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); - bool do_read=true; - std::vector> frames; + bool do_read=true; std::vector> frames; while (do_read) { PDB mypdb; // Read the pdb file @@ -164,15 +157,10 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { frames.emplace_back( std::move(mymsd) ); } } - std::vector fixed; - parseVector("--fixed",fixed); + std::vector fixed; parseVector("--fixed",fixed); if( fixed.size()==1 ) { - if( fixed[0]!=0 ) { - error("input to --fixed should be two integers"); - } - fixed.resize(2); - fixed[0]=0; - fixed[1]=frames.size()-1; + if( fixed[0]!=0 ) error("input to --fixed should be two integers"); + fixed.resize(2); fixed[0]=0; fixed[1]=frames.size()-1; } else if( fixed.size()==2 ) { if( fixed[0]>(frames.size()-1) || fixed[1]>(frames.size()-1) ) { error("input to --fixed should be two numbers between 0 and the number of frames-1"); @@ -180,18 +168,15 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { } else { error("input to --fixed should be two integers"); } - std::vector atoms; - std::vector arg_names; + std::vector atoms; std::vector arg_names; for(unsigned i=0; igetAtomRequests( atoms); frames[i]->getArgumentRequests( arg_names ); } // Generate stuff to reparameterize - Pbc fake_pbc; - std::vector> vals; + Pbc fake_pbc; std::vector> vals; for(unsigned i=0; igetNumberOfReferenceArguments(); ++i) { - vals.emplace_back(Tools::make_unique()); - vals[vals.size()-1]->setNotPeriodic(); + vals.emplace_back(Tools::make_unique()); vals[vals.size()-1]->setNotPeriodic(); } // temporary pointes used to make the conversion once @@ -200,9 +185,7 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { // And reparameterize PathReparameterization myparam( fake_pbc, vals_ptr, frames ); // And make all points equally spaced - double tol; - parse("--tolerance",tol); - myparam.reparameterize( fixed[0], fixed[1], tol ); + double tol; parse("--tolerance",tol); myparam.reparameterize( fixed[0], fixed[1], tol ); // Output data on spacings double mean=0; @@ -216,20 +199,13 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { printf("SUGGESTED LAMBDA PARAMETER IS THUS %f \n",2.3/(mean/static_cast( frames.size()-1 )) ); // Delete all the frames - OFile ofile; - ofile.open(ofilename); - std::vector argnames; - frames[0]->getArgumentRequests( argnames ); - std::vector atindices; - frames[0]->getAtomRequests( atindices ); - PDB mypdb; - mypdb.setAtomNumbers( atindices ); - mypdb.setArgumentNames( argnames ); + OFile ofile; ofile.open(ofilename); + std::vector argnames; frames[0]->getArgumentRequests( argnames ); + std::vector atindices; frames[0]->getAtomRequests( atindices ); + PDB mypdb; mypdb.setAtomNumbers( atindices ); mypdb.setArgumentNames( argnames ); for(unsigned i=0; igetReferencePositions() ); - for(unsigned j=0; jgetReferenceArguments()[j] ); - } + for(unsigned j=0; jgetReferenceArguments()[j] ); ofile.printf("REMARK TYPE=%s\n",mtype.c_str() ); mypdb.print( 10, NULL, ofile, ofmt ); } @@ -240,58 +216,39 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { } // Read initial frame - std::string istart; - parse("--start",istart); + std::string istart; parse("--start",istart); PDB mystartpdb; { FILE* fp2=std::fopen(istart.c_str(),"r"); // call fclose when fp goes out of scope - auto deleter=[](FILE* f) { - std::fclose(f); - }; + auto deleter=[](FILE* f) { std::fclose(f); }; std::unique_ptr fp_deleter(fp2,deleter); - if( istart.length()==0 ) { - error("input is missing use --istart + --iend or --path"); - } - if( !mystartpdb.readFromFilepointer(fp2,false,0.1) ) { - error("could not read fila " + istart); - } + if( istart.length()==0 ) error("input is missing use --istart + --iend or --path"); + if( !mystartpdb.readFromFilepointer(fp2,false,0.1) ) error("could not read fila " + istart); } auto sframe=metricRegister().create( mtype, mystartpdb ); // Read final frame - std::string iend; - parse("--end",iend); + std::string iend; parse("--end",iend); PDB myendpdb; { FILE* fp1=std::fopen(iend.c_str(),"r"); // call fclose when fp goes out of scope - auto deleter=[](FILE* f) { - std::fclose(f); - }; + auto deleter=[](FILE* f) { std::fclose(f); }; std::unique_ptr fp_deleter(fp1,deleter); - if( iend.length()==0 ) { - error("input is missing using --istart + --iend or --path"); - } - if( !myendpdb.readFromFilepointer(fp1,false,0.1) ) { - error("could not read fila " + iend); - } + if( iend.length()==0 ) error("input is missing using --istart + --iend or --path"); + if( !myendpdb.readFromFilepointer(fp1,false,0.1) ) error("could not read fila " + iend); } auto eframe=metricRegister().create( mtype, myendpdb ); // Get atoms and arg requests - std::vector atoms; - std::vector arg_names; - sframe->getAtomRequests( atoms); - eframe->getAtomRequests( atoms); - sframe->getArgumentRequests( arg_names ); - eframe->getArgumentRequests( arg_names ); + std::vector atoms; std::vector arg_names; + sframe->getAtomRequests( atoms); eframe->getAtomRequests( atoms); + sframe->getArgumentRequests( arg_names ); eframe->getArgumentRequests( arg_names ); // Now read in the rest of the instructions unsigned nbefore, nbetween, nafter; - parse("--nframes-before-start",nbefore); - parse("--nframes",nbetween); - parse("--nframes-after-end",nafter); + parse("--nframes-before-start",nbefore); parse("--nframes",nbetween); parse("--nframes-after-end",nafter); nbetween++; std::fprintf(out,"Generating linear path connecting structure in file named %s to structure in file named %s \n",istart.c_str(),iend.c_str() ); std::fprintf(out,"A path consisting of %u equally-spaced frames before the initial structure, %u frames between the initial and final structures " @@ -301,8 +258,7 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { Pbc fpbc; std::vector> args; for(unsigned i=0; igetNumberOfReferenceArguments(); ++i) { - args.emplace_back(Tools::make_unique()); - args[args.size()-1]->setNotPeriodic(); + args.emplace_back(Tools::make_unique()); args[args.size()-1]->setNotPeriodic(); } // convert pointer once: @@ -315,60 +271,40 @@ int PathTools::main(FILE* in, FILE*out,Communicator& pc) { // And the spacing between frames double delr = 1.0 / static_cast( nbetween ); // Calculate the vector connecting the start to the end - PDB mypdb; - mypdb.setAtomNumbers( sframe->getAbsoluteIndexes() ); - mypdb.addBlockEnd( sframe->getAbsoluteIndexes().size() ); - if( sframe->getArgumentNames().size()>0 ) { - mypdb.setArgumentNames( sframe->getArgumentNames() ); - } - Direction mydir(ReferenceConfigurationOptions("DIRECTION")); - sframe->setupPCAStorage( mypack ); - mydir.read( mypdb ); - mydir.zeroDirection(); + PDB mypdb; mypdb.setAtomNumbers( sframe->getAbsoluteIndexes() ); mypdb.addBlockEnd( sframe->getAbsoluteIndexes().size() ); + if( sframe->getArgumentNames().size()>0 ) mypdb.setArgumentNames( sframe->getArgumentNames() ); + Direction mydir(ReferenceConfigurationOptions("DIRECTION")); sframe->setupPCAStorage( mypack ); mydir.read( mypdb ); mydir.zeroDirection(); sframe->extractDisplacementVector( eframe->getReferencePositions(), args_ptr, eframe->getReferenceArguments(), false, mydir ); // Now create frames - OFile ofile; - ofile.open(ofilename); - unsigned nframes=0; - Direction pos(ReferenceConfigurationOptions("DIRECTION")); - pos.read( mypdb ); + OFile ofile; ofile.open(ofilename); unsigned nframes=0; + Direction pos(ReferenceConfigurationOptions("DIRECTION")); pos.read( mypdb ); for(int i=0; igetReferencePositions(), sframe->getReferenceArguments() ); pos.displaceReferenceConfiguration( -i*delr, mydir ); mypdb.setAtomPositions( pos.getReferencePositions() ); - for(unsigned j=0; jgetArgumentNames()[j], pos.getReferenceArgument(j) ); - } + for(unsigned j=0; jgetArgumentNames()[j], pos.getReferenceArgument(j) ); ofile.printf("REMARK TYPE=%s\n",mtype.c_str() ); - mypdb.print( 10, NULL, ofile, ofmt ); - nframes++; + mypdb.print( 10, NULL, ofile, ofmt ); nframes++; } for(unsigned i=1; igetReferencePositions(), sframe->getReferenceArguments() ); pos.displaceReferenceConfiguration( i*delr, mydir ); mypdb.setAtomPositions( pos.getReferencePositions() ); - for(unsigned j=0; jgetArgumentNames()[j], pos.getReferenceArgument(j) ); - } + for(unsigned j=0; jgetArgumentNames()[j], pos.getReferenceArgument(j) ); ofile.printf("REMARK TYPE=%s\n",mtype.c_str() ); - mypdb.print( 10, NULL, ofile, ofmt ); - nframes++; + mypdb.print( 10, NULL, ofile, ofmt ); nframes++; } for(unsigned i=0; igetReferencePositions(), eframe->getReferenceArguments() ); pos.displaceReferenceConfiguration( i*delr, mydir ); mypdb.setAtomPositions( pos.getReferencePositions() ); - for(unsigned j=0; jgetArgumentNames()[j], pos.getReferenceArgument(j) ); - } + for(unsigned j=0; jgetArgumentNames()[j], pos.getReferenceArgument(j) ); ofile.printf("REMARK TYPE=%s\n",mtype.c_str() ); - mypdb.print( 10, NULL, ofile, ofmt ); - nframes++; + mypdb.print( 10, NULL, ofile, ofmt ); nframes++; } - ofile.close(); - return 0; + ofile.close(); return 0; } } // End of namespace diff --git a/src/mapping/PropertyMap.cpp b/src/mapping/PropertyMap.cpp index f454cb75b9..2a27d8f894 100644 --- a/src/mapping/PropertyMap.cpp +++ b/src/mapping/PropertyMap.cpp @@ -111,15 +111,14 @@ void PropertyMap::registerKeywords( Keywords& keys ) { PropertyMap::PropertyMap(const ActionOptions& ao): Action(ao), - PathBase(ao) { - bool nos; - parseFlag("NOMAPPING",nos); + PathBase(ao) +{ + bool nos; parseFlag("NOMAPPING",nos); std::string empty; if(!nos) { for(std::map >::iterator it=property.begin(); it!=property.end(); ++it) { - empty="LABEL="+it->first; - addVessel( "SPATH", empty, 0 ); + empty="LABEL="+it->first; addVessel( "SPATH", empty, 0 ); } } readVesselKeywords(); diff --git a/src/mapping/SpathVessel.cpp b/src/mapping/SpathVessel.cpp index 476663ffd9..891c7dedfa 100644 --- a/src/mapping/SpathVessel.cpp +++ b/src/mapping/SpathVessel.cpp @@ -52,17 +52,15 @@ void SpathVessel::reserveKeyword( Keywords& keys ) { SpathVessel::SpathVessel( const vesselbase::VesselOptions& da ): FunctionVessel(da), - foundoneclose(false) { + foundoneclose(false) +{ mymap=dynamic_cast( getAction() ); plumed_massert( mymap, "SpathVessel can only be used with mappings"); // Retrieve the index of the property in the underlying mapping - usetol=true; - norm=true; + usetol=true; norm=true; for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - if( mymap->getTaskCode(i)!=mymap->getPositionInFullTaskList(i) ) { - error("mismatched tasks and codes"); - } + if( mymap->getTaskCode(i)!=mymap->getPositionInFullTaskList(i) ) error("mismatched tasks and codes"); } } @@ -76,12 +74,9 @@ void SpathVessel::prepare() { void SpathVessel::calculate( const unsigned& current, MultiValue& myvals, std::vector& buffer, std::vector& der_index ) const { double pp=mymap->getPropertyValue( current, getLabel() ), weight=myvals.get(0); - if( weightgetNumberOfDerivatives(); - buffer[bufstart] += weight*pp; - buffer[bufstart+1+nderivatives] += weight; + buffer[bufstart] += weight*pp; buffer[bufstart+1+nderivatives] += weight; if( getAction()->derivativesAreRequired() ) { myvals.chainRule( 0, 0, 1, 0, pp, bufstart, buffer ); myvals.chainRule( 0, 1, 1, 0, 1.0, bufstart, buffer ); diff --git a/src/mapping/TrigonometricPathVessel.cpp b/src/mapping/TrigonometricPathVessel.cpp index 5d15ac757a..e882f24042 100644 --- a/src/mapping/TrigonometricPathVessel.cpp +++ b/src/mapping/TrigonometricPathVessel.cpp @@ -46,69 +46,40 @@ TrigonometricPathVessel::TrigonometricPathVessel( const vesselbase::VesselOption mydpack3( 1, getAction()->getNumberOfDerivatives() ), mypack1( 0, 0, mydpack1 ), mypack2( 0, 0, mydpack2 ), - mypack3( 0, 0, mydpack3 ) { + mypack3( 0, 0, mydpack3 ) +{ mymap=dynamic_cast( getAction() ); plumed_massert( mymap, "Trigonometric path vessel can only be used with mappings"); // Retrieve the index of the property in the underlying mapping - if( mymap->getNumberOfProperties()!=1 ) { - error("cannot use trigonometric paths when there are multiple properties"); - } + if( mymap->getNumberOfProperties()!=1 ) error("cannot use trigonometric paths when there are multiple properties"); for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - if( mymap->getTaskCode(i)!=mymap->getPositionInFullTaskList(i) ) { - error("mismatched tasks and codes"); - } + if( mymap->getTaskCode(i)!=mymap->getPositionInFullTaskList(i) ) error("mismatched tasks and codes"); } - mymap->addComponentWithDerivatives("gspath"); - mymap->componentIsNotPeriodic("gspath"); - sp=mymap->copyOutput( mymap->getNumberOfComponents()-1 ); - sp->resizeDerivatives( mymap->getNumberOfDerivatives() ); - mymap->addComponentWithDerivatives("gzpath"); - mymap->componentIsNotPeriodic("gzpath"); - zp=mymap->copyOutput( mymap->getNumberOfComponents()-1 ); - zp->resizeDerivatives( mymap->getNumberOfDerivatives() ); + mymap->addComponentWithDerivatives("gspath"); mymap->componentIsNotPeriodic("gspath"); + sp=mymap->copyOutput( mymap->getNumberOfComponents()-1 ); sp->resizeDerivatives( mymap->getNumberOfDerivatives() ); + mymap->addComponentWithDerivatives("gzpath"); mymap->componentIsNotPeriodic("gzpath"); + zp=mymap->copyOutput( mymap->getNumberOfComponents()-1 ); zp->resizeDerivatives( mymap->getNumberOfDerivatives() ); // Check we have PCA ReferenceConfiguration* ref0=mymap->getReferenceConfiguration(0); for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - if( !(mymap->getReferenceConfiguration(i))->pcaIsEnabledForThisReference() ) { - error("pca must be implemented in order to use trigometric path"); - } - if( ref0->getName()!=(mymap->getReferenceConfiguration(i))->getName() ) { - error("cannot use mixed metrics"); - } - if( mymap->getNumberOfAtoms()!=(mymap->getReferenceConfiguration(i))->getNumberOfReferencePositions() ) { - error("all frames must use the same set of atoms"); - } - if( mymap->getNumberOfArguments()!=(mymap->getReferenceConfiguration(i))->getNumberOfReferenceArguments() ) { - error("all frames must use the same set of arguments"); - } + if( !(mymap->getReferenceConfiguration(i))->pcaIsEnabledForThisReference() ) error("pca must be implemented in order to use trigometric path"); + if( ref0->getName()!=(mymap->getReferenceConfiguration(i))->getName() ) error("cannot use mixed metrics"); + if( mymap->getNumberOfAtoms()!=(mymap->getReferenceConfiguration(i))->getNumberOfReferencePositions() ) error("all frames must use the same set of atoms"); + if( mymap->getNumberOfArguments()!=(mymap->getReferenceConfiguration(i))->getNumberOfReferenceArguments() ) error("all frames must use the same set of arguments"); } - cargs.resize( mymap->getNumberOfArguments() ); - std::vector argument_names( mymap->getNumberOfArguments() ); - for(unsigned i=0; igetNumberOfArguments(); ++i) { - argument_names[i] = (mymap->getPntrToArgument(i))->getName(); - } - PDB mypdb; - mypdb.setAtomNumbers( mymap->getAbsoluteIndexes() ); - mypdb.addBlockEnd( mymap->getAbsoluteIndexes().size() ); - if( argument_names.size()>0 ) { - mypdb.setArgumentNames( argument_names ); - } + cargs.resize( mymap->getNumberOfArguments() ); std::vector argument_names( mymap->getNumberOfArguments() ); + for(unsigned i=0; igetNumberOfArguments(); ++i) argument_names[i] = (mymap->getPntrToArgument(i))->getName(); + PDB mypdb; mypdb.setAtomNumbers( mymap->getAbsoluteIndexes() ); mypdb.addBlockEnd( mymap->getAbsoluteIndexes().size() ); + if( argument_names.size()>0 ) mypdb.setArgumentNames( argument_names ); projdir.read( mypdb ); - mypack1.resize( mymap->getNumberOfArguments(), mymap->getNumberOfAtoms() ); - ref0->setupPCAStorage( mypack1 ); - mypack2.resize( mymap->getNumberOfArguments(), mymap->getNumberOfAtoms() ); - ref0->setupPCAStorage( mypack2 ); + mypack1.resize( mymap->getNumberOfArguments(), mymap->getNumberOfAtoms() ); ref0->setupPCAStorage( mypack1 ); + mypack2.resize( mymap->getNumberOfArguments(), mymap->getNumberOfAtoms() ); ref0->setupPCAStorage( mypack2 ); mypack3.resize( mymap->getNumberOfArguments(), mymap->getNumberOfAtoms() ); - for(unsigned i=0; igetNumberOfAtoms(); ++i) { - mypack1.setAtomIndex(i,i); - mypack2.setAtomIndex(i,i); - mypack3.setAtomIndex(i,i); - } - mypack1_stashd_atoms.resize( mymap->getNumberOfAtoms() ); - mypack1_stashd_args.resize( mymap->getNumberOfArguments() ); + for(unsigned i=0; igetNumberOfAtoms(); ++i) { mypack1.setAtomIndex(i,i); mypack2.setAtomIndex(i,i); mypack3.setAtomIndex(i,i); } + mypack1_stashd_atoms.resize( mymap->getNumberOfAtoms() ); mypack1_stashd_args.resize( mymap->getNumberOfArguments() ); } std::string TrigonometricPathVessel::description() { @@ -119,8 +90,7 @@ void TrigonometricPathVessel::resize() { StoreDataVessel::resize(); if( getAction()->derivativesAreRequired() ) { unsigned nderivatives=getAction()->getNumberOfDerivatives(); - sp->resizeDerivatives( nderivatives ); - zp->resizeDerivatives( nderivatives ); + sp->resizeDerivatives( nderivatives ); zp->resizeDerivatives( nderivatives ); } } @@ -128,54 +98,38 @@ void TrigonometricPathVessel::finish( const std::vector& buffer ) { // Store the data calculated during mpi loop StoreDataVessel::finish( buffer ); // Get current value of all arguments - for(unsigned i=0; igetArgument(i); - } + for(unsigned i=0; igetArgument(i); // Determine closest and second closest point to current position double lambda=mymap->getLambda(); std::vector dist( getNumberOfComponents() ), dist2( getNumberOfComponents() );; retrieveSequentialValue( 0, false, dist ); retrieveSequentialValue( 1, false, dist2 ); - iclose1=getStoreIndex(0); - iclose2=getStoreIndex(1); + iclose1=getStoreIndex(0); iclose2=getStoreIndex(1); double mindist1=dist[0], mindist2=dist2[0]; if( lambda>0.0 ) { mindist1=-std::log( dist[0] ) / lambda; mindist2=-std::log( dist2[0] ) / lambda; } if( mindist20.0 ) { - ndist=-std::log( dist[0] ) / lambda; - } + if( lambda>0.0 ) ndist=-std::log( dist[0] ) / lambda; if( ndist1 ) { - isign=1; - } else if( isign<-1 ) { - isign=-1; - } - int iclose3 = iclose1 + isign; - double v2v2; + if( isign>1 ) isign=1; else if( isign<-1 ) isign=-1; + int iclose3 = iclose1 + isign; double v2v2; // We now have to compute vectors connecting the three closest points to the // new point double v1v1 = (mymap->getReferenceConfiguration( iclose1 ))->calculate( mymap->getPositions(), mymap->getPbc(), mymap->getArguments(), mypack1, true ); @@ -195,15 +149,12 @@ void TrigonometricPathVessel::finish( const std::vector& buffer ) { } // Stash derivatives of v1v1 - for(unsigned i=0; igetNumberOfArguments(); ++i) { - mypack1_stashd_args[i]=mypack1.getArgumentDerivative(i); - } + for(unsigned i=0; igetNumberOfArguments(); ++i) mypack1_stashd_args[i]=mypack1.getArgumentDerivative(i); if( mymap->getNumberOfAtoms()>0 ) { ReferenceAtoms* at = dynamic_cast( mymap->getReferenceConfiguration( iclose1 ) ); const std::vector & displace( at->getDisplace() ); for(unsigned i=0; igetNumberOfAtoms(); ++i) { - mypack1_stashd_atoms[i]=mypack1.getAtomDerivative(i); - mypack1.getAtomsDisplacementVector()[i] /= displace[i]; + mypack1_stashd_atoms[i]=mypack1.getAtomDerivative(i); mypack1.getAtomsDisplacementVector()[i] /= displace[i]; } } // Calculate the dot product of v1 with v2 @@ -213,8 +164,7 @@ void TrigonometricPathVessel::finish( const std::vector& buffer ) { double spacing = mymap->getPropertyValue( iclose1, (mymap->property.begin())->first ) - mymap->getPropertyValue( iclose2, (mymap->property.begin())->first ); double root = sqrt( v1v2*v1v2 - v2v2 * ( v1v1 - v3v3) ); dx = 0.5 * ( (root + v1v2) / v2v2 - 1.); - double path_s = mymap->getPropertyValue(iclose1, (mymap->property.begin())->first ) + spacing * dx; - sp->set( path_s ); + double path_s = mymap->getPropertyValue(iclose1, (mymap->property.begin())->first ) + spacing * dx; sp->set( path_s ); double fact = 0.25*spacing / v2v2; // Derivative of s wrt arguments for(unsigned i=0; igetNumberOfArguments(); ++i) { @@ -222,24 +172,16 @@ void TrigonometricPathVessel::finish( const std::vector& buffer ) { + v1v2*mypack2.getArgumentDerivative(i) )/root ) ); } // Derivative of s wrt atoms - unsigned narg=mymap->getNumberOfArguments(); - Tensor vir; - vir.zero(); - fact = 0.5*spacing / v2v2; + unsigned narg=mymap->getNumberOfArguments(); Tensor vir; vir.zero(); fact = 0.5*spacing / v2v2; if( mymap->getNumberOfAtoms()>0 ) { for(unsigned i=0; igetNumberOfAtoms(); ++i) { Vector ader = fact*(( v1v2*mypack1.getAtomDerivative(i) + 0.5*v2v2*(-mypack1_stashd_atoms[i] + mypack3.getAtomDerivative(i) ) )/root + mypack1.getAtomDerivative(i) ); - for(unsigned k=0; k<3; ++k) { - sp->setDerivative( narg+3*i+k, ader[k] ); - } + for(unsigned k=0; k<3; ++k) sp->setDerivative( narg+3*i+k, ader[k] ); vir-=Tensor( mymap->getPosition(i), ader ); } // Set the virial unsigned nbase=narg+3*mymap->getNumberOfAtoms(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - sp->setDerivative( nbase+3*i+j, vir(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) sp->setDerivative( nbase+3*i+j, vir(i,j) ); } // Now compute z value ReferenceConfiguration* conf2=mymap->getReferenceConfiguration( iclose1 ); @@ -252,50 +194,33 @@ void TrigonometricPathVessel::finish( const std::vector& buffer ) { double proj = (mymap->getReferenceConfiguration(iclose1))->projectDisplacementOnVector( projdir, mymap->getArguments(), cargs, mypack1 ); double path_z = v1v1 + dx*dx*v4v4 - 2*dx*proj; // Derivatives for z path - path_z = sqrt(path_z); - zp->set( path_z ); - vir.zero(); - for(unsigned i=0; igetNumberOfArguments(); ++i) { - zp->setDerivative( i, (mypack1_stashd_args[i] - 2*dx*mypack1.getArgumentDerivative(i))/(2.0*path_z) ); - } + path_z = sqrt(path_z); zp->set( path_z ); vir.zero(); + for(unsigned i=0; igetNumberOfArguments(); ++i) zp->setDerivative( i, (mypack1_stashd_args[i] - 2*dx*mypack1.getArgumentDerivative(i))/(2.0*path_z) ); // Derivative wrt atoms if( mymap->getNumberOfAtoms()>0 ) { for(unsigned i=0; igetNumberOfAtoms(); ++i) { - Vector dxder; - for(unsigned k=0; k<3; ++k) { - dxder[k] = ( 2*v4v4*dx - 2*proj )*spacing*sp->getDerivative( narg + 3*i+k ); - } + Vector dxder; for(unsigned k=0; k<3; ++k) dxder[k] = ( 2*v4v4*dx - 2*proj )*spacing*sp->getDerivative( narg + 3*i+k ); Vector ader = ( mypack1_stashd_atoms[i] - 2.*dx*mypack1.getAtomDerivative(i) + dxder )/ (2.0*path_z); - for(unsigned k=0; k<3; ++k) { - zp->setDerivative( narg+3*i+k, ader[k] ); - } + for(unsigned k=0; k<3; ++k) zp->setDerivative( narg+3*i+k, ader[k] ); vir-=Tensor( mymap->getPosition(i), ader ); } // Set the virial unsigned nbase=narg+3*mymap->getNumberOfAtoms(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - zp->setDerivative( nbase+3*i+j, vir(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) zp->setDerivative( nbase+3*i+j, vir(i,j) ); } } bool TrigonometricPathVessel::applyForce( std::vector& forces ) { std::vector tmpforce( forces.size(), 0.0 ); - forces.assign(forces.size(),0.0); - bool wasforced=false; + forces.assign(forces.size(),0.0); bool wasforced=false; if( sp->applyForce( tmpforce ) ) { wasforced=true; - for(unsigned j=0; japplyForce( tmpforce ) ) { wasforced=true; - for(unsigned j=0; j( getAction() ); plumed_massert( mymap, "ZpathVessel should only be used with mappings"); - invlambda = 1.0 / mymap->getLambda(); - usetol=true; + invlambda = 1.0 / mymap->getLambda(); usetol=true; } std::string ZpathVessel::value_descriptor() { @@ -62,8 +62,7 @@ std::string ZpathVessel::value_descriptor() { } double ZpathVessel::calcTransform( const double& val, double& dv ) const { - dv=0.0; - return 1.0; + dv=0.0; return 1.0; } double ZpathVessel::finalTransform( const double& val, double& dv ) { diff --git a/src/maze/Loss.cpp b/src/maze/Loss.cpp index 41ade9cd0c..78addfada0 100644 --- a/src/maze/Loss.cpp +++ b/src/maze/Loss.cpp @@ -72,7 +72,8 @@ void Loss::registerKeywords(Keywords& keys) { } Loss::Loss(const ActionOptions& ao) - : PLUMED_COLVAR_INIT(ao) { + : PLUMED_COLVAR_INIT(ao) +{ if (keywords.exists("PARAMS")) { parseVector("PARAMS", params_); diff --git a/src/maze/Memetic.cpp b/src/maze/Memetic.cpp index 7cc61c6534..36774e55e7 100644 --- a/src/maze/Memetic.cpp +++ b/src/maze/Memetic.cpp @@ -147,7 +147,8 @@ Memetic::Memetic(const ActionOptions& ao) score_best_(0), adaptation_(true), coding_len_(3), - local_search_on_(false) { + local_search_on_(false) +{ log.printf("maze> Memetic sampling.\n"); if (keywords.exists("CAPACITY")) { diff --git a/src/maze/Memetic.h b/src/maze/Memetic.h index 695584d07b..439f72cb3b 100644 --- a/src/maze/Memetic.h +++ b/src/maze/Memetic.h @@ -357,9 +357,7 @@ void Memetic::sort_members() { } double Memetic::score_mean() { - auto acc = [](double s, const Member& m) { - return s + m.score; - }; + auto acc = [](double s, const Member& m) { return s + m.score; }; return std::accumulate( members_.begin(), @@ -442,7 +440,8 @@ void Memetic::mutation(std::vector& m) { void Memetic::stochastic_hill_climbing( Member& m, - const std::vector& params) { + const std::vector& params) +{ for (std::size_t i = 0; i < n_local_iterations_; ++i) { Member n; n.translation = m.translation; @@ -457,7 +456,8 @@ void Memetic::stochastic_hill_climbing( void Memetic::random_restart_hill_climbing( Member& m, - const std::vector& params) { + const std::vector& params) +{ unsigned int n_restarts = static_cast(params[0]); std::vector s(n_restarts); unsigned int ndx = 0; @@ -479,7 +479,8 @@ void Memetic::random_restart_hill_climbing( void Memetic::annealing( Member& m, - const std::vector& params) { + const std::vector& params) +{ double T = params[0]; double alpha = params[1]; @@ -505,13 +506,15 @@ void Memetic::annealing( void Memetic::luus_jaakola( Member& m, - const std::vector& params) { + const std::vector& params) +{ /* TODO */ } void Memetic::adaptive_random_search( Member& m, - const std::vector& params) { + const std::vector& params) +{ double rho_start = params[0]; double rho_lower_bound = params[1]; double ex = params[2]; @@ -530,7 +533,8 @@ void Memetic::adaptive_random_search( while (rho_k > rho_lower_bound && k < n_local_iterations_) { if (ns >= s_ex) { rho_k *= ex; - } else if (nf >= f_ct) { + } + else if (nf >= f_ct) { rho_k *= ct; } @@ -554,7 +558,8 @@ void Memetic::adaptive_random_search( bk[i] = 0.2 * bk[i] + 0.4 * (chi[i] - xk[i]); xk[i] = chi[i]; } - } else if (score_tmp < score_xk && score_xk <= score_chi) { + } + else if (score_tmp < score_xk && score_xk <= score_chi) { ns++; nf = 0; @@ -562,7 +567,8 @@ void Memetic::adaptive_random_search( bk[i] = bk[i] - 0.4 * (chi[i] - xk[i]); xk[i] = 2.0 * xk[i] - chi[i]; } - } else { + } + else { ns = 0; nf++; @@ -585,13 +591,12 @@ void Memetic::local_search(std::vector& m) { double probability = rnd::next_double(); if (probability < local_search_rate_) { - if (local_search_type_ == "stochastic_hill_climbing") { + if (local_search_type_ == "stochastic_hill_climbing") stochastic_hill_climbing(m[i]); - } else if (local_search_type_ == "adaptive_random_search") { + else if (local_search_type_ == "adaptive_random_search") adaptive_random_search(m[i]); - } else if (local_search_type_ == "random_restart_hill_climbing") { + else if (local_search_type_ == "random_restart_hill_climbing") random_restart_hill_climbing(m[i]); - } } } } @@ -616,7 +621,8 @@ void Memetic::mating(std::vector& m) { if (i > j) { m.erase(m.begin() + i); m.erase(m.begin() + j); - } else if (j > i) { + } + else if (j > i) { m.erase(m.begin() + j); m.erase(m.begin() + i); } @@ -666,7 +672,8 @@ double Memetic::score_member(const Vector& coding) { if (pbc_) { distance = pbcDistance(getPosition(i0) + dev, getPosition(i1)); - } else { + } + else { distance = delta(getPosition(i0) + dev, getPosition(i1)); } diff --git a/src/maze/Optimizer.cpp b/src/maze/Optimizer.cpp index 8b3565576b..56d29ac54f 100644 --- a/src/maze/Optimizer.cpp +++ b/src/maze/Optimizer.cpp @@ -145,7 +145,8 @@ Optimizer::Optimizer(const ActionOptions& ao) sampling_r_(0.0), serial_(false), validate_list_(true), - first_time_(true) { + first_time_(true) +{ parseFlag("SERIAL", serial_); if (keywords.exists("LOSS")) { @@ -235,7 +236,8 @@ Optimizer::Optimizer(const ActionOptions& ao) nl_cutoff_, nl_stride_ ); - } else { + } + else { neighbor_list_=Tools::make_unique( ga_list, gb_list, @@ -246,7 +248,8 @@ Optimizer::Optimizer(const ActionOptions& ao) comm ); } - } else { + } + else { if (do_neigh) { neighbor_list_ = Tools::make_unique( ga_list, @@ -257,7 +260,8 @@ Optimizer::Optimizer(const ActionOptions& ao) nl_cutoff_, nl_stride_ ); - } else { + } + else { neighbor_list_=Tools::make_unique( ga_list, serial_, @@ -292,7 +296,8 @@ Optimizer::Optimizer(const ActionOptions& ao) if (pbc_) { log.printf("maze> Using periodic boundary conditions.\n"); - } else { + } + else { log.printf("maze> Without periodic boundary conditions.\n"); } @@ -390,7 +395,8 @@ void Optimizer::prepare() { validate_list_ = true; first_time_ = false; - } else { + } + else { requestAtoms(neighbor_list_->getReducedAtomList()); validate_list_ = false; @@ -426,7 +432,8 @@ double Optimizer::score() { if (pbc_) { distance = pbcDistance(getPosition(i0), getPosition(i1)); - } else { + } + else { distance = delta(getPosition(i0), getPosition(i1)); } @@ -443,7 +450,8 @@ void Optimizer::update_nl() { } } -double Optimizer::sampling_radius() { +double Optimizer::sampling_radius() +{ const unsigned nl_size=neighbor_list_->size(); Vector d; double min=std::numeric_limits::max(); @@ -458,7 +466,8 @@ double Optimizer::sampling_radius() { if (pbc_) { d = pbcDistance(getPosition(i0), getPosition(i1)); - } else { + } + else { d = delta(getPosition(i0), getPosition(i1)); } @@ -484,7 +493,8 @@ void Optimizer::calculate() { value_action_->set(score()); value_sampling_radius_->set(sampling_radius()); - } else { + } + else { first_step_=false; value_x_->set(opt_[0]); diff --git a/src/maze/Optimizer_Bias.cpp b/src/maze/Optimizer_Bias.cpp index 0a6e12566d..9c6b0fac24 100644 --- a/src/maze/Optimizer_Bias.cpp +++ b/src/maze/Optimizer_Bias.cpp @@ -262,7 +262,8 @@ OptimizerBias::OptimizerBias(const ActionOptions& ao) : PLUMED_BIAS_INIT(ao), bias_(0.0), force_(0.0), - total_distance_(0.0) { + total_distance_(0.0) +{ log.printf( "maze> You are using the maze module of PLUMED2,\ please read and cite " diff --git a/src/maze/Random_Acceleration_MD.cpp b/src/maze/Random_Acceleration_MD.cpp index 7eae952b48..741fda6e95 100644 --- a/src/maze/Random_Acceleration_MD.cpp +++ b/src/maze/Random_Acceleration_MD.cpp @@ -180,7 +180,8 @@ void Random_Acceleration_MD::optimize() { if (pbc_) { d = pbcDistance(c, com_); - } else { + } + else { d = delta(c, com_); } diff --git a/src/maze/Random_Walk.cpp b/src/maze/Random_Walk.cpp index 6d4e2ab6f2..5d82c456e4 100644 --- a/src/maze/Random_Walk.cpp +++ b/src/maze/Random_Walk.cpp @@ -103,7 +103,8 @@ void Random_Walk::registerKeywords(Keywords& keys) { } Random_Walk::Random_Walk(const ActionOptions& ao) - : PLUMED_OPT_INIT(ao) { + : PLUMED_OPT_INIT(ao) +{ log.printf("maze> Fake optimizer that returns a next step as random,\ can be used to monitor loss, and for debugging and regtests purposes.\n"); diff --git a/src/maze/Simulated_Annealing.cpp b/src/maze/Simulated_Annealing.cpp index 48090e536b..4edf3003cc 100644 --- a/src/maze/Simulated_Annealing.cpp +++ b/src/maze/Simulated_Annealing.cpp @@ -143,7 +143,8 @@ void Simulated_Annealing::registerKeywords(Keywords& keys) { } Simulated_Annealing::Simulated_Annealing(const ActionOptions& ao) - : PLUMED_OPT_INIT(ao) { + : PLUMED_OPT_INIT(ao) +{ log.printf("maze> Simulated annealing optimizer.\n"); if(keywords.exists("COOLING")) { @@ -183,13 +184,17 @@ Simulated_Annealing::Simulated_Annealing(const ActionOptions& ao) void Simulated_Annealing::decrease_probability(unsigned int time) { if (cooling_scheme_ == "linear") { probability_decreaser_ -= time * cooling_factor_; - } else if (cooling_scheme_ == "exponential") { + } + else if (cooling_scheme_ == "exponential") { probability_decreaser_ *= pow(cooling_factor_, time); - } else if (cooling_scheme_ == "geometric") { + } + else if (cooling_scheme_ == "geometric") { probability_decreaser_ *= cooling_factor_; - } else if (cooling_scheme_ == "logarithmic") { + } + else if (cooling_scheme_ == "logarithmic") { probability_decreaser_ = cooling_factor_ / std::log(time + 1); - } else if (cooling_scheme_ == "hoffman") { + } + else if (cooling_scheme_ == "hoffman") { probability_decreaser_ = (cooling_factor_ - 1) / std::log(time); } } @@ -229,7 +234,8 @@ void Simulated_Annealing::optimize() { getPosition(i0) + dev, getPosition(i1) ); - } else { + } + else { distance = delta( getPosition(i0) + get_opt(), getPosition(i1) diff --git a/src/maze/Steered_MD.cpp b/src/maze/Steered_MD.cpp index 74854ab181..867c354f2c 100644 --- a/src/maze/Steered_MD.cpp +++ b/src/maze/Steered_MD.cpp @@ -124,7 +124,8 @@ void Steered_MD::registerKeywords(Keywords& keys) { Steered_MD::Steered_MD(const ActionOptions& ao) : PLUMED_OPT_INIT(ao), - total_dist_(0.0) { + total_dist_(0.0) +{ log.printf("maze> Steered MD.\n"); if (keywords.exists("PULLING")) { @@ -156,7 +157,8 @@ void Steered_MD::optimize() { if (pbc_) { d = pbcDistance(c, com_); - } else { + } + else { d = delta(c, com_); } diff --git a/src/maze/Tools.h b/src/maze/Tools.h index b09bf141d6..d20694cd4e 100644 --- a/src/maze/Tools.h +++ b/src/maze/Tools.h @@ -106,9 +106,8 @@ template std::vector tls::vector_n(const std::vector& v) { double l=vector_l(v); std::vector n; - for(std::size_t i=0; i tls::get_labels_actions(const ActionSet& actionset) { std::vector action_str(0); std::vector action_pntrs=actionset.select(); - for(unsigned int i=0; igetLabel()); - } return action_str; } @@ -169,9 +167,8 @@ std::vector tls::get_pointers_labels( for(unsigned int i=0; i(action_labels[i]); - if(action_pntrs[i]==NULL) { + if(action_pntrs[i]==NULL) missing.push_back(action_labels[i]); - } } return action_pntrs; diff --git a/src/membranefusion/FusionPoreExpansionP.cpp b/src/membranefusion/FusionPoreExpansionP.cpp index dc2b988b08..5fbc9367f0 100644 --- a/src/membranefusion/FusionPoreExpansionP.cpp +++ b/src/membranefusion/FusionPoreExpansionP.cpp @@ -27,8 +27,10 @@ along with plumed. If not, see . #endif #endif -namespace PLMD { -namespace membranefusion { +namespace PLMD +{ +namespace membranefusion +{ //+PLUMEDOC MEMBRANEFUSIONMOD_COLVAR FUSIONPOREEXPANSIONP /* A CV for inducing the expansion of a fusion pore from a nucleated fusion pore. @@ -69,7 +71,8 @@ PRINT ARG=fusionPoreExpansion FILE=COLVAR STRIDE=1 */ //+ENDPLUMEDOC -class fusionPoreExpansionP : public Colvar { +class fusionPoreExpansionP : public Colvar +{ std::vector UMEM, LMEM, TAILS, WATERS, POXYGENS; std::vector NSMEM, DSMEM, HMEM, VO, D, H, RMAX, R0, XCYL, YCYL; @@ -81,7 +84,8 @@ class fusionPoreExpansionP : public Colvar { PLUMED_REGISTER_ACTION(fusionPoreExpansionP, "FUSIONPOREEXPANSIONP") -void fusionPoreExpansionP::registerKeywords(Keywords &keys) { +void fusionPoreExpansionP::registerKeywords(Keywords &keys) +{ Colvar::registerKeywords(keys); keys.add("atoms", "UMEMBRANE", "all the beads of the upper membrane."); keys.add("atoms", "LMEMBRANE", "all the beads of the lower membrane."); @@ -100,119 +104,103 @@ void fusionPoreExpansionP::registerKeywords(Keywords &keys) { keys.add("optional", "YCYL", "X coordinate of the fixed cylinder, if not present this will be calculated."); } -fusionPoreExpansionP::fusionPoreExpansionP(const ActionOptions &ao) : PLUMED_COLVAR_INIT(ao) { +fusionPoreExpansionP::fusionPoreExpansionP(const ActionOptions &ao) : PLUMED_COLVAR_INIT(ao) +{ parseAtomList("UMEMBRANE", UMEM); - if (UMEM.size() == 0) { + if (UMEM.size() == 0) error("UMEMBRANE has not any atom specified."); - } parseAtomList("LMEMBRANE", LMEM); - if (LMEM.size() == 0) { + if (LMEM.size() == 0) error("LMEMBRANE has not any atom specified."); - } parseAtomList("TAILS", TAILS); - if (TAILS.size() == 0) { + if (TAILS.size() == 0) error("TAILS has not any atom specified."); - } parseAtomList("WATERS", WATERS); - if (WATERS.size() == 0) { + if (WATERS.size() == 0) error("WATERS has not any atom specified."); - } parseAtomList("PHOSPHATEOXYGENS", POXYGENS); - if (POXYGENS.size() == 0) { + if (POXYGENS.size() == 0) error("PHOSPHATEOXYGENS has not any atom specified."); - } parseVector("NSMEM", NSMEM); - if (NSMEM.size() > 1) { + if (NSMEM.size() > 1) error("NSMEM cannot take more than one value."); - } parseVector("DSMEM", DSMEM); - if (DSMEM.size() > 1) { + if (DSMEM.size() > 1) error("DSMEM cannot take more than one value."); - } - if (DSMEM.size() == 0) { + if (DSMEM.size() == 0) DSMEM.push_back(0.1); - } parseVector("HMEM", HMEM); - if (HMEM.size() > 1) { + if (HMEM.size() > 1) error("HMEM cannot take more than one value."); - } - if (HMEM.size() == 0) { + if (HMEM.size() == 0) HMEM.push_back(0.25); - } parseVector("VO", VO); - if (VO.size() > 1) { + if (VO.size() > 1) error("VO cannot take more than one value."); - } - if (VO.size() == 0) { + if (VO.size() == 0) VO.push_back(0.076879); - } parseVector("D", D); - if (D.size() > 1) { + if (D.size() > 1) error("D cannot take more than one value."); - } parseVector("H", H); - if (H.size() > 1) { + if (H.size() > 1) error("H cannot take more than one value."); - } - if (H.size() == 0) { + if (H.size() == 0) H.push_back(0.1); - } parseVector("RMAX", RMAX); - if (RMAX.size() > 1) { + if (RMAX.size() > 1) error("RMAX cannot take more than one value."); - } - if (RMAX.size() == 0) { + if (RMAX.size() == 0) RMAX.push_back(2.5); - } parseVector("R0", R0); - if (R0.size() > 1) { + if (R0.size() > 1) error("R0 cannot take more than one value."); - } parseVector("XCYL", XCYL); - if (XCYL.size() > 1) { + if (XCYL.size() > 1) error("XCYL cannot take more than one value."); - } - if (XCYL.size() == 0) { + if (XCYL.size() == 0) XCYL.push_back(-1.0); - } parseVector("YCYL", YCYL); - if (YCYL.size() > 1) { + if (YCYL.size() > 1) error("YCYL cannot take more than one value."); - } - if (YCYL.size() == 0) { + if (YCYL.size() == 0) YCYL.push_back(-1.0); - } checkRead(); std::vector atoms; - for (unsigned i = 0; i < UMEM.size(); i++) { + for (unsigned i = 0; i < UMEM.size(); i++) + { atoms.push_back(UMEM[i]); } - for (unsigned i = 0; i < LMEM.size(); i++) { + for (unsigned i = 0; i < LMEM.size(); i++) + { atoms.push_back(LMEM[i]); } - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { atoms.push_back(TAILS[i]); } - for (unsigned i = 0; i < WATERS.size(); i++) { + for (unsigned i = 0; i < WATERS.size(); i++) + { atoms.push_back(WATERS[i]); } - for (unsigned i = 0; i < POXYGENS.size(); i++) { + for (unsigned i = 0; i < POXYGENS.size(); i++) + { atoms.push_back(POXYGENS[i]); } @@ -220,7 +208,8 @@ fusionPoreExpansionP::fusionPoreExpansionP(const ActionOptions &ao) : PLUMED_COL setNotPeriodic(); requestAtoms(atoms); } -void fusionPoreExpansionP::calculate() { +void fusionPoreExpansionP::calculate() +{ /************************* * * * System * @@ -238,7 +227,8 @@ void fusionPoreExpansionP::calculate() { #pragma omp parallel for private(uMemAngle, lMemAngle) reduction(+:ZuMemcos, ZuMemsin, ZlMemcos, ZlMemsin) #endif #endif - for (unsigned i = 0; i < UMEM.size(); i++) { + for (unsigned i = 0; i < UMEM.size(); i++) + { uMemAngle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i)))[2]; lMemAngle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + UMEM.size())))[2]; ZuMemcos += cos(uMemAngle); @@ -317,36 +307,48 @@ void fusionPoreExpansionP::calculate() { #pragma omp parallel for private(ZTailDistance, PositionS_Mem, TailPosition, x, aux, s1_Mem, s2_Mem) reduction(vec_double_plus:Fs_Mem, sx_Mem, sy_Mem, cx_Mem, cy_Mem) #endif #endif - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { ZTailDistance = pbcDistance(Vector(0.0, 0.0, ZMems), getPosition(i + membraneBeads))[2]; PositionS_Mem = (ZTailDistance + firstSliceZDist_Mem) / DSMEM[0]; // If the following condition is met the particle is in the Z space of the cylinder. - if ((PositionS_Mem >= (-0.5 - HMEM[0])) && (PositionS_Mem <= (NSMEM[0] + 0.5 - 1.0 + HMEM[0]))) { + if ((PositionS_Mem >= (-0.5 - HMEM[0])) && (PositionS_Mem <= (NSMEM[0] + 0.5 - 1.0 + HMEM[0]))) + { //Defining the slices to analyze each particle. - if (PositionS_Mem < 1) { + if (PositionS_Mem < 1) + { s1_Mem = 0; s2_Mem = 2; - } else if (PositionS_Mem <= (NSMEM[0] - 2.0)) { + } + else if (PositionS_Mem <= (NSMEM[0] - 2.0)) + { s1_Mem = floor(PositionS_Mem) - 1; s2_Mem = floor(PositionS_Mem) + 1; - } else { + } + else + { s1_Mem = NSMEM[0] - 3; s2_Mem = NSMEM[0] - 1; } TailPosition = getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + membraneBeads))); - for (unsigned s = s1_Mem; s <= s2_Mem; s++) { + for (unsigned s = s1_Mem; s <= s2_Mem; s++) + { x = (ZTailDistance - (s + 0.5 - NSMEM[0] / 2.0) * DSMEM[0]) * 2.0 / DSMEM[0]; - if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) { - if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) { + if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) + { + if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) + { faxial_Mem[i + TAILS.size() * s] = 1.0; Fs_Mem[s] += 1.0; sx_Mem[s] += sin(2.0 * M_PI * TailPosition[0]); sy_Mem[s] += sin(2.0 * M_PI * TailPosition[1]); cx_Mem[s] += cos(2.0 * M_PI * TailPosition[0]); cy_Mem[s] += cos(2.0 * M_PI * TailPosition[1]); - } else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) { + } + else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) + { aux = 0.5 - ((3.0 * x - 3.0) / (4.0 * HMEM[0])) + (pow((x - 1.0), 3) / (4.0 * pow(HMEM[0], 3))); faxial_Mem[i + TAILS.size() * s] = aux; Fs_Mem[s] += aux; @@ -354,7 +356,9 @@ void fusionPoreExpansionP::calculate() { sy_Mem[s] += aux * sin(2.0 * M_PI * TailPosition[1]); cx_Mem[s] += aux * cos(2.0 * M_PI * TailPosition[0]); cy_Mem[s] += aux * cos(2.0 * M_PI * TailPosition[1]); - } else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) { + } + else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) + { aux = 0.5 + ((3.0 * x + 3.0) / (4.0 * HMEM[0])) - (pow((x + 1.0), 3) / (4.0 * pow(HMEM[0], 3))); faxial_Mem[i + TAILS.size() * s] = aux; Fs_Mem[s] += aux; @@ -368,8 +372,10 @@ void fusionPoreExpansionP::calculate() { } } - for (unsigned s = 0; s < NSMEM[0]; s++) { - if (Fs_Mem[s] != 0.0) { + for (unsigned s = 0; s < NSMEM[0]; s++) + { + if (Fs_Mem[s] != 0.0) + { ws_Mem[s] = tanh(Fs_Mem[s]); W_Mem += ws_Mem[s]; sx_Mem[s] = sx_Mem[s] / Fs_Mem[s]; @@ -391,10 +397,13 @@ void fusionPoreExpansionP::calculate() { // Eq. 12 Hub & Awasthi JCTC 2017. double Xcyl_Mem, Ycyl_Mem; - if ((XCYL[0] > 0.0) && (YCYL[0] > 0.0)) { + if ((XCYL[0] > 0.0) && (YCYL[0] > 0.0)) + { Xcyl_Mem = XCYL[0]; Ycyl_Mem = YCYL[0]; - } else { + } + else + { Xcyl_Mem = (atan2(-Xsc_Mem, -Xcc_Mem) + M_PI) * Lx / (2 * M_PI); Ycyl_Mem = (atan2(-Ysc_Mem, -Ycc_Mem) + M_PI) * Ly / (2 * M_PI); } @@ -457,22 +466,29 @@ void fusionPoreExpansionP::calculate() { #pragma omp parallel for private(MemCylDistances, x, angle, auxcos, auxsin) reduction(+:ZMemRMAXcos, ZMemRMAXsin, countAux) #endif #endif - for (unsigned i = 0; i < membraneBeads; i++) { + for (unsigned i = 0; i < membraneBeads; i++) +{ MemCylDistances = pbcDistance(xyzCyl, pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i))); x = sqrt(pow(MemCylDistances[0], 2) + pow(MemCylDistances[1], 2)) / RMAX[0]; - if (!((x <= -1.0 - H[0]) || (x >= 1.0 + H[0]))) { + if (!((x <= -1.0 - H[0]) || (x >= 1.0 + H[0]))) + { angle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i)))[2]; auxcos = cos(angle); auxsin = sin(angle); - if (((-1.0 + H[0]) <= x) && (x <= (1.0 - H[0]))) { + if (((-1.0 + H[0]) <= x) && (x <= (1.0 - H[0]))) + { ZMemRMAXcos += 1.0 * auxcos; ZMemRMAXsin += 1.0 * auxsin; countAux += 1.0; - } else if (((1.0 - H[0]) < x) && (x < (1.0 + H[0]))) { + } + else if (((1.0 - H[0]) < x) && (x < (1.0 + H[0]))) + { ZMemRMAXcos += (0.5 - 0.75 * (x - 1.0) / H[0] + 0.25 * pow((x - 1.0), 3) / pow(H[0], 3)) * auxcos; ZMemRMAXsin += (0.5 - 0.75 * (x - 1.0) / H[0] + 0.25 * pow((x - 1.0), 3) / pow(H[0], 3)) * auxsin; countAux += (0.5 - 0.75 * (x - 1.0) / H[0] + 0.25 * pow((x - 1.0), 3) / pow(H[0], 3)); - } else if (((-1.0 - H[0]) < x) && (x < (-1.0 + H[0]))) { + } + else if (((-1.0 - H[0]) < x) && (x < (-1.0 + H[0]))) + { ZMemRMAXcos += (0.5 + 0.75 * (x + 1.0) / H[0] - 0.25 * pow((x + 1.0), 3) / pow(H[0], 3)) * auxcos; ZMemRMAXsin += (0.5 + 0.75 * (x + 1.0) / H[0] - 0.25 * pow((x + 1.0), 3) / pow(H[0], 3)) * auxsin; countAux += (0.5 + 0.75 * (x + 1.0) / H[0] - 0.25 * pow((x + 1.0), 3) / pow(H[0], 3)); @@ -491,7 +507,8 @@ void fusionPoreExpansionP::calculate() { #pragma omp parallel for private(distCylinder, fz, fz_prime, fr, fr_prime, ri, x) reduction(+:np) #endif #endif - for (unsigned i = 0; i < chainBeads; i++) { + for (unsigned i = 0; i < chainBeads; i++) +{ distCylinder = pbcDistance(xyzCyl, pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + noChainBeads))); fz = 0.0; fz_prime = 0.0; @@ -500,25 +517,37 @@ void fusionPoreExpansionP::calculate() { ri = sqrt(pow(distCylinder[0], 2) + pow(distCylinder[1], 2)); x = ri / RMAX[0]; - if (!((x <= -1.0 - H[0]) || (x >= 1.0 + H[0]))) { - if (((-1.0 + H[0]) <= x) && (x <= (1.0 - H[0]))) { + if (!((x <= -1.0 - H[0]) || (x >= 1.0 + H[0]))) + { + if (((-1.0 + H[0]) <= x) && (x <= (1.0 - H[0]))) + { fr = 1.0; - } else if (((1.0 - H[0]) < x) && (x < (1.0 + H[0]))) { + } + else if (((1.0 - H[0]) < x) && (x < (1.0 + H[0]))) + { fr = 0.5 - 0.75 * (x - 1.0) / H[0] + 0.25 * pow((x - 1.0), 3) / pow(H[0], 3); fr_prime = (-0.75 / H[0] + 0.75 * pow((x - 1.0), 2) / pow(H[0], 3)) / (RMAX[0] * ri); - } else if (((-1.0 - H[0]) < x) && (x < (-1.0 + H[0]))) { + } + else if (((-1.0 - H[0]) < x) && (x < (-1.0 + H[0]))) + { fr = 0.5 + 0.75 * (x + 1.0) / H[0] - 0.25 * pow((x + 1.0), 3) / pow(H[0], 3); fr_prime = (0.75 / H[0] - 0.75 * pow((x + 1), 2) / pow(H[0], 3)) / (RMAX[0] * ri); } x = distCylinder[2] * 2.0 / D[0]; - if (!((x <= -1.0 - H[0]) || (x >= 1.0 + H[0]))) { - if (((-1.0 + H[0]) <= x) && (x <= (1.0 - H[0]))) { + if (!((x <= -1.0 - H[0]) || (x >= 1.0 + H[0]))) + { + if (((-1.0 + H[0]) <= x) && (x <= (1.0 - H[0]))) + { fz = 1.0; - } else if (((1.0 - H[0]) < x) && (x < (1.0 + H[0]))) { + } + else if (((1.0 - H[0]) < x) && (x < (1.0 + H[0]))) + { fz = 0.5 - 0.75 * (x - 1.0) / H[0] + 0.25 * pow((x - 1.0), 3) / pow(H[0], 3); fz_prime = (-0.75 / H[0] + 0.75 * pow((x - 1.0), 2) / pow(H[0], 3)) * 2.0 / D[0]; - } else if (((-1.0 - H[0]) < x) && (x < (-1.0 + H[0]))) { + } + else if (((-1.0 - H[0]) < x) && (x < (-1.0 + H[0]))) + { fz = 0.5 + 0.75 * (x + 1.0) / H[0] - 0.25 * pow((x + 1.0), 3) / pow(H[0], 3); fz_prime = (0.75 / H[0] - 0.75 * pow((x + 1), 2) / pow(H[0], 3)) * 2.0 / D[0]; } @@ -541,7 +570,8 @@ void fusionPoreExpansionP::calculate() { // Aux for the derivatives calculations. Eq. 7 Hub 2021 JCTC. double fact2 = 0.0; - if (poreR != 0.0) { + if (poreR != 0.0) +{ fact2 = VO[0] / (2.0 * M_PI * RO * D[0] * poreR); } @@ -553,7 +583,8 @@ void fusionPoreExpansionP::calculate() { #pragma omp parallel for #endif #endif - for (unsigned i = 0; i < chainBeads; i++) { + for (unsigned i = 0; i < chainBeads; i++) +{ derivatives[i][0] = fact2 * d_np_dx[i]; derivatives[i][1] = fact2 * d_np_dy[i]; derivatives[i][2] = fact2 * d_np_dz[i]; @@ -561,7 +592,8 @@ void fusionPoreExpansionP::calculate() { } Tensor virial; - for (unsigned i = 0; i < chainBeads; i++) { + for (unsigned i = 0; i < chainBeads; i++) +{ setAtomsDerivatives((i + noChainBeads), derivatives[i]); virial -= Tensor(CylDistances[i], derivatives[i]); } diff --git a/src/membranefusion/FusionPoreNucleationP.cpp b/src/membranefusion/FusionPoreNucleationP.cpp index 4999ed541f..02569c0846 100644 --- a/src/membranefusion/FusionPoreNucleationP.cpp +++ b/src/membranefusion/FusionPoreNucleationP.cpp @@ -27,8 +27,10 @@ along with plumed. If not, see . #endif #endif -namespace PLMD { -namespace membranefusion { +namespace PLMD +{ +namespace membranefusion +{ //+PLUMEDOC MEMBRANEFUSIONMOD_COLVAR FUSIONPORENUCLEATIONP /* A CV for inducing the nucleation of the fusion pore from a hemifusion stalk. @@ -72,7 +74,8 @@ PRINT ARG=fusionPoreNucleation FILE=COLVAR STRIDE=1 */ //+ENDPLUMEDOC -class fusionPoreNucleationP : public Colvar { +class fusionPoreNucleationP : public Colvar +{ std::vector UMEM, LMEM, TAILS, WATERS, POXYGENS; std::vector NSMEM, DSMEM, HMEM, NS, DS, HCH, RCYL, ZETA, ONEOVERS2C2CUTOFF, XCYL, YCYL; @@ -84,7 +87,8 @@ class fusionPoreNucleationP : public Colvar { PLUMED_REGISTER_ACTION(fusionPoreNucleationP, "FUSIONPORENUCLEATIONP") -void fusionPoreNucleationP::registerKeywords(Keywords &keys) { +void fusionPoreNucleationP::registerKeywords(Keywords &keys) +{ Colvar::registerKeywords(keys); keys.add("atoms", "UMEMBRANE", "all the beads of the upper membrane."); keys.add("atoms", "LMEMBRANE", "all the beads of the lower membrane."); @@ -104,130 +108,111 @@ void fusionPoreNucleationP::registerKeywords(Keywords &keys) { keys.add("optional", "YCYL", "X coordinate of the fixed cylinder, if not present this will be calculated."); } -fusionPoreNucleationP::fusionPoreNucleationP(const ActionOptions &ao) : PLUMED_COLVAR_INIT(ao) { +fusionPoreNucleationP::fusionPoreNucleationP(const ActionOptions &ao) : PLUMED_COLVAR_INIT(ao) +{ parseAtomList("UMEMBRANE", UMEM); - if (UMEM.size() == 0) { + if (UMEM.size() == 0) error("UMEMBRANE has not any atom specified."); - } parseAtomList("LMEMBRANE", LMEM); - if (LMEM.size() == 0) { + if (LMEM.size() == 0) error("LMEMBRANE has not any atom specified."); - } parseAtomList("TAILS", TAILS); - if (TAILS.size() == 0) { + if (TAILS.size() == 0) error("TAILS has not any atom specified."); - } parseAtomList("WATERS", WATERS); - if (WATERS.size() == 0) { + if (WATERS.size() == 0) error("WATERS has not any atom specified."); - } parseAtomList("PHOSPHATEOXYGENS", POXYGENS); - if (POXYGENS.size() == 0) { + if (POXYGENS.size() == 0) error("PHOSPHATEOXYGENS has not any atom specified."); - } parseVector("NSMEM", NSMEM); - if (NSMEM.size() > 1) { + if (NSMEM.size() > 1) error("NSMEM cannot take more than one value."); - } parseVector("DSMEM", DSMEM); - if (DSMEM.size() > 1) { + if (DSMEM.size() > 1) error("DSMEM cannot take more than one value."); - } - if (DSMEM.size() == 0) { + if (DSMEM.size() == 0) DSMEM.push_back(0.1); - } parseVector("HMEM", HMEM); - if (HMEM.size() > 1) { + if (HMEM.size() > 1) error("HMEM cannot take more than one value."); - } - if (HMEM.size() == 0) { + if (HMEM.size() == 0) HMEM.push_back(0.25); - } parseVector("NS", NS); - if (NS.size() > 1) { + if (NS.size() > 1) error("NS cannot take more than one value."); - } parseVector("DS", DS); - if (DS.size() > 1) { + if (DS.size() > 1) error("DS cannot take more than one value."); - } - if (DS.size() == 0) { + if (DS.size() == 0) DS.push_back(0.25); - } parseVector("HCH", HCH); - if (HCH.size() > 1) { + if (HCH.size() > 1) error("H cannot take more than one value."); - } - if (HCH.size() == 0) { + if (HCH.size() == 0) HCH.push_back(0.25); - } parseVector("RCYL", RCYL); - if (RCYL.size() > 1) { + if (RCYL.size() > 1) error("RCYL cannot take more than one value."); - } - if (RCYL.size() == 0) { + if (RCYL.size() == 0) RCYL.push_back(0.8); - } parseVector("ZETA", ZETA); - if (ZETA.size() > 1) { + if (ZETA.size() > 1) error("ZETA cannot take more than one value."); - } - if (ZETA.size() == 0) { + if (ZETA.size() == 0) ZETA.push_back(0.75); - } parseVector("ONEOVERS2C2CUTOFF", ONEOVERS2C2CUTOFF); - if (ONEOVERS2C2CUTOFF.size() > 1) { + if (ONEOVERS2C2CUTOFF.size() > 1) error("ONEOVERS2C2CUTOFF cannot take more than one value."); - } - if (ONEOVERS2C2CUTOFF.size() == 0) { + if (ONEOVERS2C2CUTOFF.size() == 0) ONEOVERS2C2CUTOFF.push_back(500); - } parseVector("XCYL", XCYL); - if (XCYL.size() > 1) { + if (XCYL.size() > 1) error("XCYL cannot take more than one value."); - } - if (XCYL.size() == 0) { + if (XCYL.size() == 0) XCYL.push_back(-1.0); - } parseVector("YCYL", YCYL); - if (YCYL.size() > 1) { + if (YCYL.size() > 1) error("YCYL cannot take more than one value."); - } - if (YCYL.size() == 0) { + if (YCYL.size() == 0) YCYL.push_back(-1.0); - } checkRead(); std::vector atoms; - for (unsigned i = 0; i < UMEM.size(); i++) { + for (unsigned i = 0; i < UMEM.size(); i++) + { atoms.push_back(UMEM[i]); } - for (unsigned i = 0; i < LMEM.size(); i++) { + for (unsigned i = 0; i < LMEM.size(); i++) + { atoms.push_back(LMEM[i]); } - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { atoms.push_back(TAILS[i]); } - for (unsigned i = 0; i < WATERS.size(); i++) { + for (unsigned i = 0; i < WATERS.size(); i++) + { atoms.push_back(WATERS[i]); } - for (unsigned i = 0; i < POXYGENS.size(); i++) { + for (unsigned i = 0; i < POXYGENS.size(); i++) + { atoms.push_back(POXYGENS[i]); } @@ -236,7 +221,8 @@ fusionPoreNucleationP::fusionPoreNucleationP(const ActionOptions &ao) : PLUMED_C requestAtoms(atoms); } -void fusionPoreNucleationP::calculate() { +void fusionPoreNucleationP::calculate() +{ /************************* * * * System * @@ -254,7 +240,8 @@ void fusionPoreNucleationP::calculate() { #pragma omp parallel for private(uMemAngle, lMemAngle) reduction(+:ZuMemcos, ZuMemsin, ZlMemcos, ZlMemsin) #endif #endif - for (unsigned i = 0; i < UMEM.size(); i++) { + for (unsigned i = 0; i < UMEM.size(); i++) + { uMemAngle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i)))[2]; lMemAngle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + UMEM.size())))[2]; ZuMemcos += cos(uMemAngle); @@ -333,36 +320,48 @@ void fusionPoreNucleationP::calculate() { #pragma omp parallel for private(ZTailDistance, PositionS_Mem, s1_Mem, s2_Mem, TailPosition, x, aux) reduction(vec_double_plus:Fs_Mem, sx_Mem, sy_Mem, cx_Mem, cy_Mem) #endif #endif - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { ZTailDistance = pbcDistance(Vector(0.0, 0.0, ZMems), getPosition(i + membraneBeads))[2]; PositionS_Mem = (ZTailDistance + firstSliceZDist_Mem) / DSMEM[0]; // If the following condition is met the particle is in the Z space of the cylinder. - if ((PositionS_Mem >= (-0.5 - HMEM[0])) && (PositionS_Mem <= (NSMEM[0] + 0.5 - 1.0 + HMEM[0]))) { + if ((PositionS_Mem >= (-0.5 - HMEM[0])) && (PositionS_Mem <= (NSMEM[0] + 0.5 - 1.0 + HMEM[0]))) + { //Defining the slices to analyze each particle. - if (PositionS_Mem < 1) { + if (PositionS_Mem < 1) + { s1_Mem = 0; s2_Mem = 2; - } else if (PositionS_Mem <= (NSMEM[0] - 2.0)) { + } + else if (PositionS_Mem <= (NSMEM[0] - 2.0)) + { s1_Mem = floor(PositionS_Mem) - 1; s2_Mem = floor(PositionS_Mem) + 1; - } else { + } + else + { s1_Mem = NSMEM[0] - 3; s2_Mem = NSMEM[0] - 1; } TailPosition = getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + membraneBeads))); - for (unsigned s = s1_Mem; s <= s2_Mem; s++) { + for (unsigned s = s1_Mem; s <= s2_Mem; s++) + { x = (ZTailDistance - (s + 0.5 - NSMEM[0] / 2.0) * DSMEM[0]) * 2.0 / DSMEM[0]; - if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) { - if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) { + if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) + { + if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) + { faxial_Mem[i + TAILS.size() * s] = 1.0; Fs_Mem[s] += 1.0; sx_Mem[s] += sin(2.0 * M_PI * TailPosition[0]); sy_Mem[s] += sin(2.0 * M_PI * TailPosition[1]); cx_Mem[s] += cos(2.0 * M_PI * TailPosition[0]); cy_Mem[s] += cos(2.0 * M_PI * TailPosition[1]); - } else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) { + } + else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) + { aux = 0.5 - ((3.0 * x - 3.0) / (4.0 * HMEM[0])) + (pow((x - 1.0), 3) / (4.0 * pow(HMEM[0], 3))); faxial_Mem[i + TAILS.size() * s] = aux; Fs_Mem[s] += aux; @@ -370,7 +369,9 @@ void fusionPoreNucleationP::calculate() { sy_Mem[s] += aux * sin(2.0 * M_PI * TailPosition[1]); cx_Mem[s] += aux * cos(2.0 * M_PI * TailPosition[0]); cy_Mem[s] += aux * cos(2.0 * M_PI * TailPosition[1]); - } else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) { + } + else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) + { aux = 0.5 + ((3.0 * x + 3.0) / (4.0 * HMEM[0])) - (pow((x + 1.0), 3) / (4.0 * pow(HMEM[0], 3))); faxial_Mem[i + TAILS.size() * s] = aux; Fs_Mem[s] += aux; @@ -384,8 +385,10 @@ void fusionPoreNucleationP::calculate() { } } - for (unsigned s = 0; s < NSMEM[0]; s++) { - if (Fs_Mem[s] != 0.0) { + for (unsigned s = 0; s < NSMEM[0]; s++) + { + if (Fs_Mem[s] != 0.0) + { ws_Mem[s] = tanh(Fs_Mem[s]); W_Mem += ws_Mem[s]; sx_Mem[s] = sx_Mem[s] / Fs_Mem[s]; @@ -407,10 +410,13 @@ void fusionPoreNucleationP::calculate() { // Eq. 12 Hub & Awasthi JCTC 2017. double Xcyl_Mem, Ycyl_Mem; - if ((XCYL[0] > 0.0) && (YCYL[0] > 0.0)) { + if ((XCYL[0] > 0.0) && (YCYL[0] > 0.0)) + { Xcyl_Mem = XCYL[0]; Ycyl_Mem = YCYL[0]; - } else { + } + else + { Xcyl_Mem = (atan2(-Xsc_Mem, -Xcc_Mem) + M_PI) * Lx / (2 * M_PI); Ycyl_Mem = (atan2(-Ysc_Mem, -Ycc_Mem) + M_PI) * Ly / (2 * M_PI); } @@ -489,44 +495,57 @@ void fusionPoreNucleationP::calculate() { #pragma omp parallel for private(distCylinder, aux, condition1, condition2, condition3, ZMemDistance, PositionS, Position, x) reduction(vec_double_plus:Fs, sx, sy, cx, cy) #endif #endif - for (unsigned i = 0; i < chainBeads; i++) { + for (unsigned i = 0; i < chainBeads; i++) +{ distCylinder = pbcDistance(xyzCyl_Mem, pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + noChainBeads))); aux = sqrt(pow(distCylinder[0], 2) + pow(distCylinder[1], 2)); condition1 = ((aux / RCYLAVERAGE) < 1.0); condition2 = ((pbcDistance(Vector(0.0, 0.0, ZuMem), getPosition(i + noChainBeads))[2] > 0) && (aux / RCYLAVERAGE) < 2.0); condition3 = ((pbcDistance(getPosition(i + noChainBeads), Vector(0.0, 0.0, ZlMem))[2] > 0) && (aux / RCYLAVERAGE) < 2.0); - if (condition1 || condition2 || condition3) { + if (condition1 || condition2 || condition3) + { ZMemDistance = pbcDistance(Vector(0.0, 0.0, ZMems), getPosition(i + noChainBeads))[2]; PositionS = (ZMemDistance + firstSliceZDist) / DS[0]; // If the following condition is met the particle is in the Z space of the cylinder. - if ((PositionS >= (-0.5 - HCH[0])) && (PositionS <= (NS[0] + 0.5 - 1.0 + HCH[0]))) { + if ((PositionS >= (-0.5 - HCH[0])) && (PositionS <= (NS[0] + 0.5 - 1.0 + HCH[0]))) + { analyzeThisParticle[i] = 1.0; //Defining the slices to analyze each particle. - if (PositionS < 1) { + if (PositionS < 1) + { s1[i] = 0; s2[i] = 2; - } else if (PositionS <= (NS[0] - 2.0)) { + } + else if (PositionS <= (NS[0] - 2.0)) + { s1[i] = floor(PositionS) - 1; s2[i] = floor(PositionS) + 1; - } else { + } + else + { s1[i] = NS[0] - 3; s2[i] = NS[0] - 1; } Position = getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + noChainBeads))); - for (unsigned s = s1[i]; s <= s2[i]; s++) { + for (unsigned s = s1[i]; s <= s2[i]; s++) + { x = (ZMemDistance - (s + 0.5 - NS[0] / 2.0) * DS[0]) * 2.0 / DS[0]; - if (!((x <= -1.0 - HCH[0]) || (x >= 1.0 + HCH[0]))) { - if (((-1.0 + HCH[0]) <= x) && (x <= (1.0 - HCH[0]))) { + if (!((x <= -1.0 - HCH[0]) || (x >= 1.0 + HCH[0]))) + { + if (((-1.0 + HCH[0]) <= x) && (x <= (1.0 - HCH[0]))) + { faxial[i + chainBeads * s] = 1.0; Fs[s] += 1.0; sx[s] += sin(2.0 * M_PI * Position[0]); sy[s] += sin(2.0 * M_PI * Position[1]); cx[s] += cos(2.0 * M_PI * Position[0]); cy[s] += cos(2.0 * M_PI * Position[1]); - } else if (((1.0 - HCH[0]) < x) && (x < (1.0 + HCH[0]))) { + } + else if (((1.0 - HCH[0]) < x) && (x < (1.0 + HCH[0]))) + { aux = 0.5 - ((3.0 * x - 3.0) / (4.0 * HCH[0])) + (pow((x - 1.0), 3) / (4.0 * pow(HCH[0], 3))); faxial[i + chainBeads * s] = aux; d_faxial_dz[i + chainBeads * s] = ((-3.0 / (4.0 * HCH[0])) + ((3.0 * pow((x - 1), 2)) / (4.0 * pow(HCH[0], 3)))) * 2.0 / DS[0]; @@ -535,7 +554,9 @@ void fusionPoreNucleationP::calculate() { sy[s] += aux * sin(2.0 * M_PI * Position[1]); cx[s] += aux * cos(2.0 * M_PI * Position[0]); cy[s] += aux * cos(2.0 * M_PI * Position[1]); - } else if (((-1.0 - HCH[0]) < x) && (x < (-1.0 + HCH[0]))) { + } + else if (((-1.0 - HCH[0]) < x) && (x < (-1.0 + HCH[0]))) + { aux = 0.5 + ((3.0 * x + 3.0) / (4.0 * HCH[0])) - (pow((x + 1.0), 3) / (4.0 * pow(HCH[0], 3))); faxial[i + chainBeads * s] = aux; d_faxial_dz[i + chainBeads * s] = ((3.0 / (4.0 * HCH[0])) - ((3.0 * pow((x + 1), 2)) / (4.0 * pow(HCH[0], 3)))) * 2.0 / DS[0]; @@ -551,8 +572,10 @@ void fusionPoreNucleationP::calculate() { } } - for (unsigned s = 0; s < NS[0]; s++) { - if (Fs[s] != 0.0) { + for (unsigned s = 0; s < NS[0]; s++) + { + if (Fs[s] != 0.0) + { ws[s] = tanh(Fs[s]); W += ws[s]; sx[s] = sx[s] / Fs[s]; @@ -607,15 +630,21 @@ void fusionPoreNucleationP::calculate() { // To avoid rare instabilities auxX and auxY are truncated at a configurable value (default 500). double auxX = (1 / (pow(Xsc, 2) + pow(Xcc, 2))), auxY = (1 / (pow(Ysc, 2) + pow(Ycc, 2))); - if (auxX > ONEOVERS2C2CUTOFF[0]) { + if (auxX > ONEOVERS2C2CUTOFF[0]) + { auxX = Lx * ONEOVERS2C2CUTOFF[0] / (2 * M_PI); - } else { + } + else + { auxX = Lx * auxX / (2 * M_PI); } - if (auxY > ONEOVERS2C2CUTOFF[0]) { + if (auxY > ONEOVERS2C2CUTOFF[0]) + { auxY = Ly * ONEOVERS2C2CUTOFF[0] / (2 * M_PI); - } else { + } + else + { auxY = Ly * auxY / (2 * M_PI); } @@ -636,9 +665,11 @@ void fusionPoreNucleationP::calculate() { #pragma omp parallel for private(d_Xsc_dx,d_Xcc_dx,d_Ysc_dy,d_Ycc_dy,d_Xsc_dz,d_Xcc_dz,d_Ysc_dz,d_Ycc_dz,d_sx_dx,d_sy_dy,d_cx_dx,d_cy_dy,d_sx_dz,d_sy_dz,d_cx_dz,d_cy_dz,d_ws_dz,ri,x,fradial) reduction(vec_double_plus: Nsp, Axs, Ays) #endif #endif - for (unsigned i = 0; i < chainBeads; i++) { + for (unsigned i = 0; i < chainBeads; i++) +{ CylDistances[i] = pbcDistance(xyzCyl, pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + noChainBeads))); - if (analyzeThisParticle[i]) { + if (analyzeThisParticle[i]) + { Position = getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + noChainBeads))); d_Xsc_dx = 0.0; d_Xcc_dx = 0.0; @@ -648,8 +679,10 @@ void fusionPoreNucleationP::calculate() { d_Xcc_dz = 0.0; d_Ysc_dz = 0.0; d_Ycc_dz = 0.0; - for (unsigned s = s1[i]; s <= s2[i]; s++) { - if (Fs[s] != 0.0) { + for (unsigned s = s1[i]; s <= s2[i]; s++) + { + if (Fs[s] != 0.0) + { d_sx_dx = faxial[i + chainBeads * s] * 2.0 * M_PI * cos(2.0 * M_PI * Position[0]) / (Lx * Fs[s]); d_sy_dy = faxial[i + chainBeads * s] * 2.0 * M_PI * cos(2.0 * M_PI * Position[1]) / (Ly * Fs[s]); d_cx_dx = -faxial[i + chainBeads * s] * 2.0 * M_PI * sin(2.0 * M_PI * Position[0]) / (Lx * Fs[s]); @@ -677,20 +710,27 @@ void fusionPoreNucleationP::calculate() { ri = sqrt(pow(CylDistances[i][0], 2) + pow(CylDistances[i][1], 2)); x = ri / RCYL[0]; - if (!((x <= -1.0 - HCH[0]) || (x >= 1.0 + HCH[0]))) { - if (((-1.0 + HCH[0]) <= x) && (x <= (1.0 - HCH[0]))) { + if (!((x <= -1.0 - HCH[0]) || (x >= 1.0 + HCH[0]))) + { + if (((-1.0 + HCH[0]) <= x) && (x <= (1.0 - HCH[0]))) + { fradial = 1.0; - } else if (((1.0 - HCH[0]) < x) && (x < (1.0 + HCH[0]))) { + } + else if (((1.0 - HCH[0]) < x) && (x < (1.0 + HCH[0]))) + { fradial = 0.5 - ((3.0 * x - 3.0) / (4.0 * HCH[0])) + (pow((x - 1.0), 3) / (4.0 * pow(HCH[0], 3))); d_fradial_dx[i] = ((-3.0 / (4.0 * HCH[0])) + ((3.0 * pow((x - 1), 2)) / (4.0 * pow(HCH[0], 3)))) * CylDistances[i][0] / (RCYL[0] * ri); d_fradial_dy[i] = ((-3.0 / (4.0 * HCH[0])) + ((3.0 * pow((x - 1), 2)) / (4.0 * pow(HCH[0], 3)))) * CylDistances[i][1] / (RCYL[0] * ri); - } else if (((-1.0 - HCH[0]) < x) && (x < (-1.0 + HCH[0]))) { + } + else if (((-1.0 - HCH[0]) < x) && (x < (-1.0 + HCH[0]))) + { fradial = 0.5 + ((3.0 * x + 3.0) / (4.0 * HCH[0])) - (pow((x + 1.0), 3) / (4.0 * pow(HCH[0], 3))); d_fradial_dx[i] = ((3.0 / (4.0 * HCH[0])) - ((3.0 * pow((x + 1), 2)) / (4.0 * pow(HCH[0], 3)))) * CylDistances[i][0] / (RCYL[0] * ri); d_fradial_dy[i] = ((3.0 / (4.0 * HCH[0])) - ((3.0 * pow((x + 1), 2)) / (4.0 * pow(HCH[0], 3)))) * CylDistances[i][1] / (RCYL[0] * ri); } - for (unsigned s = s1[i]; s <= s2[i]; s++) { + for (unsigned s = s1[i]; s <= s2[i]; s++) + { Nsp[s] += fradial * faxial[i + chainBeads * s]; Axs[s] += faxial[i + chainBeads * s] * d_fradial_dx[i]; Ays[s] += faxial[i + chainBeads * s] * d_fradial_dy[i]; @@ -700,12 +740,16 @@ void fusionPoreNucleationP::calculate() { } } - for (unsigned s = 0; s < NS[0]; s++) { - if (Nsp[s] <= 1.0) { + for (unsigned s = 0; s < NS[0]; s++) + { + if (Nsp[s] <= 1.0) + { psi[s] = ZETA[0] * Nsp[s]; d_psi[s] = ZETA[0]; Xi_n += psi[s]; - } else { + } + else + { psi[s] = 1.0 - c * exp(-b * Nsp[s]); d_psi[s] = b * c * exp(-b * Nsp[s]); Xi_n += psi[s]; @@ -725,17 +769,22 @@ void fusionPoreNucleationP::calculate() { #pragma omp parallel for private(aux) #endif #endif - for (unsigned i = 0; i < chainBeads; i++) { - if (analyzeThisParticle[i]) { - for (unsigned s = s1[i]; s <= s2[i]; s++) { - if (faxial[i + chainBeads * s]) { + for (unsigned i = 0; i < chainBeads; i++) +{ + if (analyzeThisParticle[i]) + { + for (unsigned s = s1[i]; s <= s2[i]; s++) + { + if (faxial[i + chainBeads * s]) + { faxial_d_fradial_dx[i + chainBeads * s] = faxial[i + chainBeads * s] * d_fradial_dx[i] - d_Xcyl_dx[i] * Axs[s]; faxial_d_fradial_dy[i + chainBeads * s] = faxial[i + chainBeads * s] * d_fradial_dy[i] - d_Ycyl_dy[i] * Ays[s]; faxial_d_fradial_dz[i + chainBeads * s] = -d_Xcyl_dz[i] * Axs[s] - d_Ycyl_dz[i] * Ays[s]; } } - for (unsigned s = s1[i]; s <= s2[i]; s++) { + for (unsigned s = s1[i]; s <= s2[i]; s++) + { aux = d_psi[s] / NS[0]; derivatives_Chain[i][0] += aux * faxial_d_fradial_dx[i + chainBeads * s]; derivatives_Chain[i][1] += aux * faxial_d_fradial_dy[i + chainBeads * s]; @@ -745,7 +794,8 @@ void fusionPoreNucleationP::calculate() { } Tensor virial; - for (unsigned i = 0; i < chainBeads; i++) { + for (unsigned i = 0; i < chainBeads; i++) +{ setAtomsDerivatives((i + noChainBeads), derivatives_Chain[i]); virial -= Tensor(CylDistances[i], derivatives_Chain[i]); } diff --git a/src/membranefusion/MemFusionP.cpp b/src/membranefusion/MemFusionP.cpp index b516cbe6eb..7e7437d9f2 100644 --- a/src/membranefusion/MemFusionP.cpp +++ b/src/membranefusion/MemFusionP.cpp @@ -27,8 +27,10 @@ along with plumed. If not, see . #endif #endif -namespace PLMD { -namespace membranefusion { +namespace PLMD +{ +namespace membranefusion +{ //+PLUMEDOC MEMBRANEFUSIONMOD_COLVAR MEMFUSIONP /* Calculate a CV that can induce the formation of the hemifusion stalk between two initially flat and planar bilayers. @@ -73,7 +75,8 @@ You can test this CV with another example in this
1) { + if (NSMEM.size() > 1) error("NSMEM cannot take more than one value."); - } parseVector("DSMEM", DSMEM); - if (DSMEM.size() > 1) { + if (DSMEM.size() > 1) error("DSMEM cannot take more than one value."); - } - if (DSMEM.size() == 0) { + if (DSMEM.size() == 0) DSMEM.push_back(0.1); - } parseVector("HMEM", HMEM); - if (HMEM.size() > 1) { + if (HMEM.size() > 1) error("HMEM cannot take more than one value."); - } - if (HMEM.size() == 0) { + if (HMEM.size() == 0) HMEM.push_back(0.25); - } parseVector("RCYLMEM", RCYLMEM); - if (RCYLMEM.size() > 1) { + if (RCYLMEM.size() > 1) error("RCYLMEM cannot take more than one value."); - } - if (RCYLMEM.size() == 0) { + if (RCYLMEM.size() == 0) RCYLMEM.push_back(1.75); - } parseVector("ZETAMEM", ZETAMEM); - if (ZETAMEM.size() > 1) { + if (ZETAMEM.size() > 1) error("ZETA cannot take more than one value."); - } - if (ZETAMEM.size() == 0) { + if (ZETAMEM.size() == 0) ZETAMEM.push_back(0.5); - } parseVector("ONEOVERS2C2CUTOFF", ONEOVERS2C2CUTOFF); - if (ONEOVERS2C2CUTOFF.size() > 1) { + if (ONEOVERS2C2CUTOFF.size() > 1) error("ONEOVERS2C2CUTOFF cannot take more than one value."); - } - if (ONEOVERS2C2CUTOFF.size() == 0) { + if (ONEOVERS2C2CUTOFF.size() == 0) ONEOVERS2C2CUTOFF.push_back(500); - } parseVector("XCYL", XCYL); - if (XCYL.size() > 1) { + if (XCYL.size() > 1) error("XCYL cannot take more than one value."); - } - if (XCYL.size() == 0) { + if (XCYL.size() == 0) XCYL.push_back(-1.0); - } parseVector("YCYL", YCYL); - if (YCYL.size() > 1) { + if (YCYL.size() > 1) error("YCYL cannot take more than one value."); - } - if (YCYL.size() == 0) { + if (YCYL.size() == 0) YCYL.push_back(-1.0); - } checkRead(); std::vector atoms; - for (unsigned i = 0; i < UMEM.size(); i++) { + for (unsigned i = 0; i < UMEM.size(); i++) + { atoms.push_back(UMEM[i]); } - for (unsigned i = 0; i < LMEM.size(); i++) { + for (unsigned i = 0; i < LMEM.size(); i++) + { atoms.push_back(LMEM[i]); } - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { atoms.push_back(TAILS[i]); } @@ -195,7 +185,8 @@ memFusionP::memFusionP(const ActionOptions &ao) : PLUMED_COLVAR_INIT(ao) { requestAtoms(atoms); } -void memFusionP::calculate() { +void memFusionP::calculate() +{ /************************** * * * System * @@ -213,7 +204,8 @@ void memFusionP::calculate() { #pragma omp parallel for private(uMemAngle, lMemAngle) reduction(+:ZuMemcos, ZuMemsin, ZlMemcos, ZlMemsin) #endif #endif - for (unsigned i = 0; i < UMEM.size(); i++) { + for (unsigned i = 0; i < UMEM.size(); i++) + { uMemAngle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i)))[2]; lMemAngle = 2.0 * M_PI * getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + UMEM.size())))[2]; ZuMemcos += cos(uMemAngle); @@ -301,37 +293,49 @@ void memFusionP::calculate() { #pragma omp parallel for private(ZTailDistance, PositionS_Mem, TailPosition, x, aux) reduction(vec_double_plus:Fs_Mem, sx_Mem, sy_Mem, cx_Mem, cy_Mem) #endif #endif - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { ZTailDistance = pbcDistance(Vector(0.0, 0.0, ZMems), getPosition(i + membraneBeads))[2]; PositionS_Mem = (ZTailDistance + firstSliceZDist_Mem) / DSMEM[0]; // If the following condition is met the particle is in the Z space of the cylinder. - if ((PositionS_Mem >= (-0.5 - HMEM[0])) && (PositionS_Mem <= (NSMEM[0] + 0.5 - 1.0 + HMEM[0]))) { + if ((PositionS_Mem >= (-0.5 - HMEM[0])) && (PositionS_Mem <= (NSMEM[0] + 0.5 - 1.0 + HMEM[0]))) + { analyzeThisParticle_Mem[i] = 1.0; // Defining the slices to analyze each particle. - if (PositionS_Mem < 1) { + if (PositionS_Mem < 1) + { s1_Mem[i] = 0; s2_Mem[i] = 2; - } else if (PositionS_Mem <= (NSMEM[0] - 2.0)) { + } + else if (PositionS_Mem <= (NSMEM[0] - 2.0)) + { s1_Mem[i] = floor(PositionS_Mem) - 1; s2_Mem[i] = floor(PositionS_Mem) + 1; - } else { + } + else + { s1_Mem[i] = NSMEM[0] - 3; s2_Mem[i] = NSMEM[0] - 1; } TailPosition = getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + membraneBeads))); - for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) { + for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) + { x = (ZTailDistance - (s + 0.5 - NSMEM[0] / 2.0) * DSMEM[0]) * 2.0 / DSMEM[0]; - if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) { - if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) { + if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) + { + if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) + { faxial_Mem[i + TAILS.size() * s] = 1.0; Fs_Mem[s] += 1.0; sx_Mem[s] += sin(2.0 * M_PI * TailPosition[0]); sy_Mem[s] += sin(2.0 * M_PI * TailPosition[1]); cx_Mem[s] += cos(2.0 * M_PI * TailPosition[0]); cy_Mem[s] += cos(2.0 * M_PI * TailPosition[1]); - } else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) { + } + else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) + { aux = 0.5 - ((3.0 * x - 3.0) / (4.0 * HMEM[0])) + (pow((x - 1.0), 3) / (4.0 * pow(HMEM[0], 3))); faxial_Mem[i + TAILS.size() * s] = aux; d_faxial_Mem_dz[i + TAILS.size() * s] = ((-3.0 / (4.0 * HMEM[0])) + ((3.0 * pow((x - 1), 2)) / (4.0 * pow(HMEM[0], 3)))) * 2.0 / DSMEM[0]; @@ -340,7 +344,9 @@ void memFusionP::calculate() { sy_Mem[s] += aux * sin(2.0 * M_PI * TailPosition[1]); cx_Mem[s] += aux * cos(2.0 * M_PI * TailPosition[0]); cy_Mem[s] += aux * cos(2.0 * M_PI * TailPosition[1]); - } else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) { + } + else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) + { aux = 0.5 + ((3.0 * x + 3.0) / (4.0 * HMEM[0])) - (pow((x + 1.0), 3) / (4.0 * pow(HMEM[0], 3))); faxial_Mem[i + TAILS.size() * s] = aux; d_faxial_Mem_dz[i + TAILS.size() * s] = ((3.0 / (4.0 * HMEM[0])) - ((3.0 * pow((x + 1), 2)) / (4.0 * pow(HMEM[0], 3)))) * 2.0 / DSMEM[0]; @@ -355,8 +361,10 @@ void memFusionP::calculate() { } } - for (unsigned s = 0; s < NSMEM[0]; s++) { - if (Fs_Mem[s] != 0.0) { + for (unsigned s = 0; s < NSMEM[0]; s++) + { + if (Fs_Mem[s] != 0.0) + { ws_Mem[s] = tanh(Fs_Mem[s]); W_Mem += ws_Mem[s]; sx_Mem[s] = sx_Mem[s] / Fs_Mem[s]; @@ -378,10 +386,13 @@ void memFusionP::calculate() { // Eq. 12 Hub & Awasthi JCTC 2017. double Xcyl_Mem, Ycyl_Mem; - if ((XCYL[0] > 0.0) && (YCYL[0] > 0.0)) { + if ((XCYL[0] > 0.0) && (YCYL[0] > 0.0)) + { Xcyl_Mem = XCYL[0]; Ycyl_Mem = YCYL[0]; - } else { + } + else + { Xcyl_Mem = (atan2(-Xsc_Mem, -Xcc_Mem) + M_PI) * Lx / (2 * M_PI); Ycyl_Mem = (atan2(-Ysc_Mem, -Ycc_Mem) + M_PI) * Ly / (2 * M_PI); } @@ -416,15 +427,21 @@ void memFusionP::calculate() { // To avoid rare instabilities auxX_Mem and auxY_Mem are truncated at a configurable value (default = 500). double auxX_Mem = (1 / (pow(Xsc_Mem, 2) + pow(Xcc_Mem, 2))), auxY_Mem = (1 / (pow(Ysc_Mem, 2) + pow(Ycc_Mem, 2))); - if (auxX_Mem > ONEOVERS2C2CUTOFF[0]) { + if (auxX_Mem > ONEOVERS2C2CUTOFF[0]) + { auxX_Mem = Lx * ONEOVERS2C2CUTOFF[0] / (2 * M_PI); - } else { + } + else + { auxX_Mem = Lx * auxX_Mem / (2 * M_PI); } - if (auxY_Mem > ONEOVERS2C2CUTOFF[0]) { + if (auxY_Mem > ONEOVERS2C2CUTOFF[0]) + { auxY_Mem = Ly * ONEOVERS2C2CUTOFF[0] / (2 * M_PI); - } else { + } + else + { auxY_Mem = Ly * auxY_Mem / (2 * M_PI); } @@ -448,8 +465,10 @@ void memFusionP::calculate() { #pragma omp parallel for private(TailPosition,d_Xsc_Mem_dx,d_Xcc_Mem_dx,d_Ysc_Mem_dy,d_Ycc_Mem_dy,d_Xsc_Mem_dz,d_Xcc_Mem_dz,d_Ysc_Mem_dz,d_Ycc_Mem_dz,d_sx_Mem_dx,d_sy_Mem_dy,d_cx_Mem_dx,d_cy_Mem_dy,d_sx_Mem_dz,d_sy_Mem_dz,d_cx_Mem_dz,d_cy_Mem_dz,d_ws_Mem_dz,ri_Mem,x,fradial_Mem) reduction(vec_double_plus: Nsp_Mem, Axs_Mem, Ays_Mem) #endif #endif - for (unsigned i = 0; i < TAILS.size(); i++) { - if (analyzeThisParticle_Mem[i]) { + for (unsigned i = 0; i < TAILS.size(); i++) + { + if (analyzeThisParticle_Mem[i]) + { TailPosition = getPbc().realToScaled(pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + membraneBeads))); d_Xsc_Mem_dx = 0.0; d_Xcc_Mem_dx = 0.0; @@ -459,8 +478,10 @@ void memFusionP::calculate() { d_Xcc_Mem_dz = 0.0; d_Ysc_Mem_dz = 0.0; d_Ycc_Mem_dz = 0.0; - for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) { - if (Fs_Mem[s] != 0.0) { + for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) + { + if (Fs_Mem[s] != 0.0) + { d_sx_Mem_dx = faxial_Mem[i + TAILS.size() * s] * 2.0 * M_PI * cos(2.0 * M_PI * TailPosition[0]) / (Lx * Fs_Mem[s]); d_sy_Mem_dy = faxial_Mem[i + TAILS.size() * s] * 2.0 * M_PI * cos(2.0 * M_PI * TailPosition[1]) / (Ly * Fs_Mem[s]); d_cx_Mem_dx = -faxial_Mem[i + TAILS.size() * s] * 2.0 * M_PI * sin(2.0 * M_PI * TailPosition[0]) / (Lx * Fs_Mem[s]); @@ -489,20 +510,27 @@ void memFusionP::calculate() { CylDistances_Mem[i] = pbcDistance(xyzCyl_Mem, pbcDistance(Vector(0.0, 0.0, 0.0), getPosition(i + membraneBeads))); ri_Mem = sqrt(pow(CylDistances_Mem[i][0], 2) + pow(CylDistances_Mem[i][1], 2)); x = ri_Mem / RCYLMEM[0]; - if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) { - if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) { + if (!((x <= -1.0 - HMEM[0]) || (x >= 1.0 + HMEM[0]))) + { + if (((-1.0 + HMEM[0]) <= x) && (x <= (1.0 - HMEM[0]))) + { fradial_Mem = 1.0; - } else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) { + } + else if (((1.0 - HMEM[0]) < x) && (x < (1.0 + HMEM[0]))) + { fradial_Mem = 0.5 - ((3.0 * x - 3.0) / (4.0 * HMEM[0])) + (pow((x - 1.0), 3) / (4.0 * pow(HMEM[0], 3))); d_fradial_Mem_dx[i] = ((-3.0 / (4.0 * HMEM[0])) + ((3.0 * pow((x - 1), 2)) / (4.0 * pow(HMEM[0], 3)))) * CylDistances_Mem[i][0] / (RCYLMEM[0] * ri_Mem); d_fradial_Mem_dy[i] = ((-3.0 / (4.0 * HMEM[0])) + ((3.0 * pow((x - 1), 2)) / (4.0 * pow(HMEM[0], 3)))) * CylDistances_Mem[i][1] / (RCYLMEM[0] * ri_Mem); - } else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) { + } + else if (((-1.0 - HMEM[0]) < x) && (x < (-1.0 + HMEM[0]))) + { fradial_Mem = 0.5 + ((3.0 * x + 3.0) / (4.0 * HMEM[0])) - (pow((x + 1.0), 3) / (4.0 * pow(HMEM[0], 3))); d_fradial_Mem_dx[i] = ((3.0 / (4.0 * HMEM[0])) - ((3.0 * pow((x + 1), 2)) / (4.0 * pow(HMEM[0], 3)))) * CylDistances_Mem[i][0] / (RCYLMEM[0] * ri_Mem); d_fradial_Mem_dy[i] = ((3.0 / (4.0 * HMEM[0])) - ((3.0 * pow((x + 1), 2)) / (4.0 * pow(HMEM[0], 3)))) * CylDistances_Mem[i][1] / (RCYLMEM[0] * ri_Mem); } - for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) { + for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) + { Nsp_Mem[s] += fradial_Mem * faxial_Mem[i + TAILS.size() * s]; Axs_Mem[s] += faxial_Mem[i + TAILS.size() * s] * d_fradial_Mem_dx[i]; Ays_Mem[s] += faxial_Mem[i + TAILS.size() * s] * d_fradial_Mem_dy[i]; @@ -512,12 +540,16 @@ void memFusionP::calculate() { } } - for (unsigned s = 0; s < NSMEM[0]; s++) { - if (Nsp_Mem[s] <= 1.0) { + for (unsigned s = 0; s < NSMEM[0]; s++) + { + if (Nsp_Mem[s] <= 1.0) + { psi_Mem[s] = ZETAMEM[0] * Nsp_Mem[s]; d_psi_Mem[s] = ZETAMEM[0]; Xi_Mem += psi_Mem[s]; - } else { + } + else + { psi_Mem[s] = 1.0 - c_Mem * exp(-b_Mem * Nsp_Mem[s]); d_psi_Mem[s] = b_Mem * c_Mem * exp(-b_Mem * Nsp_Mem[s]); Xi_Mem += psi_Mem[s]; @@ -537,17 +569,22 @@ void memFusionP::calculate() { #pragma omp parallel for private(aux) #endif #endif - for (unsigned i = 0; i < TAILS.size(); i++) { - if (analyzeThisParticle_Mem[i]) { - for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) { - if (faxial_Mem[i + TAILS.size() * s]) { + for (unsigned i = 0; i < TAILS.size(); i++) + { + if (analyzeThisParticle_Mem[i]) + { + for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) + { + if (faxial_Mem[i + TAILS.size() * s]) + { faxial_Mem_d_fradial_Mem_dx[i + TAILS.size() * s] = faxial_Mem[i + TAILS.size() * s] * d_fradial_Mem_dx[i] - d_Xcyl_Mem_dx[i] * Axs_Mem[s]; faxial_Mem_d_fradial_Mem_dy[i + TAILS.size() * s] = faxial_Mem[i + TAILS.size() * s] * d_fradial_Mem_dy[i] - d_Ycyl_Mem_dy[i] * Ays_Mem[s]; faxial_Mem_d_fradial_Mem_dz[i + TAILS.size() * s] = -d_Xcyl_Mem_dz[i] * Axs_Mem[s] - d_Ycyl_Mem_dz[i] * Ays_Mem[s]; } } - for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) { + for (unsigned s = s1_Mem[i]; s <= s2_Mem[i]; s++) + { aux = d_psi_Mem[s] / NSMEM[0]; derivatives_Mem[i][0] += aux * faxial_Mem_d_fradial_Mem_dx[i + TAILS.size() * s]; derivatives_Mem[i][1] += aux * faxial_Mem_d_fradial_Mem_dy[i + TAILS.size() * s]; @@ -558,7 +595,8 @@ void memFusionP::calculate() { // Derivatives and virial for the Xi_Mem. Tensor virial; - for (unsigned i = 0; i < TAILS.size(); i++) { + for (unsigned i = 0; i < TAILS.size(); i++) + { setAtomsDerivatives((i + membraneBeads), derivatives_Mem[i]); virial -= Tensor(CylDistances_Mem[i], derivatives_Mem[i]); } diff --git a/src/multicolvar/ActionVolume.cpp b/src/multicolvar/ActionVolume.cpp index ff4735e6a9..c374e4c292 100644 --- a/src/multicolvar/ActionVolume.cpp +++ b/src/multicolvar/ActionVolume.cpp @@ -26,15 +26,9 @@ namespace multicolvar { void ActionVolume::registerKeywords( Keywords& keys ) { VolumeGradientBase::registerKeywords( keys ); - if( keys.reserved("VMEAN") ) { - keys.use("VMEAN"); - } - keys.use("MEAN"); - keys.use("LESS_THAN"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("SUM"); + if( keys.reserved("VMEAN") ) keys.use("VMEAN"); + keys.use("MEAN"); keys.use("LESS_THAN"); keys.use("MORE_THAN"); + keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("SUM"); keys.add("compulsory","SIGMA","the width of the function to be used for kernel density estimation"); keys.add("compulsory","KERNEL","gaussian","the type of kernel function to be used"); keys.addFlag("OUTSIDE",false,"calculate quantities for colvars that are on atoms outside the region of interest"); @@ -42,31 +36,21 @@ void ActionVolume::registerKeywords( Keywords& keys ) { ActionVolume::ActionVolume(const ActionOptions&ao): Action(ao), - VolumeGradientBase(ao) { + VolumeGradientBase(ao) +{ // Find number of quantities - if( getPntrToMultiColvar()->isDensity() ) { - nquantities=2; // Value + weight - } else if( getPntrToMultiColvar()->getNumberOfQuantities()==2 ) { - nquantities=2; // Value + weight - } else { - nquantities = 1 + getPntrToMultiColvar()->getNumberOfQuantities()-2 + 1; // Norm + vector + weight - } + if( getPntrToMultiColvar()->isDensity() ) nquantities=2; // Value + weight + else if( getPntrToMultiColvar()->getNumberOfQuantities()==2 ) nquantities=2; // Value + weight + else nquantities = 1 + getPntrToMultiColvar()->getNumberOfQuantities()-2 + 1; // Norm + vector + weight // Output some nice information std::string functype=getPntrToMultiColvar()->getName(); - std::transform( functype.begin(), functype.end(), functype.begin(), [](unsigned char c) { - return std::tolower(c); - } ); + std::transform( functype.begin(), functype.end(), functype.begin(), [](unsigned char c) { return std::tolower(c); } ); log.printf(" calculating %s inside region of insterest\n",functype.c_str() ); - parseFlag("OUTSIDE",not_in); - sigma=0.0; - if( keywords.exists("SIGMA") ) { - parse("SIGMA",sigma); - } - if( keywords.exists("KERNEL") ) { - parse("KERNEL",kerneltype); - } + parseFlag("OUTSIDE",not_in); sigma=0.0; + if( keywords.exists("SIGMA") ) parse("SIGMA",sigma); + if( keywords.exists("KERNEL") ) parse("KERNEL",kerneltype); if( getPntrToMultiColvar()->isDensity() ) { std::string input; @@ -78,34 +62,21 @@ ActionVolume::ActionVolume(const ActionOptions&ao): void ActionVolume::calculateAllVolumes( const unsigned& curr, MultiValue& outvals ) const { Vector catom_pos=getPntrToMultiColvar()->getCentralAtomPos( curr ); - double weight; - Vector wdf; - Tensor vir; - std::vector refders( getNumberOfAtoms() ); + double weight; Vector wdf; Tensor vir; std::vector refders( getNumberOfAtoms() ); weight=calculateNumberInside( catom_pos, wdf, vir, refders ); if( not_in ) { - weight = 1.0 - weight; - wdf *= -1.; - vir *=-1; - for(unsigned i=0; igetCentralAtomPos( curr ); - Vector wdf; - Tensor vir; - std::vector refders( getNumberOfAtoms() ); + Vector wdf; Tensor vir; std::vector refders( getNumberOfAtoms() ); double weight=calculateNumberInside( catom_pos, wdf, vir, refders ); - if( not_in ) { - weight = 1.0 - weight; - } - if( weight all_atoms; readAtomsLikeKeyword( "ATOMS", 4, all_atoms ); @@ -142,16 +141,12 @@ AlphaBeta::AlphaBeta(const ActionOptions&ao): // Read in reference values unsigned ntarget=0; for(unsigned i=0; i0 ) { use_sf=true; weightHasDerivatives=true; sf1.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); sf2.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); log.printf(" only calculating angles for atoms separated by less than %s\n", sf1.description().c_str() ); } else { parse("SWITCHA",sfinput); @@ -158,18 +149,11 @@ Angles::Angles(const ActionOptions&ao): use_sf=true; weightHasDerivatives=true; sf1.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCHA keyword : " + errors ); - } - sfinput.clear(); - parse("SWITCHB",sfinput); - if(sfinput.length()==0) { - error("found SWITCHA keyword without SWITCHB"); - } + if( errors.length()!=0 ) error("problem reading SWITCHA keyword : " + errors ); + sfinput.clear(); parse("SWITCHB",sfinput); + if(sfinput.length()==0) error("found SWITCHA keyword without SWITCHB"); sf2.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCHB keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCHB keyword : " + errors ); log.printf(" only calculating angles when the distance between GROUPA and GROUPB atoms is less than %s\n", sf1.description().c_str() ); log.printf(" only calculating angles when the distance between GROUPA and GROUPC atoms is less than %s\n", sf2.description().c_str() ); } @@ -177,9 +161,7 @@ Angles::Angles(const ActionOptions&ao): // Read in the atoms std::vector all_atoms; readGroupKeywords( "GROUP", "GROUPA", "GROUPB", "GROUPC", false, true, all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 3, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 3, all_atoms ); setupMultiColvarBase( all_atoms ); // Set cutoff for link cells if( use_sf ) { @@ -191,15 +173,12 @@ Angles::Angles(const ActionOptions&ao): // And check everything has been read in correctly checkRead(); // Setup stuff for central atom - std::vector catom_ind(3, false); - catom_ind[0]=true; + std::vector catom_ind(3, false); catom_ind[0]=true; setAtomsForCentralAtom( catom_ind ); } double Angles::calculateWeight( const unsigned& taskCode, const double& weight, AtomValuePack& myatoms ) const { - if(!use_sf) { - return 1.0; - } + if(!use_sf) return 1.0; Vector dij=getSeparation( myatoms.getPosition(0), myatoms.getPosition(2) ); Vector dik=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); @@ -207,16 +186,12 @@ double Angles::calculateWeight( const unsigned& taskCode, const double& weight, double ldij = dij.modulo2(), ldik = dik.modulo2(); if( use_sf ) { - if( ldij>rcut2_1 || ldik>rcut2_2 ) { - return 0.0; - } + if( ldij>rcut2_1 || ldik>rcut2_2 ) return 0.0; } w1=sf1.calculateSqr( ldij, dw1 ); w2=sf2.calculateSqr( ldik, dw2 ); - wtot=w1*w2; - dw1*=weight*w2; - dw2*=weight*w1; + wtot=w1*w2; dw1*=weight*w2; dw2*=weight*w1; addAtomDerivatives( 0, 1, dw2*dik, myatoms ); addAtomDerivatives( 0, 0, -dw1*dij - dw2*dik, myatoms ); @@ -229,8 +204,7 @@ double Angles::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { Vector dij=getSeparation( myatoms.getPosition(0), myatoms.getPosition(2) ); Vector dik=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - Vector ddij,ddik; - PLMD::Angle a; + Vector ddij,ddik; PLMD::Angle a; double angle=a.compute(dij,dik,ddij,ddik); // And finish the calculation diff --git a/src/multicolvar/AtomValuePack.cpp b/src/multicolvar/AtomValuePack.cpp index 0cf4789984..605214f0b4 100644 --- a/src/multicolvar/AtomValuePack.cpp +++ b/src/multicolvar/AtomValuePack.cpp @@ -32,7 +32,8 @@ AtomValuePack::AtomValuePack( MultiValue& vals, MultiColvarBase const * mcolv ): natoms(0), indices( vals.getIndices() ), sort_vector( vals.getSortIndices() ), - myatoms( vals.getAtomVector() ) { + myatoms( vals.getAtomVector() ) +{ if( indices.size()!=mcolv->getNumberOfAtoms() ) { indices.resize( mcolv->getNumberOfAtoms() ); sort_vector.resize( mcolv->getNumberOfAtoms() ); @@ -41,40 +42,25 @@ AtomValuePack::AtomValuePack( MultiValue& vals, MultiColvarBase const * mcolv ): } unsigned AtomValuePack::setupAtomsFromLinkCells( const std::vector& cind, const Vector& cpos, const LinkCells& linkcells ) { - if( cells_required.size()!=linkcells.getNumberOfCells() ) { - cells_required.resize( linkcells.getNumberOfCells() ); - } + if( cells_required.size()!=linkcells.getNumberOfCells() ) cells_required.resize( linkcells.getNumberOfCells() ); // Build the list of cells that we need - unsigned ncells_required=0; - linkcells.addRequiredCells( linkcells.findMyCell( cpos ), ncells_required, cells_required ); + unsigned ncells_required=0; linkcells.addRequiredCells( linkcells.findMyCell( cpos ), ncells_required, cells_required ); // Now build the list of atoms we need - natoms=cind.size(); - for(unsigned i=0; igetPositionOfAtomForLinkCells( indices[i] ) - cpos; - } - if( mycolv->usesPbc() ) { - mycolv->applyPbc( myatoms, natoms ); - } + for(unsigned i=0; igetPositionOfAtomForLinkCells( indices[i] ) - cpos; + if( mycolv->usesPbc() ) mycolv->applyPbc( myatoms, natoms ); return natoms; } void AtomValuePack::updateUsingIndices() { - if( myvals.updateComplete() ) { - return; - } + if( myvals.updateComplete() ) return; unsigned jactive=0; for(unsigned i=0; igetNumberOfAtoms(); if( myvals.isActive( nvir ) ) { - for(unsigned i=0; i<9; ++i) { - myvals.putIndexInActiveArray( nvir + i ); - } + for(unsigned i=0; i<9; ++i) myvals.putIndexInActiveArray( nvir + i ); } myvals.completeUpdate(); } diff --git a/src/multicolvar/AtomValuePack.h b/src/multicolvar/AtomValuePack.h index 5c6e80275e..e438f91d17 100644 --- a/src/multicolvar/AtomValuePack.h +++ b/src/multicolvar/AtomValuePack.h @@ -116,32 +116,27 @@ unsigned AtomValuePack::getNumberOfDerivatives() const { inline void AtomValuePack::setIndex( const unsigned& j, const unsigned& ind ) { - plumed_dbg_assert( jgetPositionOfAtomForLinkCells( ind ); + setAtomIndex( j, ind ); myatoms[j]=mycolv->getPositionOfAtomForLinkCells( ind ); } inline unsigned AtomValuePack::getIndex( const unsigned& j ) const { - plumed_dbg_assert( jatom_lab[jatom].first>0 ) { unsigned mmc=mycolv->atom_lab[jatom].first - 1; return (mycolv->mybasemulticolvars[mmc])->getAbsoluteIndexOfCentralAtom( mycolv->atom_lab[jatom].second ); @@ -194,26 +189,18 @@ void AtomValuePack::addTemporyAtomsDerivatives( const unsigned& jder, const Vect inline void AtomValuePack::addTemporyBoxDerivatives( const Tensor& vir ) { unsigned nvir=3*mycolv->getNumberOfAtoms(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - myvals.addTemporyDerivative( nvir + 3*i+j, vir(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) myvals.addTemporyDerivative( nvir + 3*i+j, vir(i,j) ); } inline void AtomValuePack::addBoxDerivatives( const unsigned& ival, const Tensor& vir ) { unsigned nvir=3*mycolv->getNumberOfAtoms(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - myvals.addDerivative( ival, nvir + 3*i+j, vir(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) myvals.addDerivative( ival, nvir + 3*i+j, vir(i,j) ); } inline void AtomValuePack::updateDynamicList() { - if( myvals.updateComplete() ) { - return; - } + if( myvals.updateComplete() ) return; myvals.updateDynamicList(); } diff --git a/src/multicolvar/Bridge.cpp b/src/multicolvar/Bridge.cpp index e6215807e3..f8a072ba1c 100644 --- a/src/multicolvar/Bridge.cpp +++ b/src/multicolvar/Bridge.cpp @@ -67,9 +67,7 @@ class Bridge : public MultiColvarBase { explicit Bridge(const ActionOptions&); // active methods: double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(Bridge,"BRIDGE") @@ -89,45 +87,33 @@ void Bridge::registerKeywords( Keywords& keys ) { Bridge::Bridge(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the atoms std::vector all_atoms; readThreeGroups("GROUPA","GROUPB","BRIDGING_ATOMS",false,true,all_atoms); // Setup the multicolvar base setupMultiColvarBase( all_atoms ); // Setup Central atom atoms - std::vector catom_ind(3, false); - catom_ind[0]=true; + std::vector catom_ind(3, false); catom_ind[0]=true; setAtomsForCentralAtom( catom_ind ); - std::string sfinput,errors; - parse("SWITCH",sfinput); + std::string sfinput,errors; parse("SWITCH",sfinput); if( sfinput.length()>0 ) { sf1.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); sf2.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); } else { parse("SWITCHA",sfinput); if(sfinput.length()>0) { weightHasDerivatives=true; sf1.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCHA keyword : " + errors ); - } - sfinput.clear(); - parse("SWITCHB",sfinput); - if(sfinput.length()==0) { - error("found SWITCHA keyword without SWITCHB"); - } + if( errors.length()!=0 ) error("problem reading SWITCHA keyword : " + errors ); + sfinput.clear(); parse("SWITCHB",sfinput); + if(sfinput.length()==0) error("found SWITCHA keyword without SWITCHB"); sf2.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCHB keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCHB keyword : " + errors ); } else { error("missing definition of switching functions"); } @@ -139,9 +125,7 @@ Bridge::Bridge(const ActionOptions&ao): setLinkCellCutoff( sf1.get_dmax() + sf2.get_dmax() ); // And setup the ActionWithVessel - if( getNumberOfVessels()!=0 ) { - error("should not have vessels for this action"); - } + if( getNumberOfVessels()!=0 ) error("should not have vessels for this action"); std::string fake_input; addVessel( "SUM", fake_input, -1 ); // -1 here means that this value will be named getLabel() readVesselKeywords(); diff --git a/src/multicolvar/BridgedMultiColvarFunction.cpp b/src/multicolvar/BridgedMultiColvarFunction.cpp index dd5fecff86..a70eec53be 100644 --- a/src/multicolvar/BridgedMultiColvarFunction.cpp +++ b/src/multicolvar/BridgedMultiColvarFunction.cpp @@ -34,36 +34,26 @@ void BridgedMultiColvarFunction::registerKeywords( Keywords& keys ) { BridgedMultiColvarFunction::BridgedMultiColvarFunction(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { - std::string mlab; - parse("DATA",mlab); + MultiColvarBase(ao) +{ + std::string mlab; parse("DATA",mlab); mycolv = plumed.getActionSet().selectWithLabel(mlab); - if(!mycolv) { - error("action labeled " + mlab + " does not exist or is not a multicolvar"); - } + if(!mycolv) error("action labeled " + mlab + " does not exist or is not a multicolvar"); // When using numerical derivatives here we must use numerical derivatives // in base multicolvar - if( checkNumericalDerivatives() ) { - mycolv->useNumericalDerivatives(); - } + if( checkNumericalDerivatives() ) mycolv->useNumericalDerivatives(); - myBridgeVessel = mycolv->addBridgingVessel( this ); - addDependency(mycolv); - weightHasDerivatives=true; - usespecies=mycolv->usespecies; + myBridgeVessel = mycolv->addBridgingVessel( this ); addDependency(mycolv); + weightHasDerivatives=true; usespecies=mycolv->usespecies; // Number of tasks is the same as the number in the underlying MultiColvar - for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - addTaskToList( mycolv->getTaskCode(i) ); - } + for(unsigned i=0; igetFullNumberOfTasks(); ++i) addTaskToList( mycolv->getTaskCode(i) ); } void BridgedMultiColvarFunction::turnOnDerivatives() { BridgedMultiColvarFunction* check = dynamic_cast( mycolv ); if( check ) { - if( check->getNumberOfAtoms()>0 ) { - error("cannot calculate required derivatives of this quantity"); - } + if( check->getNumberOfAtoms()>0 ) error("cannot calculate required derivatives of this quantity"); } MultiColvarBase::turnOnDerivatives(); } @@ -75,20 +65,12 @@ void BridgedMultiColvarFunction::transformBridgedDerivatives( const unsigned& cu if( derivativesAreRequired() ) { outvals.emptyActiveMembers(); if( mycolv->isDensity() ) { - for(unsigned j=0; j<3; ++j) { - outvals.putIndexInActiveArray( 3*current+j ); - } - for(unsigned j=invals.getNumberOfDerivatives()-9; jgetNumberOfDerivatives() ) { invals.resize( mycolv->getNumberOfQuantities(), mycolv->getNumberOfDerivatives() ); } - invals.clearAll(); - mycolv->performTask( taskIndex, current, invals ); + invals.clearAll(); mycolv->performTask( taskIndex, current, invals ); transformBridgedDerivatives( taskIndex, invals, myvals ); } @@ -118,15 +99,11 @@ void BridgedMultiColvarFunction::calculateNumericalDerivatives( ActionWithValue* } void BridgedMultiColvarFunction::applyBridgeForces( const std::vector& bb ) { - if( getNumberOfAtoms()==0 ) { - return ; - } + if( getNumberOfAtoms()==0 ) return ; std::vector& f( modifyForces() ); for(unsigned i=0; i& indices ); void applyBridgeForces( const std::vector& bb ) override; diff --git a/src/multicolvar/CatomPack.cpp b/src/multicolvar/CatomPack.cpp index dbc4f3ebd4..3f0eee8cac 100644 --- a/src/multicolvar/CatomPack.cpp +++ b/src/multicolvar/CatomPack.cpp @@ -25,8 +25,7 @@ namespace PLMD { namespace multicolvar { void CatomPack::resize( const unsigned& size ) { - indices.resize(size); - derivs.resize(size); + indices.resize(size); derivs.resize(size); } } diff --git a/src/multicolvar/CenterOfMultiColvar.cpp b/src/multicolvar/CenterOfMultiColvar.cpp index f516880eb6..f88fbcc6e8 100644 --- a/src/multicolvar/CenterOfMultiColvar.cpp +++ b/src/multicolvar/CenterOfMultiColvar.cpp @@ -103,25 +103,19 @@ void CenterOfMultiColvar::registerKeywords(Keywords& keys) { CenterOfMultiColvar::CenterOfMultiColvar(const ActionOptions&ao): Action(ao), - ActionWithVirtualAtom(ao) { - std::string mlab; - parse("DATA",mlab); + ActionWithVirtualAtom(ao) +{ + std::string mlab; parse("DATA",mlab); mycolv= plumed.getActionSet().selectWithLabel(mlab); - if(!mycolv) { - error("action labelled " + mlab + " does not exist or does not have vessels"); - } + if(!mycolv) error("action labelled " + mlab + " does not exist or does not have vessels"); // Copy the atoms from the input multicolvar BridgedMultiColvarFunction* mybr=dynamic_cast( mycolv ); if( mybr ) { - requestAtoms( (mybr->getPntrToMultiColvar())->getAbsoluteIndexes() ); - comp=1; + requestAtoms( (mybr->getPntrToMultiColvar())->getAbsoluteIndexes() ); comp=1; } else { if( mycolv->getNumberOfQuantities()>5 ) { - int incomp=-1; - parse("COMPONENT",incomp); - if( incomp<0 ) { - error("vector input but component was not specified"); - } + int incomp=-1; parse("COMPONENT",incomp); + if( incomp<0 ) error("vector input but component was not specified"); comp=incomp; } else { comp=1; @@ -129,8 +123,7 @@ CenterOfMultiColvar::CenterOfMultiColvar(const ActionOptions&ao): requestAtoms( mycolv->getAbsoluteIndexes () ); } // We need the derivatives - mycolv->turnOnDerivatives(); - addDependency(mycolv); + mycolv->turnOnDerivatives(); addDependency(mycolv); mystash = mycolv->buildDataStashes( NULL ); log.printf(" building center of mass based on weights calculated in multicolvar action named %s \n",mycolv->getLabel().c_str() ); } @@ -138,21 +131,16 @@ CenterOfMultiColvar::CenterOfMultiColvar(const ActionOptions&ao): void CenterOfMultiColvar::calculate() { // Retrieve the periodic boundary conditions const Pbc& pbc=mycolv->getPbc(); - if( !pbc.isOrthorombic() ) { - error("Berry phase does not work for non orthorhombic cells"); - } + if( !pbc.isOrthorombic() ) error("Berry phase does not work for non orthorhombic cells"); // Create a multivalue to store the derivatives - MultiValue myvals( 7, mycolv->getNumberOfDerivatives() ); - myvals.clearAll(); + MultiValue myvals( 7, mycolv->getNumberOfDerivatives() ); myvals.clearAll(); MultiValue tvals( mycolv->getNumberOfQuantities(), mycolv->getNumberOfDerivatives() ); tvals.clearAll(); // Now loop over all active multicolvars Vector stmp, ctmp, scom, ccom, sder, cder; - scom.zero(); - ccom.zero(); - double norm=0; + scom.zero(); ccom.zero(); double norm=0; std::vector cvals( mycolv->getNumberOfQuantities() ); for(unsigned i=0; igetNumberOfStoredValues(); ++i) { // Retrieve value and derivatives @@ -162,10 +150,8 @@ void CenterOfMultiColvar::calculate() { Vector fpos = pbc.realToScaled( mycolv->getCentralAtomPos( mycolv->getPositionInFullTaskList(i) ) ); // Now accumulate Berry phase averages for(unsigned j=0; j<3; ++j) { - stmp[j] = std::sin( 2*pi*fpos[j] ); - ctmp[j] = std::cos( 2*pi*fpos[j] ); - scom[j] += cvals[0]*cvals[comp]*stmp[j]; - ccom[j] += cvals[0]*cvals[comp]*ctmp[j]; + stmp[j] = std::sin( 2*pi*fpos[j] ); ctmp[j] = std::cos( 2*pi*fpos[j] ); + scom[j] += cvals[0]*cvals[comp]*stmp[j]; ccom[j] += cvals[0]*cvals[comp]*ctmp[j]; double icell = 1.0 / getPbc().getBox().getRow(j).modulo(); sder[j] = 2*pi*icell*cvals[0]*cvals[comp]*std::cos( 2*pi*fpos[j] ); cder[j]=-2*pi*icell*cvals[0]*cvals[comp]*std::sin( 2*pi*fpos[j] ); @@ -182,8 +168,7 @@ void CenterOfMultiColvar::calculate() { } } // Get the central atom pack - CatomPack mypack; - mycolv->getCentralAtomPack( 0, mycolv->getPositionInFullTaskList(i), mypack ); + CatomPack mypack; mycolv->getCentralAtomPack( 0, mycolv->getPositionInFullTaskList(i), mypack ); for(unsigned j=0; j fderiv( getNumberOfAtoms() ); for(unsigned j=0; j0) { switchingFunction.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } @@ -169,9 +150,7 @@ CoordinationNumbers::CoordinationNumbers(const ActionOptions&ao): rcut2 = rcut * rcut; // And setup the ActionWithVessel - std::vector all_atoms; - setupMultiColvarBase( all_atoms ); - checkRead(); + std::vector all_atoms; setupMultiColvarBase( all_atoms ); checkRead(); } double CoordinationNumbers::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { @@ -187,8 +166,7 @@ double CoordinationNumbers::compute( const unsigned& tindex, AtomValuePack& myat sw = switchingFunction.calculateSqr( d2, dfunc ); if(r_power > 0) { - d = std::sqrt(d2); - raised = std::pow( d, r_power - 1 ); + d = std::sqrt(d2); raised = std::pow( d, r_power - 1 ); accumulateSymmetryFunction( 1, i, sw * raised * d, (dfunc * d * raised + sw * r_power * raised / d) * distance, (-dfunc * d * raised - sw * r_power * raised / d) * Tensor(distance, distance), diff --git a/src/multicolvar/Density.cpp b/src/multicolvar/Density.cpp index 510ec4eb56..679d6d91f5 100644 --- a/src/multicolvar/Density.cpp +++ b/src/multicolvar/Density.cpp @@ -55,15 +55,9 @@ class Density : public MultiColvarBase { // active methods: double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return false; - } - bool isDensity() const override { - return true; - } - bool hasDifferentiableOrientation() const override { - return true; - } + bool isPeriodic() override { return false; } + bool isDensity() const override { return true; } + bool hasDifferentiableOrientation() const override { return true; } // void addOrientationDerivativesToBase( const unsigned& iatom, const unsigned& jstore, const unsigned& base_cv_no, // const std::vector& weight, MultiColvarFunction* func ){} void getIndexList( const unsigned& ntotal, const unsigned& jstore, const unsigned& maxder, std::vector& indices ); @@ -80,15 +74,11 @@ void Density::registerKeywords( Keywords& keys ) { Density::Density(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { - std::vector all_atoms; - parseMultiColvarAtomList("SPECIES", -1, all_atoms); - ablocks.resize(1); - ablocks[0].resize( atom_lab.size() ); - for(unsigned i=0; i all_atoms; parseMultiColvarAtomList("SPECIES", -1, all_atoms); + ablocks.resize(1); ablocks[0].resize( atom_lab.size() ); + for(unsigned i=0; i& vals ) { - plumed_dbg_assert( vals.size()==2 ); - vals[0]=vals[1]=1.0; + plumed_dbg_assert( vals.size()==2 ); vals[0]=vals[1]=1.0; } } diff --git a/src/multicolvar/DihedralCorrelation.cpp b/src/multicolvar/DihedralCorrelation.cpp index c4305e2ed4..239f128831 100644 --- a/src/multicolvar/DihedralCorrelation.cpp +++ b/src/multicolvar/DihedralCorrelation.cpp @@ -86,9 +86,7 @@ class DihedralCorrelation : public MultiColvarBase { static void registerKeywords( Keywords& keys ); explicit DihedralCorrelation(const ActionOptions&); double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(DihedralCorrelation,"DIHCOR") @@ -105,7 +103,8 @@ void DihedralCorrelation::registerKeywords( Keywords& keys ) { DihedralCorrelation::DihedralCorrelation(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the atoms std::vector all_atoms; readAtomsLikeKeyword( "ATOMS", 8, all_atoms ); diff --git a/src/multicolvar/DistanceFromContour.cpp b/src/multicolvar/DistanceFromContour.cpp index 591db68938..18acaf1263 100644 --- a/src/multicolvar/DistanceFromContour.cpp +++ b/src/multicolvar/DistanceFromContour.cpp @@ -87,14 +87,10 @@ class DistanceFromContour : public MultiColvarBase { public: static void registerKeywords( Keywords& keys ); explicit DistanceFromContour( const ActionOptions& ); - bool isDensity() const override { - return true; - } + bool isDensity() const override { return true; } void calculate() override; unsigned getNumberOfQuantities() const override; - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; double getDifferenceFromContour( const std::vector& x, std::vector& der ); // We need an apply action as we are using an independent value @@ -134,104 +130,61 @@ DistanceFromContour::DistanceFromContour( const ActionOptions& ao ): dirv(3,0.0), dirv2(3,0.0), perp_dirs(2), - mymin(this) { + mymin(this) +{ // Read in the multicolvar/atoms - std::vector all_atoms; - parse("TOLERANCE",pbc_param); + std::vector all_atoms; parse("TOLERANCE",pbc_param); bool read2 = parseMultiColvarAtomList("DATA", -1, all_atoms); - if( !read2 ) { - error("missing DATA keyword"); - } + if( !read2 ) error("missing DATA keyword"); bool read1 = parseMultiColvarAtomList("ATOM", -1, all_atoms); - if( !read1 ) { - error("missing ATOM keyword"); - } - if( all_atoms.size()!=1 ) { - error("should only be one atom specified"); - } + if( !read1 ) error("missing ATOM keyword"); + if( all_atoms.size()!=1 ) error("should only be one atom specified"); // Read in the center of the binding object log.printf(" computing distance of atom %d from contour \n",all_atoms[0].serial() ); - setupMultiColvarBase( all_atoms ); - forces.resize( 3*getNumberOfAtoms() + 9 ); - if( getNumberOfBaseMultiColvars()!=1 ) { - error("should only be one input multicolvar"); - } + setupMultiColvarBase( all_atoms ); forces.resize( 3*getNumberOfAtoms() + 9 ); + if( getNumberOfBaseMultiColvars()!=1 ) error("should only be one input multicolvar"); // Get the direction - std::string ldir; - parse("DIR",ldir ); - if( ldir=="x" ) { - dir=0; - perp_dirs[0]=1; - perp_dirs[1]=2; - dirv[0]=1; - dirv2[0]=-1; - } else if( ldir=="y" ) { - dir=1; - perp_dirs[0]=0; - perp_dirs[1]=2; - dirv[1]=1; - dirv2[1]=-1; - } else if( ldir=="z" ) { - dir=2; - perp_dirs[0]=0; - perp_dirs[1]=1; - dirv[2]=1; - dirv2[2]=-1; - } else { - error(ldir + " is not a valid direction use x, y or z"); - } + std::string ldir; parse("DIR",ldir ); + if( ldir=="x" ) { dir=0; perp_dirs[0]=1; perp_dirs[1]=2; dirv[0]=1; dirv2[0]=-1; } + else if( ldir=="y" ) { dir=1; perp_dirs[0]=0; perp_dirs[1]=2; dirv[1]=1; dirv2[1]=-1; } + else if( ldir=="z" ) { dir=2; perp_dirs[0]=0; perp_dirs[1]=1; dirv[2]=1; dirv2[2]=-1; } + else error(ldir + " is not a valid direction use x, y or z"); // Read in details of phase field construction - parseVector("BANDWIDTH",bw); - parse("KERNEL",kerneltype); - parse("CONTOUR",contour); + parseVector("BANDWIDTH",bw); parse("KERNEL",kerneltype); parse("CONTOUR",contour); log.printf(" searching for contour in %s direction at %f in phase field for multicolvar %s \n",ldir.c_str(), contour, mybasemulticolvars[0]->getLabel().c_str() ); log.printf(" constructing phase field using %s kernels with bandwidth (%f, %f, %f) \n",kerneltype.c_str(), bw[0], bw[1], bw[2] ); // Now create a task list - for(unsigned i=0; igetFullNumberOfTasks(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetFullNumberOfTasks(); ++i) addTaskToList(i); // And a cutoff std::vector pp( bw.size(),0 ); KernelFunctions kernel( pp, bw, kerneltype, "DIAGONAL", 1.0 ); double rcut = kernel.getCutoff( bw[0] ); for(unsigned j=1; jrcut ) { - rcut=kernel.getCutoff(bw[j]); - } + if( kernel.getCutoff(bw[j])>rcut ) rcut=kernel.getCutoff(bw[j]); } rcut2=rcut*rcut; // Create the values - addComponent("thickness"); - componentIsNotPeriodic("thickness"); - addComponent("dist1"); - componentIsNotPeriodic("dist1"); - addComponent("dist2"); - componentIsNotPeriodic("dist2"); - addComponentWithDerivatives("qdist"); - componentIsNotPeriodic("qdist"); + addComponent("thickness"); componentIsNotPeriodic("thickness"); + addComponent("dist1"); componentIsNotPeriodic("dist1"); + addComponent("dist2"); componentIsNotPeriodic("dist2"); + addComponentWithDerivatives("qdist"); componentIsNotPeriodic("qdist"); // Create sum vessels - std::string fake_input; - std::string deriv_input="COMPONENT=2"; + std::string fake_input; std::string deriv_input="COMPONENT=2"; if( mybasemulticolvars[0]->isDensity() ) { - addVessel( "SUM", fake_input, -1 ); - addVessel( "SUM", deriv_input, -1 ); + addVessel( "SUM", fake_input, -1 ); addVessel( "SUM", deriv_input, -1 ); } else { - addVessel( "MEAN", fake_input, -1 ); - addVessel( "MEAN", deriv_input, -1 ); + addVessel( "MEAN", fake_input, -1 ); addVessel( "MEAN", deriv_input, -1 ); } // And convert to a value vessel so we can get the final value myvalue_vessel = dynamic_cast( getPntrToVessel(0) ); myderiv_vessel = dynamic_cast( getPntrToVessel(1) ); - plumed_assert( myvalue_vessel && myderiv_vessel ); - resizeFunctions(); + plumed_assert( myvalue_vessel && myderiv_vessel ); resizeFunctions(); // Create the vector of values that holds the position - for(unsigned i=0; i<3; ++i) { - pval.emplace_back( Tools::make_unique() ); - } + for(unsigned i=0; i<3; ++i) pval.emplace_back( Tools::make_unique() ); } unsigned DistanceFromContour::getNumberOfQuantities() const { @@ -240,35 +193,26 @@ unsigned DistanceFromContour::getNumberOfQuantities() const { void DistanceFromContour::calculate() { // Check box is orthorhombic - if( !getPbc().isOrthorombic() ) { - error("cell box must be orthorhombic"); - } + if( !getPbc().isOrthorombic() ) error("cell box must be orthorhombic"); // The nanoparticle is at the origin of our coordinate system - pos1[0]=pos1[1]=pos1[2]=0.0; - pos2[0]=pos2[1]=pos2[2]=0.0; + pos1[0]=pos1[1]=pos1[2]=0.0; pos2[0]=pos2[1]=pos2[2]=0.0; // Set bracket as center of mass of membrane in active region deactivateAllTasks(); - Vector myvec = getSeparation( getPosition(getNumberOfAtoms()-1), getPosition(0) ); - pos2[dir]=myvec[dir]; - taskFlags[0]=1; - double mindist = myvec.modulo2(); + Vector myvec = getSeparation( getPosition(getNumberOfAtoms()-1), getPosition(0) ); pos2[dir]=myvec[dir]; + taskFlags[0]=1; double mindist = myvec.modulo2(); for(unsigned j=1; jepsilon ) { - pos2[dir]=distance[dir]; - mindist = d2; - } + if( d2epsilon ) { pos2[dir]=distance[dir]; mindist = d2; } taskFlags[j]=1; } } - lockContributors(); - derivTime=false; + lockContributors(); derivTime=false; // pos1 position of the nanoparticle, in the first time // pos2 is the position of the closer atom in the membrane with respect the nanoparticle // fa = distance between pos1 and the contour @@ -280,11 +224,8 @@ void DistanceFromContour::calculate() { unsigned maxtries = std::floor( ( getBox()(dir,dir) ) / bw[dir] ); for(unsigned i=0; i0)? -1 : +1; // If the nanoparticle is inside the membrane push it out - pos1[dir] += sign*bw[dir]; - fa = getDifferenceFromContour( pos1, faked ); - if( fa*fb<0 ) { - break; - } + pos1[dir] += sign*bw[dir]; fa = getDifferenceFromContour( pos1, faked ); + if( fa*fb<0 ) break; // if fa*fb is less than zero the new pos 1 is outside the contour } } @@ -298,11 +239,8 @@ void DistanceFromContour::calculate() { unsigned maxtries = std::floor( ( getBox()(dir,dir) ) / bw[dir] ); for(unsigned i=0; i0)? +1 : -1; - pos2[dir] += sign*bw[dir]; - fc = getDifferenceFromContour( pos2, faked ); - if( fc*fb<0 ) { - break; - } + pos2[dir] += sign*bw[dir]; fc = getDifferenceFromContour( pos2, faked ); + if( fc*fb<0 ) break; } dirv2[dir] = ( pos1[dir] + dirv[dir] ) - pos2[dir]; } @@ -310,17 +248,11 @@ void DistanceFromContour::calculate() { // Now do a search for the two contours mymin.lsearch( dirv, pos1, &DistanceFromContour::getDifferenceFromContour ); // Save the first value - Vector root1; - root1.zero(); - root1[dir] = pval[dir]->get(); + Vector root1; root1.zero(); root1[dir] = pval[dir]->get(); mymin.lsearch( dirv2, pos2, &DistanceFromContour::getDifferenceFromContour ); // Calculate the separation between the two roots using PBC - Vector root2; - root2.zero(); - root2[dir]=pval[dir]->get(); - Vector sep = getSeparation( root1, root2 ); - double spacing = std::fabs( sep[dir] ); - plumed_assert( spacing>epsilon ); + Vector root2; root2.zero(); root2[dir]=pval[dir]->get(); + Vector sep = getSeparation( root1, root2 ); double spacing = std::fabs( sep[dir] ); plumed_assert( spacing>epsilon ); getPntrToComponent("thickness")->set( spacing ); // Make sure the sign is right @@ -341,39 +273,19 @@ void DistanceFromContour::calculate() { // Now calculate the derivatives if( !doNotCalculateDerivatives() ) { - Value* ival=myvalue_vessel->getFinalValue(); - ival->clearDerivatives(); - std::vector root1v(3); - for(unsigned i=0; i<3; ++i) { - root1v[i]=root1[i]; - } - derivTime=true; - std::vector der(3); - getDifferenceFromContour( root1v, der ); - double prefactor; - if( mybasemulticolvars[0]->isDensity() ) { - prefactor = root2[dir] / myderiv_vessel->getOutputValue(); - } else { - plumed_error(); - } + Value* ival=myvalue_vessel->getFinalValue(); ival->clearDerivatives(); + std::vector root1v(3); for(unsigned i=0; i<3; ++i) root1v[i]=root1[i]; + derivTime=true; std::vector der(3); getDifferenceFromContour( root1v, der ); double prefactor; + if( mybasemulticolvars[0]->isDensity() ) prefactor = root2[dir] / myderiv_vessel->getOutputValue(); + else plumed_error(); Value* val=getPntrToComponent("qdist"); - for(unsigned i=0; igetNumberOfDerivatives(); ++i) { - val->setDerivative( i, -prefactor*ival->getDerivative(i) ); - } + for(unsigned i=0; igetNumberOfDerivatives(); ++i) val->setDerivative( i, -prefactor*ival->getDerivative(i) ); ival->clearDerivatives(); - std::vector root2v(3); - for(unsigned i=0; i<3; ++i) { - root2v[i]=root2[i]; - } + std::vector root2v(3); for(unsigned i=0; i<3; ++i) root2v[i]=root2[i]; getDifferenceFromContour( root2v, der ); - if( mybasemulticolvars[0]->isDensity() ) { - prefactor = root1[dir] / myderiv_vessel->getOutputValue(); - } else { - plumed_error(); - } - for(unsigned i=0; igetNumberOfDerivatives(); ++i) { - val->addDerivative( i, -prefactor*ival->getDerivative(i) ); - } + if( mybasemulticolvars[0]->isDensity() ) prefactor = root1[dir] / myderiv_vessel->getOutputValue(); + else plumed_error(); + for(unsigned i=0; igetNumberOfDerivatives(); ++i) val->addDerivative( i, -prefactor*ival->getDerivative(i) ); } } @@ -382,8 +294,7 @@ double DistanceFromContour::getDifferenceFromContour( const std::vector& for(unsigned j=0; j<3; ++j) { Tools::convert( -0.5*getBox()(j,j), min ); Tools::convert( +0.5*getBox()(j,j), max ); - pval[j]->setDomain( min, max ); - pval[j]->set( x[j] ); + pval[j]->setDomain( min, max ); pval[j]->set( x[j] ); } runAllTasks(); return myvalue_vessel->getOutputValue() - contour; @@ -391,34 +302,27 @@ double DistanceFromContour::getDifferenceFromContour( const std::vector& double DistanceFromContour::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { Vector distance = getSeparation( getPosition(getNumberOfAtoms()-1), myatoms.getPosition(0) ); - std::vector pp(3), der(3,0); - for(unsigned j=0; j<3; ++j) { - pp[j] = distance[j]; - } + std::vector pp(3), der(3,0); for(unsigned j=0; j<3; ++j) pp[j] = distance[j]; // convert the pointer once auto pval_ptr=Tools::unique2raw(pval); // Now create the kernel and evaluate KernelFunctions kernel( pp, bw, kerneltype, "DIAGONAL", 1.0 ); - kernel.normalize( pval_ptr ); - double newval = kernel.evaluate( pval_ptr, der, true ); + kernel.normalize( pval_ptr ); double newval = kernel.evaluate( pval_ptr, der, true ); if( mybasemulticolvars[0]->isDensity() ) { if( !doNotCalculateDerivatives() && derivTime ) { MultiValue& myvals=myatoms.getUnderlyingMultiValue(); - Vector vder; - unsigned basen=myvals.getNumberOfDerivatives() - 12; + Vector vder; unsigned basen=myvals.getNumberOfDerivatives() - 12; for(unsigned i=0; i<3; ++i) { - vder[i]=der[i]; - myvals.addDerivative( 1, basen+i, vder[i] ); + vder[i]=der[i]; myvals.addDerivative( 1, basen+i, vder[i] ); } myatoms.setValue( 2, der[dir] ); addAtomDerivatives( 1, 0, -vder, myatoms ); myatoms.addBoxDerivatives( 1, Tensor(vder,distance) ); } - myatoms.setValue( 0, 1.0 ); - return newval; + myatoms.setValue( 0, 1.0 ); return newval; } // This does the stuff for averaging @@ -431,9 +335,7 @@ double DistanceFromContour::compute( const unsigned& tindex, AtomValuePack& myat } void DistanceFromContour::apply() { - if( getPntrToComponent("qdist")->applyForce( forces ) ) { - setForcesOnAtoms( forces ); - } + if( getPntrToComponent("qdist")->applyForce( forces ) ) setForcesOnAtoms( forces ); } } diff --git a/src/multicolvar/Distances.cpp b/src/multicolvar/Distances.cpp index 3465ea9539..624f49a66e 100644 --- a/src/multicolvar/Distances.cpp +++ b/src/multicolvar/Distances.cpp @@ -129,26 +129,16 @@ class Distances : public MultiColvarBase { // active methods: double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(Distances,"DISTANCES") void Distances::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("ALT_MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("MAX"); - keys.use("LESS_THAN"); // keys.use("DHENERGY"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("ALT_MIN"); keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("MEAN"); keys.use("MIN"); keys.use("MAX"); keys.use("LESS_THAN"); // keys.use("DHENERGY"); + keys.use("MORE_THAN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.add("numbered","ATOMS","the atoms involved in each of the distances you wish to calculate. " "Keywords like ATOMS1, ATOMS2, ATOMS3,... should be listed and one distance will be " "calculated for each ATOM keyword you specify (all ATOM keywords should " @@ -164,31 +154,25 @@ void Distances::registerKeywords( Keywords& keys ) { Distances::Distances(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the atoms std::vector all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); setupMultiColvarBase( all_atoms ); // And check everything has been read in correctly checkRead(); // Now check if we can use link cells if( getNumberOfVessels()>0 ) { - bool use_link=false; - double rcut; + bool use_link=false; double rcut; vesselbase::LessThan* lt=dynamic_cast( getPntrToVessel(0) ); if( lt ) { - use_link=true; - rcut=lt->getCutoff(); + use_link=true; rcut=lt->getCutoff(); } else { vesselbase::Between* bt=dynamic_cast( getPntrToVessel(0) ); - if( bt ) { - use_link=true; - rcut=bt->getCutoff(); - } + if( bt ) { use_link=true; rcut=bt->getCutoff(); } } if( use_link ) { for(unsigned i=1; i( getPntrToVessel(i) ); if( lt2 ) { double tcut=lt2->getCutoff(); - if( tcut>rcut ) { - rcut=tcut; - } + if( tcut>rcut ) rcut=tcut; } else if( bt ) { double tcut=bt->getCutoff(); - if( tcut>rcut ) { - rcut=tcut; - } + if( tcut>rcut ) rcut=tcut; } else { use_link=false; } } } - if( use_link ) { - setLinkCellCutoff( rcut ); - } + if( use_link ) setLinkCellCutoff( rcut ); } } diff --git a/src/multicolvar/DumpMultiColvar.cpp b/src/multicolvar/DumpMultiColvar.cpp index 567ed0ece0..d84e34a507 100644 --- a/src/multicolvar/DumpMultiColvar.cpp +++ b/src/multicolvar/DumpMultiColvar.cpp @@ -34,7 +34,8 @@ #include "vesselbase/ActionWithInputVessel.h" #include "vesselbase/StoreDataVessel.h" -namespace PLMD { +namespace PLMD +{ namespace multicolvar { //+PLUMEDOC PRINTANALYSIS DUMPMULTICOLVAR @@ -63,7 +64,8 @@ DUMPMULTICOLVAR DATA=slt FILE=MULTICOLVAR.xyz class DumpMultiColvar: public ActionPilot, public ActionAtomistic, - public vesselbase::ActionWithInputVessel { + public vesselbase::ActionWithInputVessel +{ OFile of; double lenunit; MultiColvarBase* mycolv; @@ -73,9 +75,7 @@ class DumpMultiColvar: ~DumpMultiColvar(); static void registerKeywords( Keywords& keys ); void calculate() override {} - void calculateNumericalDerivatives( ActionWithValue* vv ) override { - plumed_error(); - } + void calculateNumericalDerivatives( ActionWithValue* vv ) override { plumed_error(); } void apply() override {} void update() override; }; @@ -98,42 +98,30 @@ DumpMultiColvar::DumpMultiColvar(const ActionOptions&ao): Action(ao), ActionPilot(ao), ActionAtomistic(ao), - ActionWithInputVessel(ao) { + ActionWithInputVessel(ao) +{ readArgument("store"); mycolv = dynamic_cast( getDependencies()[0] ); plumed_assert( getDependencies().size()==1 ); - if(!mycolv) { - error("action labeled " + getDependencies()[0]->getLabel() + " is not a multicolvar"); - } + if(!mycolv) error("action labeled " + getDependencies()[0]->getLabel() + " is not a multicolvar"); log.printf(" printing colvars calculated by action %s \n",mycolv->getLabel().c_str() ); std::vector atom; parseAtomList("ORIGIN",atom); - if( atom.size()>1 ) { - error("should only be one atom specified"); - } - if( atom.size()==1 ) { - log.printf(" origin is at position of atom : %d\n",atom[0].serial() ); - } + if( atom.size()>1 ) error("should only be one atom specified"); + if( atom.size()==1 ) log.printf(" origin is at position of atom : %d\n",atom[0].serial() ); - std::string file; - parse("FILE",file); - if(file.length()==0) { - error("name out output file was not specified"); - } + std::string file; parse("FILE",file); + if(file.length()==0) error("name out output file was not specified"); std::string type=Tools::extension(file); log<<" file name "<0) { - int p; - Tools::convert(precision,p); + int p; Tools::convert(precision,p); log<<" with precision "<getCentralAtomPos( mycolv->getPositionInFullTaskList(i) ); - if( getNumberOfAtoms()>0 ) { - apos=pbcDistance( getPosition(0), apos ); - } + if( getNumberOfAtoms()>0 ) apos=pbcDistance( getPosition(0), apos ); of.printf(("%s "+fmt_xyz+" "+fmt_xyz+" "+fmt_xyz).c_str(),name,lenunit*apos[0],lenunit*apos[1],lenunit*apos[2]); stash->retrieveSequentialValue( i, true, cvals ); if( mycolv->weightWithDerivatives() ) { - for(unsigned j=0; jisPeriodic() ) { - std::string min, max; - getPntrToMultiColvar()->retrieveDomain( min, max ); - double mlow, mhigh; - Tools::convert( min,mlow ); - Tools::convert( max, mhigh); + std::string min, max; getPntrToMultiColvar()->retrieveDomain( min, max ); + double mlow, mhigh; Tools::convert( min,mlow ); Tools::convert( max, mhigh); hb.isPeriodic( mlow, mhigh ); } else { hb.isNotPeriodic(); @@ -175,21 +172,13 @@ FilterBetween::FilterBetween(const ActionOptions& ao): if(sw.length()>0) { hb.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading BEAD keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading BEAD keyword : " + errors ); } else { - double l, u, s; - std::string ll, uu, ss; - parse("LOWER",l); - parse("UPPER",u); - parse("SMEAR",s); - Tools::convert(l,ll); - Tools::convert(u,uu); - Tools::convert(s,ss); + double l, u, s; std::string ll, uu, ss; + parse("LOWER",l); parse("UPPER",u); parse("SMEAR",s); + Tools::convert(l,ll); Tools::convert(u,uu); Tools::convert(s,ss); sw="GAUSSIAN LOWER=" + ll + " UPPER=" + uu + " SMEAR=" + ss; - hb.set(sw,errors); - plumed_massert(errors.length()==0,"problems with bead" + errors); + hb.set(sw,errors); plumed_massert(errors.length()==0,"problems with bead" + errors); } log.printf(" filtering colvar values and focussing only on those values in range %s\n",( hb.description() ).c_str() ); diff --git a/src/multicolvar/FilterLessThan.cpp b/src/multicolvar/FilterLessThan.cpp index 949e13671c..c2d9385d6c 100644 --- a/src/multicolvar/FilterLessThan.cpp +++ b/src/multicolvar/FilterLessThan.cpp @@ -134,25 +134,18 @@ void FilterLess::registerKeywords( Keywords& keys ) { FilterLess::FilterLess(const ActionOptions& ao): Action(ao), - MultiColvarFilter(ao) { + MultiColvarFilter(ao) +{ // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { sf.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); sf.set(nn,mm,r_0,d_0); } log.printf(" filtering colvar values and focussing only on those less than %s\n",( sf.description() ).c_str() ); @@ -161,8 +154,7 @@ FilterLess::FilterLess(const ActionOptions& ao): } double FilterLess::applyFilter( const double& val, double& df ) const { - double f = sf.calculate( val, df ); - df*=val; + double f = sf.calculate( val, df ); df*=val; return f; } diff --git a/src/multicolvar/FilterMoreThan.cpp b/src/multicolvar/FilterMoreThan.cpp index 28b7e0379b..a26a570780 100644 --- a/src/multicolvar/FilterMoreThan.cpp +++ b/src/multicolvar/FilterMoreThan.cpp @@ -151,25 +151,18 @@ void FilterMore::registerKeywords( Keywords& keys ) { FilterMore::FilterMore(const ActionOptions& ao): Action(ao), - MultiColvarFilter(ao) { + MultiColvarFilter(ao) +{ // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { sf.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); sf.set(nn,mm,r_0,d_0); } log.printf(" filtering colvar values and focussing only on those more than %s\n",( sf.description() ).c_str() ); @@ -178,8 +171,7 @@ FilterMore::FilterMore(const ActionOptions& ao): } double FilterMore::applyFilter( const double& val, double& df ) const { - double f = 1.0 - sf.calculate( val, df ); - df*=-val; + double f = 1.0 - sf.calculate( val, df ); df*=-val; return f; } diff --git a/src/multicolvar/InPlaneDistances.cpp b/src/multicolvar/InPlaneDistances.cpp index db4a395a5d..289a4ca01b 100644 --- a/src/multicolvar/InPlaneDistances.cpp +++ b/src/multicolvar/InPlaneDistances.cpp @@ -66,26 +66,16 @@ class InPlaneDistances : public MultiColvarBase { explicit InPlaneDistances(const ActionOptions&); // active methods: double compute(const unsigned& tindex, AtomValuePack& myatoms ) const override; - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(InPlaneDistances,"INPLANEDISTANCES") void InPlaneDistances::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("ALT_MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("MAX"); - keys.use("LESS_THAN"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("ALT_MIN"); keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("MEAN"); keys.use("MIN"); keys.use("MAX"); keys.use("LESS_THAN"); + keys.use("MORE_THAN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.add("atoms","VECTORSTART","The first atom position that is used to define the normal to the plane of interest"); keys.add("atoms","VECTOREND","The second atom position that is used to define the normal to the plane of interest"); keys.add("atoms-2","GROUP","The set of atoms for which you wish to calculate the in plane distance "); @@ -93,35 +83,30 @@ void InPlaneDistances::registerKeywords( Keywords& keys ) { InPlaneDistances::InPlaneDistances(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the atoms std::vector all_atoms; readThreeGroups("GROUP","VECTORSTART","VECTOREND",false,false,all_atoms); setupMultiColvarBase( all_atoms ); // Setup the multicolvar base - setupMultiColvarBase( all_atoms ); - readVesselKeywords(); + setupMultiColvarBase( all_atoms ); readVesselKeywords(); // Check atoms are OK - if( getFullNumberOfTasks()!=getNumberOfAtoms()-2 ) { - error("you should specify one atom for VECTORSTART and one atom for VECTOREND only"); - } + if( getFullNumberOfTasks()!=getNumberOfAtoms()-2 ) error("you should specify one atom for VECTORSTART and one atom for VECTOREND only"); // And check everything has been read in correctly checkRead(); // Now check if we can use link cells if( getNumberOfVessels()>0 ) { - bool use_link=false; - double rcut; + bool use_link=false; double rcut; vesselbase::LessThan* lt=dynamic_cast( getPntrToVessel(0) ); if( lt ) { - use_link=true; - rcut=lt->getCutoff(); + use_link=true; rcut=lt->getCutoff(); } else { vesselbase::Between* bt=dynamic_cast( getPntrToVessel(0) ); if( bt ) { - use_link=true; - rcut=bt->getCutoff(); + use_link=true; rcut=bt->getCutoff(); } } if( use_link ) { @@ -130,31 +115,23 @@ InPlaneDistances::InPlaneDistances(const ActionOptions&ao): vesselbase::Between* bt=dynamic_cast( getPntrToVessel(i) ); if( lt2 ) { double tcut=lt2->getCutoff(); - if( tcut>rcut ) { - rcut=tcut; - } + if( tcut>rcut ) rcut=tcut; } else if( bt ) { double tcut=bt->getCutoff(); - if( tcut>rcut ) { - rcut=tcut; - } + if( tcut>rcut ) rcut=tcut; } else { use_link=false; } } } - if( use_link ) { - setLinkCellCutoff( rcut ); - } + if( use_link ) setLinkCellCutoff( rcut ); } } double InPlaneDistances::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { Vector normal=getSeparation( myatoms.getPosition(1), myatoms.getPosition(2) ); Vector dir=getSeparation( myatoms.getPosition(1), myatoms.getPosition(0) ); - PLMD::Angle a; - Vector ddij, ddik; - double angle=a.compute(normal,dir,ddij,ddik); + PLMD::Angle a; Vector ddij, ddik; double angle=a.compute(normal,dir,ddij,ddik); double sangle=std::sin(angle), cangle=std::cos(angle); double dd=dir.modulo(), invdd=1.0/dd, val=dd*sangle; diff --git a/src/multicolvar/LocalAverage.cpp b/src/multicolvar/LocalAverage.cpp index 1d76d80029..11a9eb3344 100644 --- a/src/multicolvar/LocalAverage.cpp +++ b/src/multicolvar/LocalAverage.cpp @@ -97,9 +97,7 @@ class LocalAverage : public MultiColvarBase { /// We overwrite this in order to have dumpmulticolvar working for local average void normalizeVector( std::vector& vals ) const override {} /// Is the variable periodic - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(LocalAverage,"LOCAL_AVERAGE") @@ -114,53 +112,34 @@ void LocalAverage::registerKeywords( Keywords& keys ) { "The following provides information on the \\ref switchingfunction that are available. " "When this keyword is present you no longer need the NN, MM, D_0 and R_0 keywords."); // Use actionWithDistributionKeywords - keys.use("SPECIES"); - keys.use("SPECIESA"); - keys.use("SPECIESB"); - keys.remove("LOWMEM"); - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("LESS_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("SPECIES"); keys.use("SPECIESA"); keys.use("SPECIESB"); + keys.remove("LOWMEM"); keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("LESS_THAN"); + keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.addFlag("LOWMEM",false,"lower the memory requirements"); - if( keys.reserved("VMEAN") ) { - keys.use("VMEAN"); - } - if( keys.reserved("VSUM") ) { - keys.use("VSUM"); - } + if( keys.reserved("VMEAN") ) keys.use("VMEAN"); + if( keys.reserved("VSUM") ) keys.use("VSUM"); } LocalAverage::LocalAverage(const ActionOptions& ao): Action(ao), - MultiColvarBase(ao) { - if( getNumberOfBaseMultiColvars()>1 ) { - error("local average with more than one base colvar makes no sense"); - } + MultiColvarBase(ao) +{ + if( getNumberOfBaseMultiColvars()>1 ) error("local average with more than one base colvar makes no sense"); // Read in the switching function - std::string sw, errors; - parse("SWITCH",sw); + std::string sw, errors; parse("SWITCH",sw); if(sw.length()>0) { switchingFunction.set(sw,errors); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } log.printf(" averaging over central molecule and those within %s\n",( switchingFunction.description() ).c_str() ); rcut2 = switchingFunction.get_dmax()*switchingFunction.get_dmax(); setLinkCellCutoff( switchingFunction.get_dmax() ); - std::vector all_atoms; - setupMultiColvarBase( all_atoms ); + std::vector all_atoms; setupMultiColvarBase( all_atoms ); } unsigned LocalAverage::getNumberOfQuantities() const { @@ -168,16 +147,13 @@ unsigned LocalAverage::getNumberOfQuantities() const { } double LocalAverage::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { - double sw, dfunc; - MultiValue& myvals = myatoms.getUnderlyingMultiValue(); + double sw, dfunc; MultiValue& myvals = myatoms.getUnderlyingMultiValue(); std::vector values( getBaseMultiColvar(0)->getNumberOfQuantities() ); getInputData( 0, false, myatoms, values ); myvals.addTemporyValue( values[0] ); if( values.size()>2 ) { - for(unsigned j=2; j0 ); + unsigned katom = myatoms.getIndex( 0 ); plumed_dbg_assert( katom0 ); // Find base colvar - unsigned mmc=atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + unsigned mmc=atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); // Get start of indices for this atom - unsigned basen=0; - for(unsigned i=0; igetNumberOfDerivatives() - 9; - } + unsigned basen=0; for(unsigned i=0; igetNumberOfDerivatives() - 9; plumed_dbg_assert( basen%3==0 ); // Check the number of atoms is consistent with input derivatives unsigned virbas = myvals.getNumberOfDerivatives()-9; @@ -256,9 +226,7 @@ double LocalAverage::compute( const unsigned& tindex, AtomValuePack& myatoms ) c getInputData( i, false, myatoms, values ); if( values.size()>2 ) { - for(unsigned j=2; j0 ); + unsigned katom = myatoms.getIndex( i ); plumed_dbg_assert( katom0 ); // Find base colvar - unsigned mmc=atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + unsigned mmc=atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); // Get start of indices for this atom - unsigned basen=0; - for(unsigned j=0; jgetNumberOfDerivatives() - 9; - } + unsigned basen=0; for(unsigned j=0; jgetNumberOfDerivatives() - 9; plumed_dbg_assert( basen%3==0 ); // Check the number of atoms is consistent with input derivatives unsigned virbas = myvals.getNumberOfDerivatives()-9; @@ -350,9 +312,7 @@ double LocalAverage::compute( const unsigned& tindex, AtomValuePack& myatoms ) c // Calculate length of vector norm+=myvals.get(i)*myvals.get(i); } - norm=sqrt(norm); - myatoms.setValue(1, norm); - double inorm = 1.0 / norm; + norm=sqrt(norm); myatoms.setValue(1, norm); double inorm = 1.0 / norm; for(unsigned j=0; j& all_atoms ) { plumed_assert( !usespecies ); - if( all_atoms.size()>0 ) { - return; - } + if( all_atoms.size()>0 ) return; std::vector t; for(int i=1;; ++i ) { parseAtomList(key, i, t ); - if( t.empty() ) { - break; - } + if( t.empty() ) break; log.printf(" Colvar %d is calculated from atoms : ", i); - for(unsigned j=0; j( 0, ablocks.size()*(i-1)+j ) ); } t.resize(0); } if( all_atoms.size()>0 ) { nblock=0; - for(unsigned i=0; i& t) { std::vector mlabs; - if( num<0 ) { - parseVector(key,mlabs); - } else { - parseNumberedVector(key,num,mlabs); - } + if( num<0 ) parseVector(key,mlabs); + else parseNumberedVector(key,num,mlabs); - if( mlabs.size()==0 ) { - return false; - } + if( mlabs.size()==0 ) return false; - std::string mname; - unsigned found_mcolv=mlabs.size(); + std::string mname; unsigned found_mcolv=mlabs.size(); for(unsigned i=0; i(mlabs[i]); - if(!mycolv) { - found_mcolv=i; - break; - } + if(!mycolv) { found_mcolv=i; break; } // Check all base multicolvars are of same type if( i==0 ) { mname = mycolv->getName(); - if( keywords.exists("ALL_INPUT_SAME_TYPE") && mycolv->isPeriodic() ) { - error("multicolvar functions don't work with this multicolvar"); - } + if( keywords.exists("ALL_INPUT_SAME_TYPE") && mycolv->isPeriodic() ) error("multicolvar functions don't work with this multicolvar"); } else { - if( keywords.exists("ALL_INPUT_SAME_TYPE") && mname!=mycolv->getName() ) { - error("All input multicolvars must be of same type"); - } + if( keywords.exists("ALL_INPUT_SAME_TYPE") && mname!=mycolv->getName() ) error("All input multicolvars must be of same type"); } // And track which variable stores each colvar - for(unsigned j=0; jgetFullNumberOfTasks(); ++j) { - atom_lab.push_back( std::pair( mybasemulticolvars.size()+1, j ) ); - } + for(unsigned j=0; jgetFullNumberOfTasks(); ++j) atom_lab.push_back( std::pair( mybasemulticolvars.size()+1, j ) ); // And store the multicolvar base mybasemulticolvars.push_back( mycolv ); // And create a basedata stash mybasedata.push_back( mybasemulticolvars[mybasemulticolvars.size()-1]->buildDataStashes( this ) ); // Check if weight has derivatives - if( mybasemulticolvars[ mybasemulticolvars.size()-1 ]->weightHasDerivatives ) { - weightHasDerivatives=true; - } + if( mybasemulticolvars[ mybasemulticolvars.size()-1 ]->weightHasDerivatives ) weightHasDerivatives=true; plumed_assert( mybasemulticolvars.size()==mybasedata.size() ); } // Have we conventional atoms to read in if( found_mcolv==0 ) { - std::vector tt; - ActionAtomistic::interpretAtomList( mlabs, tt ); - for(unsigned i=0; i( 0, t.size() + i ) ); - } + std::vector tt; ActionAtomistic::interpretAtomList( mlabs, tt ); + for(unsigned i=0; i( 0, t.size() + i ) ); } log.printf(" keyword %s takes atoms : ", key.c_str() ); - for(unsigned i=0; i& all_atoms ) { - plumed_dbg_assert( keywords.exists(key0) && keywords.exists(key1) && keywords.exists(key2) ); - ablocks.resize( 2 ); + plumed_dbg_assert( keywords.exists(key0) && keywords.exists(key1) && keywords.exists(key2) ); ablocks.resize( 2 ); if( parseMultiColvarAtomList(key0,-1,all_atoms) ) { - nblock=atom_lab.size(); - for(unsigned i=0; i<2; ++i) { - ablocks[i].resize(nblock); - } + nblock=atom_lab.size(); for(unsigned i=0; i<2; ++i) ablocks[i].resize(nblock); resizeBookeepingArray( nblock, nblock ); - for(unsigned i=0; iablocks[1].size() ) { - nblock = ablocks[0].size(); - } else { - nblock=ablocks[1].size(); - } + if( ablocks[0].size()>ablocks[1].size() ) nblock = ablocks[0].size(); + else nblock=ablocks[1].size(); resizeBookeepingArray( ablocks[0].size(), ablocks[1].size() ); for(unsigned i=0; i0 && atom_lab[ablocks[1][j]].first>0 ) { if( mybasemulticolvars[atom_lab[ablocks[0][i]].first-1]->getLabel()!=mybasemulticolvars[atom_lab[ablocks[1][j]].first-1]->getLabel() && - atom_lab[ablocks[0][i]].second!=atom_lab[ablocks[1][j]].second ) { - addTaskToList( i*nblock + j ); - } - } else if( all_atoms[atom_lab[ablocks[0][i]].second]!=all_atoms[atom_lab[ablocks[1][j]].second] ) { - addTaskToList( i*nblock + j ); - } + atom_lab[ablocks[0][i]].second!=atom_lab[ablocks[1][j]].second ) addTaskToList( i*nblock + j ); + } else if( all_atoms[atom_lab[ablocks[0][i]].second]!=all_atoms[atom_lab[ablocks[1][j]].second] ) addTaskToList( i*nblock + j ); bookeeping(i,j).second=getFullNumberOfTasks(); } } @@ -271,24 +210,16 @@ void MultiColvarBase::readTwoGroups( const std::string& key0, const std::string& void MultiColvarBase::readGroupKeywords( const std::string& key0, const std::string& key1, const std::string& key2, const std::string& key3, const bool& no_third_dim_accum, const bool& symmetric, std::vector& all_atoms ) { - plumed_dbg_assert( keywords.exists(key0) && keywords.exists(key1) && keywords.exists(key2) && keywords.exists(key3) ); - ablocks.resize( 3 ); + plumed_dbg_assert( keywords.exists(key0) && keywords.exists(key1) && keywords.exists(key2) && keywords.exists(key3) ); ablocks.resize( 3 ); if( parseMultiColvarAtomList(key0,-1,all_atoms) ) { if( no_third_dim_accum ) { - nblock=atom_lab.size(); - ablocks[0].resize(nblock); - ablocks[1].resize( nblock ); - for(unsigned i=0; i& all_atoms ) { - plumed_dbg_assert( keywords.exists(key1) && keywords.exists(key2) && keywords.exists(key3) ); - ablocks.resize( 3 ); + plumed_dbg_assert( keywords.exists(key1) && keywords.exists(key2) && keywords.exists(key3) ); ablocks.resize( 3 ); bool readkey1=parseMultiColvarAtomList(key1,-1,all_atoms); - ablocks[0].resize( atom_lab.size() ); - for(unsigned i=0; iablocks[0].size() ) { - nblock=ablocks[1].size(); - } else { - nblock=ablocks[0].size(); - } + if( ablocks[1].size()>ablocks[0].size() ) nblock=ablocks[1].size(); + else nblock=ablocks[0].size(); ablocks[2].resize( ablocks[1].size() ); - for(unsigned i=0; igetLabel()!=mybasemulticolvars[atom_lab[ablocks[2][k]].first-1]->getLabel() && mybasemulticolvars[atom_lab[ablocks[1][j]].first-1]->getLabel()!=mybasemulticolvars[atom_lab[ablocks[2][k]].first-1]->getLabel() && atom_lab[ablocks[0][i]].second!=atom_lab[ablocks[1][j]].second && atom_lab[ablocks[0][i]].second!=atom_lab[ablocks[2][k]].second && - atom_lab[ablocks[1][j]].second!=atom_lab[ablocks[2][k]].second ) { - addTaskToList( nblock*nblock*i + nblock*j + k ); - } + atom_lab[ablocks[1][j]].second!=atom_lab[ablocks[2][k]].second ) addTaskToList( nblock*nblock*i + nblock*j + k ); } else if( all_atoms[atom_lab[ablocks[0][i]].second]!=all_atoms[atom_lab[ablocks[1][j]].second] && all_atoms[atom_lab[ablocks[0][i]].second]!=all_atoms[atom_lab[ablocks[2][k]].second] && - all_atoms[atom_lab[ablocks[1][j]].second]!=all_atoms[atom_lab[ablocks[2][k]].second] ) { - addTaskToList( nblock*nblock*i + nblock*j + k ); - } + all_atoms[atom_lab[ablocks[1][j]].second]!=all_atoms[atom_lab[ablocks[2][k]].second] ) addTaskToList( nblock*nblock*i + nblock*j + k ); } bookeeping(i,j).second=getFullNumberOfTasks(); } } } else { ablocks[2].resize( atom_lab.size() - ablocks[1].size() - ablocks[0].size() ); - for(unsigned i=0; iablocks[0].size() ) { - nblock=ablocks[1].size(); - } else { - nblock=ablocks[0].size(); - } - if( ablocks[2].size()>nblock ) { - nblock=ablocks[2].size(); - } + if( ablocks[1].size()>ablocks[0].size() ) nblock=ablocks[1].size(); + else nblock=ablocks[0].size(); + if( ablocks[2].size()>nblock ) nblock=ablocks[2].size(); - unsigned kcount; - if( no_third_dim_accum ) { - kcount=1; - } else { - kcount=ablocks[2].size(); - } + unsigned kcount; if( no_third_dim_accum ) kcount=1; else kcount=ablocks[2].size(); for(unsigned i=0; i0 && atom_lab[ablocks[1][j]].first>0 && atom_lab[ablocks[2][k]].first>0 ) { + if( no_third_dim_accum ) addTaskToList( nblock*i + j ); + else if( atom_lab[ablocks[0][i]].first>0 && atom_lab[ablocks[1][j]].first>0 && atom_lab[ablocks[2][k]].first>0 ) { if( mybasemulticolvars[atom_lab[ablocks[0][i]].first-1]->getLabel()!=mybasemulticolvars[atom_lab[ablocks[1][j]].first-1]->getLabel() && mybasemulticolvars[atom_lab[ablocks[0][i]].first-1]->getLabel()!=mybasemulticolvars[atom_lab[ablocks[2][k]].first-1]->getLabel() && mybasemulticolvars[atom_lab[ablocks[1][j]].first-1]->getLabel()!=mybasemulticolvars[atom_lab[ablocks[2][k]].first-1]->getLabel() && atom_lab[ablocks[0][i]].second!=atom_lab[ablocks[1][j]].second && atom_lab[ablocks[0][i]].second!=atom_lab[ablocks[2][k]].second && - atom_lab[ablocks[1][j]].second!=atom_lab[ablocks[2][k]].second ) { - addTaskToList( nblock*nblock*i + nblock*j + k ); - } + atom_lab[ablocks[1][j]].second!=atom_lab[ablocks[2][k]].second ) addTaskToList( nblock*nblock*i + nblock*j + k ); } else if( all_atoms[atom_lab[ablocks[0][i]].second]!=all_atoms[atom_lab[ablocks[1][j]].second] && all_atoms[atom_lab[ablocks[0][i]].second]!=all_atoms[atom_lab[ablocks[2][k]].second] && - all_atoms[atom_lab[ablocks[1][j]].second]!=all_atoms[atom_lab[ablocks[2][k]].second] ) { - addTaskToList( nblock*nblock*i + nblock*j + k ); - } + all_atoms[atom_lab[ablocks[1][j]].second]!=all_atoms[atom_lab[ablocks[2][k]].second] ) addTaskToList( nblock*nblock*i + nblock*j + k ); } bookeeping(i,j).second=getFullNumberOfTasks(); } @@ -464,12 +341,8 @@ void MultiColvarBase::readThreeGroups( const std::string& key1, const std::strin void MultiColvarBase::buildSets() { std::vector fake_atoms; - if( !parseMultiColvarAtomList("DATA",-1,fake_atoms) ) { - error("missing DATA keyword"); - } - if( fake_atoms.size()>0 ) { - error("no atoms should appear in the specification for this object. Input should be other multicolvars"); - } + if( !parseMultiColvarAtomList("DATA",-1,fake_atoms) ) error("missing DATA keyword"); + if( fake_atoms.size()>0 ) error("no atoms should appear in the specification for this object. Input should be other multicolvars"); nblock = mybasemulticolvars[0]->getFullNumberOfTasks(); for(unsigned i=0; iresizeTemporyMultiValues( mybasemulticolvars.size() ); - setupMultiColvarBase( fake_atoms ); + mybasedata[0]->resizeTemporyMultiValues( mybasemulticolvars.size() ); setupMultiColvarBase( fake_atoms ); } void MultiColvarBase::addTaskToList( const unsigned& taskCode ) { @@ -509,23 +375,17 @@ void MultiColvarBase::addTaskToList( const unsigned& taskCode ) { void MultiColvarBase::resizeBookeepingArray( const unsigned& num1, const unsigned& num2 ) { bookeeping.resize( num1, num2 ); for(unsigned i=0; i& atoms ) { - if( !matsums && atom_lab.size()==0 ) { - error("No atoms have been read in"); - } + if( !matsums && atom_lab.size()==0 ) error("No atoms have been read in"); std::vector all_atoms; // Setup decoder array if( !usespecies && nblock>0 ) { - ncentral=ablocks.size(); - use_for_central_atom.resize( ablocks.size(), true ); + ncentral=ablocks.size(); use_for_central_atom.resize( ablocks.size(), true ); numberForCentralAtom = 1.0 / static_cast( ablocks.size() ); if( ablocks.size()==3 ) { allthirdblockintasks=uselinkforthree=true; @@ -546,97 +406,55 @@ void MultiColvarBase::setupMultiColvarBase( const std::vector& atoms } if( allthirdblockintasks ) { - decoder.resize(2); - plumed_assert( ablocks.size()==3 ); + decoder.resize(2); plumed_assert( ablocks.size()==3 ); // Check if number of atoms is too large - if( std::pow( double(nblock), 2.0 )>std::numeric_limits::max() ) { - error("number of atoms in groups is too big for PLUMED to handle"); - } + if( std::pow( double(nblock), 2.0 )>std::numeric_limits::max() ) error("number of atoms in groups is too big for PLUMED to handle"); } else { decoder.resize( ablocks.size() ); // Check if number of atoms is too large - if( std::pow( double(nblock), double(ablocks.size()) )>std::numeric_limits::max() ) { - error("number of atoms in groups is too big for PLUMED to handle"); - } - } - unsigned code=1; - for(unsigned i=0; istd::numeric_limits::max() ) error("number of atoms in groups is too big for PLUMED to handle"); } + unsigned code=1; for(unsigned i=0; i( ablocks.size() ); } else if( keywords.exists("SPECIESA") ) { plumed_assert( atom_lab.size()==0 && all_atoms.size()==0 ); - ablocks.resize( 1 ); - bool readspecies=parseMultiColvarAtomList("SPECIES", -1, all_atoms); + ablocks.resize( 1 ); bool readspecies=parseMultiColvarAtomList("SPECIES", -1, all_atoms); if( readspecies ) { - ablocks[0].resize( atom_lab.size() ); - for(unsigned i=0; i0 && atom_lab[j].first>0 ) { if( atom_lab[nat1+i].first==atom_lab[j].first && mybasemulticolvars[atom_lab[nat1+i].first-1]->getAbsoluteIndexOfCentralAtom(atom_lab[nat1+i].second)== - mybasemulticolvars[atom_lab[j].first-1]->getAbsoluteIndexOfCentralAtom(atom_lab[j].second) ) { - found=true; - inum=j; - break; - } + mybasemulticolvars[atom_lab[j].first-1]->getAbsoluteIndexOfCentralAtom(atom_lab[j].second) ) { found=true; inum=j; break; } } else if( atom_lab[nat1+i].first>0 ) { if( mybasemulticolvars[atom_lab[nat1+i].first-1]->getAbsoluteIndexOfCentralAtom(atom_lab[nat1+i].second)== - all_atoms[atom_lab[j].second] ) { - found=true; - inum=nat1 + i; - break; - } + all_atoms[atom_lab[j].second] ) { found=true; inum=nat1 + i; break; } } else if( atom_lab[j].first>0 ) { if( all_atoms[atom_lab[nat1+i].second]== - mybasemulticolvars[atom_lab[j].first-1]->getAbsoluteIndexOfCentralAtom(atom_lab[j].second) ) { - found=true; - inum=nat1+i; - break; - } - } else if( all_atoms[atom_lab[nat1+i].second]==all_atoms[atom_lab[j].second] ) { - found=true; - inum=j; - break; - } + mybasemulticolvars[atom_lab[j].first-1]->getAbsoluteIndexOfCentralAtom(atom_lab[j].second) ) { found=true; inum=nat1+i; break; } + } else if( all_atoms[atom_lab[nat1+i].second]==all_atoms[atom_lab[j].second] ) { found=true; inum=j; break; } } // This prevents mistakes being made in colvar setup - if( found ) { - ablocks[0][i]=inum; - } else { - ablocks[0][i]=nat1 + i; - } + if( found ) { ablocks[0][i]=inum; } + else { ablocks[0][i]=nat1 + i; } } } } if( mybasemulticolvars.size()>0 ) { for(unsigned i=0; iresizeTemporyMultiValues(2); - mybasemulticolvars[i]->my_tmp_capacks.resize(2); + mybasedata[i]->resizeTemporyMultiValues(2); mybasemulticolvars[i]->my_tmp_capacks.resize(2); } } @@ -644,37 +462,27 @@ void MultiColvarBase::setupMultiColvarBase( const std::vector& atoms std::vector tmp_atoms; for(unsigned i=0; igetAbsoluteIndexes(); - for(unsigned j=0; j& catom_ind ) { - unsigned nat=0; - plumed_assert( catom_ind.size()==ablocks.size() ); + unsigned nat=0; plumed_assert( catom_ind.size()==ablocks.size() ); for(unsigned i=0; i0 ); - ncentral=nat; + plumed_dbg_assert( nat>0 ); ncentral=nat; numberForCentralAtom = 1.0 / static_cast( nat ); } @@ -686,20 +494,14 @@ void MultiColvarBase::turnOnDerivatives() { void MultiColvarBase::setLinkCellCutoff( const double& lcut, double tcut ) { plumed_assert( usespecies || ablocks.size()<4 ); - if( tcut<0 ) { - tcut=lcut; - } + if( tcut<0 ) tcut=lcut; if( !linkcells.enabled() ) { linkcells.setCutoff( lcut ); threecells.setCutoff( tcut ); } else { - if( lcut>linkcells.getCutoff() ) { - linkcells.setCutoff( lcut ); - } - if( tcut>threecells.getCutoff() ) { - threecells.setCutoff( tcut ); - } + if( lcut>linkcells.getCutoff() ) linkcells.setCutoff( lcut ); + if( tcut>threecells.getCutoff() ) threecells.setCutoff( tcut ); } } @@ -708,9 +510,7 @@ double MultiColvarBase::getLinkCellCutoff() const { } void MultiColvarBase::setupLinkCells() { - if( (!usespecies && nblock==0) || !linkcells.enabled() ) { - return ; - } + if( (!usespecies && nblock==0) || !linkcells.enabled() ) return ; // Retrieve any atoms that haven't already been retrieved for(std::vector::iterator p=mybasemulticolvars.begin(); p!=mybasemulticolvars.end(); ++p) { (*p)->retrieveAtoms(); @@ -729,9 +529,7 @@ void MultiColvarBase::setupLinkCells() { // Count number of currently active atoms nactive_atoms=0; for(unsigned i=0; i0 ) { @@ -741,18 +539,14 @@ void MultiColvarBase::setupLinkCells() { nactive_atoms=0; if( usespecies ) { for(unsigned i=0; i requiredlinkcells; @@ -776,40 +568,27 @@ void MultiColvarBase::setupNonUseSpeciesLinkCells( const unsigned& my_always_act // Get some parallel info unsigned stride=comm.Get_size(); unsigned rank=comm.Get_rank(); - if( serialCalculation() ) { - stride=1; - rank=0; - } + if( serialCalculation() ) { stride=1; rank=0; } // Ensure we only do tasks where atoms are in appropriate link cells std::vector linked_atoms( 1+ablocks[1].size() ); for(unsigned i=rank; i0 ) { // Get some parallel info unsigned stride=comm.Get_size(); unsigned rank=comm.Get_rank(); - if( serialCalculation() ) { - stride=1; - rank=0; - } + if( serialCalculation() ) { stride=1; rank=0; } unsigned nactive_three=0; for(unsigned i=0; i lttmp_pos( nactive_three ); @@ -818,18 +597,14 @@ void MultiColvarBase::setupNonUseSpeciesLinkCells( const unsigned& my_always_act nactive_three=0; if( allthirdblockintasks ) { for(unsigned i=0; i linked_atoms( 1+ablocks[1].size() ); std::vector tlinked_atoms( 1+ablocks[2].size() ); for(unsigned i=rank; i& atoms ) const { plumed_dbg_assert( !usespecies && nblock>0 ); - if( atoms.size()!=decoder.size() ) { - atoms.resize( decoder.size() ); - } + if( atoms.size()!=decoder.size() ) atoms.resize( decoder.size() ); unsigned scode = taskCode; for(unsigned i=0; i task_atoms(1); - task_atoms[0]=taskCode; + std::vector task_atoms(1); task_atoms[0]=taskCode; unsigned natomsper=myatoms.setupAtomsFromLinkCells( task_atoms, getPositionOfAtomForLinkCells( taskCode ), linkcells ); return natomsper>1; } else if( matsums ) { myatoms.setNumberOfAtoms( getNumberOfAtoms() ); - for(unsigned i=0; i atoms(2); - decodeIndexToAtoms( taskCode, atoms ); + plumed_dbg_assert( ablocks.size()==3 ); std::vector atoms(2); decodeIndexToAtoms( taskCode, atoms ); myatoms.setupAtomsFromLinkCells( atoms, getPositionOfAtomForLinkCells( atoms[0] ), threecells ); } else if( nblock>0 ) { std::vector atoms( ablocks.size() ); - decodeIndexToAtoms( taskCode, atoms ); - myatoms.setNumberOfAtoms( ablocks.size() ); - for(unsigned i=0; i& active_tasks, c justVolumes=true; for(unsigned i=0; i( getPntrToVessel(i) ); - if( mys ) { - continue; - } + if( mys ) continue; vesselbase::BridgeVessel* myb=dynamic_cast( getPntrToVessel(i) ); - if( !myb ) { - justVolumes=false; - break; - } + if( !myb ) { justVolumes=false; break; } ActionVolume* myv=dynamic_cast( myb->getOutputAction() ); - if( !myv ) { - justVolumes=false; - break; - } + if( !myv ) { justVolumes=false; break; } } } deactivateAllTasks(); if( justVolumes && mydata ) { - if( mydata->getNumberOfDataUsers()==0 ) { - justVolumes=false; - } + if( mydata->getNumberOfDataUsers()==0 ) justVolumes=false; for(unsigned i=0; igetNumberOfDataUsers(); ++i) { MultiColvarBase* myu=dynamic_cast( mydata->getDataUser(i) ); if( myu ) { myu->setupActiveTaskSet( taskFlags, getLabel() ); } else { - for(unsigned i=0; i( getPntrToVessel(j) ); - if( !myb ) { - continue ; - } + if( !myb ) continue ; ActionVolume* myv=dynamic_cast( myb->getOutputAction() ); - if( !myv ) { - continue ; - } - myv->retrieveAtoms(); - myv->setupRegions(); + if( !myv ) continue ; + myv->retrieveAtoms(); myv->setupRegions(); for(unsigned i=0; iinVolumeOfInterest(i) ) { - taskFlags[i]=1; - } + if( myv->inVolumeOfInterest(i) ) taskFlags[i]=1; } } } else { - for(unsigned i=0; i& active_tasks, c if( getLabel()!=input_label ) { int input_code=-1; for(unsigned i=0; igetLabel()==input_label ) { - input_code=i+1; - break; - } + if( mybasemulticolvars[i]->getLabel()==input_label ) { input_code=i+1; break; } } MultiValue my_tvals( getNumberOfQuantities(), getNumberOfDerivatives() ); AtomValuePack mytmp_atoms( my_tvals, this ); for(unsigned i=0; i( mybasemulticolvars[i] ); - if( myfilt || mybasemulticolvars[i]->filtersUsedAsInput() ) { - inputAreFilters=true; - } + if( myfilt || mybasemulticolvars[i]->filtersUsedAsInput() ) inputAreFilters=true; } return inputAreFilters; } @@ -1037,9 +758,7 @@ void MultiColvarBase::calculate() { setupActiveTaskSet( taskFlags, getLabel() ); // Check for filters and rerun setup of link cells if there are any - if( mybasemulticolvars.size()>0 && filtersUsedAsInput() ) { - setupLinkCells(); - } + if( mybasemulticolvars.size()>0 && filtersUsedAsInput() ) setupLinkCells(); // Setup the link cells if we are not using species if( !usespecies && ablocks.size()>1 ) { @@ -1047,11 +766,9 @@ void MultiColvarBase::calculate() { // of a peculiarity in linkcells unsigned first_active=std::numeric_limits::max(); for(unsigned i=0; i0 ) { - plumed_merror("cannot calculate numerical derivatives for this quantity"); - } + if( mybasemulticolvars.size()>0 ) plumed_merror("cannot calculate numerical derivatives for this quantity"); calculateAtomicNumericalDerivatives( this, 0 ); } void MultiColvarBase::prepare() { - setup_completed=false; - atomsWereRetrieved=false; + setup_completed=false; atomsWereRetrieved=false; } void MultiColvarBase::retrieveAtoms() { - if( !atomsWereRetrieved ) { - ActionAtomistic::retrieveAtoms(); - atomsWereRetrieved=true; - } + if( !atomsWereRetrieved ) { ActionAtomistic::retrieveAtoms(); atomsWereRetrieved=true; } } void MultiColvarBase::mergeInputDerivatives( const unsigned& ival, const unsigned& start, const unsigned& end, @@ -1087,17 +798,11 @@ void MultiColvarBase::mergeInputDerivatives( const unsigned& ival, const unsigne plumed_dbg_assert( start0 ); + unsigned katom = myatoms.getIndex( jatom ); plumed_dbg_assert( katom0 ); // Find base colvar - unsigned mmc=atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + unsigned mmc=atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); // Get start of indices for this atom - unsigned basen=0; - for(unsigned i=0; igetNumberOfDerivatives() - 9; - } + unsigned basen=0; for(unsigned i=0; igetNumberOfDerivatives() - 9; plumed_dbg_assert( basen%3==0 ); // Check the number of atoms is consistent with input derivatives unsigned virbas = myvals.getNumberOfDerivatives()-9; for(unsigned j=0; j0 ); + unsigned katom = myatoms.getIndex( jatom ); plumed_dbg_assert( katom0 ); // Find base colvar - unsigned mmc=atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + unsigned mmc=atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); // Get start of indices for this atom - unsigned basen=0; - for(unsigned i=0; igetNumberOfDerivatives() - 9; - } + unsigned basen=0; for(unsigned i=0; igetNumberOfDerivatives() - 9; plumed_dbg_assert( basen%3==0 ); // Check the number of atoms is consistent with input derivatives unsigned virbas = myvals.getNumberOfDerivatives()-9; for(unsigned j=0; jgetNumberOfDerivatives()-9 ) { - unsigned kder=basen+jder; - plumed_assert( kder(myatoms.getUnderlyingMultiValue().getNumberOfValues()) && iatom0 ); + unsigned katom = myatoms.getIndex( iatom ); plumed_dbg_assert( atom_lab[katom].first>0 ); // Find base colvar - unsigned mmc = atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); - if( usespecies && iatom==0 ) { - myatoms.addComDerivatives( ival, der, mybasemulticolvars[mmc]->my_tmp_capacks[0] ); - return; - } + unsigned mmc = atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + if( usespecies && iatom==0 ) { myatoms.addComDerivatives( ival, der, mybasemulticolvars[mmc]->my_tmp_capacks[0] ); return; } // Get start of indices for this atom - unsigned basen=0; - for(unsigned i=0; igetNumberOfDerivatives() - 9) / 3; - } + unsigned basen=0; for(unsigned i=0; igetNumberOfDerivatives() - 9) / 3; mybasemulticolvars[mmc]->getCentralAtomPack( basen, atom_lab[katom].second, mybasemulticolvars[mmc]->my_tmp_capacks[1] ); myatoms.addComDerivatives( ival, der, mybasemulticolvars[mmc]->my_tmp_capacks[1] ); } @@ -1180,34 +870,23 @@ void MultiColvarBase::getInputData( const unsigned& ind, const bool& normed, const multicolvar::AtomValuePack& myatoms, std::vector& orient ) const { // Converint input atom to local index - unsigned katom = myatoms.getIndex(ind); - plumed_dbg_assert( atom_lab[katom].first>0 ); + unsigned katom = myatoms.getIndex(ind); plumed_dbg_assert( atom_lab[katom].first>0 ); // Find base colvar - unsigned mmc = atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + unsigned mmc = atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); // Check if orient is the correct size - if( orient.size()!=mybasemulticolvars[mmc]->getNumberOfQuantities() ) { - orient.resize( mybasemulticolvars[mmc]->getNumberOfQuantities() ); - } + if( orient.size()!=mybasemulticolvars[mmc]->getNumberOfQuantities() ) orient.resize( mybasemulticolvars[mmc]->getNumberOfQuantities() ); // Retrieve the value mybasedata[mmc]->retrieveValueWithIndex( atom_lab[katom].second, normed, orient ); } MultiValue& MultiColvarBase::getInputDerivatives( const unsigned& iatom, const bool& normed, const multicolvar::AtomValuePack& myatoms ) const { // Converint input atom to local index - unsigned katom = myatoms.getIndex(iatom); - plumed_dbg_assert( atom_lab[katom].first>0 ); + unsigned katom = myatoms.getIndex(iatom); plumed_dbg_assert( atom_lab[katom].first>0 ); // Find base colvar - unsigned mmc = atom_lab[katom].first - 1; - plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); - if( usespecies && !normed && iatom==0 ) { - return mybasedata[mmc]->getTemporyMultiValue(0); - } + unsigned mmc = atom_lab[katom].first - 1; plumed_dbg_assert( mybasemulticolvars[mmc]->taskIsCurrentlyActive( atom_lab[katom].second ) ); + if( usespecies && !normed && iatom==0 ) return mybasedata[mmc]->getTemporyMultiValue(0); - unsigned oval=0; - if( iatom>0 ) { - oval=1; - } + unsigned oval=0; if( iatom>0 ) oval=1; MultiValue& myder=mybasedata[mmc]->getTemporyMultiValue(oval); if( myder.getNumberOfValues()!=mybasemulticolvars[mmc]->getNumberOfQuantities() || myder.getNumberOfDerivatives()!=mybasemulticolvars[mmc]->getNumberOfDerivatives() ) { @@ -1218,76 +897,48 @@ MultiValue& MultiColvarBase::getInputDerivatives( const unsigned& iatom, const b } void MultiColvarBase::accumulateSymmetryFunction( const int& ival, const unsigned& iatom, const double& val, const Vector& der, const Tensor& vir, multicolvar::AtomValuePack& myatoms ) const { - plumed_dbg_assert( usespecies ); - unsigned katom=myatoms.getIndex(0), jatom=myatoms.getIndex(iatom); - double weight0=1.0; - if( atom_lab[katom].first>0 ) { - weight0=mybasedata[atom_lab[katom].first-1]->retrieveWeightWithIndex( atom_lab[katom].second ); - } - double weighti=1.0; - if( atom_lab[jatom].first>0 ) { - weighti=mybasedata[atom_lab[jatom].first-1]->retrieveWeightWithIndex( atom_lab[jatom].second ); - } + plumed_dbg_assert( usespecies ); unsigned katom=myatoms.getIndex(0), jatom=myatoms.getIndex(iatom); + double weight0=1.0; if( atom_lab[katom].first>0 ) weight0=mybasedata[atom_lab[katom].first-1]->retrieveWeightWithIndex( atom_lab[katom].second ); + double weighti=1.0; if( atom_lab[jatom].first>0 ) weighti=mybasedata[atom_lab[jatom].first-1]->retrieveWeightWithIndex( atom_lab[jatom].second ); // Accumulate the value - if( ival<0 ) { - myatoms.getUnderlyingMultiValue().addTemporyValue( weight0*weighti*val ); - } else { - myatoms.addValue( ival, weight0*weighti*val ); - } + if( ival<0 ) myatoms.getUnderlyingMultiValue().addTemporyValue( weight0*weighti*val ); + else myatoms.addValue( ival, weight0*weighti*val ); // Return if we don't need derivatives - if( doNotCalculateDerivatives() ) { - return ; - } + if( doNotCalculateDerivatives() ) return ; // And virial - if( ival<0 ) { - myatoms.addTemporyBoxDerivatives( weight0*weighti*vir ); - } else { - myatoms.addBoxDerivatives( ival, weight0*weighti*vir ); - } + if( ival<0 ) myatoms.addTemporyBoxDerivatives( weight0*weighti*vir ); + else myatoms.addBoxDerivatives( ival, weight0*weighti*vir ); // Add derivatives of central atom if( atom_lab[katom].first>0 ) { addComDerivatives( ival, 0, -weight0*weighti*der, myatoms ); std::vector tmpder( mybasemulticolvars[atom_lab[katom].first - 1]->getNumberOfQuantities(), 0. ); - tmpder[0]=weighti*val; - mergeInputDerivatives( ival, 0, 1, 0, tmpder, getInputDerivatives(0, false, myatoms), myatoms ); + tmpder[0]=weighti*val; mergeInputDerivatives( ival, 0, 1, 0, tmpder, getInputDerivatives(0, false, myatoms), myatoms ); } else { - if( ival<0 ) { - myatoms.addTemporyAtomsDerivatives( 0, -der ); - } else { - myatoms.addAtomsDerivatives( ival, 0, -der ); - } + if( ival<0 ) myatoms.addTemporyAtomsDerivatives( 0, -der ); + else myatoms.addAtomsDerivatives( ival, 0, -der ); } // Add derivatives of atom in coordination sphere if( atom_lab[jatom].first>0 ) { addComDerivatives( ival, iatom, weight0*weighti*der, myatoms ); std::vector tmpder( mybasemulticolvars[atom_lab[katom].first - 1]->getNumberOfQuantities(), 0. ); - tmpder[0]=weight0*val; - mergeInputDerivatives( ival, 0, 1, iatom, tmpder, getInputDerivatives(iatom, false, myatoms), myatoms ); + tmpder[0]=weight0*val; mergeInputDerivatives( ival, 0, 1, iatom, tmpder, getInputDerivatives(iatom, false, myatoms), myatoms ); } else { - if( ival<0 ) { - myatoms.addTemporyAtomsDerivatives( iatom, der ); - } else { - myatoms.addAtomsDerivatives( ival, iatom, der ); - } + if( ival<0 ) myatoms.addTemporyAtomsDerivatives( iatom, der ); + else myatoms.addAtomsDerivatives( ival, iatom, der ); } } void MultiColvarBase::addAtomDerivatives( const int& ival, const unsigned& iatom, const Vector& der, multicolvar::AtomValuePack& myatoms ) const { - if( doNotCalculateDerivatives() ) { - return ; - } + if( doNotCalculateDerivatives() ) return ; unsigned jatom=myatoms.getIndex(iatom); if( atom_lab[jatom].first>0 ) { addComDerivatives( ival, iatom, der, myatoms ); } else { - if( ival<0 ) { - myatoms.addTemporyAtomsDerivatives( iatom, der ); - } else { - myatoms.addAtomsDerivatives( ival, iatom, der ); - } + if( ival<0 ) myatoms.addTemporyAtomsDerivatives( iatom, der ); + else myatoms.addAtomsDerivatives( ival, iatom, der ); } } @@ -1298,28 +949,20 @@ double MultiColvarBase::calculateWeight( const unsigned& current, const double& void MultiColvarBase::performTask( const unsigned& task_index, const unsigned& current, MultiValue& myvals ) const { AtomValuePack myatoms( myvals, this ); // Retrieve the atom list - if( !setupCurrentAtomList( current, myatoms ) ) { - return; - } + if( !setupCurrentAtomList( current, myatoms ) ) return; // Get weight due to dynamic groups double weight = 1.0; if( !matsums ) { for(unsigned i=0; i1 ) { - break; - } + if( allthirdblockintasks && i>1 ) break; unsigned mmc = atom_lab[myatoms.getIndex(i)].first - 1; weight *= mybasedata[mmc]->retrieveWeightWithIndex( atom_lab[myatoms.getIndex(i)].second ); } } else if( usespecies ) { if( atom_lab[myatoms.getIndex(0)].first>0 ) { - if( mybasedata[atom_lab[myatoms.getIndex(0)].first-1]->retrieveWeightWithIndex( atom_lab[myatoms.getIndex(0)].second )retrieveWeightWithIndex( atom_lab[myatoms.getIndex(0)].second )0 ) { - MultiValue& outder=myatoms.getUnderlyingMultiValue(); - MultiValue myder(0,0); + MultiValue& outder=myatoms.getUnderlyingMultiValue(); MultiValue myder(0,0); for(unsigned i=0; iretrieveWeightWithIndex( atom_lab[myatoms.getIndex(i)].second ); // And accumulate the derivatives - for(unsigned j=0; jgetNumberOfQuantities(), mybasemulticolvars[mmc]->getNumberOfDerivatives() ); } mybasedata[mmc]->retrieveDerivatives( atom_lab[myatoms.getIndex(0)].second, false, myder ); - unsigned basen=0; - for(unsigned i=0; igetNumberOfDerivatives() - 9; - } + unsigned basen=0; for(unsigned i=0; igetNumberOfDerivatives() - 9; mybasemulticolvars[mmc]->getCentralAtomPack( basen, atom_lab[myatoms.getIndex(0)].second, mybasemulticolvars[mmc]->my_tmp_capacks[0] ); } } // Compute everything - double vv=compute( task_index, myatoms ); - updateActiveAtoms( myatoms ); + double vv=compute( task_index, myatoms ); updateActiveAtoms( myatoms ); myatoms.setValue( 1, vv ); return; } void MultiColvarBase::updateActiveAtoms( AtomValuePack& myatoms ) const { - if( mybasemulticolvars.size()==0 ) { - myatoms.updateUsingIndices(); - } else { - myatoms.updateDynamicList(); - } + if( mybasemulticolvars.size()==0 ) myatoms.updateUsingIndices(); + else myatoms.updateDynamicList(); } Vector MultiColvarBase::getCentralAtomPos( const unsigned& taskIndex ) { @@ -1395,23 +1025,16 @@ Vector MultiColvarBase::getCentralAtomPos( const unsigned& taskIndex ) { return getPositionOfAtomForLinkCells(curr); } else if( nblock>0 ) { // double factor=1.0/static_cast( ablocks.size() ); - Vector mypos; - mypos.zero(); - std::vector atoms( ablocks.size() ); - decodeIndexToAtoms( curr, atoms ); + Vector mypos; mypos.zero(); + std::vector atoms( ablocks.size() ); decodeIndexToAtoms( curr, atoms ); for(unsigned i=0; i0 ) { - if( mypack.getNumberOfAtomsWithDerivatives()!=ncentral ) { - mypack.resize(ncentral); - } + if( mypack.getNumberOfAtomsWithDerivatives()!=ncentral ) mypack.resize(ncentral); unsigned k=0; - std::vector atoms( ablocks.size() ); - decodeIndexToAtoms( curr, atoms ); + std::vector atoms( ablocks.size() ); decodeIndexToAtoms( curr, atoms ); for(unsigned i=0; i& dlist, unsigned int max_index) const { - if (usepbc) { - pbcApply(dlist, max_index); - } + if (usepbc) pbcApply(dlist, max_index); } void MultiColvarBase::apply() { - if( getForcesFromVessels( forcesToApply ) ) { - setForcesOnAtoms( forcesToApply ); - } + if( getForcesFromVessels( forcesToApply ) ) setForcesOnAtoms( forcesToApply ); } } diff --git a/src/multicolvar/MultiColvarBase.h b/src/multicolvar/MultiColvarBase.h index 365e12ea09..5c5208c77c 100644 --- a/src/multicolvar/MultiColvarBase.h +++ b/src/multicolvar/MultiColvarBase.h @@ -41,7 +41,8 @@ class ActionVolume; class MultiColvarBase : public ActionAtomistic, public ActionWithValue, - public vesselbase::ActionWithVessel { + public vesselbase::ActionWithVessel +{ friend class BridgedMultiColvarFunction; friend class VolumeGradientBase; friend class MultiColvarFilter; @@ -157,9 +158,7 @@ class MultiColvarBase : /// Apply PBCs over a set of distance vectors void applyPbc(std::vector& dlist, unsigned max_index=0) const; /// Is it safe to use multithreading - bool threadSafe() const override { - return !(mybasemulticolvars.size()>0); - } + bool threadSafe() const override { return !(mybasemulticolvars.size()>0); } /// Do some setup before the calculation void prepare() override; /// This is overwritten here in order to make sure that we do not retrieve atoms multiple times @@ -193,15 +192,11 @@ class MultiColvarBase : /// You can use this to screen contributions that are very small so we can avoid expensive (and pointless) calculations virtual double calculateWeight( const unsigned& taskCode, const double& weight, AtomValuePack& myatoms ) const ; /// Is this a density? - virtual bool isDensity() const { - return false; - } + virtual bool isDensity() const { return false; } /// Is the iatom'th stored value currently active bool storedValueIsActive( const unsigned& iatom ); /// This is true if multicolvar is calculating a vector or if the multicolvar is the density - virtual bool hasDifferentiableOrientation() const { - return false; - } + virtual bool hasDifferentiableOrientation() const { return false; } /// This makes sure we are not calculating the director when we do LocalAverage virtual void doNotCalculateDirector() {} /// Ensure that derivatives are only calculated when needed @@ -258,9 +253,7 @@ bool MultiColvarBase::usesPbc() const { inline bool MultiColvarBase::doNotCalculateDerivatives() const { - if( !dertime ) { - return true; - } + if( !dertime ) return true; return ActionWithValue::doNotCalculateDerivatives(); } diff --git a/src/multicolvar/MultiColvarCombine.cpp b/src/multicolvar/MultiColvarCombine.cpp index 783690f35f..7dd7b96e38 100644 --- a/src/multicolvar/MultiColvarCombine.cpp +++ b/src/multicolvar/MultiColvarCombine.cpp @@ -47,9 +47,7 @@ class MultiColvarCombine : public MultiColvarBase { /// Actually do the calculation double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; /// Is the variable periodic - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(MultiColvarCombine,"MCOLV_COMBINE") @@ -58,41 +56,27 @@ void MultiColvarCombine::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); keys.add("compulsory","DATA","the multicolvars you are calculating linear combinations for"); keys.add("compulsory","COEFFICIENTS","1.0","the coefficients to use for the various multicolvars"); - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("SUM"); - keys.use("LESS_THAN"); - keys.use("HISTOGRAM"); - keys.use("MIN"); - keys.use("MAX"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("ALT_MIN"); - keys.use("BETWEEN"); - keys.use("MOMENTS"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("SUM"); keys.use("LESS_THAN"); keys.use("HISTOGRAM"); + keys.use("MIN"); keys.use("MAX"); keys.use("LOWEST"); keys.use("HIGHEST"); keys.use("ALT_MIN"); keys.use("BETWEEN"); keys.use("MOMENTS"); } MultiColvarCombine::MultiColvarCombine(const ActionOptions& ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ buildSets(); for(unsigned i=0; iweightWithDerivatives() ) { - error("cannot combine multicolvars with weights"); - } + if( mybasemulticolvars[i]->weightWithDerivatives() ) error("cannot combine multicolvars with weights"); } coeff.resize( getNumberOfBaseMultiColvars() ); parseVector("COEFFICIENTS",coeff); log.printf(" coefficients of multicolvars %f", coeff[0] ); - for(unsigned i=1; i tval(2); + double dot=0; std::vector tval(2); for(unsigned i=0; i cc(2); for(unsigned i=0; i atom; parseAtomList("ORIGIN",atom); - if( atom.size()!=1 ) { - error("should only be one atom specified"); - } + if( atom.size()!=1 ) error("should only be one atom specified"); log.printf(" origin is at position of atom : %d\n",atom[0].serial() ); - std::string mlab; - parse("DATA",mlab); + std::string mlab; parse("DATA",mlab); mycolv = plumed.getActionSet().selectWithLabel(mlab); - if(!mycolv) { - error("action labelled " + mlab + " does not exist or is not a MultiColvar"); - } + if(!mycolv) error("action labelled " + mlab + " does not exist or is not a MultiColvar"); stash = mycolv->buildDataStashes( NULL ); parseFlag("FRACTIONAL",fractional); - std::string direction; - parse("DIR",direction); + std::string direction; parse("DIR",direction); log.printf(" calculating for %s density profile along ", mycolv->getLabel().c_str() ); if( direction=="x" ) { log.printf("x axis"); - directions.resize(1); - directions[0]=0; + directions.resize(1); directions[0]=0; } else if( direction=="y" ) { log.printf("y axis"); - directions.resize(1); - directions[0]=1; + directions.resize(1); directions[0]=1; } else if( direction=="z" ) { log.printf("z axis"); - directions.resize(1); - directions[0]=2; + directions.resize(1); directions[0]=2; } else if( direction=="xy" ) { log.printf("x and y axes"); - directions.resize(2); - directions[0]=0; - directions[1]=1; + directions.resize(2); directions[0]=0; directions[1]=1; } else if( direction=="xz" ) { log.printf("x and z axes"); - directions.resize(2); - directions[0]=0; - directions[1]=2; + directions.resize(2); directions[0]=0; directions[1]=2; } else if( direction=="yz" ) { log.printf("y and z axis"); - directions.resize(2); - directions[0]=1; - directions[1]=2; + directions.resize(2); directions[0]=1; directions[1]=2; } else if( direction=="xyz" ) { log.printf("x, y and z axes"); - directions.resize(3); - directions[0]=0; - directions[1]=1; - directions[2]=2; + directions.resize(3); directions[0]=0; directions[1]=1; directions[2]=2; } else { error( direction + " is not valid gradient direction"); } log.printf(" for colvars calculated by action %s \n",mycolv->getLabel().c_str() ); - parseVector("NBINS",nbins); - parseVector("SPACING",gspacing); - if( nbins.size()!=directions.size() && gspacing.size()!=directions.size() ) { - error("NBINS or SPACING must be set"); - } + parseVector("NBINS",nbins); parseVector("SPACING",gspacing); + if( nbins.size()!=directions.size() && gspacing.size()!=directions.size() ) error("NBINS or SPACING must be set"); - confined.resize( directions.size() ); - cmin.resize( directions.size(), 0 ); - cmax.resize( directions.size(), 0 ); + confined.resize( directions.size() ); cmin.resize( directions.size(), 0 ); cmax.resize( directions.size(), 0 ); for(unsigned i=0; igetLabel() + ".dens"; vstring +=" COORDINATES="; - if( directions[0]==0 ) { - vstring+="x"; - } else if( directions[0]==1 ) { - vstring+="y"; - } else if( directions[0]==2 ) { - vstring+="z"; - } + if( directions[0]==0 ) vstring+="x"; + else if( directions[0]==1 ) vstring+="y"; + else if( directions[0]==2 ) vstring+="z"; for(unsigned i=1; igetFullNumberOfTasks(); ++i) { - addTaskToList(i); - } + for(unsigned i=0; igetFullNumberOfTasks(); ++i) addTaskToList(i); // And create the grid std::unique_ptr grid; - if( mycolv->isDensity() ) { - grid=createGrid( "histogram", vstring ); - } else { - grid=createGrid( "average", vstring ); - } + if( mycolv->isDensity() ) grid=createGrid( "histogram", vstring ); + else grid=createGrid( "average", vstring ); // cppcheck-suppress danglingLifetime mygrid=grid.get(); // And finish the grid setup @@ -302,15 +235,11 @@ MultiColvarDensity::MultiColvarDensity(const ActionOptions&ao): // Enusre units for cube files are set correctly if( !fractional ) { - if( plumed.getAtoms().usingNaturalUnits() ) { - mygrid->setCubeUnits( 1.0/0.5292 ); - } else { - mygrid->setCubeUnits( plumed.getAtoms().getUnits().getLength()/.05929 ); - } + if( plumed.getAtoms().usingNaturalUnits() ) mygrid->setCubeUnits( 1.0/0.5292 ); + else mygrid->setCubeUnits( plumed.getAtoms().getUnits().getLength()/.05929 ); } - checkRead(); - requestAtoms(atom); + checkRead(); requestAtoms(atom); // Stupid dependencies cleared by requestAtoms - why GBussi why? That's got me so many times addDependency( mycolv ); } @@ -322,10 +251,7 @@ unsigned MultiColvarDensity::getNumberOfQuantities() const { void MultiColvarDensity::clearAverage() { std::vector min(directions.size()), max(directions.size()); std::vector gmin(directions.size()), gmax(directions.size());; - for(unsigned i=0; igetPbc().isOrthorombic() ) { error("I think that density profiles with non-orthorhombic cells don't work. If you want it have a look and see if you can work it out"); @@ -336,55 +262,35 @@ void MultiColvarDensity::clearAverage() { min[i]*=mycolv->getBox()(directions[i],directions[i]); max[i]*=mycolv->getBox()(directions[i],directions[i]); } else { - min[i]=cmin[i]; - max[i]=cmax[i]; + min[i]=cmin[i]; max[i]=cmax[i]; } } } - for(unsigned i=0; isetBounds( gmin, gmax, nbins, gspacing ); - resizeFunctions(); + mygrid->setBounds( gmin, gmax, nbins, gspacing ); resizeFunctions(); } void MultiColvarDensity::prepareForAveraging() { for(unsigned i=0; igetBox()(directions[i],directions[i]), max ); - if( max!=mygrid->getMax()[i] ) { - error("box size should be fixed. Use FRACTIONAL"); - } + if( confined[i] ) continue; + std::string max; Tools::convert( 0.5*mycolv->getBox()(directions[i],directions[i]), max ); + if( max!=mygrid->getMax()[i] ) error("box size should be fixed. Use FRACTIONAL"); } // Ensure we only work with active multicolvars deactivateAllTasks(); - for(unsigned i=0; igetNumberOfStoredValues(); ++i) { - taskFlags[i]=1; - } + for(unsigned i=0; igetNumberOfStoredValues(); ++i) taskFlags[i]=1; lockContributors(); // Retrieve the origin origin = getPosition(0); } void MultiColvarDensity::compute( const unsigned& current, MultiValue& myvals ) const { - std::vector cvals( mycolv->getNumberOfQuantities() ); - stash->retrieveSequentialValue( current, false, cvals ); + std::vector cvals( mycolv->getNumberOfQuantities() ); stash->retrieveSequentialValue( current, false, cvals ); Vector fpos, apos = pbcDistance( origin, mycolv->getCentralAtomPos( mycolv->getPositionInFullTaskList(current) ) ); - if( fractional ) { - fpos = getPbc().realToScaled( apos ); - } else { - fpos=apos; - } + if( fractional ) { fpos = getPbc().realToScaled( apos ); } else { fpos=apos; } - myvals.setValue( 0, cweight*cvals[0] ); - for(unsigned j=0; jisDensity() ) { - error("filtering/transforming density makes no sense"); - } + BridgedMultiColvarFunction(ao) +{ + if( getPntrToMultiColvar()->isDensity() ) error("filtering/transforming density makes no sense"); - if( getName().find("MFILTER")!=std::string::npos ) { - filter=true; - } else { + if( getName().find("MFILTER")!=std::string::npos ) filter=true; + else { plumed_assert( getName().find("MTRANSFORM")!=std::string::npos ); filter=false; } @@ -62,9 +53,7 @@ void MultiColvarFilter::doJobsRequiredBeforeTaskList() { void MultiColvarFilter::completeTask( const unsigned& curr, MultiValue& invals, MultiValue& outvals ) const { invals.copyValues( outvals ); - if( derivativesAreRequired() ) { - invals.copyDerivatives( outvals ); - } + if( derivativesAreRequired() ) invals.copyDerivatives( outvals ); // Retrieve the value of the multicolvar and apply filter double val=invals.get(1), df, weight=applyFilter( val, df ); @@ -79,8 +68,7 @@ void MultiColvarFilter::completeTask( const unsigned& curr, MultiValue& invals, } } } else if( filter ) { - double ww=outvals.get(0); - outvals.setValue( 0, ww*weight ); + double ww=outvals.get(0); outvals.setValue( 0, ww*weight ); if( derivativesAreRequired() ) { for(unsigned i=0; iweightWithDerivatives() ) { - error("cannot take product of multicolvars with weights"); - } + if( mybasemulticolvars[i]->weightWithDerivatives() ) error("cannot take product of multicolvars with weights"); } } double MultiColvarProduct::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { - double dot=1; - std::vector tval(2); + double dot=1; std::vector tval(2); for(unsigned i=0; i cc(2); for(unsigned i=0; i0) { switchingFunction.set(sw,errors); } else { - double r_0=-1.0, d_0; - int nn, mm; - parse("NN",nn); - parse("MM",mm); - parse("R_0",r_0); - parse("D_0",d_0); - if( r_0<0.0 ) { - error("you must set a value for R_0"); - } + double r_0=-1.0, d_0; int nn, mm; + parse("NN",nn); parse("MM",mm); + parse("R_0",r_0); parse("D_0",d_0); + if( r_0<0.0 ) error("you must set a value for R_0"); switchingFunction.set(nn,mm,r_0,d_0); } log.printf(" calculating number of links with atoms separation of %s\n",( switchingFunction.description() ).c_str() ); - std::vector all_atoms; - readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - setupMultiColvarBase( all_atoms ); - setLinkCellCutoff( switchingFunction.get_dmax() ); + std::vector all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); + setupMultiColvarBase( all_atoms ); setLinkCellCutoff( switchingFunction.get_dmax() ); for(unsigned i=0; ihasDifferentiableOrientation() ) { - error("cannot use multicolvar of type " + getBaseMultiColvar(i)->getName() ); - } + if( !getBaseMultiColvar(i)->hasDifferentiableOrientation() ) error("cannot use multicolvar of type " + getBaseMultiColvar(i)->getName() ); } // Create holders for the collective variable readVesselKeywords(); plumed_assert( getNumberOfVessels()==0 ); - std::string input; - addVessel( "SUM", input, -1 ); + std::string input; addVessel( "SUM", input, -1 ); readVesselKeywords(); } @@ -160,9 +148,7 @@ double NumberOfLinks::calculateWeight( const unsigned& taskCode, const double& w } double NumberOfLinks::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { - if( getBaseMultiColvar(0)->getNumberOfQuantities()<3 ) { - return 1.0; - } + if( getBaseMultiColvar(0)->getNumberOfQuantities()<3 ) return 1.0; unsigned ncomp=getBaseMultiColvar(0)->getNumberOfQuantities(); diff --git a/src/multicolvar/Torsions.cpp b/src/multicolvar/Torsions.cpp index e8ccd2f93a..cd565ea73b 100644 --- a/src/multicolvar/Torsions.cpp +++ b/src/multicolvar/Torsions.cpp @@ -78,13 +78,8 @@ class Torsions : public MultiColvarBase { static void registerKeywords( Keywords& keys ); explicit Torsions(const ActionOptions&); double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; - bool isPeriodic() override { - return true; - } - void retrieveDomain( std::string& min, std::string& max ) override { - min="-pi"; - max="pi"; - } + bool isPeriodic() override { return true; } + void retrieveDomain( std::string& min, std::string& max ) override { min="-pi"; max="pi"; } }; PLUMED_REGISTER_ACTION(Torsions,"TORSIONS") @@ -97,16 +92,15 @@ void Torsions::registerKeywords( Keywords& keys ) { "provide the indices of four atoms). The eventual number of quantities calculated by this " "action will depend on what functions of the distribution you choose to calculate."); keys.reset_style("ATOMS","atoms"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); + keys.use("BETWEEN"); keys.use("HISTOGRAM"); } Torsions::Torsions(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the atoms - int natoms=4; - std::vector all_atoms; + int natoms=4; std::vector all_atoms; readAtomsLikeKeyword( "ATOMS", natoms, all_atoms ); setupMultiColvarBase( all_atoms ); std::vector catom_ind(4, false); @@ -124,8 +118,7 @@ double Torsions::compute( const unsigned& tindex, AtomValuePack& myatoms ) const d1=getSeparation(myatoms.getPosition(2),myatoms.getPosition(1)); d2=getSeparation(myatoms.getPosition(3),myatoms.getPosition(2)); - Vector dd0,dd1,dd2; - PLMD::Torsion t; + Vector dd0,dd1,dd2; PLMD::Torsion t; double value = t.compute(d0,d1,d2,dd0,dd1,dd2); addAtomDerivatives(1,0,dd0,myatoms); diff --git a/src/multicolvar/VolumeAround.cpp b/src/multicolvar/VolumeAround.cpp index c869886690..6d8f7e1e09 100644 --- a/src/multicolvar/VolumeAround.cpp +++ b/src/multicolvar/VolumeAround.cpp @@ -95,47 +95,29 @@ void VolumeAround::registerKeywords( Keywords& keys ) { VolumeAround::VolumeAround(const ActionOptions& ao): Action(ao), - ActionVolume(ao) { + ActionVolume(ao) +{ std::vector atom; parseAtomList("ATOM",atom); - if( atom.size()!=1 ) { - error("should only be one atom specified"); - } + if( atom.size()!=1 ) error("should only be one atom specified"); log.printf(" boundaries for region are calculated based on positions of atom : %d\n",atom[0].serial() ); - dox=true; - parse("XLOWER",xlow); - parse("XUPPER",xhigh); - doy=true; - parse("YLOWER",ylow); - parse("YUPPER",yhigh); - doz=true; - parse("ZLOWER",zlow); - parse("ZUPPER",zhigh); - if( xlow==0.0 && xhigh==0.0 ) { - dox=false; - } - if( ylow==0.0 && yhigh==0.0 ) { - doy=false; - } - if( zlow==0.0 && zhigh==0.0 ) { - doz=false; - } - if( !dox && !doy && !doz ) { - error("no subregion defined use XLOWER, XUPPER, YLOWER, YUPPER, ZLOWER, ZUPPER"); - } + dox=true; parse("XLOWER",xlow); parse("XUPPER",xhigh); + doy=true; parse("YLOWER",ylow); parse("YUPPER",yhigh); + doz=true; parse("ZLOWER",zlow); parse("ZUPPER",zhigh); + if( xlow==0.0 && xhigh==0.0 ) dox=false; + if( ylow==0.0 && yhigh==0.0 ) doy=false; + if( zlow==0.0 && zhigh==0.0 ) doz=false; + if( !dox && !doy && !doz ) error("no subregion defined use XLOWER, XUPPER, YLOWER, YUPPER, ZLOWER, ZUPPER"); log.printf(" boundaries for region (region of interest about atom) : x %f %f, y %f %f, z %f %f \n",xlow,xhigh,ylow,yhigh,zlow,zhigh); - checkRead(); - requestAtoms(atom); + checkRead(); requestAtoms(atom); } void VolumeAround::setupRegions() { } double VolumeAround::calculateNumberInside( const Vector& cpos, Vector& derivatives, Tensor& vir, std::vector& refders ) const { // Setup the histogram bead - HistogramBead bead; - bead.isNotPeriodic(); - bead.setKernelType( getKernelType() ); + HistogramBead bead; bead.isNotPeriodic(); bead.setKernelType( getKernelType() ); // Calculate position of atom wrt to origin Vector fpos=pbcDistance( getPosition(0), cpos ); @@ -144,22 +126,19 @@ double VolumeAround::calculateNumberInside( const Vector& cpos, Vector& derivati bead.set( xlow, xhigh, getSigma() ); xcontr=bead.calculate( fpos[0], xder ); } else { - xcontr=1.; - xder=0.; + xcontr=1.; xder=0.; } if( doy ) { bead.set( ylow, yhigh, getSigma() ); ycontr=bead.calculate( fpos[1], yder ); } else { - ycontr=1.; - yder=0.; + ycontr=1.; yder=0.; } if( doz ) { bead.set( zlow, zhigh, getSigma() ); zcontr=bead.calculate( fpos[2], zder ); } else { - zcontr=1.; - zder=0.; + zcontr=1.; zder=0.; } derivatives[0]=xder*ycontr*zcontr; derivatives[1]=xcontr*yder*zcontr; diff --git a/src/multicolvar/VolumeBetweenContours.cpp b/src/multicolvar/VolumeBetweenContours.cpp index 00a23d1fc3..d72e4c5937 100644 --- a/src/multicolvar/VolumeBetweenContours.cpp +++ b/src/multicolvar/VolumeBetweenContours.cpp @@ -78,8 +78,7 @@ class VolumeInEnvelope : public ActionVolume { PLUMED_REGISTER_ACTION(VolumeInEnvelope,"INENVELOPE") void VolumeInEnvelope::registerKeywords( Keywords& keys ) { - ActionVolume::registerKeywords( keys ); - keys.remove("SIGMA"); + ActionVolume::registerKeywords( keys ); keys.remove("SIGMA"); keys.add("atoms","ATOMS","the atom whose positions we are constructing a field from"); keys.add("compulsory","BANDWIDTH","the bandwidths for kernel density estimation"); keys.add("compulsory","CONTOUR","a switching function that tells PLUMED how large the density should be"); @@ -88,90 +87,58 @@ void VolumeInEnvelope::registerKeywords( Keywords& keys ) { VolumeInEnvelope::VolumeInEnvelope(const ActionOptions& ao): Action(ao), ActionVolume(ao), - mylinks(comm) { - std::vector atoms; - parseAtomList("ATOMS",atoms); + mylinks(comm) +{ + std::vector atoms; parseAtomList("ATOMS",atoms); log.printf(" creating density field from atoms : "); - for(unsigned i=0; i pp(3,0.0), bandwidth(3); - parseVector("BANDWIDTH",bandwidth); + std::vector pp(3,0.0), bandwidth(3); parseVector("BANDWIDTH",bandwidth); log.printf(" using %s kernel with bandwidths %f %f %f \n",getKernelType().c_str(),bandwidth[0],bandwidth[1],bandwidth[2] ); kernel=Tools::make_unique( pp, bandwidth, getKernelType(), "DIAGONAL", 1.0 ); - for(unsigned i=0; i<3; ++i) { - pos.emplace_back(Tools::make_unique()); - pos[i]->setNotPeriodic(); - } + for(unsigned i=0; i<3; ++i) { pos.emplace_back(Tools::make_unique()); pos[i]->setNotPeriodic(); } std::vector csupport( kernel->getContinuousSupport() ); double maxs = csupport[0]; for(unsigned i=1; imaxs ) { - maxs = csupport[i]; - } + if( csupport[i]>maxs ) maxs = csupport[i]; } - checkRead(); - requestAtoms(atoms); - mylinks.setCutoff( maxs ); + checkRead(); requestAtoms(atoms); mylinks.setCutoff( maxs ); } void VolumeInEnvelope::setupRegions() { - for(unsigned i=0; i& refders ) const { - unsigned ncells_required=0, natoms=1; - std::vector cells_required( mylinks.getNumberOfCells() ), indices( 1 + getNumberOfAtoms() ); + unsigned ncells_required=0, natoms=1; std::vector cells_required( mylinks.getNumberOfCells() ), indices( 1 + getNumberOfAtoms() ); mylinks.addRequiredCells( mylinks.findMyCell( cpos ), ncells_required, cells_required ); - indices[0]=getNumberOfAtoms(); - mylinks.retrieveAtomsInCells( ncells_required, cells_required, natoms, indices ); - double value=0; - std::vector der(3); - Vector tder; + indices[0]=getNumberOfAtoms(); mylinks.retrieveAtomsInCells( ncells_required, cells_required, natoms, indices ); + double value=0; std::vector der(3); Vector tder; // convert pointer once auto pos_ptr=Tools::unique2raw(pos); for(unsigned i=1; iset( dist[j] ); - } + for(unsigned j=0; j<3; ++j) pos[j]->set( dist[j] ); value += kernel->evaluate( pos_ptr, der, true ); for(unsigned j=0; j<3; ++j) { - derivatives[j] -= der[j]; - refders[ indices[i] ][j] += der[j]; - tder[j]=der[j]; + derivatives[j] -= der[j]; refders[ indices[i] ][j] += der[j]; tder[j]=der[j]; } vir -= Tensor( tder, dist ); } double deriv, fval = sfunc.calculate( value, deriv ); - derivatives *= -deriv*value; - vir *= -deriv*value; - for(unsigned i=1; i atoms; parseAtomList("ATOMS",atoms); - if( atoms.size()!=4 ) { - error("number of atoms should be equal to four"); - } + if( atoms.size()!=4 ) error("number of atoms should be equal to four"); log.printf(" boundaries for region are calculated based on positions of atoms : "); - for(unsigned i=0; i0 ) { - Units u; - u.setLength(unitname); + Units u; u.setLength(unitname); lenunit=plumed.getAtoms().getUnits().getLength()/u.getLength(); } else { unitname="nm"; @@ -207,14 +198,10 @@ void VolumeCavity::setupRegions() { d3 = pbcDistance(origin,getPosition(3)); // Create a set of unit vectors - bi = d1 / d1l; - len_bi=dotProduct( d3, bi ); - cross = crossProduct( d1, d2 ); - double crossmod=cross.modulo(); - cross = cross / crossmod; - len_cross=dotProduct( d3, cross ); - perp = crossProduct( cross, bi ); - len_perp=dotProduct( d3, perp ); + bi = d1 / d1l; len_bi=dotProduct( d3, bi ); + cross = crossProduct( d1, d2 ); double crossmod=cross.modulo(); + cross = cross / crossmod; len_cross=dotProduct( d3, cross ); + perp = crossProduct( cross, bi ); len_perp=dotProduct( d3, perp ); // Calculate derivatives of box shape with respect to atoms double d1l3=d1l*d1l*d1l; @@ -239,9 +226,7 @@ void VolumeCavity::setupRegions() { dbi[1](2,2) = ( (d1[1]*d1[1]+d1[0]*d1[0])/d1l3 ); dbi[2].zero(); - Tensor tcderiv; - double cmod3=crossmod*crossmod*crossmod; - Vector ucross=crossmod*cross; + Tensor tcderiv; double cmod3=crossmod*crossmod*crossmod; Vector ucross=crossmod*cross; tcderiv.setCol( 0, crossProduct( d1, Vector(-1.0,0.0,0.0) ) + crossProduct( Vector(-1.0,0.0,0.0), d2 ) ); tcderiv.setCol( 1, crossProduct( d1, Vector(0.0,-1.0,0.0) ) + crossProduct( Vector(0.0,-1.0,0.0), d2 ) ); tcderiv.setCol( 2, crossProduct( d1, Vector(0.0,0.0,-1.0) ) + crossProduct( Vector(0.0,0.0,-1.0), d2 ) ); @@ -295,29 +280,18 @@ void VolumeCavity::setupRegions() { // Ensure that all lengths are positive if( len_bi<0 ) { - bi=-bi; - len_bi=-len_bi; - for(unsigned i=0; i<3; ++i) { - dbi[i]*=-1.0; - } + bi=-bi; len_bi=-len_bi; + for(unsigned i=0; i<3; ++i) dbi[i]*=-1.0; } if( len_cross<0 ) { - cross=-cross; - len_cross=-len_cross; - for(unsigned i=0; i<3; ++i) { - dcross[i]*=-1.0; - } + cross=-cross; len_cross=-len_cross; + for(unsigned i=0; i<3; ++i) dcross[i]*=-1.0; } if( len_perp<0 ) { - perp=-perp; - len_perp=-len_perp; - for(unsigned i=0; i<3; ++i) { - dperp[i]*=-1.0; - } - } - if( len_bi<=0 || len_cross<=0 || len_perp<=0 ) { - plumed_merror("Invalid box coordinates"); + perp=-perp; len_perp=-len_perp; + for(unsigned i=0; i<3; ++i) dperp[i]*=-1.0; } + if( len_bi<=0 || len_cross<=0 || len_perp<=0 ) plumed_merror("Invalid box coordinates"); // Now derivatives of lengths Tensor dd3( Tensor::identity() ); @@ -338,15 +312,9 @@ void VolumeCavity::setupRegions() { // Need to calculate the jacobian Tensor jacob; - jacob(0,0)=bi[0]; - jacob(1,0)=bi[1]; - jacob(2,0)=bi[2]; - jacob(0,1)=cross[0]; - jacob(1,1)=cross[1]; - jacob(2,1)=cross[2]; - jacob(0,2)=perp[0]; - jacob(1,2)=perp[1]; - jacob(2,2)=perp[2]; + jacob(0,0)=bi[0]; jacob(1,0)=bi[1]; jacob(2,0)=bi[2]; + jacob(0,1)=cross[0]; jacob(1,1)=cross[1]; jacob(2,1)=cross[2]; + jacob(0,2)=perp[0]; jacob(1,2)=perp[1]; jacob(2,2)=perp[2]; jacob_det = std::fabs( jacob.determinant() ); } @@ -388,9 +356,7 @@ void VolumeCavity::update() { double VolumeCavity::calculateNumberInside( const Vector& cpos, Vector& derivatives, Tensor& vir, std::vector& rderiv ) const { // Setup the histogram bead - HistogramBead bead; - bead.isNotPeriodic(); - bead.setKernelType( getKernelType() ); + HistogramBead bead; bead.isNotPeriodic(); bead.setKernelType( getKernelType() ); // Calculate distance of atom from origin of new coordinate frame Vector datom=pbcDistance( origin, cpos ); @@ -417,23 +383,15 @@ double VolumeCavity::calculateNumberInside( const Vector& cpos, Vector& derivati double wdlen=bead.uboundDerivative( wpos ); double wder2 = bead.lboundDerivative( wpos ) - wdlen; - Vector dfd; - dfd[0]=uder*vcontr*wcontr; - dfd[1]=ucontr*vder*wcontr; - dfd[2]=ucontr*vcontr*wder; + Vector dfd; dfd[0]=uder*vcontr*wcontr; dfd[1]=ucontr*vder*wcontr; dfd[2]=ucontr*vcontr*wder; derivatives[0] = (dfd[0]*bi[0]+dfd[1]*cross[0]+dfd[2]*perp[0]); derivatives[1] = (dfd[0]*bi[1]+dfd[1]*cross[1]+dfd[2]*perp[1]); derivatives[2] = (dfd[0]*bi[2]+dfd[1]*cross[2]+dfd[2]*perp[2]); double tot = ucontr*vcontr*wcontr*jacob_det; // Add reference atom derivatives - dfd[0]=uder2*vcontr*wcontr; - dfd[1]=ucontr*vder2*wcontr; - dfd[2]=ucontr*vcontr*wder2; - Vector dfld; - dfld[0]=udlen*vcontr*wcontr; - dfld[1]=ucontr*vdlen*wcontr; - dfld[2]=ucontr*vcontr*wdlen; + dfd[0]=uder2*vcontr*wcontr; dfd[1]=ucontr*vder2*wcontr; dfd[2]=ucontr*vcontr*wder2; + Vector dfld; dfld[0]=udlen*vcontr*wcontr; dfld[1]=ucontr*vdlen*wcontr; dfld[2]=ucontr*vcontr*wdlen; rderiv[0] = dfd[0]*matmul(datom,dbi[0]) + dfd[1]*matmul(datom,dcross[0]) + dfd[2]*matmul(datom,dperp[0]) + dfld[0]*dlbi[0] + dfld[1]*dlcross[0] + dfld[2]*dlperp[0] - derivatives; rderiv[1] = dfd[0]*matmul(datom,dbi[1]) + dfd[1]*matmul(datom,dcross[1]) + dfd[2]*matmul(datom,dperp[1]) + @@ -442,8 +400,7 @@ double VolumeCavity::calculateNumberInside( const Vector& cpos, Vector& derivati dfld[0]*dlbi[2] + dfld[1]*dlcross[2] + dfld[2]*dlperp[2]; rderiv[3] = dfld[0]*dlbi[3] + dfld[1]*dlcross[3] + dfld[2]*dlperp[3]; - vir.zero(); - vir-=Tensor( cpos,derivatives ); + vir.zero(); vir-=Tensor( cpos,derivatives ); for(unsigned i=0; i<4; ++i) { vir -= Tensor( getPosition(i), rderiv[i] ); } diff --git a/src/multicolvar/VolumeGradientBase.cpp b/src/multicolvar/VolumeGradientBase.cpp index a0b1c5414f..2c7161ceda 100644 --- a/src/multicolvar/VolumeGradientBase.cpp +++ b/src/multicolvar/VolumeGradientBase.cpp @@ -33,28 +33,20 @@ void VolumeGradientBase::registerKeywords( Keywords& keys ) { VolumeGradientBase::VolumeGradientBase(const ActionOptions&ao): Action(ao), - BridgedMultiColvarFunction(ao) { + BridgedMultiColvarFunction(ao) +{ } void VolumeGradientBase::requestAtoms( const std::vector& atoms ) { - ActionAtomistic::requestAtoms(atoms); - bridgeVariable=3*atoms.size(); + ActionAtomistic::requestAtoms(atoms); bridgeVariable=3*atoms.size(); std::map checklabs; - for(const auto & p : getDependencies() ) { - checklabs.insert(std::pair(p->getLabel(),false)); - } + for(const auto & p : getDependencies() ) checklabs.insert(std::pair(p->getLabel(),false)); for(const auto & p : plumed.getActionSet() ) { - if( p->getLabel()==getPntrToMultiColvar()->getLabel() ) { - break; - } - if( checklabs.count(p->getLabel()) ) { - checklabs[p->getLabel()]=true; - } + if( p->getLabel()==getPntrToMultiColvar()->getLabel() ) break; + if( checklabs.count(p->getLabel()) ) checklabs[p->getLabel()]=true; } for(const auto & p : checklabs ) { - if( !p.second ) { - error("the input for the virtual atoms used in the input for this action must appear in the input file before the input multicolvar"); - } + if( !p.second ) error("the input for the virtual atoms used in the input for this action must appear in the input file before the input multicolvar"); } addDependency( getPntrToMultiColvar() ); tmpforces.resize( 3*atoms.size()+9 ); @@ -62,21 +54,17 @@ void VolumeGradientBase::requestAtoms( const std::vector& atoms ) { void VolumeGradientBase::doJobsRequiredBeforeTaskList() { ActionWithValue::clearDerivatives(); - retrieveAtoms(); - setupRegions(); + retrieveAtoms(); setupRegions(); ActionWithVessel::doJobsRequiredBeforeTaskList(); } void VolumeGradientBase::completeTask( const unsigned& curr, MultiValue& invals, MultiValue& outvals ) const { if( getPntrToMultiColvar()->isDensity() ) { - outvals.setValue(0, 1.0); - outvals.setValue(1, 1.0); + outvals.setValue(0, 1.0); outvals.setValue(1, 1.0); } else { // Copy derivatives of the colvar and the value of the colvar invals.copyValues( outvals ); - if( derivativesAreRequired() ) { - invals.copyDerivatives( outvals ); - } + if( derivativesAreRequired() ) invals.copyDerivatives( outvals ); } calculateAllVolumes( curr, outvals ); } @@ -88,8 +76,7 @@ void VolumeGradientBase::setNumberInVolume( const unsigned& ivol, const unsigned if( !mcolv->weightHasDerivatives ) { outvals.setValue(ivol, weight ); if( derivativesAreRequired() ) { - CatomPack catom; - mcolv->getCentralAtomPack( 0, curr, catom ); + CatomPack catom; mcolv->getCentralAtomPack( 0, curr, catom ); for(unsigned i=0; igetNumberOfDerivatives(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - outvals.addDerivative( ivol, nmder-9+3*i+j, virial(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) outvals.addDerivative( ivol, nmder-9+3*i+j, virial(i,j) ); for(unsigned i=0; igetCentralAtomPack( 0, curr, catom ); + CatomPack catom; mcolv->getCentralAtomPack( 0, curr, catom ); for(unsigned i=0; igetNumberOfDerivatives(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - outvals.addDerivative( ivol, nmder-9+3*i+j, ww*virial(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) outvals.addDerivative( ivol, nmder-9+3*i+j, ww*virial(i,j) ); for(unsigned i=0; igetCentralAtomPack( 0, curr, catom ); + CatomPack catom; mcolv->getCentralAtomPack( 0, curr, catom ); for(unsigned i=0; igetNumberOfDerivatives(); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - outvals.addDerivative( ivol, nmder-9+3*i+j, ww*virial(i,j) ); - } + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) outvals.addDerivative( ivol, nmder-9+3*i+j, ww*virial(i,j) ); for(unsigned i=0; i& bb ) { plumed_dbg_assert( bb.size()==tmpforces.size()-9 ); // Forces on local atoms - for(unsigned i=0; i(bridgeVariable)>=3*iatom && static_cast(bridgeVariable)<(iatom+1)*3 ) { - tmp_p[bridgeVariable%3]+=sqrt(epsilon); - } + if( static_cast(bridgeVariable)>=3*iatom && static_cast(bridgeVariable)<(iatom+1)*3 ) tmp_p[bridgeVariable%3]+=sqrt(epsilon); } // This makes sure that numerical derivatives of virial are calculated correctly tmp_p = ActionAtomistic::getPbc().realToScaled( tmp_p ); diff --git a/src/multicolvar/VolumeInCylinder.cpp b/src/multicolvar/VolumeInCylinder.cpp index 7134521520..c37ed8fda2 100644 --- a/src/multicolvar/VolumeInCylinder.cpp +++ b/src/multicolvar/VolumeInCylinder.cpp @@ -99,60 +99,35 @@ void VolumeInCylinder::registerKeywords( Keywords& keys ) { VolumeInCylinder::VolumeInCylinder(const ActionOptions& ao): Action(ao), ActionVolume(ao), - docylinder(false) { + docylinder(false) +{ std::vector atom; parseAtomList("ATOM",atom); - if( atom.size()!=1 ) { - error("should only be one atom specified"); - } + if( atom.size()!=1 ) error("should only be one atom specified"); log.printf(" center of cylinder is at position of atom : %d\n",atom[0].serial() ); - std::string sdir; - parse("DIRECTION",sdir); - if( sdir=="X") { - dir.push_back(1); - dir.push_back(2); - dir.push_back(0); - } else if( sdir=="Y") { - dir.push_back(0); - dir.push_back(2); - dir.push_back(1); - } else if( sdir=="Z") { - dir.push_back(0); - dir.push_back(1); - dir.push_back(2); - } else { - error(sdir + "is not a valid direction. Should be X, Y or Z"); - } + std::string sdir; parse("DIRECTION",sdir); + if( sdir=="X") {dir.push_back(1); dir.push_back(2); dir.push_back(0); } + else if( sdir=="Y") {dir.push_back(0); dir.push_back(2); dir.push_back(1); } + else if( sdir=="Z") {dir.push_back(0); dir.push_back(1); dir.push_back(2); } + else { error(sdir + "is not a valid direction. Should be X, Y or Z"); } log.printf(" cylinder's long axis is along %s axis\n",sdir.c_str() ); - std::string sw, errors; - parse("RADIUS",sw); - if(sw.length()==0) { - error("missing RADIUS keyword"); - } + std::string sw, errors; parse("RADIUS",sw); + if(sw.length()==0) error("missing RADIUS keyword"); switchingFunction.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading RADIUS keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading RADIUS keyword : " + errors ); log.printf(" radius of cylinder is given by %s \n", ( switchingFunction.description() ).c_str() ); - double min, max; - parse("LOWER",min); - parse("UPPER",max); + double min, max; parse("LOWER",min); parse("UPPER",max); if( min!=0.0 || max!=0.0 ) { - if( min>max ) { - error("minimum of cylinder should be less than maximum"); - } + if( min>max ) error("minimum of cylinder should be less than maximum"); docylinder=true; log.printf(" cylinder extends from %f to %f along the %s axis\n",min,max,sdir.c_str() ); - bead.isNotPeriodic(); - bead.setKernelType( getKernelType() ); - bead.set( min, max, getSigma() ); + bead.isNotPeriodic(); bead.setKernelType( getKernelType() ); bead.set( min, max, getSigma() ); } - checkRead(); - requestAtoms(atom); + checkRead(); requestAtoms(atom); } void VolumeInCylinder::setupRegions() { } @@ -165,14 +140,12 @@ double VolumeInCylinder::calculateNumberInside( const Vector& cpos, Vector& deri if( docylinder ) { vcylinder=bead.calculate( fpos[dir[2]], dcylinder ); } else { - vcylinder=1.0; - dcylinder=0.0; + vcylinder=1.0; dcylinder=0.0; } const double dd = fpos[dir[0]]*fpos[dir[0]] + fpos[dir[1]]*fpos[dir[1]]; double dfunc, vswitch = switchingFunction.calculateSqr( dd, dfunc ); - derivatives.zero(); - double value=vswitch*vcylinder; + derivatives.zero(); double value=vswitch*vcylinder; derivatives[dir[0]]=vcylinder*dfunc*fpos[dir[0]]; derivatives[dir[1]]=vcylinder*dfunc*fpos[dir[1]]; derivatives[dir[2]]=vswitch*dcylinder; diff --git a/src/multicolvar/VolumeInSphere.cpp b/src/multicolvar/VolumeInSphere.cpp index a79c6add0b..9de9077fc2 100644 --- a/src/multicolvar/VolumeInSphere.cpp +++ b/src/multicolvar/VolumeInSphere.cpp @@ -91,27 +91,20 @@ void VolumeInSphere::registerKeywords( Keywords& keys ) { VolumeInSphere::VolumeInSphere(const ActionOptions& ao): Action(ao), - ActionVolume(ao) { + ActionVolume(ao) +{ std::vector atom; parseAtomList("ATOM",atom); - if( atom.size()!=1 ) { - error("should only be one atom specified"); - } + if( atom.size()!=1 ) error("should only be one atom specified"); log.printf(" center of sphere is at position of atom : %d\n",atom[0].serial() ); - std::string sw, errors; - parse("RADIUS",sw); - if(sw.length()==0) { - error("missing RADIUS keyword"); - } + std::string sw, errors; parse("RADIUS",sw); + if(sw.length()==0) error("missing RADIUS keyword"); switchingFunction.set(sw,errors); - if( errors.length()!=0 ) { - error("problem reading RADIUS keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading RADIUS keyword : " + errors ); log.printf(" radius of sphere is given by %s \n", ( switchingFunction.description() ).c_str() ); - checkRead(); - requestAtoms(atom); + checkRead(); requestAtoms(atom); } void VolumeInSphere::setupRegions() { } @@ -120,9 +113,7 @@ double VolumeInSphere::calculateNumberInside( const Vector& cpos, Vector& deriva // Calculate position of atom wrt to origin Vector fpos=pbcDistance( getPosition(0), cpos ); double dfunc, value = switchingFunction.calculateSqr( fpos.modulo2(), dfunc ); - derivatives.zero(); - derivatives = dfunc*fpos; - refders[0] = -derivatives; + derivatives.zero(); derivatives = dfunc*fpos; refders[0] = -derivatives; // Add a virial contribution vir -= Tensor(fpos,derivatives); return value; diff --git a/src/multicolvar/VolumeTetrapore.cpp b/src/multicolvar/VolumeTetrapore.cpp index 97cbe507df..ee66d158dd 100644 --- a/src/multicolvar/VolumeTetrapore.cpp +++ b/src/multicolvar/VolumeTetrapore.cpp @@ -152,32 +152,23 @@ VolumeTetrapore::VolumeTetrapore(const ActionOptions& ao): dlperp(4), dbi(3), dcross(3), - dperp(3) { + dperp(3) +{ std::vector atoms; parseAtomList("ATOMS",atoms); - if( atoms.size()!=4 ) { - error("number of atoms should be equal to four"); - } + if( atoms.size()!=4 ) error("number of atoms should be equal to four"); log.printf(" boundaries for region are calculated based on positions of atoms : "); - for(unsigned i=0; i0 ) { - Units u; - u.setLength(unitname); + Units u; u.setLength(unitname); lenunit=plumed.getAtoms().getUnits().getLength()/u.getLength(); } else { unitname="nm"; @@ -214,15 +205,11 @@ void VolumeTetrapore::setupRegions() { d3 = pbcDistance(origin,getPosition(3)); // Create a set of unit vectors - Vector bisector = d1 + d2; - double bmod=bisector.modulo(); - bisector=bisector/bmod; + Vector bisector = d1 + d2; double bmod=bisector.modulo(); bisector=bisector/bmod; // bi = d1 / d1l; len_bi=dotProduct( d3, bi ); - cross = crossProduct( d1, d2 ); - double crossmod=cross.modulo(); - cross = cross / crossmod; - len_cross=dotProduct( d3, cross ); + cross = crossProduct( d1, d2 ); double crossmod=cross.modulo(); + cross = cross / crossmod; len_cross=dotProduct( d3, cross ); Vector truep = crossProduct( cross, bisector ); // These are our true vectors 45 degrees from bisector @@ -230,25 +217,13 @@ void VolumeTetrapore::setupRegions() { perp = std::cos(pi/4.0)*bisector - std::sin(pi/4.0)*truep; // And the lengths of the various parts average distance to opposite corners of tetetrahedron - len_bi = dotProduct( d1, bi ); - double len_bi2 = dotProduct( d2, bi ); - unsigned lbi=1; - if( len_bi2>len_bi ) { - len_bi=len_bi2; - lbi=2; - } - len_perp = dotProduct( d1, perp ); - double len_perp2 = dotProduct( d2, perp ); - unsigned lpi=1; - if( len_perp2>len_perp ) { - len_perp=len_perp2; - lpi=2; - } + len_bi = dotProduct( d1, bi ); double len_bi2 = dotProduct( d2, bi ); unsigned lbi=1; + if( len_bi2>len_bi ) { len_bi=len_bi2; lbi=2; } + len_perp = dotProduct( d1, perp ); double len_perp2 = dotProduct( d2, perp ); unsigned lpi=1; + if( len_perp2>len_perp ) { len_perp=len_perp2; lpi=2; } plumed_assert( lbi!=lpi ); - Tensor tcderiv; - double cmod3=crossmod*crossmod*crossmod; - Vector ucross=crossmod*cross; + Tensor tcderiv; double cmod3=crossmod*crossmod*crossmod; Vector ucross=crossmod*cross; tcderiv.setCol( 0, crossProduct( d1, Vector(-1.0,0.0,0.0) ) + crossProduct( Vector(-1.0,0.0,0.0), d2 ) ); tcderiv.setCol( 1, crossProduct( d1, Vector(0.0,-1.0,0.0) ) + crossProduct( Vector(0.0,-1.0,0.0), d2 ) ); tcderiv.setCol( 2, crossProduct( d1, Vector(0.0,0.0,-1.0) ) + crossProduct( Vector(0.0,0.0,-1.0), d2 ) ); @@ -289,8 +264,7 @@ void VolumeTetrapore::setupRegions() { dcross[2](2,2)=( tcderiv(2,2)/crossmod - ucross[2]*(ucross[0]*tcderiv(0,2) + ucross[1]*tcderiv(1,2) + ucross[2]*tcderiv(2,2))/cmod3 ); // dz/dz std::vector dbisector(3); - double bmod3=bmod*bmod*bmod; - Vector ubisector=bmod*bisector; + double bmod3=bmod*bmod*bmod; Vector ubisector=bmod*bisector; dbisector[0](0,0)= -2.0/bmod + 2*ubisector[0]*ubisector[0]/bmod3; dbisector[0](0,1)= 2*ubisector[0]*ubisector[1]/bmod3; dbisector[0](0,2)= 2*ubisector[0]*ubisector[2]/bmod3; @@ -342,39 +316,22 @@ void VolumeTetrapore::setupRegions() { // Ensure that all lengths are positive if( len_bi<0 ) { - bi=-bi; - len_bi=-len_bi; - for(unsigned i=0; i<3; ++i) { - dbi[i]*=-1.0; - } + bi=-bi; len_bi=-len_bi; + for(unsigned i=0; i<3; ++i) dbi[i]*=-1.0; } if( len_cross<0 ) { - cross=-cross; - len_cross=-len_cross; - for(unsigned i=0; i<3; ++i) { - dcross[i]*=-1.0; - } + cross=-cross; len_cross=-len_cross; + for(unsigned i=0; i<3; ++i) dcross[i]*=-1.0; } if( len_perp<0 ) { - perp=-perp; - len_perp=-len_perp; - for(unsigned i=0; i<3; ++i) { - dperp[i]*=-1.0; - } - } - if( len_bi<=0 || len_cross<=0 || len_perp<=0 ) { - plumed_merror("Invalid box coordinates"); + perp=-perp; len_perp=-len_perp; + for(unsigned i=0; i<3; ++i) dperp[i]*=-1.0; } + if( len_bi<=0 || len_cross<=0 || len_perp<=0 ) plumed_merror("Invalid box coordinates"); // Now derivatives of lengths - Tensor dd3( Tensor::identity() ); - Vector ddb2=d1; - if( lbi==2 ) { - ddb2=d2; - } - dlbi[1].zero(); - dlbi[2].zero(); - dlbi[3].zero(); + Tensor dd3( Tensor::identity() ); Vector ddb2=d1; if( lbi==2 ) ddb2=d2; + dlbi[1].zero(); dlbi[2].zero(); dlbi[3].zero(); dlbi[0] = matmul(ddb2,dbi[0]) - matmul(bi,dd3); dlbi[lbi] = matmul(ddb2,dbi[lbi]) + matmul(bi,dd3); // Derivative wrt d1 @@ -383,27 +340,16 @@ void VolumeTetrapore::setupRegions() { dlcross[2] = matmul(d3,dcross[2]); dlcross[3] = matmul(cross,dd3); - ddb2=d1; - if( lpi==2 ) { - ddb2=d2; - } - dlperp[1].zero(); - dlperp[2].zero(); - dlperp[3].zero(); + ddb2=d1; if( lpi==2 ) ddb2=d2; + dlperp[1].zero(); dlperp[2].zero(); dlperp[3].zero(); dlperp[0] = matmul(ddb2,dperp[0]) - matmul( perp, dd3 ); dlperp[lpi] = matmul(ddb2,dperp[lpi]) + matmul(perp, dd3); // Need to calculate the jacobian Tensor jacob; - jacob(0,0)=bi[0]; - jacob(1,0)=bi[1]; - jacob(2,0)=bi[2]; - jacob(0,1)=cross[0]; - jacob(1,1)=cross[1]; - jacob(2,1)=cross[2]; - jacob(0,2)=perp[0]; - jacob(1,2)=perp[1]; - jacob(2,2)=perp[2]; + jacob(0,0)=bi[0]; jacob(1,0)=bi[1]; jacob(2,0)=bi[2]; + jacob(0,1)=cross[0]; jacob(1,1)=cross[1]; jacob(2,1)=cross[2]; + jacob(0,2)=perp[0]; jacob(1,2)=perp[1]; jacob(2,2)=perp[2]; jacob_det = std::fabs( jacob.determinant() ); } @@ -445,9 +391,7 @@ void VolumeTetrapore::update() { double VolumeTetrapore::calculateNumberInside( const Vector& cpos, Vector& derivatives, Tensor& vir, std::vector& rderiv ) const { // Setup the histogram bead - HistogramBead bead; - bead.isNotPeriodic(); - bead.setKernelType( getKernelType() ); + HistogramBead bead; bead.isNotPeriodic(); bead.setKernelType( getKernelType() ); // Calculate distance of atom from origin of new coordinate frame Vector datom=pbcDistance( origin, cpos ); @@ -474,23 +418,15 @@ double VolumeTetrapore::calculateNumberInside( const Vector& cpos, Vector& deriv double wdlen=bead.uboundDerivative( wpos ); double wder2 = bead.lboundDerivative( wpos ) - wdlen; - Vector dfd; - dfd[0]=uder*vcontr*wcontr; - dfd[1]=ucontr*vder*wcontr; - dfd[2]=ucontr*vcontr*wder; + Vector dfd; dfd[0]=uder*vcontr*wcontr; dfd[1]=ucontr*vder*wcontr; dfd[2]=ucontr*vcontr*wder; derivatives[0] = (dfd[0]*bi[0]+dfd[1]*cross[0]+dfd[2]*perp[0]); derivatives[1] = (dfd[0]*bi[1]+dfd[1]*cross[1]+dfd[2]*perp[1]); derivatives[2] = (dfd[0]*bi[2]+dfd[1]*cross[2]+dfd[2]*perp[2]); double tot = ucontr*vcontr*wcontr*jacob_det; // Add reference atom derivatives - dfd[0]=uder2*vcontr*wcontr; - dfd[1]=ucontr*vder2*wcontr; - dfd[2]=ucontr*vcontr*wder2; - Vector dfld; - dfld[0]=udlen*vcontr*wcontr; - dfld[1]=ucontr*vdlen*wcontr; - dfld[2]=ucontr*vcontr*wdlen; + dfd[0]=uder2*vcontr*wcontr; dfd[1]=ucontr*vder2*wcontr; dfd[2]=ucontr*vcontr*wder2; + Vector dfld; dfld[0]=udlen*vcontr*wcontr; dfld[1]=ucontr*vdlen*wcontr; dfld[2]=ucontr*vcontr*wdlen; rderiv[0] = dfd[0]*matmul(datom,dbi[0]) + dfd[1]*matmul(datom,dcross[0]) + dfd[2]*matmul(datom,dperp[0]) + dfld[0]*dlbi[0] + dfld[1]*dlcross[0] + dfld[2]*dlperp[0] - derivatives; rderiv[1] = dfd[0]*matmul(datom,dbi[1]) + dfd[1]*matmul(datom,dcross[1]) + dfd[2]*matmul(datom,dperp[1]) + @@ -499,8 +435,7 @@ double VolumeTetrapore::calculateNumberInside( const Vector& cpos, Vector& deriv dfld[0]*dlbi[2] + dfld[1]*dlcross[2] + dfld[2]*dlperp[2]; rderiv[3] = dfld[0]*dlbi[3] + dfld[1]*dlcross[3] + dfld[2]*dlperp[3]; - vir.zero(); - vir-=Tensor( cpos,derivatives ); + vir.zero(); vir-=Tensor( cpos,derivatives ); for(unsigned i=0; i<4; ++i) { vir -= Tensor( getPosition(i), rderiv[i] ); } diff --git a/src/multicolvar/XAngle.cpp b/src/multicolvar/XAngle.cpp index 27c8a1dd59..e50a90b227 100644 --- a/src/multicolvar/XAngle.cpp +++ b/src/multicolvar/XAngle.cpp @@ -93,9 +93,7 @@ class XAngles : public MultiColvarBase { double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; double calculateWeight( const unsigned& taskCode, const double& weight, AtomValuePack& ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(XAngles,"XANGLES") @@ -104,17 +102,10 @@ PLUMED_REGISTER_ACTION(XAngles,"ZANGLES") void XAngles::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("MAX"); - keys.use("ALT_MIN"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("LESS_THAN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("MAX"); keys.use("ALT_MIN"); + keys.use("MEAN"); keys.use("MIN"); keys.use("LESS_THAN"); + keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("MORE_THAN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.add("numbered","ATOMS","the atoms involved in each of the angles you wish to calculate. " "Keywords like ATOMS1, ATOMS2, ATOMS3,... should be listed and one angle will be " "calculated for each ATOM keyword you specify (all ATOM keywords should " @@ -133,27 +124,19 @@ void XAngles::registerKeywords( Keywords& keys ) { XAngles::XAngles(const ActionOptions&ao): Action(ao), MultiColvarBase(ao), - use_sf(false) { - if( getName().find("X")!=std::string::npos) { - myc=0; - } else if( getName().find("Y")!=std::string::npos) { - myc=1; - } else if( getName().find("Z")!=std::string::npos) { - myc=2; - } else { - plumed_error(); - } + use_sf(false) +{ + if( getName().find("X")!=std::string::npos) myc=0; + else if( getName().find("Y")!=std::string::npos) myc=1; + else if( getName().find("Z")!=std::string::npos) myc=2; + else plumed_error(); // Read in switching function - std::string sfinput, errors; - parse("SWITCH",sfinput); + std::string sfinput, errors; parse("SWITCH",sfinput); if( sfinput.length()>0 ) { - use_sf=true; - weightHasDerivatives=true; + use_sf=true; weightHasDerivatives=true; sf1.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); log.printf(" only calculating angles for atoms separated by less than %s\n", sf1.description().c_str() ); setLinkCellCutoff( sf1.get_dmax() ); } @@ -161,18 +144,14 @@ XAngles::XAngles(const ActionOptions&ao): // Read in the atoms std::vector all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); setupMultiColvarBase( all_atoms ); // And check everything has been read in correctly checkRead(); } double XAngles::calculateWeight( const unsigned& taskCode, const double& weight, AtomValuePack& myatoms ) const { - if(!use_sf) { - return 1.0; - } + if(!use_sf) return 1.0; Vector distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); double dw, w = sf1.calculateSqr( distance.modulo2(), dw ); @@ -183,12 +162,9 @@ double XAngles::calculateWeight( const unsigned& taskCode, const double& weight, } double XAngles::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { - Vector ddij, ddik, axis, distance; - axis.zero(); - axis[myc]=1; + Vector ddij, ddik, axis, distance; axis.zero(); axis[myc]=1; distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - PLMD::Angle a; - double angle=a.compute( distance, axis, ddij, ddik ); + PLMD::Angle a; double angle=a.compute( distance, axis, ddij, ddik ); addAtomDerivatives( 1, 0, -ddij, myatoms ); addAtomDerivatives( 1, 1, ddij, myatoms ); diff --git a/src/multicolvar/XDistances.cpp b/src/multicolvar/XDistances.cpp index 4e6eecf08e..a60347eef4 100644 --- a/src/multicolvar/XDistances.cpp +++ b/src/multicolvar/XDistances.cpp @@ -179,9 +179,7 @@ class XDistances : public MultiColvarBase { // active methods: double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(XDistances,"XDISTANCES") @@ -190,17 +188,10 @@ PLUMED_REGISTER_ACTION(XDistances,"ZDISTANCES") void XDistances::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("MAX"); - keys.use("ALT_MIN"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("LESS_THAN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("MAX"); keys.use("ALT_MIN"); + keys.use("MEAN"); keys.use("MIN"); keys.use("LESS_THAN"); + keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("MORE_THAN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.add("numbered","ATOMS","the atoms involved in each of the distances you wish to calculate. " "Keywords like ATOMS1, ATOMS2, ATOMS3,... should be listed and one distance will be " "calculated for each ATOM keyword you specify (all ATOM keywords should " @@ -216,23 +207,17 @@ void XDistances::registerKeywords( Keywords& keys ) { XDistances::XDistances(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { - if( getName().find("X")!=std::string::npos) { - myc=0; - } else if( getName().find("Y")!=std::string::npos) { - myc=1; - } else if( getName().find("Z")!=std::string::npos) { - myc=2; - } else { - plumed_error(); - } + MultiColvarBase(ao) +{ + if( getName().find("X")!=std::string::npos) myc=0; + else if( getName().find("Y")!=std::string::npos) myc=1; + else if( getName().find("Z")!=std::string::npos) myc=2; + else plumed_error(); // Read in the atoms std::vector all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); setupMultiColvarBase( all_atoms ); // And check everything has been read in correctly checkRead(); @@ -243,13 +228,10 @@ double XDistances::compute( const unsigned& tindex, AtomValuePack& myatoms ) con distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); const double value=distance[myc]; - Vector myvec; - myvec.zero(); + Vector myvec; myvec.zero(); // And finish the calculation - myvec[myc]=+1; - addAtomDerivatives( 1, 1, myvec, myatoms ); - myvec[myc]=-1; - addAtomDerivatives( 1, 0, myvec, myatoms ); + myvec[myc]=+1; addAtomDerivatives( 1, 1, myvec, myatoms ); + myvec[myc]=-1; addAtomDerivatives( 1, 0, myvec, myatoms ); myatoms.addBoxDerivatives( 1, Tensor(distance,myvec) ); return value; } diff --git a/src/multicolvar/XYDistances.cpp b/src/multicolvar/XYDistances.cpp index bbafbcd4c5..a01d002bab 100644 --- a/src/multicolvar/XYDistances.cpp +++ b/src/multicolvar/XYDistances.cpp @@ -104,9 +104,7 @@ class XYDistances : public MultiColvarBase { // active methods: double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(XYDistances,"XYDISTANCES") @@ -115,17 +113,9 @@ PLUMED_REGISTER_ACTION(XYDistances,"YZDISTANCES") void XYDistances::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("MAX"); - keys.use("ALT_MIN"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("LESS_THAN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("MORE_THAN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("MAX"); keys.use("ALT_MIN"); + keys.use("MEAN"); keys.use("MIN"); keys.use("LESS_THAN"); keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("MORE_THAN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.add("numbered","ATOMS","the atoms involved in each of the distances you wish to calculate. " "Keywords like ATOMS1, ATOMS2, ATOMS3,... should be listed and one distance will be " "calculated for each ATOM keyword you specify (all ATOM keywords should " @@ -141,26 +131,20 @@ void XYDistances::registerKeywords( Keywords& keys ) { XYDistances::XYDistances(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ if( getName().find("XY")!=std::string::npos) { - myc1=0; - myc2=1; + myc1=0; myc2=1; } else if( getName().find("XZ")!=std::string::npos) { - myc1=0; - myc2=2; + myc1=0; myc2=2; } else if( getName().find("YZ")!=std::string::npos) { - myc1=1; - myc2=2; - } else { - plumed_error(); - } + myc1=1; myc2=2; + } else plumed_error(); // Read in the atoms std::vector all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); setupMultiColvarBase( all_atoms ); // And check everything has been read in correctly checkRead(); @@ -172,15 +156,10 @@ double XYDistances::compute( const unsigned& tindex, AtomValuePack& myatoms ) co const double value=std::sqrt(distance[myc1]*distance[myc1] + distance[myc2]*distance[myc2] ); const double invvalue=1.0/value; - Vector myvec; - myvec.zero(); + Vector myvec; myvec.zero(); // And finish the calculation - myvec[myc1]=+invvalue*distance[myc1]; - myvec[myc2]=+invvalue*distance[myc2]; - addAtomDerivatives( 1, 1, myvec, myatoms ); - myvec[myc1]=-invvalue*distance[myc1]; - myvec[myc2]=-invvalue*distance[myc2]; - addAtomDerivatives( 1, 0, myvec, myatoms ); + myvec[myc1]=+invvalue*distance[myc1]; myvec[myc2]=+invvalue*distance[myc2]; addAtomDerivatives( 1, 1, myvec, myatoms ); + myvec[myc1]=-invvalue*distance[myc1]; myvec[myc2]=-invvalue*distance[myc2]; addAtomDerivatives( 1, 0, myvec, myatoms ); myatoms.addBoxDerivatives( 1, Tensor(distance,myvec) ); return value; } diff --git a/src/multicolvar/XYTorsion.cpp b/src/multicolvar/XYTorsion.cpp index e644728686..0d1d45c2d8 100644 --- a/src/multicolvar/XYTorsion.cpp +++ b/src/multicolvar/XYTorsion.cpp @@ -142,13 +142,8 @@ class XYTorsion : public MultiColvarBase { double compute( const unsigned& tindex, AtomValuePack& myatoms ) const override; double calculateWeight( const unsigned& taskCode, const double& weight, AtomValuePack& ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return true; - } - void retrieveDomain( std::string& min, std::string& max) override { - min="-pi"; - max="pi"; - } + bool isPeriodic() override { return true; } + void retrieveDomain( std::string& min, std::string& max) override { min="-pi"; max="pi"; } }; PLUMED_REGISTER_ACTION(XYTorsion,"XYTORSIONS") @@ -160,15 +155,10 @@ PLUMED_REGISTER_ACTION(XYTorsion,"ZYTORSIONS") void XYTorsion::registerKeywords( Keywords& keys ) { MultiColvarBase::registerKeywords( keys ); - keys.use("MAX"); - keys.use("ALT_MIN"); - keys.use("MEAN"); - keys.use("MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); + keys.use("MAX"); keys.use("ALT_MIN"); + keys.use("MEAN"); keys.use("MIN"); + keys.use("LOWEST"); keys.use("HIGHEST"); + keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); keys.add("numbered","ATOMS","the atoms involved in each of the torsion angles you wish to calculate. " "Keywords like ATOMS1, ATOMS2, ATOMS3,... should be listed and one torsion will be " "calculated for each ATOM keyword you specify (all ATOM keywords should " @@ -187,39 +177,22 @@ void XYTorsion::registerKeywords( Keywords& keys ) { XYTorsion::XYTorsion(const ActionOptions&ao): Action(ao), MultiColvarBase(ao), - use_sf(false) { - if( getName().find("XY")!=std::string::npos) { - myc1=0; - myc2=1; - } else if( getName().find("XZ")!=std::string::npos) { - myc1=0; - myc2=2; - } else if( getName().find("YX")!=std::string::npos) { - myc1=1; - myc2=0; - } else if( getName().find("YZ")!=std::string::npos) { - myc1=1; - myc2=2; - } else if( getName().find("ZX")!=std::string::npos) { - myc1=2; - myc2=0; - } else if( getName().find("ZY")!=std::string::npos) { - myc1=2; - myc2=1; - } else { - plumed_error(); - } + use_sf(false) +{ + if( getName().find("XY")!=std::string::npos) { myc1=0; myc2=1; } + else if( getName().find("XZ")!=std::string::npos) { myc1=0; myc2=2; } + else if( getName().find("YX")!=std::string::npos) { myc1=1; myc2=0; } + else if( getName().find("YZ")!=std::string::npos) { myc1=1; myc2=2; } + else if( getName().find("ZX")!=std::string::npos) { myc1=2; myc2=0; } + else if( getName().find("ZY")!=std::string::npos) { myc1=2; myc2=1; } + else plumed_error(); // Read in switching function - std::string sfinput, errors; - parse("SWITCH",sfinput); + std::string sfinput, errors; parse("SWITCH",sfinput); if( sfinput.length()>0 ) { - use_sf=true; - weightHasDerivatives=true; + use_sf=true; weightHasDerivatives=true; sf1.set(sfinput,errors); - if( errors.length()!=0 ) { - error("problem reading SWITCH keyword : " + errors ); - } + if( errors.length()!=0 ) error("problem reading SWITCH keyword : " + errors ); log.printf(" only calculating angles for atoms separated by less than %s\n", sf1.description().c_str() ); setLinkCellCutoff( sf1.get_dmax() ); } @@ -227,18 +200,14 @@ XYTorsion::XYTorsion(const ActionOptions&ao): // Read in the atoms std::vector all_atoms; readTwoGroups( "GROUP", "GROUPA", "GROUPB", all_atoms ); - if( atom_lab.size()==0 ) { - readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); - } + if( atom_lab.size()==0 ) readAtomsLikeKeyword( "ATOMS", 2, all_atoms ); setupMultiColvarBase( all_atoms ); // And check everything has been read in correctly checkRead(); } double XYTorsion::calculateWeight( const unsigned& taskCode, const double& weight, AtomValuePack& myatoms ) const { - if(!use_sf) { - return 1.0; - } + if(!use_sf) return 1.0; Vector distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); double dw, w = sf1.calculateSqr( distance.modulo2(), dw ); @@ -250,13 +219,9 @@ double XYTorsion::calculateWeight( const unsigned& taskCode, const double& weigh double XYTorsion::compute( const unsigned& tindex, AtomValuePack& myatoms ) const { Vector dd0, dd1, dd2, axis, rot, distance; - axis.zero(); - rot.zero(); - rot[myc1]=1; - axis[myc2]=1; + axis.zero(); rot.zero(); rot[myc1]=1; axis[myc2]=1; distance=getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - PLMD::Torsion t; - double torsion=t.compute( distance, rot, axis, dd0, dd1, dd2 ); + PLMD::Torsion t; double torsion=t.compute( distance, rot, axis, dd0, dd1, dd2 ); addAtomDerivatives( 1, 0, -dd0, myatoms ); addAtomDerivatives( 1, 1, dd0, myatoms ); diff --git a/src/opes/ECVcustom.cpp b/src/opes/ECVcustom.cpp index 4cfb77f952..cde45524d9 100644 --- a/src/opes/ECVcustom.cpp +++ b/src/opes/ECVcustom.cpp @@ -59,7 +59,8 @@ opes: OPES_EXPANDED ARG=ecv.* PACE=500 //+ENDPLUMEDOC class ECVcustom : - public ExpansionCVs { + public ExpansionCVs +{ private: unsigned P0_contribution_; double barrier_; @@ -83,7 +84,8 @@ class ECVcustom : PLUMED_REGISTER_ACTION(ECVcustom,"ECV_CUSTOM") -void ECVcustom::registerKeywords(Keywords& keys) { +void ECVcustom::registerKeywords(Keywords& keys) +{ ExpansionCVs::registerKeywords(keys); keys.remove("ARG"); keys.add("compulsory","ARG","the labels of the single ECVs. \\f$\\Delta U_i\\f$, in energy units"); @@ -95,22 +97,21 @@ void ECVcustom::registerKeywords(Keywords& keys) { ECVcustom::ECVcustom(const ActionOptions&ao) : Action(ao) , ExpansionCVs(ao) - , beta0_(1./kbt_) { + , beta0_(1./kbt_) +{ //set beta0_ bool dimensionless; parseFlag("DIMENSIONLESS",dimensionless); - if(dimensionless) { + if(dimensionless) beta0_=1; - } //set P0_contribution_ bool add_P0=false; parseFlag("ADD_P0",add_P0); - if(add_P0) { + if(add_P0) P0_contribution_=1; - } else { + else P0_contribution_=0; - } //set barrier_ barrier_=std::numeric_limits::infinity(); @@ -122,105 +123,106 @@ ECVcustom::ECVcustom(const ActionOptions&ao) totNumECVs_=getNumberOfArguments()+P0_contribution_; ECVs_.resize(getNumberOfArguments(),std::vector(totNumECVs_)); derECVs_.resize(getNumberOfArguments(),std::vector(totNumECVs_)); - for(unsigned j=0; j::infinity()) { + if(barrier_!=std::numeric_limits::infinity()) + { log.printf(" guess for free energy BARRIER = %g\n",barrier_); - if(dimensionless) { + if(dimensionless) log.printf(" also the BARRIER is considered to be DIMENSIONLESS\n"); - } } - if(P0_contribution_==1) { + if(P0_contribution_==1) log.printf(" -- ADD_P0: the target includes also the unbiased probability itself\n"); - } } -void ECVcustom::calculateECVs(const double * cv) { - for(unsigned j=0; j > ECVcustom::getIndex_k() const { +std::vector< std::vector > ECVcustom::getIndex_k() const +{ plumed_massert(isReady_ && totNumECVs_>0,"cannot access getIndex_k() of ECV before initialization"); std::vector< std::vector > index_k(totNumECVs_,std::vector(getNumberOfArguments())); for(unsigned k=0; k ECVcustom::getLambdas() const { +std::vector ECVcustom::getLambdas() const +{ std::vector lambdas(totNumECVs_); - if(P0_contribution_==1) { + if(P0_contribution_==1) + { std::ostringstream subs; subs<<"P0"; - for(unsigned j=1; j(this)->getPntrToArgument(kk)->getName(); - } else { + else subs<<"NaN"; - } - for(unsigned j=1; j(this)->getPntrToArgument(kk)->getName(); - } else { + else subs<<"_NaN"; - } } lambdas[k]=subs.str(); } return lambdas; } -void ECVcustom::initECVs() { +void ECVcustom::initECVs() +{ plumed_massert(!isReady_,"initialization should not be called twice"); isReady_=true; log.printf(" *%4u ECVs for %s\n",totNumECVs_,getName().c_str()); } -void ECVcustom::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) { +void ECVcustom::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) +{ initECVs(); calculateECVs(&all_obs_cvs[index_j]); - for(unsigned j=0; j& lambdas) { +void ECVcustom::initECVs_restart(const std::vector& lambdas) +{ std::size_t pos=0; - for(unsigned j=0; jlambdas[0].length(),"this should not happen, more '_' than expected in "+getName()); diff --git a/src/opes/ECVlinear.cpp b/src/opes/ECVlinear.cpp index 6bed2d1081..89e856e7f7 100644 --- a/src/opes/ECVlinear.cpp +++ b/src/opes/ECVlinear.cpp @@ -70,7 +70,8 @@ Notice that by defauly LAMBDA=0, LAMBDA_MIN=0 and LAMBDA_MAX=1, which is the typ //+ENDPLUMEDOC class ECVlinear : - public ExpansionCVs { + public ExpansionCVs +{ private: bool todoAutomatic_; bool geom_spacing_; @@ -93,7 +94,8 @@ class ECVlinear : PLUMED_REGISTER_ACTION(ECVlinear,"ECV_LINEAR") -void ECVlinear::registerKeywords(Keywords& keys) { +void ECVlinear::registerKeywords(Keywords& keys) +{ ExpansionCVs::registerKeywords(keys); keys.remove("ARG"); keys.add("compulsory","ARG","the label of the Hamiltonian difference. \\f$\\Delta U\\f$"); @@ -110,15 +112,15 @@ ECVlinear::ECVlinear(const ActionOptions&ao) : Action(ao) , ExpansionCVs(ao) , todoAutomatic_(false) - , beta0_(1./kbt_) { + , beta0_(1./kbt_) +{ plumed_massert(getNumberOfArguments()==1,"only DeltaU should be given as ARG"); //set beta0_ bool dimensionless; parseFlag("DIMENSIONLESS",dimensionless); - if(dimensionless) { + if(dimensionless) beta0_=1; - } //parse lambda info parse("LAMBDA",lambda0_); @@ -136,26 +138,28 @@ ECVlinear::ECVlinear(const ActionOptions&ao) checkRead(); //set the diff vector using lambdas - if(lambdas.size()>0) { + if(lambdas.size()>0) + { plumed_massert(lambda_steps==0,"cannot set both LAMBDA_STEPS and LAMBDA_SET_ALL"); plumed_massert(lambda_min==myNone && lambda_max==myNone,"cannot set both LAMBDA_SET_ALL and LAMBDA_MIN/MAX"); plumed_massert(lambdas.size()>=2,"set at least 2 lambdas with LAMBDA_SET_ALL"); - for(unsigned k=0; k0) { + if(lambda_steps>0) derECVs_=getSteps(derECVs_[0],derECVs_[1],lambda_steps,"LAMBDA",geom_spacing_,beta0_*lambda0_); - } else { + else todoAutomatic_=true; - } } - if(lambda0_lambda_max) { + if(lambda0_lambda_max) log.printf(" +++ WARNING +++ running at LAMBDA=%g which is outside the chosen lambda range\n",lambda0_); - } //print some info log.printf(" running at LAMBDA=%g\n",lambda0_); log.printf(" targeting a lambda range from LAMBDA_MIN=%g to LAMBDA_MAX=%g\n",lambda_min,lambda_max); - if(dimensionless) { + if(dimensionless) log.printf(" -- DIMENSIONLESS: the ARG is not multiplied by beta\n"); - } - if(geom_spacing_) { + if(geom_spacing_) log.printf(" -- GEOM_SPACING: lambdas will be geometrically spaced\n"); - } } -void ECVlinear::calculateECVs(const double * DeltaU) { - for(unsigned k=0; k ECVlinear::getLambdas() const { +std::vector ECVlinear::getLambdas() const +{ plumed_massert(!todoAutomatic_,"cannot access lambdas before initializing them"); std::vector lambdas(derECVs_.size()); - for(unsigned k=0; k ECVlinear::getLambdas() const { return lambdas; } -void ECVlinear::initECVs() { +void ECVlinear::initECVs() +{ plumed_massert(!isReady_,"initialization should not be called twice"); plumed_massert(!todoAutomatic_,"this should not happen"); totNumECVs_=derECVs_.size(); @@ -226,17 +230,17 @@ void ECVlinear::initECVs() { log.printf(" *%4lu lambdas for %s\n",derECVs_.size(),getName().c_str()); } -void ECVlinear::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) { - if(todoAutomatic_) { //estimate the steps in lambda from observations +void ECVlinear::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) +{ + if(todoAutomatic_) //estimate the steps in lambda from observations + { plumed_massert(all_obs_cvs.size()%ncv==0 && index_j obs_cv(all_obs_cvs.size()/ncv); //copy only useful observation (would be better not to copy...) - for(unsigned t=0; t& all_obs_cvs,const uns calculateECVs(&all_obs_cvs[index_j]); } -void ECVlinear::initECVs_restart(const std::vector& lambdas) { +void ECVlinear::initECVs_restart(const std::vector& lambdas) +{ std::size_t pos=lambdas[0].find("_"); plumed_massert(pos==std::string::npos,"this should not happen, only one CV is used in "+getName()); - if(todoAutomatic_) { + if(todoAutomatic_) + { derECVs_=getSteps(derECVs_[0],derECVs_[1],lambdas.size(),"LAMBDA",geom_spacing_,beta0_*lambda0_); todoAutomatic_=false; } diff --git a/src/opes/ECVmultiThermal.cpp b/src/opes/ECVmultiThermal.cpp index b753374c56..d714eba64e 100644 --- a/src/opes/ECVmultiThermal.cpp +++ b/src/opes/ECVmultiThermal.cpp @@ -80,7 +80,8 @@ Notice that \f$p=0.06022140857\f$ corresponds to 1 bar when using the default PL //+ENDPLUMEDOC class ECVmultiThermal : - public ExpansionCVs { + public ExpansionCVs +{ private: bool todoAutomatic_; bool geom_spacing_; @@ -101,7 +102,8 @@ class ECVmultiThermal : PLUMED_REGISTER_ACTION(ECVmultiThermal,"ECV_MULTITHERMAL") -void ECVmultiThermal::registerKeywords(Keywords& keys) { +void ECVmultiThermal::registerKeywords(Keywords& keys) +{ ExpansionCVs::registerKeywords(keys); keys.remove("ARG"); keys.add("compulsory","ARG","the label of the internal energy of the system. If volume is fixed it is calculated by the \\ref ENERGY colvar"); @@ -115,7 +117,8 @@ void ECVmultiThermal::registerKeywords(Keywords& keys) { ECVmultiThermal::ECVmultiThermal(const ActionOptions&ao) : Action(ao) , ExpansionCVs(ao) - , todoAutomatic_(false) { + , todoAutomatic_(false) +{ plumed_massert(getNumberOfArguments()==1,"only the internal energy should be given as ARG"); //set temp0 @@ -136,27 +139,31 @@ ECVmultiThermal::ECVmultiThermal(const ActionOptions&ao) checkRead(); //set the intermediate temperatures - if(temps.size()>0) { + if(temps.size()>0) + { plumed_massert(temp_steps==0,"cannot set both TEMP_STEPS and TEMP_SET_ALL"); plumed_massert(temp_min==-1 && temp_max==-1,"cannot set both TEMP_SET_ALL and TEMP_MIN/MAX"); plumed_massert(temps.size()>=2,"set at least 2 temperatures"); temp_min=temps[0]; temp_max=temps[temps.size()-1]; derECVs_.resize(temps.size()); - for(unsigned k=0; k0) { + if(temp_steps>0) derECVs_=getSteps(derECVs_[0],derECVs_[1],temp_steps,"TEMP",geom_spacing_,1./kbt_); - } else { + else todoAutomatic_=true; - } } const double tol=1e-3; //if temp is taken from MD engine it might be numerically slightly different - if(temp0<(1-tol)*temp_min || temp0>(1+tol)*temp_max) { + if(temp0<(1-tol)*temp_min || temp0>(1+tol)*temp_max) log.printf(" +++ WARNING +++ running at TEMP=%g which is outside the chosen temperature range\n",temp0); - } //print some info log.printf(" targeting a temperature range from TEMP_MIN=%g to TEMP_MAX=%g\n",temp_min,temp_max); - if(!geom_spacing_) { + if(!geom_spacing_) log.printf(" -- NO_GEOM_SPACING: inverse temperatures will be linearly spaced\n"); - } } -void ECVmultiThermal::calculateECVs(const double * ene) { - for(unsigned k=0; k ECVmultiThermal::getLambdas() const { +std::vector ECVmultiThermal::getLambdas() const +{ plumed_massert(!todoAutomatic_,"cannot access lambdas before initializing them"); const double temp0=kbt_/plumed.getAtoms().getKBoltzmann(); std::vector lambdas(derECVs_.size()); - for(unsigned k=0; k ECVmultiThermal::getLambdas() const { return lambdas; } -void ECVmultiThermal::initECVs() { +void ECVmultiThermal::initECVs() +{ plumed_massert(!isReady_,"initialization should not be called twice"); plumed_massert(!todoAutomatic_,"this should not happen"); totNumECVs_=derECVs_.size(); @@ -225,13 +233,14 @@ void ECVmultiThermal::initECVs() { log.printf(" *%4lu temperatures for %s\n",derECVs_.size(),getName().c_str()); } -void ECVmultiThermal::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) { - if(todoAutomatic_) { //estimate the steps in beta from observations +void ECVmultiThermal::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) +{ + if(todoAutomatic_) //estimate the steps in beta from observations + { plumed_massert(all_obs_cvs.size()%ncv==0 && index_j obs_ene(all_obs_cvs.size()/ncv); //copy only useful observation (would be better not to copy...) - for(unsigned t=0; t& all_obs_cvs,con calculateECVs(&all_obs_cvs[index_j]); } -void ECVmultiThermal::initECVs_restart(const std::vector& lambdas) { +void ECVmultiThermal::initECVs_restart(const std::vector& lambdas) +{ std::size_t pos=lambdas[0].find("_"); plumed_massert(pos==std::string::npos,"this should not happen, only one CV is used in "+getName()); - if(todoAutomatic_) { + if(todoAutomatic_) + { derECVs_=getSteps(derECVs_[0],derECVs_[1],lambdas.size(),"TEMP",geom_spacing_,1./kbt_); todoAutomatic_=false; } diff --git a/src/opes/ECVmultiThermalBaric.cpp b/src/opes/ECVmultiThermalBaric.cpp index 367a40fdd9..693d19d9d2 100644 --- a/src/opes/ECVmultiThermalBaric.cpp +++ b/src/opes/ECVmultiThermalBaric.cpp @@ -74,7 +74,8 @@ If you modify them via the \ref UNITS command, then the pressure has to be resca //+ENDPLUMEDOC class ECVmultiThermalBaric : - public ExpansionCVs { + public ExpansionCVs +{ private: bool todoAutomatic_beta_; bool todoAutomatic_pres_; @@ -108,7 +109,8 @@ class ECVmultiThermalBaric : PLUMED_REGISTER_ACTION(ECVmultiThermalBaric,"ECV_MULTITHERMAL_MULTIBARIC") -void ECVmultiThermalBaric::registerKeywords(Keywords& keys) { +void ECVmultiThermalBaric::registerKeywords(Keywords& keys) +{ ExpansionCVs::registerKeywords(keys); keys.remove("ARG"); keys.add("compulsory","ARG","the labels of the potential energy and of the volume of the system. You can calculate them with \\ref ENERGY and \\ref VOLUME respectively"); @@ -136,7 +138,8 @@ ECVmultiThermalBaric::ECVmultiThermalBaric(const ActionOptions&ao) , todoAutomatic_pres_(false) , coeff_(0) , pres_low_(0) - , kB_temp_low_(0) { + , kB_temp_low_(0) +{ plumed_massert(getNumberOfArguments()==2,"ENERGY and VOLUME should be given as ARG"); //set temp0 @@ -171,7 +174,8 @@ ECVmultiThermalBaric::ECVmultiThermalBaric(const ActionOptions&ao) checkRead(); - if(custom_lambdas_.size()>0) { + if(custom_lambdas_.size()>0) + { //make sure no incompatible options are used plumed_massert(temps.size()==0,"cannot set both SET_ALL_TEMP_PRESSURE and TEMP_SET_ALL"); plumed_massert(pres_.size()==0,"cannot set both SET_ALL_TEMP_PRESSURE and PRESSURE_SET_ALL"); @@ -184,8 +188,10 @@ ECVmultiThermalBaric::ECVmultiThermalBaric(const ActionOptions&ao) derECVs_beta_.resize(custom_lambdas_.size()); derECVs_pres_.resize(custom_lambdas_.size()); const std::string error_msg="SET_ALL_TEMP_PRESSURE: two underscore-separated values are expected for each comma-separated point, cannot understand: "; - for(unsigned i=0; i0) { + if(temps.size()>0) + { plumed_massert(temp_steps==0,"cannot set both TEMP_STEPS and TEMP_SET_ALL"); plumed_massert(temp_min==-1 && temp_max==-1,"cannot set both TEMP_SET_ALL and TEMP_MIN/MAX"); plumed_massert(temps.size()>=2,"set at least 2 temperatures"); temp_min=temps[0]; temp_max=temps[temps.size()-1]; derECVs_beta_.resize(temps.size()); - for(unsigned k=0; k0) { + if(temp_steps>0) derECVs_beta_=getSteps(derECVs_beta_[0],derECVs_beta_[1],temp_steps,"TEMP",geom_spacing_,1./kbt_); - } else { + else todoAutomatic_beta_=true; - } } const double tol=1e-3; //if temp is taken from MD engine it might be numerically slightly different - if(temp0<(1-tol)*temp_min || temp0>(1+tol)*temp_max) { + if(temp0<(1-tol)*temp_min || temp0>(1+tol)*temp_max) log.printf(" +++ WARNING +++ running at TEMP=%g which is outside the chosen temperature range\n",temp0); - } //set the intermediate pressures - if(pres_.size()>0) { + if(pres_.size()>0) + { plumed_massert(pres_steps==0,"cannot set both PRESSURE_STEPS and PRESSURE_SET_ALL"); plumed_massert(pres_min==myNone && pres_max==myNone,"cannot set both PRESSURE_SET_ALL and PRESSURE_MIN/MAX"); plumed_massert(pres_.size()>=2,"set at least 2 pressures"); - for(unsigned kk=0; kk=pres_min,"PRESSURE_MAX should be bigger than PRESSURE_MIN"); - if(pres_min==pres_max && pres_steps==0) { + if(pres_min==pres_max && pres_steps==0) pres_steps=1; - } - if(pres_steps>0) { + if(pres_steps>0) pres_=getSteps(pres_min,pres_max,pres_steps,"PRESSURE",false,0); - } else { + else + { pres_.resize(2); pres_[0]=pres_min; pres_[1]=pres_max; todoAutomatic_pres_=true; } } - if(pres0_pres_max) { + if(pres0_pres_max) log.printf(" +++ WARNING +++ running at PRESSURE=%g which is outside the chosen pressure range\n",pres0_); - } //set CUT_CORNER std::string cc_usage("CUT_CORNER=temp_low,pres_low,temp_high,pres_high"); - if(cut_corner.size()==4) { + if(cut_corner.size()==4) + { const double temp_low=cut_corner[0]; const double pres_low=cut_corner[1]; const double temp_high=cut_corner[2]; @@ -299,7 +313,9 @@ ECVmultiThermalBaric::ECVmultiThermalBaric(const ActionOptions&ao) const double small_value=(temp_high-pres_low)/1e4; pres_low_=pres_low-small_value; //make sure pres_max is included plumed_massert(pres_max>=coeff_*(kB*temp_max-kB_temp_low_)+pres_low_,"please chose a pres_high slightly smaller than PRESSURE_MAX in "+cc_usage); - } else { + } + else + { plumed_massert(cut_corner.size()==0,"expected 4 values: "+cc_usage); } } @@ -307,66 +323,67 @@ ECVmultiThermalBaric::ECVmultiThermalBaric(const ActionOptions&ao) //print some info log.printf(" running at TEMP=%g and PRESSURE=%g\n",temp0,pres0_); log.printf(" targeting a temperature range from TEMP_MIN=%g to TEMP_MAX=%g\n",temp_min,temp_max); - if(temp_min==temp_max) { + if(temp_min==temp_max) log.printf(" +++ WARNING +++ if you only need a multibaric simulation it is more efficient to set it up with ECV_LINEAR\n"); - } log.printf(" and a pressure range from PRESSURE_MIN=%g to PRESSURE_MAX=%g\n",pres_min,pres_max); - if(pres_min==pres_max) { + if(pres_min==pres_max) log.printf(" +++ WARNING +++ if you only need a multithermal simulation it is more efficient to set it up with ECV_MULTITHERMAL\n"); - } - if(!geom_spacing_) { + if(!geom_spacing_) log.printf(" -- NO_GEOM_SPACING: inverse temperatures will be linearly spaced\n"); - } - if(coeff_!=0) { + if(coeff_!=0) log.printf(" -- CUT_CORNER: ignoring some high temperature and low pressure values\n"); - } } -void ECVmultiThermalBaric::calculateECVs(const double * ene_vol) { - for(unsigned k=0; k > ECVmultiThermalBaric::getIndex_k() const { +std::vector< std::vector > ECVmultiThermalBaric::getIndex_k() const +{ plumed_massert(isReady_ && totNumECVs_>0,"cannot access getIndex_k() of ECV before initialization"); std::vector< std::vector > index_k; - if(custom_lambdas_.size()>0) { - //same as default getIndex_k() function + if(custom_lambdas_.size()>0) + { //same as default getIndex_k() function plumed_massert(totNumECVs_==custom_lambdas_.size(),"this should not happen"); for(unsigned i=0; i {i,i}); - } else { + } + else + { unsigned i=0; - for(unsigned k=0; k=line_k) { //important to be inclusive, thus >=, not just > + for(unsigned kk=0; kk=line_k) //important to be inclusive, thus >=, not just > + { index_k.emplace_back(std::vector {k,i}); i++; } @@ -377,19 +394,22 @@ std::vector< std::vector > ECVmultiThermalBaric::getIndex_k() const { return index_k; } -std::vector ECVmultiThermalBaric::getLambdas() const { - if(custom_lambdas_.size()>0) { +std::vector ECVmultiThermalBaric::getLambdas() const +{ + if(custom_lambdas_.size()>0) return custom_lambdas_; - } plumed_massert(!todoAutomatic_beta_ && !todoAutomatic_pres_,"cannot access lambdas before initializing them"); std::vector lambdas; const double kB=plumed.getAtoms().getKBoltzmann(); - for(unsigned k=0; k=line_k) { + for(unsigned kk=0; kk=line_k) + { std::ostringstream subs; subs< ECVmultiThermalBaric::getLambdas() const { return lambdas; } -void ECVmultiThermalBaric::initECVs() { +void ECVmultiThermalBaric::initECVs() +{ plumed_massert(!isReady_,"initialization should not be called twice"); plumed_massert(!todoAutomatic_beta_ && !todoAutomatic_pres_,"this should not happen"); totNumECVs_=getLambdas().size(); //slow, but runs only once - if(custom_lambdas_.size()>0) { + if(custom_lambdas_.size()>0) + { log.printf(" *%4lu temperatures for %s\n",derECVs_beta_.size(),getName().c_str()); log.printf(" *%4lu beta-pressures for %s\n",derECVs_pres_.size(),getName().c_str()); log.printf(" -- SET_ALL_TEMP_PRESSURE: total number of temp-pres points is %u\n",totNumECVs_); - } else { + } + else + { plumed_massert(derECVs_beta_.size()*pres_.size()>=totNumECVs_,"this should not happen, is something wrong with CUT_CORNER ?"); derECVs_pres_.resize(totNumECVs_); //pres is mixed with temp (beta*p*V), thus we need to store all possible //initialize the derECVs. //this could be done before and one could avoid storing also beta0, beta_k, etc. but this way the code should be more readable unsigned i=0; - for(unsigned k=0; k=line_k) { + for(unsigned kk=0; kk=line_k) + { derECVs_pres_[i]=(pres_[kk]/kB_temp_k-pres0_/kbt_); i++; } @@ -425,33 +452,33 @@ void ECVmultiThermalBaric::initECVs() { } log.printf(" *%4lu temperatures for %s\n",derECVs_beta_.size(),getName().c_str()); log.printf(" *%4lu pressures for %s\n",pres_.size(),getName().c_str()); - if(coeff_!=0) { + if(coeff_!=0) log.printf(" -- CUT_CORNER: %lu temp-pres points were excluded, thus total is %u\n",derECVs_beta_.size()*pres_.size()-totNumECVs_,totNumECVs_); - } } ECVs_beta_.resize(derECVs_beta_.size()); ECVs_pres_.resize(derECVs_pres_.size()); isReady_=true; } -void ECVmultiThermalBaric::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) { - if(todoAutomatic_beta_) { //estimate the steps in beta from observations +void ECVmultiThermalBaric::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) +{ + if(todoAutomatic_beta_) //estimate the steps in beta from observations + { plumed_massert(all_obs_cvs.size()%ncv==0 && index_j obs_ene(all_obs_cvs.size()/ncv); //copy only useful observations - for(unsigned t=0; t obs_vol(all_obs_cvs.size()/ncv); //copy only useful observations - for(unsigned t=0; t& all_obs_cv calculateECVs(&all_obs_cvs[index_j]); } -void ECVmultiThermalBaric::initECVs_restart(const std::vector& lambdas) { +void ECVmultiThermalBaric::initECVs_restart(const std::vector& lambdas) +{ std::size_t pos=lambdas[0].find("_"); plumed_massert(pos!=std::string::npos,"this should not happen, two CVs are used in "+getName()+", not less"); pos=lambdas[0].find("_",pos+1); plumed_massert(pos==std::string::npos,"this should not happen, two CVs are used in "+getName()+", not more"); - auto getPres=[&lambdas](const unsigned i) { - return lambdas[i].substr(lambdas[i].find("_")+1); - }; - if(todoAutomatic_pres_) { + auto getPres=[&lambdas](const unsigned i) {return lambdas[i].substr(lambdas[i].find("_")+1);}; + if(todoAutomatic_pres_) + { unsigned pres_steps=1; std::string pres_min=getPres(0); - for(unsigned i=1; i::infinity(); @@ -130,33 +132,38 @@ ECVumbrellasFile::ECVumbrellasFile(const ActionOptions&ao): parse("FILE",umbrellasFileName); IFile ifile; ifile.link(*this); - if(ifile.FileExist(umbrellasFileName)) { + if(ifile.FileExist(umbrellasFileName)) + { log.printf(" reading from FILE '%s'\n",umbrellasFileName.c_str()); ifile.open(umbrellasFileName); ifile.allowIgnoredFields(); double time; //first field is ignored - while(ifile.scanField("time",time)) { - for(unsigned j=0; jgetName(),centers_j); centers_[j].push_back(centers_j); //this might be slow } - for(unsigned j=0; jgetName(),sigmas_j); sigmas_[j].push_back(sigmas_j); } ifile.scanField(); } - } else { - plumed_merror("Umbrellas FILE '"+umbrellasFileName+"' not found"); } + else + plumed_merror("Umbrellas FILE '"+umbrellasFileName+"' not found"); checkRead(); //extra consistency checks const unsigned sizeUmbrellas=centers_[0].size(); - for(unsigned j=0; j::infinity()) { + if(barrier_!=std::numeric_limits::infinity()) log.printf(" guess for free energy BARRIER = %g\n",barrier_); - } - if(P0_contribution_==1) { + if(P0_contribution_==1) log.printf(" -- ADD_P0: the target includes also the unbiased probability itself\n"); - } - if(lower_only_) { + if(lower_only_) log.printf(" -- LOWER_HALF_ONLY: the ECVs are set to zero for values of the CV above the respective center\n"); - } } -void ECVumbrellasFile::calculateECVs(const double * cv) { - if(lower_only_) { - for(unsigned j=0; j=0) { + if(dist_jk>=0) + { ECVs_[j][k]=0; derECVs_[j][k]=0; - } else { + } + else + { ECVs_[j][k]=0.5*std::pow(dist_jk,2); derECVs_[j][k]=dist_jk/sigmas_[j][kk]; } } } - } else { - for(unsigned j=0; j ECVumbrellasFile::getLambdas() const { - //notice that sigmas are not considered! +std::vector ECVumbrellasFile::getLambdas() const +{ //notice that sigmas are not considered! std::vector lambdas(totNumECVs_); - if(P0_contribution_==1) { + if(P0_contribution_==1) + { std::ostringstream subs; subs<<"P0"; - for(unsigned j=1; j& all_obs_cvs,const unsigned ncv,const unsigned index_j) { +void ECVumbrellasFile::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) +{ //this non-linear exansion never uses automatic initialization initECVs(); calculateECVs(&all_obs_cvs[index_j]); //use only first obs point for(unsigned j=0; j& lambdas) { +void ECVumbrellasFile::initECVs_restart(const std::vector& lambdas) +{ std::size_t pos=0; - for(unsigned j=0; jlambdas[0].length(),"this should not happen, more '_' than expected in "+getName()); diff --git a/src/opes/ECVumbrellasLine.cpp b/src/opes/ECVumbrellasLine.cpp index 3c420889bc..0ab817422f 100644 --- a/src/opes/ECVumbrellasLine.cpp +++ b/src/opes/ECVumbrellasLine.cpp @@ -69,7 +69,8 @@ opes: OPES_EXPANDED ARG=ecv1.*,ecv2.* PACE=500 //+ENDPLUMEDOC class ECVumbrellasLine : - public ExpansionCVs { + public ExpansionCVs +{ private: double barrier_; unsigned P0_contribution_; @@ -95,7 +96,8 @@ class ECVumbrellasLine : PLUMED_REGISTER_ACTION(ECVumbrellasLine,"ECV_UMBRELLAS_LINE") -void ECVumbrellasLine::registerKeywords(Keywords& keys) { +void ECVumbrellasLine::registerKeywords(Keywords& keys) +{ ExpansionCVs::registerKeywords(keys); keys.use("ARG"); keys.add("compulsory","CV_MIN","the minimum of the CV range to be explored"); @@ -109,15 +111,15 @@ void ECVumbrellasLine::registerKeywords(Keywords& keys) { ECVumbrellasLine::ECVumbrellasLine(const ActionOptions&ao): Action(ao), - ExpansionCVs(ao) { + ExpansionCVs(ao) +{ //set P0_contribution_ bool add_P0=false; parseFlag("ADD_P0",add_P0); - if(add_P0) { + if(add_P0) P0_contribution_=1; - } else { + else P0_contribution_=0; - } //set barrier_ barrier_=std::numeric_limits::infinity(); @@ -135,38 +137,37 @@ ECVumbrellasLine::ECVumbrellasLine(const ActionOptions&ao): double spacing; parse("SPACING",spacing); double length=0; - for(unsigned j=0; j1) - for(unsigned k=0; kisPeriodic()) { + if(getPntrToArgument(j)->isPeriodic()) + { double min,max; std::string min_str,max_str; getPntrToArgument(j)->getDomain(min,max); getPntrToArgument(j)->getDomain(min_str,max_str); plumed_massert(cv_min[j]>=min,"ARG "+std::to_string(j)+": CV_MIN cannot be smaller than the periodic bound "+min_str); plumed_massert(cv_max[j]<=max,"ARG "+std::to_string(j)+": CV_MAX cannot be greater than the periodic bound "+max_str); - if(cv_min[j]==min && cv_max[j]==max) { + if(cv_min[j]==min && cv_max[j]==max) full_period++; - } } } - if(full_period==getNumberOfArguments() && sizeUmbrellas>1) { //first and last are the same point + if(full_period==getNumberOfArguments() && sizeUmbrellas>1) //first and last are the same point + { sizeUmbrellas--; - for(unsigned j=0; j::infinity()) { + if(barrier_!=std::numeric_limits::infinity()) log.printf(" guess for free energy BARRIER = %g\n",barrier_); - } - if(P0_contribution_==1) { + if(P0_contribution_==1) log.printf(" -- ADD_P0: the target includes also the unbiased probability itself\n"); - } - if(lower_only_) { + if(lower_only_) log.printf(" -- LOWER_HALF_ONLY: the ECVs are set to zero for values of the CV above the respective center\n"); - } } -void ECVumbrellasLine::calculateECVs(const double * cv) { - if(lower_only_) { - for(unsigned j=0; j=0) { + if(dist_jk>=0) + { ECVs_[j][k]=0; derECVs_[j][k]=0; - } else { + } + else + { ECVs_[j][k]=0.5*std::pow(dist_jk,2); derECVs_[j][k]=dist_jk/sigma_; } } } - } else { - for(unsigned j=0; j ECVumbrellasLine::getLambdas() const { +std::vector ECVumbrellasLine::getLambdas() const +{ std::vector lambdas(totNumECVs_); - if(P0_contribution_==1) { + if(P0_contribution_==1) + { std::ostringstream subs; subs<<"P0"; - for(unsigned j=1; j& all_obs_cvs,const unsigned ncv,const unsigned index_j) { +void ECVumbrellasLine::initECVs_observ(const std::vector& all_obs_cvs,const unsigned ncv,const unsigned index_j) +{ //this non-linear exansion never uses automatic initialization initECVs(); calculateECVs(&all_obs_cvs[index_j]); //use only first obs point for(unsigned j=0; j& lambdas) { +void ECVumbrellasLine::initECVs_restart(const std::vector& lambdas) +{ std::size_t pos=0; - for(unsigned j=0; jlambdas[0].length(),"this should not happen, more '_' than expected in "+getName()); diff --git a/src/opes/ExpansionCVs.cpp b/src/opes/ExpansionCVs.cpp index e20eb9edc1..321c29ae4d 100644 --- a/src/opes/ExpansionCVs.cpp +++ b/src/opes/ExpansionCVs.cpp @@ -25,7 +25,8 @@ namespace PLMD { namespace opes { -void ExpansionCVs::registerKeywords(Keywords& keys) { +void ExpansionCVs::registerKeywords(Keywords& keys) +{ Action::registerKeywords(keys); ActionWithValue::registerKeywords(keys); ActionWithArguments::registerKeywords(keys); @@ -38,16 +39,17 @@ ExpansionCVs::ExpansionCVs(const ActionOptions&ao) , ActionWithValue(ao) , ActionWithArguments(ao) , isReady_(false) - , totNumECVs_(0) { + , totNumECVs_(0) +{ //set kbt_ const double kB=plumed.getAtoms().getKBoltzmann(); kbt_=plumed.getAtoms().getKbT(); double temp=-1; parse("TEMP",temp); - if(temp>0) { - if(kbt_>0 && std::abs(kbt_-kB*temp)>1e-4) { + if(temp>0) + { + if(kbt_>0 && std::abs(kbt_-kB*temp)>1e-4) log.printf(" +++ WARNING +++ using TEMP=%g while MD engine uses %g\n",temp,kbt_/kB); - } kbt_=kB*temp; } plumed_massert(kbt_>0,"your MD engine does not pass the temperature to plumed, you must specify it using TEMP"); @@ -55,93 +57,104 @@ ExpansionCVs::ExpansionCVs(const ActionOptions&ao) //set components plumed_massert( getNumberOfArguments()!=0, "you must specify the underlying CV"); - for(unsigned j=0; jgetName(); ActionWithValue::addComponentWithDerivatives(name_j); getPntrToComponent(j)->resizeDerivatives(1); - if(getPntrToArgument(j)->isPeriodic()) { //it should not be necessary, but why not + if(getPntrToArgument(j)->isPeriodic()) //it should not be necessary, but why not + { std::string min,max; getPntrToArgument(j)->getDomain(min,max); getPntrToComponent(j)->setDomain(min,max); - } else { - getPntrToComponent(j)->setNotPeriodic(); } + else + getPntrToComponent(j)->setNotPeriodic(); } plumed_massert((int)getNumberOfArguments()==getNumberOfComponents(),"Expansion CVs have same number of arguments and components"); } -void ExpansionCVs::calculate() { +void ExpansionCVs::calculate() +{ std::vector args(getNumberOfArguments()); - for(unsigned j=0; jset(args[j]); //components are equal to arguments getPntrToComponent(j)->addDerivative(0,1.); //the derivative of the identity is 1 } - if(isReady_) { + if(isReady_) calculateECVs(&args[0]); - } } -void ExpansionCVs::apply() { - for(unsigned j=0; j force_j(1); - if(getPntrToComponent(j)->applyForce(force_j)) { //a bias is applied? - getPntrToArgument(j)->addForce(force_j[0]); //just tell it to the CV! - } + if(getPntrToComponent(j)->applyForce(force_j)) //a bias is applied? + getPntrToArgument(j)->addForce(force_j[0]); //just tell it to the CV! } } -std::vector< std::vector > ExpansionCVs::getIndex_k() const { +std::vector< std::vector > ExpansionCVs::getIndex_k() const +{ plumed_massert(isReady_ && totNumECVs_>0,"cannot access getIndex_k() of ECV before initialization"); std::vector< std::vector > index_k(totNumECVs_,std::vector(getNumberOfArguments())); for(unsigned k=0; k ExpansionCVs::getSteps(double lambda_min,double lambda_max,const unsigned lambda_steps,const std::string& msg,const bool geom_spacing, const double shift) const { +std::vector ExpansionCVs::getSteps(double lambda_min,double lambda_max,const unsigned lambda_steps,const std::string& msg,const bool geom_spacing, const double shift) const +{ plumed_massert(!(lambda_min==lambda_max && lambda_steps>1),"cannot have multiple "+msg+"_STEPS if "+msg+"_MIN=="+msg+"_MAX"); std::vector lambda(lambda_steps); - if(lambda_steps==1) { + if(lambda_steps==1) + { lambda[0]=(lambda_min+lambda_max)/2.; log.printf(" +++ WARNING +++ using one single %s as target = %g\n",msg.c_str(),lambda[0]); - } else { - if(geom_spacing) { //geometric spacing - //this way lambda[k]/lambda[k+1] is constant + } + else + { + if(geom_spacing) //geometric spacing + { //this way lambda[k]/lambda[k+1] is constant lambda_min+=shift; lambda_max+=shift; plumed_massert(lambda_min>0,"cannot use GEOM_SPACING when %s_MIN is not greater than zero"); plumed_massert(lambda_max>0,"cannot use GEOM_SPACING when %s_MAX is not greater than zero"); const double log_lambda_min=std::log(lambda_min); const double log_lambda_max=std::log(lambda_max); - for(unsigned k=0; k& obs,const std::string& msg) const { - //for linear expansions only, it uses effective sample size (Neff) to estimate the grid spacing - if(left_side==0 && right_side==0) { +unsigned ExpansionCVs::estimateNumSteps(const double left_side,const double right_side,const std::vector& obs,const std::string& msg) const +{ //for linear expansions only, it uses effective sample size (Neff) to estimate the grid spacing + if(left_side==0 && right_side==0) + { log.printf(" +++ WARNING +++ %s_MIN and %s_MAX are equal to %s, using single step\n",msg.c_str(),msg.c_str(),msg.c_str()); return 1; } - auto get_neff_HWHM=[](const double side,const std::vector& obs) { //HWHM = half width at half maximum. neff is in general not symmetric + auto get_neff_HWHM=[](const double side,const std::vector& obs) //HWHM = half width at half maximum. neff is in general not symmetric + { //func: Neff/N-0.5 is a function between -0.5 and 0.5 - auto func=[](const double delta,const std::vector& obs) { + auto func=[](const double delta,const std::vector& obs) + { double sum_w=0; double sum_w2=0; //we could avoid recomputing safe_shift every time, but here speed is not a concern const double safe_shift=delta<0?*std::max_element(obs.begin(),obs.end()):*std::min_element(obs.begin(),obs.end()); - for(unsigned t=0; t=0) { - return 0.0; //no zero is present! - } - if(b<0) { //left side case + if(func_b>=0) + return 0.0; //no zero is present! + if(b<0) //left side case + { std::swap(a,b); std::swap(func_a,func_b); } double c=a; double func_c=func_a; - while(std::abs(func_c)>tolerance) { - if(func_a*func_c>0) { + while(std::abs(func_c)>tolerance) + { + if(func_a*func_c>0) + { a=c; func_a=func_c; - } else { + } + else + { b=c; func_b=func_c; } @@ -180,33 +197,32 @@ unsigned ExpansionCVs::estimateNumSteps(const double left_side,const double righ //estimation double left_HWHM=0; - if(left_side!=0) { + if(left_side!=0) left_HWHM=get_neff_HWHM(left_side,obs); - } double right_HWHM=0; - if(right_side!=0) { + if(right_side!=0) right_HWHM=get_neff_HWHM(right_side,obs); - } - if(left_HWHM==0) { + if(left_HWHM==0) + { right_HWHM*=2; - if(left_side==0) { + if(left_side==0) log.printf(" --- %s_MIN is equal to %s\n",msg.c_str(),msg.c_str()); - } else { + else log.printf(" +++ WARNING +++ %s_MIN is very close to %s\n",msg.c_str(),msg.c_str()); - } } - if(right_HWHM==0) { + if(right_HWHM==0) + { left_HWHM*=2; - if(right_side==0) { + if(right_side==0) log.printf(" --- %s_MAX is equal to %s\n",msg.c_str(),msg.c_str()); - } else { + else log.printf(" +++ WARNING +++ %s_MAX is very close to %s\n",msg.c_str(),msg.c_str()); - } } const double grid_spacing=left_HWHM+right_HWHM; log.printf(" estimated %s spacing = %g\n",msg.c_str(),grid_spacing); unsigned steps=std::ceil(std::abs(right_side-left_side)/grid_spacing); - if(steps<2 || grid_spacing==0) { + if(steps<2 || grid_spacing==0) + { log.printf(" +++ WARNING +++ %s range is very narrow, using %s_MIN and %s_MAX as only steps\n",msg.c_str(),msg.c_str(),msg.c_str()); steps=2; } diff --git a/src/opes/ExpansionCVs.h b/src/opes/ExpansionCVs.h index 65a9ab6004..3fecf96001 100644 --- a/src/opes/ExpansionCVs.h +++ b/src/opes/ExpansionCVs.h @@ -34,7 +34,8 @@ They take as argument regular CVs, and output them as components without modific class ExpansionCVs: public ActionWithValue, - public ActionWithArguments { + public ActionWithArguments +{ protected: bool isReady_; //true only after initECVs double kbt_; @@ -50,17 +51,10 @@ class ExpansionCVs: void apply() override; void calculate() override; static void registerKeywords(Keywords&); - inline unsigned getNumberOfDerivatives() override { - return 1; - }; + inline unsigned getNumberOfDerivatives() override {return 1;}; - inline double getKbT() const { - return kbt_; - }; - inline unsigned getTotNumECVs() const { - plumed_massert(isReady_,"cannot ask for totNumECVs before ECV isReady"); - return totNumECVs_; - }; + inline double getKbT() const {return kbt_;}; + inline unsigned getTotNumECVs() const {plumed_massert(isReady_,"cannot ask for totNumECVs before ECV isReady"); return totNumECVs_;}; virtual std::vector< std::vector > getIndex_k() const; //might need to override this virtual void calculateECVs(const double *) = 0; diff --git a/src/opes/OPESexpanded.cpp b/src/opes/OPESexpanded.cpp index bcfc60b642..e5ee2cee93 100644 --- a/src/opes/OPESexpanded.cpp +++ b/src/opes/OPESexpanded.cpp @@ -178,7 +178,8 @@ class OPESexpanded : public bias::Bias { PLUMED_REGISTER_ACTION(OPESexpanded,"OPES_EXPANDED") -void OPESexpanded::registerKeywords(Keywords& keys) { +void OPESexpanded::registerKeywords(Keywords& keys) +{ Bias::registerKeywords(keys); keys.remove("ARG"); keys.add("compulsory","ARG","the label of the ECVs that define the expansion. You can use an * to make sure all the output components of the ECVs are used, as in the examples above"); @@ -212,7 +213,8 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) , ncv_(getNumberOfArguments()) , deltaF_size_(0) , rct_(0) - , work_(0) { + , work_(0) +{ //set pace parse("PACE",stride_); parse("OBSERVATION_STEPS",obs_steps_); @@ -234,15 +236,12 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) parse("STATE_WSTRIDE",wStateStride_); storeOldStates_=false; parseFlag("STORE_STATES",storeOldStates_); - if(wStateStride_!=0 || storeOldStates_) { + if(wStateStride_!=0 || storeOldStates_) plumed_massert(stateFileName.length()>0,"filename for storing simulation status not specified, use STATE_WFILE"); - } - if(wStateStride_>0) { + if(wStateStride_>0) plumed_massert(wStateStride_>=(int)stride_,"STATE_WSTRIDE is in units of MD steps, thus should be a multiple of PACE"); - } - if(stateFileName.length()>0 && wStateStride_==0) { - wStateStride_=-1; //will print only on CPT events (checkpoints set by some MD engines, like gromacs) - } + if(stateFileName.length()>0 && wStateStride_==0) + wStateStride_=-1;//will print only on CPT events (checkpoints set by some MD engines, like gromacs) //work flag parseFlag("CALC_WORK",calc_work_); @@ -250,18 +249,22 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) //multiple walkers //external MW for cp2k not supported, but anyway cp2k cannot put bias on energy! bool walkers_mpi=false; parseFlag("WALKERS_MPI",walkers_mpi); - if(walkers_mpi) { + if(walkers_mpi) + { //If this Action is not compiled with MPI the user is informed and we exit gracefully plumed_massert(Communicator::plumedHasMPI(),"Invalid walkers configuration: WALKERS_MPI flag requires MPI compilation"); plumed_massert(Communicator::initialized(),"Invalid walkers configuration: WALKERS_MPI needs the communicator correctly initialized."); - if(comm.Get_rank()==0) { //multi_sim_comm works on first rank only + if(comm.Get_rank()==0) //multi_sim_comm works on first rank only + { NumWalkers_=multi_sim_comm.Get_size(); walker_rank_=multi_sim_comm.Get_rank(); } comm.Bcast(NumWalkers_,0); //if each walker has more than one processor update them all comm.Bcast(walker_rank_,0); - } else { + } + else + { NumWalkers_=1; walker_rank_=0; } @@ -272,7 +275,8 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) rank_=comm.Get_rank(); bool serial=false; parseFlag("SERIAL",serial); - if(serial) { + if(serial) + { NumOMP_=1; NumParallel_=1; rank_=0; @@ -284,33 +288,38 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) init_pntrToECVsClass(); //set kbt_ kbt_=pntrToECVsClass_[0]->getKbT(); - for(unsigned l=0; lgetKbT())<1e-4,"must set same TEMP for each ECV"); - } //restart if needed - if(getRestart()) { + if(getRestart()) + { bool stateRestart=true; - if(restartFileName.length()==0) { + if(restartFileName.length()==0) + { stateRestart=false; restartFileName=deltaFsFileName; } IFile ifile; ifile.link(*this); - if(ifile.FileExist(restartFileName)) { + if(ifile.FileExist(restartFileName)) + { log.printf(" RESTART - make sure all ECVs used are the same as before\n"); log.printf(" restarting from: %s\n",restartFileName.c_str()); ifile.open(restartFileName); - if(stateRestart) { //get all info + if(stateRestart) //get all info + { log.printf(" it should be a STATE file (not a DELTAFS file)\n"); double time; //not used ifile.scanField("time",time); ifile.scanField("counter",counter_); ifile.scanField("rct",rct_); std::string tmp_lambda; - while(ifile.scanField(getPntrToArgument(0)->getName(),tmp_lambda)) { + while(ifile.scanField(getPntrToArgument(0)->getName(),tmp_lambda)) + { std::string subs="DeltaF_"+tmp_lambda; - for(unsigned jj=1; jjgetName(),tmp_lambda); subs+="_"+tmp_lambda; @@ -323,10 +332,11 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) tmp_lambda.clear(); } log.printf(" successfully read %lu DeltaF values\n",deltaF_name_.size()); - if(NumParallel_>1) { + if(NumParallel_>1) all_deltaF_=deltaF_; - } - } else { //get just deltaFs names + } + else //get just deltaFs names + { ifile.scanFieldList(deltaF_name_); plumed_massert(deltaF_name_.size()>=4,"RESTART - fewer than expected FIELDS found in '"+deltaFsFileName+"' file"); plumed_massert(deltaF_name_[deltaF_name_.size()-1]=="print_stride","RESTART - coult not find expected FIELDS in '"+deltaFsFileName+"' file"); @@ -335,39 +345,38 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) deltaF_name_.pop_back(); deltaF_name_.erase(deltaF_name_.begin(),deltaF_name_.begin()+2); std::size_t pos=5; //each name starts with "DeltaF" - for(unsigned j=0; jdeltaF_name_[0].length(),"RESTART - more '_' than expected in DeltaF fields: did you add new CV?"); } //get lambdas, init ECVs and Link them deltaF_size_=deltaF_name_.size(); - auto getLambdaName=[](const std::string& name,const unsigned start,const unsigned dim) { + auto getLambdaName=[](const std::string& name,const unsigned start,const unsigned dim) + { std::size_t pos_start=5; //each name starts with "DeltaF" - for(unsigned j=0; j<=start; j++) { + for(unsigned j=0; j<=start; j++) pos_start=name.find("_",pos_start+1); - } std::size_t pos_end=pos_start; - for(unsigned j=0; j=0; l--) { + for(int l=pntrToECVsClass_.size()-1; l>=0; l--) + { const unsigned dim_l=pntrToECVsClass_[l]->getNumberOfArguments(); index_j-=dim_l; std::vector lambdas_l(1); lambdas_l[0]=getLambdaName(deltaF_name_[0],index_j,dim_l); - for(unsigned i=sizeSkip; iinitECVs_restart(lambdas_l); @@ -377,38 +386,42 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) init_linkECVs(); //link ECVs and initializes index_k_ log.printf(" ->%4u DeltaFs in total\n",deltaF_size_); obs_steps_=0; //avoid initializing again - if(stateRestart) { - if(NumParallel_>1) { + if(stateRestart) + { + if(NumParallel_>1) + { const unsigned start=(deltaF_size_/NumParallel_)*rank_+std::min(rank_,deltaF_size_%NumParallel_); unsigned iter=0; - for(unsigned i=start; i0) { + if(count_lines>0) counter_+=restart_stride; - } count_lines++; } counter_*=NumWalkers_; @@ -416,65 +429,63 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) } ifile.reset(false); ifile.close(); - } else { //same behaviour as METAD - plumed_merror("RESTART requested, but file '"+restartFileName+"' was not found!\n Set RESTART=NO or provide a restart file"); } - if(NumWalkers_>1) { //make sure that all walkers are doing the same thing + else //same behaviour as METAD + plumed_merror("RESTART requested, but file '"+restartFileName+"' was not found!\n Set RESTART=NO or provide a restart file"); + if(NumWalkers_>1) //make sure that all walkers are doing the same thing + { std::vector all_counter(NumWalkers_); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) multi_sim_comm.Allgather(counter_,all_counter); - } comm.Bcast(all_counter,0); bool same_number_of_steps=true; for(unsigned w=1; w0) { - log.printf(" +++ WARNING +++ the provided STATE_RFILE will be ignored, since RESTART was not requested\n"); } + else if(restartFileName.length()>0) + log.printf(" +++ WARNING +++ the provided STATE_RFILE will be ignored, since RESTART was not requested\n"); //sync all walkers to avoid opening files before reding is over (see also METAD) comm.Barrier(); - if(comm.Get_rank()==0 && walkers_mpi) { + if(comm.Get_rank()==0 && walkers_mpi) multi_sim_comm.Barrier(); - } //setup DeltaFs file deltaFsOfile_.link(*this); - if(NumWalkers_>1) { - if(walker_rank_>0) { - deltaFsFileName="/dev/null"; //only first walker writes on file - } + if(NumWalkers_>1) + { + if(walker_rank_>0) + deltaFsFileName="/dev/null"; //only first walker writes on file deltaFsOfile_.enforceSuffix(""); } deltaFsOfile_.open(deltaFsFileName); - if(fmt.length()>0) { + if(fmt.length()>0) deltaFsOfile_.fmtField(" "+fmt); - } deltaFsOfile_.setHeavyFlush(); //do I need it? deltaFsOfile_.addConstantField("print_stride"); deltaFsOfile_.printField("print_stride",print_stride_); //open file for storing state - if(wStateStride_!=0) { + if(wStateStride_!=0) + { stateOfile_.link(*this); - if(NumWalkers_>1) { - if(walker_rank_>0) { - stateFileName="/dev/null"; //only first walker writes on file - } + if(NumWalkers_>1) + { + if(walker_rank_>0) + stateFileName="/dev/null"; //only first walker writes on file stateOfile_.enforceSuffix(""); } stateOfile_.open(stateFileName); - if(fmt.length()>0) { + if(fmt.length()>0) stateOfile_.fmtField(" "+fmt); - } } //add output components - if(calc_work_) { + if(calc_work_) + { addComponent("work"); componentIsNotPeriodic("work"); } @@ -482,96 +493,90 @@ OPESexpanded::OPESexpanded(const ActionOptions&ao) //printing some info log.printf(" updating the bias with PACE = %u\n",stride_); log.printf(" initial unbiased OBSERVATION_STEPS = %u (in units of PACE)\n",obs_steps_); - if(wStateStride_>0) { + if(wStateStride_>0) log.printf(" state checkpoints are written on file %s every %d MD steps\n",stateFileName.c_str(),wStateStride_); - } - if(wStateStride_==-1) { + if(wStateStride_==-1) log.printf(" state checkpoints are written on file '%s' only on CPT events (or never if MD code does define them!)\n",stateFileName.c_str()); - } - if(walkers_mpi) { + if(walkers_mpi) log.printf(" -- WALKERS_MPI: if multiple replicas are present, they will share the same bias via MPI\n"); - } - if(NumWalkers_>1) { + if(NumWalkers_>1) + { log.printf(" using multiple walkers\n"); log.printf(" number of walkers: %u\n",NumWalkers_); log.printf(" walker rank: %u\n",walker_rank_); } int mw_warning=0; - if(!walkers_mpi && comm.Get_rank()==0 && multi_sim_comm.Get_size()>(int)NumWalkers_) { + if(!walkers_mpi && comm.Get_rank()==0 && multi_sim_comm.Get_size()>(int)NumWalkers_) mw_warning=1; - } comm.Bcast(mw_warning,0); - if(mw_warning) { //log.printf messes up with comm, so never use it without Bcast! + if(mw_warning) //log.printf messes up with comm, so never use it without Bcast! log.printf(" +++ WARNING +++ multiple replicas will NOT communicate unless the flag WALKERS_MPI is used\n"); - } - if(NumParallel_>1) { + if(NumParallel_>1) log.printf(" using multiple MPI processes per simulation: %u\n",NumParallel_); - } - if(NumOMP_>1) { + if(NumOMP_>1) log.printf(" using multiple OpenMP threads per simulation: %u\n",NumOMP_); - } - if(serial) { + if(serial) log.printf(" -- SERIAL: no loop parallelization, despite %d MPI processes and %u OpenMP threads available\n",comm.Get_size(),OpenMP::getNumThreads()); - } log.printf(" Bibliography: "); log<::max(); #pragma omp parallel num_threads(NumOMP_) { #pragma omp for reduction(max:diffMax) - for(unsigned i=0; idiffMax) { + if(diff_[i]>diffMax) diffMax=diff_[i]; - } } } - if(NumParallel_>1) { + if(NumParallel_>1) comm.Max(diffMax); - } //calculate the bias and the forces double sum=0; std::vector der_sum_cv(ncv_,0); - if(NumOMP_==1) { - for(unsigned i=0; i omp_der_sum_cv(ncv_,0); #pragma omp for reduction(+:sum) nowait - for(unsigned i=0; i1) { - //each MPI process has part of the full deltaF_ vector, so must Sum + if(NumParallel_>1) + { //each MPI process has part of the full deltaF_ vector, so must Sum comm.Sum(sum); comm.Sum(der_sum_cv); } @@ -579,25 +584,27 @@ void OPESexpanded::calculate() { //set bias and forces const double bias=-kbt_*(diffMax+std::log(sum/deltaF_size_)); setBias(bias); - for(unsigned j=0; j0) { - for(unsigned j=0; j0) + { + for(unsigned j=0; j cvs(ncv_); - for(unsigned j=0; j all_bias(NumWalkers_); std::vector all_cvs(NumWalkers_*ncv_); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) + { multi_sim_comm.Allgather(current_bias,all_bias); multi_sim_comm.Allgather(cvs,all_cvs); } comm.Bcast(all_bias,0); comm.Bcast(all_cvs,0); - for(unsigned w=0; wcalculateECVs(&all_cvs[index_wj]); index_wj+=pntrToECVsClass_[k]->getNumberOfArguments(); } @@ -636,40 +646,36 @@ void OPESexpanded::update() { } //write DeltaFs to file - if((counter_/NumWalkers_-1)%print_stride_==0) { + if((counter_/NumWalkers_-1)%print_stride_==0) printDeltaF(); - } //calculate work if requested - if(calc_work_) { - //some copy and paste from calculate() + if(calc_work_) + { //some copy and paste from calculate() //get diffMax, to avoid over/underflow double diffMax=-std::numeric_limits::max(); #pragma omp parallel num_threads(NumOMP_) { #pragma omp for reduction(max:diffMax) - for(unsigned i=0; idiffMax) { + if(diff_[i]>diffMax) diffMax=diff_[i]; - } } } - if(NumParallel_>1) { + if(NumParallel_>1) comm.Max(diffMax); - } //calculate the bias double sum=0; #pragma omp parallel num_threads(NumOMP_) { #pragma omp for reduction(+:sum) nowait - for(unsigned i=0; i1) { + if(NumParallel_>1) comm.Sum(sum); - } const double new_bias=-kbt_*(diffMax+std::log(sum/deltaF_size_)); //accumulate work work_+=new_bias-current_bias; @@ -678,26 +684,30 @@ void OPESexpanded::update() { } //dump state if requested - if( (wStateStride_>0 && getStep()%wStateStride_==0) || (wStateStride_==-1 && getCPT()) ) { + if( (wStateStride_>0 && getStep()%wStateStride_==0) || (wStateStride_==-1 && getCPT()) ) dumpStateToFile(); - } } -void OPESexpanded::init_pntrToECVsClass() { +void OPESexpanded::init_pntrToECVsClass() +{ std::vector all_pntrToECVsClass=plumed.getActionSet().select(); plumed_massert(all_pntrToECVsClass.size()>0,"no Expansion CVs found"); - for(unsigned j=0; jgetName().find("."); plumed_massert(dot_posgetName().size(),error_notECV+", thus contain a dot in the name"); unsigned foundECV_l=all_pntrToECVsClass.size(); - for(unsigned l=0; lgetName().substr(0,dot_pos)==all_pntrToECVsClass[l]->getLabel()) { + for(unsigned l=0; lgetName().substr(0,dot_pos)==all_pntrToECVsClass[l]->getLabel()) + { foundECV_l=l; pntrToECVsClass_.push_back(all_pntrToECVsClass[l]); std::string missing_arg="some ECV component is missing from ARG"; plumed_massert(j+all_pntrToECVsClass[l]->getNumberOfArguments()<=getNumberOfArguments(),missing_arg); - for(unsigned h=0; hgetNumberOfArguments(); h++) { + for(unsigned h=0; hgetNumberOfArguments(); h++) + { std::string argName=getPntrToArgument(j+h)->getName(); std::string expectedECVname=all_pntrToECVsClass[l]->getComponentsVector()[h]; plumed_massert(argName==expectedECVname,missing_arg+", or is in wrong order: given ARG="+argName+" expected ARG="+expectedECVname); @@ -709,12 +719,12 @@ void OPESexpanded::init_pntrToECVsClass() { plumed_massert(foundECV_lgetLabel()!=pntrToECVsClass_[ll]->getLabel(),"cannot use same ECV twice"); - } } -void OPESexpanded::init_linkECVs() { +void OPESexpanded::init_linkECVs() +{ //TODO It should be possible to make all of this more straightforward (and probably also faster): // - get rid of index_k_, making it trivial for each ECV // - store the ECVs_ and derECVs_ vectors here as a contiguous vector, and use pointers in the ECV classes @@ -722,19 +732,20 @@ void OPESexpanded::init_linkECVs() { // - ECVmultiThermalBaric has a nontrivial index_k_ to avoid duplicates. use duplicates instead // - can the ECVs be MPI parallel or it's too complicated? plumed_massert(deltaF_size_>0,"must set deltaF_size_ before calling init_linkECVs()"); - if(NumParallel_==1) { + if(NumParallel_==1) deltaF_.resize(deltaF_size_); - } else { + else + { const unsigned extra=(rank_<(deltaF_size_%NumParallel_)?1:0); deltaF_.resize(deltaF_size_/NumParallel_+extra); //these are used when printing deltaF_ to file all_deltaF_.resize(deltaF_size_); all_size_.resize(NumParallel_,deltaF_size_/NumParallel_); disp_.resize(NumParallel_); - for(unsigned r=0; r(ncv_)); unsigned index_j=0; unsigned sizeSkip=deltaF_size_; - for(unsigned l=0; l > l_index_k(pntrToECVsClass_[l]->getIndex_k()); plumed_massert(deltaF_size_%l_index_k.size()==0,"buggy ECV: mismatch between getTotNumECVs() and getIndex_k().size()"); plumed_massert(l_index_k[0].size()==pntrToECVsClass_[l]->getNumberOfArguments(),"buggy ECV: mismatch between number of ARG and underlying CVs"); sizeSkip/=l_index_k.size(); - for(unsigned h=0; hgetNumberOfArguments(); h++) { + for(unsigned h=0; hgetNumberOfArguments(); h++) + { ECVs_[index_j+h]=pntrToECVsClass_[l]->getPntrToECVs(h); derECVs_[index_j+h]=pntrToECVsClass_[l]->getPntrToDerECVs(h); - if(NumParallel_==1) { - for(unsigned i=0; igetNumberOfArguments(); @@ -769,13 +783,14 @@ void OPESexpanded::init_linkECVs() { plumed_massert(sizeSkip==1,"this should not happen!"); } -void OPESexpanded::init_fromObs() { //This could probably be faster and/or require less memory... +void OPESexpanded::init_fromObs() //This could probably be faster and/or require less memory... +{ //in case of multiple walkers gather all the statistics - if(NumWalkers_>1) { + if(NumWalkers_>1) + { std::vector all_obs_cv(ncv_*obs_steps_*NumWalkers_); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) multi_sim_comm.Allgather(obs_cvs_,all_obs_cv); - } comm.Bcast(all_obs_cv,0); obs_cvs_=all_obs_cv; //could this lead to memory issues? obs_steps_*=NumWalkers_; @@ -784,7 +799,8 @@ void OPESexpanded::init_fromObs() { //This could probably be faster and/or requi //initialize ECVs from observations unsigned index_j=0; deltaF_size_=1; - for(unsigned l=0; linitECVs_observ(obs_cvs_,ncv_,index_j); deltaF_size_*=pntrToECVsClass_[l]->getTotNumECVs(); //ECVs from different exansions will be combined index_j+=pntrToECVsClass_[l]->getNumberOfArguments(); @@ -797,22 +813,23 @@ void OPESexpanded::init_fromObs() { //This could probably be faster and/or requi //for the first point, t=0, the ECVs are calculated by initECVs_observ, setting also any initial guess index_j=0; for(unsigned i=0; icalculateECVs(&obs_cvs_[t*ncv_+index_j]); index_j+=pntrToECVsClass_[l]->getNumberOfArguments(); } - for(unsigned i=0; i0) { //save exp from overflow + if(diff_i>0) //save exp from overflow deltaF_[i]-=kbt_*(diff_i+std::log1p(std::exp(-diff_i))+std::log1p(-1./(1.+t))); - } else { + else deltaF_[i]-=kbt_*(std::log1p(std::exp(diff_i))+std::log1p(-1./(1.+t))); - } } } obs_cvs_.clear(); @@ -820,13 +837,13 @@ void OPESexpanded::init_fromObs() { //This could probably be faster and/or requi //set deltaF_name_ deltaF_name_.resize(deltaF_size_,"DeltaF"); unsigned sizeSkip=deltaF_size_; - for(unsigned l=0; l lambdas_l=pntrToECVsClass_[l]->getLambdas(); plumed_massert(lambdas_l.size()==pntrToECVsClass_[l]->getTotNumECVs(),"buggy ECV: mismatch between getTotNumECVs() and getLambdas().size()"); sizeSkip/=lambdas_l.size(); - for(unsigned i=0; i1) { - comm.Allgatherv(deltaF_,all_deltaF_,&all_size_[0],&disp_[0]); //can we avoid using this big vector? - } - for(unsigned i=0; i1) + comm.Allgatherv(deltaF_,all_deltaF_,&all_size_[0],&disp_[0]); //can we avoid using this big vector? + for(unsigned i=0; i6,"not enought _ in deltaF_name_"+std::to_string(i-1)+" string?"); const std::size_t pos_end=deltaF_name_[i].find("_",pos_start); stateOfile_.printField(getPntrToArgument(j)->getName()," "+deltaF_name_[i].substr(pos_start,pos_end-pos_start)); pos_start=pos_end+1; } - if(NumParallel_==1) { + if(NumParallel_==1) stateOfile_.printField("DeltaF",deltaF_[i]); - } else { + else stateOfile_.printField("DeltaF",all_deltaF_[i]); - } stateOfile_.printField(); } //make sure file is written even if small - if(!storeOldStates_) { + if(!storeOldStates_) stateOfile_.flush(); - } } -void OPESexpanded::updateDeltaF(double bias) { +void OPESexpanded::updateDeltaF(double bias) +{ plumed_dbg_massert(counter_>0,"deltaF_ must be initialized"); counter_++; const double arg=(bias-rct_)/kbt_-std::log(counter_-1.); double increment; - if(arg>0) { //save exp from overflow + if(arg>0) //save exp from overflow increment=kbt_*(arg+std::log1p(std::exp(-arg))); - } else { + else increment=kbt_*(std::log1p(std::exp(arg))); - } #pragma omp parallel num_threads(NumOMP_) { #pragma omp for - for(unsigned i=0; i0) { //save exp from overflow + if(diff_i>0) //save exp from overflow deltaF_[i]+=increment-kbt_*(diff_i+std::log1p(std::exp(-diff_i))); - } else { + else deltaF_[i]+=increment-kbt_*std::log1p(std::exp(diff_i)); - } } } rct_+=increment+kbt_*std::log1p(-1./counter_); } -double OPESexpanded::getExpansion(unsigned i) const { +double OPESexpanded::getExpansion(unsigned i) const +{ double expansion=0; - for(unsigned j=0; j center; std::vector sigma; @@ -250,9 +251,7 @@ class OPESmetad : public bias::Bias { static void registerKeywords(Keywords& keys); }; -struct convergence { - static const bool explore=false; -}; +struct convergence { static const bool explore=false; }; typedef OPESmetad OPESmetad_c; PLUMED_REGISTER_ACTION(OPESmetad_c,"OPES_METAD") @@ -296,22 +295,20 @@ PRINT STRIDE=100 FILE=COLVAR ARG=cv,opes.* */ //+ENDPLUMEDOC -struct exploration { - static const bool explore=true; -}; +struct exploration { static const bool explore=true; }; typedef OPESmetad OPESmetad_e; PLUMED_REGISTER_ACTION(OPESmetad_e,"OPES_METAD_EXPLORE") template -void OPESmetad::registerKeywords(Keywords& keys) { +void OPESmetad::registerKeywords(Keywords& keys) +{ Bias::registerKeywords(keys); keys.use("ARG"); keys.add("compulsory","TEMP","-1","temperature. If not set, it is taken from MD engine, but not all MD codes provide it"); keys.add("compulsory","PACE","the frequency for kernel deposition"); std::string info_sigma("the initial widths of the kernels"); - if(mode::explore) { + if(mode::explore) info_sigma+=", divided by the square root of gamma"; - } info_sigma+=". If not set, an adaptive sigma will be used with the given ADAPTIVE_SIGMA_STRIDE"; keys.add("compulsory","SIGMA","ADAPTIVE",info_sigma); keys.add("compulsory","BARRIER","the free energy barrier to be overcome. It is used to set BIASFACTOR, EPSILON, and KERNEL_CUTOFF to reasonable values"); @@ -320,11 +317,10 @@ void OPESmetad::registerKeywords(Keywords& keys) { keys.add("optional","ADAPTIVE_SIGMA_STRIDE","number of steps for measuring adaptive sigma. Default is 10xPACE"); keys.add("optional","SIGMA_MIN","never reduce SIGMA below this value"); std::string info_biasfactor("the gamma bias factor used for the well-tempered target distribution. "); - if(mode::explore) { + if(mode::explore) info_biasfactor+="Cannot be 'inf'"; - } else { + else info_biasfactor+="Set to 'inf' for uniform flat target"; - } keys.add("optional","BIASFACTOR",info_biasfactor); keys.add("optional","EPSILON","the value of the regularization constant for the probability"); keys.add("optional","KERNEL_CUTOFF","truncate kernels at this distance, in units of sigma"); @@ -343,9 +339,8 @@ void OPESmetad::registerKeywords(Keywords& keys) { keys.addFlag("STORE_STATES",false,"append to STATE_WFILE instead of ovewriting it each time"); //miscellaneous keys.add("optional","EXCLUDED_REGION","kernels are not deposited when the action provided here has a nonzero value, see example above"); - if(!mode::explore) { + if(!mode::explore) keys.add("optional","EXTRA_BIAS","consider also these other bias potentials for the internal reweighting. This can be used e.g. for sampling a custom target distribution (see example above)"); - } keys.addFlag("CALC_WORK",false,"calculate the total accumulated work done by the bias since last restart"); keys.addFlag("WALKERS_MPI",false,"switch on MPI version of multiple walkers"); keys.addFlag("SERIAL",false,"perform calculations in serial"); @@ -371,7 +366,8 @@ OPESmetad::OPESmetad(const ActionOptions& ao) , ncv_(getNumberOfArguments()) , Zed_(1) , work_(0) - , excluded_region_(NULL) { + , excluded_region_(NULL) +{ std::string error_in_input1("Error in input in action "+getName()+" with label "+getLabel()+": the keyword "); std::string error_in_input2(" could not be read correctly"); @@ -380,10 +376,10 @@ OPESmetad::OPESmetad(const ActionOptions& ao) kbt_=plumed.getAtoms().getKbT(); double temp=-1; parse("TEMP",temp); - if(temp>0) { - if(kbt_>0 && std::abs(kbt_-kB*temp)>1e-4) { + if(temp>0) + { + if(kbt_>0 && std::abs(kbt_-kB*temp)>1e-4) log.printf(" +++ WARNING +++ using TEMP=%g while MD engine uses %g\n",temp,kbt_/kB); - } kbt_=kB*temp; } plumed_massert(kbt_>0,"your MD engine does not pass the temperature to plumed, you must specify it using TEMP"); @@ -398,17 +394,20 @@ OPESmetad::OPESmetad(const ActionOptions& ao) biasfactor_=barrier/kbt_; std::string biasfactor_str; parse("BIASFACTOR",biasfactor_str); - if(biasfactor_str=="inf" || biasfactor_str=="INF") { + if(biasfactor_str=="inf" || biasfactor_str=="INF") + { biasfactor_=std::numeric_limits::infinity(); bias_prefactor_=1; - } else { - if(biasfactor_str.length()>0) { + } + else + { + if(biasfactor_str.length()>0) plumed_massert(Tools::convertNoexcept(biasfactor_str,biasfactor_),error_in_input1+"BIASFACTOR"+error_in_input2); - } plumed_massert(biasfactor_>1,"BIASFACTOR must be greater than one (use 'inf' for uniform target)"); bias_prefactor_=1-1./biasfactor_; } - if(mode::explore) { + if(mode::explore) + { plumed_massert(!std::isinf(biasfactor_),"BIASFACTOR=inf is not compatible with EXPLORE mode"); bias_prefactor_=biasfactor_-1; } @@ -420,33 +419,35 @@ OPESmetad::OPESmetad(const ActionOptions& ao) parseVector("SIGMA",sigma_str); sigma0_.resize(ncv_); double dummy; - if(sigma_str.size()==1 && !Tools::convertNoexcept(sigma_str[0],dummy)) { + if(sigma_str.size()==1 && !Tools::convertNoexcept(sigma_str[0],dummy)) + { plumed_massert(sigma_str[0]=="ADAPTIVE" || sigma_str[0]=="adaptive",error_in_input1+"SIGMA"+error_in_input2); plumed_massert(!std::isinf(biasfactor_),"cannot use BIASFACTOR=inf with adaptive SIGMA"); adaptive_counter_=0; - if(adaptive_sigma_stride_==0) { - adaptive_sigma_stride_=10*stride_; //NB: this is arbitrary, chosen from few tests - } + if(adaptive_sigma_stride_==0) + adaptive_sigma_stride_=10*stride_; //NB: this is arbitrary, chosen from few tests av_cv_.resize(ncv_,0); av_M2_.resize(ncv_,0); plumed_massert(adaptive_sigma_stride_>=stride_,"better to chose ADAPTIVE_SIGMA_STRIDE > PACE"); adaptive_sigma_=true; - } else { + } + else + { plumed_massert(sigma_str.size()==ncv_,"number of SIGMA parameters does not match number of arguments"); plumed_massert(adaptive_sigma_stride_==0,"if SIGMA is not ADAPTIVE you cannot set an ADAPTIVE_SIGMA_STRIDE"); - for(unsigned i=0; i0 && !adaptive_sigma_) { - for(unsigned i=0; i0 && !adaptive_sigma_) + { + for(unsigned i=0; i::OPESmetad(const ActionOptions& ao) sum_weights2_=sum_weights_*sum_weights_; double cutoff=sqrt(2.*barrier/bias_prefactor_/kbt_); - if(mode::explore) { - cutoff=sqrt(2.*barrier/kbt_); //otherwise it is too small - } + if(mode::explore) + cutoff=sqrt(2.*barrier/kbt_); //otherwise it is too small parse("KERNEL_CUTOFF",cutoff); plumed_massert(cutoff>0,"you must choose a value for KERNEL_CUTOFF greater than zero"); cutoff2_=cutoff*cutoff; @@ -467,24 +467,25 @@ OPESmetad::OPESmetad(const ActionOptions& ao) threshold2_=1; parse("COMPRESSION_THRESHOLD",threshold2_); threshold2_*=threshold2_; - if(threshold2_!=0) { + if(threshold2_!=0) plumed_massert(threshold2_>0 && threshold2_ nlist_param; parseVector("NLIST_PARAMETERS",nlist_param); - if(nlist_param.size()==0) { + if(nlist_param.size()==0) + { nlist_param_[0]=3.0;//*cutoff2_ -> max distance of neighbors nlist_param_[1]=0.5;//*nlist_dev2_[i] -> condition for rebuilding - } else { + } + else + { nlist_=true; plumed_massert(nlist_param.size()==2,"two cutoff parameters are needed for the neighbor list"); plumed_massert(nlist_param[0]>1.0,"the first of NLIST_PARAMETERS must be greater than 1. The smaller the first, the smaller should be the second as well"); @@ -502,8 +503,8 @@ OPESmetad::OPESmetad(const ActionOptions& ao) //optional stuff no_Zed_=false; parseFlag("NO_ZED",no_Zed_); - if(no_Zed_) { - //this makes it more gentle in the initial phase + if(no_Zed_) + { //this makes it more gentle in the initial phase sum_weights_=1; sum_weights2_=1; } @@ -517,16 +518,17 @@ OPESmetad::OPESmetad(const ActionOptions& ao) //options involving extra arguments std::vector args; parseArgumentList("EXCLUDED_REGION",args); - if(args.size()>0) { + if(args.size()>0) + { plumed_massert(args.size()==1,"only one characteristic function should define the region to be excluded"); requestExtraDependencies(args); excluded_region_=args[0]; } - if(!mode::explore) { + if(!mode::explore) + { parseArgumentList("EXTRA_BIAS",extra_biases_); - if(extra_biases_.size()>0) { + if(extra_biases_.size()>0) requestExtraDependencies(extra_biases_); - } } //kernels file @@ -544,31 +546,32 @@ OPESmetad::OPESmetad(const ActionOptions& ao) parse("STATE_WSTRIDE",wStateStride_); storeOldStates_=false; parseFlag("STORE_STATES",storeOldStates_); - if(wStateStride_!=0 || storeOldStates_) { + if(wStateStride_!=0 || storeOldStates_) plumed_massert(stateFileName.length()>0,"filename for storing simulation status not specified, use STATE_WFILE"); - } - if(wStateStride_>0) { + if(wStateStride_>0) plumed_massert(wStateStride_>=(int)stride_,"STATE_WSTRIDE is in units of MD steps, thus it is suggested to use a multiple of PACE"); - } - if(stateFileName.length()>0 && wStateStride_==0) { - wStateStride_=-1; //will print only on CPT events (checkpoints set by some MD engines, like gromacs) - } + if(stateFileName.length()>0 && wStateStride_==0) + wStateStride_=-1;//will print only on CPT events (checkpoints set by some MD engines, like gromacs) //multiple walkers //TODO implement also external mw for cp2k bool walkers_mpi=false; parseFlag("WALKERS_MPI",walkers_mpi); - if(walkers_mpi) { + if(walkers_mpi) + { //If this Action is not compiled with MPI the user is informed and we exit gracefully plumed_massert(Communicator::plumedHasMPI(),"Invalid walkers configuration: WALKERS_MPI flag requires MPI compilation"); plumed_massert(Communicator::initialized(),"Invalid walkers configuration: WALKERS_MPI needs the communicator correctly initialized."); - if(comm.Get_rank()==0) { //multi_sim_comm works on first rank only + if(comm.Get_rank()==0)//multi_sim_comm works on first rank only + { NumWalkers_=multi_sim_comm.Get_size(); walker_rank_=multi_sim_comm.Get_rank(); } comm.Bcast(NumWalkers_,0); //if each walker has more than one processor update them all comm.Bcast(walker_rank_,0); - } else { + } + else + { NumWalkers_=1; walker_rank_=0; } @@ -579,7 +582,8 @@ OPESmetad::OPESmetad(const ActionOptions& ao) rank_=comm.Get_rank(); bool serial=false; parseFlag("SERIAL",serial); - if(serial) { + if(serial) + { NumOMP_=1; NumParallel_=1; rank_=0; @@ -589,25 +593,31 @@ OPESmetad::OPESmetad(const ActionOptions& ao) //restart if needed bool convertKernelsToState=false; - if(getRestart()) { + if(getRestart()) + { bool stateRestart=true; - if(restartFileName.length()==0) { + if(restartFileName.length()==0) + { stateRestart=false; restartFileName=kernelsFileName; } IFile ifile; ifile.link(*this); - if(ifile.FileExist(restartFileName)) { + if(ifile.FileExist(restartFileName)) + { bool tmp_nlist=nlist_; nlist_=false; // NLIST is not needed while restarting ifile.open(restartFileName); log.printf(" RESTART - make sure all used options are compatible\n"); log.printf(" restarting from: %s\n",restartFileName.c_str()); std::string action_name=getName(); - if(stateRestart) { + if(stateRestart) + { log.printf(" it should be a STATE file (not a KERNELS file)\n"); action_name+="_state"; - } else { + } + else + { log.printf(" +++ WARNING +++ RESTART from KERNELS might be approximate, use STATE_WFILE and STATE_RFILE to restart from the exact state\n"); action_name+="_kernels"; } @@ -616,55 +626,61 @@ OPESmetad::OPESmetad(const ActionOptions& ao) plumed_massert(action_name==old_action_name,"RESTART - mismatch between old and new action name. Expected '"+action_name+"', but found '"+old_action_name+"'"); std::string old_biasfactor_str; ifile.scanField("biasfactor",old_biasfactor_str); - if(old_biasfactor_str=="inf" || old_biasfactor_str=="INF") { - if(!std::isinf(biasfactor_)) { + if(old_biasfactor_str=="inf" || old_biasfactor_str=="INF") + { + if(!std::isinf(biasfactor_)) log.printf(" +++ WARNING +++ previous bias factor was inf while now it is %g\n",biasfactor_); - } - } else { + } + else + { double old_biasfactor; ifile.scanField("biasfactor",old_biasfactor); - if(std::abs(biasfactor_-old_biasfactor)>1e-6*biasfactor_) { + if(std::abs(biasfactor_-old_biasfactor)>1e-6*biasfactor_) log.printf(" +++ WARNING +++ previous bias factor was %g while now it is %g. diff = %g\n",old_biasfactor,biasfactor_,biasfactor_-old_biasfactor); - } } double old_epsilon; ifile.scanField("epsilon",old_epsilon); - if(std::abs(epsilon_-old_epsilon)>1e-6*epsilon_) { + if(std::abs(epsilon_-old_epsilon)>1e-6*epsilon_) log.printf(" +++ WARNING +++ previous epsilon was %g while now it is %g. diff = %g\n",old_epsilon,epsilon_,epsilon_-old_epsilon); - } double old_cutoff; ifile.scanField("kernel_cutoff",old_cutoff); - if(std::abs(cutoff-old_cutoff)>1e-6*cutoff) { + if(std::abs(cutoff-old_cutoff)>1e-6*cutoff) log.printf(" +++ WARNING +++ previous kernel_cutoff was %g while now it is %g. diff = %g\n",old_cutoff,cutoff,cutoff-old_cutoff); - } double old_threshold; const double threshold=sqrt(threshold2_); ifile.scanField("compression_threshold",old_threshold); - if(std::abs(threshold-old_threshold)>1e-6*threshold) { + if(std::abs(threshold-old_threshold)>1e-6*threshold) log.printf(" +++ WARNING +++ previous compression_threshold was %g while now it is %g. diff = %g\n",old_threshold,threshold,threshold-old_threshold); - } - if(stateRestart) { + if(stateRestart) + { ifile.scanField("zed",Zed_); ifile.scanField("sum_weights",sum_weights_); ifile.scanField("sum_weights2",sum_weights2_); ifile.scanField("counter",counter_); - if(adaptive_sigma_) { + if(adaptive_sigma_) + { ifile.scanField("adaptive_counter",adaptive_counter_); - if(NumWalkers_==1) { - for(unsigned i=0; igetName(),sigma0_[i]); ifile.scanField("av_cv_"+getPntrToArgument(i)->getName(),av_cv_[i]); ifile.scanField("av_M2_"+getPntrToArgument(i)->getName(),av_M2_[i]); } - } else { + } + else + { for(unsigned w=0; wgetName()+"_"+std::to_string(w); ifile.scanField("sigma0_"+arg_iw,tmp0); ifile.scanField("av_cv_"+arg_iw,tmp1); ifile.scanField("av_M2_"+arg_iw,tmp2); - if(w==walker_rank_) { + if(w==walker_rank_) + { sigma0_[i]=tmp0; av_cv_[i]=tmp1; av_M2_[i]=tmp2; @@ -673,8 +689,10 @@ OPESmetad::OPESmetad(const ActionOptions& ao) } } } - for(unsigned i=0; iisPeriodic()) { + for(unsigned i=0; iisPeriodic()) + { std::string arg_min,arg_max; getPntrToArgument(i)->getDomain(arg_min,arg_max); std::string file_min,file_max; @@ -684,40 +702,40 @@ OPESmetad::OPESmetad(const ActionOptions& ao) plumed_massert(file_max==arg_max,"RESTART - mismatch between old and new ARG periodicity"); } } - if(stateRestart) { + if(stateRestart) + { double time; - while(ifile.scanField("time",time)) { + while(ifile.scanField("time",time)) + { std::vector center(ncv_); std::vector sigma(ncv_); double height; - for(unsigned i=0; igetName(),center[i]); - } - for(unsigned i=0; igetName(),sigma[i]); - } ifile.scanField("height",height); ifile.scanField(); kernels_.emplace_back(height,center,sigma); } log.printf(" a total of %lu kernels where read\n",kernels_.size()); - } else { + } + else + { ifile.allowIgnoredFields(); //this allows for multiple restart, but without checking for consistency between them! double time; - while(ifile.scanField("time",time)) { + while(ifile.scanField("time",time)) + { std::vector center(ncv_); std::vector sigma(ncv_); double height; double logweight; - for(unsigned i=0; igetName(),center[i]); - } - for(unsigned i=0; igetName(),sigma[i]); - } - if(counter_==(1+walker_rank_) && adaptive_sigma_) { + if(counter_==(1+walker_rank_) && adaptive_sigma_) sigma0_=sigma; - } ifile.scanField("height",height); ifile.scanField("logweight",logweight); ifile.scanField(); @@ -728,15 +746,14 @@ OPESmetad::OPESmetad(const ActionOptions& ao) counter_++; } KDEnorm_=mode::explore?counter_:sum_weights_; - if(!no_Zed_) { + if(!no_Zed_) + { double sum_uprob=0; for(unsigned k=rank_; k1) { + if(NumParallel_>1) comm.Sum(sum_uprob); - } Zed_=sum_uprob/KDEnorm_/kernels_.size(); } log.printf(" a total of %llu kernels where read, and compressed to %lu\n",counter_-1,kernels_.size()); @@ -745,45 +762,42 @@ OPESmetad::OPESmetad(const ActionOptions& ao) ifile.reset(false); ifile.close(); nlist_=tmp_nlist; - } else { //same behaviour as METAD - plumed_merror("RESTART requested, but file '"+restartFileName+"' was not found!\n Set RESTART=NO or provide a restart file"); } - if(NumWalkers_>1) { //make sure that all walkers are doing the same thing + else //same behaviour as METAD + plumed_merror("RESTART requested, but file '"+restartFileName+"' was not found!\n Set RESTART=NO or provide a restart file"); + if(NumWalkers_>1) //make sure that all walkers are doing the same thing + { const unsigned kernels_size=kernels_.size(); std::vector all_kernels_size(NumWalkers_); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) multi_sim_comm.Allgather(kernels_size,all_kernels_size); - } comm.Bcast(all_kernels_size,0); bool same_number_of_kernels=true; for(unsigned w=1; w0) { - log.printf(" +++ WARNING +++ the provided STATE_RFILE will be ignored, since RESTART was not requested\n"); } + else if(restartFileName.length()>0) + log.printf(" +++ WARNING +++ the provided STATE_RFILE will be ignored, since RESTART was not requested\n"); //sync all walkers to avoid opening files before reading is over (see also METAD) comm.Barrier(); - if(comm.Get_rank()==0 && walkers_mpi) { + if(comm.Get_rank()==0 && walkers_mpi) multi_sim_comm.Barrier(); - } //setup output kernels file kernelsOfile_.link(*this); - if(NumWalkers_>1) { - if(walker_rank_>0) { - kernelsFileName="/dev/null"; //only first walker writes on file - } + if(NumWalkers_>1) + { + if(walker_rank_>0) + kernelsFileName="/dev/null"; //only first walker writes on file kernelsOfile_.enforceSuffix(""); } kernelsOfile_.open(kernelsFileName); - if(fmt.length()>0) { + if(fmt.length()>0) kernelsOfile_.fmtField(" "+fmt); - } kernelsOfile_.setHeavyFlush(); //do I need it? //define and set const fields kernelsOfile_.addConstantField("action"); @@ -791,9 +805,8 @@ OPESmetad::OPESmetad(const ActionOptions& ao) kernelsOfile_.addConstantField("epsilon"); kernelsOfile_.addConstantField("kernel_cutoff"); kernelsOfile_.addConstantField("compression_threshold"); - for(unsigned i=0; i::OPESmetad(const ActionOptions& ao) kernelsOfile_.printField("compression_threshold",sqrt(threshold2_)); //open file for storing state - if(wStateStride_!=0) { + if(wStateStride_!=0) + { stateOfile_.link(*this); - if(NumWalkers_>1) { - if(walker_rank_>0) { - stateFileName="/dev/null"; //only first walker writes on file - } + if(NumWalkers_>1) + { + if(walker_rank_>0) + stateFileName="/dev/null"; //only first walker writes on file stateOfile_.enforceSuffix(""); } stateOfile_.open(stateFileName); - if(fmt.length()>0) { + if(fmt.length()>0) stateOfile_.fmtField(" "+fmt); - } - if(convertKernelsToState) { + if(convertKernelsToState) dumpStateToFile(); - } } //set initial old values @@ -835,11 +847,13 @@ OPESmetad::OPESmetad(const ActionOptions& ao) addComponent("nker"); componentIsNotPeriodic("nker"); getPntrToComponent("nker")->set(kernels_.size()); - if(calc_work_) { + if(calc_work_) + { addComponent("work"); componentIsNotPeriodic("work"); } - if(nlist_) { + if(nlist_) + { addComponent("nlker"); componentIsNotPeriodic("nlker"); addComponent("nlsteps"); @@ -852,129 +866,116 @@ OPESmetad::OPESmetad(const ActionOptions& ao) log.printf(" depositing new kernels with PACE = %u\n",stride_); log.printf(" expected BARRIER is %g\n",barrier); log.printf(" using target distribution with BIASFACTOR gamma = %g\n",biasfactor_); - if(std::isinf(biasfactor_)) { + if(std::isinf(biasfactor_)) log.printf(" (thus a uniform flat target distribution, no well-tempering)\n"); - } - if(excluded_region_!=NULL) { + if(excluded_region_!=NULL) log.printf(" -- EXCLUDED_REGION: kernels will be deposited only when '%s' is equal to zero\n",excluded_region_->getName().c_str()); - } - if(extra_biases_.size()>0) { + if(extra_biases_.size()>0) + { log.printf(" -- EXTRA_BIAS: "); - for(unsigned e=0; egetName().c_str()); - } log.printf("will be reweighted\n"); } - if(adaptive_sigma_) { + if(adaptive_sigma_) + { log.printf(" adaptive SIGMA will be used, with ADAPTIVE_SIGMA_STRIDE = %u\n",adaptive_sigma_stride_); unsigned x=std::ceil(adaptive_sigma_stride_/stride_); log.printf(" thus the first x kernel depositions will be skipped, x = ADAPTIVE_SIGMA_STRIDE/PACE = %u\n",x); - } else { + } + else + { log.printf(" kernels have initial SIGMA = "); - for(unsigned i=0; i0) { + if(sigma_min_.size()>0) + { log.printf(" kernels have a SIGMA_MIN = "); - for(unsigned i=0; iepsilon_*(1+1e-6)) { + if(val_at_cutoff_>epsilon_*(1+1e-6)) log.printf(" +++ WARNING +++ the KERNEL_CUTOFF might be too small for the given EPSILON\n"); - } log.printf(" kernels will be compressed when closer than COMPRESSION_THRESHOLD = %g\n",sqrt(threshold2_)); - if(threshold2_==0) { + if(threshold2_==0) log.printf(" +++ WARNING +++ kernels will never merge, expect slowdowns\n"); - } - if(!recursive_merge_) { + if(!recursive_merge_) log.printf(" -- RECURSIVE_MERGE_OFF: only one merge for each new kernel will be attempted. This is faster only if total number of kernels does not grow too much\n"); - } - if(nlist_) { + if(nlist_) log.printf(" -- NLIST: using neighbor list for kernels, with parameters: %g,%g\n",nlist_param_[0],nlist_param_[1]); - } - if(nlist_pace_reset_) { + if(nlist_pace_reset_) log.printf(" -- NLIST_PACE_RESET: forcing the neighbor list to update every PACE\n"); - } - if(no_Zed_) { + if(no_Zed_) log.printf(" -- NO_ZED: using fixed normalization factor = %g\n",Zed_); - } - if(wStateStride_>0) { + if(wStateStride_>0) log.printf(" state checkpoints are written on file %s every %d MD steps\n",stateFileName.c_str(),wStateStride_); - } - if(wStateStride_==-1) { + if(wStateStride_==-1) log.printf(" state checkpoints are written on file %s only on CPT events (or never if MD code does define them!)\n",stateFileName.c_str()); - } - if(walkers_mpi) { + if(walkers_mpi) log.printf(" -- WALKERS_MPI: if multiple replicas are present, they will share the same bias via MPI\n"); - } - if(NumWalkers_>1) { + if(NumWalkers_>1) + { log.printf(" using multiple walkers\n"); log.printf(" number of walkers: %u\n",NumWalkers_); log.printf(" walker rank: %u\n",walker_rank_); } int mw_warning=0; - if(!walkers_mpi && comm.Get_rank()==0 && multi_sim_comm.Get_size()>(int)NumWalkers_) { + if(!walkers_mpi && comm.Get_rank()==0 && multi_sim_comm.Get_size()>(int)NumWalkers_) mw_warning=1; - } comm.Bcast(mw_warning,0); - if(mw_warning) { //log.printf messes up with comm, so never use it without Bcast! + if(mw_warning) //log.printf messes up with comm, so never use it without Bcast! log.printf(" +++ WARNING +++ multiple replicas will NOT communicate unless the flag WALKERS_MPI is used\n"); - } - if(NumParallel_>1) { + if(NumParallel_>1) log.printf(" using multiple MPI processes per simulation: %u\n",NumParallel_); - } - if(NumOMP_>1) { + if(NumOMP_>1) log.printf(" using multiple OpenMP threads per simulation: %u\n",NumOMP_); - } - if(serial) { + if(serial) log.printf(" -- SERIAL: no loop parallelization, despite %d MPI processes and %u OpenMP threads available\n",comm.Get_size(),OpenMP::getNumThreads()); - } log.printf(" Bibliography: "); log< -void OPESmetad::calculate() { +void OPESmetad::calculate() +{ //get cv std::vector cv(ncv_); - for(unsigned i=0; inlist_param_[1]*nlist_dev2_[i]) { + if(diff_i*diff_i>nlist_param_[1]*nlist_dev2_[i]) + { nlist_update_=true; break; } } } - if(nlist_update_) { + if(nlist_update_) updateNlist(cv); - } } //set bias and forces @@ -982,55 +983,57 @@ void OPESmetad::calculate() { const double prob=getProbAndDerivatives(cv,der_prob); const double bias=kbt_*bias_prefactor_*std::log(prob/Zed_+epsilon_); setBias(bias); - for(unsigned i=0; i -void OPESmetad::update() { - if(isFirstStep_) { //same in MetaD, useful for restarts? +void OPESmetad::update() +{ + if(isFirstStep_)//same in MetaD, useful for restarts? + { isFirstStep_=false; return; } //update variance if adaptive sigma - if(adaptive_sigma_) { + if(adaptive_sigma_) + { adaptive_counter_++; unsigned tau=adaptive_sigma_stride_; - if(adaptive_counter_1 if restarting - return; //do not apply bias before having measured sigma - } + if(adaptive_counter_1 if restarting + return; //do not apply bias before having measured sigma } //do update - if(getStep()%stride_==0 && (excluded_region_==NULL || excluded_region_->get()==0)) { + if(getStep()%stride_==0 && (excluded_region_==NULL || excluded_region_->get()==0)) + { old_KDEnorm_=KDEnorm_; delta_kernels_.clear(); unsigned old_nker=kernels_.size(); //get new kernel height double log_weight=getOutputQuantity(0)/kbt_; //first value is always the current bias - for(unsigned e=0; eget()/kbt_; //extra biases contribute to the weight - } + for(unsigned e=0; eget()/kbt_; //extra biases contribute to the weight double height=std::exp(log_weight); //update sum_weights_ and neff double sum_heights=height; double sum_heights2=height*height; - if(NumWalkers_>1) { - if(comm.Get_rank()==0) { + if(NumWalkers_>1) + { + if(comm.Get_rank()==0) + { multi_sim_comm.Sum(sum_heights); multi_sim_comm.Sum(sum_heights2); } @@ -1043,85 +1046,90 @@ void OPESmetad::update() { const double neff=std::pow(1+sum_weights_,2)/(1+sum_weights2_); //adding 1 makes it more robust at the start getPntrToComponent("rct")->set(kbt_*std::log(sum_weights_/counter_)); getPntrToComponent("neff")->set(neff); - if(mode::explore) { + if(mode::explore) + { KDEnorm_=counter_; height=1; //plain KDE, bias reweight does not enter here - } else { - KDEnorm_=sum_weights_; } + else + KDEnorm_=sum_weights_; //if needed, rescale sigma and height std::vector sigma=sigma0_; - if(adaptive_sigma_) { + if(adaptive_sigma_) + { const double factor=mode::explore?1:biasfactor_; - if(counter_==1+NumWalkers_) { //first time only - for(unsigned i=0; i1e-6,"ADAPTIVE SIGMA is suspiciously small for CV i="+std::to_string(i)+"\nManually provide SIGMA or set a safe SIGMA_MIN to avoid possible issues"); - } - } else { - for(unsigned i=0; i0) { - for(unsigned i=0; i0) + { + for(unsigned i=0; i center(ncv_); - for(unsigned i=0; i all_height(NumWalkers_,0.0); std::vector all_center(NumWalkers_*ncv_,0.0); std::vector all_sigma(NumWalkers_*ncv_,0.0); std::vector all_logweight(NumWalkers_,0.0); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) + { multi_sim_comm.Allgather(height,all_height); multi_sim_comm.Allgather(center,all_center); multi_sim_comm.Allgather(sigma,all_sigma); @@ -1131,102 +1139,111 @@ void OPESmetad::update() { comm.Bcast(all_center,0); comm.Bcast(all_sigma,0); comm.Bcast(all_logweight,0); - if(nlist_) { - //gather all the nlist_index_, so merging can be done using it + if(nlist_) + { //gather all the nlist_index_, so merging can be done using it std::vector all_nlist_size(NumWalkers_); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) + { all_nlist_size[walker_rank_]=nlist_index_.size(); multi_sim_comm.Sum(all_nlist_size); } comm.Bcast(all_nlist_size,0); unsigned tot_size=0; - for(unsigned w=0; w0) { + if(tot_size>0) + { std::vector disp(NumWalkers_); - for(unsigned w=0; w all_nlist_index(tot_size); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) multi_sim_comm.Allgatherv(nlist_index_,all_nlist_index,&all_nlist_size[0],&disp[0]); - } comm.Bcast(all_nlist_index,0); std::set nlist_index_set(all_nlist_index.begin(),all_nlist_index.end()); //remove duplicates and sort nlist_index_.assign(nlist_index_set.begin(),nlist_index_set.end()); } } - for(unsigned w=0; w center_w(all_center.begin()+ncv_*w,all_center.begin()+ncv_*(w+1)); std::vector sigma_w(all_sigma.begin()+ncv_*w,all_sigma.begin()+ncv_*(w+1)); addKernel(all_height[w],center_w,sigma_w,all_logweight[w]); } } getPntrToComponent("nker")->set(kernels_.size()); - if(nlist_) { + if(nlist_) + { getPntrToComponent("nlker")->set(nlist_index_.size()); - if(nlist_pace_reset_) { + if(nlist_pace_reset_) nlist_update_=true; - } } //update Zed_ - if(!no_Zed_) { + if(!no_Zed_) + { double sum_uprob=0; const unsigned ks=kernels_.size(); const unsigned ds=delta_kernels_.size(); const bool few_kernels=(ks*ks<(3*ks*ds+2*ds*ds*NumParallel_+100)); //this seems reasonable, but is not rigorous... - if(few_kernels) { //really needed? Probably is almost always false + if(few_kernels) //really needed? Probably is almost always false + { #pragma omp parallel num_threads(NumOMP_) { #pragma omp for reduction(+:sum_uprob) nowait for(unsigned k=rank_; k1) { + if(NumParallel_>1) comm.Sum(sum_uprob); - } - } else { + } + else + { // Here instead of redoing the full summation, we add only the changes, knowing that // uprob = old_uprob + delta_uprob // and we also need to consider that in the new sum there are some novel centers and some disappeared ones double delta_sum_uprob=0; - if(!nlist_) { + if(!nlist_) + { #pragma omp parallel num_threads(NumOMP_) { #pragma omp for reduction(+:delta_sum_uprob) nowait - for(unsigned k=rank_; k1) { + if(NumParallel_>1) comm.Sum(delta_sum_uprob); - } #pragma omp parallel num_threads(NumOMP_) { #pragma omp for reduction(+:delta_sum_uprob) - for(unsigned d=0; d::update() { } //calculate work if requested - if(calc_work_) { + if(calc_work_) + { std::vector dummy(ncv_); //derivatives are not actually needed const double prob=getProbAndDerivatives(center,dummy); const double new_bias=kbt_*bias_prefactor_*std::log(prob/Zed_+epsilon_); @@ -1249,104 +1267,113 @@ void OPESmetad::update() { } //dump state if requested - if( (wStateStride_>0 && getStep()%wStateStride_==0) || (wStateStride_==-1 && getCPT()) ) { + if( (wStateStride_>0 && getStep()%wStateStride_==0) || (wStateStride_==-1 && getCPT()) ) dumpStateToFile(); - } } template -double OPESmetad::getProbAndDerivatives(const std::vector& cv,std::vector& der_prob) { +double OPESmetad::getProbAndDerivatives(const std::vector& cv,std::vector& der_prob) +{ double prob=0.0; - if(!nlist_) { - if(NumOMP_==1 || (unsigned)kernels_.size()<2*NumOMP_*NumParallel_) { + if(!nlist_) + { + if(NumOMP_==1 || (unsigned)kernels_.size()<2*NumOMP_*NumParallel_) + { // for performances and thread safety std::vector dist(ncv_); - for(unsigned k=rank_; k omp_deriv(der_prob.size(),0.); // for performances and thread safety std::vector dist(ncv_); #pragma omp for reduction(+:prob) nowait - for(unsigned k=rank_; k dist(ncv_); - for(unsigned nk=rank_; nk omp_deriv(der_prob.size(),0.); // for performances and thread safety std::vector dist(ncv_); #pragma omp for reduction(+:prob) nowait - for(unsigned nk=rank_; nk1) { + if(NumParallel_>1) + { comm.Sum(prob); comm.Sum(der_prob); } //normalize the estimate prob/=KDEnorm_; - for(unsigned i=0; i -void OPESmetad::addKernel(const double height,const std::vector& center,const std::vector& sigma) { +void OPESmetad::addKernel(const double height,const std::vector& center,const std::vector& sigma) +{ bool no_match=true; - if(threshold2_!=0) { + if(threshold2_!=0) + { unsigned taker_k=getMergeableKernel(center,kernels_.size()); - if(taker_kgiver_k) { //saves time when erasing + if(taker_k>giver_k) //saves time when erasing std::swap(taker_k,giver_k); - } mergeKernels(kernels_[taker_k],kernels_[giver_k]); delta_kernels_.push_back(kernels_[taker_k]); kernels_.erase(kernels_.begin()+giver_k); - if(nlist_) { + if(nlist_) + { unsigned giver_nk=0; bool found_giver=false; - for(unsigned nk=0; nk::addKernel(const double height,const std::vector& c } } } - if(no_match) { + if(no_match) + { kernels_.emplace_back(height,center,sigma); delta_kernels_.emplace_back(height,center,sigma); - if(nlist_) { + if(nlist_) nlist_index_.push_back(kernels_.size()-1); - } } } template -void OPESmetad::addKernel(const double height,const std::vector& center,const std::vector& sigma,const double logweight) { +void OPESmetad::addKernel(const double height,const std::vector& center,const std::vector& sigma,const double logweight) +{ addKernel(height,center,sigma); //write to file kernelsOfile_.printField("time",getTime()); - for(unsigned i=0; igetName(),sigma[i]); - } kernelsOfile_.printField("height",height); kernelsOfile_.printField("logweight",logweight); kernelsOfile_.printField(); } template -unsigned OPESmetad::getMergeableKernel(const std::vector& giver_center,const unsigned giver_k) { - //returns kernels_.size() if no match is found +unsigned OPESmetad::getMergeableKernel(const std::vector& giver_center,const unsigned giver_k) +{ //returns kernels_.size() if no match is found unsigned min_k=kernels_.size(); double min_norm2=threshold2_; - if(!nlist_) { + if(!nlist_) + { #pragma omp parallel num_threads(NumOMP_) { unsigned min_k_omp = min_k; double min_norm2_omp = threshold2_; #pragma omp for nowait - for(unsigned k=rank_; k=min_norm2_omp) { + if(norm2>=min_norm2_omp) break; - } } - if(norm2=min_norm2) { + if(norm2>=min_norm2) break; - } } - if(norm21) { + if(NumParallel_>1) + { std::vector all_min_norm2(NumParallel_); std::vector all_min_k(NumParallel_); comm.Allgather(min_norm2,all_min_norm2); @@ -1466,85 +1500,89 @@ unsigned OPESmetad::getMergeableKernel(const std::vector& giver_ce } template -void OPESmetad::updateNlist(const std::vector& new_center) { - if(kernels_.size()==0) { //no need to check for neighbors +void OPESmetad::updateNlist(const std::vector& new_center) +{ + if(kernels_.size()==0) //no need to check for neighbors return; - } nlist_center_=new_center; nlist_index_.clear(); //first we gather all the nlist_index - if(NumOMP_==1 || (unsigned)kernels_.size()<2*NumOMP_*NumParallel_) { - for(unsigned k=rank_; k private_nlist_index; #pragma omp for nowait - for(unsigned k=rank_; k1) { + if(NumParallel_>1) + { std::vector all_nlist_size(NumParallel_); all_nlist_size[rank_]=nlist_index_.size(); comm.Sum(all_nlist_size); unsigned tot_size=0; - for(unsigned r=0; r0) { + if(tot_size>0) + { std::vector disp(NumParallel_); - for(unsigned r=0; r local_nlist_index=nlist_index_; nlist_index_.resize(tot_size); comm.Allgatherv(local_nlist_index,nlist_index_,&all_nlist_size[0],&disp[0]); - if(recursive_merge_) { + if(recursive_merge_) std::sort(nlist_index_.begin(),nlist_index_.end()); - } } } //calculate the square deviation std::vector dev2(ncv_,0.); - for(unsigned k=rank_; k1) { + if(NumParallel_>1) comm.Sum(dev2); - } - for(unsigned i=0; iset(nlist_index_.size()); getPntrToComponent("nlsteps")->set(nlist_steps_); @@ -1553,17 +1591,20 @@ void OPESmetad::updateNlist(const std::vector& new_center) { } template -void OPESmetad::dumpStateToFile() { +void OPESmetad::dumpStateToFile() +{ //gather adaptive sigma info if needed //doing this while writing to file can lead to misterious slowdowns std::vector all_sigma0; std::vector all_av_cv; std::vector all_av_M2; - if(adaptive_sigma_ && NumWalkers_>1) { + if(adaptive_sigma_ && NumWalkers_>1) + { all_sigma0.resize(NumWalkers_*ncv_); all_av_cv.resize(NumWalkers_*ncv_); all_av_M2.resize(NumWalkers_*ncv_); - if(comm.Get_rank()==0) { + if(comm.Get_rank()==0) + { multi_sim_comm.Allgather(sigma0_,all_sigma0); multi_sim_comm.Allgather(av_cv_,all_av_cv); multi_sim_comm.Allgather(av_M2_,all_av_M2); @@ -1574,11 +1615,10 @@ void OPESmetad::dumpStateToFile() { } //rewrite header or rewind file - if(storeOldStates_) { + if(storeOldStates_) stateOfile_.clearFields(); - } else if(walker_rank_==0) { + else if(walker_rank_==0) stateOfile_.rewind(); - } //define fields stateOfile_.addConstantField("action"); stateOfile_.addConstantField("biasfactor"); @@ -1589,17 +1629,23 @@ void OPESmetad::dumpStateToFile() { stateOfile_.addConstantField("sum_weights"); stateOfile_.addConstantField("sum_weights2"); stateOfile_.addConstantField("counter"); - if(adaptive_sigma_) { + if(adaptive_sigma_) + { stateOfile_.addConstantField("adaptive_counter"); - if(NumWalkers_==1) { - for(unsigned i=0; igetName()); stateOfile_.addConstantField("av_cv_"+getPntrToArgument(i)->getName()); stateOfile_.addConstantField("av_M2_"+getPntrToArgument(i)->getName()); } - } else { + } + else + { for(unsigned w=0; wgetName()+"_"+std::to_string(w); stateOfile_.addConstantField("sigma0_"+arg_iw); stateOfile_.addConstantField("av_cv_"+arg_iw); @@ -1608,9 +1654,8 @@ void OPESmetad::dumpStateToFile() { } } //print fields - for(unsigned i=0; i::dumpStateToFile() { stateOfile_.printField("sum_weights",sum_weights_); stateOfile_.printField("sum_weights2",sum_weights2_); stateOfile_.printField("counter",counter_); - if(adaptive_sigma_) { + if(adaptive_sigma_) + { stateOfile_.printField("adaptive_counter",adaptive_counter_); - if(NumWalkers_==1) { - for(unsigned i=0; igetName(),sigma0_[i]); stateOfile_.printField("av_cv_"+getPntrToArgument(i)->getName(),av_cv_[i]); stateOfile_.printField("av_M2_"+getPntrToArgument(i)->getName(),av_M2_[i]); } - } else { + } + else + { for(unsigned w=0; wgetName()+"_"+std::to_string(w); stateOfile_.printField("sigma0_"+arg_iw,all_sigma0[w*ncv_+i]); stateOfile_.printField("av_cv_"+arg_iw,all_av_cv[w*ncv_+i]); @@ -1639,72 +1690,69 @@ void OPESmetad::dumpStateToFile() { } } //print kernels - for(unsigned k=0; kgetName(),kernels_[k].sigma[i]); - } stateOfile_.printField("height",kernels_[k].height); stateOfile_.printField(); } //make sure file is written even if small - if(!storeOldStates_) { + if(!storeOldStates_) stateOfile_.flush(); - } } template -inline double OPESmetad::evaluateKernel(const kernel& G,const std::vector& x) const { - //NB: cannot be a method of kernel class, because uses external variables (for cutoff) +inline double OPESmetad::evaluateKernel(const kernel& G,const std::vector& x) const +{ //NB: cannot be a method of kernel class, because uses external variables (for cutoff) double norm2=0; - for(unsigned i=0; i=cutoff2_) { + if(norm2>=cutoff2_) return 0; - } } return G.height*(std::exp(-0.5*norm2)-val_at_cutoff_); } template -inline double OPESmetad::evaluateKernel(const kernel& G,const std::vector& x, std::vector& acc_der, std::vector& dist) { - //NB: cannot be a method of kernel class, because uses external variables (for cutoff) +inline double OPESmetad::evaluateKernel(const kernel& G,const std::vector& x, std::vector& acc_der, std::vector& dist) +{ //NB: cannot be a method of kernel class, because uses external variables (for cutoff) double norm2=0; - for(unsigned i=0; i=cutoff2_) { + if(norm2>=cutoff2_) return 0; - } } const double val=G.height*(std::exp(-0.5*norm2)-val_at_cutoff_); - for(unsigned i=0; i -inline void OPESmetad::mergeKernels(kernel& k1,const kernel& k2) { +inline void OPESmetad::mergeKernels(kernel& k1,const kernel& k2) +{ const double h=k1.height+k2.height; - for(unsigned i=0; iisPeriodic(); - if(isPeriodic_i) { - k1.center[i]=k2.center[i]+difference(i,k2.center[i],k1.center[i]); //fix PBC - } + if(isPeriodic_i) + k1.center[i]=k2.center[i]+difference(i,k2.center[i],k1.center[i]); //fix PBC const double c_i=(k1.height*k1.center[i]+k2.height*k2.center[i])/h; const double ss_k1_part=k1.height*(k1.sigma[i]*k1.sigma[i]+k1.center[i]*k1.center[i]); const double ss_k2_part=k2.height*(k2.sigma[i]*k2.sigma[i]+k2.center[i]*k2.center[i]); const double ss_i=(ss_k1_part+ss_k2_part)/h-c_i*c_i; - if(isPeriodic_i) { + if(isPeriodic_i) k1.center[i]=bringBackInPbc(i,c_i); - } else { + else k1.center[i]=c_i; - } k1.sigma[i]=sqrt(ss_i); } k1.height=h; diff --git a/src/pamm/HBPammHydrogens.cpp b/src/pamm/HBPammHydrogens.cpp index a0cbf83d9f..e4364308de 100644 --- a/src/pamm/HBPammHydrogens.cpp +++ b/src/pamm/HBPammHydrogens.cpp @@ -54,9 +54,7 @@ class HBPammHydrogens : public multicolvar::MultiColvarBase { // active methods: double compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const override; /// Returns the number of coordinates of the field - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(HBPammHydrogens,"HBPAMM_SH") @@ -84,77 +82,44 @@ void HBPammHydrogens::registerKeywords( Keywords& keys ) { keys.add("compulsory","REGULARISE","0.001","don't allow the denominator to be smaller then this value"); keys.reset_style("CLUSTERS","compulsory"); // Use actionWithDistributionKeywords - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("LESS_THAN"); - keys.use("MAX"); - keys.use("MIN"); - keys.use("BETWEEN"); - keys.use("HISTOGRAM"); - keys.use("MOMENTS"); - keys.use("ALT_MIN"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("SUM"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("LESS_THAN"); keys.use("MAX"); + keys.use("MIN"); keys.use("BETWEEN"); keys.use("HISTOGRAM"); keys.use("MOMENTS"); + keys.use("ALT_MIN"); keys.use("LOWEST"); keys.use("HIGHEST"); keys.use("SUM"); } HBPammHydrogens::HBPammHydrogens(const ActionOptions&ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // Read in the atoms - usespecies=true; - weightHasDerivatives=false; + usespecies=true; weightHasDerivatives=false; // Read in hydrogen atom indicees - std::vector all_atoms; - parseMultiColvarAtomList("HYDROGENS",-1,all_atoms); - if( atom_lab.size()==0 ) { - error("no hydrogens specified in input file"); - } + std::vector all_atoms; parseMultiColvarAtomList("HYDROGENS",-1,all_atoms); + if( atom_lab.size()==0 ) error("no hydrogens specified in input file"); // Now create a task list - one task per hydrogen - unsigned nH = atom_lab.size(); - for(unsigned i=0; inH ) { - block1upper=atom_lab.size() - nH + 1; - block2lower=0; - ablocks[0].resize( atom_lab.size() - nH ); - for(unsigned i=nH; i(block1upper+nH-1) || (block1upper-1)>0 ) { - error("no acceptor donor pairs in input specified therefore no hydrogen bonds"); - } - for(unsigned i=nH+block2lower-1; i(block1upper+nH-1) || (block1upper-1)>0 ) error("no acceptor donor pairs in input specified therefore no hydrogen bonds"); + for(unsigned i=nH+block2lower-1; i0 ) { - error( errormsg ); - } + if( errormsg.length()>0 ) error( errormsg ); } else { unsigned nr=nnode_t, nc=nnode_t; hbpamm_obj.resize( nr, nc ); @@ -170,19 +135,14 @@ HBPammHydrogens::HBPammHydrogens(const ActionOptions&ao): } for(unsigned j=i; j0 ) { - error( errormsg ); - } + if( errormsg.length()>0 ) error( errormsg ); } else { hbpamm_obj(i,j).setup( desc, reg, this, errormsg ); hbpamm_obj(j,i).setup( desc, reg, this, errormsg ); - if( errormsg.length()>0 ) { - error( errormsg ); - } + if( errormsg.length()>0 ) error( errormsg ); } } } @@ -193,9 +153,7 @@ HBPammHydrogens::HBPammHydrogens(const ActionOptions&ao): for(unsigned i=0; isfmax ) { - sfmax=rcut; - } + if( rcut>sfmax ) { sfmax=rcut; } } } setLinkCellCutoff( sfmax ); @@ -212,22 +170,16 @@ double HBPammHydrogens::compute( const unsigned& tindex, multicolvar::AtomValueP // Calculate the coordination number for(unsigned i=1; iblock1upper ) { - continue; - } + if( i>block1upper ) continue; for(unsigned j=1; j& myvals ) const { - return !(myvals[1]>epsilon); - } + bool checkForConnection( const std::vector& myvals ) const { return !(myvals[1]>epsilon); } }; PLUMED_REGISTER_ACTION(HBPammMatrix,"HBPAMM_MATRIX") @@ -83,19 +81,18 @@ void HBPammMatrix::registerKeywords( Keywords& keys ) { keys.add("atoms","HYDROGENS","The list of hydrogen atoms that can form part of a hydrogen bond. The atoms must be specified using a comma separated list, " "an index range or by using a \\ref GROUP"); keys.add("numbered","CLUSTERS","the name of the file that contains the definitions of all the kernels for PAMM"); - keys.reset_style("CLUSTERS","compulsory"); - keys.use("SUM"); + keys.reset_style("CLUSTERS","compulsory"); keys.use("SUM"); keys.add("compulsory","REGULARISE","0.001","don't allow the denominator to be smaller then this value"); } HBPammMatrix::HBPammMatrix(const ActionOptions& ao): Action(ao), - AdjacencyMatrixBase(ao) { + AdjacencyMatrixBase(ao) +{ readMaxThreeSpeciesMatrix("SITES", "DONORS", "ACCEPTORS", "HYDROGENS", false ); // Retrieve dimensions of hbonding matrix and resize - unsigned nrows, ncols; - retrieveTypeDimensions( nrows, ncols, ndonor_types ); + unsigned nrows, ncols; retrieveTypeDimensions( nrows, ncols, ndonor_types ); myhb_objs.resize( nrows, ncols ); // Read in the regularisation parameter parse("REGULARISE",regulariser); @@ -107,9 +104,7 @@ HBPammMatrix::HBPammMatrix(const ActionOptions& ao): for(unsigned i=0; isfmax ) { - sfmax=rcut; - } + if( rcut>sfmax ) { sfmax=rcut; } } } setLinkCellCutoff( sfmax ); @@ -117,30 +112,23 @@ HBPammMatrix::HBPammMatrix(const ActionOptions& ao): void HBPammMatrix::setupConnector( const unsigned& id, const unsigned& i, const unsigned& j, const std::vector& desc ) { log.printf(" reading definition of hydrogen bond between between type %u and %u from file %s \n",i,j,desc[0].c_str() ); - plumed_assert( desc.size()==1 ); - std::string errors; + plumed_assert( desc.size()==1 ); std::string errors; if( i==j ) { myhb_objs( i, j ).setup( desc[0], regulariser, this, errors ); } else { myhb_objs( i, j ).setup( desc[0], regulariser, this, errors ); myhb_objs( j, i ).setup( desc[0], regulariser, this, errors ); } - if( errors.length()>0 ) { - error( errors ); - } + if( errors.length()>0 ) error( errors ); } double HBPammMatrix::compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const { - Vector d_da = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); - double md_da = d_da.modulo(); // acceptor - donor + Vector d_da = getSeparation( myatoms.getPosition(0), myatoms.getPosition(1) ); double md_da = d_da.modulo(); // acceptor - donor // Get the base colvar numbers unsigned ano, dno = getBaseColvarNumber( myatoms.getIndex(0) ); - if( ndonor_types==0 ) { - ano = getBaseColvarNumber( myatoms.getIndex(1) ); - } else { - ano = getBaseColvarNumber( myatoms.getIndex(1) ) - ndonor_types; - } + if( ndonor_types==0 ) ano = getBaseColvarNumber( myatoms.getIndex(1) ); + else ano = getBaseColvarNumber( myatoms.getIndex(1) ) - ndonor_types; double value=0; if( myatoms.getNumberOfAtoms()>3 ) { diff --git a/src/pamm/HBPammObject.cpp b/src/pamm/HBPammObject.cpp index 20b9484eab..e75f3c12b3 100644 --- a/src/pamm/HBPammObject.cpp +++ b/src/pamm/HBPammObject.cpp @@ -26,13 +26,9 @@ namespace PLMD { namespace pamm { void HBPammObject::setup( const std::string& filename, const double& reg, multicolvar::MultiColvarBase* mybase, std::string& errorstr ) { - mymulti=mybase; - std::vector valnames(3); - valnames[0]="ptc"; - valnames[1]="ssc"; - valnames[2]="adc"; - std::vector min(3), max(3); - std::vector pbc(3, false); + mymulti=mybase; std::vector valnames(3); + valnames[0]="ptc"; valnames[1]="ssc"; valnames[2]="adc"; + std::vector min(3), max(3); std::vector pbc(3, false); mypamm.setup( filename, reg, valnames, pbc, min, max, errorstr ); } @@ -40,31 +36,23 @@ double HBPammObject::get_cutoff() const { double sfmax=0; for(unsigned k=0; ksfmax ) { - sfmax=rcut; - } + if( rcut>sfmax ) { sfmax=rcut; } } return sfmax; } double HBPammObject::evaluate( const unsigned& dno, const unsigned& ano, const unsigned& hno, const Vector& d_da, const double& md_da, multicolvar::AtomValuePack& myatoms ) const { - Vector d_dh = mymulti->getSeparation( myatoms.getPosition(dno), myatoms.getPosition(hno) ); - double md_dh = d_dh.modulo(); // hydrogen - donor - Vector d_ah = mymulti->getSeparation( myatoms.getPosition(ano), myatoms.getPosition(hno) ); - double md_ah = d_ah.modulo(); // hydrogen - acceptor + Vector d_dh = mymulti->getSeparation( myatoms.getPosition(dno), myatoms.getPosition(hno) ); double md_dh = d_dh.modulo(); // hydrogen - donor + Vector d_ah = mymulti->getSeparation( myatoms.getPosition(ano), myatoms.getPosition(hno) ); double md_ah = d_ah.modulo(); // hydrogen - acceptor // Create some vectors locally for pamm evaluation std::vector invals( 3 ), outvals( mypamm.getNumberOfKernels() ); std::vector > der( mypamm.getNumberOfKernels() ); - for(unsigned i=0; idoNotCalculateDerivatives() ) { diff --git a/src/pamm/PAMM.cpp b/src/pamm/PAMM.cpp index 8dd95be2cc..a699c11e53 100644 --- a/src/pamm/PAMM.cpp +++ b/src/pamm/PAMM.cpp @@ -126,9 +126,7 @@ class PAMM : public multicolvar::MultiColvarBase { /// This returns the position of the central atom Vector getCentralAtom(); /// Is the variable periodic - bool isPeriodic() override { - return false; - } + bool isPeriodic() override { return false; } }; PLUMED_REGISTER_ACTION(PAMM,"PAMM") @@ -138,18 +136,8 @@ void PAMM::registerKeywords( Keywords& keys ) { keys.add("compulsory","DATA","the multicolvars from which the pamm coordinates are calculated"); keys.add("compulsory","CLUSTERS","the name of the file that contains the definitions of all the clusters"); keys.add("compulsory","REGULARISE","0.001","don't allow the denominator to be smaller then this value"); - keys.use("MEAN"); - keys.use("MORE_THAN"); - keys.use("SUM"); - keys.use("LESS_THAN"); - keys.use("HISTOGRAM"); - keys.use("MIN"); - keys.use("MAX"); - keys.use("LOWEST"); - keys.use("HIGHEST"); - keys.use("ALT_MIN"); - keys.use("BETWEEN"); - keys.use("MOMENTS"); + keys.use("MEAN"); keys.use("MORE_THAN"); keys.use("SUM"); keys.use("LESS_THAN"); keys.use("HISTOGRAM"); + keys.use("MIN"); keys.use("MAX"); keys.use("LOWEST"); keys.use("HIGHEST"); keys.use("ALT_MIN"); keys.use("BETWEEN"); keys.use("MOMENTS"); keys.setComponentsIntroduction("When the label of this action is used as the input for a second you are not referring to a scalar quantity as you are in " "regular collective variables. The label is used to reference the full set of quantities calculated by " "the action. This is usual when using \\ref multicolvarfunction. Generally when doing this the set of PAMM variables " @@ -170,14 +158,13 @@ void PAMM::registerKeywords( Keywords& keys ) { PAMM::PAMM(const ActionOptions& ao): Action(ao), - MultiColvarBase(ao) { + MultiColvarBase(ao) +{ // This builds the lists buildSets(); // Check for reasonable input for(unsigned i=0; igetNumberOfQuantities()!=2 ) { - error("cannot use PAMM with " + getBaseMultiColvar(i)->getName() ); - } + if( getBaseMultiColvar(i)->getNumberOfQuantities()!=2 ) error("cannot use PAMM with " + getBaseMultiColvar(i)->getName() ); } bool mixed=getBaseMultiColvar(0)->isPeriodic(); @@ -185,24 +172,16 @@ PAMM::PAMM(const ActionOptions& ao): std::vector valnames( getNumberOfBaseMultiColvars() ); std::vector min( getNumberOfBaseMultiColvars() ), max( getNumberOfBaseMultiColvars() ); for(unsigned i=0; iisPeriodic()!=mixed ) { - warning("mixing of periodic and aperiodic base variables in pamm is untested"); - } + if( getBaseMultiColvar(i)->isPeriodic()!=mixed ) warning("mixing of periodic and aperiodic base variables in pamm is untested"); pbc[i]=getBaseMultiColvar(i)->isPeriodic(); - if( pbc[i] ) { - getBaseMultiColvar(i)->retrieveDomain( min[i], max[i] ); - } + if( pbc[i] ) getBaseMultiColvar(i)->retrieveDomain( min[i], max[i] ); valnames[i]=getBaseMultiColvar(i)->getLabel(); } - double regulariser; - parse("REGULARISE",regulariser); - std::string errorstr, filename; - parse("CLUSTERS",filename); + double regulariser; parse("REGULARISE",regulariser); + std::string errorstr, filename; parse("CLUSTERS",filename); mypamm.setup( filename, regulariser, valnames, pbc, min, max, errorstr ); - if( errorstr.length()>0 ) { - error( errorstr ); - } + if( errorstr.length()>0 ) error( errorstr ); } unsigned PAMM::getNumberOfQuantities() const { @@ -212,11 +191,9 @@ unsigned PAMM::getNumberOfQuantities() const { void PAMM::calculateWeight( multicolvar::AtomValuePack& myatoms ) { unsigned nvars = getNumberOfBaseMultiColvars(); // Weight of point is average of weights of input colvars? - std::vector tval(2); - double ww=0; + std::vector tval(2); double ww=0; for(unsigned i=0; i( nvars ) ); @@ -236,22 +213,17 @@ void PAMM::calculateWeight( multicolvar::AtomValuePack& myatoms ) { double PAMM::compute( const unsigned& tindex, multicolvar::AtomValuePack& myatoms ) const { unsigned nvars = getNumberOfBaseMultiColvars(); std::vector > tderiv( mypamm.getNumberOfKernels() ); - for(unsigned i=0; i tval(2), invals( nvars ), vals( mypamm.getNumberOfKernels() ); for(unsigned i=0; i mypref( 1 + vals.size() ); @@ -259,9 +231,7 @@ double PAMM::compute( const unsigned& tindex, multicolvar::AtomValuePack& myatom // Get the values of the derivatives MultiValue& myder = getInputDerivatives( ivar, false, myatoms ); // And calculate the derivatives - for(unsigned i=0; i( in.kernels[i].get() ) ); - } + max(in.max) +{ + for(unsigned i=0; i( in.kernels[i].get() ) ); } void PammObject::setup( const std::string& filename, const double& reg, const std::vector& valnames, const std::vector& pbcin, const std::vector& imin, const std::vector& imax, std::string& errorstr ) { - IFile ifile; - regulariser=reg; + IFile ifile; regulariser=reg; if( !ifile.FileExist(filename) ) { errorstr = "could not find file named " + filename; return; @@ -55,25 +54,16 @@ void PammObject::setup( const std::string& filename, const double& reg, const st min.resize( valnames.size() ); max.resize( valnames.size() ); for(unsigned i=0; i() ); - if( !pbc[i] ) { - pos[i]->setNotPeriodic(); - } else { - pos[i]->setDomain( min[i], max[i] ); - } + if( !pbc[i] ) pos[i]->setNotPeriodic(); + else pos[i]->setDomain( min[i], max[i] ); } - ifile.open(filename); - ifile.allowIgnoredFields(); - kernels.resize(0); + ifile.open(filename); ifile.allowIgnoredFields(); kernels.resize(0); for(unsigned k=0;; ++k) { std::unique_ptr kk = KernelFunctions::read( &ifile, false, valnames ); - if( !kk ) { - break ; - } + if( !kk ) break ; kk->normalize( Tools::unique2raw( pos ) ); kernels.emplace_back( std::move(kk) ); ifile.scanField(); @@ -85,11 +75,8 @@ void PammObject::evaluate( const std::vector& invar, std::vector std::vector> pos; for(unsigned i=0; i() ); - if( !pbc[i] ) { - pos[i]->setNotPeriodic(); - } else { - pos[i]->setDomain( min[i], max[i] ); - } + if( !pbc[i] ) pos[i]->setNotPeriodic(); + else pos[i]->setDomain( min[i], max[i] ); // And set the value pos[i]->set( invar[i] ); } @@ -98,21 +85,15 @@ void PammObject::evaluate( const std::vector& invar, std::vector auto pos_ptr=Tools::unique2raw(pos); // Evaluate the set of kernels - double denom=regulariser; - std::vector dderiv( der[0].size(), 0 ); + double denom=regulariser; std::vector dderiv( der[0].size(), 0 ); for(unsigned i=0; ievaluate( pos_ptr, der[i] ); - denom+=outvals[i]; - for(unsigned j=0; jevaluate( pos_ptr, der[i] ); denom+=outvals[i]; + for(unsigned j=0; j& valnames, const std::vector& pbcin, const std::vector& imin, const std::vector& imax, diff --git a/src/piv/PIV.cpp b/src/piv/PIV.cpp index d65e8bd7e6..8476f201e9 100644 --- a/src/piv/PIV.cpp +++ b/src/piv/PIV.cpp @@ -31,8 +31,10 @@ along with plumed. If not, see . using namespace std; -namespace PLMD { -namespace piv { +namespace PLMD +{ +namespace piv +{ //+PLUMEDOC PIVMOD_COLVAR PIV /* @@ -180,7 +182,8 @@ When using PIV please cite \cite pipolo2017navigating . */ //+ENDPLUMEDOC -class PIV : public Colvar { +class PIV : public Colvar +{ private: bool pbc, serial, timer; ForwardDecl stopwatch_fwd; @@ -230,7 +233,8 @@ class PIV : public Colvar { PLUMED_REGISTER_ACTION(PIV,"PIV") -void PIV::registerKeywords( Keywords& keys ) { +void PIV::registerKeywords( Keywords& keys ) +{ Colvar::registerKeywords( keys ); keys.add("numbered","SWITCH","The switching functions parameter." "You should specify a Switching function for all PIV blocks." @@ -288,7 +292,8 @@ PIV::PIV(const ActionOptions&ao): doneigh(false), test(false), CompDer(false), - com(false) { + com(false) +{ log << "Starting PIV Constructor\n"; { @@ -315,9 +320,7 @@ PIV::PIV(const ActionOptions&ao): // Precision on the real-to-integer transformation for the sorting parse("PRECISION",Nprec); - if(Nprec<2) { - error("Precision must be => 2"); - } + if(Nprec<2) error("Precision must be => 2"); // PBC bool nopbc=!pbc; @@ -339,9 +342,7 @@ PIV::PIV(const ActionOptions&ao): // Derivatives parseFlag("DERIVATIVES",CompDer); - if(CompDer) { - log << "Computing Derivatives\n"; - } + if(CompDer) log << "Computing Derivatives\n"; // Timing parseFlag("TIMER",timer); @@ -361,9 +362,7 @@ PIV::PIV(const ActionOptions&ao): // Test parseFlag("COM",com); - if(com) { - log << "Building PIV using COMs\n"; - } + if(com) log << "Building PIV using COMs\n"; // Volume Scaling parse("VOLUME",Vol0); @@ -545,15 +544,9 @@ PIV::PIV(const ActionOptions&ao): parseVector("NL_SKIN",nl_skin); //if(nl_skin.size()!=getNumberOfArguments() && nl_skin.size()!=0) error("not enough values for NL_SKIN"); for (unsigned j=0; jprev_stp&&getStep()%updatePIV==0)||CompDer) { - if (CompDer) { - log << " Step " << getStep() << " Computing Derivatives NON-SORTED PIV \n"; - } + if (CompDer) log << " Step " << getStep() << " Computing Derivatives NON-SORTED PIV \n"; // // build COMs from positions if requested if(com) { - if(pbc) { - makeWhole(); - } + if(pbc) makeWhole(); for(unsigned j=0; jsize(); i+=stride) { unsigned i0=(nl[j]->getClosePairAtomNumber(i).first).index(); unsigned i1=(nl[j]->getClosePairAtomNumber(i).second).index(); @@ -973,12 +951,8 @@ void PIV::calculate() { A0[Vint].push_back(i0); A1[Vint].push_back(i1); } - if(timer) { - stopwatch.stop("1 Build cPIV"); - } - if(timer) { - stopwatch.start("2 Sort cPIV"); - } + if(timer) stopwatch.stop("1 Build cPIV"); + if(timer) stopwatch.start("2 Sort cPIV"); if(!doserial && comm.initialized()) { // Vectors keeping track of the dimension and the starting-position of the rank-specific pair vector in the big pair vector. std:: vector Vdim(stride,0); @@ -1041,12 +1015,8 @@ void PIV::calculate() { // Loop on blocks //for(unsigned m=0;m PytorchModel::tensor_to_vector(const torch::Tensor& x) { PytorchModel::PytorchModel(const ActionOptions&ao): Action(ao), - Function(ao) { - //print pytorch version + Function(ao) +{ //print pytorch version //number of inputs of the model _n_in=getNumberOfArguments(); @@ -118,7 +119,8 @@ PytorchModel::PytorchModel(const ActionOptions&ao): std::string version; ss >> version; // extract into the string. plumed_merror("Cannot load FILE: '"+fname+"'. Please check that it is a Pytorch compiled model (exported with 'torch.jit.trace' or 'torch.jit.script') and that the Pytorch version matches the LibTorch one ("+version+")."); - } else { + } + else { plumed_merror("The FILE: '"+fname+"' does not exist."); } } @@ -156,9 +158,8 @@ void PytorchModel::calculate() { //retrieve arguments vector current_S(_n_in); - for(unsigned i=0; i<_n_in; i++) { + for(unsigned i=0; i<_n_in; i++) current_S[i]=getArgument(i); - } //convert to tensor torch::Tensor input_S = torch::tensor(current_S).view({1,_n_in}); input_S.set_requires_grad(true); @@ -191,9 +192,8 @@ void PytorchModel::calculate() { string name_comp = "node-"+std::to_string(j); //set derivatives of component j - for(unsigned i=0; i<_n_in; i++) { + for(unsigned i=0; i<_n_in; i++) setDerivative( getPntrToComponent(name_comp),i, der[i] ); - } } } } diff --git a/src/reference/ArgumentOnlyDistance.cpp b/src/reference/ArgumentOnlyDistance.cpp index 9671234663..5d3dd88f59 100644 --- a/src/reference/ArgumentOnlyDistance.cpp +++ b/src/reference/ArgumentOnlyDistance.cpp @@ -26,7 +26,8 @@ namespace PLMD { ArgumentOnlyDistance::ArgumentOnlyDistance( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), - ReferenceArguments(ro) { + ReferenceArguments(ro) +{ } void ArgumentOnlyDistance::read( const PDB& pdb ) { @@ -35,13 +36,9 @@ void ArgumentOnlyDistance::read( const PDB& pdb ) { double ArgumentOnlyDistance::calculate( const std::vector& vals, ReferenceValuePack& myder, const bool& squared ) const { std::vector tmparg( vals.size() ); - for(unsigned i=0; iget(); - } + for(unsigned i=0; iget(); double d=calculateArgumentDistance( vals, tmparg, myder, squared ); - if( !myder.updateComplete() ) { - myder.updateDynamicLists(); - } + if( !myder.updateComplete() ) myder.updateDynamicLists(); return d; } @@ -49,9 +46,7 @@ double ArgumentOnlyDistance::calc( const std::vector& pos, const Pbc& pb ReferenceValuePack& myder, const bool& squared ) const { plumed_dbg_assert( pos.size()==0 ); double d=calculateArgumentDistance( vals, arg, myder, squared ); - if( !myder.updateComplete() ) { - myder.updateDynamicLists(); - } + if( !myder.updateComplete() ) myder.updateDynamicLists(); return d; } diff --git a/src/reference/ArgumentOnlyDistance.h b/src/reference/ArgumentOnlyDistance.h index 60a2eed061..28ff5e0e3f 100644 --- a/src/reference/ArgumentOnlyDistance.h +++ b/src/reference/ArgumentOnlyDistance.h @@ -35,12 +35,8 @@ class ArgumentOnlyDistance : public ReferenceArguments { public: explicit ArgumentOnlyDistance( const ReferenceConfigurationOptions& ro ); void read( const PDB& pdb ) override; - bool pcaIsEnabledForThisReference() override { - return true; - } - void setupPCAStorage( ReferenceValuePack& mypack ) override { - mypack.switchOnPCAOption(); - } + bool pcaIsEnabledForThisReference() override { return true; } + void setupPCAStorage( ReferenceValuePack& mypack ) override { mypack.switchOnPCAOption(); } double calc( const std::vector& pos, const Pbc& pbc, const std::vector& vals, const std::vector& arg, ReferenceValuePack& myder, const bool& squared ) const override; double calculate( const std::vector& vals, ReferenceValuePack& myder, const bool& squared ) const ; }; diff --git a/src/reference/DRMSD.cpp b/src/reference/DRMSD.cpp index ce0f51d5b8..20ceaf6b8c 100644 --- a/src/reference/DRMSD.cpp +++ b/src/reference/DRMSD.cpp @@ -33,35 +33,25 @@ DRMSD::DRMSD( const ReferenceConfigurationOptions& ro ): nopbc(true), bounds_were_set(false), lower(0), - upper(std::numeric_limits::max( )) { + upper(std::numeric_limits::max( )) +{ } void DRMSD::setBoundsOnDistances( bool dopbc, double lbound, double ubound ) { - bounds_were_set=true; - nopbc=!dopbc; - lower=lbound; - upper=ubound; + bounds_were_set=true; nopbc=!dopbc; + lower=lbound; upper=ubound; } void DRMSD::readBounds( const PDB& pdb ) { - if( bounds_were_set ) { - return; - } - double tmp; - nopbc=pdb.hasFlag("NOPBC"); - if( pdb.getArgumentValue("LOWER_CUTOFF",tmp) ) { - lower=tmp; - } - if( pdb.getArgumentValue("UPPER_CUTOFF",tmp) ) { - upper=tmp; - } + if( bounds_were_set ) return; + double tmp; nopbc=pdb.hasFlag("NOPBC"); + if( pdb.getArgumentValue("LOWER_CUTOFF",tmp) ) lower=tmp; + if( pdb.getArgumentValue("UPPER_CUTOFF",tmp) ) upper=tmp; bounds_were_set=true; } void DRMSD::read( const PDB& pdb ) { - readAtomsFromPDB( pdb ); - readBounds( pdb ); - setup_targets(); + readAtomsFromPDB( pdb ); readBounds( pdb ); setup_targets(); } void DRMSD::setReferenceAtoms( const std::vector& conf, const std::vector& align_in, const std::vector& displace_in ) { @@ -81,9 +71,7 @@ void DRMSD::setup_targets() { } } } - if( targets.empty() ) { - error("drmsd will compare no distances - check upper and lower bounds are sensible"); - } + if( targets.empty() ) error("drmsd will compare no distances - check upper and lower bounds are sensible"); } double DRMSD::calc( const std::vector& pos, const Pbc& pbc, ReferenceValuePack& myder, const bool& squared ) const { @@ -97,11 +85,8 @@ double DRMSD::calc( const std::vector& pos, const Pbc& pbc, ReferenceVal const unsigned i=getAtomIndex( it.first.first ); const unsigned j=getAtomIndex( it.first.second ); - if(nopbc) { - distance=delta( pos[i], pos[j] ); - } else { - distance=pbc.distance( pos[i], pos[j] ); - } + if(nopbc) distance=delta( pos[i], pos[j] ); + else distance=pbc.distance( pos[i], pos[j] ); const double len = distance.modulo(); const double diff = len - it.second; diff --git a/src/reference/Direction.cpp b/src/reference/Direction.cpp index 180577b766..3ef01af789 100644 --- a/src/reference/Direction.cpp +++ b/src/reference/Direction.cpp @@ -30,7 +30,8 @@ Direction::Direction( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), ReferenceAtoms(ro), ReferenceArguments(ro), - normalized(false) { + normalized(false) +{ } void Direction::read( const PDB& pdb ) { @@ -39,38 +40,22 @@ void Direction::read( const PDB& pdb ) { } void Direction::setDirection( const std::vector& conf, const std::vector& args ) { - std::vector sigma( args.size(), 1.0 ); - setReferenceArguments( args, sigma ); - - reference_atoms.resize( conf.size() ); - align.resize( conf.size() ); - displace.resize( conf.size() ); - atom_der_index.resize( conf.size() ); - for(unsigned i=0; i sigma( args.size(), 1.0 ); setReferenceArguments( args, sigma ); + + reference_atoms.resize( conf.size() ); align.resize( conf.size() ); + displace.resize( conf.size() ); atom_der_index.resize( conf.size() ); + for(unsigned i=0; i& pos, const Pbc& pbc, const std::vector& vals, const std::vector& args, @@ -79,15 +64,11 @@ double Direction::calc( const std::vector& pos, const Pbc& pbc, const st } void Direction::extractArgumentDisplacement( const std::vector& vals, const std::vector& arg, std::vector& dirout ) const { - for(unsigned i=0; i& pos, std::vector& dirout ) const { - for(unsigned i=0; i& conf, const std::vector& args ); void addDirection( const double& weight, const Direction& dir ); - void setReferenceAtoms( const std::vector& conf, const std::vector& align_in, const std::vector& displace_in ) override { - plumed_error(); - } + void setReferenceAtoms( const std::vector& conf, const std::vector& align_in, const std::vector& displace_in ) override { plumed_error(); } /// This allows us to extract the reference positions, which are the direction in this case void extractArgumentDisplacement( const std::vector& vals, const std::vector& arg, std::vector& dirout ) const override; void extractAtomicDisplacement( const std::vector& pos, std::vector& dirout ) const override; diff --git a/src/reference/DotProductDistance.cpp b/src/reference/DotProductDistance.cpp index 545f95c5f6..8cc2becde5 100644 --- a/src/reference/DotProductDistance.cpp +++ b/src/reference/DotProductDistance.cpp @@ -37,7 +37,8 @@ PLUMED_REGISTER_METRIC(DotProductDistance,"DOTPRODUCT") DotProductDistance::DotProductDistance( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), - ArgumentOnlyDistance(ro) { + ArgumentOnlyDistance(ro) +{ } void DotProductDistance::read( const PDB& pdb ) { @@ -47,15 +48,9 @@ void DotProductDistance::read( const PDB& pdb ) { double DotProductDistance::calculateArgumentDistance( const std::vector & vals, const std::vector& arg, ReferenceValuePack& myder, const bool& squared ) const { double dot=0.0; - for (std::size_t i=0; i::min(); - } + for (std::size_t i=0; i::min(); return -log(dot); } diff --git a/src/reference/EuclideanDistance.cpp b/src/reference/EuclideanDistance.cpp index b9f75527a6..2211b5aca8 100644 --- a/src/reference/EuclideanDistance.cpp +++ b/src/reference/EuclideanDistance.cpp @@ -33,7 +33,8 @@ PLUMED_REGISTER_METRIC(EuclideanDistance,"EUCLIDEAN") EuclideanDistance::EuclideanDistance( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), - ArgumentOnlyDistance(ro) { + ArgumentOnlyDistance(ro) +{ } } diff --git a/src/reference/FakeFrame.h b/src/reference/FakeFrame.h index 99b8f82630..ab886c0b01 100644 --- a/src/reference/FakeFrame.h +++ b/src/reference/FakeFrame.h @@ -27,12 +27,11 @@ namespace PLMD { class FakeFrame : - public PLMD::ReferenceConfiguration { + public PLMD::ReferenceConfiguration +{ public: explicit FakeFrame( const ReferenceConfigurationOptions& ro ) : ReferenceConfiguration(ro) {} - void read( const PDB& ) override { - plumed_merror("should not be called"); - } + void read( const PDB& ) override { plumed_merror("should not be called"); } double calc( const std::vector& pos, const Pbc& pbc, const std::vector& vals, const std::vector& arg, ReferenceValuePack& myder, const bool& squared ) const override { plumed_merror("should not be called"); } diff --git a/src/reference/IntermolecularDRMSD.cpp b/src/reference/IntermolecularDRMSD.cpp index f9d19f944c..3025ed4d09 100644 --- a/src/reference/IntermolecularDRMSD.cpp +++ b/src/reference/IntermolecularDRMSD.cpp @@ -39,22 +39,15 @@ PLUMED_REGISTER_METRIC(IntermolecularDRMSD,"INTER-DRMSD") IntermolecularDRMSD::IntermolecularDRMSD( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration( ro ), DRMSD( ro ), - nblocks(0) { + nblocks(0) +{ } void IntermolecularDRMSD::read( const PDB& pdb ) { - readAtomsFromPDB( pdb, true ); - nblocks = pdb.getNumberOfAtomBlocks(); - blocks.resize( nblocks+1 ); - if( nblocks==1 ) { - error("Trying to compute intermolecular rmsd but found no TERs in input PDB"); - } - blocks[0]=0; - for(unsigned i=0; i lower ) { - targets[std::make_pair(iatom,jatom)] = distance; - } + if(distance < upper && distance > lower ) targets[std::make_pair(iatom,jatom)] = distance; } } } diff --git a/src/reference/IntramolecularDRMSD.cpp b/src/reference/IntramolecularDRMSD.cpp index bc8223df0b..4ae85d0e7f 100644 --- a/src/reference/IntramolecularDRMSD.cpp +++ b/src/reference/IntramolecularDRMSD.cpp @@ -39,22 +39,15 @@ PLUMED_REGISTER_METRIC(IntramolecularDRMSD,"INTRA-DRMSD") IntramolecularDRMSD::IntramolecularDRMSD( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration( ro ), DRMSD( ro ), - nblocks(0) { + nblocks(0) +{ } void IntramolecularDRMSD::read( const PDB& pdb ) { - readAtomsFromPDB( pdb, true ); - nblocks = pdb.getNumberOfAtomBlocks(); - blocks.resize( nblocks+1 ); - if( nblocks==1 ) { - error("Trying to compute intramolecular rmsd but found no TERs in input PDB"); - } - blocks[0]=0; - for(unsigned i=0; i lower ) { - targets[std::make_pair(iatom,jatom)] = distance; - } + if(distance < upper && distance > lower ) targets[std::make_pair(iatom,jatom)] = distance; } } } diff --git a/src/reference/MahalanobisDistance.cpp b/src/reference/MahalanobisDistance.cpp index 75585e6e09..6e90183d36 100644 --- a/src/reference/MahalanobisDistance.cpp +++ b/src/reference/MahalanobisDistance.cpp @@ -33,7 +33,8 @@ PLUMED_REGISTER_METRIC(MahalanobisDistance,"MAHALANOBIS") MahalanobisDistance::MahalanobisDistance( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), - ArgumentOnlyDistance(ro) { + ArgumentOnlyDistance(ro) +{ hasmetric=true; } diff --git a/src/reference/MetricRegister.cpp b/src/reference/MetricRegister.cpp index 506cc34f7d..8abaa2dbd7 100644 --- a/src/reference/MetricRegister.cpp +++ b/src/reference/MetricRegister.cpp @@ -27,9 +27,7 @@ namespace PLMD { MetricRegister::~MetricRegister() { if(m.size()>0) { std::string names=""; - for(const auto & p : m) { - names+=p.first+" "; - } + for(const auto & p : m) names+=p.first+" "; std::cerr<<"WARNING: ReferenceConfiguration "+ names +" has not been properly unregistered. This might lead to memory leak!!\n"; } } @@ -42,8 +40,7 @@ MetricRegister& metricRegister() { void MetricRegister::remove(creator_pointer f) { for(auto p=m.begin(); p!=m.end(); ++p) { if((*p).second==f) { - m.erase(p); - break; + m.erase(p); break; } } } @@ -54,9 +51,7 @@ void MetricRegister::add( std::string type, creator_pointer f ) { } bool MetricRegister::check(const std::string & type) { - if( m.count(type)>0 ) { - return true; - } + if( m.count(type)>0 ) return true; return false; } diff --git a/src/reference/MetricRegister.h b/src/reference/MetricRegister.h index a663b90def..cd71772826 100644 --- a/src/reference/MetricRegister.h +++ b/src/reference/MetricRegister.h @@ -86,9 +86,7 @@ std::unique_ptr MetricRegister::create( const std::string& type ) { // if this throws, the unique_ptr conf is deleted. // Notice that with the original version of the code (2.4) an error here // would have lead to a memory leak. - if(!ptr ) { - plumed_merror( type + " metric is not valid in this context"); - } + if(!ptr ) plumed_merror( type + " metric is not valid in this context"); // release ownership in order to transfer it to returned pointer conf.release(); // notice that I should pass ptr here rather than conf.release(), diff --git a/src/reference/MultiDomainRMSD.cpp b/src/reference/MultiDomainRMSD.cpp index d60282a3af..760e562a49 100644 --- a/src/reference/MultiDomainRMSD.cpp +++ b/src/reference/MultiDomainRMSD.cpp @@ -31,47 +31,31 @@ PLUMED_REGISTER_METRIC(MultiDomainRMSD,"MULTI") MultiDomainRMSD::MultiDomainRMSD( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), ReferenceAtoms(ro), - ftype(ro.getMultiRMSDType()) { + ftype(ro.getMultiRMSDType()) +{ } void MultiDomainRMSD::read( const PDB& pdb ) { unsigned nblocks = pdb.getNumberOfAtomBlocks(); - if( nblocks<2 ) { - error("multidomain RMSD only has one block of atoms"); - } + if( nblocks<2 ) error("multidomain RMSD only has one block of atoms"); - std::vector positions; - std::vector align, displace; - std::string num; - blocks.resize( nblocks+1 ); - blocks[0]=0; - for(unsigned i=0; i positions; std::vector align, displace; + std::string num; blocks.resize( nblocks+1 ); blocks[0]=0; + for(unsigned i=0; i::max( ); - if( pdb.getArgumentValue("LOWER_CUTOFF",tmp) ) { - lower=tmp; - } - if( pdb.getArgumentValue("UPPER_CUTOFF",tmp) ) { - upper=tmp; - } + if( pdb.getArgumentValue("LOWER_CUTOFF",tmp) ) lower=tmp; + if( pdb.getArgumentValue("UPPER_CUTOFF",tmp) ) upper=tmp; bool nopbc=pdb.hasFlag("NOPBC"); - domains.resize(0); - weights.resize(0); + domains.resize(0); weights.resize(0); for(unsigned i=1; i<=nblocks; ++i) { Tools::convert(i,num); if( ftype=="RMSD" ) { // parse("TYPE"+num, ftype ); - lower=0.0; - upper=std::numeric_limits::max( ); - if( pdb.getArgumentValue("LOWER_CUTOFF"+num,tmp) ) { - lower=tmp; - } - if( pdb.getArgumentValue("UPPER_CUTOFF"+num,tmp) ) { - upper=tmp; - } + lower=0.0; upper=std::numeric_limits::max( ); + if( pdb.getArgumentValue("LOWER_CUTOFF"+num,tmp) ) lower=tmp; + if( pdb.getArgumentValue("UPPER_CUTOFF"+num,tmp) ) upper=tmp; nopbc=pdb.hasFlag("NOPBC"); } domains.emplace_back( metricRegister().create( ftype ) ); @@ -90,19 +74,12 @@ void MultiDomainRMSD::read( const PDB& pdb ) { domains[i-1]->setupRMSDObject(); double ww=0; - if( !pdb.getArgumentValue("WEIGHT"+num,ww) ) { - weights.push_back( 1.0 ); - } else { - weights.push_back( ww ); - } + if( !pdb.getArgumentValue("WEIGHT"+num,ww) ) weights.push_back( 1.0 ); + else weights.push_back( ww ); } // And set the atom numbers for this object - indices.resize(0); - atom_der_index.resize(0); - for(unsigned i=0; i& conf, const } double MultiDomainRMSD::calculate( const std::vector& pos, const Pbc& pbc, ReferenceValuePack& myder, const bool& squared ) const { - double totd=0.; - Tensor tvirial; - std::vector mypos; - MultiValue tvals( 1, 3*pos.size()+9 ); - ReferenceValuePack tder( 0, getNumberOfAtoms(), tvals ); - myder.clear(); + double totd=0.; Tensor tvirial; std::vector mypos; MultiValue tvals( 1, 3*pos.size()+9 ); + ReferenceValuePack tder( 0, getNumberOfAtoms(), tvals ); myder.clear(); for(unsigned i=0; isetupPCAStorage( tder ); - } - unsigned n=0; - for(unsigned j=blocks[i]; jsetupPCAStorage( tder ); + unsigned n=0; for(unsigned j=blocks[i]; jcalculate( mypos, pbc, tder, true ); // Now merge the derivative @@ -140,34 +104,24 @@ double MultiDomainRMSD::calculate( const std::vector& pos, const Pbc& pb // If PCA copy PCA stuff if( myder.calcUsingPCAOption() ) { unsigned n=0; - if( tder.centeredpos.size()>0 ) { - myder.rot[i]=tder.rot[0]; - } + if( tder.centeredpos.size()>0 ) myder.rot[i]=tder.rot[0]; for(unsigned j=blocks[i]; j0 ) { myder.centeredpos[j]=tder.centeredpos[n]; - for(unsigned p=0; p<3; ++p) - for(unsigned q=0; q<3; ++q) { - myder.DRotDPos(p,q)[j]=tder.DRotDPos(p,q)[n]; - } + for(unsigned p=0; p<3; ++p) for(unsigned q=0; q<3; ++q) myder.DRotDPos(p,q)[j]=tder.DRotDPos(p,q)[n]; } n++; } } // Make sure virial status is set correctly in output derivative pack // This is only done here so I do this by using class friendship - if( tder.virialWasSet() ) { - myder.boxWasSet=true; - } - } - if( !myder.updateComplete() ) { - myder.updateDynamicLists(); + if( tder.virialWasSet() ) myder.boxWasSet=true; } + if( !myder.updateComplete() ) myder.updateDynamicLists(); if( !squared ) { - totd=std::sqrt(totd); - double xx=0.5/totd; + totd=std::sqrt(totd); double xx=0.5/totd; myder.scaleAllDerivatives( xx ); } return totd; @@ -182,9 +136,7 @@ double MultiDomainRMSD::calc( const std::vector& pos, const Pbc& pbc, co bool MultiDomainRMSD::pcaIsEnabledForThisReference() { bool enabled=true; for(unsigned i=0; ipcaIsEnabledForThisReference() ) { - enabled=false; - } + if( !domains[i]->pcaIsEnabledForThisReference() ) enabled=false; } return enabled; } @@ -194,12 +146,8 @@ void MultiDomainRMSD::setupPCAStorage( ReferenceValuePack& mypack ) { mypack.switchOnPCAOption(); mypack.displacement.resize( getNumberOfAtoms() ); mypack.centeredpos.resize( getNumberOfAtoms() ); - mypack.DRotDPos.resize(3,3); - mypack.rot.resize( domains.size() ); - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - mypack.DRotDPos(i,j).resize( getNumberOfAtoms() ); - } + mypack.DRotDPos.resize(3,3); mypack.rot.resize( domains.size() ); + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) mypack.DRotDPos(i,j).resize( getNumberOfAtoms() ); } // Vector MultiDomainRMSD::getAtomicDisplacement( const unsigned& iatom ){ @@ -216,61 +164,36 @@ void MultiDomainRMSD::extractAtomicDisplacement( const std::vector& pos, std::vector mypos, mydir; for(unsigned i=0; iextractAtomicDisplacement( mypos, mydir ); // Extract the direction - n=0; - for(unsigned j=blocks[i]; j& vecs, ReferenceValuePack& mypack ) const { - double totd=0.; - std::vector tvecs; - mypack.clear(); - MultiValue tvals( 1, mypack.getNumberOfDerivatives() ); - ReferenceValuePack tder( 0, getNumberOfAtoms(), tvals ); + double totd=0.; std::vector tvecs; mypack.clear(); + MultiValue tvals( 1, mypack.getNumberOfDerivatives() ); ReferenceValuePack tder( 0, getNumberOfAtoms(), tvals ); for(unsigned i=0; isetupPCAStorage( tder ); + tvecs.resize( blocks[i+1] - blocks[i] ); domains[i]->setupPCAStorage( tder ); if( tder.centeredpos.size()>0 ) { - for(unsigned p=0; p<3; ++p) - for(unsigned q=0; q<3; ++q) { - tder.DRotDPos(p,q).resize( tvecs.size() ); - } + for(unsigned p=0; p<3; ++p) for(unsigned q=0; q<3; ++q) tder.DRotDPos(p,q).resize( tvecs.size() ); } // Extract information from storage pack and put in local pack - if( tder.centeredpos.size()>0 ) { - tder.rot[0]=mypack.rot[i]; - } + if( tder.centeredpos.size()>0 ) tder.rot[0]=mypack.rot[i]; unsigned n=0; for(unsigned j=blocks[i]; j0 ) { tder.centeredpos[n]=mypack.centeredpos[j]; - for(unsigned p=0; p<3; ++p) - for(unsigned q=0; q<3; ++q) { - tder.DRotDPos(p,q)[n]=mypack.DRotDPos(p,q)[j]; - } + for(unsigned p=0; p<3; ++p) for(unsigned q=0; q<3; ++q) tder.DRotDPos(p,q)[n]=mypack.DRotDPos(p,q)[j]; } n++; } - for(unsigned k=n; kprojectAtomicDisplacementOnVector( normalized, tvecs, tder ); @@ -278,9 +201,7 @@ double MultiDomainRMSD::projectAtomicDisplacementOnVector( const bool& normalize // And derivatives mypack.copyScaledDerivatives( 0, weights[i], tvals ); } - if( !mypack.updateComplete() ) { - mypack.updateDynamicLists(); - } + if( !mypack.updateComplete() ) mypack.updateDynamicLists(); return totd; } diff --git a/src/reference/NormalizedEuclideanDistance.cpp b/src/reference/NormalizedEuclideanDistance.cpp index af08099298..03cdcac0bc 100644 --- a/src/reference/NormalizedEuclideanDistance.cpp +++ b/src/reference/NormalizedEuclideanDistance.cpp @@ -33,7 +33,8 @@ PLUMED_REGISTER_METRIC(NormalizedEuclideanDistance,"NORM-EUCLIDEAN") NormalizedEuclideanDistance::NormalizedEuclideanDistance( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), - ArgumentOnlyDistance(ro) { + ArgumentOnlyDistance(ro) +{ hasweights=true; } diff --git a/src/reference/OptimalRMSD.cpp b/src/reference/OptimalRMSD.cpp index acf52bcf3c..f680ee9643 100644 --- a/src/reference/OptimalRMSD.cpp +++ b/src/reference/OptimalRMSD.cpp @@ -34,19 +34,13 @@ class OptimalRMSD : public RMSDBase { explicit OptimalRMSD(const ReferenceConfigurationOptions& ro); void read( const PDB& ) override; double calc( const std::vector& pos, ReferenceValuePack& myder, const bool& squared ) const override; - bool pcaIsEnabledForThisReference() override { - return true; - } - void setupRMSDObject() override { - myrmsd.clear(); - myrmsd.set(getAlign(),getDisplace(),getReferencePositions(),"OPTIMAL"); - } + bool pcaIsEnabledForThisReference() override { return true; } + void setupRMSDObject() override { myrmsd.clear(); myrmsd.set(getAlign(),getDisplace(),getReferencePositions(),"OPTIMAL"); } void setupPCAStorage( ReferenceValuePack& mypack ) override { mypack.switchOnPCAOption(); mypack.centeredpos.resize( getNumberOfAtoms() ); mypack.displacement.resize( getNumberOfAtoms() ); - mypack.DRotDPos.resize(3,3); - mypack.rot.resize(1); + mypack.DRotDPos.resize(3,3); mypack.rot.resize(1); } void extractAtomicDisplacement( const std::vector& pos, std::vector& direction ) const override; double projectAtomicDisplacementOnVector( const bool& normalized, const std::vector& vecs, ReferenceValuePack& mypack ) const override; @@ -56,13 +50,13 @@ PLUMED_REGISTER_METRIC(OptimalRMSD,"OPTIMAL") OptimalRMSD::OptimalRMSD(const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), - RMSDBase(ro) { + RMSDBase(ro) +{ fast=ro.usingFastOption(); } void OptimalRMSD::read( const PDB& pdb ) { - readReference( pdb ); - setupRMSDObject(); + readReference( pdb ); setupRMSDObject(); } double OptimalRMSD::calc( const std::vector& pos, ReferenceValuePack& myder, const bool& squared ) const { @@ -71,87 +65,52 @@ double OptimalRMSD::calc( const std::vector& pos, ReferenceValuePack& my std::vector centeredreference( getNumberOfAtoms () ); d=myrmsd.calc_PCAelements(pos,myder.getAtomVector(),myder.rot[0],myder.DRotDPos,myder.getAtomsDisplacementVector(),myder.centeredpos,centeredreference,squared); unsigned nat = pos.size(); - for(unsigned i=0; i(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); - } else { - d=myrmsd.optimalAlignment(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); - } + if( getAlign()==getDisplace() ) d=myrmsd.optimalAlignment(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); + else d=myrmsd.optimalAlignment(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); } else { - if( getAlign()==getDisplace() ) { - d=myrmsd.optimalAlignment(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); - } else { - d=myrmsd.optimalAlignment(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); - } - } - myder.clear(); - for(unsigned i=0; i(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); + else d=myrmsd.optimalAlignment(getAlign(),getDisplace(),pos,getReferencePositions(),myder.getAtomVector(),squared); } + myder.clear(); for(unsigned i=0; i& pos, std::vector& direction ) const { - std::vector rot(1); - Matrix > DRotDPos( 3, 3 ); + std::vector rot(1); Matrix > DRotDPos( 3, 3 ); std::vector centeredreference( getNumberOfAtoms() ), centeredpos( getNumberOfAtoms() ), avector( getNumberOfAtoms() ); myrmsd.calc_PCAelements(pos,avector,rot[0],DRotDPos,direction,centeredpos,centeredreference,true); - unsigned nat = pos.size(); - for(unsigned i=0; i& vecs, ReferenceValuePack& mypack ) const { plumed_dbg_assert( mypack.calcUsingPCAOption() ); - double proj=0.0; - mypack.clear(); + double proj=0.0; mypack.clear(); for(unsigned i=0; i( getNumberOfAtoms() ); - for(unsigned n=0; n( getNumberOfAtoms() ); + for(unsigned n=0; n& pos, ReferenceValuePack& myder, const bool& squared ) const { diff --git a/src/reference/ReferenceArguments.cpp b/src/reference/ReferenceArguments.cpp index b9f8a41f3e..15d70732c1 100644 --- a/src/reference/ReferenceArguments.cpp +++ b/src/reference/ReferenceArguments.cpp @@ -30,42 +30,32 @@ namespace PLMD { ReferenceArguments::ReferenceArguments( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration(ro), hasweights(false), - hasmetric(false) { + hasmetric(false) +{ } void ReferenceArguments::readArgumentsFromPDB( const PDB& pdb ) { ReferenceAtoms* aref=dynamic_cast( this ); arg_names.resize( pdb.getArgumentNames().size() ); - for(unsigned i=0; i& arg_v unsigned k=0; for(unsigned i=0; i& arg_vals ) { plumed_dbg_assert( reference_args.size()==arg_vals.size() ); - for(unsigned i=0; i& argout, bool disable_checks ) { @@ -120,28 +102,19 @@ void ReferenceArguments::getArgumentRequests( std::vector& argout, } } else { if(!disable_checks) { - if( arg_names.size()!=argout.size() ) { - error("mismatched numbers of arguments in pdb frames"); - } + if( arg_names.size()!=argout.size() ) error("mismatched numbers of arguments in pdb frames"); } for(unsigned i=0; i& argout, const std::vector& ReferenceArguments::getReferenceMetric() { if( hasmetric ) { unsigned ntot=(reference_args.size() / 2 )*(reference_args.size()+1); - if( trig_metric.size()!=ntot ) { - trig_metric.resize( ntot ); - } + if( trig_metric.size()!=ntot ) trig_metric.resize( ntot ); unsigned k=0; for(unsigned i=0; i & vals, const std::vector& arg, ReferenceValuePack& myder, const bool& squared ) const { - double r=0; - std::vector arg_ders( vals.size() ); + double r=0; std::vector arg_ders( vals.size() ); if( hasmetric ) { for(unsigned i=0; idifference( reference_args[i], arg[ik] ); for(unsigned j=0; jdifference( reference_args[j], arg[jk] ); - } + if(i==j) dp_j=dp_i; + else dp_j=vals[jk]->difference( reference_args[j], arg[jk] ); arg_ders[ ik ]+=2.0*metric(i,j)*dp_j; // Factor of two for off diagonal terms as you have terms from ij and ji r+=dp_i*dp_j*metric(i,j); @@ -199,20 +160,14 @@ double ReferenceArguments::calculateArgumentDistance( const std::vector for(unsigned i=0; idifference( reference_args[i], arg[ik] ); - r+=weights[i]*dp_i*dp_i; - arg_ders[ik]=2.0*weights[i]*dp_i; + r+=weights[i]*dp_i*dp_i; arg_ders[ik]=2.0*weights[i]*dp_i; } } if(!squared) { - r=std::sqrt(r); - double ir=1.0/(2.0*r); - for(unsigned i=0; i& plumed_error(); } else { for(unsigned j=0; jdifference( reference_args[j], arg[jk] ); + unsigned jk=arg_der_index[j]; dirout[jk]=sqrtweight[j]*vals[jk]->difference( reference_args[j], arg[jk] ); } } } @@ -244,9 +198,7 @@ double ReferenceArguments::projectArgDisplacementOnVector( const std::vector& displace ) { plumed_dbg_assert( displace.size()==getNumberOfReferenceArguments() ); - for(unsigned i=0; i& numbers, boo } } else { if(!disable_checks) { - if( numbers.size()!=indices.size() ) { - error("mismatched numbers of atoms in pdb frames"); - } + if( numbers.size()!=indices.size() ) error("mismatched numbers of atoms in pdb frames"); } for(unsigned i=0; i& numbers, boo void ReferenceAtoms::displaceReferenceAtoms( const double& weight, const std::vector& dir ) { plumed_dbg_assert( dir.size()==reference_atoms.size() ); - for(unsigned i=0; i& pos, const Pbc& pbc, const std::vector& vals, ReferenceValuePack& myder, const bool& squared ) const { std::vector tmparg( vals.size() ); - for(unsigned i=0; iget(); - } + for(unsigned i=0; iget(); return calc( pos, pbc, vals, tmparg, myder, squared ); } void ReferenceConfiguration::displaceReferenceConfiguration( const double& weight, Direction& dir ) { ReferenceArguments* args=dynamic_cast(this); - if( args ) { - args->displaceReferenceArguments( weight, dir.getReferenceArguments() ); - } + if( args ) args->displaceReferenceArguments( weight, dir.getReferenceArguments() ); ReferenceAtoms* atoms=dynamic_cast(this); - if( atoms ) { - atoms->displaceReferenceAtoms( weight, dir.getReferencePositions() ); - } + if( atoms ) atoms->displaceReferenceAtoms( weight, dir.getReferencePositions() ); } void ReferenceConfiguration::extractDisplacementVector( const std::vector& pos, const std::vector& vals, const std::vector& arg, const bool& nflag, Direction& mydir ) const { const ReferenceAtoms* atoms=dynamic_cast( this ); - if( atoms ) { - atoms->extractAtomicDisplacement( pos, mydir.reference_atoms ); - } + if( atoms ) atoms->extractAtomicDisplacement( pos, mydir.reference_atoms ); const ReferenceArguments* args=dynamic_cast( this ); - if( args ) { - args->extractArgumentDisplacement( vals, arg, mydir.reference_args ); - } + if( args ) args->extractArgumentDisplacement( vals, arg, mydir.reference_args ); // Normalize direction if required if( nflag ) { // Calculate length of vector - double tmp, norm=0; - mydir.normalized = true; + double tmp, norm=0; mydir.normalized = true; for(unsigned i=0; i( this ); - if( atoms ) { - proj += atoms->projectAtomicDisplacementOnVector( mydir.normalized, mydir.getReferencePositions(), mypack ); - } + if( atoms ) proj += atoms->projectAtomicDisplacementOnVector( mydir.normalized, mydir.getReferencePositions(), mypack ); const ReferenceArguments* args=dynamic_cast( this ); - if( args ) { - proj += args->projectArgDisplacementOnVector( mydir.getReferenceArguments(), vals, arg, mypack ); - } + if( args ) proj += args->projectArgDisplacementOnVector( mydir.getReferenceArguments(), vals, arg, mypack ); return proj; } double distance( const Pbc& pbc, const std::vector & vals, ReferenceConfiguration* ref1, ReferenceConfiguration* ref2, const bool& squared ) { unsigned nder; - if( ref1->getReferencePositions().size()>0 ) { - nder=ref1->getReferenceArguments().size() + 3*ref1->getReferencePositions().size() + 9; - } else { - nder=ref1->getReferenceArguments().size(); - } + if( ref1->getReferencePositions().size()>0 ) nder=ref1->getReferenceArguments().size() + 3*ref1->getReferencePositions().size() + 9; + else nder=ref1->getReferenceArguments().size(); - MultiValue myvals( 1, nder ); - ReferenceValuePack myder( ref1->getReferenceArguments().size(), ref1->getReferencePositions().size(), myvals ); + MultiValue myvals( 1, nder ); ReferenceValuePack myder( ref1->getReferenceArguments().size(), ref1->getReferencePositions().size(), myvals ); double dist1=ref1->calc( ref2->getReferencePositions(), pbc, vals, ref2->getReferenceArguments(), myder, squared ); #ifndef NDEBUG // Check that A - B = B - A diff --git a/src/reference/ReferenceConfiguration.h b/src/reference/ReferenceConfiguration.h index 3e064cb531..d752ce3f63 100644 --- a/src/reference/ReferenceConfiguration.h +++ b/src/reference/ReferenceConfiguration.h @@ -111,9 +111,7 @@ class ReferenceConfiguration { /// Copy derivatives from one frame to this frame void copyDerivatives( const ReferenceConfiguration* ); /// Get one of the referene arguments - virtual double getReferenceArgument( const unsigned& i ) const { - plumed_error(); - } + virtual double getReferenceArgument( const unsigned& i ) const { plumed_error(); } /// These are overwritten in ReferenceArguments and ReferenceAtoms but are required here /// to make PLMD::distance work virtual const std::vector& getReferencePositions() const ; @@ -127,15 +125,11 @@ class ReferenceConfiguration { const std::vector& arg, const bool& nflag, Direction& mydir ) const ; /// Stuff for pca - virtual bool pcaIsEnabledForThisReference() { - return false; - } + virtual bool pcaIsEnabledForThisReference() { return false; } double projectDisplacementOnVector( const Direction& mydir, const std::vector& vals, const std::vector& arg, ReferenceValuePack& mypack ) const ; /// Stuff to setup pca - virtual void setupPCAStorage( ReferenceValuePack& mypack ) { - plumed_error(); - } + virtual void setupPCAStorage( ReferenceValuePack& mypack ) { plumed_error(); } /// Move the reference configuration by an amount specified using a Direction void displaceReferenceConfiguration( const double& weight, Direction& dir ); }; diff --git a/src/reference/ReferenceValuePack.cpp b/src/reference/ReferenceValuePack.cpp index ea0005992d..d3cacac992 100644 --- a/src/reference/ReferenceValuePack.cpp +++ b/src/reference/ReferenceValuePack.cpp @@ -29,34 +29,24 @@ ReferenceValuePack::ReferenceValuePack( const unsigned& nargs, const unsigned& n oind_set(false), myvals(vals), atom_indices(myvals.getIndices()), - pca(false) { - if( atom_indices.size()!=natoms ) { - atom_indices.resize( natoms ); - myvals.getAtomVector().resize( natoms ); - } - if( vals.getNumberOfValues()==1 ) { - oind=0; - oind_set=true; - } + pca(false) +{ + if( atom_indices.size()!=natoms ) { atom_indices.resize( natoms ); myvals.getAtomVector().resize( natoms ); } + if( vals.getNumberOfValues()==1 ) { oind=0; oind_set=true; } } void ReferenceValuePack::resize( const unsigned& nargs, const unsigned& natoms ) { - numberOfArgs=nargs; - atom_indices.resize( natoms ); + numberOfArgs=nargs; atom_indices.resize( natoms ); myvals.getAtomVector().resize( natoms ); } void ReferenceValuePack::updateDynamicLists() { myvals.emptyActiveMembers(); - for(unsigned i=0; i0 ); - boxWasSet=true; - unsigned nbase = myvals.getNumberOfDerivatives() - 9; - for(unsigned i=0; i<3; ++i) - for(unsigned j=0; j<3; ++j) { - myvals.addDerivative( oind, nbase + 3*i + j, vir(i,j) ); - } + boxWasSet=true; unsigned nbase = myvals.getNumberOfDerivatives() - 9; + for(unsigned i=0; i<3; ++i) for(unsigned j=0; j<3; ++j) myvals.addDerivative( oind, nbase + 3*i + j, vir(i,j) ); } inline void ReferenceValuePack::setValIndex( const unsigned& ind ) { - oind=ind; - oind_set=true; + oind=ind; oind_set=true; } inline @@ -191,8 +183,7 @@ bool ReferenceValuePack::virialWasSet() const { inline Vector ReferenceValuePack::getAtomDerivative( const unsigned& iatom ) const { - Vector tmp; - plumed_dbg_assert( oind_set && iatom& pos, ReferenceValuePack& myder, const bool& squared ) const override; - bool pcaIsEnabledForThisReference() override { - return true; - } + bool pcaIsEnabledForThisReference() override { return true; } void setupPCAStorage( ReferenceValuePack& mypack ) override { - mypack.switchOnPCAOption(); - mypack.getAtomsDisplacementVector().resize( getNumberOfAtoms() ); + mypack.switchOnPCAOption(); mypack.getAtomsDisplacementVector().resize( getNumberOfAtoms() ); } void extractAtomicDisplacement( const std::vector& pos, std::vector& direction ) const override; double projectAtomicDisplacementOnVector( const bool& normalized, const std::vector& vecs, ReferenceValuePack& mypack ) const override; @@ -47,7 +44,8 @@ PLUMED_REGISTER_METRIC(SimpleRMSD,"SIMPLE") SimpleRMSD::SimpleRMSD( const ReferenceConfigurationOptions& ro ): ReferenceConfiguration( ro ), - RMSDBase( ro ) { + RMSDBase( ro ) +{ } void SimpleRMSD::read( const PDB& pdb ) { @@ -55,49 +53,33 @@ void SimpleRMSD::read( const PDB& pdb ) { } double SimpleRMSD::calc( const std::vector& pos, ReferenceValuePack& myder, const bool& squared ) const { - if( myder.getAtomsDisplacementVector().size()!=pos.size() ) { - myder.getAtomsDisplacementVector().resize( pos.size() ); - } + if( myder.getAtomsDisplacementVector().size()!=pos.size() ) myder.getAtomsDisplacementVector().resize( pos.size() ); double d=myrmsd.simpleAlignment( getAlign(), getDisplace(), pos, getReferencePositions(), myder.getAtomVector(), myder.getAtomsDisplacementVector(), squared ); - myder.clear(); - for(unsigned i=0; i& pos, std::vector& direction ) const { std::vector tder( getNumberOfAtoms() ); myrmsd.simpleAlignment( getAlign(), getDisplace(), pos, getReferencePositions(), tder, direction, true ); - for(unsigned i=0; i& vecs, ReferenceValuePack& mypack ) const { - plumed_dbg_assert( mypack.calcUsingPCAOption() ); - Vector comder; - comder.zero(); + plumed_dbg_assert( mypack.calcUsingPCAOption() ); Vector comder; comder.zero(); for(unsigned j=0; jepsilon) { double w=1.0/wa; - for(unsigned i=0; iepsilon) { double w=1.0/wd; - for(unsigned i=0; i& conf, const std::vector& align_in, const std::vector& displace_in ) { - reference_atoms.resize( conf.size() ); - align.resize( conf.size() ); - displace.resize( conf.size() ); - atom_der_index.resize( conf.size() ); + reference_atoms.resize( conf.size() ); align.resize( conf.size() ); + displace.resize( conf.size() ); atom_der_index.resize( conf.size() ); double wa=0, wd=0; - for(unsigned i=0; iepsilon) { double w=1.0/wa; - for(unsigned i=0; iepsilon) { double w=1.0/wd; - for(unsigned i=0; i(main_atoms,heavy_atoms,serial_,dopair,pbc_,getPbc(),comm,nl_cut,nl_st); - } else { + } + else { nl=Tools::make_unique(main_atoms,heavy_atoms,serial_,dopair,pbc_,getPbc(),comm); } @@ -203,16 +201,15 @@ S2ContactModel::S2ContactModel(const ActionOptions&ao): log << plumed.cite("Ming and Bruschweiler, J. Biomol. NMR, 29, 363 (2004) - DOI:10.1023/B:JNMR.0000032612.70767.35"); log.printf("\n"); log.printf(" calculation of methyl order parameter using atom %d \n",methyl_atom[0].serial()); - } else if(modeltype_==nh) { + } + else if(modeltype_==nh) { log << plumed.cite("Zhang and Bruschweiler, J. Am. Chem. Soc. 124, 12654 (2002) - DOI:10.1021/ja027847a"); log.printf("\n"); log.printf(" calculation of NH order parameter using atoms %d and %d\n",nh_atoms[0].serial(),nh_atoms[1].serial()); } log.printf(" heavy atoms used in the calculation (%u in total):\n",static_cast(heavy_atoms.size())); for(unsigned int i=0; igetReducedAtomList()); invalidateList=false; - if(getExchangeStep()) { - error("Neighbor lists should be updated on exchange steps - choose a NL_STRIDE which divides the exchange stride!"); - } - } - if(getExchangeStep()) { - firsttime=true; + if(getExchangeStep()) error("Neighbor lists should be updated on exchange steps - choose a NL_STRIDE which divides the exchange stride!"); } + if(getExchangeStep()) firsttime=true; } } @@ -289,9 +282,7 @@ void S2ContactModel::calculate() { Vector distance; unsigned int i0=nl->getClosePair(i).first; unsigned int i1=nl->getClosePair(i).second; - if(getAbsoluteIndex(i0)==getAbsoluteIndex(i1)) { - continue; - } + if(getAbsoluteIndex(i0)==getAbsoluteIndex(i1)) {continue;} if(pbc_) { distance=pbcDistance(getPosition(i0),getPosition(i1)); diff --git a/src/sasa/sasa_HASEL.cpp b/src/sasa/sasa_HASEL.cpp index 1859ac9cfa..3d421f9b08 100644 --- a/src/sasa/sasa_HASEL.cpp +++ b/src/sasa/sasa_HASEL.cpp @@ -181,42 +181,32 @@ SASA_HASEL::SASA_HASEL(const ActionOptions&ao): nl_update(0), DeltaGValues("absent"), Ti(0), - firstStepFlag(0) { + firstStepFlag(0) +{ rs = 0.14; parse("DELTAGFILE",DeltaGValues); parse("APPROACH", approach); parseAtomList("ATOMS",atoms); - if(atoms.size()==0) { - error("no atoms specified"); - } + if(atoms.size()==0) error("no atoms specified"); std::string Type; parse("TYPE",Type); parse("NL_STRIDE", stride); parseFlag("NOPBC",nopbc); checkRead(); - if(Type=="TOTAL") { - sasa_type=TOTAL; - } else if(Type=="TRANSFER") { - sasa_type=TRANSFER; - } else { - error("Unknown SASA type"); - } + if(Type=="TOTAL") sasa_type=TOTAL; + else if(Type=="TRANSFER") sasa_type=TRANSFER; + else error("Unknown SASA type"); - switch(sasa_type) { - case TOTAL: - log.printf(" TOTAL SASA;"); - break; - case TRANSFER: - log.printf(" TRANSFER MODEL;"); - break; + switch(sasa_type) + { + case TOTAL: log.printf(" TOTAL SASA;"); break; + case TRANSFER: log.printf(" TRANSFER MODEL;"); break; } log.printf(" atoms involved : "); for(unsigned i=0; i -void split(const std::string& str, Container& cont) { +void split(const std::string& str, Container& cont) +{ std::istringstream iss(str); std::copy(std::istream_iterator(iss), std::istream_iterator(), @@ -258,9 +248,7 @@ void split(const std::string& str, Container& cont) { void SASA_HASEL::readPDB() { auto* moldat = plumed.getActionSet().selectLatest(this); - if( ! moldat ) { - error("Unable to find MOLINFO in input"); - } + if( ! moldat ) error("Unable to find MOLINFO in input"); AtomResidueName[0].clear(); AtomResidueName[1].clear(); @@ -598,12 +586,9 @@ void SASA_HASEL::readDeltaG() { } } } - if ( backboneflag == 0) { - error("Cannot find backbone value in Delta G parameters file\n"); - } - } else { - error("Cannot open DeltaG file"); + if ( backboneflag == 0) error("Cannot find backbone value in Delta G parameters file\n"); } + else error("Cannot open DeltaG file"); for(unsigned i=0; i(this); - if( ! moldat ) { - error("Unable to find MOLINFO in input"); - } + if( ! moldat ) error("Unable to find MOLINFO in input"); double Si, sasai, bij; double sasa = 0; vector derivatives( natoms ); diff --git a/src/sasa/sasa_LCPO.cpp b/src/sasa/sasa_LCPO.cpp index a4ef8cb475..0d5bf5d08c 100755 --- a/src/sasa/sasa_LCPO.cpp +++ b/src/sasa/sasa_LCPO.cpp @@ -179,42 +179,32 @@ SASA_LCPO::SASA_LCPO(const ActionOptions&ao): Ti(0), stride(10), nl_update(0), - firstStepFlag(0) { + firstStepFlag(0) +{ rs = 0.14; parse("DELTAGFILE",DeltaGValues); parse("APPROACH", approach); parseAtomList("ATOMS",atoms); - if(atoms.size()==0) { - error("no atoms specified"); - } + if(atoms.size()==0) error("no atoms specified"); std::string Type; parse("TYPE",Type); parse("NL_STRIDE", stride); parseFlag("NOPBC",nopbc); checkRead(); - if(Type=="TOTAL") { - sasa_type=TOTAL; - } else if(Type=="TRANSFER") { - sasa_type=TRANSFER; - } else { - error("Unknown SASA type"); - } + if(Type=="TOTAL") sasa_type=TOTAL; + else if(Type=="TRANSFER") sasa_type=TRANSFER; + else error("Unknown SASA type"); - switch(sasa_type) { - case TOTAL: - log.printf(" TOTAL SASA;"); - break; - case TRANSFER: - log.printf(" TRANSFER MODEL;"); - break; + switch(sasa_type) + { + case TOTAL: log.printf(" TOTAL SASA;"); break; + case TRANSFER: log.printf(" TRANSFER MODEL;"); break; } log.printf(" atoms involved : "); for(unsigned i=0; i -void split(const std::string& str, Container& cont) { +void split(const std::string& str, Container& cont) +{ std::istringstream iss(str); std::copy(std::istream_iterator(iss), std::istream_iterator(), @@ -255,9 +245,7 @@ void split(const std::string& str, Container& cont) { void SASA_LCPO::readPDB() { auto* moldat = plumed.getActionSet().selectLatest(this); - if( ! moldat ) { - error("Unable to find MOLINFO in input"); - } + if( ! moldat ) error("Unable to find MOLINFO in input"); AtomResidueName[0].clear(); AtomResidueName[1].clear(); @@ -564,12 +552,9 @@ void SASA_LCPO::readDeltaG() { } } } - if ( backboneflag == 0) { - error("Cannot find backbone value in Delta G parameters file\n"); - } - } else { - error("Cannot open DeltaG file"); + if ( backboneflag == 0) error("Cannot find backbone value in Delta G parameters file\n"); } + else error("Cannot open DeltaG file"); for(unsigned i=0; i 0 ) { - sasa += sasai/100; - } + if (sasai > 0 ) sasa += sasai/100; derivatives[i][0] += (dAijdc_2[0]*LCPOparam[i][2]+dAijdc_4[0]*LCPOparam[i][4])/10; derivatives[i][1] += (dAijdc_2[1]*LCPOparam[i][2]+dAijdc_4[1]*LCPOparam[i][4])/10; derivatives[i][2] += (dAijdc_2[2]*LCPOparam[i][2]+dAijdc_4[2]*LCPOparam[i][4])/10; @@ -1069,18 +1046,14 @@ void SASA_LCPO::calculate() { double sasai = (LCPOparam[i][1]*S1+LCPOparam[i][2]*Aij+LCPOparam[i][3]*Ajk+LCPOparam[i][4]*Aijk); if (AtomResidueName[0][i] == "N" || AtomResidueName[0][i] == "CA" || AtomResidueName[0][i] == "C" || AtomResidueName[0][i] == "O") { - if (sasai > 0 ) { - sasa += (sasai/MaxSurf[i][0]*DeltaG[natoms][0]); - } + if (sasai > 0 ) sasa += (sasai/MaxSurf[i][0]*DeltaG[natoms][0]); derivatives[i][0] += ((dAijdc_2[0]*LCPOparam[i][2]+dAijdc_4[0]*LCPOparam[i][4])/MaxSurf[i][0]*DeltaG[natoms][0])*10; derivatives[i][1] += ((dAijdc_2[1]*LCPOparam[i][2]+dAijdc_4[1]*LCPOparam[i][4])/MaxSurf[i][0]*DeltaG[natoms][0])*10; derivatives[i][2] += ((dAijdc_2[2]*LCPOparam[i][2]+dAijdc_4[2]*LCPOparam[i][4])/MaxSurf[i][0]*DeltaG[natoms][0])*10; } if (AtomResidueName[0][i] != "N" && AtomResidueName[0][i] != "CA" && AtomResidueName[0][i] != "C" && AtomResidueName[0][i] != "O") { - if (sasai > 0. ) { - sasa += (sasai/MaxSurf[i][1]*DeltaG[i][0]); - } + if (sasai > 0. ) sasa += (sasai/MaxSurf[i][1]*DeltaG[i][0]); derivatives[i][0] += ((dAijdc_2[0]*LCPOparam[i][2]+dAijdc_4[0]*LCPOparam[i][4])/MaxSurf[i][1]*DeltaG[i][0])*10; derivatives[i][1] += ((dAijdc_2[1]*LCPOparam[i][2]+dAijdc_4[1]*LCPOparam[i][4])/MaxSurf[i][1]*DeltaG[i][0])*10; derivatives[i][2] += ((dAijdc_2[2]*LCPOparam[i][2]+dAijdc_4[2]*LCPOparam[i][4])/MaxSurf[i][1]*DeltaG[i][0])*10; @@ -1092,9 +1065,7 @@ void SASA_LCPO::calculate() { } - for(unsigned i=0; i chains; - readBackboneAtoms( "protein", chains); + std::vector chains; readBackboneAtoms( "protein", chains); // This constructs all conceivable sections of alpha helix in the backbone of the chains - unsigned nprevious=0; - std::vector nlist(30); + unsigned nprevious=0; std::vector nlist(30); for(unsigned i=0; i chains; - readBackboneAtoms( "protein", chains ); + std::vector chains; readBackboneAtoms( "protein", chains ); bool intra_chain(false), inter_chain(false); - std::string style; - parse("STYLE",style); + std::string style; parse("STYLE",style); if( style=="all" ) { - intra_chain=true; - inter_chain=true; + intra_chain=true; inter_chain=true; } else if( style=="inter") { - intra_chain=false; - inter_chain=true; + intra_chain=false; inter_chain=true; } else if( style=="intra") { - intra_chain=true; - inter_chain=false; + intra_chain=true; inter_chain=false; } else { error( style + " is not a valid directive for the STYLE keyword"); } @@ -131,17 +127,12 @@ AntibetaRMSD::AntibetaRMSD(const ActionOptions&ao): // This constructs all conceivable sections of antibeta sheet in the backbone of the chains if( intra_chain ) { - unsigned nprevious=0; - std::vector nlist(30); + unsigned nprevious=0; std::vector nlist(30); for(unsigned i=0; i nlist(30); for(unsigned ichain=1; ichain chains; - readBackboneAtoms( "protein", chains ); + std::vector chains; readBackboneAtoms( "protein", chains ); bool intra_chain(false), inter_chain(false); - std::string style; - parse("STYLE",style); + std::string style; parse("STYLE",style); if( style=="all" ) { - intra_chain=true; - inter_chain=true; + intra_chain=true; inter_chain=true; } else if( style=="inter") { - intra_chain=false; - inter_chain=true; + intra_chain=false; inter_chain=true; } else if( style=="intra") { - intra_chain=true; - inter_chain=false; + intra_chain=true; inter_chain=false; } else { error( style + " is not a valid directive for the STYLE keyword"); } @@ -132,17 +128,12 @@ ParabetaRMSD::ParabetaRMSD(const ActionOptions&ao): // This constructs all conceivable sections of antibeta sheet in the backbone of the chains if( intra_chain ) { - unsigned nprevious=0; - std::vector nlist(30); + unsigned nprevious=0; std::vector nlist(30); for(unsigned i=0; i nlist(30); for(unsigned ichain=1; ichain0) { - log.printf(" ignoring contributions from strands that are more than %f apart\n",s_cutoff); - } + parse("STRANDS_CUTOFF",s_cutoff); align_strands=true; + if( s_cutoff>0) log.printf(" ignoring contributions from strands that are more than %f apart\n",s_cutoff); s_cutoff2=s_cutoff*s_cutoff; } } @@ -113,28 +105,21 @@ void SecondaryStructureRMSD::turnOnDerivatives() { } void SecondaryStructureRMSD::setAtomsFromStrands( const unsigned& atom1, const unsigned& atom2 ) { - align_atom_1=atom1; - align_atom_2=atom2; + align_atom_1=atom1; align_atom_2=atom2; } void SecondaryStructureRMSD::readBackboneAtoms( const std::string& moltype, std::vector& chain_lengths ) { auto* moldat=plumed.getActionSet().selectLatest(this); - if( ! moldat ) { - error("Unable to find MOLINFO in input"); - } + if( ! moldat ) error("Unable to find MOLINFO in input"); - std::vector resstrings; - parseVector( "RESIDUES", resstrings ); + std::vector resstrings; parseVector( "RESIDUES", resstrings ); if( !verbose_output ) { - if(resstrings.size()==0) { - error("residues are not defined, check the keyword RESIDUES"); - } else if(resstrings[0]=="all") { + if(resstrings.size()==0) error("residues are not defined, check the keyword RESIDUES"); + else if(resstrings[0]=="all") { log.printf(" examining all possible secondary structure combinations\n"); } else { log.printf(" examining secondary structure in residue positions : %s \n",resstrings[0].c_str() ); - for(unsigned i=1; i& newatoms ) { - if( colvar_atoms.size()>0 ) { - plumed_assert( colvar_atoms[0].size()==newatoms.size() ); - } + if( colvar_atoms.size()>0 ) plumed_assert( colvar_atoms[0].size()==newatoms.size() ); if( verbose_output ) { log.printf(" Secondary structure segment %u contains atoms : ", static_cast(colvar_atoms.size()+1)); - for(unsigned i=0; i& structu // Convert into correct units for(unsigned i=0; i& structu // And prepare the task list deactivateAllTasks(); - for(unsigned i=0; i pos( references[0]->getNumberOfAtoms() ); const unsigned n=pos.size(); - for(unsigned i=0; i0 ) { if( distance.modulo2()>s_cutoff2 ) { myvals.setValue( 0, 0.0 ); @@ -254,8 +217,7 @@ void SecondaryStructureRMSD::performTask( const unsigned& task_index, const unsi Vector & second (pos[i+1]); second=first+pbcDistance(first,second); } - Vector origin_old, origin_new; - origin_old=pos[align_atom_2]; + Vector origin_old, origin_new; origin_old=pos[align_atom_2]; origin_new=pos[align_atom_1]+distance; for(unsigned i=15; i<30; ++i) { pos[i]+=( origin_new - origin_old ); @@ -268,11 +230,8 @@ void SecondaryStructureRMSD::performTask( const unsigned& task_index, const unsi } } // Create a holder for the derivatives - ReferenceValuePack mypack( 0, pos.size(), myvals ); - mypack.setValIndex( 1 ); - for(unsigned i=0; icalculate( pos, pbc, mypack, false ); - if( nr0 ) { - mypack.moveDerivatives( closest+1, 1 ); - } + myvals.setValue( 0, 1.0 ); myvals.setValue( 1, r ); + if( closest>0 ) mypack.moveDerivatives( closest+1, 1 ); if( !mypack.virialWasSet() ) { Tensor vir; @@ -301,17 +254,14 @@ void SecondaryStructureRMSD::performTask( const unsigned& task_index, const unsi for(unsigned i=0; i0) { - u.setLength(s); - } + if(s.length()>0) u.setLength(s); if(u.getLengthString().length()>0 && u.getLengthString()=="nm") { log.printf(" length: %s\n",u.getLengthString().c_str()); - } else if(u.getLengthString().length()>0 && u.getLengthString()!="nm") { + } + else if(u.getLengthString().length()>0 && u.getLengthString()!="nm") { log.printf(" length: %s = %g nm\n",u.getLengthString().c_str(),u.getLength()); - } else { + } + else { log.printf(" length: %g nm\n",u.getLength()); } s=""; parse("ENERGY",s); - if(s.length()>0) { - u.setEnergy(s); - } + if(s.length()>0) u.setEnergy(s); if(u.getEnergyString().length()>0 && u.getEnergyString()=="kj/mol") { log.printf(" energy: %s\n",u.getEnergyString().c_str()); - } else if(u.getEnergyString().length()>0 && u.getEnergyString()!="kj/mol") { + } + else if(u.getEnergyString().length()>0 && u.getEnergyString()!="kj/mol") { log.printf(" energy: %s = %g kj/mol\n",u.getEnergyString().c_str(),u.getEnergy()); - } else { + } + else { log.printf(" energy: %g kj/mol\n",u.getEnergy()); } s=""; parse("TIME",s); - if(s.length()>0) { - u.setTime(s); - } + if(s.length()>0) u.setTime(s); if(u.getTimeString().length()>0 && u.getTimeString()=="ps") { log.printf(" time: %s\n",u.getTimeString().c_str()); - } else if(u.getTimeString().length()>0 && u.getTimeString()!="ps") { + } + else if(u.getTimeString().length()>0 && u.getTimeString()!="ps") { log.printf(" time: %s = %g ps\n",u.getTimeString().c_str(),u.getTime()); - } else { + } + else { log.printf(" time: %g ps\n",u.getTime()); } s=""; parse("CHARGE",s); - if(s.length()>0) { - u.setCharge(s); - } + if(s.length()>0) u.setCharge(s); if(u.getChargeString().length()>0 && u.getChargeString()=="e") { log.printf(" charge: %s\n",u.getChargeString().c_str()); - } else if(u.getChargeString().length()>0 && u.getChargeString()!="e") { + } + else if(u.getChargeString().length()>0 && u.getChargeString()!="e") { log.printf(" charge: %s = %g e\n",u.getChargeString().c_str(),u.getCharge()); - } else { + } + else { log.printf(" charge: %g e\n",u.getCharge()); } s=""; parse("MASS",s); - if(s.length()>0) { - u.setMass(s); - } + if(s.length()>0) u.setMass(s); if(u.getMassString().length()>0 && u.getMassString()=="amu") { log.printf(" mass: %s\n",u.getMassString().c_str()); - } else if(u.getMassString().length()>0 && u.getMassString()!="amu") { + } + else if(u.getMassString().length()>0 && u.getMassString()!="amu") { log.printf(" mass: %s = %g amu\n",u.getMassString().c_str(),u.getMass()); - } else { + } + else { log.printf(" mass: %g amu\n",u.getMass()); } diff --git a/src/tools/BiasRepresentation.cpp b/src/tools/BiasRepresentation.cpp index 2c241812a5..4e75209cad 100644 --- a/src/tools/BiasRepresentation.cpp +++ b/src/tools/BiasRepresentation.cpp @@ -43,7 +43,8 @@ BiasRepresentation::BiasRepresentation(const std::vector & tmpvalues, Co /// overload the constructor: add the sigma at constructor time BiasRepresentation::BiasRepresentation(const std::vector & tmpvalues, Communicator &cc, const std::vector & sigma ): - hasgrid(false), rescaledToBias(false), histosigma(sigma),mycomm(cc) { + hasgrid(false), rescaledToBias(false), histosigma(sigma),mycomm(cc) +{ lowI_=0.0; uppI_=0.0; doInt_=false; @@ -57,7 +58,8 @@ BiasRepresentation::BiasRepresentation(const std::vector & tmpvalues, Co /// overload the constructor: add the grid at constructor time BiasRepresentation::BiasRepresentation(const std::vector & tmpvalues, Communicator &cc, const std::vector & gmin, const std::vector & gmax, const std::vector & nbin, bool doInt, double lowI, double uppI): - hasgrid(false), rescaledToBias(false), mycomm(cc) { + hasgrid(false), rescaledToBias(false), mycomm(cc) +{ ndim=tmpvalues.size(); for(int i=0; i & tmpvalues, Co /// overload the constructor with some external sigmas: needed for histogram BiasRepresentation::BiasRepresentation(const std::vector & tmpvalues, Communicator &cc, const std::vector & gmin, const std::vector & gmax, const std::vector & nbin, const std::vector & sigma): - hasgrid(false), rescaledToBias(false),histosigma(sigma),mycomm(cc) { + hasgrid(false), rescaledToBias(false),histosigma(sigma),mycomm(cc) +{ lowI_=0.0; uppI_=0.0; doInt_=false; @@ -89,22 +92,14 @@ BiasRepresentation::BiasRepresentation(const std::vector & tmpvalues, Co void BiasRepresentation::addGrid(const std::vector & gmin, const std::vector & gmax, const std::vector & nbin ) { plumed_massert(hills.size()==0,"you can set the grid before loading the hills"); plumed_massert(hasgrid==false,"to build the grid you should not having the grid in this bias representation"); - std::string ss; - ss="file.free"; - std::vector vv; - for(unsigned i=0; i vv; for(unsigned i=0; i(ss,vv,gmin,gmax,nbin,false,true); hasgrid=true; } bool BiasRepresentation::hasSigmaInInput() { - if(histosigma.size()==0) { - return false; - } else { - return true; - } + if(histosigma.size()==0) {return false;} else {return true;} } void BiasRepresentation::setRescaledToBias(bool rescaled) { @@ -158,19 +153,14 @@ void BiasRepresentation::pushKernel( IFile *ifile ) { } // the bias factor is not something about the kernels but // must be stored to keep the bias/free energy duality - std::string dummy; - double dummyd; + std::string dummy; double dummyd; if(ifile->FieldExist("biasf")) { ifile->scanField("biasf",dummy); Tools::convert(dummy,dummyd); - } else { - dummyd=1.0; - } + } else {dummyd=1.0;} biasf.push_back(dummyd); // the domain does not pertain to the kernel but to the values here defined - std::string mins,maxs,minv,maxv,mini,maxi; - mins="min_"; - maxs="max_"; + std::string mins,maxs,minv,maxv,mini,maxi; mins="min_"; maxs="max_"; for(int i=0 ; iisPeriodic()) { ifile->scanField(mins+names[i],minv); @@ -187,35 +177,24 @@ void BiasRepresentation::pushKernel( IFile *ifile ) { std::vector nneighb; if(doInt_&&(kk->getCenter()[0]+kk->getContinuousSupport()[0] > uppI_ || kk->getCenter()[0]-kk->getContinuousSupport()[0] < lowI_ )) { nneighb=BiasGrid_->getNbin(); - } else { - nneighb=kk->getSupport(BiasGrid_->getDx()); - } + } else nneighb=kk->getSupport(BiasGrid_->getDx()); std::vector neighbors=BiasGrid_->getNeighbors(kk->getCenter(),nneighb); std::vector der(ndim); std::vector xx(ndim); if(mycomm.Get_size()==1) { for(unsigned i=0; igetPoint(ineigh,xx); // assign xx to a new vector of values - for(int j=0; jset(xx[j]); - } + for(int j=0; jset(xx[j]);} double bias; - if(doInt_) { - bias=kk->evaluate(values,der,true,doInt_,lowI_,uppI_); - } else { - bias=kk->evaluate(values,der,true); - } + if(doInt_) bias=kk->evaluate(values,der,true,doInt_,lowI_,uppI_); + else bias=kk->evaluate(values,der,true); if(rescaledToBias) { double f=(biasf.back()-1.)/(biasf.back()); bias*=f; - for(int j=0; jaddValueAndDerivatives(ineigh,bias,der); } @@ -228,35 +207,23 @@ void BiasRepresentation::pushKernel( IFile *ifile ) { for(unsigned i=rank; igetPoint(ineigh,xx); - for(int j=0; jset(xx[j]); - } - if(doInt_) { - allbias[i]=kk->evaluate(values,der,true,doInt_,lowI_,uppI_); - } else { - allbias[i]=kk->evaluate(values,der,true); - } + for(int j=0; jset(xx[j]);} + if(doInt_) allbias[i]=kk->evaluate(values,der,true,doInt_,lowI_,uppI_); + else allbias[i]=kk->evaluate(values,der,true); if(rescaledToBias) { double f=(biasf.back()-1.)/(biasf.back()); allbias[i]*=f; - for(int j=0; jaddValueAndDerivatives(ineigh,allbias[i],der); } } @@ -275,14 +242,10 @@ Grid* BiasRepresentation::getGridPtr() { void BiasRepresentation::getMinMaxBin(std::vector &vmin, std::vector &vmax, std::vector &vbin) { std::vector ss,cc,binsize; - vmin.clear(); - vmin.resize(ndim,10.e20); - vmax.clear(); - vmax.resize(ndim,-10.e20); - vbin.clear(); - vbin.resize(ndim); - binsize.clear(); - binsize.resize(ndim,10.e20); + vmin.clear(); vmin.resize(ndim,10.e20); + vmax.clear(); vmax.resize(ndim,-10.e20); + vbin.clear(); vbin.resize(ndim); + binsize.clear(); binsize.resize(ndim,10.e20); int ndiv=10; // adjustable parameter: division per support for(unsigned i=0; i &vmin, std::vectorvmax[j]) { - vmax[j]=dmax; - } - if(ddivvmax[j])vmax[j]=dmax; + if(ddiv &vmin, std::vectorisPeriodic()) { double minv,maxv; values[j]->getDomain(minv,maxv); - if(minv>vmin[j]) { - vmin[j]=minv; - } - if(maxvvmin[j])vmin[j]=minv; + if(maxv(std::ceil((vmax[j]-vmin[j])/binsize[j]) ); } diff --git a/src/tools/Brent1DRootSearch.h b/src/tools/Brent1DRootSearch.h index 15e653e0d1..491b9816a7 100644 --- a/src/tools/Brent1DRootSearch.h +++ b/src/tools/Brent1DRootSearch.h @@ -68,19 +68,14 @@ Brent1DRootSearch::Brent1DRootSearch( const FCLASS& pf, const double& t EXPAND(1.6), ax(0), bx(0), fa(0), fb(0), - myclass_func(pf) { + myclass_func(pf) +{ } template void Brent1DRootSearch::bracket( const double& a, const double& b, eng_pointer eng ) { - plumed_assert( a!=b ); - ax=a; - bx=b; - fa=(myclass_func.*eng)(a); - fb=(myclass_func.*eng)(b); - if ((fa > 0.0 && fb > 0.0) || (fa < 0.0 && fb < 0.0)) { - plumed_merror("input points do not bracket root"); - } + plumed_assert( a!=b ); ax=a; bx=b; fa=(myclass_func.*eng)(a); fb=(myclass_func.*eng)(b); + if ((fa > 0.0 && fb > 0.0) || (fa < 0.0 && fb < 0.0)) plumed_merror("input points do not bracket root"); bracketed=true; } @@ -90,61 +85,31 @@ double Brent1DRootSearch::search( eng_pointer eng ) { double cx=bx, d, e, min1, min2, fc=fb, p, q, r, s, tol1, xm; for(unsigned iter=0; iter0.0 && fc>0.0) || (fb<0.0 && fc<0.0) ) { - cx=ax; - fc=fa; - e=d=bx-ax; - } - if( std::fabs(fc) < std::fabs(fb) ) { - ax=bx; - bx=cx; - cx=ax; - fa=fb; - fb=fc; - fc=fa; - } - tol1=2*EPS*std::fabs(bx)+0.5*tol; - xm=0.5*(cx-bx); - if( std::fabs(xm) <= tol1 || fb == 0.0 ) { - return bx; - } + if ( (fb>0.0 && fc>0.0) || (fb<0.0 && fc<0.0) ) { cx=ax; fc=fa; e=d=bx-ax; } + if( std::fabs(fc) < std::fabs(fb) ) { ax=bx; bx=cx; cx=ax; fa=fb; fb=fc; fc=fa; } + tol1=2*EPS*std::fabs(bx)+0.5*tol; xm=0.5*(cx-bx); + if( std::fabs(xm) <= tol1 || fb == 0.0 ) return bx; if( std::fabs(e) >= tol1 && std::fabs(fa) > std::fabs(fb) ) { s=fb/fa; if( ax==cx ) { - p=2.0*xm*s; - q=1.0-s; + p=2.0*xm*s; q=1.0-s; } else { - q=fa/fc; - r=fb/fc; - p=s*(2.0*xm*q*(q-r)-(bx-ax)*(r-1.0)); - q=(q-1.0)*(r-1.0)*(s-1.0); + q=fa/fc; r=fb/fc; p=s*(2.0*xm*q*(q-r)-(bx-ax)*(r-1.0)); q=(q-1.0)*(r-1.0)*(s-1.0); } - if (p > 0.0) { - q = -q; - } - p=std::fabs(p); - min1=3.0*xm*q-std::fabs(tol1*q); - min2=std::fabs(e*q); + if (p > 0.0) q = -q; + p=std::fabs(p); min1=3.0*xm*q-std::fabs(tol1*q); min2=std::fabs(e*q); if (2.0*p < (min1 < min2 ? min1 : min2)) { - e=d; - d=p/q; + e=d; d=p/q; } else { - d=xm; - e=d; + d=xm; e=d; } } else { - d=xm; - e=d; - } - ax=bx; - fa=fb; - if( std::fabs(d) > tol1 ) { - bx+=d; - } else if(xm<0 ) { - bx -= std::fabs(tol1); // SIGN(tol1,xm); - } else { - bx += tol1; + d=xm; e=d; } + ax=bx; fa=fb; + if( std::fabs(d) > tol1 ) bx+=d; + else if(xm<0 ) bx -= std::fabs(tol1); // SIGN(tol1,xm); + else bx += tol1; fb = (myclass_func.*eng)(bx); } diff --git a/src/tools/Citations.cpp b/src/tools/Citations.cpp index 2f4a06ca00..25f41cf355 100644 --- a/src/tools/Citations.cpp +++ b/src/tools/Citations.cpp @@ -28,13 +28,8 @@ namespace PLMD { std::string Citations::cite(const std::string & item) { unsigned i; - for(i=0; i()); - } + if(val) Set_comm(*(const MPI_Comm*)val.get()); #else (void) val; plumed_merror("you are trying to use an MPI function, but PLUMED has been compiled without MPI support"); @@ -136,9 +124,7 @@ void Communicator::Abort(int errorcode) { void Communicator::Bcast(Data data,int root) { #if defined(__PLUMED_HAS_MPI) - if(initialized()) { - MPI_Bcast(data.pointer,data.size,data.type,root,communicator); - } + if(initialized()) MPI_Bcast(data.pointer,data.size,data.type,root,communicator); #else (void) data; (void) root; @@ -147,9 +133,7 @@ void Communicator::Bcast(Data data,int root) { void Communicator::Sum(Data data) { #if defined(__PLUMED_HAS_MPI) - if(initialized()) { - MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_SUM,communicator); - } + if(initialized()) MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_SUM,communicator); #else (void) data; #endif @@ -157,9 +141,7 @@ void Communicator::Sum(Data data) { void Communicator::Prod(Data data) { #if defined(__PLUMED_HAS_MPI) - if(initialized()) { - MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_PROD,communicator); - } + if(initialized()) MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_PROD,communicator); #else (void) data; #endif @@ -167,9 +149,7 @@ void Communicator::Prod(Data data) { void Communicator::Max(Data data) { #if defined(__PLUMED_HAS_MPI) - if(initialized()) { - MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_MAX,communicator); - } + if(initialized()) MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_MAX,communicator); #else (void) data; #endif @@ -177,9 +157,7 @@ void Communicator::Max(Data data) { void Communicator::Min(Data data) { #if defined(__PLUMED_HAS_MPI) - if(initialized()) { - MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_MIN,communicator); - } + if(initialized()) MPI_Allreduce(MPI_IN_PLACE,data.pointer,data.size,data.type,MPI_MIN,communicator); #else (void) data; #endif @@ -207,9 +185,7 @@ void Communicator::Allgatherv(ConstData in,Data out,const int*recvcounts,const i int*di=const_cast(displs); #if defined(__PLUMED_HAS_MPI) if(initialized()) { - if(s==NULL) { - s=MPI_IN_PLACE; - } + if(s==NULL)s=MPI_IN_PLACE; MPI_Allgatherv(s,in.size,in.type,r,rc,di,out.type,communicator); } else { plumed_assert(in.nbytes==out.nbytes); @@ -217,9 +193,7 @@ void Communicator::Allgatherv(ConstData in,Data out,const int*recvcounts,const i plumed_assert(rc); plumed_assert(rc[0]==in.size); plumed_assert(di); - if(s) { - std::memcpy(static_cast(r)+displs[0]*in.nbytes,s,size_t(in.size)*in.nbytes); - } + if(s) std::memcpy(static_cast(r)+displs[0]*in.nbytes,s,size_t(in.size)*in.nbytes); } #else plumed_assert(in.nbytes==out.nbytes); @@ -227,9 +201,7 @@ void Communicator::Allgatherv(ConstData in,Data out,const int*recvcounts,const i plumed_assert(rc); plumed_assert(rc[0]==in.size); plumed_assert(di); - if(s) { - std::memcpy(static_cast(r)+displs[0]*in.nbytes,s,size_t(in.size)*in.nbytes); - } + if(s) std::memcpy(static_cast(r)+displs[0]*in.nbytes,s,size_t(in.size)*in.nbytes); #endif } @@ -238,34 +210,25 @@ void Communicator::Allgather(ConstData in,Data out) { void*r=const_cast((const void*)out.pointer); #if defined(__PLUMED_HAS_MPI) if(initialized()) { - if(s==NULL) { - s=MPI_IN_PLACE; - } + if(s==NULL)s=MPI_IN_PLACE; MPI_Allgather(s,in.size,in.type,r,out.size/Get_size(),out.type,communicator); } else { plumed_assert(in.nbytes==out.nbytes); plumed_assert(in.size==out.size); - if(s) { - std::memcpy(r,s,size_t(in.size)*in.nbytes); - } + if(s) std::memcpy(r,s,size_t(in.size)*in.nbytes); } #else plumed_assert(in.nbytes==out.nbytes); plumed_assert(in.size==out.size); - if(s) { - std::memcpy(r,s,size_t(in.size)*in.nbytes); - } + if(s) std::memcpy(r,s,size_t(in.size)*in.nbytes); #endif } void Communicator::Recv(Data data,int source,int tag,Status&status) { #ifdef __PLUMED_HAS_MPI plumed_massert(initialized(),"you are trying to use an MPI function, but MPI is not initialized"); - if(&status==&StatusIgnore) { - MPI_Recv(data.pointer,data.size,data.type,source,tag,communicator,MPI_STATUS_IGNORE); - } else { - MPI_Recv(data.pointer,data.size,data.type,source,tag,communicator,&status.s); - } + if(&status==&StatusIgnore) MPI_Recv(data.pointer,data.size,data.type,source,tag,communicator,MPI_STATUS_IGNORE); + else MPI_Recv(data.pointer,data.size,data.type,source,tag,communicator,&status.s); #else (void) data; (void) source; @@ -277,9 +240,7 @@ void Communicator::Recv(Data data,int source,int tag,Status&status) { void Communicator::Barrier()const { #ifdef __PLUMED_HAS_MPI - if(initialized()) { - MPI_Barrier(communicator); - } + if(initialized()) MPI_Barrier(communicator); #endif } @@ -291,11 +252,8 @@ bool Communicator::initialized() { #if defined(__PLUMED_HAS_MPI) int flag=0; MPI_Initialized(&flag); - if(flag) { - return true; - } else { - return false; - } + if(flag) return true; + else return false; #endif return false; } @@ -303,11 +261,8 @@ bool Communicator::initialized() { void Communicator::Request::wait(Status&s) { #ifdef __PLUMED_HAS_MPI plumed_massert(initialized(),"you are trying to use an MPI function, but MPI is not initialized"); - if(&s==&StatusIgnore) { - MPI_Wait(&r,MPI_STATUS_IGNORE); - } else { - MPI_Wait(&r,&s.s); - } + if(&s==&StatusIgnore) MPI_Wait(&r,MPI_STATUS_IGNORE); + else MPI_Wait(&r,&s.s); #else (void) s; plumed_merror("you are trying to use an MPI function, but PLUMED has been compiled without MPI support"); @@ -315,61 +270,25 @@ void Communicator::Request::wait(Status&s) { } #ifdef __PLUMED_HAS_MPI -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_FLOAT; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_DOUBLE; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_INT; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_CHAR; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_UNSIGNED; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_UNSIGNED; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_UNSIGNED_LONG; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_UNSIGNED_LONG_LONG; -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_LONG_DOUBLE; -} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_FLOAT;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_DOUBLE;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_INT;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_CHAR;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_UNSIGNED;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_UNSIGNED;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_UNSIGNED_LONG;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_UNSIGNED_LONG_LONG;} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_LONG_DOUBLE;} #else -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} -template<> MPI_Datatype Communicator::getMPIType() { - return MPI_Datatype(); -} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} +template<> MPI_Datatype Communicator::getMPIType() { return MPI_Datatype();} #endif void Communicator::Split(int color,int key,Communicator&pc)const { diff --git a/src/tools/Communicator.h b/src/tools/Communicator.h index 16ef37ddfb..aff4771852 100644 --- a/src/tools/Communicator.h +++ b/src/tools/Communicator.h @@ -82,34 +82,17 @@ class Communicator { template explicit Data(TensorGeneric &p): pointer(&p), size(n*m), nbytes(sizeof(double)), type(getMPIType()) {} /// Init from reference to std::vector template explicit Data(std::vector&v) { - Data d(v.data(),v.size()); - pointer=d.pointer; - size=d.size; - type=d.type; + Data d(v.data(),v.size()); pointer=d.pointer; size=d.size; type=d.type; } /// Init from reference to PLMD::Matrix template explicit Data(Matrix&m ) { - if(m.nrows()*m.ncols()>0) { - Data d(&m(0,0),m.nrows()*m.ncols()); - pointer=d.pointer; - size=d.size; - type=d.type; - } else { - pointer=NULL; - size=0; - } + if(m.nrows()*m.ncols()>0) { Data d(&m(0,0),m.nrows()*m.ncols()); pointer=d.pointer; size=d.size; type=d.type; } + else { pointer=NULL; size=0; } } /// Init from reference to std::string explicit Data(std::string&s) { - if(s.size()>0) { - Data d(&s[0],s.size()); - pointer=d.pointer; - size=d.size; - type=d.type; - } else { - pointer=NULL; - size=0; - } + if(s.size()>0) { Data d(&s[0],s.size()); pointer=d.pointer; size=d.size; type=d.type; } + else { pointer=NULL; size=0; } } }; /// Const version of Communicator::Data @@ -126,32 +109,15 @@ class Communicator { template explicit ConstData(const TensorGeneric *p,int s): pointer(p), size(n*m*s), nbytes(sizeof(double)), type(getMPIType()) {} template explicit ConstData(const TensorGeneric &p): pointer(&p), size(n*m), nbytes(sizeof(double)), type(getMPIType()) {} template explicit ConstData(const std::vector&v) { - ConstData d(v.data(),v.size()); - pointer=d.pointer; - size=d.size; - type=d.type; + ConstData d(v.data(),v.size()); pointer=d.pointer; size=d.size; type=d.type; } template explicit ConstData(const Matrix&m ) { - if(m.nrows()*m.ncols()>0) { - ConstData d(&m(0,0),m.nrows()*m.ncols()); - pointer=d.pointer; - size=d.size; - type=d.type; - } else { - pointer=NULL; - size=0; - } + if(m.nrows()*m.ncols()>0) { ConstData d(&m(0,0),m.nrows()*m.ncols()); pointer=d.pointer; size=d.size; type=d.type; } + else { pointer=NULL; size=0; } } explicit ConstData(const std::string&s) { - if(s.size()>0) { - ConstData d(&s[0],s.size()); - pointer=d.pointer; - size=d.size; - type=d.type; - } else { - pointer=NULL; - size=0; - } + if(s.size()>0) { ConstData d(&s[0],s.size()); pointer=d.pointer; size=d.size; type=d.type; } + else { pointer=NULL; size=0; } } }; public: @@ -164,9 +130,7 @@ class Communicator { public: MPI_Status s; template - int Get_count()const { - return Get_count(getMPIType()); - } + int Get_count()const {return Get_count(getMPIType());} }; /// Special status used when status should be ignored. /// E.g. `Recv(a,0,1,Communicator::StatusIgnore);` @@ -214,65 +178,41 @@ class Communicator { /// Wrapper for MPI_Allreduce with MPI_SUM (data struct) void Sum(Data); /// Wrapper for MPI_Allreduce with MPI_SUM (pointer) - template void Sum(T*buf,int count) { - Sum(Data(buf,count)); - } + template void Sum(T*buf,int count) {Sum(Data(buf,count));} /// Wrapper for MPI_Allreduce with MPI_SUM (reference) - template void Sum(T&buf) { - Sum(Data(buf)); - } + template void Sum(T&buf) {Sum(Data(buf));} /// Wrapper for MPI_Allreduce with MPI_PROD (data struct) void Prod(Data); /// Wrapper for MPI_Allreduce with MPI_PROD (pointer) - template void Prod(T*buf,int count) { - Prod(Data(buf,count)); - } + template void Prod(T*buf,int count) {Prod(Data(buf,count));} /// Wrapper for MPI_Allreduce with MPI_PROD (reference) - template void Prod(T&buf) { - Prod(Data(buf)); - } + template void Prod(T&buf) {Prod(Data(buf));} /// Wrapper for MPI_Allreduce with MPI_MAX (data struct) void Max(Data); /// Wrapper for MPI_Allreduce with MPI_MAX (pointer) - template void Max(T*buf,int count) { - Max(Data(buf,count)); - } + template void Max(T*buf,int count) {Max(Data(buf,count));} /// Wrapper for MPI_Allreduce with MPI_MAX (reference) - template void Max(T&buf) { - Max(Data(buf)); - } + template void Max(T&buf) {Max(Data(buf));} /// Wrapper for MPI_Allreduce with MPI_MIN (data struct) void Min(Data); /// Wrapper for MPI_Allreduce with MPI_MIN (pointer) - template void Min(T*buf,int count) { - Min(Data(buf,count)); - } + template void Min(T*buf,int count) {Min(Data(buf,count));} /// Wrapper for MPI_Allreduce with MPI_MIN (reference) - template void Min(T&buf) { - Min(Data(buf)); - } + template void Min(T&buf) {Min(Data(buf));} /// Wrapper for MPI_Bcast (data struct) void Bcast(Data,int); /// Wrapper for MPI_Bcast (pointer) - template void Bcast(T*buf,int count,int root) { - Bcast(Data(buf,count),root); - } + template void Bcast(T*buf,int count,int root) {Bcast(Data(buf,count),root);} /// Wrapper for MPI_Bcast (reference) - template void Bcast(T&buf,int root) { - Bcast(Data(buf),root); - } + template void Bcast(T&buf,int root) {Bcast(Data(buf),root);} /// Wrapper for MPI_Isend (data struct) Request Isend(ConstData,int,int); /// Wrapper for MPI_Isend (pointer) - template Request Isend(const T*buf,int count,int source,int tag) { - return Isend(ConstData(buf,count),source,tag); - } + template Request Isend(const T*buf,int count,int source,int tag) {return Isend(ConstData(buf,count),source,tag);} /// Wrapper for MPI_Isend (reference) - template Request Isend(const T&buf,int source,int tag) { - return Isend(ConstData(buf),source,tag); - } + template Request Isend(const T&buf,int source,int tag) {return Isend(ConstData(buf),source,tag);} /// Wrapper for MPI_Allgatherv (data struct) void Allgatherv(ConstData in,Data out,const int*,const int*); @@ -299,13 +239,9 @@ class Communicator { /// Wrapper for MPI_Recv (data struct) void Recv(Data,int,int,Status&s=StatusIgnore); /// Wrapper for MPI_Recv (pointer) - template void Recv(T*buf,int count,int source,int tag,Status&s=StatusIgnore) { - Recv(Data(buf,count),source,tag,s); - } + template void Recv(T*buf,int count,int source,int tag,Status&s=StatusIgnore) {Recv(Data(buf,count),source,tag,s);} /// Wrapper for MPI_Recv (reference) - template void Recv(T&buf,int source,int tag,Status&s=StatusIgnore) { - Recv(Data(buf),source,tag,s); - } + template void Recv(T&buf,int source,int tag,Status&s=StatusIgnore) {Recv(Data(buf),source,tag,s);} /// Wrapper to MPI_Comm_split void Split(int,int,Communicator&)const; diff --git a/src/tools/ConjugateGradient.h b/src/tools/ConjugateGradient.h index 2b060e484c..2319f8caa9 100644 --- a/src/tools/ConjugateGradient.h +++ b/src/tools/ConjugateGradient.h @@ -43,34 +43,20 @@ template void ConjugateGradient::minimise( const double& ftol, std::vector& p, engf_pointer myfunc ) { std::vector xi( p.size() ), g( p.size() ), h( p.size() ); double fp = this->calcDerivatives( p, xi, myfunc ); - for(unsigned j=0; jlinemin( xi, p, myfunc ); // The exit condition - if( 2.0*std::fabs(fret-fp) <= ftol*(std::fabs(fret)+std::fabs(fp)+EPS)) { - return; - } - fp = fret; - this->calcDerivatives( p, xi, myfunc ); + if( 2.0*std::fabs(fret-fp) <= ftol*(std::fabs(fret)+std::fabs(fp)+EPS)) { return; } + fp = fret; this->calcDerivatives( p, xi, myfunc ); double ddg=0., gg=0.; - for(unsigned j=0; j std::vector DynamicList::retrieveActiveList() { std::vector this_active(nactive); - for(unsigned k=0; k void DynamicList::clear() { all.resize(0); - onoff.resize(0); - active.resize(0); + onoff.resize(0); active.resize(0); } template @@ -240,31 +237,25 @@ unsigned DynamicList::getNumberActive() const { template void DynamicList::addIndexToList( const T & ii ) { - all.push_back(ii); - active.resize( all.size() ); - onoff.push_back(0); + all.push_back(ii); active.resize( all.size() ); onoff.push_back(0); } template void DynamicList::createIndexListFromVector( const std::vector& myind ) { - plumed_dbg_assert( all.size()==0 ); - onoff.resize( myind.size(), 0 ); + plumed_dbg_assert( all.size()==0 ); onoff.resize( myind.size(), 0 ); active.resize( myind.size() ); all.insert( all.end(), myind.begin(), myind.end() ); } template void DynamicList::setupMPICommunication( Communicator& comm ) { - nprocessors=comm.Get_size(); - rank=comm.Get_rank(); + nprocessors=comm.Get_size(); rank=comm.Get_rank(); } template int DynamicList::getIndexOfElement( const T& t ) const { for(unsigned i=0; i void DynamicList::deactivate( const T& t ) { plumed_dbg_assert( allWereActivated ); unsigned ii=getIndexOfElement( t ); - if( onoff[ii]==0 || onoff[ii]%nprocessors!=0 ) { - return; - } + if( onoff[ii]==0 || onoff[ii]%nprocessors!=0 ) return; // Deactivates the component - if( rank==0 ) { - onoff[ii]=nprocessors-1; - } else { - onoff[ii]=nprocessors-rank; - } + if( rank==0 ) onoff[ii]=nprocessors-1; + else onoff[ii]=nprocessors-rank; } template void DynamicList::deactivateAll() { - allWereDeactivated=true; - allWereActivated=false; - for(unsigned i=0; i::activate( const unsigned ii ) { template void DynamicList::activateAll() { - for(unsigned i=0; i::mpi_gatherActiveMembers(Communicator& comm) { plumed_massert( comm.Get_size()==nprocessors, "error missing a call to DynamicList::setupMPICommunication"); comm.Sum(&onoff[0],onoff.size()); // When we mpi gather onoff to be on it should be active on ALL nodes - for(unsigned i=0; i0 && onoff[i]%nprocessors==0 ) { - onoff[i]=nprocessors; - } + for(unsigned i=0; i0 && onoff[i]%nprocessors==0 ) { onoff[i]=nprocessors; } updateActiveMembers(); } template void DynamicList::updateActiveMembers() { plumed_dbg_assert( allWereActivated || allWereDeactivated ); - unsigned kk=0; - allWereActivated=allWereDeactivated=false; + unsigned kk=0; allWereActivated=allWereDeactivated=false; for(unsigned i=0; i0 && onoff[i]%nprocessors==0 ) { - active[kk]=i; - kk++; - } + if( onoff[i]>0 && onoff[i]%nprocessors==0 ) { active[kk]=i; kk++; } } nactive=kk; } @@ -353,8 +323,7 @@ template void DynamicList::putIndexInActiveArray( const unsigned& ii ) { plumed_dbg_assert( allWereActivated || allWereDeactivated ); plumed_dbg_assert( onoff[ii]>0 && onoff[ii]%nprocessors==0 ); - active[nactive]=ii; - nactive++; + active[nactive]=ii; nactive++; } template @@ -372,17 +341,14 @@ void DynamicList::sortActiveList() { template bool DynamicList::updateComplete() const { - if( !allWereActivated && !allWereDeactivated ) { - return true; - } + if( !allWereActivated && !allWereDeactivated ) return true; return false; } template void mpi_gatherActiveMembers(Communicator& comm, std::vector< DynamicList >& ll ) { // Setup an array to hold all data - unsigned bufsize=0; - unsigned size=comm.Get_size(); + unsigned bufsize=0; unsigned size=comm.Get_size(); for(unsigned i=0; i >& // Gather all onoff data into a single array bufsize=0; for(unsigned i=0; i >& bufsize=0; for(unsigned i=0; i0 && buffer[bufsize]%size==0 ) { - ll[i].onoff[j]=size; - } else { - ll[i].onoff[j]=size-1; - } + if( buffer[bufsize]>0 && buffer[bufsize]%size==0 ) ll[i].onoff[j]=size; + else ll[i].onoff[j]=size-1; bufsize++; } } - for(unsigned i=0; i & reference, const std::vecto bool ERMSD::inPair(unsigned i, unsigned j) { - if(pairs.size()==0) { - return true; - } + if(pairs.size()==0) return true; for(unsigned idx=0; idx & positions,const Pbc& pbc,\ ermsd = std::sqrt(ermsd/nresidues); double iermsd = 1.0/(ermsd*nresidues); - for(unsigned i=0; i v; int n = path.length(); @@ -52,12 +53,13 @@ std::string simplify(const std::string & path) { // if ".." , we pop. if (dir == "..") { - if (!v.empty()) { + if (!v.empty()) v.pop_back(); - } - } else if (dir == "." || dir == "") { + } + else if (dir == "." || dir == "") { // do nothing (added for better understanding.) - } else { + } + else { // push the current directory into the vector. v.push_back(dir); } @@ -66,24 +68,22 @@ std::string simplify(const std::string & path) { // forming the ans bool first=true; for (auto i : v) { - if(!first) { - ans += "/"; - } + if(!first) ans += "/"; first=false; ans += i; } // vector is empty - if (ans == "") { + if (ans == "") return "/"; - } return ans; } } -Exception::Exception() { +Exception::Exception() +{ callstack.fill(nullptr); #ifdef __PLUMED_HAS_EXECINFO callstack_n = backtrace(&callstack[0], callstack.size()-1); @@ -96,18 +96,18 @@ Exception::Exception() { #endif } -Exception& Exception::operator<<(const std::string&msg) { +Exception& Exception::operator<<(const std::string&msg) +{ if(msg.length()>0) { - if(note) { - this->msg +="\n"; - } + if(note) this->msg +="\n"; this->msg +=msg; note=false; } return *this; } -Exception& Exception::operator<<(const Location&loc) { +Exception& Exception::operator<<(const Location&loc) +{ if(loc.file) { const std::size_t clinelen=1000; char cline[clinelen]; @@ -130,7 +130,8 @@ Exception& Exception::operator<<(const Location&loc) { return *this; } -Exception& Exception::operator<<(const Assertion&as) { +Exception& Exception::operator<<(const Assertion&as) +{ if(as.assertion) { this->msg += "\n+++ assertion failed: "; this->msg += as.assertion; @@ -143,10 +144,7 @@ const char* Exception::stack() const { #ifdef __PLUMED_HAS_EXECINFO if(stackTrace.length()==0) { char** strs = backtrace_symbols(&callstack[0], callstack_n); - for (int i = 0; i < callstack_n; ++i) { - stackTrace+=strs[i]; - stackTrace+="\n"; - } + for (int i = 0; i < callstack_n; ++i) {stackTrace+=strs[i]; stackTrace+="\n";} free(strs); } #endif diff --git a/src/tools/Exception.h b/src/tools/Exception.h index 439be552ec..0792da371a 100644 --- a/src/tools/Exception.h +++ b/src/tools/Exception.h @@ -152,7 +152,8 @@ this in all previous PLUMED versions. In case it is necessary, we can replace it later with a fixed size array placed on the stack. */ -class Exception : public std::exception { +class Exception : public std::exception +{ /// Reported message. Can be updated. std::string msg; /// Flag to remember if we have to write the `+++ message follows +++` string. @@ -219,7 +220,8 @@ class Exception : public std::exception { /// Constructor compatible with PLUMED <=2.4. explicit Exception(const std::string & msg): - Exception() { + Exception() + { *this << msg; } @@ -230,7 +232,8 @@ class Exception : public std::exception { note(e.note), callstack(e.callstack), callstack_n(e.callstack_n), - stackTrace(e.stackTrace) { + stackTrace(e.stackTrace) + { } /// Assignment. @@ -249,9 +252,7 @@ class Exception : public std::exception { /// In case the environment variable PLUMED_STACK_TRACE was defined /// and equal to `yes` when the exception was raised, /// the error message will contain the stack trace as well. - const char* what() const noexcept override { - return msg.c_str(); - } + const char* what() const noexcept override {return msg.c_str();} /// Returns the stack trace as a string. /// This function is slow as it requires building a parsed string. @@ -259,14 +260,10 @@ class Exception : public std::exception { const char* stack() const; /// Returns the callstack. - const std::array & trace() const noexcept { - return callstack; - } + const std::array & trace() const noexcept {return callstack;} /// Returns the number of elements in the trace array - int trace_n() const noexcept { - return callstack_n; - } + int trace_n() const noexcept {return callstack_n;} /// Destructor should be defined and should not throw other exceptions ~Exception() noexcept override {} diff --git a/src/tools/FileBase.cpp b/src/tools/FileBase.cpp index b8cd6ce795..9e656eb022 100644 --- a/src/tools/FileBase.cpp +++ b/src/tools/FileBase.cpp @@ -47,9 +47,7 @@ FileBase& FileBase::link(FILE*fp) { } FileBase& FileBase::flush() { - if(fp) { - fflush(fp); - } + if(fp) fflush(fp); return *this; } @@ -80,11 +78,7 @@ bool FileBase::FileExist(const std::string& path) { // first try with suffix FILE *ff=std::fopen(const_cast(this->path.c_str()),"r"); // call fclose when ff goes out of scope - auto deleter=[](FILE* f) { - if(f) { - std::fclose(f); - } - }; + auto deleter=[](FILE* f) { if(f) std::fclose(f); }; std::unique_ptr fp_deleter(ff,deleter); if(!ff) { @@ -93,20 +87,14 @@ bool FileBase::FileExist(const std::string& path) { ff=std::fopen(const_cast(this->path.c_str()),"r"); mode="r"; } - if(ff) { - do_exist=true; - } - if(comm) { - comm->Barrier(); - } + if(ff) do_exist=true; + if(comm) comm->Barrier(); return do_exist; } bool FileBase::isOpen() { bool isopen=false; - if(fp) { - isopen=true; - } + if(fp) isopen=true; return isopen; } @@ -114,13 +102,9 @@ void FileBase::close() { plumed_assert(!cloned); eof=false; err=false; - if(fp) { - std::fclose(fp); - } + if(fp) std::fclose(fp); #ifdef __PLUMED_HAS_ZLIB - if(gzfp) { - gzclose(gzFile(gzfp)); - } + if(gzfp) gzclose(gzFile(gzfp)); #endif fp=NULL; gzfp=NULL; @@ -136,20 +120,16 @@ FileBase::FileBase(): eof(false), err(false), heavyFlush(false), - enforcedSuffix_(false) { + enforcedSuffix_(false) +{ } -FileBase::~FileBase() { - if(plumed) { - plumed->eraseFile(*this); - } - if(!cloned && fp) { - std::fclose(fp); - } +FileBase::~FileBase() +{ + if(plumed) plumed->eraseFile(*this); + if(!cloned && fp) std::fclose(fp); #ifdef __PLUMED_HAS_ZLIB - if(!cloned && gzfp) { - gzclose(gzFile(gzfp)); - } + if(!cloned && gzfp) gzclose(gzFile(gzfp)); #endif } @@ -158,9 +138,7 @@ FileBase::operator bool()const { } std::string FileBase::appendSuffix(const std::string&path,const std::string&suffix) { - if(path=="/dev/null") { - return path; // do not append a suffix to /dev/null - } + if(path=="/dev/null") return path; // do not append a suffix to /dev/null std::string ret=path; std::string ext=Tools::extension(path); @@ -178,9 +156,7 @@ std::string FileBase::appendSuffix(const std::string&path,const std::string&suff ret.resize(l); } ret+=suffix; - if(ext.length()>0) { - ret+="."+ext; - } + if(ext.length()>0)ret+="."+ext; return ret; } @@ -191,12 +167,8 @@ FileBase& FileBase::enforceSuffix(const std::string&suffix) { } std::string FileBase::getSuffix()const { - if(enforcedSuffix_) { - return enforcedSuffix; - } - if(plumed) { - return plumed->getSuffix(); - } + if(enforcedSuffix_) return enforcedSuffix; + if(plumed) return plumed->getSuffix(); return ""; } diff --git a/src/tools/FileBase.h b/src/tools/FileBase.h index 714182131c..5f148e4041 100644 --- a/src/tools/FileBase.h +++ b/src/tools/FileBase.h @@ -113,9 +113,7 @@ class FileBase { /// Check for error/eof. operator bool () const; /// Set heavyFlush flag - void setHeavyFlush() { - heavyFlush=true; - } + void setHeavyFlush() { heavyFlush=true;} /// Opens the file virtual FileBase& open(const std::string&name)=0; /// Check if the file exists diff --git a/src/tools/ForwardDecl.h b/src/tools/ForwardDecl.h index 929e85ad53..db7bbdceca 100644 --- a/src/tools/ForwardDecl.h +++ b/src/tools/ForwardDecl.h @@ -33,7 +33,8 @@ namespace PLMD { */ template class ForwardDecl: - std::unique_ptr { + std::unique_ptr +{ public: // Construction with arbitrary argument. template diff --git a/src/tools/Grid.cpp b/src/tools/Grid.cpp index 7e6e1fee09..a533715ce9 100644 --- a/src/tools/Grid.cpp +++ b/src/tools/Grid.cpp @@ -88,8 +88,7 @@ void GridBase::Init(const std::string& funcl, const std::vector &na plumed_massert(names.size()==nbin.size(),"grid dimensions in input do not match number of arguments"); plumed_massert(names.size()==gmax.size(),"grid dimensions in input do not match number of arguments"); dimension_=gmax.size(); - str_min_=gmin; - str_max_=gmax; + str_min_=gmin; str_max_=gmax; argnames.resize( dimension_ ); min_.resize( dimension_ ); max_.resize( dimension_ ); @@ -112,16 +111,11 @@ void GridBase::Init(const std::string& funcl, const std::vector &na nbin_=nbin; dospline_=dospline; usederiv_=usederiv; - if(dospline_) { - plumed_assert(dospline_==usederiv_); - } + if(dospline_) plumed_assert(dospline_==usederiv_); maxsize_=1; for(unsigned int i=0; i( nbin_[i] ) ); - if( !pbc_[i] ) { - max_[i] += dx_[i]; - nbin_[i] += 1; - } + if( !pbc_[i] ) { max_[i] += dx_[i]; nbin_[i] += 1; } maxsize_*=nbin_[i]; } } @@ -144,9 +138,7 @@ double GridBase::getDx(index_t j) const { double GridBase::getBinVolume() const { double vol=1.; - for(unsigned i=0; i GridBase::getIndices(index_t index) const { } void GridBase::getIndices(index_t index, std::vector& indices) const { - if (indices.size()!=dimension_) { - indices.resize(dimension_); - } + if (indices.size()!=dimension_) indices.resize(dimension_); index_t kk=index; indices[0]=(index%nbin_[0]); for(unsigned int i=1; i GridBase::getIndices(const std::vector & x) const void GridBase::getIndices(const std::vector & x, std::vector& indices) const { plumed_dbg_assert(x.size()==dimension_); - if (indices.size()!=dimension_) { - indices.resize(dimension_); - } + if (indices.size()!=dimension_) indices.resize(dimension_); for(unsigned int i=0; i GridBase::getNeighbors(const std::vector=static_cast(nbin_[i])) { - continue; - } - if( pbc_[i] && i0<0) { - i0=nbin_[i]-(-i0)%nbin_[i]; - } - if( pbc_[i] && i0>=static_cast(nbin_[i])) { - i0%=nbin_[i]; - } + if(!pbc_[i] && i0<0) continue; + if(!pbc_[i] && i0>=static_cast(nbin_[i])) continue; + if( pbc_[i] && i0<0) i0=nbin_[i]-(-i0)%nbin_[i]; + if( pbc_[i] && i0>=static_cast(nbin_[i])) i0%=nbin_[i]; tmp_indices[ll]=static_cast(i0); ll++; } tmp_indices.resize(ll); - if(tmp_indices.size()==dimension_) { - neighbors.push_back(getIndex(tmp_indices)); - } + if(tmp_indices.size()==dimension_) {neighbors.push_back(getIndex(tmp_indices));} } return neighbors; } @@ -337,30 +315,20 @@ std::vector GridBase::getNeighbors(index_t index,const std::v void GridBase::getSplineNeighbors(const std::vector & indices, std::vector& neighbors, unsigned& nneighbors)const { plumed_dbg_assert(indices.size()==dimension_); unsigned nneigh=unsigned(std::pow(2.0,int(dimension_))); - if (neighbors.size()!=nneigh) { - neighbors.resize(nneigh); - } + if (neighbors.size()!=nneigh) neighbors.resize(nneigh); std::vector nindices(dimension_); - unsigned inind; - nneighbors = 0; + unsigned inind; nneighbors = 0; for(unsigned int i=0; iset(xx[j]); - } + for(unsigned j=0; jset(xx[j]); double newval = kernel.evaluate( vv_ptr, der, usederiv_ ); - if( usederiv_ ) { - addValueAndDerivatives( ineigh, newval, der ); - } else { - addValue( ineigh, newval ); - } + if( usederiv_ ) addValueAndDerivatives( ineigh, newval, der ); + else addValue( ineigh, newval ); } } @@ -451,17 +414,13 @@ double GridBase::getValueAndDerivatives(const std::vector & x, std::vect std::vector dder(dimension_); // reset value=0.0; - for(unsigned int i=0; i indices(dimension_); getIndices(x, indices); std::vector xfloor(dimension_); getPoint(indices, xfloor); - std::vector neigh; - unsigned nneigh; - getSplineNeighbors(indices, neigh, nneigh); + std::vector neigh; unsigned nneigh; getSplineNeighbors(indices, neigh, nneigh); // loop over neighbors std::vector nindices; @@ -472,19 +431,14 @@ double GridBase::getValueAndDerivatives(const std::vector & x, std::vect for(unsigned j=0; j & x, std::vect } for(unsigned j=0; j0 && dimension_>1 && getIndices(i)[dimension_-2]==0) { - ofile.printf("\n"); - } + if(usederiv_) {f=getValueAndDerivatives(i,der);} + else {f=getValue(i);} + if(i>0 && dimension_>1 && getIndices(i)[dimension_-2]==0) ofile.printf("\n"); for(unsigned j=0; j(nbin_[j]) ); - if( pbc_[j] ) { - ofile.printField("periodic_" + argnames[j], "true" ); - } else { - ofile.printField("periodic_" + argnames[j], "false" ); - } + if( pbc_[j] ) ofile.printField("periodic_" + argnames[j], "true" ); + else ofile.printField("periodic_" + argnames[j], "false" ); } - for(unsigned j=0; j GridBase::create(const std::string& funcl, const std:: return grid; } -std::unique_ptr GridBase::create(const std::string& funcl, const std::vector & args, IFile& ifile, bool dosparse, bool dospline, bool doder) { +std::unique_ptr GridBase::create(const std::string& funcl, const std::vector & args, IFile& ifile, bool dosparse, bool dospline, bool doder) +{ std::unique_ptr grid; - unsigned nvar=args.size(); - bool hasder=false; - std::string pstring; - std::vector gbin1(nvar); - std::vector gbin(nvar); + unsigned nvar=args.size(); bool hasder=false; std::string pstring; + std::vector gbin1(nvar); std::vector gbin(nvar); std::vector labels(nvar),gmin(nvar),gmax(nvar); - std::vector fieldnames; - ifile.scanFieldList( fieldnames ); + std::vector fieldnames; ifile.scanFieldList( fieldnames ); // Retrieve names for fields - for(unsigned i=0; igetName(); - } + for(unsigned i=0; igetName(); // And read the stuff from the header plumed_massert( ifile.FieldExist( funcl ), "no column labelled " + funcl + " in in grid input"); for(unsigned i=0; i GridBase::create(const std::string& funcl, const std:: if( args[i]->isPeriodic() ) { plumed_massert( pstring=="true", "input value is periodic but grid is not"); std::string pmin, pmax; - args[i]->getDomain( pmin, pmax ); - gbin[i]=gbin1[i]; - if( pmin!=gmin[i] || pmax!=gmax[i] ) { - plumed_merror("mismatch between grid boundaries and periods of values"); - } + args[i]->getDomain( pmin, pmax ); gbin[i]=gbin1[i]; + if( pmin!=gmin[i] || pmax!=gmax[i] ) plumed_merror("mismatch between grid boundaries and periods of values"); } else { gbin[i]=gbin1[i]-1; // Note header in grid file indicates one more bin that there should be when data is not periodic plumed_massert( pstring=="false", "input value is not periodic but grid is"); } hasder=ifile.FieldExist( "der_" + args[i]->getName() ); - if( doder && !hasder ) { - plumed_merror("missing derivatives from grid file"); - } + if( doder && !hasder ) plumed_merror("missing derivatives from grid file"); for(unsigned j=0; j(funcl,args,gmin,gmax,gbin,dospline,doder); - } else { - grid=Tools::make_unique(funcl,args,gmin,gmax,gbin,dospline,doder); - } + if(!dosparse) {grid=Tools::make_unique(funcl,args,gmin,gmax,gbin,dospline,doder);} + else {grid=Tools::make_unique(funcl,args,gmin,gmax,gbin,dospline,doder);} std::vector xx(nvar),dder(nvar); std::vector dx=grid->getDx(); double f,x; while( ifile.scanField(funcl,f) ) { for(unsigned i=0; igetName(), dder[i] ); - } - } + if(hasder) { for(unsigned i=0; igetName(), dder[i] ); } } index_t index=grid->getIndex(xx); - if(doder) { - grid->setValueAndDerivatives(index,f,dder); - } else { - grid->setValue(index,f); - } + if(doder) {grid->setValueAndDerivatives(index,f,dder);} + else {grid->setValue(index,f);} ifile.scanField(); } return grid; @@ -710,9 +614,7 @@ double Grid::getMinValue() const { double minval; minval=DBL_MAX; for(index_t i=0; imaxval) { - maxval=grid_[i]; - } + if(grid_[i]>maxval)maxval=grid_[i]; } return maxval; } @@ -732,14 +632,10 @@ void Grid::scaleAllValuesAndDerivatives( const double& scalef ) { if(usederiv_) { for(index_t i=0; i direction( dimension_, 0 ); // Run over whole grid - npoints=0; - RootFindingBase mymin( this ); + npoints=0; RootFindingBase mymin( this ); for(unsigned i=0; i& der) const { plumed_dbg_assert(index& der) { plumed_dbg_assert(index& der) { plumed_dbg_assert(indexsecond; - } + if(it!=map_.end()) value=it->second; return value; } double SparseGrid::getValueAndDerivatives(index_t index, std::vector& der)const { plumed_assert(indexsecond; - } + if(it!=map_.end()) value=it->second; const auto itder=der_.find(index); - if(itder!=der_.end()) { - der=itder->second; - } + if(itder!=der_.end()) der=itder->second; return value; } @@ -950,9 +801,7 @@ void SparseGrid::addValueAndDerivatives(index_t index, double value, std::vector plumed_assert(index0 && dimension_>1 && getIndices(i)[dimension_-2]==0) { - ofile.printf("\n"); - } + if(usederiv_) {f=getValueAndDerivatives(i,der);} + else {f=getValue(i);} + if(i>0 && dimension_>1 && getIndices(i)[dimension_-2]==0) ofile.printf("\n"); for(unsigned j=0; j(nbin_[j]) ); - if( pbc_[j] ) { - ofile.printField("periodic_" + argnames[j], "true" ); - } else { - ofile.printField("periodic_" + argnames[j], "false" ); - } - } - for(unsigned j=0; jmaxval) { - maxval=i.second; - } + if(i.second>maxval) maxval=i.second; } return maxval; } @@ -1037,9 +868,7 @@ void Grid::projectOnLowDimension(double &val, std::vector &vHigh, WeightBas // std::cerr< vv(vHigh.size()); - for(unsigned j=0; j & proj, WeightBase *ptr2obj ) // check if the two key methods are there WeightBase* pp = dynamic_cast(ptr2obj); - if (!pp) { - plumed_merror("This WeightBase is not complete: you need a projectInnerLoop and projectOuterLoop "); - } + if (!pp)plumed_merror("This WeightBase is not complete: you need a projectInnerLoop and projectOuterLoop "); for(unsigned j=0; j & proj, WeightBase *ptr2obj ) for(unsigned i=0; i & proj, WeightBase *ptr2obj ) std::vector v; v=smallgrid.getIndices(i); std::vector vHigh((getArgNames()).size(),-1); - for(unsigned j=0; j & proj, WeightBase *ptr2obj ) } double Grid::integrate( std::vector& npoints ) { - plumed_dbg_assert( npoints.size()==dimension_ ); - plumed_assert( dospline_ ); + plumed_dbg_assert( npoints.size()==dimension_ ); plumed_assert( dospline_ ); - unsigned ntotgrid=1; - double box_vol=1.0; + unsigned ntotgrid=1; double box_vol=1.0; std::vector ispacing( npoints.size() ); for(unsigned j=0; j& npoints ) { } else { ispacing[j] = ( max_[j] - min_[j] ) / static_cast( npoints[j] ); } - ntotgrid*=npoints[j]; - box_vol*=ispacing[j]; + ntotgrid*=npoints[j]; box_vol*=ispacing[j]; } std::vector vals( dimension_ ); - std::vector t_index( dimension_ ); - double integral=0.0; + std::vector t_index( dimension_ ); double integral=0.0; for(unsigned i=0; i=2 ) { - t_index[dimension_-1]=((kk-t_index[dimension_-2])/npoints[dimension_-2]); - } + for(unsigned j=1; j=2 ) t_index[dimension_-1]=((kk-t_index[dimension_-2])/npoints[dimension_-2]); - for(unsigned j=0; j& npoints ) { } void Grid::mpiSumValuesAndDerivatives( Communicator& comm ) { - comm.Sum( grid_ ); - for(unsigned i=0; i getArgNames() const; /// get if the grid has derivatives - bool hasDerivatives() const { - return usederiv_; - } + bool hasDerivatives() const {return usederiv_;} /// methods to handle grid indices void getIndices(index_t index, std::vector& rindex) const; @@ -229,20 +218,17 @@ class GridBase { virtual ~GridBase() {} /// set output format - void setOutputFmt(const std::string & ss) { - fmt_=ss; - } + void setOutputFmt(const std::string & ss) {fmt_=ss;} /// reset output format to the default %14.9f format - void resetToDefaultOutputFmt() { - fmt_="%14.9f"; - } + void resetToDefaultOutputFmt() {fmt_="%14.9f";} /// /// Find the maximum over paths of the minimum value of the gridded function along the paths /// for all paths of neighboring grid lattice points from a source point to a sink point. double findMaximalPathMinimum(const std::vector &source, const std::vector &sink); }; -class Grid : public GridBase { +class Grid : public GridBase +{ std::vector grid_; std::vector der_; double contour_location=0.0; @@ -250,22 +236,20 @@ class Grid : public GridBase { Grid(const std::string& funcl, const std::vector & args, const std::vector & gmin, const std::vector & gmax, const std::vector & nbin, bool dospline, bool usederiv): - GridBase(funcl,args,gmin,gmax,nbin,dospline,usederiv) { + GridBase(funcl,args,gmin,gmax,nbin,dospline,usederiv) + { grid_.assign(maxsize_,0.0); - if(usederiv_) { - der_.assign(maxsize_*dimension_,0.0); - } + if(usederiv_) der_.assign(maxsize_*dimension_,0.0); } /// this constructor here is not Value-aware Grid(const std::string& funcl, const std::vector &names, const std::vector & gmin, const std::vector & gmax, const std::vector & nbin, bool dospline, bool usederiv, const std::vector &isperiodic, const std::vector &pmin, const std::vector &pmax ): - GridBase(funcl,names,gmin,gmax,nbin,dospline,usederiv,isperiodic,pmin,pmax) { + GridBase(funcl,names,gmin,gmax,nbin,dospline,usederiv,isperiodic,pmin,pmax) + { grid_.assign(maxsize_,0.0); - if(usederiv_) { - der_.assign(maxsize_*dimension_,0.0); - } + if(usederiv_) der_.assign(maxsize_*dimension_,0.0); } index_t getSize() const override; /// this is to access to Grid:: version of these methods (allowing overloading of virtual methods) @@ -320,7 +304,8 @@ class Grid : public GridBase { }; -class SparseGrid : public GridBase { +class SparseGrid : public GridBase +{ std::map map_; std::map< index_t,std::vector > der_; diff --git a/src/tools/HistogramBead.cpp b/src/tools/HistogramBead.cpp index 0fb95191e1..eec7d7a312 100644 --- a/src/tools/HistogramBead.cpp +++ b/src/tools/HistogramBead.cpp @@ -101,7 +101,8 @@ HistogramBead::HistogramBead(): min(0.0), max(0.0), max_minus_min(0.0), - inv_max_minus_min(0.0) { + inv_max_minus_min(0.0) +{ } std::string HistogramBead::description() const { @@ -116,9 +117,7 @@ void HistogramBead::generateBins( const std::string& params, std::vector range(2); - std::string smear; + unsigned nbins; std::vector range(2); std::string smear; bool found_nb=Tools::parse(data,"NBINS",nbins); plumed_massert(found_nb,"Number of bins in histogram not found"); bool found_r=Tools::parse(data,"LOWER",range[0]); @@ -127,12 +126,9 @@ void HistogramBead::generateBins( const std::string& params, std::vector( nbins ); + std::string lb,ub; double delr = ( range[1]-range[0] ) / static_cast( nbins ); for(unsigned i=0; i=highb ) { - errormsg="Lower bound is higher than upper bound"; - } + if( !found_r ) errormsg="Upper bound has not been specified use UPPER"; + if( lowb>=highb ) errormsg="Lower bound is higher than upper bound"; - smear=0.5; - Tools::parse(data,"SMEAR",smear); - width=smear*(highb-lowb); - init=true; + smear=0.5; Tools::parse(data,"SMEAR",smear); + width=smear*(highb-lowb); init=true; } void HistogramBead::set( double l, double h, double w) { - init=true; - lowb=l; - highb=h; - width=w; + init=true; lowb=l; highb=h; width=w; const double DP2CUTOFF=6.25; - if( type==gaussian ) { - cutoff=std::sqrt(2.0*DP2CUTOFF); - } else if( type==triangular ) { - cutoff=1.; - } else { - plumed_error(); - } + if( type==gaussian ) cutoff=std::sqrt(2.0*DP2CUTOFF); + else if( type==triangular ) cutoff=1.; + else plumed_error(); } void HistogramBead::setKernelType( const std::string& ktype ) { - if(ktype=="gaussian") { - type=gaussian; - } else if(ktype=="triangular") { - type=triangular; - } else { - plumed_merror("cannot understand kernel type " + ktype ); - } + if(ktype=="gaussian") type=gaussian; + else if(ktype=="triangular") type=triangular; + else plumed_merror("cannot understand kernel type " + ktype ); } double HistogramBead::calculate( double x, double& df ) const { @@ -216,26 +186,14 @@ double HistogramBead::calculate( double x, double& df ) const { lowB = ( difference( x, lowb ) / width ); upperB = ( difference( x, highb ) / width ); df=0; - if( std::fabs(lowB)<1. ) { - df = (1 - std::fabs(lowB)) / width; - } - if( std::fabs(upperB)<1. ) { - df -= (1 - std::fabs(upperB)) / width; - } + if( std::fabs(lowB)<1. ) df = (1 - std::fabs(lowB)) / width; + if( std::fabs(upperB)<1. ) df -= (1 - std::fabs(upperB)) / width; if (upperB<=-1. || lowB >=1.) { f=0.; } else { double ia, ib; - if( lowB>-1.0 ) { - ia=lowB; - } else { - ia=-1.0; - } - if( upperB<1.0 ) { - ib=upperB; - } else { - ib=1.0; - } + if( lowB>-1.0 ) { ia=lowB; } else { ia=-1.0; } + if( upperB<1.0 ) { ib=upperB; } else { ib=1.0; } f = (ib*(2.-std::fabs(ib))-ia*(2.-std::fabs(ia)))*0.5; } } else { @@ -248,40 +206,23 @@ double HistogramBead::calculateWithCutoff( double x, double& df ) const { plumed_dbg_assert(init && periodicity!=unset ); double lowB, upperB, f; - lowB = difference( x, lowb ) / width ; - upperB = difference( x, highb ) / width; - if( upperB<=-cutoff || lowB>=cutoff ) { - df=0; - return 0; - } + lowB = difference( x, lowb ) / width ; upperB = difference( x, highb ) / width; + if( upperB<=-cutoff || lowB>=cutoff ) { df=0; return 0; } if( type==gaussian ) { - lowB /= std::sqrt(2.0); - upperB /= std::sqrt(2.0); + lowB /= std::sqrt(2.0); upperB /= std::sqrt(2.0); df = ( exp( -lowB*lowB ) - exp( -upperB*upperB ) ) / ( std::sqrt(2*pi)*width ); f = 0.5*( erf( upperB ) - erf( lowB ) ); } else if( type==triangular ) { df=0; - if( std::fabs(lowB)<1. ) { - df = (1 - std::fabs(lowB)) / width; - } - if( std::fabs(upperB)<1. ) { - df -= (1 - std::fabs(upperB)) / width; - } + if( std::fabs(lowB)<1. ) df = (1 - std::fabs(lowB)) / width; + if( std::fabs(upperB)<1. ) df -= (1 - std::fabs(upperB)) / width; if (upperB<=-1. || lowB >=1.) { f=0.; } else { double ia, ib; - if( lowB>-1.0 ) { - ia=lowB; - } else { - ia=-1.0; - } - if( upperB<1.0 ) { - ib=upperB; - } else { - ib=1.0; - } + if( lowB>-1.0 ) { ia=lowB; } else { ia=-1.0; } + if( upperB<1.0 ) { ib=upperB; } else { ib=1.0; } f = (ib*(2.-std::fabs(ib))-ia*(2.-std::fabs(ia)))*0.5; } } else { diff --git a/src/tools/HistogramBead.h b/src/tools/HistogramBead.h index 35d3bd0ca9..247ec47c52 100644 --- a/src/tools/HistogramBead.h +++ b/src/tools/HistogramBead.h @@ -80,28 +80,20 @@ void HistogramBead::isNotPeriodic() { inline void HistogramBead::isPeriodic( const double& mlow, const double& mhigh ) { - periodicity=periodic; - min=mlow; - max=mhigh; + periodicity=periodic; min=mlow; max=mhigh; max_minus_min=max-min; plumed_massert(max_minus_min>0, "your function has a very strange domain?"); inv_max_minus_min=1.0/max_minus_min; } inline -double HistogramBead::getlowb() const { - return lowb; -} +double HistogramBead::getlowb() const { return lowb; } inline -double HistogramBead::getbigb() const { - return highb; -} +double HistogramBead::getbigb() const { return highb; } inline -double HistogramBead::getCutoff() const { - return cutoff*width; -} +double HistogramBead::getCutoff() const { return cutoff*width; } inline double HistogramBead::difference( const double& d1, const double& d2 ) const { @@ -113,9 +105,7 @@ double HistogramBead::difference( const double& d1, const double& d2 ) const { newx=Tools::pbc(newx); newx*=max_minus_min; return d2-newx; - } else { - plumed_merror("periodicty was not set"); - } + } else plumed_merror("periodicty was not set"); return 0; } diff --git a/src/tools/IFile.cpp b/src/tools/IFile.cpp index 444bd69a1c..760400ede6 100644 --- a/src/tools/IFile.cpp +++ b/src/tools/IFile.cpp @@ -44,24 +44,16 @@ size_t IFile::llread(char*ptr,size_t s) { if(gzfp) { #ifdef __PLUMED_HAS_ZLIB int rr=gzread(gzFile(gzfp),ptr,s); - if(rr==0) { - eof=true; - } - if(rr<0) { - err=true; - } + if(rr==0) eof=true; + if(rr<0) err=true; r=rr; #else plumed_merror("file " + getPath() + ": trying to use a gz file without zlib being linked"); #endif } else { r=std::fread(ptr,1,s,fp); - if(std::feof(fp)) { - eof=true; - } - if(std::ferror(fp)) { - err=true; - } + if(std::feof(fp)) eof=true; + if(std::ferror(fp)) err=true; } return r; } @@ -73,9 +65,7 @@ IFile& IFile::advanceField() { while(!done) { getline(line); // using explicit conversion not to confuse cppcheck 1.86 - if(!bool(*this)) { - return *this; - } + if(!bool(*this)) {return *this;} std::vector words=Tools::getWords(line); if(words.size()>=2 && words[0]=="#!" && words[1]=="FIELDS") { fields.clear(); @@ -92,18 +82,13 @@ IFile& IFile::advanceField() { fields.push_back(field); } else { unsigned nf=0; - for(unsigned i=0; iinsertFile(*this); - } + if(plumed) plumed->insertFile(*this); return *this; } IFile& IFile::scanFieldList(std::vector&s) { - if(!inMiddleOfField) { - advanceField(); - } + if(!inMiddleOfField) advanceField(); // using explicit conversion not to confuse cppcheck 1.86 - if(!bool(*this)) { - return *this; - } + if(!bool(*this)) return *this; s.clear(); - for(unsigned i=0; i slist; scanFieldList(slist); int mycount = (int) std::count(slist.begin(), slist.end(), s); - if(mycount>0) { - return true; - } else { - return false; - } + if(mycount>0) return true; + else return false; } IFile& IFile::scanField(const std::string&name,std::string&str) { - if(!inMiddleOfField) { - advanceField(); - } + if(!inMiddleOfField) advanceField(); // using explicit conversion not to confuse cppcheck 1.86 - if(!bool(*this)) { - return *this; - } + if(!bool(*this)) return *this; unsigned i=findField(name); str=fields[i].value; fields[i].read=true; @@ -183,63 +154,49 @@ IFile& IFile::scanField(const std::string&name,std::string&str) { IFile& IFile::scanField(const std::string&name,double &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } IFile& IFile::scanField(const std::string&name,int &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } IFile& IFile::scanField(const std::string&name,long int &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } IFile& IFile::scanField(const std::string&name,long long int &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } IFile& IFile::scanField(const std::string&name,unsigned &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } IFile& IFile::scanField(const std::string&name,long unsigned &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } IFile& IFile::scanField(const std::string&name,long long unsigned &x) { std::string str; scanField(name,str); - if(*this) { - Tools::convert(str,x); - } + if(*this) Tools::convert(str,x); return *this; } @@ -271,13 +228,12 @@ IFile& IFile::scanField() { IFile::IFile(): inMiddleOfField(false), ignoreFields(false), - noEOL(false) { + noEOL(false) +{ } IFile::~IFile() { - if(inMiddleOfField) { - std::cerr<<"WARNING: IFile closed in the middle of reading. seems strange!\n"; - } + if(inMiddleOfField) std::cerr<<"WARNING: IFile closed in the middle of reading. seems strange!\n"; } IFile& IFile::getline(std::string &str) { @@ -293,15 +249,11 @@ IFile& IFile::getline(std::string &str) { plumed_massert(tmp=='\n',"plumed only accepts \\n (unix) or \\r\\n (dos) new lines"); } if(eof && noEOL) { - if(str.length()>0) { - eof=false; - } + if(str.length()>0) eof=false; } else if(eof || err || tmp!='\n') { eof = true; str=""; - if(!err) { - fsetpos(fp,&pos); - } + if(!err) fsetpos(fp,&pos); // there was a fsetpos here that apparently is not necessary // fsetpos(fp,&pos); // I think it was necessary to have rewind working correctly @@ -315,10 +267,7 @@ IFile& IFile::getline(std::string &str) { unsigned IFile::findField(const std::string&name)const { unsigned i; - for(i=0; i=fields.size()) { plumed_merror("file " + getPath() + ": field " + name + " cannot be found"); } @@ -328,13 +277,9 @@ unsigned IFile::findField(const std::string&name)const { void IFile::reset(bool reset) { eof = reset; err = reset; - if(!reset && fp) { - clearerr(fp); - } + if(!reset && fp) clearerr(fp); #ifdef __PLUMED_HAS_ZLIB - if(!reset && gzfp) { - gzclearerr(gzFile(gzfp)); - } + if(!reset && gzfp) gzclearerr(gzFile(gzfp)); #endif return; } diff --git a/src/tools/KernelFunctions.cpp b/src/tools/KernelFunctions.cpp index ad69465590..b824d7048d 100644 --- a/src/tools/KernelFunctions.cpp +++ b/src/tools/KernelFunctions.cpp @@ -105,48 +105,26 @@ KernelFunctions::KernelFunctions( const std::string& input ) { std::vector at; bool foundc = Tools::parseVector(data,"CENTER",at); - if(!foundc) { - plumed_merror("failed to find center keyword in definition of kernel"); - } + if(!foundc) plumed_merror("failed to find center keyword in definition of kernel"); std::vector sig; bool founds = Tools::parseVector(data,"SIGMA",sig); - if(!founds) { - plumed_merror("failed to find sigma keyword in definition of kernel"); - } + if(!founds) plumed_merror("failed to find sigma keyword in definition of kernel"); - bool multi=false; - Tools::parseFlag(data,"MULTIVARIATE",multi); - bool vonmises=false; - Tools::parseFlag(data,"VON-MISSES",vonmises); - if( center.size()==1 && multi ) { - plumed_merror("one dimensional kernel cannot be multivariate"); - } - if( center.size()==1 && vonmises ) { - plumed_merror("one dimensional kernal cannot be von-misses"); - } - if( center.size()==1 && sig.size()!=1 ) { - plumed_merror("size mismatch between center size and sigma size"); - } - if( multi && center.size()>1 && sig.size()!=0.5*center.size()*(center.size()-1) ) { - plumed_merror("size mismatch between center size and sigma size"); - } - if( !multi && center.size()>1 && sig.size()!=center.size() ) { - plumed_merror("size mismatch between center size and sigma size"); - } + bool multi=false; Tools::parseFlag(data,"MULTIVARIATE",multi); + bool vonmises=false; Tools::parseFlag(data,"VON-MISSES",vonmises); + if( center.size()==1 && multi ) plumed_merror("one dimensional kernel cannot be multivariate"); + if( center.size()==1 && vonmises ) plumed_merror("one dimensional kernal cannot be von-misses"); + if( center.size()==1 && sig.size()!=1 ) plumed_merror("size mismatch between center size and sigma size"); + if( multi && center.size()>1 && sig.size()!=0.5*center.size()*(center.size()-1) ) plumed_merror("size mismatch between center size and sigma size"); + if( !multi && center.size()>1 && sig.size()!=center.size() ) plumed_merror("size mismatch between center size and sigma size"); double h; bool foundh = Tools::parse(data,"HEIGHT",h); - if( !foundh) { - h=1.0; - } + if( !foundh) h=1.0; - if( multi ) { - setData( at, sig, name, "MULTIVARIATE", h ); - } else if( vonmises ) { - setData( at, sig, name, "VON-MISSES", h ); - } else { - setData( at, sig, name, "DIAGONAL", h ); - } + if( multi ) setData( at, sig, name, "MULTIVARIATE", h ); + else if( vonmises ) setData( at, sig, name, "VON-MISSES", h ); + else setData( at, sig, name, "DIAGONAL", h ); } KernelFunctions::KernelFunctions( const std::vector& at, const std::vector& sig, const std::string& type, const std::string& mtype, const double& w ) { @@ -164,7 +142,8 @@ KernelFunctions::KernelFunctions( const KernelFunctions* in ): ktype(in->ktype), center(in->center), width(in->width), - height(in->height) { + height(in->height) +{ if(!dp2cutoffNoStretch()) { stretchA=dp2cutoffA; stretchB=dp2cutoffB; @@ -174,23 +153,12 @@ KernelFunctions::KernelFunctions( const KernelFunctions* in ): void KernelFunctions::setData( const std::vector& at, const std::vector& sig, const std::string& type, const std::string& mtype, const double& w ) { height=w; - center.resize( at.size() ); - for(unsigned i=0; i& myvals ) { double det=1.; unsigned ncv=ndim(); if(dtype==diagonal) { - for(unsigned i=0; i mymatrix( getMatrix() ), myinv( ncv, ncv ); - Invert(mymatrix,myinv); - double logd; + Invert(mymatrix,myinv); double logd; logdet( myinv, logd ); det=std::exp(logd); } @@ -234,22 +199,15 @@ void KernelFunctions::normalize( const std::vector& myvals ) { } else if( ktype==uniform || ktype==triangular ) { if( ncv%2==1 ) { double dfact=1; - for(unsigned i=1; i(i); - } + for(unsigned i=1; i(i); volume=( pow( pi, (ncv-1)/2 ) ) * ( pow( 2., (ncv+1)/2 ) ) / dfact; } else { double fact=1.; - for(unsigned i=1; i(i); - } + for(unsigned i=1; i(i); volume=pow( pi,ncv/2 ) / fact; } - if(ktype==uniform) { - volume*=det; - } else if(ktype==triangular) { - volume*=det / 3.; - } + if(ktype==uniform) volume*=det; + else if(ktype==triangular) volume*=det / 3.; } else { plumed_merror("not a valid kernel type"); } @@ -260,9 +218,7 @@ void KernelFunctions::normalize( const std::vector& myvals ) { // Now calculate determinant for aperiodic variables unsigned naper=0; for(unsigned i=0; iisPeriodic() ) { - naper++; - } + if( !myvals[i]->isPeriodic() ) naper++; } // Now construct sub matrix double volume=1; @@ -270,23 +226,16 @@ void KernelFunctions::normalize( const std::vector& myvals ) { unsigned isub=0; Matrix mymatrix( getMatrix() ), mysub( naper, naper ); for(unsigned i=0; iisPeriodic() ) { - continue; - } + if( myvals[i]->isPeriodic() ) continue; unsigned jsub=0; for(unsigned j=0; jisPeriodic() ) { - continue; - } - mysub( isub, jsub ) = mymatrix( i, j ); - jsub++; + if( myvals[j]->isPeriodic() ) continue; + mysub( isub, jsub ) = mymatrix( i, j ); jsub++; } isub++; } - Matrix myisub( naper, naper ); - double logd; - Invert( mysub, myisub ); - logdet( myisub, logd ); + Matrix myisub( naper, naper ); double logd; + Invert( mysub, myisub ); logdet( myisub, logd ); det=std::exp(logd); volume=pow( 2*pi, 0.5*ncv ) * pow( det, 0.5 ); } @@ -294,9 +243,7 @@ void KernelFunctions::normalize( const std::vector& myvals ) { // Calculate volume of periodic variables unsigned nper=0; for(unsigned i=0; iisPeriodic() ) { - nper++; - } + if( myvals[i]->isPeriodic() ) nper++; } // Now construct sub matrix @@ -304,24 +251,18 @@ void KernelFunctions::normalize( const std::vector& myvals ) { unsigned isub=0; Matrix mymatrix( getMatrix() ), mysub( nper, nper ); for(unsigned i=0; iisPeriodic() ) { - continue; - } + if( !myvals[i]->isPeriodic() ) continue; unsigned jsub=0; for(unsigned j=0; jisPeriodic() ) { - continue; - } - mysub( isub, jsub ) = mymatrix( i, j ); - jsub++; + if( !myvals[j]->isPeriodic() ) continue; + mysub( isub, jsub ) = mymatrix( i, j ); jsub++; } isub++; } Matrix eigvec( nper, nper ); std::vector eigval( nper ); diagMat( mysub, eigval, eigvec ); - unsigned iper=0; - volume=1; + unsigned iper=0; volume=1; for(unsigned i=0; iisPeriodic() ) { volume *= myvals[i]->getMaxMinusMin()*Tools::bessel0(eigval[iper])*std::exp(-eigval[iper]); @@ -334,15 +275,10 @@ void KernelFunctions::normalize( const std::vector& myvals ) { double KernelFunctions::getCutoff( const double& width ) const { const double DP2CUTOFF=6.25; - if( ktype==gaussian || ktype==truncatedgaussian || ktype==stretchedgaussian ) { - return std::sqrt(2.0*DP2CUTOFF)*width; - } else if(ktype==triangular ) { - return width; - } else if(ktype==uniform) { - return width; - } else { - plumed_merror("No valid kernel type"); - } + if( ktype==gaussian || ktype==truncatedgaussian || ktype==stretchedgaussian ) return std::sqrt(2.0*DP2CUTOFF)*width; + else if(ktype==triangular ) return width; + else if(ktype==uniform) return width; + else plumed_merror("No valid kernel type"); return 0.0; } @@ -350,22 +286,16 @@ std::vector KernelFunctions::getContinuousSupport( ) const { unsigned ncv=ndim(); std::vector support( ncv ); if(dtype==diagonal) { - for(unsigned i=0; i mymatrix( getMatrix() ), myinv( ncv,ncv ); Invert(mymatrix,myinv); - Matrix myautovec(ncv,ncv); - std::vector myautoval(ncv); + Matrix myautovec(ncv,ncv); std::vector myautoval(ncv); diagMat(myinv,myautoval,myautovec); double maxautoval=0.; unsigned ind_maxautoval=0; for (unsigned i=0; imaxautoval) { - maxautoval=myautoval[i]; - ind_maxautoval=i; - } + if(myautoval[i]>maxautoval) {maxautoval=myautoval[i]; ind_maxautoval=i;} } for(unsigned i=0; i KernelFunctions::getSupport( const std::vector& dx plumed_assert( ndim()==dx.size() ); std::vector support( dx.size() ); std::vector vv=getContinuousSupport( ); - for(unsigned i=0; i(ceil( vv[i]/dx[i] )); - } + for(unsigned i=0; i(ceil( vv[i]/dx[i] )); return support; } double KernelFunctions::evaluate( const std::vector& pos, std::vector& derivatives, bool usederiv, bool doInt, double lowI_, double uppI_) const { plumed_dbg_assert( pos.size()==ndim() && derivatives.size()==ndim() ); #ifndef NDEBUG - if( usederiv ) { - plumed_massert( ktype!=uniform, "step function can not be differentiated" ); - } + if( usederiv ) plumed_massert( ktype!=uniform, "step function can not be differentiated" ); #endif if(doInt) { plumed_dbg_assert(center.size()==1); - if(pos[0]->get()set(lowI_); - } - if(pos[0]->get()>uppI_) { - pos[0]->set(uppI_); - } + if(pos[0]->get()set(lowI_); + if(pos[0]->get()>uppI_) pos[0]->set(uppI_); } double r2=0; if(dtype==diagonal) { @@ -413,15 +335,11 @@ double KernelFunctions::evaluate( const std::vector& pos, std::vector mymatrix( getMatrix() ); for(unsigned i=0; idifference( center[i] ); for(unsigned j=0; jdifference( center[j] ); - } + if(i==j) dp_j=dp_i; + else dp_j=-pos[j]->difference( center[j] ); derivatives[i]+=mymatrix(i,j)*dp_j; r2+=dp_i*dp_j*mymatrix(i,j); @@ -448,23 +366,16 @@ double KernelFunctions::evaluate( const std::vector& pos, std::vectorisPeriodic() ) { - derivatives[i] *= (2*pi/pos[i]->getMaxMinusMin()); - } - } - for(unsigned i=0; iisPeriodic() ) derivatives[i] *= (2*pi/pos[i]->getMaxMinusMin()); } + for(unsigned i=0; i& pos, std::vectorget() <= lowI_ || pos[0]->get() >= uppI_) && usederiv ) - for(unsigned i=0; iget() <= lowI_ || pos[0]->get() >= uppI_) && usederiv ) for(unsigned i=0; i KernelFunctions::read( IFile* ifile, const bool& cholesky, const std::vector& valnames ) { double h; - if( !ifile->scanField("height",h) ) { - return NULL; - }; - - std::string sss; - ifile->scanField("multivariate",sss); - std::string ktype="stretched-gaussian"; - if( ifile->FieldExist("kerneltype") ) { - ifile->scanField("kerneltype",ktype); - } + if( !ifile->scanField("height",h) ) return NULL;; + + std::string sss; ifile->scanField("multivariate",sss); + std::string ktype="stretched-gaussian"; if( ifile->FieldExist("kerneltype") ) ifile->scanField("kerneltype",ktype); plumed_massert( sss=="false" || sss=="true" || sss=="von-misses", "multivariate flag must be either false, true or von-misses"); // Read the position of the center std::vector cc( valnames.size() ); - for(unsigned i=0; iscanField(valnames[i],cc[i]); - } + for(unsigned i=0; iscanField(valnames[i],cc[i]); std::vector sig; if( sss=="false" ) { sig.resize( valnames.size() ); for(unsigned i=0; iscanField("sigma_"+valnames[i],sig[i]); - if( !cholesky ) { - sig[i]=std::sqrt(sig[i]); - } + if( !cholesky ) sig[i]=std::sqrt(sig[i]); } return Tools::make_unique(cc, sig, ktype, "DIAGONAL", h); } @@ -550,24 +439,16 @@ std::unique_ptr KernelFunctions::read( IFile* ifile, const bool for(unsigned i=0; iscanField("sigma_" +valnames[j+i] + "_" + valnames[j], lower(j+i,j) ); - upper(j,j+i)=lower(j+i,j); - mymult(j+i,j)=mymult(j,j+i)=lower(j+i,j); + upper(j,j+i)=lower(j+i,j); mymult(j+i,j)=mymult(j,j+i)=lower(j+i,j); } } - if( cholesky ) { - mult(lower,upper,mymult); - } + if( cholesky ) mult(lower,upper,mymult); Invert( mymult, invmatrix ); unsigned k=0; for(unsigned i=0; i(cc, sig, ktype, "MULTIVARIATE", h); + for(unsigned j=i; j(cc, sig, ktype, "MULTIVARIATE", h); return Tools::make_unique( cc, sig, ktype, "VON-MISSES", h ); } diff --git a/src/tools/KernelFunctions.h b/src/tools/KernelFunctions.h index 72b1ba9c42..7e9def564a 100644 --- a/src/tools/KernelFunctions.h +++ b/src/tools/KernelFunctions.h @@ -73,8 +73,7 @@ class KernelFunctions { inline Matrix KernelFunctions::getMatrix() const { - unsigned k=0, ncv=ndim(); - Matrix mymatrix(ncv,ncv); + unsigned k=0, ncv=ndim(); Matrix mymatrix(ncv,ncv); for(unsigned i=0; i& kk, std::vector& std::map& cd ) const { for(unsigned i=0; i( thiskey,types.find(thiskey)->second) ); - if( (types.find(thiskey)->second).isAtomList() ) { - atags.insert( std::pair( thiskey,atomtags.find(thiskey)->second) ); - } + if( (types.find(thiskey)->second).isAtomList() ) atags.insert( std::pair( thiskey,atomtags.find(thiskey)->second) ); plumed_massert( allowmultiple.count( thiskey ), "no numbered data on keyword " + thiskey + " to copy" ); am.insert( std::pair(thiskey,allowmultiple.find(thiskey)->second) ); plumed_massert( documentation.count( thiskey ), "no documentation for keyword " + thiskey + " to copy" ); docs.insert( std::pair(thiskey,documentation.find(thiskey)->second) ); - if( booldefs.count( thiskey ) ) { - bools.insert( std::pair( thiskey,booldefs.find(thiskey)->second) ); - } - if( numdefs.count( thiskey ) ) { - nums.insert( std::pair( thiskey,numdefs.find(thiskey)->second) ); - } + if( booldefs.count( thiskey ) ) bools.insert( std::pair( thiskey,booldefs.find(thiskey)->second) ); + if( numdefs.count( thiskey ) ) nums.insert( std::pair( thiskey,numdefs.find(thiskey)->second) ); } for(unsigned i=0; i( thiskey,types.find(thiskey)->second) ); - if( (types.find(thiskey)->second).isAtomList() ) { - atags.insert( std::pair( thiskey,atomtags.find(thiskey)->second) ); - } + if( (types.find(thiskey)->second).isAtomList() ) atags.insert( std::pair( thiskey,atomtags.find(thiskey)->second) ); plumed_massert( allowmultiple.count( thiskey ), "no numbered data on keyword " + thiskey + " to copy" ); am.insert( std::pair(thiskey,allowmultiple.find(thiskey)->second) ); plumed_massert( documentation.count( thiskey ), "no documentation for keyword " + thiskey + " to copy" ); docs.insert( std::pair(thiskey,documentation.find(thiskey)->second) ); - if( booldefs.count( thiskey ) ) { - bools.insert( std::pair( thiskey,booldefs.find(thiskey)->second) ); - } - if( numdefs.count( thiskey ) ) { - nums.insert( std::pair( thiskey,numdefs.find(thiskey)->second) ); - } + if( booldefs.count( thiskey ) ) bools.insert( std::pair( thiskey,booldefs.find(thiskey)->second) ); + if( numdefs.count( thiskey ) ) nums.insert( std::pair( thiskey,numdefs.find(thiskey)->second) ); } for(unsigned i=0; i( thisnam, ckey.find(thisnam)->second) ); @@ -143,24 +121,19 @@ void Keywords::reserve( const std::string & t, const std::string & k, const std: plumed_assert( !exists(k) && !reserved(k) ); std::string fd, lowkey=k; // Convert to lower case - std::transform(lowkey.begin(),lowkey.end(),lowkey.begin(),[](unsigned char c) { - return std::tolower(c); - }); + std::transform(lowkey.begin(),lowkey.end(),lowkey.begin(),[](unsigned char c) { return std::tolower(c); }); // Remove any underscore characters for(unsigned i=0;; ++i) { std::size_t num=lowkey.find_first_of("_"); - if( num==std::string::npos ) { - break; - } + if( num==std::string::npos ) break; lowkey.erase( lowkey.begin() + num, lowkey.begin() + num + 1 ); } if( t=="vessel" ) { fd = d + " The final value can be referenced using label." + lowkey; - if(d.find("flag")==std::string::npos) - fd += ". You can use multiple instances of this keyword i.e. " + - k +"1, " + k + "2, " + k + "3... The corresponding values are then " - "referenced using label."+ lowkey +"-1, label." + lowkey + - "-2, label." + lowkey + "-3..."; + if(d.find("flag")==std::string::npos) fd += ". You can use multiple instances of this keyword i.e. " + + k +"1, " + k + "2, " + k + "3... The corresponding values are then " + "referenced using label."+ lowkey +"-1, label." + lowkey + + "-2, label." + lowkey + "-3..."; allowmultiple.insert( std::pair(k,true) ); types.insert( std::pair(k,KeyType("vessel")) ); } else if( t=="numbered" ) { @@ -169,14 +142,10 @@ void Keywords::reserve( const std::string & t, const std::string & k, const std: types.insert( std::pair(k,KeyType("optional")) ); } else { fd = d; - if( t=="atoms" && isaction ) { - fd = d + ". For more information on how to specify lists of atoms see \\ref Group"; - } + if( t=="atoms" && isaction ) fd = d + ". For more information on how to specify lists of atoms see \\ref Group"; allowmultiple.insert( std::pair(k,false) ); types.insert( std::pair(k,KeyType(t)) ); - if( (types.find(k)->second).isAtomList() ) { - atomtags.insert( std::pair(k,t) ); - } + if( (types.find(k)->second).isAtomList() ) atomtags.insert( std::pair(k,t) ); } documentation.insert( std::pair(k,fd) ); reserved_keys.push_back(k); @@ -185,16 +154,9 @@ void Keywords::reserve( const std::string & t, const std::string & k, const std: void Keywords::reserveFlag( const std::string & k, const bool def, const std::string & d ) { plumed_assert( !exists(k) && !reserved(k) ); std::string defstr; - if( def ) { - defstr="( default=on ) "; - } else { - defstr="( default=off ) "; - } + if( def ) { defstr="( default=on ) "; } else { defstr="( default=off ) "; } types.insert( std::pair(k,KeyType("flag")) ); - std::string fd,lowkey=k; - std::transform(lowkey.begin(),lowkey.end(),lowkey.begin(),[](unsigned char c) { - return std::tolower(c); - }); + std::string fd,lowkey=k; std::transform(lowkey.begin(),lowkey.end(),lowkey.begin(),[](unsigned char c) { return std::tolower(c); }); fd=defstr + d; documentation.insert( std::pair(k,fd) ); allowmultiple.insert( std::pair(k,false) ); @@ -205,21 +167,15 @@ void Keywords::reserveFlag( const std::string & k, const bool def, const std::st void Keywords::use( const std::string & k ) { plumed_massert( reserved(k), "the " + k + " keyword is not reserved"); for(unsigned i=0; isecond).setStyle(style); - if( (types.find(k)->second).isVessel() ) { - allowmultiple[k]=true; - } - if( (types.find(k)->second).isAtomList() ) { - atomtags.insert( std::pair(k,style) ); - } + if( (types.find(k)->second).isVessel() ) allowmultiple[k]=true; + if( (types.find(k)->second).isAtomList() ) atomtags.insert( std::pair(k,style) ); } void Keywords::add( const std::string & t, const std::string & k, const std::string & d ) { @@ -233,13 +189,9 @@ void Keywords::add( const std::string & t, const std::string & k, const std::str fd=d; allowmultiple.insert( std::pair(k,false) ); types.insert( std::pair(k,KeyType(t)) ); - if( (types.find(k)->second).isAtomList() ) { - atomtags.insert( std::pair(k,t) ); - } - } - if( t=="atoms" && isaction ) { - fd = d + ". For more information on how to specify lists of atoms see \\ref Group"; + if( (types.find(k)->second).isAtomList() ) atomtags.insert( std::pair(k,t) ); } + if( t=="atoms" && isaction ) fd = d + ". For more information on how to specify lists of atoms see \\ref Group"; documentation.insert( std::pair(k,fd) ); keys.push_back(k); } @@ -255,8 +207,7 @@ void Keywords::add( const std::string & t, const std::string & k, const std::str void Keywords::addFlag( const std::string & k, const bool def, const std::string & d ) { plumed_massert( !exists(k) && !reserved(k), "keyword " + k + " has already been registered"); - std::string defstr; - plumed_massert( !def, "the second argument to addFlag must be false " + k ); + std::string defstr; plumed_massert( !def, "the second argument to addFlag must be false " + k ); defstr="( default=off ) "; types.insert( std::pair(k,KeyType("flag")) ); documentation.insert( std::pair(k,defstr + d) ); @@ -266,49 +217,32 @@ void Keywords::addFlag( const std::string & k, const bool def, const std::string } void Keywords::remove( const std::string & k ) { - bool found=false; - unsigned j=0, n=0; + bool found=false; unsigned j=0, n=0; while(true) { - for(j=0; jsecond; } bool Keywords::style( const std::string & k, const std::string & t ) const { - if( getStyle(k)==t ) { - return true; - } + if( getStyle(k)==t ) return true; return false; } @@ -323,18 +257,14 @@ std::string Keywords::getKeyword( const unsigned i ) const { bool Keywords::exists( const std::string & k ) const { for(unsigned i=0; isecond).isAtomList() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isAtomList() ) nkeys++; } if( nkeys>0 ) { std::string prevtag="start"; for(unsigned i=0; isecond).isAtomList() ) { plumed_massert( atomtags.count(keys[i]), "keyword " + keys[i] + " allegedly specifies atoms but no tag has been specified. Please email Gareth Tribello"); - if( prevtag!="start" && prevtag!=atomtags.find(keys[i])->second ) { - break; - } - if( (atomtags.find(keys[i])->second).find("residues")!=std::string::npos) { - std::printf(" %s=", keys[i].c_str() ); - } else { - std::printf(" %s=", keys[i].c_str() ); - } + if( prevtag!="start" && prevtag!=atomtags.find(keys[i])->second ) break; + if( (atomtags.find(keys[i])->second).find("residues")!=std::string::npos) std::printf(" %s=", keys[i].c_str() ); + else std::printf(" %s=", keys[i].c_str() ); prevtag=atomtags.find(keys[i])->second; } } @@ -367,9 +290,7 @@ void Keywords::print_template(const std::string& actionname, bool include_option nkeys=0; for(unsigned i=0; isecond).isCompulsory() ) { - nkeys++; - } + (types.find(keys[i])->second).isCompulsory() ) nkeys++; } if( nkeys>0 ) { for(unsigned i=0; isecond).isFlag() ) { std::printf( ",flag:%s", keys[i].c_str() ); } else { - if( allowmultiple.find(keys[i])->second ) { - std::printf(",numbered:%s",keys[i].c_str() ); - } else { - std::printf(",option:%s",keys[i].c_str() ); - } + if( allowmultiple.find(keys[i])->second ) std::printf(",numbered:%s",keys[i].c_str() ); + else std::printf(",option:%s",keys[i].c_str() ); } } std::fprintf(stdout, "\n%s", getHelpString().c_str() ); @@ -411,9 +329,7 @@ void Keywords::print_html() const { if( cnames.size()>0 ) { unsigned ndef=0; for(unsigned i=0; isecond=="default") { - ndef++; - } + if(ckey.find(cnames[i])->second=="default") ndef++; } if( ndef>0 ) { @@ -424,10 +340,7 @@ void Keywords::print_html() const { unsigned nndef=0; for(unsigned i=0; isecond=="default" ); - if( ckey.find(cnames[i])->second!="default" ) { - nndef++; - continue; - } + if( ckey.find(cnames[i])->second!="default" ) { nndef++; continue; } std::printf("\n"); std::printf(" %s \n",cnames[i].c_str() ); std::printf(" %s \n",(cdocs.find(cnames[i])->second).c_str() ); @@ -453,9 +366,7 @@ void Keywords::print_html() const { } else { unsigned nregs=0; for(unsigned i=0; isecond) ) { - nregs++; - } + if( exists(ckey.find(cnames[i])->second) ) nregs++; } if( nregs>0 ) { std::cout<<"\\par Description of components\n\n"; @@ -478,34 +389,22 @@ void Keywords::print_html() const { unsigned nkeys=0; for(unsigned i=0; isecond).isAtomList() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isAtomList() ) nkeys++; } if( nkeys>0 ) { - if(isaction && isatoms) { - std::cout<<"\\par The atoms involved can be specified using\n\n"; - } else if(isaction) { - std::cout<<"\\par The data to analyze can be the output from another analysis algorithm\n\n"; - } else { - std::cout<<"\\par The input trajectory is specified using one of the following\n\n"; - } + if(isaction && isatoms) std::cout<<"\\par The atoms involved can be specified using\n\n"; + else if(isaction) std::cout<<"\\par The data to analyze can be the output from another analysis algorithm\n\n"; + else std::cout<<"\\par The input trajectory is specified using one of the following\n\n"; std::cout<<" \n"; - std::string prevtag="start"; - unsigned counter=0; + std::string prevtag="start"; unsigned counter=0; for(unsigned i=0; isecond).isAtomList() ) { plumed_massert( atomtags.count(keys[i]), "keyword " + keys[i] + " allegedly specifies atoms but no tag has been specified. Please email Gareth Tribello"); if( prevtag!="start" && prevtag!=atomtags.find(keys[i])->second && isaction ) { std::cout<<"
\n\n"; - if( isatoms ) { - std::cout<<"\\par Or alternatively by using\n\n"; - } else if( counter==0 ) { - std::cout<<"\\par Alternatively data can be collected from the trajectory using \n\n"; - counter++; - } else { - std::cout<<"\\par Lastly data collected in a previous analysis action can be reanalyzed by using the keyword \n\n"; - } + if( isatoms ) std::cout<<"\\par Or alternatively by using\n\n"; + else if( counter==0 ) { std::cout<<"\\par Alternatively data can be collected from the trajectory using \n\n"; counter++; } + else std::cout<<"\\par Lastly data collected in a previous analysis action can be reanalyzed by using the keyword \n\n"; std::cout<<" \n"; } print_html_item( keys[i] ); @@ -516,152 +415,102 @@ void Keywords::print_html() const { } nkeys=0; for(unsigned i=0; isecond).isCompulsory() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isCompulsory() ) nkeys++; } if( nkeys>0 ) { - if(isaction) { - std::cout<< "\\par Compulsory keywords\n\n"; - } else { - std::cout<<"\\par The following must be present\n\n"; - } + if(isaction) std::cout<< "\\par Compulsory keywords\n\n"; + else std::cout<<"\\par The following must be present\n\n"; std::cout<<"
\n"; for(unsigned i=0; isecond).isCompulsory() ) { - print_html_item( keys[i] ); - } + if ( (types.find(keys[i])->second).isCompulsory() ) print_html_item( keys[i] ); } std::cout<<"
\n\n"; } nkeys=0; for(unsigned i=0; isecond).isFlag() || (types.find(keys[i])->second).isOptional() || (types.find(keys[i])->second).isVessel() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isFlag() || (types.find(keys[i])->second).isOptional() || (types.find(keys[i])->second).isVessel() ) nkeys++; } if( nkeys>0 ) { - if(isaction) { - std::cout<<"\\par Options\n\n"; - } else { - std::cout<<"\\par The following options are available\n\n"; - } + if(isaction) std::cout<<"\\par Options\n\n"; + else std::cout<<"\\par The following options are available\n\n"; std::cout<<" \n"; for(unsigned i=0; isecond).isFlag() ) { - print_html_item( keys[i] ); - } + if ( (types.find(keys[i])->second).isFlag() ) print_html_item( keys[i] ); } std::cout<<"\n"; } nkeys=0; for(unsigned i=0; isecond).isOptional() || (types.find(keys[i])->second).isVessel() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isOptional() || (types.find(keys[i])->second).isVessel() ) nkeys++; } if( nkeys>0 ) { for(unsigned i=0; isecond).isOptional() || (types.find(keys[i])->second).isVessel() ) { - print_html_item( keys[i] ); - } + if ( (types.find(keys[i])->second).isOptional() || (types.find(keys[i])->second).isVessel() ) print_html_item( keys[i] ); } } std::cout<<"
\n\n"; } void Keywords::print_spelling() const { - for(unsigned i=0; isecond).find("\\f$")!=std::string::npos ); // Check for latex std::vector w=Tools::getWords( documentation.find(key)->second ); - std::stringstream sstr; - sstr<60 ) { - sstr<<"\n"<second).isAtomList() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isAtomList() ) nkeys++; } if( nkeys>0 ) { helpstr += "The input trajectory can be in any of the following formats: \n\n"; for(unsigned i=0; isecond).isAtomList() ) { - helpstr += getKeywordDocs( keys[i] ); - } + if ( (types.find(keys[i])->second).isAtomList() ) helpstr += getKeywordDocs( keys[i] ); } } nkeys=0; for(unsigned i=0; isecond).isCompulsory() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isCompulsory() ) nkeys++; } unsigned ncompulsory=nkeys; if( nkeys>0 ) { helpstr += "\nThe following arguments are compulsory: \n\n"; for(unsigned i=0; isecond).isCompulsory() ) { - helpstr += getKeywordDocs( keys[i] ); - } + if ( (types.find(keys[i])->second).isCompulsory() ) helpstr += getKeywordDocs( keys[i] ); } } nkeys=0; for(unsigned i=0; isecond).isFlag() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isFlag() ) nkeys++; } if( nkeys>0 ) { - if(ncompulsory>0) { - helpstr += "\nIn addition you may use the following options: \n\n"; - } else { - helpstr += "\nThe following options are available\n\n"; - } + if(ncompulsory>0) helpstr += "\nIn addition you may use the following options: \n\n"; + else helpstr += "\nThe following options are available\n\n"; for(unsigned i=0; isecond).isFlag() ) { - helpstr += getKeywordDocs( keys[i] ).c_str(); - } + if ( (types.find(keys[i])->second).isFlag() ) helpstr += getKeywordDocs( keys[i] ).c_str(); } } nkeys=0; for(unsigned i=0; isecond).isOptional() || (types.find(keys[i])->second).isVessel() ) { - nkeys++; - } + if ( (types.find(keys[i])->second).isOptional() || (types.find(keys[i])->second).isVessel() ) nkeys++; } if( nkeys>0 ) { for(unsigned i=0; isecond).isOptional() || (types.find(keys[i])->second).isVessel() ) { - helpstr += getKeywordDocs( keys[i] ); - } + if ( (types.find(keys[i])->second).isOptional() || (types.find(keys[i])->second).isVessel() ) helpstr += getKeywordDocs( keys[i] ); } helpstr += "\n"; } @@ -677,34 +526,22 @@ void Keywords::print( FILE* out ) const { } std::string Keywords::getTooltip( const std::string& name ) const { - std::size_t dd=name.find_first_of("0123456789"); - std::string kname=name.substr(0,dd); - if( !exists(kname) ) { - return " could not find this keyword "; - } + std::size_t dd=name.find_first_of("0123456789"); std::string kname=name.substr(0,dd); + if( !exists(kname) ) return " could not find this keyword "; std::string mystring, docstr = documentation.find(kname)->second; if( types.find(kname)->second.isCompulsory() ) { mystring += "compulsory keyword "; if( docstr.find("default")!=std::string::npos ) { - std::size_t bra = docstr.find_first_of(")"); - mystring += docstr.substr(0,bra+1); - docstr = docstr.substr(bra+1); + std::size_t bra = docstr.find_first_of(")"); mystring += docstr.substr(0,bra+1); docstr = docstr.substr(bra+1); } mystring += "\n"; } - std::vector w=Tools::getWords( docstr ); - unsigned nl=0; + std::vector w=Tools::getWords( docstr ); unsigned nl=0; for(unsigned i=0; i80 ) { - mystring += w[i] + "\n"; - nl=0; - } else { - mystring += w[i] + " "; - } - if( w[i].find(".")!=std::string::npos ) { - break; // Only write up the the first dot - } + if( nl>80 ) { mystring += w[i] + "\n"; nl=0; } + else { mystring += w[i] + " "; } + if( w[i].find(".")!=std::string::npos ) break; // Only write up the the first dot } return mystring; } @@ -742,17 +579,10 @@ bool Keywords::getDefaultValue(const std::string & key, std::string& def ) const } void Keywords::destroyData() { - keys.clear(); - reserved_keys.clear(); - types.clear(); - allowmultiple.clear(); - documentation.clear(); - booldefs.clear(); - numdefs.clear(); - atomtags.clear(); - ckey.clear(); - cdocs.clear(); - ckey.clear(); + keys.clear(); reserved_keys.clear(); types.clear(); + allowmultiple.clear(); documentation.clear(); + booldefs.clear(); numdefs.clear(); atomtags.clear(); + ckey.clear(); cdocs.clear(); ckey.clear(); } void Keywords::setComponentsIntroduction( const std::string& instr ) { @@ -765,8 +595,7 @@ void Keywords::addOutputComponent( const std::string& name, const std::string& k std::size_t num2=name.find_first_of("_"); if( num2!=std::string::npos ) { - char uu = '_'; - plumed_massert( std::count(name.begin(),name.end(), uu)==1, "underscore is reserved character in component names and there should only be one"); + char uu = '_'; plumed_massert( std::count(name.begin(),name.end(), uu)==1, "underscore is reserved character in component names and there should only be one"); plumed_massert( num2==0, "underscore is reserved character in component names that has special meaning"); } @@ -776,26 +605,18 @@ void Keywords::addOutputComponent( const std::string& name, const std::string& k } bool Keywords::outputComponentExists( const std::string& name, const bool& custom ) const { - if( custom && cstring.find("customize")!=std::string::npos ) { - return true; - } + if( custom && cstring.find("customize")!=std::string::npos ) return true; std::string sname; std::size_t num=name.find_first_of("-"); std::size_t num2=name.find_last_of("_"); - if( num2!=std::string::npos ) { - sname=name.substr(num2); - } else if( num!=std::string::npos ) { - sname=name.substr(0,num); - } else { - sname=name; - } + if( num2!=std::string::npos ) sname=name.substr(num2); + else if( num!=std::string::npos ) sname=name.substr(0,num); + else sname=name; for(unsigned i=0; isecond; } @@ -826,20 +641,14 @@ void Keywords::removeComponent( const std::string& name ) { while(true) { unsigned j; - for(j=0; j Keywords::getOutputComponents() const { } std::string Keywords::getKeywordDescription( const std::string& key ) const { - plumed_assert( exists( key ) ); - return documentation.find(key)->second; + plumed_assert( exists( key ) ); return documentation.find(key)->second; } } diff --git a/src/tools/Keywords.h b/src/tools/Keywords.h index 75316208f9..976b500228 100644 --- a/src/tools/Keywords.h +++ b/src/tools/Keywords.h @@ -40,37 +40,19 @@ class Keywords { enum {hidden,compulsory,flag,optional,atoms,vessel} style; explicit KeyType( const std::string& type ); void setStyle( const std::string& type ); - bool isCompulsory() const { - return (style==compulsory); - } - bool isFlag() const { - return (style==flag); - } - bool isOptional() const { - return (style==optional); - } - bool isAtomList() const { - return (style==atoms); - } - bool isVessel() const { - return (style==vessel); - } + bool isCompulsory() const { return (style==compulsory); } + bool isFlag() const { return (style==flag); } + bool isOptional() const { return (style==optional); } + bool isAtomList() const { return (style==atoms); } + bool isVessel() const { return (style==vessel); } std::string toString() const { - if(style==compulsory) { - return "compulsory"; - } else if(style==optional) { - return "optional"; - } else if(style==atoms) { - return "atoms"; - } else if(style==flag) { - return "flag"; - } else if(style==hidden) { - return "hidden"; - } else if(style==vessel) { - return "vessel"; - } else { - plumed_assert(0); - } + if(style==compulsory) return "compulsory"; + else if(style==optional) return "optional"; + else if(style==atoms) return "atoms"; + else if(style==flag) return "flag"; + else if(style==hidden) return "hidden"; + else if(style==vessel) return "vessel"; + else plumed_assert(0); return ""; } }; @@ -110,13 +92,9 @@ class Keywords { /// Constructor Keywords() : isaction(true), isatoms(true) {} /// - void isDriver() { - isaction=false; - } + void isDriver() { isaction=false; } /// - void isAnalysis() { - isatoms=false; - } + void isAnalysis() { isatoms=false; } /// find out whether flag key is on or off by default. bool getLogicalDefault(const std::string & key, bool& def ) const ; /// Get the value of the default for the keyword named key @@ -196,9 +174,7 @@ class Keywords { /// Remove a component with a particular name from the keywords void removeComponent( const std::string& name ); /// Reference to keys - std::vector getKeys() const { - return keys; - } + std::vector getKeys() const { return keys; } /// Get the description of a particular keyword std::string getTooltip( const std::string& name ) const ; }; diff --git a/src/tools/LatticeReduction.cpp b/src/tools/LatticeReduction.cpp index 2893c1bcf2..c7d388161c 100644 --- a/src/tools/LatticeReduction.cpp +++ b/src/tools/LatticeReduction.cpp @@ -34,9 +34,7 @@ void LatticeReduction::sort(Vector v[3]) { m[0]=modulo2(v[0]); m[1]=modulo2(v[1]); m[2]=modulo2(v[2]); - for(int i=0; i<3; i++) - for(int j=i+1; j<3; j++) - if(m[i]>m[j]) { + for(int i=0; i<3; i++) for(int j=i+1; j<3; j++) if(m[i]>m[j]) { std::swap(v[i],v[j]); std::swap(m[i],m[j]); } @@ -56,17 +54,13 @@ void LatticeReduction::reduce(Vector&a,Vector&b) { } a-=b*floor(dotProduct(a,b)/mb+0.5); ma=modulo2(a); - if(mb<=ma*onePlusEpsilon) { - break; - } + if(mb<=ma*onePlusEpsilon) break; counter++; if(counter%100==0) { // only test rarely since this might be expensive plumed_assert(!std::isnan(ma)); plumed_assert(!std::isnan(mb)); } - if(counter%10000==0) { - std::fprintf(stderr,"WARNING: LatticeReduction::reduce stuck after %u iterations\n",counter); - } + if(counter%10000==0) std::fprintf(stderr,"WARNING: LatticeReduction::reduce stuck after %u iterations\n",counter); } std::swap(a,b); @@ -74,42 +68,32 @@ void LatticeReduction::reduce(Vector&a,Vector&b) { void LatticeReduction::reduce2(Vector&a,Vector&b,Vector&c) { Vector v[3]; - v[0]=a; - v[1]=b; - v[2]=c; + v[0]=a; v[1]=b; v[2]=c; int iter=0; int ok=0; while(ok<3) { int i,j; if(iter%3==0) { - i=0; - j=1; + i=0; j=1; } else if(iter%3==1) { - i=0; - j=2; + i=0; j=2; } else { - i=1; - j=2; + i=1; j=2; } - if(isReduced(v[i],v[j])) { - ok++; - } else { + if(isReduced(v[i],v[j])) ok++; + else { reduce(v[i],v[j]); ok=1; } iter++; } - a=v[0]; - b=v[1]; - c=v[2]; + a=v[0]; b=v[1]; c=v[2]; } bool LatticeReduction::isReduced(const Vector&a,const Vector&b) { const int cut=5; for(int i=-cut; i<=cut; i++) { - if(modulo2(b+i*a)=modulo2(v[2])) { - break; - } + if(modulo2(best)*onePlusEpsilon>=modulo2(v[2])) break; counter++; - if(counter%10000==0) { - std::fprintf(stderr,"WARNING: LatticeReduction::reduceFast stuck after %u iterations\n",counter); - } + if(counter%10000==0) std::fprintf(stderr,"WARNING: LatticeReduction::reduceFast stuck after %u iterations\n",counter); v[2]=best; } sort(v); @@ -189,21 +169,10 @@ void LatticeReduction::reduceSlow(Tensor&t) { double e02=dotProduct(v[0],v[2]); double e12=dotProduct(v[1],v[2]); if(e01*e02*e12<0) { - int eps01=0; - if(e01>0.0) { - eps01=1; - } else if(e01<0.0) { - eps01=-1; - } - int eps02=0; - if(e02>0.0) { - eps02=1; - } else if(e02<0.0) { - eps02=-1; - } + int eps01=0; if(e01>0.0) eps01=1; else if(e01<0.0) eps01=-1; + int eps02=0; if(e02>0.0) eps02=1; else if(e02<0.0) eps02=-1; Vector n=v[0]-eps01*v[1]-eps02*v[2]; - int i=0; - double mx=modulo2(v[i]); + int i=0; double mx=modulo2(v[i]); for(int j=1; j<3; j++) { double f=modulo2(v[j]); if(f>mx) { @@ -211,9 +180,7 @@ void LatticeReduction::reduceSlow(Tensor&t) { mx=f; } } - if(modulo2(n)& pos, const std::vector& indices, const Pbc& pbc ) { @@ -53,8 +52,7 @@ void LinkCells::buildCellLists( const std::vector& pos, const std::vecto // Setup the lists if( pos.size()!=allcells.size() ) { - allcells.resize( pos.size() ); - lcell_lists.resize( pos.size() ); + allcells.resize( pos.size() ); lcell_lists.resize( pos.size() ); } { @@ -63,33 +61,22 @@ void LinkCells::buildCellLists( const std::vector& pos, const std::vecto // This allows to use linked cells in non orthorhomic boxes Tensor reciprocal(transpose(mypbc.getInvBox())); ncells[0] = std::floor( 1.0/ reciprocal.getRow(0).modulo() / link_cutoff ); - if( ncells[0]==0 ) { - ncells[0]=1; - } + if( ncells[0]==0 ) ncells[0]=1; ncells[1] = std::floor( 1.0/ reciprocal.getRow(1).modulo() / link_cutoff ); - if( ncells[1]==0 ) { - ncells[1]=1; - } + if( ncells[1]==0 ) ncells[1]=1; ncells[2] = std::floor( 1.0/ reciprocal.getRow(2).modulo() / link_cutoff ); - if( ncells[2]==0 ) { - ncells[2]=1; - } + if( ncells[2]==0 ) ncells[2]=1; } // Setup the strides - nstride[0]=1; - nstride[1]=ncells[0]; - nstride[2]=ncells[0]*ncells[1]; + nstride[0]=1; nstride[1]=ncells[0]; nstride[2]=ncells[0]*ncells[1]; // Setup the storage for link cells unsigned ncellstot=ncells[0]*ncells[1]*ncells[2]; if( lcell_tots.size()!=ncellstot ) { - lcell_tots.resize( ncellstot ); - lcell_starts.resize( ncellstot ); + lcell_tots.resize( ncellstot ); lcell_starts.resize( ncellstot ); } // Clear nlcells - for(unsigned i=0; i& pos, const std::vecto lcell_tots[allcells[i]]++; } // And gather all this information on every node - comm.Sum( allcells ); - comm.Sum( lcell_tots ); + comm.Sum( allcells ); comm.Sum( lcell_tots ); // Now prepare the link cell lists unsigned tot=0; - for(unsigned i=0; i& celn, unsigned& int zval = celn[2] + nz; zval=LINKC_PBC(zval,ncells[2])*nstride[2]; - unsigned mybox=xval+yval+zval; - bool added=false; + unsigned mybox=xval+yval+zval; bool added=false; for(unsigned k=0; k& celn, unsigned& void LinkCells::retrieveNeighboringAtoms( const Vector& pos, std::vector& cell_list, unsigned& natomsper, std::vector& atoms ) const { - if( cell_list.size()!=getNumberOfCells() ) { - cell_list.resize( getNumberOfCells() ); - } - unsigned ncellt=0; - addRequiredCells( findMyCell( pos ), ncellt, cell_list ); + if( cell_list.size()!=getNumberOfCells() ) cell_list.resize( getNumberOfCells() ); + unsigned ncellt=0; addRequiredCells( findMyCell( pos ), ncellt, cell_list ); retrieveAtomsInCells( ncellt, cell_list, natomsper, atoms ); } diff --git a/src/tools/Log.h b/src/tools/Log.h index fb8ce4a1a1..8475822fb6 100644 --- a/src/tools/Log.h +++ b/src/tools/Log.h @@ -33,7 +33,8 @@ namespace PLMD { /// lines with the "PLUMED:" prefix, useful to grep out plumed /// log from output class Log : - public OFile { + public OFile +{ }; } diff --git a/src/tools/Matrix.h b/src/tools/Matrix.h index 064ec604d9..aa55c43909 100644 --- a/src/tools/Matrix.h +++ b/src/tools/Matrix.h @@ -36,26 +36,21 @@ namespace PLMD { /// Calculate the dot product between two vectors template T dotProduct( const std::vector& A, const std::vector& B ) { plumed_assert( A.size()==B.size() ); - T val; - for(unsigned i=0; i T norm( const std::vector& A ) { - T val; - for(unsigned i=0; i class Matrix: - public MatrixSquareBracketsAccess,T> { + public MatrixSquareBracketsAccess,T> +{ /// Multiply matrix by scalar template friend Matrix operator*(U&, const Matrix& ); /// Matrix matrix multiply @@ -95,44 +90,22 @@ class Matrix: explicit Matrix(const unsigned nr=0, const unsigned nc=0 ) : sz(nr*nc), rw(nr), cl(nc), data(nr*nc) {} Matrix(const Matrix& t) : sz(t.sz), rw(t.rw), cl(t.cl), data(t.data) {} /// Resize the matrix - void resize( const unsigned nr, const unsigned nc ) { - rw=nr; - cl=nc; - sz=nr*nc; - data.resize(sz); - } + void resize( const unsigned nr, const unsigned nc ) { rw=nr; cl=nc; sz=nr*nc; data.resize(sz); } /// Return the number of rows - inline unsigned nrows() const { - return rw; - } + inline unsigned nrows() const { return rw; } /// Return the number of columns - inline unsigned ncols() const { - return cl; - } + inline unsigned ncols() const { return cl; } /// Return the contents of the matrix as a vector of length rw*cl - inline std::vector& getVector() { - return data; - } + inline std::vector& getVector() { return data; } /// Set the matrix from a vector input - inline void setFromVector( const std::vector& vecin ) { - plumed_assert( vecin.size()==sz ); - for(unsigned i=0; i& vecin ) { plumed_assert( vecin.size()==sz ); for(unsigned i=0; i& operator=(const T& v) { - for(unsigned i=0; i& operator=(const std::vector& v) { plumed_dbg_assert( v.size()==sz ); - for(unsigned i=0; i operator+=(const T& v) { - for(unsigned i=0; i operator*=(const T& v) { - for(unsigned i=0; i operator-=(const T& v) { - for(unsigned i=0; i1.e-10 ) { - sym=0; - break; - } + for(unsigned i=1; i1.e-10 ) { sym=0; break; } return sym; } }; @@ -209,67 +167,37 @@ template Matrix operator*(T& v, const Matrix& m ) { template void mult( const Matrix& A, const Matrix& B, Matrix& C ) { plumed_assert(A.cl==B.rw); - if( A.rw !=C.rw || B.cl !=C.cl ) { - C.resize( A.rw, B.cl ); - } - C=static_cast( 0 ); - for(unsigned i=0; i( 0 ); + for(unsigned i=0; i void mult( const Matrix& A, const std::vector& B, std::vector& C) { plumed_assert( A.cl==B.size() ); - if( C.size()!=A.rw ) { - C.resize(A.rw); - } - for(unsigned i=0; i( 0 ); - } - for(unsigned i=0; i( 0 ); } + for(unsigned i=0; i void mult( const std::vector& A, const Matrix& B, std::vector& C) { plumed_assert( B.rw==A.size() ); - if( C.size()!=B.cl ) { - C.resize( B.cl ); - } - for(unsigned i=0; i( 0 ); - } - for(unsigned i=0; i( 0 ); } + for(unsigned i=0; i void transpose( const Matrix& A, Matrix& AT ) { - if( A.rw!=AT.cl || A.cl!=AT.rw ) { - AT.resize( A.cl, A.rw ); - } - for(unsigned i=0; i Log& operator<<(Log& ostr, const Matrix& mat) { - for(unsigned i=0; i void matrixOut( Log& ostr, const Matrix& mat) { for(unsigned i=0; i void matrixOut( Log& ostr, const Matrix& mat) { template int diagMat( const Matrix& A, std::vector& eigenvals, Matrix& eigenvecs ) { // Check matrix is square and symmetric - plumed_assert( A.rw==A.cl ); - plumed_assert( A.isSymmetric()==1 ); + plumed_assert( A.rw==A.cl ); plumed_assert( A.isSymmetric()==1 ); std::vector da(A.sz); unsigned k=0; std::vector evals(A.cl); // Transfer the matrix to the local array - for (unsigned i=0; i( A(j,i) ); - } + for (unsigned i=0; i( A(j,i) ); - int n=A.cl; - int lwork=-1, liwork=-1, m, info, one=1; + int n=A.cl; int lwork=-1, liwork=-1, m, info, one=1; std::vector work(A.cl); std::vector iwork(A.cl); double vl, vu, abstol=0.0; @@ -300,38 +223,26 @@ template int diagMat( const Matrix& A, std::vector& eige plumed_lapack_dsyevr("V", "I", "U", &n, da.data(), &n, &vl, &vu, &one, &n, &abstol, &m, evals.data(), evecs.data(), &n, isup.data(), work.data(), &lwork, iwork.data(), &liwork, &info); - if (info!=0) { - return info; - } + if (info!=0) return info; // Retrieve correct sizes for work and iwork then reallocate - liwork=iwork[0]; - iwork.resize(liwork); - lwork=static_cast( work[0] ); - work.resize(lwork); + liwork=iwork[0]; iwork.resize(liwork); + lwork=static_cast( work[0] ); work.resize(lwork); plumed_lapack_dsyevr("V", "I", "U", &n, da.data(), &n, &vl, &vu, &one, &n, &abstol, &m, evals.data(), evecs.data(), &n, isup.data(), work.data(), &lwork, iwork.data(), &liwork, &info); - if (info!=0) { - return info; - } + if (info!=0) return info; - if( eigenvals.size()!=A.cl ) { - eigenvals.resize( A.cl ); - } - if( eigenvecs.rw!=A.rw || eigenvecs.cl!=A.cl ) { - eigenvecs.resize( A.rw, A.cl ); - } + if( eigenvals.size()!=A.cl ) { eigenvals.resize( A.cl ); } + if( eigenvecs.rw!=A.rw || eigenvecs.cl!=A.cl ) { eigenvecs.resize( A.rw, A.cl ); } k=0; for(unsigned i=0; i int diagMat( const Matrix& A, std::vector& eige // the result reproducible for(int i=0; i1e-14) { - break; - } - if(j1e-14) break; + if(j int pseudoInvert( const Matrix& A, Matrix& pseu std::vector da(A.sz); unsigned k=0; // Transfer the matrix to the local array - for (unsigned i=0; i( A(j,i) ); - } + for (unsigned i=0; i( A(j,i) ); int nsv, info, nrows=A.rw, ncols=A.cl; - if(A.rw>A.cl) { - nsv=A.cl; - } else { - nsv=A.rw; - } + if(A.rw>A.cl) {nsv=A.cl;} else {nsv=A.rw;} // Create some containers for stuff from single value decomposition std::vector S(nsv); @@ -379,62 +276,30 @@ template int pseudoInvert( const Matrix& A, Matrix& pseu int lwork=-1; std::vector work(1); plumed_lapack_dgesdd( "A", &nrows, &ncols, da.data(), &nrows, S.data(), U.data(), &nrows, VT.data(), &ncols, work.data(), &lwork, iwork.data(), &info ); - if(info!=0) { - return info; - } + if(info!=0) return info; // Retrieve correct sizes for work and rellocate - lwork=(int) work[0]; - work.resize(lwork); + lwork=(int) work[0]; work.resize(lwork); // This does the singular value decomposition plumed_lapack_dgesdd( "A", &nrows, &ncols, da.data(), &nrows, S.data(), U.data(), &nrows, VT.data(), &ncols, work.data(), &lwork, iwork.data(), &info ); - if(info!=0) { - return info; - } + if(info!=0) return info; // Compute the tolerance on the singular values ( machine epsilon * number of singular values * maximum singular value ) - double tol; - tol=S[0]; - for(int i=1; itol ) { - tol=S[i]; - } - } - tol*=nsv*epsilon; + double tol; tol=S[0]; for(int i=1; itol ) { tol=S[i]; } } tol*=nsv*epsilon; // Get the inverses of the singlular values - Matrix Si( ncols, nrows ); - Si=0.0; - for(int i=0; itol ) { - Si(i,i)=1./S[i]; - } else { - Si(i,i)=0.0; - } - } + Matrix Si( ncols, nrows ); Si=0.0; + for(int i=0; itol ) { Si(i,i)=1./S[i]; } else { Si(i,i)=0.0; } } // Now extract matrices for pseudoinverse Matrix V( ncols, ncols ), UT( nrows, nrows ), tmp( ncols, nrows ); - k=0; - for(int i=0; i int Invert( const Matrix& A, Matrix& inverse ) // GAT -- I only ever use symmetric matrices so I can invert them like this. // I choose to do this as I have had problems with the more general way of doing this that // is implemented below. - std::vector eval(A.rw); - Matrix evec(A.rw,A.cl), tevec(A.rw,A.cl); - int err; - err=diagMat( A, eval, evec ); - if(err!=0) { - return err; - } - for (unsigned i=0; i eval(A.rw); Matrix evec(A.rw,A.cl), tevec(A.rw,A.cl); + int err; err=diagMat( A, eval, evec ); + if(err!=0) return err; + for (unsigned i=0; i da(A.sz); std::vector ipiv(A.cl); - unsigned k=0; - int n=A.rw, info; - for(unsigned i=0; i( A(j,i) ); - } + unsigned k=0; int n=A.rw, info; + for(unsigned i=0; i( A(j,i) ); plumed_lapack_dgetrf(&n,&n,da.data(),&n,ipiv.data(),&info); - if(info!=0) { - return info; - } + if(info!=0) return info; int lwork=-1; std::vector work(A.cl); plumed_lapack_dgetri(&n,da.data(),&n,ipiv.data(),work.data(),&lwork,&info); - if(info!=0) { - return info; - } + if(info!=0) return info; - lwork=static_cast( work[0] ); - work.resize(lwork); + lwork=static_cast( work[0] ); work.resize(lwork); plumed_lapack_dgetri(&n,da.data(),&n,ipiv.data(),work.data(),&lwork,&info); - if(info!=0) { - return info; - } + if(info!=0) return info; - if( inverse.cl!=A.cl || inverse.rw!=A.rw ) { - inverse.resize(A.rw,A.cl); - } - k=0; - for(unsigned i=0; i int Invert( const Matrix& A, Matrix& inverse ) template void cholesky( const Matrix& A, Matrix& B ) { plumed_assert( A.rw==A.cl && A.isSymmetric() ); - Matrix L(A.rw,A.cl); - L=0.; + Matrix L(A.rw,A.cl); L=0.; std::vector D(A.rw,0.); for(unsigned i=0; i( 1 ); for (unsigned j=0; j( 0 ); - } + for (unsigned k=0; k( 0 ); } D[i]=A(i,i); - for (unsigned k=0; k0.?std::sqrt(D[i]):0.); - } - if( B.rw!=A.rw || B.cl!=A.cl ) { - B.resize( A.rw, A.cl); - } - B=0.; - for(unsigned i=0; i0.?std::sqrt(D[i]):0.); + if( B.rw!=A.rw || B.cl!=A.cl ) { B.resize( A.rw, A.cl); } + B=0.; for(unsigned i=0; i void chol_elsolve( const Matrix& M, const std::vector& b, std::vector& y ) { plumed_assert( M.rw==M.cl && M(0,1)==0.0 && b.size()==M.rw ); - if( y.size()!=M.rw ) { - y.resize( M.rw ); - } + if( y.size()!=M.rw ) { y.resize( M.rw ); } for(unsigned i=0; i int logdet( const Matrix& M, double& ldet ) { unsigned k=0; std::vector evals(M.cl); // Transfer the matrix to the local array - for (unsigned i=0; i( M(j,i) ); - } + for (unsigned i=0; i( M(j,i) ); - int n=M.cl; - int lwork=-1, liwork=-1, info, m, one=1; + int n=M.cl; int lwork=-1, liwork=-1, info, m, one=1; std::vector work(M.rw); std::vector iwork(M.rw); double vl, vu, abstol=0.0; @@ -575,28 +391,19 @@ template int logdet( const Matrix& M, double& ldet ) { plumed_lapack_dsyevr("N", "I", "U", &n, da.data(), &n, &vl, &vu, &one, &n, &abstol, &m, evals.data(), evecs.data(), &n, isup.data(), work.data(), &lwork, iwork.data(), &liwork, &info); - if (info!=0) { - return info; - } + if (info!=0) return info; // Retrieve correct sizes for work and iwork then reallocate - lwork=static_cast( work[0] ); - work.resize(lwork); - liwork=iwork[0]; - iwork.resize(liwork); + lwork=static_cast( work[0] ); work.resize(lwork); + liwork=iwork[0]; iwork.resize(liwork); plumed_lapack_dsyevr("N", "I", "U", &n, da.data(), &n, &vl, &vu, &one, &n, &abstol, &m, evals.data(), evecs.data(), &n, isup.data(), work.data(), &lwork, iwork.data(), &liwork, &info); - if (info!=0) { - return info; - } + if (info!=0) return info; // Transfer the eigenvalues and eigenvectors to the output - ldet=0; - for(unsigned i=0; i::Minimise1DBrent( const FCLASS& pf, const double& t ): ax(0),bx(0),cx(0), fa(0),fb(0),fc(0), fmin(0), - myclass_func(pf) { + myclass_func(pf) +{ } template void Minimise1DBrent::bracket( const double& a, const double& b, eng_pointer eng ) { - ax=a; - bx=b; - double fu; - fa=(myclass_func.*eng)(ax); - fb=(myclass_func.*eng)(bx); + ax=a; bx=b; double fu; + fa=(myclass_func.*eng)(ax); fb=(myclass_func.*eng)(bx); if( fb>fa ) { double tmp; - tmp=ax; - ax=bx; - bx=tmp; - tmp=fa; - fa=fb; - fb=tmp; + tmp=ax; ax=bx; bx=tmp; + tmp=fa; fa=fb; fb=tmp; } cx=bx+GOLD*(bx-ax); fc=(myclass_func.*eng)(cx); @@ -112,29 +106,16 @@ void Minimise1DBrent::bracket( const double& a, const double& b, eng_poi if((bx-u)*(u-cx) > 0.0 ) { fu=(myclass_func.*eng)(u); if( fu < fc ) { - ax=bx; - bx=u; - fa=fb; - fb=fu; - bracketed=true; - return; + ax=bx; bx=u; fa=fb; fb=fu; bracketed=true; return; } else if( fu > fb ) { - cx=u; - fc=fu; - bracketed=true; - return; + cx=u; fc=fu; bracketed=true; return; } - u=cx+GOLD*(cx-bx); - fu=(myclass_func.*eng)(u); + u=cx+GOLD*(cx-bx); fu=(myclass_func.*eng)(u); } else if((cx-u)*(u-ulim) > 0.0 ) { fu=(myclass_func.*eng)(u); if( fu= 0.0 ) { u=ulim; @@ -143,12 +124,8 @@ void Minimise1DBrent::bracket( const double& a, const double& b, eng_poi u=cx+GOLD*(cx-bx); fu=(myclass_func.*eng)(u); } - ax=bx; - bx=cx; - cx=u; - fa=fb; - fb=fc; - fc=fu; + ax=bx; bx=cx; cx=u; + fa=fb; fb=fc; fc=fu; } bracketed=true; } @@ -169,65 +146,39 @@ double Minimise1DBrent::minimise( eng_pointer eng ) { xm=0.5*(a+b); tol2=2.0*(tol1=tol*std::fabs(x)+ZEPS); if( std::fabs(x-xm) <= (tol2-0.5*(b-a))) { - fmin=fx; - minimised=true; - return x; + fmin=fx; minimised=true; return x; } if( std::fabs(e) > tol1 ) { r=(x-w)*(fx-fv); q=(x-v)*(fx-fw); p=(x-v)*q-(x-w)*r; q=2.0*(q-r); - if( q > 0.0 ) { - p = -p; - } + if( q > 0.0 ) p = -p; q=std::fabs(q); etemp=e; e=d; if( std::fabs(p) >= std::fabs(0.5*q*etemp) || p <= q*(a-x) || p >= q*(b-x) ) { d = CGOLD*(e=(x >= xm ? a-x : b-x )); } else { - d=p/q; - u=x+d; - if(u-a < tol2 || b-u < tol2 ) { - d=(xm-x>=0?std::fabs(tol1):-std::fabs(tol1)); - } + d=p/q; u=x+d; + if(u-a < tol2 || b-u < tol2 ) d=(xm-x>=0?std::fabs(tol1):-std::fabs(tol1)); } } else { d=CGOLD*(e=( x >= xm ? a-x : b-x )); } - if( std::fabs(d)>=tol1) { - u=x+d; - } else { - u=x+(d>=0?std::fabs(tol1):-std::fabs(tol1)); - } + if( std::fabs(d)>=tol1) u=x+d; else u=x+(d>=0?std::fabs(tol1):-std::fabs(tol1)); fu=(myclass_func.*eng)(u); if( fu <= fx ) { - if( u >= x ) { - a=x; - } else { - b=x; - } - v=w; - fv=fw; - w=x; - fw=fx; - x=u; - fx=fu; + if( u >= x ) a=x; else b=x; + v=w; fv=fw; + w=x; fw=fx; + x=u; fx=fu; } else { - if( u < x ) { - a=u; - } else { - b=u; - } + if( u < x ) a=u; else b=u; if( fu <=fw || w==x ) { - v=w; - w=u; - fv=fw; - fw=fu; + v=w; w=u; fv=fw; fw=fu; } else if( fu <= fv || v==x || v==w ) { - v=u; - fv=fu; + v=u; fv=fu; } } } diff --git a/src/tools/MinimiseBase.h b/src/tools/MinimiseBase.h index cb9adf8f79..34cbc177a6 100644 --- a/src/tools/MinimiseBase.h +++ b/src/tools/MinimiseBase.h @@ -61,18 +61,15 @@ F1dim::F1dim( const std::vector& pp, const std::vector& fake_der(pp.size()), func(ff), calc(cc), - calc2(cc2) { + calc2(cc2) +{ plumed_assert( calc || calc2 ); } template double F1dim::getEng( const double& xt ) { - for(unsigned j=0; j*calc)(pt,fake_der); - } + for(unsigned j=0; j*calc)(pt,fake_der); return (func->*calc2)(pt,fake_der); } @@ -105,9 +102,7 @@ double MinimiseBase::linemin( const std::vector& dir, std::vecto double ax=0.0, xx=1.0; bb.bracket( ax, xx, &F1dim::getEng ); double xmin=bb.minimise( &F1dim::getEng ); - for(unsigned i=0; i tmpnum1(mypdb.getAtomsInResidue(resnum,chainid)); for(unsigned i=0; i myind( nder ); - for(unsigned i=0; i myind( nder ); - for(unsigned i=0; i myind( nder ); + for(unsigned i=0; i& buffer ) { - if( !hasDerivatives.updateComplete() ) { - hasDerivatives.updateActiveMembers(); - } + if( !hasDerivatives.updateComplete() ) hasDerivatives.updateActiveMembers(); plumed_dbg_assert( offepsilon ) { - wpref=1.0/tmpval; - } else { - wpref=1.0; - } + if( std::fabs(tmpval)>epsilon ) { wpref=1.0/tmpval; } + else { wpref=1.0; } double pref = values[nder]*wpref*wpref; for(unsigned j=0; j& list0, const std::vect const bool& serial, const bool& do_pair, const bool& do_pbc, const Pbc& pbc, Communicator& cm, const double& distance, const unsigned& stride): reduced(false), serial_(serial), do_pair_(do_pair), do_pbc_(do_pbc), pbc_(&pbc), comm(cm), - distance_(distance), stride_(stride) { + distance_(distance), stride_(stride) +{ // store full list of atoms needed fullatomlist_=list0; fullatomlist_.insert(fullatomlist_.end(),list1.begin(),list1.end()); @@ -136,14 +137,9 @@ void NeighborList::update(const std::vector& positions) { // find total dimension of neighborlist std::vector local_nl_size(stride, 0); local_nl_size[rank] = local_flat_nl.size(); - if(!serial_) { - comm.Sum(&local_nl_size[0], stride); - } + if(!serial_) comm.Sum(&local_nl_size[0], stride); int tot_size = std::accumulate(local_nl_size.begin(), local_nl_size.end(), 0); - if(tot_size==0) { - setRequestList(); - return; - } + if(tot_size==0) {setRequestList(); return;} // merge std::vector merge_nl(tot_size, 0); // calculate vector of displacement @@ -155,11 +151,8 @@ void NeighborList::update(const std::vector& positions) { disp[i+1] = rank_size; } // Allgather neighbor list - if(comm.initialized()&&!serial_) { - comm.Allgatherv((!local_flat_nl.empty()?&local_flat_nl[0]:NULL), local_nl_size[rank], &merge_nl[0], &local_nl_size[0], &disp[0]); - } else { - merge_nl = local_flat_nl; - } + if(comm.initialized()&&!serial_) comm.Allgatherv((!local_flat_nl.empty()?&local_flat_nl[0]:NULL), local_nl_size[rank], &merge_nl[0], &local_nl_size[0], &disp[0]); + else merge_nl = local_flat_nl; // resize neighbor stuff neighbors_.resize(tot_size/2); for(unsigned i=0; i& NeighborList::getReducedAtomList() { - if(!reduced) - for(unsigned int i=0; i(newindex0,newindex1); } reduced=true; @@ -228,12 +216,8 @@ std::pair NeighborList::getClosePairAtomNumber(unsigned i std::vector NeighborList::getNeighbors(unsigned index) { std::vector neighbors; for(unsigned int i=0; illwrite(ptr,s); - } + if(linked) return linked->llwrite(ptr,s); if(! (comm && comm->Get_rank()>0)) { - if(!fp) { - plumed_merror("writing on uninitialized File"); - } + if(!fp) plumed_merror("writing on uninitialized File"); if(gzfp) { #ifdef __PLUMED_HAS_ZLIB r=gzwrite(gzFile(gzfp),ptr,s); @@ -81,15 +77,14 @@ OFile::OFile(): fieldChanged(false), backstring("bck"), enforceRestart_(false), - enforceBackup_(false) { + enforceBackup_(false) +{ fmtField(); buflen=1; actual_buffer_length=0; buffer.resize(buflen); // these are set to zero to avoid valgrind errors - for(int i=0; i=buflen-actual_buffer_length) { int newlen=buflen; - while(newlen<=r+actual_buffer_length) { - newlen*=2; - } + while(newlen<=r+actual_buffer_length) newlen*=2; std::vector newbuf(newlen); std::memmove(newbuf.data(),buffer.data(),buflen); - for(int k=buflen; k0) { - llwrite(linePrefix.c_str(),linePrefix.length()); - } + if(linePrefix.length()>0) llwrite(linePrefix.c_str(),linePrefix.length()); llwrite(p1,p2-p1+1); actual_buffer_length-=(p2-p1)+1; p1=p2+1; psearch=p1; }; - if(buffer.data()!=p1) { - std::memmove(buffer.data(),p1,actual_buffer_length); - } + if(buffer.data()!=p1) std::memmove(buffer.data(),p1,actual_buffer_length); return r; } @@ -180,9 +167,7 @@ OFile& OFile::printField(const std::string&name,double v) { // When one tries to print -nan we print nan instead. // The distinction between +nan and -nan is not well defined // Always printing nan simplifies some regtest (special functions computed our of range). - if(std::isnan(v)) { - v=std::numeric_limits::quiet_NaN(); - } + if(std::isnan(v)) v=std::numeric_limits::quiet_NaN(); std::snprintf(buffer_string.data(),buffer_string.size(),fieldFmt.c_str(),v); printField(name,buffer_string.data()); return *this; @@ -226,19 +211,14 @@ OFile& OFile::printField(const std::string&name,long long unsigned v) { OFile& OFile::printField(const std::string&name,const std::string & v) { unsigned i; - for(i=0; i=const_fields.size()) { Field field; field.name=name; field.value=v; fields.push_back(field); } else { - if(const_fields[i].value!=v) { - fieldChanged=true; - } + if(const_fields[i].value!=v) fieldChanged=true; const_fields[i].value=v; } return *this; @@ -255,8 +235,7 @@ OFile& OFile::setupPrintValue( Value *val ) { OFile& OFile::printField( Value* val, const double& v ) { printField( val->getName(), v ); if( val->isPeriodic() ) { - std::string min, max; - val->getDomain( min, max ); + std::string min, max; val->getDomain( min, max ); printField( "min_" + val->getName(), min ); printField("max_" + val->getName(), max ); } @@ -267,8 +246,7 @@ OFile& OFile::printField() { bool reprint=false; if(fieldChanged || fields.size()!=previous_fields.size()) { reprint=true; - } else - for(unsigned i=0; i0 && (!comm || comm->Get_rank()==0)) { FILE* ff=std::fopen(const_cast(fname.c_str()),"r"); if(ff) { @@ -343,17 +306,12 @@ void OFile::backupFile( const std::string& bstring, const std::string& fname ) { for(int i=0;; i++) { std::string num; Tools::convert(i,num); - if(i>maxbackup) { - plumed_merror("cannot backup file "+file+" maximum number of backup is "+num+"\n"); - } + if(i>maxbackup) plumed_merror("cannot backup file "+file+" maximum number of backup is "+num+"\n"); backup=directory+bstring +"."+num+"."+file; FILE* fff=std::fopen(backup.c_str(),"r"); // no exception here - if(!fff) { - break; - } else { - std::fclose(fff); - } + if(!fff) break; + else std::fclose(fff); } int check=rename(fname.c_str(),backup.c_str()); plumed_massert(check==0,"renaming "+fname+" into "+backup+" failed for reason: "+std::strerror(errno)); @@ -381,9 +339,7 @@ OFile& OFile::open(const std::string&path) { } } else { backupFile( backstring, this->path ); - if(comm) { - comm->Barrier(); - } + if(comm)comm->Barrier(); fp=std::fopen(const_cast(this->path.c_str()),"w"); mode="w"; if(Tools::extension(this->path)=="gz") { @@ -394,9 +350,7 @@ OFile& OFile::open(const std::string&path) { #endif } } - if(plumed) { - plumed->insertFile(*this); - } + if(plumed) plumed->insertFile(*this); return *this; } @@ -417,9 +371,7 @@ OFile& OFile::rewind() { plumed_massert(check==0,"renaming "+fname+" into "+backup+" failed for reason: "+std::strerror(errno)); } - if(comm) { - comm->Barrier(); - } + if(comm) comm->Barrier(); if(gzfp) { #ifdef __PLUMED_HAS_ZLIB @@ -454,26 +406,18 @@ FileBase& OFile::flush() { // for some reason flushing with Z_FINISH has problems on linux // I thus use this (incomplete) flush #ifdef __PLUMED_HAS_ZLIB - if(gzfp) { - gzflush(gzFile(gzfp),Z_FULL_FLUSH); - } + if(gzfp) gzflush(gzFile(gzfp),Z_FULL_FLUSH); #endif } return *this; } bool OFile::checkRestart()const { - if(enforceRestart_) { - return true; - } else if(enforceBackup_) { - return false; - } else if(action) { - return action->getRestart(); - } else if(plumed) { - return plumed->getRestart(); - } else { - return false; - } + if(enforceRestart_) return true; + else if(enforceBackup_) return false; + else if(action) return action->getRestart(); + else if(plumed) return plumed->getRestart(); + else return false; } OFile& OFile::enforceRestart() { diff --git a/src/tools/OpenMP.cpp b/src/tools/OpenMP.cpp index 90e40417df..ada29dea50 100644 --- a/src/tools/OpenMP.cpp +++ b/src/tools/OpenMP.cpp @@ -48,9 +48,7 @@ void OpenMP::setNumThreads(const unsigned nt) { unsigned OpenMP::getCachelineSize() { if(!getOpenMPVars().cache_set) { - if(std::getenv("PLUMED_CACHELINE_SIZE")) { - Tools::convert(std::getenv("PLUMED_CACHELINE_SIZE"),getOpenMPVars().cacheline_size); - } + if(std::getenv("PLUMED_CACHELINE_SIZE")) Tools::convert(std::getenv("PLUMED_CACHELINE_SIZE"),getOpenMPVars().cacheline_size); getOpenMPVars().cache_set = true; } return getOpenMPVars().cacheline_size; @@ -58,9 +56,7 @@ unsigned OpenMP::getCachelineSize() { unsigned OpenMP::getNumThreads() { if(!getOpenMPVars().nt_env_set) { - if(std::getenv("PLUMED_NUM_THREADS")) { - Tools::convert(std::getenv("PLUMED_NUM_THREADS"),getOpenMPVars().num_threads); - } + if(std::getenv("PLUMED_NUM_THREADS")) Tools::convert(std::getenv("PLUMED_NUM_THREADS"),getOpenMPVars().num_threads); getOpenMPVars().nt_env_set = true; } return getOpenMPVars().num_threads; diff --git a/src/tools/OpenMP.h b/src/tools/OpenMP.h index eedff96185..1d727aa659 100644 --- a/src/tools/OpenMP.h +++ b/src/tools/OpenMP.h @@ -60,22 +60,16 @@ unsigned OpenMP::getGoodNumThreads(const T*x,unsigned n) { // to cache line boundary unsigned m=n*sizeof(T)/(2*getCachelineSize()); unsigned numThreads=getNumThreads(); - if(m>=numThreads) { - m=numThreads; - } else { - m=1; - } + if(m>=numThreads) m=numThreads; + else m=1; return m; } template unsigned OpenMP::getGoodNumThreads(const std::vector & v) { - if(v.size()==0) { - return 1; - } else { - return getGoodNumThreads(&v[0],v.size()); - } + if(v.size()==0) return 1; + else return getGoodNumThreads(&v[0],v.size()); } diff --git a/src/tools/PDB.cpp b/src/tools/PDB.cpp index 8d02835679..049f1a7093 100644 --- a/src/tools/PDB.cpp +++ b/src/tools/PDB.cpp @@ -131,15 +131,9 @@ In addition, as of PLUMED 2.5, we provide a \ref pdbrenumber "command line tool" namespace PLMD { void PDB::setAtomNumbers( const std::vector& atoms ) { - positions.resize( atoms.size() ); - occupancy.resize( atoms.size() ); - beta.resize( atoms.size() ); - numbers.resize( atoms.size() ); - for(unsigned i=0; i& argument_names ) { @@ -152,18 +146,13 @@ void PDB::setArgumentNames( const std::vector& argument_names ) { bool PDB::getArgumentValue( const std::string& name, double& value ) const { std::map::const_iterator it = arg_data.find(name); - if( it!=arg_data.end() ) { - value = it->second; - return true; - } + if( it!=arg_data.end() ) { value = it->second; return true; } return false; } void PDB::setAtomPositions( const std::vector& pos ) { plumed_assert( pos.size()==positions.size() ); - for(unsigned i=0; i& v1 ) { std::size_t eq=v1[i].find_first_of('='); std::string name=v1[i].substr(0,eq); std::string sval=v1[i].substr(eq+1); - double val; - Tools::convert( sval, val ); + double val; Tools::convert( sval, val ); arg_data.insert( std::pair( name, val ) ); } else { flags.push_back(v1[i]); @@ -240,9 +228,7 @@ void PDB::addRemark( std::vector& v1 ) { bool PDB::hasFlag( const std::string& fname ) const { for(unsigned i=0; isecond]; - } + } else return atomsymb[p->second]; } unsigned PDB::getResidueNumber(AtomNumber a)const { const auto p=number2index.find(a); if(p==number2index.end()) { - std::string num; - Tools::convert( a.serial(), num ); + std::string num; Tools::convert( a.serial(), num ); plumed_merror("Residue for atom " + num + " not found" ); - } else { - return residue[p->second]; - } + } else return residue[p->second]; } std::string PDB::getResidueName(AtomNumber a) const { const auto p=number2index.find(a); if(p==number2index.end()) { - std::string num; - Tools::convert( a.serial(), num ); + std::string num; Tools::convert( a.serial(), num ); plumed_merror("Residue for atom " + num + " not found" ); - } else { - return residuenames[p->second]; - } + } else return residuenames[p->second]; } unsigned PDB::size()const { @@ -304,18 +281,13 @@ unsigned PDB::size()const { bool PDB::readFromFilepointer(FILE *fp,bool naturalUnits,double scale) { //cerr< v1; - v1=Tools::getWords(line.substr(6)); + std::vector v1; v1=Tools::getWords(line.substr(6)); addRemark( v1 ); } if(record=="CRYST1") { @@ -363,11 +325,7 @@ bool PDB::readFromFilepointer(FILE *fp,bool naturalUnits,double scale) { double cosB=std::cos(BoxABG[1]*pi/180.); double cosG=std::cos(BoxABG[2]*pi/180.); double sinG=std::sin(BoxABG[2]*pi/180.); - for (unsigned i=0; i<3; i++) { - Box[i][0]=0.; - Box[i][1]=0.; - Box[i][2]=0.; - } + for (unsigned i=0; i<3; i++) {Box[i][0]=0.; Box[i][1]=0.; Box[i][2]=0.;} Box[0][0]=BoxXYZ[0]; Box[1][0]=BoxXYZ[1]*cosG; Box[1][1]=BoxXYZ[1]*sinG; @@ -385,9 +343,7 @@ bool PDB::readFromFilepointer(FILE *fp,bool naturalUnits,double scale) { int result; auto trimmed=serial; Tools::trim(trimmed); - while(trimmed.length()<5) { - trimmed = std::string(" ") + trimmed; - } + while(trimmed.length()<5) trimmed = std::string(" ") + trimmed; const char* errmsg = h36::hy36decode(5, trimmed.c_str(),trimmed.length(), &result); if(errmsg) { std::string msg(errmsg); @@ -402,9 +358,7 @@ bool PDB::readFromFilepointer(FILE *fp,bool naturalUnits,double scale) { Tools::trim(trimmed); if(trimmed.length()>0) { int result; - while(trimmed.length()<4) { - trimmed = std::string(" ") + trimmed; - } + while(trimmed.length()<4) trimmed = std::string(" ") + trimmed; const char* errmsg = h36::hy36decode(4, trimmed.c_str(),trimmed.length(), &result); if(errmsg) { std::string msg(errmsg); @@ -434,21 +388,15 @@ bool PDB::readFromFilepointer(FILE *fp,bool naturalUnits,double scale) { residuenames.push_back(residuename); } } - if( between_ters ) { - block_ends.push_back( positions.size() ); - } + if( between_ters ) block_ends.push_back( positions.size() ); return file_is_alive; } bool PDB::read(const std::string&file,bool naturalUnits,double scale) { FILE* fp=std::fopen(file.c_str(),"r"); - if(!fp) { - return false; - } + if(!fp) return false; // call fclose when exiting this function - auto deleter=[](FILE* f) { - std::fclose(f); - }; + auto deleter=[](FILE* f) { std::fclose(f); }; std::unique_ptr fp_deleter(fp,deleter); readFromFilepointer(fp,naturalUnits,scale); return true; @@ -458,9 +406,7 @@ void PDB::getChainNames( std::vector& chains ) const { chains.resize(0); chains.push_back( chain[0] ); for(unsigned i=1; i PDB::getAtomsInResidue(const unsigned& resnum,const std::string& chainid)const { std::vector tmp; for(unsigned i=0; i PDB::getAtomsInResidue(const unsigned& resnum,const std: std::vector PDB::getAtomsInChain(const std::string& chainid)const { std::vector tmp; for(unsigned i=0; i PDB::getAtomsInChain(const std::string& chainid)const { std::string PDB::getChainID(const unsigned& resnumber) const { for(unsigned i=0; isecond]; @@ -602,18 +518,14 @@ std::string PDB::getChainID(AtomNumber a) const { bool PDB::checkForResidue( const std::string& name ) const { for(unsigned i=0; isecond]; - } + if(p==number2index.end()) plumed_merror("atom not available"); + else return positions[p->second]; } std::vector PDB::getArgumentNames()const { @@ -653,11 +562,8 @@ std::string PDB::getMtype() const { void PDB::print( const double& lunits, GenericMolInfo* mymoldat, OFile& ofile, const std::string& fmt ) { if( argnames.size()>0 ) { ofile.printf("REMARK ARG=%s", argnames[0].c_str() ); - for(unsigned i=1; i::iterator it=arg_data.begin(); it!=arg_data.end(); ++it) { - ofile.printf( descr2.c_str(),it->first.c_str(), it->second ); - } - if( argnames.size()>0 ) { - ofile.printf("\n"); - } + for(std::map::iterator it=arg_data.begin(); it!=arg_data.end(); ++it) ofile.printf( descr2.c_str(),it->first.c_str(), it->second ); + if( argnames.size()>0 ) ofile.printf("\n"); if( !mymoldat ) { for(unsigned i=0; i at; @@ -719,258 +621,127 @@ void PDB::print( const double& lunits, GenericMolInfo* mymoldat, OFile& ofile, c bool PDB::allowedResidue( const std::string& type, const std::string& residuename ) const { if( type=="protein" ) { - if(residuename=="ALA") { - return true; - } else if(residuename=="ARG") { - return true; - } else if(residuename=="ASN") { - return true; - } else if(residuename=="ASP") { - return true; - } else if(residuename=="CYS") { - return true; - } else if(residuename=="GLN") { - return true; - } else if(residuename=="GLU") { - return true; - } else if(residuename=="GLY") { - return true; - } else if(residuename=="HIS") { - return true; - } else if(residuename=="ILE") { - return true; - } else if(residuename=="LEU") { - return true; - } else if(residuename=="LYS") { - return true; - } else if(residuename=="MET") { - return true; - } else if(residuename=="PHE") { - return true; - } else if(residuename=="PRO") { - return true; - } else if(residuename=="SER") { - return true; - } else if(residuename=="THR") { - return true; - } else if(residuename=="TRP") { - return true; - } else if(residuename=="TYR") { - return true; - } else if(residuename=="VAL") { - return true; - } + if(residuename=="ALA") return true; + else if(residuename=="ARG") return true; + else if(residuename=="ASN") return true; + else if(residuename=="ASP") return true; + else if(residuename=="CYS") return true; + else if(residuename=="GLN") return true; + else if(residuename=="GLU") return true; + else if(residuename=="GLY") return true; + else if(residuename=="HIS") return true; + else if(residuename=="ILE") return true; + else if(residuename=="LEU") return true; + else if(residuename=="LYS") return true; + else if(residuename=="MET") return true; + else if(residuename=="PHE") return true; + else if(residuename=="PRO") return true; + else if(residuename=="SER") return true; + else if(residuename=="THR") return true; + else if(residuename=="TRP") return true; + else if(residuename=="TYR") return true; + else if(residuename=="VAL") return true; // Terminal groups - else if(residuename=="ACE") { - return true; - } else if(residuename=="NME") { - return true; - } else if(residuename=="NH2") { - return true; - } + else if(residuename=="ACE") return true; + else if(residuename=="NME") return true; + else if(residuename=="NH2") return true; // Alternative residue names in common force fields - else if(residuename=="GLH") { - return true; // neutral GLU - } else if(residuename=="ASH") { - return true; // neutral ASP - } else if(residuename=="HID") { - return true; // HIS-D amber - } else if(residuename=="HSD") { - return true; // HIS-D charmm - } else if(residuename=="HIE") { - return true; // HIS-E amber - } else if(residuename=="HSE") { - return true; // HIS-E charmm - } else if(residuename=="HIP") { - return true; // HIS-P amber - } else if(residuename=="HSP") { - return true; // HIS-P charmm - } else if(residuename=="CYX") { - return true; // disulfide bridge CYS - } + else if(residuename=="GLH") return true; // neutral GLU + else if(residuename=="ASH") return true; // neutral ASP + else if(residuename=="HID") return true; // HIS-D amber + else if(residuename=="HSD") return true; // HIS-D charmm + else if(residuename=="HIE") return true; // HIS-E amber + else if(residuename=="HSE") return true; // HIS-E charmm + else if(residuename=="HIP") return true; // HIS-P amber + else if(residuename=="HSP") return true; // HIS-P charmm + else if(residuename=="CYX") return true; // disulfide bridge CYS // Weird amino acids - else if(residuename=="NLE") { - return true; - } else if(residuename=="SFO") { - return true; - } else { - return false; - } + else if(residuename=="NLE") return true; + else if(residuename=="SFO") return true; + else return false; } else if( type=="dna" ) { - if(residuename=="A") { - return true; - } else if(residuename=="A5") { - return true; - } else if(residuename=="A3") { - return true; - } else if(residuename=="AN") { - return true; - } else if(residuename=="G") { - return true; - } else if(residuename=="G5") { - return true; - } else if(residuename=="G3") { - return true; - } else if(residuename=="GN") { - return true; - } else if(residuename=="T") { - return true; - } else if(residuename=="T5") { - return true; - } else if(residuename=="T3") { - return true; - } else if(residuename=="TN") { - return true; - } else if(residuename=="C") { - return true; - } else if(residuename=="C5") { - return true; - } else if(residuename=="C3") { - return true; - } else if(residuename=="CN") { - return true; - } else if(residuename=="DA") { - return true; - } else if(residuename=="DA5") { - return true; - } else if(residuename=="DA3") { - return true; - } else if(residuename=="DAN") { - return true; - } else if(residuename=="DG") { - return true; - } else if(residuename=="DG5") { - return true; - } else if(residuename=="DG3") { - return true; - } else if(residuename=="DGN") { - return true; - } else if(residuename=="DT") { - return true; - } else if(residuename=="DT5") { - return true; - } else if(residuename=="DT3") { - return true; - } else if(residuename=="DTN") { - return true; - } else if(residuename=="DC") { - return true; - } else if(residuename=="DC5") { - return true; - } else if(residuename=="DC3") { - return true; - } else if(residuename=="DCN") { - return true; - } else { - return false; - } + if(residuename=="A") return true; + else if(residuename=="A5") return true; + else if(residuename=="A3") return true; + else if(residuename=="AN") return true; + else if(residuename=="G") return true; + else if(residuename=="G5") return true; + else if(residuename=="G3") return true; + else if(residuename=="GN") return true; + else if(residuename=="T") return true; + else if(residuename=="T5") return true; + else if(residuename=="T3") return true; + else if(residuename=="TN") return true; + else if(residuename=="C") return true; + else if(residuename=="C5") return true; + else if(residuename=="C3") return true; + else if(residuename=="CN") return true; + else if(residuename=="DA") return true; + else if(residuename=="DA5") return true; + else if(residuename=="DA3") return true; + else if(residuename=="DAN") return true; + else if(residuename=="DG") return true; + else if(residuename=="DG5") return true; + else if(residuename=="DG3") return true; + else if(residuename=="DGN") return true; + else if(residuename=="DT") return true; + else if(residuename=="DT5") return true; + else if(residuename=="DT3") return true; + else if(residuename=="DTN") return true; + else if(residuename=="DC") return true; + else if(residuename=="DC5") return true; + else if(residuename=="DC3") return true; + else if(residuename=="DCN") return true; + else return false; } else if( type=="rna" ) { - if(residuename=="A") { - return true; - } else if(residuename=="A5") { - return true; - } else if(residuename=="A3") { - return true; - } else if(residuename=="AN") { - return true; - } else if(residuename=="G") { - return true; - } else if(residuename=="G5") { - return true; - } else if(residuename=="G3") { - return true; - } else if(residuename=="GN") { - return true; - } else if(residuename=="U") { - return true; - } else if(residuename=="U5") { - return true; - } else if(residuename=="U3") { - return true; - } else if(residuename=="UN") { - return true; - } else if(residuename=="C") { - return true; - } else if(residuename=="C5") { - return true; - } else if(residuename=="C3") { - return true; - } else if(residuename=="CN") { - return true; - } else if(residuename=="RA") { - return true; - } else if(residuename=="RA5") { - return true; - } else if(residuename=="RA3") { - return true; - } else if(residuename=="RAN") { - return true; - } else if(residuename=="RG") { - return true; - } else if(residuename=="RG5") { - return true; - } else if(residuename=="RG3") { - return true; - } else if(residuename=="RGN") { - return true; - } else if(residuename=="RU") { - return true; - } else if(residuename=="RU5") { - return true; - } else if(residuename=="RU3") { - return true; - } else if(residuename=="RUN") { - return true; - } else if(residuename=="RC") { - return true; - } else if(residuename=="RC5") { - return true; - } else if(residuename=="RC3") { - return true; - } else if(residuename=="RCN") { - return true; - } else { - return false; - } + if(residuename=="A") return true; + else if(residuename=="A5") return true; + else if(residuename=="A3") return true; + else if(residuename=="AN") return true; + else if(residuename=="G") return true; + else if(residuename=="G5") return true; + else if(residuename=="G3") return true; + else if(residuename=="GN") return true; + else if(residuename=="U") return true; + else if(residuename=="U5") return true; + else if(residuename=="U3") return true; + else if(residuename=="UN") return true; + else if(residuename=="C") return true; + else if(residuename=="C5") return true; + else if(residuename=="C3") return true; + else if(residuename=="CN") return true; + else if(residuename=="RA") return true; + else if(residuename=="RA5") return true; + else if(residuename=="RA3") return true; + else if(residuename=="RAN") return true; + else if(residuename=="RG") return true; + else if(residuename=="RG5") return true; + else if(residuename=="RG3") return true; + else if(residuename=="RGN") return true; + else if(residuename=="RU") return true; + else if(residuename=="RU5") return true; + else if(residuename=="RU3") return true; + else if(residuename=="RUN") return true; + else if(residuename=="RC") return true; + else if(residuename=="RC5") return true; + else if(residuename=="RC3") return true; + else if(residuename=="RCN") return true; + else return false; } else if( type=="water" ) { - if(residuename=="SOL") { - return true; - } - if(residuename=="WAT") { - return true; - } + if(residuename=="SOL") return true; + if(residuename=="WAT") return true; return false; } else if( type=="ion" ) { - if(residuename=="IB+") { - return true; - } - if(residuename=="CA") { - return true; - } - if(residuename=="CL") { - return true; - } - if(residuename=="NA") { - return true; - } - if(residuename=="MG") { - return true; - } - if(residuename=="K") { - return true; - } - if(residuename=="RB") { - return true; - } - if(residuename=="CS") { - return true; - } - if(residuename=="LI") { - return true; - } - if(residuename=="ZN") { - return true; - } + if(residuename=="IB+") return true; + if(residuename=="CA") return true; + if(residuename=="CL") return true; + if(residuename=="NA") return true; + if(residuename=="MG") return true; + if(residuename=="K") return true; + if(residuename=="RB") return true; + if(residuename=="CS") return true; + if(residuename=="LI") return true; + if(residuename=="ZN") return true; return false; } return false; diff --git a/src/tools/Pbc.cpp b/src/tools/Pbc.cpp index e8b84b7bf9..c81a913cd7 100644 --- a/src/tools/Pbc.cpp +++ b/src/tools/Pbc.cpp @@ -30,7 +30,8 @@ namespace PLMD { Pbc::Pbc(): - type(unset) { + type(unset) +{ box.zero(); invBox.zero(); } @@ -39,17 +40,11 @@ void Pbc::buildShifts(std::vector shifts[2][2][2])const { const double small=1e-28; // clear all shifts - for(int i=0; i<2; i++) - for(int j=0; j<2; j++) - for(int k=0; k<2; k++) { - shifts[i][j][k].clear(); - } + for(int i=0; i<2; i++) for(int j=0; j<2; j++) for(int k=0; k<2; k++) shifts[i][j][k].clear(); // enumerate all possible shifts // since box is reduced, only 27 shifts have to be attempted - for(int l=-1; l<=1; l++) - for(int m=-1; m<=1; m++) - for(int n=-1; n<=1; n++) { + for(int l=-1; l<=1; l++) for(int m=-1; m<=1; m++) for(int n=-1; n<=1; n++) { // int/double shift vectors const int ishift[3]= {l,m,n}; @@ -57,16 +52,11 @@ void Pbc::buildShifts(std::vector shifts[2][2][2])const { // count how many components are != 0 unsigned count=0; - for(int s=0; s<3; s++) - if(ishift[s]!=0) { - count++; - } + for(int s=0; s<3; s++) if(ishift[s]!=0) count++; // skips trivial (0,0,0) and cases with three shifts // only 18 shifts survive past this point - if(count==0 || count==3) { - continue; - } + if(count==0 || count==3) continue; // check if that Wigner-Seitz face is perpendicular to the axis. // this allows to eliminate shifts in symmetric cells. @@ -75,37 +65,24 @@ void Pbc::buildShifts(std::vector shifts[2][2][2])const { Vector cosdir=matmul(reduced,transpose(reduced),dshift); double dp=dotProduct(dshift,cosdir); double ref=modulo2(dshift)*modulo2(cosdir); - if(std::fabs(ref-dp*dp)0) { - skip=true; - } - if(skip) { - continue; - } + for(int s=0; s<3; s++) if(ishift[s]*block[s]>0) skip=true; + if(skip) continue; skip=true; for(int s=0; s<3; s++) { // check that the components of cosdir along the non-shifted directions // have the proper sign - if(((1-ishift[s]*ishift[s])*block[s])*cosdir[s]<-small) { - skip=false; - } - } - if(skip) { - continue; + if(((1-ishift[s]*ishift[s])*block[s])*cosdir[s]<-small) skip=false; } + if(skip)continue; // if we arrive to this point, shift is eligible and is added to the list shifts[i][j][k].push_back(matmul(transpose(reduced),dshift)); @@ -114,13 +91,9 @@ void Pbc::buildShifts(std::vector shifts[2][2][2])const { } void Pbc::fullSearch(Vector&d)const { - if(type==unset) { - return; - } + if(type==unset) return; Vector s=matmul(invReduced.transpose(),d); - for(int i=0; i<3; i++) { - s[i]=Tools::pbc(s[i]); - } + for(int i=0; i<3; i++) s[i]=Tools::pbc(s[i]); d=matmul(reduced.transpose(),s); const int smax=4; Vector a0(reduced.getRow(0)); @@ -128,9 +101,7 @@ void Pbc::fullSearch(Vector&d)const { Vector a2(reduced.getRow(2)); Vector best(d); double lbest=d.modulo2(); - for(int i=-smax; i<=smax; i++) - for(int j=-smax; j<=smax; j++) - for(int k=-smax; k<=smax; k++) { + for(int i=-smax; i<=smax; i++) for(int j=-smax; j<=smax; j++) for(int k=-smax; k<=smax; k++) { Vector trial=d+i*a0+j*a1+k*a2; double ltrial=trial.modulo2(); if(ltrial& dlist, unsigned max_index) const { - if (max_index==0) { - max_index=dlist.size(); - } + if (max_index==0) max_index=dlist.size(); if(type==unset) { // do nothing } else if(type==orthorombic) { #ifdef __PLUMED_PBC_WHILE for(unsigned k=0; khdiag[0]) { - dlist[k][0]-=diag[0]; - } - while(dlist[k][0]<=mdiag[0]) { - dlist[k][0]+=diag[0]; - } - while(dlist[k][1]>hdiag[1]) { - dlist[k][1]-=diag[1]; - } - while(dlist[k][1]<=mdiag[1]) { - dlist[k][1]+=diag[1]; - } - while(dlist[k][2]>hdiag[2]) { - dlist[k][2]-=diag[2]; - } - while(dlist[k][2]<=mdiag[2]) { - dlist[k][2]+=diag[2]; - } + while(dlist[k][0]>hdiag[0]) dlist[k][0]-=diag[0]; + while(dlist[k][0]<=mdiag[0]) dlist[k][0]+=diag[0]; + while(dlist[k][1]>hdiag[1]) dlist[k][1]-=diag[1]; + while(dlist[k][1]<=mdiag[1]) dlist[k][1]+=diag[1]; + while(dlist[k][2]>hdiag[2]) dlist[k][2]-=diag[2]; + while(dlist[k][2]<=mdiag[2]) dlist[k][2]+=diag[2]; } #else - for(unsigned k=0; khdiag[i]) { - d[i]-=diag[i]; - } - while(d[i]<=mdiag[i]) { - d[i]+=diag[i]; - } + while(d[i]>hdiag[i]) d[i]-=diag[i]; + while(d[i]<=mdiag[i]) d[i]+=diag[i]; } #else - for(int i=0; i<3; i++) { - d[i]=Tools::pbc(d[i]*invBox(i,i))*box(i,i); - } + for(int i=0; i<3; i++) d[i]=Tools::pbc(d[i]*invBox(i,i))*box(i,i); #endif } else if(type==generic) { Vector s=matmul(d,invReduced); @@ -269,9 +199,7 @@ Vector Pbc::distance(const Vector&v1,const Vector&v2,int*nshifts)const { // introduce a significant gain. I thus leave it out for the moment. if(true) { // bring to -0.5,+0.5 region in scaled coordinates: - for(int i=0; i<3; i++) { - s[i]=Tools::pbc(s[i]); - } + for(int i=0; i<3; i++) s[i]=Tools::pbc(s[i]); d=matmul(s,reduced); // check if shifts have to be attempted: if((std::fabs(s[0])+std::fabs(s[1])+std::fabs(s[2])>0.5)) { @@ -280,9 +208,7 @@ Vector Pbc::distance(const Vector&v1,const Vector&v2,int*nshifts)const { Vector best(d); double lbest(modulo2(best)); // loop over possible shifts: - if(nshifts) { - *nshifts+=myshifts.size(); - } + if(nshifts) *nshifts+=myshifts.size(); for(unsigned i=0; i()) { + local(Tools::make_unique()) +{ } PlumedHandle::PlumedHandle(const char* kernel) #ifdef __PLUMED_HAS_DLOPEN : - loaded(plumed_c2v(plumed_create_dlopen(kernel))) { + loaded(plumed_c2v(plumed_create_dlopen(kernel))) +{ if(!plumed_valid(plumed_v2c(loaded))) { // this is necessary to make sure loaded is properly destroyed plumed_finalize(plumed_v2c(loaded)); @@ -62,9 +65,7 @@ PlumedHandle::PlumedHandle(const char* kernel) #endif PlumedHandle::~PlumedHandle() { - if(loaded) { - plumed_finalize(plumed_v2c(loaded)); - } + if(loaded) plumed_finalize(plumed_v2c(loaded)); } PlumedHandle PlumedHandle::dlopen(const char* path) { @@ -82,22 +83,19 @@ void PlumedHandle::cmd(const std::string & key,const TypesafePtr & ptr) { safe.flags=ptr.getFlags(); safe.opt=nullptr; plumed_cmd(plumed_v2c(loaded),key.c_str(),safe); - } else { - plumed_error() << "should never arrive here (either one or the other should work)"; - } + } else plumed_error() << "should never arrive here (either one or the other should work)"; } PlumedHandle::PlumedHandle(PlumedHandle && other) noexcept: local(std::move(other.local)), - loaded(other.loaded) { + loaded(other.loaded) +{ other.loaded=nullptr; } PlumedHandle & PlumedHandle::operator=(PlumedHandle && other) noexcept { if(this!=&other) { - if(loaded) { - plumed_finalize(plumed_v2c(loaded)); - } + if(loaded) plumed_finalize(plumed_v2c(loaded)); local=std::move(other.local); loaded=other.loaded; other.loaded=nullptr; diff --git a/src/tools/PlumedHandle.h b/src/tools/PlumedHandle.h index 315c445c05..d3e1d5d77c 100644 --- a/src/tools/PlumedHandle.h +++ b/src/tools/PlumedHandle.h @@ -26,7 +26,8 @@ #include "TypesafePtr.h" #include -namespace PLMD { +namespace PLMD +{ class PlumedMain; @@ -70,7 +71,8 @@ Thus, once constructed the object is guaranteed to be functional. */ class PlumedHandle : - public WithCmd { + public WithCmd +{ /// Pointer to PlumedMain. /// Used when using the current kernel in order to avoid unneeded indirections. std::unique_ptr local; diff --git a/src/tools/RMSD.cpp b/src/tools/RMSD.cpp index 169d7bd2d8..5959c2eaea 100644 --- a/src/tools/RMSD.cpp +++ b/src/tools/RMSD.cpp @@ -54,13 +54,14 @@ void RMSD::setType(const std::string & mytype) { alignmentMethod=SIMPLE; // initialize with the simplest case: no rotation if (mytype=="SIMPLE") { alignmentMethod=SIMPLE; - } else if (mytype=="OPTIMAL") { + } + else if (mytype=="OPTIMAL") { alignmentMethod=OPTIMAL; - } else if (mytype=="OPTIMAL-FAST") { + } + else if (mytype=="OPTIMAL-FAST") { alignmentMethod=OPTIMAL_FAST; - } else { - plumed_merror("unknown RMSD type" + mytype); } + else plumed_merror("unknown RMSD type" + mytype); } @@ -79,15 +80,9 @@ void RMSD::clear() { std::string RMSD::getMethod() { std::string mystring; switch(alignmentMethod) { - case SIMPLE: - mystring.assign("SIMPLE"); - break; - case OPTIMAL: - mystring.assign("OPTIMAL"); - break; - case OPTIMAL_FAST: - mystring.assign("OPTIMAL-FAST"); - break; + case SIMPLE: mystring.assign("SIMPLE"); break; + case OPTIMAL: mystring.assign("OPTIMAL"); break; + case OPTIMAL_FAST: mystring.assign("OPTIMAL-FAST"); break; } return mystring; } @@ -102,13 +97,9 @@ void RMSD::setReference(const std::vector & reference) { plumed_massert(displace.empty(),"you should first clear() an RMSD object, then set a new reference"); align.resize(n,1.0/n); displace.resize(n,1.0/n); - for(unsigned i=0; ireference[i]*align[i]; - } + for(unsigned i=0; ireference[i]*align[i]; #pragma omp simd - for(unsigned i=0; ireference[i]-=reference_center; - } + for(unsigned i=0; ireference[i]-=reference_center; reference_center_is_calculated=true; reference_center_is_removed=true; } @@ -125,21 +116,15 @@ void RMSD::setAlign(const std::vector & align, bool normalize_weights, b if(normalize_weights) { double w=0.0; #pragma omp simd reduction(+:w) - for(unsigned i=0; ialign[i]; - } + for(unsigned i=0; ialign[i]; if(w>epsilon) { double inv=1.0/w; #pragma omp simd - for(unsigned i=0; ialign[i]*=inv; - } + for(unsigned i=0; ialign[i]*=inv; } else { double inv=1.0/n; #pragma omp simd - for(unsigned i=0; ialign[i]=inv; - } + for(unsigned i=0; ialign[i]=inv; } } // recalculate the center anyway @@ -171,21 +156,15 @@ void RMSD::setDisplace(const std::vector & displace, bool normalize_weig if(normalize_weights) { double w=0.0; #pragma omp simd reduction(+:w) - for(unsigned i=0; idisplace[i]; - } + for(unsigned i=0; idisplace[i]; if(w>epsilon) { double inv=1.0/w; #pragma omp simd - for(unsigned i=0; idisplace[i]*=inv; - } + for(unsigned i=0; idisplace[i]*=inv; } else { double inv=1.0/n; #pragma omp simd - for(unsigned i=0; idisplace[i]=inv; - } + for(unsigned i=0; idisplace[i]=inv; } } } @@ -205,24 +184,16 @@ double RMSD::calculate(const std::vector & positions,std::vector std::vector displacement( derivatives.size() ); ret=simpleAlignment(align,displace,positions,reference,derivatives,displacement,squared); break; - } - case OPTIMAL_FAST : { + } case OPTIMAL_FAST : { // this is calling the fastest option: - if(align==displace) { - ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); - } else { - ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); - } + if(align==displace) ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); + else ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); break; - } - case OPTIMAL : { + } case OPTIMAL : { // this is the fast routine but in the "safe" mode, which gives less numerical error: - if(align==displace) { - ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); - } else { - ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); - } + if(align==displace) ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); + else ret=optimalAlignment(align,displace,positions,reference,derivatives,squared); break; } } @@ -240,18 +211,12 @@ double RMSD::calc_DDistDRef( const std::vector& positions, std::vector(align,displace,positions,reference,derivatives,DDistDRef, squared); - } else { - ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef,squared); - } + if(align==displace) ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef, squared); + else ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef,squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef,squared); - } else { - ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef,squared); - } + if(align==displace) ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef,squared); + else ret=optimalAlignment_DDistDRef(align,displace,positions,reference,derivatives,DDistDRef,squared); break; } return ret; @@ -267,18 +232,12 @@ double RMSD::calc_SOMA( const std::vector& positions, std::vector(align,displace,positions,reference,derivatives,DDistDRef, squared); - } else { - ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef,squared); - } + if(align==displace) ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef, squared); + else ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef,squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef,squared); - } else { - ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef,squared); - } + if(align==displace) ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef,squared); + else ret=optimalAlignment_SOMA(align,displace,positions,reference,derivatives,DDistDRef,squared); break; } return ret; @@ -292,18 +251,12 @@ double RMSD::calc_DDistDRef_Rot_DRotDPos( const std::vector& positions, plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); - } else { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); - } + if(align==displace) ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); + else ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); - } else { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); - } + if(align==displace) ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); + else ret=optimalAlignment_DDistDRef_Rot_DRotDPos(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, squared); break; } return ret; @@ -316,18 +269,12 @@ double RMSD::calc_DDistDRef_Rot_DRotDPos_DRotDRef( const std::vector& po plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); - } else { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); - } + if(align==displace) ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); + else ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); - } else { - ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); - } + if(align==displace) ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); + else ret=optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(align,displace,positions,reference,derivatives,DDistDRef, Rot, DRotDPos, DRotDRef, squared); break; } return ret; @@ -340,18 +287,12 @@ double RMSD::calc_Rot_DRotDRr01( const std::vector& positions, Tensor & plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); - } else { - ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); - } + if(align==displace) ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); + else ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); - } else { - ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); - } + if(align==displace) ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); + else ret=optimalAlignment_Rot_DRotDRr01(align,displace,positions,reference, Rotation, DRotDRr01, squared); break; } return ret; @@ -364,18 +305,12 @@ double RMSD::calc_Rot( const std::vector& positions, std::vector plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); - } else { - ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); - } + if(align==displace) ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); + else ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); - } else { - ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); - } + if(align==displace) ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); + else ret=optimalAlignment_Rot(align,displace,positions,reference,derivatives, Rotation, squared); break; } return ret; @@ -388,18 +323,12 @@ double RMSD::calculateWithCloseStructure( const std::vector& positions, plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); - } else { - ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); - } + if(align==displace) ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); + else ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); - } else { - ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); - } + if(align==displace) ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); + else ret=optimalAlignmentWithCloseStructure(align,displace,positions,reference,derivatives, rotationPosClose, rotationRefClose, drotationPosCloseDrr01, squared); break; } return ret; @@ -412,18 +341,12 @@ double RMSD::calc_PCAelements( const std::vector& positions, std::vector plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); - } else { - ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); - } + if(align==displace) ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); + else ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); - } else { - ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); - } + if(align==displace) ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); + else ret=optimalAlignment_PCA(align,displace,positions,reference, alignedpositions, centeredpositions,centeredreference,Rotation,DDistDPos,DRotDPos,squared); break; } return ret; @@ -437,18 +360,12 @@ double RMSD::calc_FitElements( const std::vector& positions, Tensor & Ro plumed_merror("derivative of the refreence frame not implemented for SIMPLE alignmentMethod \n"); break; case OPTIMAL_FAST: - if(align==displace) { - ret=optimalAlignment_Fit(align,displace,positions,reference, Rotation,DRotDPos,centeredpositions,center_positions,squared); - } else { - ret=optimalAlignment_Fit(align,displace,positions,reference, Rotation,DRotDPos,centeredpositions,center_positions,squared); - } + if(align==displace)ret=optimalAlignment_Fit(align,displace,positions,reference, Rotation,DRotDPos,centeredpositions,center_positions,squared); + else ret=optimalAlignment_Fit(align,displace,positions,reference, Rotation,DRotDPos,centeredpositions,center_positions,squared); break; case OPTIMAL: - if(align==displace) { - ret=optimalAlignment_Fit(align,displace,positions,reference,Rotation,DRotDPos,centeredpositions,center_positions,squared); - } else { - ret=optimalAlignment_Fit(align,displace,positions,reference,Rotation,DRotDPos,centeredpositions,center_positions,squared); - } + if(align==displace)ret=optimalAlignment_Fit(align,displace,positions,reference,Rotation,DRotDPos,centeredpositions,center_positions,squared); + else ret=optimalAlignment_Fit(align,displace,positions,reference,Rotation,DRotDPos,centeredpositions,center_positions,squared); break; } return ret; @@ -495,9 +412,7 @@ double RMSD::simpleAlignment(const std::vector & align, // sqrt dist=std::sqrt(dist); ///// sqrt on derivatives - for(unsigned i=0; i & align, dist=eigenvals[0]+rr00+rr11; q=Vector4d(eigenvecs[0][0],eigenvecs[0][1],eigenvecs[0][2],eigenvecs[0][3]); double dq_dm[4][4][4]; - for(unsigned i=0; i<4; i++) - for(unsigned j=0; j<4; j++) - for(unsigned k=0; k<4; k++) { + for(unsigned i=0; i<4; i++) for(unsigned j=0; j<4; j++) for(unsigned k=0; k<4; k++) { double tmp=0.0; // perturbation theory for matrix m - for(unsigned l=1; l<4; l++) { - tmp+=eigenvecs[l][j]*eigenvecs[l][i]/(eigenvals[0]-eigenvals[l])*eigenvecs[0][k]; - } + for(unsigned l=1; l<4; l++) tmp+=eigenvecs[l][j]*eigenvecs[l][i]/(eigenvals[0]-eigenvals[l])*eigenvecs[0][k]; dq_dm[i][j][k]=tmp; } // propagation to _drr01 for(unsigned i=0; i<4; i++) { Tensor tmp; - for(unsigned j=0; j<4; j++) - for(unsigned k=0; k<4; k++) { + for(unsigned j=0; j<4; j++) for(unsigned k=0; k<4; k++) { tmp+=dq_dm[i][j][k]*dm_drr01[j][k]; } dq_drr01[i]=tmp; @@ -647,14 +557,10 @@ double RMSD::optimalAlignment(const std::vector & align, double prefactor=2.0; - if(!squared && alEqDis) { - prefactor*=0.5/std::sqrt(dist); - } + if(!squared && alEqDis) prefactor*=0.5/std::sqrt(dist); // if "safe", recompute dist here to a better accuracy - if(safe || !alEqDis) { - dist=0.0; - } + if(safe || !alEqDis) dist=0.0; // If safe is set to "false", MSD is taken from the eigenvalue of the M matrix // If safe is set to "true", MSD is recomputed from the rotational matrix @@ -670,9 +576,7 @@ double RMSD::optimalAlignment(const std::vector & align, // there is no need for derivatives of rotation and shift here as it is by construction zero // (similar to Hellman-Feynman forces) derivatives[iat]= prefactor*align[iat]*d; - if(safe) { - dist+=align[iat]*modulo2(d); - } + if(safe) dist+=align[iat]*modulo2(d); } else { // the case for align != displace is different, sob: dist+=displace[iat]*modulo2(d); @@ -687,10 +591,7 @@ double RMSD::optimalAlignment(const std::vector & align, if(!alEqDis) { Tensor ddist_drr01; - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<3; j++) { - ddist_drr01+=ddist_drotation[i][j]*drotation_drr01[i][j]; - } + for(unsigned i=0; i<3; i++) for(unsigned j=0; j<3; j++) ddist_drr01+=ddist_drotation[i][j]*drotation_drr01[i][j]; for(unsigned iat=0; iat & align, dist=std::sqrt(dist); if(!alEqDis) { double xx=0.5/dist; - for(unsigned iat=0; iat & align, // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -762,18 +655,12 @@ double RMSD::optimalAlignment_DDistDRef(const std::vector & align, // transfer the settings for the center to let the CoreCalc deal with it // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -799,18 +686,12 @@ double RMSD::optimalAlignment_SOMA(const std::vector & align, // transfer the settings for the center to let the CoreCalc deal with it // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -839,18 +720,12 @@ double RMSD::optimalAlignment_DDistDRef_Rot_DRotDPos(const std::vector // transfer the settings for the center to let the CoreCalc deal with it // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -883,18 +758,12 @@ double RMSD::optimalAlignment_DDistDRef_Rot_DRotDPos_DRotDRef(const std::vector // transfer the settings for the center to let the CoreCalc deal with it // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -924,18 +793,12 @@ double RMSD::optimalAlignment_Rot_DRotDRr01(const std::vector & align, RMSDCoreData cd(align,displace,positions,reference); // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -961,18 +824,12 @@ double RMSD::optimalAlignment_Rot(const std::vector & align, RMSDCoreData cd(align,displace,positions,reference); // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -1000,18 +857,12 @@ double RMSD::optimalAlignmentWithCloseStructure(const std::vector & al RMSDCoreData cd(align,displace,positions,reference); // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // instead of diagonalization, approximate with saved rotation matrix cd.doCoreCalcWithCloseStructure(safe,alEqDis, rotationPosClose, rotationRefClose, drotationPosCloseDrr01); @@ -1040,18 +891,12 @@ double RMSD::optimalAlignment_PCA(const std::vector & align, RMSDCoreData cd(align,displace,positions,reference); // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -1088,18 +933,12 @@ double RMSD::optimalAlignment_Fit(const std::vector & align, RMSDCoreData cd(align,displace,positions,reference); // transfer the settings for the center to let the CoreCalc deal with it cd.setPositionsCenterIsRemoved(positions_center_is_removed); - if(positions_center_is_calculated) { - cd.setPositionsCenter(positions_center); - } else { - cd.calcPositionsCenter(); - }; + if(positions_center_is_calculated) {cd.setPositionsCenter(positions_center);} + else {cd.calcPositionsCenter();}; cd.setReferenceCenterIsRemoved(reference_center_is_removed); - if(!reference_center_is_calculated) { - cd.calcReferenceCenter(); - } else { - cd.setReferenceCenter(reference_center); - } + if(!reference_center_is_calculated) {cd.calcReferenceCenter();} + else {cd.setReferenceCenter(reference_center);} // Perform the diagonalization and all the needed stuff cd.doCoreCalc(safe,alEqDis); @@ -1140,16 +979,8 @@ void RMSDCoreData::doCoreCalc(bool safe,bool alEqDis, bool only_rotation) { // This is positions*reference Tensor rr01; // center of mass managing: must subtract the center from the position or not? - Vector cp; - cp.zero(); - if(!cpositions_is_removed) { - cp=cpositions; - } - Vector cr; - cr.zero(); - if(!creference_is_removed) { - cr=creference; - } + Vector cp; cp.zero(); if(!cpositions_is_removed)cp=cpositions; + Vector cr; cr.zero(); if(!creference_is_removed)cr=creference; // second expensive loop: compute second moments wrt centers for(unsigned iat=0; iat here_eigenvecs; VectorGeneric<1> here_eigenvals; diagMatSym(m, here_eigenvals, here_eigenvecs ); - for(unsigned i=0; i<4; i++) { - eigenvecs[0][i]=here_eigenvecs[0][i]; - } + for(unsigned i=0; i<4; i++) eigenvecs[0][i]=here_eigenvecs[0][i]; eigenvals[0]=here_eigenvals[0]; q=Vector4d(eigenvecs[0][0],eigenvecs[0][1],eigenvecs[0][2],eigenvecs[0][3]); } @@ -1266,9 +1090,7 @@ void RMSDCoreData::doCoreCalc(bool safe,bool alEqDis, bool only_rotation) { d.resize(n); // calculate rotation matrix derivatives and components distances needed for components only when align!=displacement - if(!alEqDis) { - ddist_drotation.zero(); - } + if(!alEqDis)ddist_drotation.zero(); // This pragma leads to incorrect results with INTEL compiler. // Failures are seen in rt65-rmsd2, rt-close-structure, rt64-pca, and others. // Not really clear why. GB @@ -1280,15 +1102,11 @@ void RMSDCoreData::doCoreCalc(bool safe,bool alEqDis, bool only_rotation) { } // ddist_drotation if needed if(!alEqDis or !only_rotation) { - for (unsigned iat=0; iatalEqDis=alEqDis; @@ -1299,23 +1117,17 @@ void RMSDCoreData::doCoreCalc(bool safe,bool alEqDis, bool only_rotation) { /// just retrieve the distance already calculated double RMSDCoreData::getDistance( bool squared) { - if(!isInitialized) { - plumed_merror("getDistance cannot calculate the distance without being initialized first by doCoreCalc "); - } + if(!isInitialized)plumed_merror("getDistance cannot calculate the distance without being initialized first by doCoreCalc "); double localDist=0.0; const unsigned n=static_cast(reference.size()); - if(safe || !alEqDis) { - localDist=0.0; - } else { + if(safe || !alEqDis) localDist=0.0; + else localDist=eigenvals[0]+rr00+rr11; - } #pragma omp simd reduction(+:localDist) for(unsigned iat=0; iatalEqDis=alEqDis; this->safe=safe; @@ -1381,16 +1184,10 @@ std::vector RMSDCoreData::getDDistanceDPositions() { Vector ddist_dcpositions; derivatives.resize(n); double prefactor=1.0; - if(!distanceIsMSD) { - prefactor*=0.5/dist; - } + if(!distanceIsMSD) prefactor*=0.5/dist; plumed_massert(!retrieve_only_rotation,"You used only_rotation=true in doCoreCalc therefore you cannot retrieve this information now"); - if(!hasDistance) { - plumed_merror("getDPositionsDerivatives needs to calculate the distance via getDistance first !"); - } - if(!isInitialized) { - plumed_merror("getDPositionsDerivatives needs to initialize the coreData first!"); - } + if(!hasDistance)plumed_merror("getDPositionsDerivatives needs to calculate the distance via getDistance first !"); + if(!isInitialized)plumed_merror("getDPositionsDerivatives needs to initialize the coreData first!"); Vector csum; for(unsigned iat=0; iat RMSDCoreData::getDDistanceDPositions() { if(!alEqDis) #pragma omp simd - for(unsigned iat=0; iat RMSDCoreData::getDDistanceDReference() { Vector ddist_dcreference; derivatives.resize(n); double prefactor=1.0; - if(!distanceIsMSD) { - prefactor*=0.5/dist; - } + if(!distanceIsMSD) prefactor*=0.5/dist; Vector csum; plumed_massert(!retrieve_only_rotation,"You used only_rotation=true in doCoreCalc therefore you cannot retrieve this information now"); - if(!hasDistance) { - plumed_merror("getDDistanceDReference needs to calculate the distance via getDistance first !"); - } - if(!isInitialized) { - plumed_merror("getDDistanceDReference to initialize the coreData first!"); - } + if(!hasDistance)plumed_merror("getDDistanceDReference needs to calculate the distance via getDistance first !"); + if(!isInitialized)plumed_merror("getDDistanceDReference to initialize the coreData first!"); // get the transpose rotation Tensor t_rotation=rotation.transpose(); Tensor t_ddist_drr01=ddist_drr01.transpose(); @@ -1463,9 +1252,7 @@ std::vector RMSDCoreData::getDDistanceDReference() { if(!alEqDis) #pragma omp simd - for(unsigned iat=0; iat RMSDCoreData::getDDistanceDReferenceSOMA() { Vector ddist_dcreference; derivatives.resize(n); double prefactor=1.0; - if(!distanceIsMSD) { - prefactor*=0.5/dist; - } + if(!distanceIsMSD) prefactor*=0.5/dist; Vector csum,tmp1,tmp2; plumed_massert(!retrieve_only_rotation,"You used only_rotation=true in doCoreCalc therefore you cannot retrieve this information now"); - if(!hasDistance) { - plumed_merror("getDDistanceDReference needs to calculate the distance via getDistance first !"); - } - if(!isInitialized) { - plumed_merror("getDDistanceDReference to initialize the coreData first!"); - } + if(!hasDistance)plumed_merror("getDDistanceDReference needs to calculate the distance via getDistance first !"); + if(!isInitialized)plumed_merror("getDDistanceDReference to initialize the coreData first!"); // get the transpose rotation Tensor t_rotation=rotation.transpose(); @@ -1508,10 +1289,7 @@ std::vector RMSDCoreData::getDDistanceDReferenceSOMA() { } } - if(!alEqDis) - for(unsigned iat=0; iat > RMSDCoreData::getDRotationDPositions( bool inverseTransform ) { const unsigned n=static_cast(reference.size()); plumed_massert(!retrieve_only_rotation,"You used only_rotation=true in doCoreCalc therefore you cannot retrieve this information now"); - if(!isInitialized) { - plumed_merror("getDRotationDPosition to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getDRotationDPosition to initialize the coreData first!"); Matrix > DRotDPos=Matrix >(3,3); // remember drotation_drr01 is Tensor drotation_drr01[3][3] // (3x3 rot) (3x3 components of rr01) std::vector v(n); Vector csum; // these below could probably be calculated in the main routine - Vector cp; - cp.zero(); - if(!cpositions_is_removed) { - cp=cpositions; - } - Vector cr; - cr.zero(); - if(!creference_is_removed) { - cr=creference; - } - for(unsigned iat=0; iat > RMSDCoreData::getDRotationDReference( bool inverseTransform ) { const unsigned n=static_cast(reference.size()); plumed_massert(!retrieve_only_rotation,"You used only_rotation=true in doCoreCalc therefore you cannot retrieve this information now"); - if(!isInitialized) { - plumed_merror("getDRotationDPositions to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getDRotationDPositions to initialize the coreData first!"); Matrix > DRotDRef=Matrix >(3,3); // remember drotation_drr01 is Tensor drotation_drr01[3][3] // (3x3 rot) (3x3 components of rr01) std::vector v(n); Vector csum; // these below could probably be calculated in the main routine - Vector cp; - cp.zero(); - if(!cpositions_is_removed) { - cp=cpositions; - } - Vector cr; - cr.zero(); - if(!creference_is_removed) { - cr=creference; - } - for(unsigned iat=0; iat RMSDCoreData::getAlignedReferenceToPositions() { std::vector alignedref; const unsigned n=static_cast(reference.size()); alignedref.resize(n); - if(!isInitialized) { - plumed_merror("getAlignedReferenceToPostions needs to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getAlignedReferenceToPostions needs to initialize the coreData first!"); // avoid to calculate matrix element but use the sum of what you have - Vector cp; - cp.zero(); - if(!cpositions_is_removed) { - cp=cpositions; - } - for(unsigned iat=0; iat RMSDCoreData::getAlignedPositionsToReference() { std::vector alignedpos; - if(!isInitialized) { - plumed_merror("getAlignedPostionsToReference needs to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getAlignedPostionsToReference needs to initialize the coreData first!"); const unsigned n=static_cast(positions.size()); alignedpos.resize(n); - Vector cp; - cp.zero(); - if(!cpositions_is_removed) { - cp=cpositions; - } + Vector cp; cp.zero(); if(!cpositions_is_removed)cp=cpositions; // avoid to calculate matrix element but use the sum of what you have - for(unsigned iat=0; iat RMSDCoreData::getCenteredPositions() { std::vector centeredpos; const unsigned n=static_cast(reference.size()); centeredpos.resize(n); - if(!isInitialized) { - plumed_merror("getCenteredPositions needs to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getCenteredPositions needs to initialize the coreData first!"); // avoid to calculate matrix element but use the sum of what you have - for(unsigned iat=0; iat RMSDCoreData::getCenteredReference() { std::vector centeredref; const unsigned n=static_cast(reference.size()); centeredref.resize(n); - if(!isInitialized) { - plumed_merror("getCenteredReference needs to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getCenteredReference needs to initialize the coreData first!"); // avoid to calculate matrix element but use the sum of what you have - Vector cr; - cr.zero(); - if(!creference_is_removed) { - cr=creference; - } - for(unsigned iat=0; iat,3> & RMSDCoreData::getDRotationDRr01() const { - if(!isInitialized) { - plumed_merror("getDRotationDRr01 needs to initialize the coreData first!"); - } + if(!isInitialized)plumed_merror("getDRotationDRr01 needs to initialize the coreData first!"); return drotation_drr01; } diff --git a/src/tools/RMSD.h b/src/tools/RMSD.h index a9034724e7..ea00c8fc91 100644 --- a/src/tools/RMSD.h +++ b/src/tools/RMSD.h @@ -61,7 +61,8 @@ val=rmsd.calculate(getPositions(),derivs,true); **/ -class RMSD { +class RMSD +{ enum AlignmentMethod {SIMPLE, OPTIMAL, OPTIMAL_FAST}; AlignmentMethod alignmentMethod; // Reference coordinates @@ -81,28 +82,18 @@ class RMSD { // calculates the center from the position provided Vector calculateCenter(const std::vector &p,const std::vector &w) { plumed_massert(p.size()==w.size(),"mismatch in dimension of position/align arrays while calculating the center"); - unsigned n; - n=p.size(); - Vector c; - c.zero(); - for(unsigned i=0; i &p, const Vector &c) { - unsigned n; - n=p.size(); - for(unsigned i=0; i &p, const Vector &c) { - Vector cc=c*-1.; - removeCenter(p,cc); - }; + void addCenter(std::vector &p, const Vector &c) {Vector cc=c*-1.; removeCenter(p,cc);}; public: /// Constructor @@ -259,22 +250,17 @@ class RMSD { /// static convenience method to get the matrix i,a from drotdpos (which is a bit tricky) static Tensor getMatrixFromDRot(const Matrix< std::vector > &drotdpos, const unsigned &i, const unsigned &a) { Tensor t; - t[0][0]=drotdpos(0,0)[i][a]; - t[0][1]=drotdpos(0,1)[i][a]; - t[0][2]=drotdpos(0,2)[i][a]; - t[1][0]=drotdpos(1,0)[i][a]; - t[1][1]=drotdpos(1,1)[i][a]; - t[1][2]=drotdpos(1,2)[i][a]; - t[2][0]=drotdpos(2,0)[i][a]; - t[2][1]=drotdpos(2,1)[i][a]; - t[2][2]=drotdpos(2,2)[i][a]; + t[0][0]=drotdpos(0,0)[i][a]; t[0][1]=drotdpos(0,1)[i][a]; t[0][2]=drotdpos(0,2)[i][a]; + t[1][0]=drotdpos(1,0)[i][a]; t[1][1]=drotdpos(1,1)[i][a]; t[1][2]=drotdpos(1,2)[i][a]; + t[2][0]=drotdpos(2,0)[i][a]; t[2][1]=drotdpos(2,1)[i][a]; t[2][2]=drotdpos(2,2)[i][a]; return t; }; }; /// this is a class which is needed to share information across the various non-threadsafe routines /// so that the public function of rmsd are threadsafe while the inner core can safely share information -class RMSDCoreData { +class RMSDCoreData +{ private: bool alEqDis; bool distanceIsMSD; // default is RMSD but can deliver the MSD @@ -322,52 +308,26 @@ class RMSDCoreData { RMSDCoreData(const std::vector &a,const std::vector &d,const std::vector &p, const std::vector &r): alEqDis(false),distanceIsMSD(false),hasDistance(false),isInitialized(false),safe(false), creference_is_calculated(false),creference_is_removed(false), - cpositions_is_calculated(false),cpositions_is_removed(false),retrieve_only_rotation(false),positions(p),reference(r),align(a),displace(d),dist(0.0),rr00(0.0),rr11(0.0) { - cpositions.zero(); - creference.zero(); - }; + cpositions_is_calculated(false),cpositions_is_removed(false),retrieve_only_rotation(false),positions(p),reference(r),align(a),displace(d),dist(0.0),rr00(0.0),rr11(0.0) + {cpositions.zero(); creference.zero();}; // set the center on the fly without subtracting void calcPositionsCenter() { plumed_massert(!cpositions_is_calculated,"the center was already calculated"); - cpositions.zero(); - for(unsigned i=0; i0) { - idum_=-idum_; - } + if(idum_>0) idum_=-idum_; idum=idum_; incPrec=false; } -double Random::RandU01 () { - if (incPrec) { +double Random::RandU01 () +{ + if (incPrec) return U01d(); - } else { + else return U01(); - } } -double Random::U01d () { +double Random::U01d () +{ double u; u = U01(); u += U01() * fact; @@ -79,36 +77,24 @@ double Random::U01() { int j,k; double temp; if (idum <= 0 || !iy) { - if (-idum < 1) { - idum=1; - } else { - idum = -idum; - } + if (-idum < 1) idum=1; + else idum = -idum; for (j=NTAB+7; j>=0; j--) { k=idum/IQ; idum=IA*(idum-k*IQ)-IR*k; - if (idum < 0) { - idum += IM; - } - if (j < NTAB) { - iv[j] = idum; - } + if (idum < 0) idum += IM; + if (j < NTAB) iv[j] = idum; } iy=iv[0]; } k=idum/IQ; idum=IA*(idum-k*IQ)-IR*k; - if (idum < 0) { - idum += IM; - } + if (idum < 0) idum += IM; j=iy/NDIV; iy=iv[j]; iv[j] = idum; - if ((temp=AM*iy) > RNMX) { - return RNMX; - } else { - return temp; - } + if ((temp=AM*iy) > RNMX) return RNMX; + else return temp; } void Random::WriteStateFull(std::ostream & out)const { @@ -125,9 +111,7 @@ void Random::WriteStateFull(std::ostream & out)const { void Random::ReadStateFull (std::istream & in) { getline(in,name); in>>idum>>iy; - for (int i = 0; i < NTAB; i++) { - in>>iv[i]; - } + for (int i = 0; i < NTAB; i++) in>>iv[i]; in>>switchGaussian; in>>saveGaussian; } @@ -143,15 +127,10 @@ void Random::toString(std::string & str)const { void Random::fromString(const std::string & str) { std::string s=str; - for(unsigned i=0; i>idum>>iy; - for (int i = 0; i < NTAB; i++) { - istr>>iv[i]; - } + for (int i = 0; i < NTAB; i++) istr>>iv[i]; } // This allows to have the same stream of random numbers @@ -170,9 +149,7 @@ double Random::Gaussian() { v1=2.0*RandU01()-1.0; v2=2.0*RandU01()-1.0; rsq=v1*v1+v2*v2; - if(rsq<1.0 && rsq>0.0) { - break; - } + if(rsq<1.0 && rsq>0.0) break; } double fac=std::sqrt(-2.*std::log(rsq)/rsq); saveGaussian=v1*fac; diff --git a/src/tools/Random.h b/src/tools/Random.h index 573e575539..279a8a7c3d 100644 --- a/src/tools/Random.h +++ b/src/tools/Random.h @@ -57,17 +57,13 @@ class Random { void fromString(const std::string & str); void toString(std::string & str)const; friend std::ostream & operator<<(std::ostream & out,const Random & rng) { - rng.WriteStateFull(out); - return out; + rng.WriteStateFull(out); return out; } friend std::istream & operator>>(std::istream & in,Random & rng) { - rng.ReadStateFull(in); - return in; + rng.ReadStateFull(in); return in; } double Gaussian(); - void IncreasedPrecis(bool i) { - incPrec=i; - } + void IncreasedPrecis(bool i) {incPrec=i;} }; } diff --git a/src/tools/RootFindingBase.h b/src/tools/RootFindingBase.h index 750b05210e..7a097f9bfb 100644 --- a/src/tools/RootFindingBase.h +++ b/src/tools/RootFindingBase.h @@ -54,9 +54,7 @@ void RootFindingBase::doSearch( const std::vector& dir, std::vec double ax=0.0, xx=1.0; bb.bracket( ax, xx, &F1dim::getEng ); double xmin=bb.search( &F1dim::getEng ); - for(unsigned i=0; i diff --git a/src/tools/Stopwatch.cpp b/src/tools/Stopwatch.cpp index d38ab46dca..080ae7f855 100644 --- a/src/tools/Stopwatch.cpp +++ b/src/tools/Stopwatch.cpp @@ -42,9 +42,7 @@ Stopwatch::~Stopwatch() { // this is necessary e.g. to make sure the main watch present in PlumedMain // is stopped correctly. for(auto & w : watches) { - if(w.second.state==Watch::State::paused) { - w.second.start().stop(); - } + if(w.second.state==Watch::State::paused) w.second.start().stop(); } *mylog << *this; } @@ -54,15 +52,11 @@ std::ostream& Stopwatch::log(std::ostream&os)const { const std::size_t bufferlen=1000; char buffer[bufferlen]; buffer[0]=0; - for(unsigned i=0; i<40; i++) { - os<<" "; - } + for(unsigned i=0; i<40; i++) os<<" "; os<<" Cycles Total Average Minimum Maximum\n"; std::vector names; - for(const auto & it : watches) { - names.push_back(it.first); - } + for(const auto & it : watches) names.push_back(it.first); std::sort(names.begin(),names.end()); const double frac=1.0/1000000000.0; @@ -70,9 +64,7 @@ std::ostream& Stopwatch::log(std::ostream&os)const { for(const auto & name : names) { const Watch&t(watches.find(name)->second); os<start(); } inline Stopwatch::Handler::~Handler() { if(watch) { - if(stop) { - watch->stop(); - } else { - watch->pause(); - } + if(stop) watch->stop(); + else watch->pause(); } } @@ -333,7 +331,8 @@ Stopwatch::Handler Stopwatch::startPause(const std::string&name) { inline Stopwatch::Handler::Handler(Handler && handler) noexcept : watch(handler.watch), - stop(handler.stop) { + stop(handler.stop) +{ handler.watch=nullptr; } @@ -342,11 +341,8 @@ Stopwatch::Handler & Stopwatch::Handler::operator=(Handler && handler) noexcept if(this!=&handler) { if(watch) { try { - if(stop) { - watch->stop(); - } else { - watch->pause(); - } + if(stop) watch->stop(); + else watch->pause(); } catch(...) { // this is to avoid problems with cppcheck, given than this method is declared as // noexcept and stop and pause might throw in case of an internal bug @@ -374,12 +370,8 @@ Stopwatch::Watch & Stopwatch::Watch::stop() { state=State::stopped; cycles++; total+=lap; - if(lap>max) { - max=lap; - } - if(min>lap || cycles==1) { - min=lap; - } + if(lap>max)max=lap; + if(min>lap || cycles==1)min=lap; lap=0; return *this; } @@ -394,9 +386,7 @@ Stopwatch::Watch & Stopwatch::Watch::pause() { running--; // notice: with exception safety the following might be converted to a plain error. // I leave it like this for now: - if(running!=0) { - return *this; - } + if(running!=0) return *this; auto t=std::chrono::duration_cast(std::chrono::high_resolution_clock::now()-lastStart); lap+=t.count(); return *this; diff --git a/src/tools/Subprocess.cpp b/src/tools/Subprocess.cpp index 2ad2ee1c8e..5019d97fee 100644 --- a/src/tools/Subprocess.cpp +++ b/src/tools/Subprocess.cpp @@ -44,24 +44,19 @@ class SubprocessPid { public: pid_t pid; explicit SubprocessPid(pid_t pid): - pid(pid) { + pid(pid) + { plumed_assert(pid!=0 && pid!=-1); } void stop() noexcept { // Signals give problems with MPI on Travis. // I disable them for now. - if(SubprocessPidGetenvSignals()) - if(pid!=0 && pid!=-1) { - kill(pid,SIGSTOP); - } + if(SubprocessPidGetenvSignals()) if(pid!=0 && pid!=-1) kill(pid,SIGSTOP); } void cont() noexcept { // Signals give problems with MPI on Travis. // I disable them for now. - if(SubprocessPidGetenvSignals()) - if(pid!=0 && pid!=-1) { - kill(pid,SIGCONT); - } + if(SubprocessPidGetenvSignals()) if(pid!=0 && pid!=-1) kill(pid,SIGCONT); } ~SubprocessPid() { // this is apparently working also with MPI on Travis. @@ -85,49 +80,30 @@ Subprocess::Subprocess(const std::string & cmd) { }; int cp[2]; int pc[2]; - if(pipe(pc)<0) { - plumed_error()<<"error creating parent to child pipe"; - } - if(pipe(cp)<0) { - plumed_error()<<"error creating child to parent pipe"; - } + if(pipe(pc)<0) plumed_error()<<"error creating parent to child pipe"; + if(pipe(cp)<0) plumed_error()<<"error creating child to parent pipe"; pid_t pid=fork(); switch(pid) { case -1: plumed_error()<<"error forking"; break; // CHILD: - case 0: { - if(close(1)<0) { - plumed_error()<<"error closing file"; - } - if(dup(cp[1])<0) { - plumed_error()<<"error duplicating file"; - } - if(close(0)<0) { - plumed_error()<<"error closing file"; - } - if(dup(pc[0])<0) { - plumed_error()<<"error duplicating file"; - } - if(close(pc[1])<0) { - plumed_error()<<"error closing file"; - } - if(close(cp[0])<0) { - plumed_error()<<"error closing file"; - } + case 0: + { + if(close(1)<0) plumed_error()<<"error closing file"; + if(dup(cp[1])<0) plumed_error()<<"error duplicating file"; + if(close(0)<0) plumed_error()<<"error closing file"; + if(dup(pc[0])<0) plumed_error()<<"error duplicating file"; + if(close(pc[1])<0) plumed_error()<<"error closing file"; + if(close(cp[0])<0) plumed_error()<<"error closing file"; execv(arr[0],arr); plumed_error()<<"error in script file"; } // PARENT:: default: this->pid=Tools::make_unique(pid); - if(close(pc[0])<0) { - plumed_error()<<"error closing file"; - } - if(close(cp[1])<0) { - plumed_error()<<"error closing file"; - } + if(close(pc[0])<0) plumed_error()<<"error closing file"; + if(close(cp[1])<0) plumed_error()<<"error closing file"; fpc=pc[1]; fcp=cp[0]; fppc=fdopen(fpc,"w"); @@ -180,33 +156,29 @@ void Subprocess::flush() { Subprocess & Subprocess::getline(std::string & line) { child_to_parent.getline(line); - if(!child_to_parent) { - plumed_error() <<"error reading subprocess"; - } + if(!child_to_parent) plumed_error() <<"error reading subprocess"; return (*this); } Subprocess::Handler::Handler(Subprocess *sp) noexcept: - sp(sp) { + sp(sp) +{ sp->cont(); } Subprocess::Handler::~Handler() { - if(sp) { - sp->stop(); - } + if(sp) sp->stop(); } Subprocess::Handler::Handler(Handler && handler) noexcept : - sp(handler.sp) { + sp(handler.sp) +{ handler.sp=nullptr; } Subprocess::Handler & Subprocess::Handler::operator=(Handler && handler) noexcept { if(this!=&handler) { - if(sp) { - sp->stop(); - } + if(sp) sp->stop(); sp=handler.sp; handler.sp=nullptr; } diff --git a/src/tools/SwitchingFunction.cpp b/src/tools/SwitchingFunction.cpp index 73b7c496fb..58e85d7cb3 100644 --- a/src/tools/SwitchingFunction.cpp +++ b/src/tools/SwitchingFunction.cpp @@ -203,33 +203,23 @@ void SwitchingFunction::set(const std::string & definition,std::string& errormsg bool present; present=Tools::findKeyword(data,"D_0"); - if(present && !Tools::parse(data,"D_0",d0)) { - errormsg="could not parse D_0"; - } + if(present && !Tools::parse(data,"D_0",d0)) errormsg="could not parse D_0"; present=Tools::findKeyword(data,"D_MAX"); - if(present && !Tools::parse(data,"D_MAX",dmax)) { - errormsg="could not parse D_MAX"; - } - if(dmax::max())) { - dmax_2=dmax*dmax; - } + if(present && !Tools::parse(data,"D_MAX",dmax)) errormsg="could not parse D_MAX"; + if(dmax::max())) dmax_2=dmax*dmax; bool dostretch=false; Tools::parseFlag(data,"STRETCH",dostretch); // this is ignored now dostretch=true; bool dontstretch=false; Tools::parseFlag(data,"NOSTRETCH",dontstretch); // this is ignored now - if(dontstretch) { - dostretch=false; - } + if(dontstretch) dostretch=false; double r0; if(name=="CUBIC") { r0 = dmax - d0; } else { bool found_r0=Tools::parse(data,"R_0",r0); - if(!found_r0) { - errormsg="R_0 is required"; - } + if(!found_r0) errormsg="R_0 is required"; } invr0=1.0/r0; invr0_2=invr0*invr0; @@ -239,66 +229,45 @@ void SwitchingFunction::set(const std::string & definition,std::string& errormsg nn=6; mm=0; present=Tools::findKeyword(data,"NN"); - if(present && !Tools::parse(data,"NN",nn)) { - errormsg="could not parse NN"; - } + if(present && !Tools::parse(data,"NN",nn)) errormsg="could not parse NN"; present=Tools::findKeyword(data,"MM"); - if(present && !Tools::parse(data,"MM",mm)) { - errormsg="could not parse MM"; - } - if(mm==0) { - mm=2*nn; - } + if(present && !Tools::parse(data,"MM",mm)) errormsg="could not parse MM"; + if(mm==0) mm=2*nn; fastrational=(nn%2==0 && mm%2==0 && d0==0.0); } else if(name=="SMAP") { type=smap; present=Tools::findKeyword(data,"A"); - if(present && !Tools::parse(data,"A",a)) { - errormsg="could not parse A"; - } + if(present && !Tools::parse(data,"A",a)) errormsg="could not parse A"; present=Tools::findKeyword(data,"B"); - if(present && !Tools::parse(data,"B",b)) { - errormsg="could not parse B"; - } + if(present && !Tools::parse(data,"B",b)) errormsg="could not parse B"; c=std::pow(2., static_cast(a)/static_cast(b) ) - 1; d = -static_cast(b) / static_cast(a); - } else if(name=="Q") { + } + else if(name=="Q") { type=nativeq; beta = 50.0; // nm-1 lambda = 1.8; // unitless present=Tools::findKeyword(data,"BETA"); - if(present && !Tools::parse(data, "BETA", beta)) { - errormsg="could not parse BETA"; - } + if(present && !Tools::parse(data, "BETA", beta)) errormsg="could not parse BETA"; present=Tools::findKeyword(data,"LAMBDA"); - if(present && !Tools::parse(data, "LAMBDA", lambda)) { - errormsg="could not parse LAMBDA"; - } + if(present && !Tools::parse(data, "LAMBDA", lambda)) errormsg="could not parse LAMBDA"; bool found_ref=Tools::parse(data,"REF",ref); // nm - if(!found_ref) { - errormsg="REF (reference disatance) is required for native Q"; - } + if(!found_ref) errormsg="REF (reference disatance) is required for native Q"; - } else if(name=="EXP") { - type=exponential; - } else if(name=="GAUSSIAN") { - type=gaussian; - } else if(name=="CUBIC") { - type=cubic; - } else if(name=="TANH") { - type=tanh; - } else if(name=="COSINUS") { - type=cosinus; - } else if((name=="MATHEVAL" || name=="CUSTOM")) { + } + else if(name=="EXP") type=exponential; + else if(name=="GAUSSIAN") type=gaussian; + else if(name=="CUBIC") type=cubic; + else if(name=="TANH") type=tanh; + else if(name=="COSINUS") type=cosinus; + else if((name=="MATHEVAL" || name=="CUSTOM")) { type=leptontype; std::string func; Tools::parse(data,"FUNC",func); lepton::ParsedExpression pe=lepton::Parser::parse(func).optimize(lepton::Constants()); lepton_func=func; expression.resize(OpenMP::getNumThreads()); - for(auto & e : expression) { - e=pe.createCompiledExpression(); - } + for(auto & e : expression) e=pe.createCompiledExpression(); lepton_ref.resize(expression.size()); for(unsigned t=0; t::max()) { @@ -450,12 +412,8 @@ double SwitchingFunction::calculateSqr(double distance2,double&dfunc)const { const unsigned t=OpenMP::getThreadNum(); const double rdist_2 = distance2*invr0_2; plumed_assert(tnn=nn; this->mm=mm; this->invr0=1.0/r0; diff --git a/src/tools/Tensor.h b/src/tools/Tensor.h index 4ed456b3d7..a4f53c8a9b 100644 --- a/src/tools/Tensor.h +++ b/src/tools/Tensor.h @@ -85,7 +85,8 @@ int main(){ */ template class TensorGeneric: - public MatrixSquareBracketsAccess,double> { + public MatrixSquareBracketsAccess,double> +{ std::array d; /// Auxiliary private function for constructor void auxiliaryConstructor(); @@ -211,14 +212,16 @@ void TensorGeneric::auxiliaryConstructor() template template -void TensorGeneric::auxiliaryConstructor(double first,Args... arg) { +void TensorGeneric::auxiliaryConstructor(double first,Args... arg) +{ d[n*m-(sizeof...(Args))-1]=first; auxiliaryConstructor(arg...); } template template -TensorGeneric::TensorGeneric(double first,Args... arg) { +TensorGeneric::TensorGeneric(double first,Args... arg) +{ static_assert((sizeof...(Args))+1==n*m,"you are trying to initialize a Tensor with the wrong number of arguments"); auxiliaryConstructor(first,arg...); } @@ -230,10 +233,7 @@ TensorGeneric::TensorGeneric() { template TensorGeneric::TensorGeneric(const VectorGeneric&v1,const VectorGeneric&v2) { - for(unsigned i=0; i @@ -297,35 +297,27 @@ TensorGeneric TensorGeneric::operator-()const { template TensorGeneric& TensorGeneric::setCol(unsigned j,const VectorGeneric & c) { - for(unsigned i=0; i TensorGeneric& TensorGeneric::setRow(unsigned i,const VectorGeneric & r) { - for(unsigned j=0; j VectorGeneric TensorGeneric::getCol(unsigned j)const { VectorGeneric v; - for(unsigned i=0; i VectorGeneric TensorGeneric::getRow(unsigned i)const { VectorGeneric v; - for(unsigned j=0; j inline TensorGeneric TensorGeneric::identity() { TensorGeneric t; - for(unsigned i=0; i TensorGeneric TensorGeneric::transpose()const { TensorGeneric t; - for(unsigned i=0; i TensorGeneric<3,3>::inverse()const { TensorGeneric t; double invdet=1.0/determinant(); - for(unsigned i=0; i<3; i++) - for(unsigned j=0; j<3; j++) + for(unsigned i=0; i<3; i++) for(unsigned j=0; j<3; j++) t(j,i)=invdet*( (*this)((i+1)%3,(j+1)%3)*(*this)((i+2)%3,(j+2)%3) -(*this)((i+1)%3,(j+2)%3)*(*this)((i+2)%3,(j+1)%3)); return t; @@ -407,9 +393,7 @@ TensorGeneric<3,3> TensorGeneric<3,3>::inverse()const { template TensorGeneric matmul(const TensorGeneric&a,const TensorGeneric&b) { TensorGeneric t; - for(unsigned i=0; i matmul(const TensorGeneric&a,const TensorGeneric&b) template VectorGeneric matmul(const TensorGeneric&a,const VectorGeneric&b) { VectorGeneric t; - for(unsigned i=0; i VectorGeneric matmul(const VectorGeneric&a,const TensorGeneric&b) { VectorGeneric t; - for(unsigned i=0; i dcrossDv2(const VectorGeneric<3>&v1,const VectorGeneric<3>&v2 template std::ostream & operator<<(std::ostream &os, const TensorGeneric& t) { - for(unsigned i=0; i&mat,VectorGeneric&evals,TensorGeneri TensorGenericAux::local_dsyevr("V", (n==m?"A":"I"), "U", &nn, const_cast(&mat_copy[0][0]), &nn, &vl, &vu, &one, &mm, &abstol, &mout, &evals_tmp[0], &evec[0][0], &nn, isup.data(), work.data(), &lwork, iwork.data(), &liwork, &info); - if(info!=0) - plumed_error()<<"Error diagonalizing matrix\n" - <<"Matrix:\n"<1e-14) { - break; - } - if(j1e-14) break; + if(j bool Tools::convertToAny(const std::string & str,T & t) { std::istringstream istr(str.c_str()); bool ok=static_cast(istr>>t); - if(!ok) { - return false; - } + if(!ok) return false; std::string remaining; istr>>remaining; return remaining.length()==0; @@ -77,18 +75,14 @@ bool Tools::convertNoexcept(const std::string & str,AtomNumber &a) { // avoid using lepton conversions. unsigned i; bool r=convertToAny(str,i); - if(r) { - a.setSerial(i); - } + if(r) a.setSerial(i); return r; } template bool Tools::convertToInt(const std::string & str,T & t) { // First try standard conversion - if(convertToAny(str,t)) { - return true; - } + if(convertToAny(str,t)) return true; // Then use lepton try { double r=lepton::Parser::parse(str).evaluate(lepton::Constants()); @@ -97,30 +91,20 @@ bool Tools::convertToInt(const std::string & str,T & t) { // it should not overflow the requested int type: // (see https://stackoverflow.com/a/526092) - if(r>std::nextafter(std::numeric_limits::max(), 0)) { - return false; - } - if(r::min(), 0)) { - return false; - } + if(r>std::nextafter(std::numeric_limits::max(), 0)) return false; + if(r::min(), 0)) return false; // do the actual conversion auto tmp=static_cast(std::round(r)); // it should be *very close* to itself if converted back to double double diff= r-static_cast(tmp); - if(diff*diff > 1e-20) { - return false; - } + if(diff*diff > 1e-20) return false; // this is to accomodate small numerical errors and allow e.g. exp(log(7)) to be integer // it should be change if incremented or decremented by one (see https://stackoverflow.com/a/43656140) - if(r == static_cast(tmp-1)) { - return false; - } - if(r == static_cast(tmp+1)) { - return false; - } + if(r == static_cast(tmp-1)) return false; + if(r == static_cast(tmp+1)) return false; // everything is fine, then store in t t=tmp; @@ -133,15 +117,11 @@ bool Tools::convertToInt(const std::string & str,T & t) { template bool Tools::convertToReal(const std::string & str,T & t) { - if(convertToAny(str,t)) { - return true; - } + if(convertToAny(str,t)) return true; if(str=="PI" || str=="+PI" || str=="+pi" || str=="pi") { - t=pi; - return true; + t=pi; return true; } else if(str=="-PI" || str=="-pi") { - t=-pi; - return true; + t=-pi; return true; } try { t=lepton::Parser::parse(str).evaluate(lepton::Constants()); @@ -150,33 +130,21 @@ bool Tools::convertToReal(const std::string & str,T & t) { } if( str.find("PI")!=std::string::npos ) { std::size_t pi_start=str.find_first_of("PI"); - if(str.substr(pi_start)!="PI") { - return false; - } + if(str.substr(pi_start)!="PI") return false; std::istringstream nstr(str.substr(0,pi_start)); - T ff=0.0; - bool ok=static_cast(nstr>>ff); - if(!ok) { - return false; - } + T ff=0.0; bool ok=static_cast(nstr>>ff); + if(!ok) return false; t=ff*pi; - std::string remains; - nstr>>remains; + std::string remains; nstr>>remains; return remains.length()==0; } else if( str.find("pi")!=std::string::npos ) { std::size_t pi_start=str.find_first_of("pi"); - if(str.substr(pi_start)!="pi") { - return false; - } + if(str.substr(pi_start)!="pi") return false; std::istringstream nstr(str.substr(0,pi_start)); - T ff=0.0; - bool ok=static_cast(nstr>>ff); - if(!ok) { - return false; - } + T ff=0.0; bool ok=static_cast(nstr>>ff); + if(!ok) return false; t=ff*pi; - std::string remains; - nstr>>remains; + std::string remains; nstr>>remains; return remains.length()==0; } else if(str=="NAN") { t=std::numeric_limits::quiet_NaN(); @@ -206,67 +174,41 @@ std::vector Tools::getWords(const std::string & line,const char* se plumed_massert(std::strlen(parenthesis)==1,"multiple parenthesis type not available"); plumed_massert(parenthesis[0]=='(' || parenthesis[0]=='[' || parenthesis[0]=='{', "only ( [ { allowed as parenthesis"); - if(!separators) { - separators=" \t\n"; - } + if(!separators) separators=" \t\n"; const std::string sep(separators); char openpar=parenthesis[0]; char closepar; - if(openpar=='(') { - closepar=')'; - } - if(openpar=='[') { - closepar=']'; - } - if(openpar=='{') { - closepar='}'; - } + if(openpar=='(') closepar=')'; + if(openpar=='[') closepar=']'; + if(openpar=='{') closepar='}'; std::vector words; std::string word; int parenthesisLevel=0; - if(parlevel) { - parenthesisLevel=*parlevel; - } + if(parlevel) parenthesisLevel=*parlevel; for(unsigned i=0; i=0,"Extra closed parenthesis in '" + line + "'"); } - if(parenthesisLevel==0) - for(unsigned j=0; j0) { - if(!parlevel) { - plumed_massert(parenthesisLevel==0,"Unmatching parenthesis in '" + line + "'"); - } + if(!parlevel) plumed_massert(parenthesisLevel==0,"Unmatching parenthesis in '" + line + "'"); words.push_back(word); word.clear(); } } if(word.length()>0) { - if(!parlevel) { - plumed_massert(parenthesisLevel==0,"Unmatching parenthesis in '" + line + "'"); - } + if(!parlevel) plumed_massert(parenthesisLevel==0,"Unmatching parenthesis in '" + line + "'"); words.push_back(word); } - if(parlevel) { - *parlevel=parenthesisLevel; - } + if(parlevel) *parlevel=parenthesisLevel; return words; } @@ -278,25 +220,16 @@ bool Tools::getParsedLine(IFile& ifile,std::vector & words, bool tr int parlevel=0; bool mergenext=false; while((stat=ifile.getline(line))) { - if(trimcomments) { - trimComments(line); - } + if(trimcomments) trimComments(line); trim(line); - if(line.length()==0) { - continue; - } + if(line.length()==0) continue; std::vector w=getWords(line,NULL,&parlevel,"{",trimcomments); if(!w.empty()) { if(inside && *(w.begin())=="...") { inside=false; - if(w.size()==2) { - plumed_massert(w[1]==words[0],"second word in terminating \"...\" "+w[1]+" line, if present, should be equal to first word of directive: "+words[0]); - } + if(w.size()==2) plumed_massert(w[1]==words[0],"second word in terminating \"...\" "+w[1]+" line, if present, should be equal to first word of directive: "+words[0]); plumed_massert(w.size()<=2,"terminating \"...\" lines cannot consist of more than two words"); - w.clear(); - if(!trimcomments) { - words.push_back("..."); - } + w.clear(); if(!trimcomments) words.push_back("..."); } else if(*(w.end()-1)=="...") { inside=true; w.erase(w.end()-1); @@ -306,24 +239,15 @@ bool Tools::getParsedLine(IFile& ifile,std::vector & words, bool tr words[words.size()-1]+=" "+w[0]; i0=1; } - for(unsigned i=i0; i0); - if(!inside) { - break; - } - if(!trimcomments && parlevel==0) { - words.push_back("@newline"); - } else if(!trimcomments) { - words[words.size()-1] += " @newline"; - } + if(!inside)break; + if(!trimcomments && parlevel==0) words.push_back("@newline"); + else if(!trimcomments) words[words.size()-1] += " @newline"; } plumed_massert(parlevel==0,"non matching parenthesis"); - if(words.size()>0) { - return true; - } + if(words.size()>0) return true; return stat; } @@ -333,43 +257,29 @@ bool Tools::getline(FILE* fp,std::string & line) { const int bufferlength=1024; char buffer[bufferlength]; bool ret; - for(int i=0; i0) - if(buffer[ss-1]=='\n') { - break; - } + if(ss>0) if(buffer[ss-1]=='\n') break; }; - if(line.length()>0) - if(*(line.end()-1)=='\n') { - line.erase(line.end()-1); - } - if(line.length()>0) - if(*(line.end()-1)=='\r') { - line.erase(line.end()-1); - } + if(line.length()>0) if(*(line.end()-1)=='\n') line.erase(line.end()-1); + if(line.length()>0) if(*(line.end()-1)=='\r') line.erase(line.end()-1); return ret; } void Tools::trim(std::string & s) { auto n=s.find_last_not_of(" \t"); - if(n!=std::string::npos) { - s.resize(n+1); - } + if(n!=std::string::npos) s.resize(n+1); } void Tools::trimComments(std::string & s) { auto n=s.find_first_of("#"); - if(n!=std::string::npos) { - s.resize(n); - } + if(n!=std::string::npos) s.resize(n); } -bool Tools::caseInSensStringCompare(const std::string & str1, const std::string &str2) { +bool Tools::caseInSensStringCompare(const std::string & str1, const std::string &str2) +{ return ((str1.size() == str2.size()) && std::equal(str1.begin(), str1.end(), str2.begin(), [](char c1, char c2) { return (c1 == c2 || std::toupper(c1) == std::toupper(c2)); })); @@ -378,14 +288,10 @@ bool Tools::caseInSensStringCompare(const std::string & str1, const std::string bool Tools::getKey(std::vector& line,const std::string & key,std::string & s,int rep) { s.clear(); for(auto p=line.begin(); p!=line.end(); ++p) { - if((*p).length()==0) { - continue; - } + if((*p).length()==0) continue; std::string x=(*p).substr(0,key.length()); if(caseInSensStringCompare(x,key)) { - if((*p).length()==key.length()) { - return false; - } + if((*p).length()==key.length())return false; std::string tmp=(*p).substr(key.length(),(*p).length()); line.erase(p); s=tmp; @@ -407,25 +313,17 @@ void Tools::interpretRanges(std::vector&s) { for(const auto & p :s) { news.push_back(p); size_t dash=p.find("-"); - if(dash==std::string::npos) { - continue; - } + if(dash==std::string::npos) continue; int first; - if(!Tools::convertToAny(p.substr(0,dash),first)) { - continue; - } + if(!Tools::convertToAny(p.substr(0,dash),first)) continue; int stride=1; int second; size_t colon=p.substr(dash+1).find(":"); if(colon!=std::string::npos) { if(!Tools::convertToAny(p.substr(dash+1).substr(0,colon),second) || - !Tools::convertToAny(p.substr(dash+1).substr(colon+1),stride)) { - continue; - } + !Tools::convertToAny(p.substr(dash+1).substr(colon+1),stride)) continue; } else { - if(!Tools::convertToAny(p.substr(dash+1),second)) { - continue; - } + if(!Tools::convertToAny(p.substr(dash+1),second)) continue; } news.resize(news.size()-1); if(first<=second) { @@ -448,14 +346,10 @@ void Tools::interpretRanges(std::vector&s) { } void Tools::interpretLabel(std::vector&s) { - if(s.size()<2) { - return; - } + if(s.size()<2)return; std::string s0=s[0]; unsigned l=s0.length(); - if(l<1) { - return; - } + if(l<1) return; if(s0[l-1]==':') { s[0]=s[1]; s[1]="LABEL="+s0.substr(0,l-1); @@ -477,12 +371,8 @@ std::vector Tools::ls(const std::string&d) { #else res=readdir(dir); #endif - if(!res) { - break; - } - if(std::string(res->d_name)!="." && std::string(res->d_name)!="..") { - result.push_back(res->d_name); - } + if(!res) break; + if(std::string(res->d_name)!="." && std::string(res->d_name)!="..") result.push_back(res->d_name); } closedir (dir); } @@ -492,9 +382,7 @@ std::vector Tools::ls(const std::string&d) { void Tools::stripLeadingAndTrailingBlanks( std::string& str ) { std::size_t first=str.find_first_not_of(' '); std::size_t last=str.find_last_not_of(' '); - if( first<=last && first!=std::string::npos) { - str=str.substr(first,last+1); - } + if( first<=last && first!=std::string::npos) str=str.substr(first,last+1); } std::string Tools::extension(const std::string&s) { @@ -502,16 +390,10 @@ std::string Tools::extension(const std::string&s) { std::string ext; if(n!=std::string::npos && n+1=s.length()) { ext=s.substr(n+1); - if(ext.find("/")!=std::string::npos) { - ext=""; - } + if(ext.find("/")!=std::string::npos) ext=""; std::string base=s.substr(0,n); - if(base.length()==0) { - ext=""; - } - if(base.length()>0 && base[base.length()-1]=='/') { - ext=""; - } + if(base.length()==0) ext=""; + if(base.length()>0 && base[base.length()-1]=='/') ext=""; } return ext; } @@ -533,20 +415,14 @@ bool Tools::startWith(const std::string & full,const std::string &start) { bool Tools::findKeyword(const std::vector&line,const std::string&key) { const std::string search(key+"="); for(const auto & p : line) { - if(startWith(p,search)) { - return true; - } + if(startWith(p,search)) return true; } return false; } Tools::DirectoryChanger::DirectoryChanger(const char*path) { - if(!path) { - return; - } - if(std::strlen(path)==0) { - return; - } + if(!path) return; + if(std::strlen(path)==0) return; #ifdef __PLUMED_HAS_GETCWD char* ret=getcwd(cwd,buffersize); plumed_assert(ret)<<"Name of current directory too long, increase buffer size"; @@ -563,15 +439,11 @@ Tools::DirectoryChanger::DirectoryChanger(const char*path) { Tools::DirectoryChanger::~DirectoryChanger() { #ifdef __PLUMED_HAS_CHDIR - if(std::strlen(cwd)==0) { - return; - } + if(std::strlen(cwd)==0) return; int ret=chdir(cwd); // we cannot put an assertion here (in a destructor) otherwise cppcheck complains // we thus just report the problem - if(ret!=0) { - std::fprintf(stderr,"+++ WARNING: cannot cd back to directory %s\n",cwd); - } + if(ret!=0) std::fprintf(stderr,"+++ WARNING: cannot cd back to directory %s\n",cwd); #endif } @@ -587,9 +459,7 @@ class process_one_exception { std::string & msg; bool first=true; void update() { - if(!first) { - msg+="\n\nThe above exception was the direct cause of the following exception:\n"; - } + if(!first) msg+="\n\nThe above exception was the direct cause of the following exception:\n"; first=false; } public: @@ -624,9 +494,7 @@ static void process_all_exceptions(T&& f) { process_all_exceptions(f); } auto d=dynamic_cast(&e); - if(d) { - f(*d); - } + if(d) f(*d); } catch(const std::exception &e) { // If not nested, we end recursion f(e); diff --git a/src/tools/Tools.h b/src/tools/Tools.h index 653a4bf273..802a2f4a72 100644 --- a/src/tools/Tools.h +++ b/src/tools/Tools.h @@ -240,26 +240,20 @@ class Tools { make_unique(Args&&...) = delete; static void set_to_zero(double*ptr,unsigned n) { - for(unsigned i=0; i static void set_to_zero(std::vector> & vec) { unsigned s=vec.size(); - if(s==0) { - return; - } + if(s==0) return; set_to_zero(&vec[0][0],s*n); } template static void set_to_zero(std::vector> & vec) { unsigned s=vec.size(); - if(s==0) { - return; - } + if(s==0) return; set_to_zero(&vec[0](0,0),s*n*m); } @@ -275,19 +269,16 @@ class Tools { static void mergeSortedVectors(const std::vector & vecs, std::vector & result,bool priority_queue=false) { /// local class storing the range of remaining objects to be pushed - struct Entry { + struct Entry + { typename C::const_iterator fwdIt,endIt; explicit Entry(C const& v) : fwdIt(v.begin()), endIt(v.end()) {} /// check if this vector still contains something to be pushed - explicit operator bool () const { - return fwdIt != endIt; - } + explicit operator bool () const { return fwdIt != endIt; } /// to allow using a priority_queu, which selects the highest element. /// we here (counterintuitively) define < as > - bool operator< (Entry const& rhs) const { - return *fwdIt > *rhs.fwdIt; - } + bool operator< (Entry const& rhs) const { return *fwdIt > *rhs.fwdIt; } }; if(priority_queue) { @@ -298,40 +289,28 @@ class Tools { { std::size_t maxsize=0; for(unsigned i=0; isize()>maxsize) { - maxsize=vecs[i]->size(); - } - if(!vecs[i]->empty()) { - queue.push(Entry(*vecs[i])); - } + if(vecs[i]->size()>maxsize) maxsize=vecs[i]->size(); + if(!vecs[i]->empty())queue.push(Entry(*vecs[i])); } // this is just to save multiple reallocations on push_back result.reserve(maxsize); } // first iteration (to avoid a if in the main loop) - if(queue.empty()) { - return; - } + if(queue.empty()) return; auto tmp=queue.top(); queue.pop(); result.push_back(*tmp.fwdIt); tmp.fwdIt++; - if(tmp) { - queue.push(tmp); - } + if(tmp) queue.push(tmp); // main loop while(!queue.empty()) { auto tmp=queue.top(); queue.pop(); - if(result.back() < *tmp.fwdIt) { - result.push_back(*tmp.fwdIt); - } + if(result.back() < *tmp.fwdIt) result.push_back(*tmp.fwdIt); tmp.fwdIt++; - if(tmp) { - queue.push(tmp); - } + if(tmp) queue.push(tmp); } } else { @@ -341,12 +320,8 @@ class Tools { { std::size_t maxsize=0; for(int i=0; isize()>maxsize) { - maxsize=vecs[i]->size(); - } - if(!vecs[i]->empty()) { - entries.push_back(Entry(*vecs[i])); - } + if(vecs[i]->size()>maxsize) maxsize=vecs[i]->size(); + if(!vecs[i]->empty())entries.push_back(Entry(*vecs[i])); } // this is just to save multiple reallocations on push_back result.reserve(maxsize); @@ -361,15 +336,10 @@ class Tools { result.push_back(minval); // fast forward vectors with elements equal to minval (to avoid duplicates) - for(auto & e : entries) - while(e && *e.fwdIt==minval) { - ++e.fwdIt; - } + for(auto & e : entries) while(e && *e.fwdIt==minval) ++e.fwdIt; // remove from the entries vector all exhausted vectors - auto erase=std::remove_if(entries.begin(),entries.end(),[](const Entry & e) { - return !e; - }); + auto erase=std::remove_if(entries.begin(),entries.end(),[](const Entry & e) {return !e;}); entries.erase(erase,entries.end()); } } @@ -384,21 +354,15 @@ class Tools { template bool Tools::parse(std::vector&line,const std::string&key,T&val,int rep) { std::string s; - if(!getKey(line,key+"=",s,rep)) { - return false; - } - if(s.length()>0 && !convertNoexcept(s,val)) { - return false; - } + if(!getKey(line,key+"=",s,rep)) return false; + if(s.length()>0 && !convertNoexcept(s,val))return false; return true; } template bool Tools::parseVector(std::vector&line,const std::string&key,std::vector&val,int rep) { std::string s; - if(!getKey(line,key+"=",s,rep)) { - return false; - } + if(!getKey(line,key+"=",s,rep)) return false; val.clear(); std::vector words=getWords(s,"\t\n ,"); for(unsigned i=0; i&line,const std::string&key,std: plumed_assert(rep(words.size())); s=words[rep]; } - if(!convertNoexcept(s,v)) { - return false; - } + if(!convertNoexcept(s,v))return false; val.push_back(v); } return true; } template -void Tools::removeDuplicates(std::vector& vec) { +void Tools::removeDuplicates(std::vector& vec) +{ std::sort(vec.begin(), vec.end()); vec.erase(std::unique(vec.begin(), vec.end()), vec.end()); } @@ -441,27 +404,18 @@ bool Tools::parseFlag(std::vector&line,const std::string&key,bool&v inline double Tools::pbc(double x) { #ifdef __PLUMED_PBC_WHILE - while (x>0.5) { - x-=1.0; - } - while (x<-0.5) { - x+=1.0; - } + while (x>0.5) x-=1.0; + while (x<-0.5) x+=1.0; return x; #else if(std::numeric_limits::round_style == std::round_toward_zero) { const double offset=100.0; const double y=x+offset; - if(y>=0) { - return y-int(y+0.5); - } else { - return y-int(y-0.5); - } + if(y>=0) return y-int(y+0.5); + else return y-int(y-0.5); } else if(std::numeric_limits::round_style == std::round_to_nearest) { return x-int(x); - } else { - return x-floor(x+0.5); - } + } else return x-floor(x+0.5); #endif } @@ -474,16 +428,17 @@ bool Tools::convertNoexcept(T i,std::string & str) { } inline -double Tools::fastpow(double base, int exp) { +double Tools::fastpow(double base, int exp) +{ if(exp<0) { exp=-exp; base=1.0/base; } double result = 1.0; - while (exp) { - if (exp & 1) { + while (exp) + { + if (exp & 1) result *= base; - } exp >>= 1; base *= base; } @@ -494,18 +449,14 @@ double Tools::fastpow(double base, int exp) { template std::vector Tools::unique2raw(const std::vector> & x) { std::vector v(x.size()); - for(unsigned i=0; i std::vector Tools::unique2raw(const std::vector> & x) { std::vector v(x.size()); - for(unsigned i=0; iisWhole()) { - plumed_merror("Check that reference structure in PDB file is not broken by pbc and set WHOLE in MOLINFO line"); - } + if(!moldat_->isWhole()) plumed_merror("Check that reference structure in PDB file is not broken by pbc and set WHOLE in MOLINFO line"); } -std::vector Tree::getTree(std::vector atoms) { +std::vector Tree::getTree(std::vector atoms) +{ // Implementation inspired from: // https://mayanknatani.wordpress.com/2013/05/31/euclidean-minimummaximum-spanning-tree-emst/ // @@ -56,9 +53,7 @@ std::vector Tree::getTree(std::vector atoms) { std::vector addtotree, addtoroot; std::vector newatoms; newatoms.reserve(atoms.size()); - if(!moldat_->checkForAtom(atoms[0])) { - plumed_merror("The first atom in the list should be present in the PDB file"); - } + if(!moldat_->checkForAtom(atoms[0])) plumed_merror("The first atom in the list should be present in the PDB file"); // store first atom newatoms.push_back(atoms[0]); for(unsigned i=1; i Tree::getTree(std::vector atoms) { for(unsigned i=0; i=0); @@ -95,18 +89,14 @@ std::vector Tree::getTree(std::vector atoms) { int iroot = -1; for(unsigned j=0; jgetPosition(atoms[selected_vertex]), moldat_->getPosition(atoms[j])).modulo2(); - if(dist < mindist[j]) { - mindist[j] = dist; - } + if(dist < mindist[j]) mindist[j] = dist; if(dist < minroot && intree[j] && dist>0.0) { minroot = dist; iroot = j; } } // add to root vector - if(iroot>=0) { - root_.push_back(atoms[iroot]); - } + if(iroot>=0) root_.push_back(atoms[iroot]); } // now re-add atoms not present in the PDB @@ -119,7 +109,8 @@ std::vector Tree::getTree(std::vector atoms) { return tree; } -std::vector Tree::getRoot() const { +std::vector Tree::getRoot() const +{ return root_; } diff --git a/src/tools/Tree.h b/src/tools/Tree.h index 8338d5d1f1..c0551e82b1 100644 --- a/src/tools/Tree.h +++ b/src/tools/Tree.h @@ -31,7 +31,8 @@ namespace PLMD { /// \ingroup TOOLBOX -class Tree { +class Tree +{ private: GenericMolInfo* moldat_; diff --git a/src/tools/TypesafePtr.cpp b/src/tools/TypesafePtr.cpp index 2ec705fcf1..f019381ea8 100644 --- a/src/tools/TypesafePtr.cpp +++ b/src/tools/TypesafePtr.cpp @@ -33,13 +33,9 @@ TypesafePtr TypesafePtr::fromSafePtr(void* safe) { TypesafePtr TypesafePtr::copy() const { auto passbyvalue=((flags>>25)&0x7)==1; - if(passbyvalue) { - throw ExceptionTypeError()<<"PLUMED is trying to copy the pointer of an object passed by value"; - } + if(passbyvalue) throw ExceptionTypeError()<<"PLUMED is trying to copy the pointer of an object passed by value"; auto forbidstore=flags&0x10000000; - if(forbidstore) { - throw ExceptionTypeError()<<"PLUMED is trying to copy the pointer of an object for which this was forbidden"; - } + if(forbidstore) throw ExceptionTypeError()<<"PLUMED is trying to copy the pointer of an object for which this was forbidden"; TypesafePtr ret; ret.ptr=ptr; ret.flags=flags; diff --git a/src/tools/TypesafePtr.h b/src/tools/TypesafePtr.h index ab6d43ada2..008482d4bd 100644 --- a/src/tools/TypesafePtr.h +++ b/src/tools/TypesafePtr.h @@ -73,16 +73,12 @@ class TypesafePtr { unsigned i=0; for(i=0; ishape.size(); i++) { this->shape[i]=*shape; - if(*shape==0) { - break; - } + if(*shape==0) break; nelem_*=*shape; shape++; } plumed_assert(ishape.size()); // check that last element is actually zero - if(nelem==0) { - nelem=nelem_; - } + if(nelem==0) nelem=nelem_; plumed_assert(nelem==nelem_) << "Inconsistent shape/nelem"; } } @@ -94,7 +90,8 @@ class TypesafePtr { TypesafePtr(void* ptr, std::size_t nelem, const std::size_t* shape, std::size_t flags): ptr(ptr), nelem(nelem), - flags(flags) { + flags(flags) + { buffer[0]='\0'; init_shape(shape); } @@ -116,7 +113,8 @@ class TypesafePtr { buffer[0]='\0'; } - TypesafePtr(std::nullptr_t) { + TypesafePtr(std::nullptr_t) + { shape[0]=0; buffer[0]='\0'; } @@ -197,7 +195,8 @@ class TypesafePtr { ptr(other.ptr==&other.buffer[0] ? &buffer[0] : other.ptr), nelem(other.nelem), shape(other.shape), - flags(other.flags) { + flags(other.flags) + { other.ptr=nullptr; } @@ -215,24 +214,12 @@ class TypesafePtr { std::string type_str() const { auto type=(flags>>16)&0xff; - if(type==0) { - return "wildcard"; - } - if(type==1) { - return "void"; - } - if(type==2) { - return "integral"; - } - if(type==3) { - return "integral"; - } - if(type==4) { - return "floating point"; - } - if(type==5) { - return "FILE"; - } + if(type==0) return "wildcard"; + if(type==1) return "void"; + if(type==2) return "integral"; + if(type==3) return "integral"; + if(type==4) return "floating point"; + if(type==5) return "FILE"; return "unknown"; } @@ -241,13 +228,9 @@ class TypesafePtr { template T* get_priv(std::size_t nelem, const std::size_t* shape, bool byvalue) const { - if(typesafePtrSkipCheck()) { - return (T*) ptr; - } + if(typesafePtrSkipCheck()) return (T*) ptr; typedef typename std::remove_pointer::type T_noptr; - if(flags==0) { - return (T*) ptr; // no check - } + if(flags==0) return (T*) ptr; // no check auto size=flags&0xffff; auto type=(flags>>16)&0xff; // auto unsi=(flags>>24)&0x1; // ignored @@ -271,8 +254,7 @@ class TypesafePtr { throw ExceptionTypeError() << "This command expects a type with size " << typesafePtrSizeof() << ". Received type has size " << size << " instead"<::value) { - if(cons==1) { - throw ExceptionTypeError() << "This command expects a pointer-to-pointer. It received a value intead"<::value) { - if(cons!=4) { - throw ExceptionTypeError() << "This command expects a modifiable pointer-to-pointer (T**)"<::value) { - if(cons!=4 && cons!=5) { - throw ExceptionTypeError() << "This command expects T*const* pointer, and can only receive T** or T*const* pointers"<shape[i]==0) { throw ExceptionTypeError() << "Incorrect number of axis (requested greater than passed)"<this->shape[i])) { throw ExceptionTypeError() << "This command wants " << shape[i] << " elements on axis " << i <<" of this pointer, but " << this->shape[i] << " have been passed"<0) { nelem=1; for(unsigned i=0; ishape.size(); i++) { - if(shape[i]==0) { - break; - } + if(shape[i]==0) break; nelem*=shape[i]; } } // check number of elements - if(nelem>0 && this->nelem>0) - if(!(nelem<=this->nelem)) { + if(nelem>0 && this->nelem>0) if(!(nelem<=this->nelem)) { throw ExceptionTypeError() << "This command wants to access " << nelem << " from this pointer, but only " << this->nelem << " have been passed"<::auxiliaryConstructor() template template -void VectorGeneric::auxiliaryConstructor(double first,Args... arg) { +void VectorGeneric::auxiliaryConstructor(double first,Args... arg) +{ d[n-(sizeof...(Args))-1]=first; auxiliaryConstructor(arg...); } template template -VectorGeneric::VectorGeneric(double first,Args... arg) { +VectorGeneric::VectorGeneric(double first,Args... arg) +{ static_assert((sizeof...(Args))+1==n,"you are trying to initialize a Vector with the wrong number of arguments"); auxiliaryConstructor(first,arg...); } @@ -306,9 +308,7 @@ double modulo(const VectorGeneric&v) { template std::ostream & operator<<(std::ostream &os, const VectorGeneric& v) { - for(unsigned i=0; i= digits_size) { @@ -174,9 +159,7 @@ decode_pure( value += dv; } } - if (have_minus) { - value = -value; - } + if (have_minus) value = -value; *result = value; return 0; } @@ -200,7 +183,8 @@ decode_pure( if (errmsg) throw std::runtime_error(errmsg); */ const char* -hy36encode(unsigned width, int value, char* result) { +hy36encode(unsigned width, int value, char* result) +{ int i = value; if (width == 4U) { if (i >= -999) { @@ -221,7 +205,8 @@ hy36encode(unsigned width, int value, char* result) { return 0; } } - } else if (width == 5U) { + } + else if (width == 5U) { if (i >= -9999) { if (i < 100000) { encode_pure(digits_upper(), 10U, 5U, i, result); @@ -240,7 +225,8 @@ hy36encode(unsigned width, int value, char* result) { return 0; } } - } else { + } + else { fill_with_stars(width, result); return unsupported_width(); } @@ -271,7 +257,8 @@ hy36encode(unsigned width, int value, char* result) { if (errmsg) throw std::runtime_error(errmsg); */ const char* -hy36decode(unsigned width, const char* s, unsigned s_size, int* result) { +hy36decode(unsigned width, const char* s, unsigned s_size, int* result) +{ static const std::vector digits_values_upper_vector([]() { std::vector ret(128U,-1); for(unsigned i=0; i<36U; i++) { @@ -282,8 +269,7 @@ hy36decode(unsigned width, const char* s, unsigned s_size, int* result) { ret[di] = i; } return ret; - } - ()); + }()); static const int* digits_values_upper=digits_values_upper_vector.data(); static const std::vector digits_values_lower_vector([]() { std::vector ret(128U,-1); @@ -295,8 +281,7 @@ hy36decode(unsigned width, const char* s, unsigned s_size, int* result) { ret[di] = i; } return ret; - } - ()); + }()); static const int* digits_values_lower=digits_values_lower_vector.data(); int di; const char* errmsg; @@ -307,35 +292,31 @@ hy36decode(unsigned width, const char* s, unsigned s_size, int* result) { errmsg = decode_pure(digits_values_upper, 36U, s, s_size, result); if (errmsg == 0) { /* result - 10*36**(width-1) + 10**width */ - if (width == 4U) { - (*result) -= 456560; - } else if (width == 5U) { - (*result) -= 16696160; - } else { + if (width == 4U) (*result) -= 456560; + else if (width == 5U) (*result) -= 16696160; + else { *result = 0; return unsupported_width(); } return 0; } - } else if (digits_values_lower[di] >= 10) { + } + else if (digits_values_lower[di] >= 10) { errmsg = decode_pure(digits_values_lower, 36U, s, s_size, result); if (errmsg == 0) { /* result + 16*36**(width-1) + 10**width */ - if (width == 4U) { - (*result) += 756496; - } else if (width == 5U) { - (*result) += 26973856; - } else { + if (width == 4U) (*result) += 756496; + else if (width == 5U) (*result) += 26973856; + else { *result = 0; return unsupported_width(); } return 0; } - } else { + } + else { errmsg = decode_pure(digits_values_upper, 10U, s, s_size, result); - if (errmsg) { - return errmsg; - } + if (errmsg) return errmsg; if (!(width == 4U || width == 5U)) { *result = 0; return unsupported_width(); diff --git a/src/vatom/Center.cpp b/src/vatom/Center.cpp index e27f0aa527..461f92eb66 100644 --- a/src/vatom/Center.cpp +++ b/src/vatom/Center.cpp @@ -117,7 +117,8 @@ PRINT ARG=d1 class Center: - public ActionWithVirtualAtom { + public ActionWithVirtualAtom +{ std::vector weights; std::vector dcenter_sin; std::vector dcenter_cos; @@ -158,60 +159,41 @@ Center::Center(const ActionOptions&ao): weight_mass(false), nopbc(false), first(true), - phases(false) { + phases(false) +{ std::vector atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()==0) { - error("at least one atom should be specified"); - } + if(atoms.size()==0) error("at least one atom should be specified"); parseVector("WEIGHTS",weights); parseFlag("MASS",weight_mass); parseFlag("NOPBC",nopbc); parseFlag("PHASES",phases); parse("SET_CHARGE",charge_); - if(!std::isnan(charge_)) { - isChargeSet_=true; - } + if(!std::isnan(charge_)) isChargeSet_=true; parse("SET_MASS",mass_); - if(mass_>0.) { - isMassSet_=true; - } - if(mass_==0.) { - error("SETMASS must be greater than 0"); - } - if( getName()=="COM") { - weight_mass=true; - } + if(mass_>0.) isMassSet_=true; + if(mass_==0.) error("SETMASS must be greater than 0"); + if( getName()=="COM") weight_mass=true; checkRead(); log.printf(" of atoms:"); for(unsigned i=0; i deriv(getNumberOfAtoms()); - for(unsigned i=0; i atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()!=0) { - error("ATOMS should be empty"); - } + if(atoms.size()!=0) error("ATOMS should be empty"); parseFlag("SCALED_COMPONENTS",scaled_components); std::vector at; parseVector("AT",at); - if(at.size()!=3) { - error("AT should be a list of three real numbers"); - } + if(at.size()!=3) error("AT should be a list of three real numbers"); parse("SET_MASS",mass); parse("SET_CHARGE",charge); @@ -129,9 +127,7 @@ FixedAtom::FixedAtom(const ActionOptions&ao): checkRead(); log<<" AT position "< coord; public: explicit Ghost(const ActionOptions&ao); @@ -67,23 +68,18 @@ void Ghost::registerKeywords(Keywords& keys) { Ghost::Ghost(const ActionOptions&ao): Action(ao), - ActionWithVirtualAtom(ao) { + ActionWithVirtualAtom(ao) +{ std::vector atoms; parseAtomList("ATOMS",atoms); - if(atoms.size()!=3) { - error("ATOMS should contain a list of three atoms"); - } + if(atoms.size()!=3) error("ATOMS should contain a list of three atoms"); parseVector("COORDINATES",coord); - if(coord.size()!=3) { - error("COORDINATES should be a list of three real numbers"); - } + if(coord.size()!=3) error("COORDINATES should be a list of three real numbers"); checkRead(); log.printf(" of atoms"); - for(unsigned i=0; i basisf_labels; - parseVector("BASIS_FUNCTIONS",basisf_labels); - addKeywordToList("BASIS_FUNCTIONS",basisf_labels); + parseVector("BASIS_FUNCTIONS",basisf_labels); addKeywordToList("BASIS_FUNCTIONS",basisf_labels); if(basisf_labels.size()==1) { plumed_merror("using only one basis function in BF_COMBINED does not make sense"); } std::string error_msg = ""; basisf_pntrs_ = VesTools::getPointersFromLabels(basisf_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword BASIS_FUNCTIONS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword BASIS_FUNCTIONS of "+getName()+": "+error_msg);} unsigned int nbasisf_total_ = 1; bool periodic = true; @@ -110,19 +108,14 @@ BF_Combined::BF_Combined(const ActionOptions&ao): if(basisf_pntrs_[i]->intervalMinStr()!=basisf_pntrs_[0]->intervalMinStr() || basisf_pntrs_[i]->intervalMaxStr()!=basisf_pntrs_[0]->intervalMaxStr()) { plumed_merror("all the basis functions to be combined should have same MINIMUM and MAXIMUM"); } - if(!basisf_pntrs_[i]->arePeriodic()) { - periodic=false; - } + if(!basisf_pntrs_[i]->arePeriodic()) {periodic=false;} } setOrder(nbasisf_total_-1); setNumberOfBasisFunctions(nbasisf_total_); setInterval(basisf_pntrs_[0]->intervalMinStr(),basisf_pntrs_[0]->intervalMaxStr()); setIntrinsicInterval("-1.0","+1.0"); - if(periodic) { - setPeriodic(); - } else { - setNonPeriodic(); - } + if(periodic) {setPeriodic();} + else {setNonPeriodic();} setIntervalBounded(); setType("combined"); setDescription("Combined"); @@ -169,8 +162,7 @@ void BF_Combined::getAllValues(const double arg, double& argT, bool& inside_rang for(unsigned int i=1; inumberOfBasisFunctions(),0.0); derivs_tmp.assign(basisf_pntrs_[i]->numberOfBasisFunctions(),0.0); - double dummy_dbl; - bool dummy_bool=true; + double dummy_dbl; bool dummy_bool=true; basisf_pntrs_[i]->getAllValues(arg,dummy_dbl,dummy_bool,values_tmp,derivs_tmp); for(unsigned int l=1; lnumberOfBasisFunctions(); l++) { values[r] = values_tmp[l]; diff --git a/src/ves/BF_Cosine.cpp b/src/ves/BF_Cosine.cpp index c9b069a3d1..f7e15b547d 100644 --- a/src/ves/BF_Cosine.cpp +++ b/src/ves/BF_Cosine.cpp @@ -100,7 +100,8 @@ void BF_Cosine::registerKeywords(Keywords& keys) { BF_Cosine::BF_Cosine(const ActionOptions&ao): - PLUMED_VES_BASISFUNCTIONS_INIT(ao) { + PLUMED_VES_BASISFUNCTIONS_INIT(ao) +{ setNumberOfBasisFunctions(getOrder()+1); setIntrinsicInterval("-pi","+pi"); setPeriodic(); @@ -127,9 +128,7 @@ void BF_Cosine::getAllValues(const double arg, double& argT, bool& inside_range, derivs[i] = -io*sin_tmp*intervalDerivf(); } if(!inside_range) { - for(unsigned int i=0; i 2) { value=0.0; deriv=0.0; - } else if(x >= 1) { + } + else if(x >= 1) { value = ((2.0-x)*(2.0-x)*(2.0-x)); deriv = dx*(-3.0*(2.0-x)*(2.0-x)); // value=((2.0-x)*(2.0-x)*(2.0-x))/6.0; // deriv=-x*x*(2.0-x)*(2.0-x); - } else { + } + else { value = 4.0-6.0*x*x+3.0*x*x*x; deriv = dx*(-12.0*x+9.0*x*x); // value=x*x*x*0.5-x*x+2.0/3.0; diff --git a/src/ves/BF_Custom.cpp b/src/ves/BF_Custom.cpp index 87dd2a4962..627736c728 100644 --- a/src/ves/BF_Custom.cpp +++ b/src/ves/BF_Custom.cpp @@ -147,36 +147,28 @@ BF_Custom::BF_Custom(const ActionOptions&ao): variable_str_("x"), transf_variable_str_("t"), do_transf_(false), - check_nan_inf_(false) { + check_nan_inf_(false) +{ std::vector bf_str; std::string str_t1="1"; bf_str.push_back(str_t1); for(int i=1;; i++) { std::string str_t2; - if(!parseNumbered("FUNC",i,str_t2)) { - break; - } - std::string is; - Tools::convert(i,is); + if(!parseNumbered("FUNC",i,str_t2)) {break;} + std::string is; Tools::convert(i,is); addKeywordToList("FUNC"+is,str_t2); bf_str.push_back(str_t2); } // - if(bf_str.size()==1) { - plumed_merror(getName()+" with label "+getLabel()+": No FUNC keywords given"); - } + if(bf_str.size()==1) {plumed_merror(getName()+" with label "+getLabel()+": No FUNC keywords given");} setOrder(bf_str.size()-1); setNumberOfBasisFunctions(getOrder()+1); setIntrinsicInterval(intervalMin(),intervalMax()); bool periodic = false; - parseFlag("PERIODIC",periodic); - addKeywordToList("PERIODIC",periodic); - if(periodic) { - setPeriodic(); - } else { - setNonPeriodic(); - } + parseFlag("PERIODIC",periodic); addKeywordToList("PERIODIC",periodic); + if(periodic) {setPeriodic();} + else {setNonPeriodic();} setIntervalBounded(); setType("custom_functions"); setDescription("Custom Functions"); @@ -192,15 +184,14 @@ BF_Custom::BF_Custom(const ActionOptions&ao): bf_derivs_lepton_ref_.resize(getNumberOfBasisFunctions()); // for(unsigned int i=1; i(intrinsic_length)}; - } else { + } + else { plumed_massert(!periodic, "TAILS_THRESHOLD can't be used with the periodic wavelet variant"); addKeywordToList("TAILS_THRESHOLD",threshold); cutoffpoints = getCutoffPoints(threshold); @@ -309,12 +307,14 @@ BF_Wavelets::BF_Wavelets(const ActionOptions& ao): if (periodic) { // this is the same value as num_shifts above + constant num_BFs = static_cast(bias_length * scale_) + 1; - } else { + } + else { num_BFs = 1; // constant one // left shifts (w/o left cutoff) + right shifts - right cutoff - 1 num_BFs += static_cast(ceil(cutoffpoints[1] + (bias_length)*scale_ - cutoffpoints[0]) - 1); } - } else { + } + else { plumed_massert(num_BFs > 0, "The number of basis functions has to be positive (NUM_BF > 0)"); // check does not work if function length was given as intrinsic length, but can't check for keyword use directly plumed_massert(function_length==bias_length,"The keywords \"NUM_BF\" and \"FUNCTION_LENGTH\" cannot be used at the same time"); @@ -322,7 +322,8 @@ BF_Wavelets::BF_Wavelets(const ActionOptions& ao): if (periodic) { // inverted num_BFs calculation from where FUNCTION_LENGTH is specified scale_ = (num_BFs - 1) / bias_length ; - } else { + } + else { double cutoff_length = cutoffpoints[1] - cutoffpoints [0]; double intrinsic_bias_length = num_BFs - cutoff_length + 1; // length of bias in intrinsic scale of wavelets scale_ = intrinsic_bias_length / bias_length; @@ -363,19 +364,15 @@ void BF_Wavelets::getAllValues(const double arg, double& argT, bool& inside_rang } if (x < 0 || x >= intrinsicIntervalMax()) { // Wavelets are 0 outside the defined range - values[i] = 0.0; - derivs[i] = 0.0; - } else { + values[i] = 0.0; derivs[i] = 0.0; + } + else { std::vector temp_deriv (1); values[i] = GridLinearInterpolation::getGridValueAndDerivativesWithLinearInterpolation(waveletGrid_.get(), {x}, temp_deriv); derivs[i] = temp_deriv[0] * scale_; // scale derivative } } - if(!inside_range) { - for(auto& deriv : derivs) { - deriv=0.0; - } - } + if(!inside_range) {for(auto& deriv : derivs) {deriv=0.0;}} } @@ -411,8 +408,7 @@ void BF_Wavelets::setupLabels() { if (arePeriodic()) { pos = pos - floor((pos-intervalMin())/intervalRange())*intervalRange(); } - std::string is; - Tools::convert(pos, is); + std::string is; Tools::convert(pos, is); setLabel(i,"i="+is); } } diff --git a/src/ves/BasisFunctions.cpp b/src/ves/BasisFunctions.cpp index 51d7d4a0cb..4da5223078 100644 --- a/src/ves/BasisFunctions.cpp +++ b/src/ves/BasisFunctions.cpp @@ -73,22 +73,20 @@ BasisFunctions::BasisFunctions(const ActionOptions&ao): nbins_(1001), uniform_integrals_(nbasis_,0.0), vesbias_pntr_(NULL), - action_pntr_(NULL) { + action_pntr_(NULL) +{ bf_keywords_.push_back(getName()); if(keywords.exists("ORDER")) { - parse("ORDER",norder_); - addKeywordToList("ORDER",norder_); + parse("ORDER",norder_); addKeywordToList("ORDER",norder_); } nbasis_=norder_+1; // - std::string str_imin; - std::string str_imax; + std::string str_imin; std::string str_imax; if(keywords.exists("MINIMUM") && keywords.exists("MAXIMUM")) { - parse("MINIMUM",str_imin); - addKeywordToList("MINIMUM",str_imin); - parse("MAXIMUM",str_imax); - addKeywordToList("MAXIMUM",str_imax); - } else { + parse("MINIMUM",str_imin); addKeywordToList("MINIMUM",str_imin); + parse("MAXIMUM",str_imax); addKeywordToList("MAXIMUM",str_imax); + } + else { str_imin = "-1.0"; str_imax = "1.0"; } @@ -100,9 +98,7 @@ BasisFunctions::BasisFunctions(const ActionOptions&ao): if(!Tools::convertNoexcept(str_imax,interval_max_)) { plumed_merror(getName()+": cannot convert the value given in MAXIMUM to a double"); } - if(interval_min_>interval_max_) { - plumed_merror(getName()+": MINIMUM and MAXIMUM are not correctly defined"); - } + if(interval_min_>interval_max_) {plumed_merror(getName()+": MINIMUM and MAXIMUM are not correctly defined");} // parseFlag("DEBUG_INFO",print_debug_info_); if(keywords.exists("NUMERICAL_INTEGRALS")) { @@ -172,8 +168,7 @@ void BasisFunctions::setupInterval() { void BasisFunctions::setupLabels() { for(unsigned int i=0; i < nbasis_; i++) { - std::string is; - Tools::convert(i,is); + std::string is; Tools::convert(i,is); bf_labels_[i]=bf_label_prefix_+is+"(s)"; } } @@ -186,51 +181,32 @@ void BasisFunctions::setupUniformIntegrals() { void BasisFunctions::setupBF() { - if(interval_intrinsic_min_>interval_intrinsic_max_) { - plumed_merror("setupBF: default intervals are not correctly set"); - } + if(interval_intrinsic_min_>interval_intrinsic_max_) {plumed_merror("setupBF: default intervals are not correctly set");} setupInterval(); setupLabels(); - if(bf_labels_.size()==1) { - plumed_merror("setupBF: the labels of the basis functions are not correct."); - } - if(!numerical_uniform_integrals_) { - setupUniformIntegrals(); - } else { - numericalUniformIntegrals(); - } - if(uniform_integrals_.size()==1) { - plumed_merror("setupBF: the integrals of the basis functions is not correct."); - } - if(type_=="Undefined") { - plumed_merror("setupBF: the type of the basis function is not defined."); - } - if(description_=="Undefined") { - plumed_merror("setupBF: the description of the basis function is not defined."); - } + if(bf_labels_.size()==1) {plumed_merror("setupBF: the labels of the basis functions are not correct.");} + if(!numerical_uniform_integrals_) {setupUniformIntegrals();} + else {numericalUniformIntegrals();} + if(uniform_integrals_.size()==1) {plumed_merror("setupBF: the integrals of the basis functions is not correct.");} + if(type_=="Undefined") {plumed_merror("setupBF: the type of the basis function is not defined.");} + if(description_=="Undefined") {plumed_merror("setupBF: the description of the basis function is not defined.");} has_been_set=true; printInfo(); } void BasisFunctions::printInfo() const { - if(!has_been_set) { - plumed_merror("the basis set has not be setup correctly"); - } + if(!has_been_set) {plumed_merror("the basis set has not be setup correctly");} log.printf(" One-dimensional basis set\n"); log.printf(" Description: %s\n",description_.c_str()); log.printf(" Type: %s\n",type_.c_str()); - if(periodic_) { - log.printf(" The basis functions are periodic\n"); - } + if(periodic_) {log.printf(" The basis functions are periodic\n");} log.printf(" Order of basis set: %u\n",norder_); log.printf(" Number of basis functions: %u\n",nbasis_); // log.printf(" Interval of basis set: %f to %f\n",interval_min_,interval_max_); log.printf(" Interval of basis set: %s to %s\n",interval_min_str_.c_str(),interval_max_str_.c_str()); log.printf(" Description of basis functions:\n"); - for(unsigned int i=0; i < nbasis_; i++) { - log.printf(" %2u %10s\n",i,bf_labels_[i].c_str()); - } + for(unsigned int i=0; i < nbasis_; i++) {log.printf(" %2u %10s\n",i,bf_labels_[i].c_str());} // if(print_debug_info_) { log.printf(" Debug information:\n"); @@ -242,12 +218,8 @@ void BasisFunctions::printInfo() const { log.printf(" Defined interval of basis set: range=%f, mean=%f\n",interval_range_,interval_mean_); log.printf(" Derivative factor due to interval translation: %f\n",argT_derivf_); log.printf(" Integral of basis functions over the interval:\n"); - if(numerical_uniform_integrals_) { - log.printf(" Note: calculated numerically\n"); - } - for(unsigned int i=0; i < nbasis_; i++) { - log.printf(" %2u %16.10f\n",i,uniform_integrals_[i]); - } + if(numerical_uniform_integrals_) {log.printf(" Note: calculated numerically\n");} + for(unsigned int i=0; i < nbasis_; i++) {log.printf(" %2u %16.10f\n",i,uniform_integrals_[i]);} log.printf(" --------------------------\n"); } } @@ -265,19 +237,12 @@ void BasisFunctions::linkAction(Action* action_pntr_in) { void BasisFunctions::numericalUniformIntegrals() { - std::vector grid_min(1); - grid_min[0]=intervalMinStr(); - std::vector grid_max(1); - grid_max[0]=intervalMaxStr(); - std::vector grid_bins(1); - grid_bins[0]=nbins_; - std::vector> arguments(1); - arguments[0]= Tools::make_unique(nullptr,"arg",false); - if(arePeriodic()) { - arguments[0]->setDomain(intervalMinStr(),intervalMaxStr()); - } else { - arguments[0]->setNotPeriodic(); - } + std::vector grid_min(1); grid_min[0]=intervalMinStr(); + std::vector grid_max(1); grid_max[0]=intervalMaxStr(); + std::vector grid_bins(1); grid_bins[0]=nbins_; + std::vector> arguments(1); arguments[0]= Tools::make_unique(nullptr,"arg",false); + if(arePeriodic()) {arguments[0]->setDomain(intervalMinStr(),intervalMaxStr());} + else {arguments[0]->setNotPeriodic();} auto uniform_grid = Tools::make_unique("uniform",Tools::unique2raw(arguments),grid_min,grid_max,grid_bins,false,false); // double inverse_normalization = 1.0/(intervalMax()-intervalMin()); @@ -317,7 +282,8 @@ std::vector BasisFunctions::numericalTargetDistributionIntegralsFromGrid std::vector BasisFunctions::getTargetDistributionIntegrals(const TargetDistribution* targetdist_pntr) const { if(targetdist_pntr==NULL) { return getUniformIntegrals(); - } else { + } + else { Grid* targetdist_grid = targetdist_pntr->getTargetDistGridPntr(); return numericalTargetDistributionIntegralsFromGrid(targetdist_grid); } @@ -326,9 +292,7 @@ std::vector BasisFunctions::getTargetDistributionIntegrals(const TargetD std::string BasisFunctions::getKeywordString() const { std::string str_keywords=bf_keywords_[0]; - for(unsigned int i=1; i& args, std::vect void BasisFunctions::writeBasisFunctionsToFile(OFile& ofile_values, OFile& ofile_derivs, const std::string& min_in, const std::string& max_in, unsigned int nbins_in, const bool ignore_periodicity, const std::string& output_fmt_values, const std::string& output_fmt_derivs, const bool numerical_deriv) const { - std::vector min(1); - min[0]=min_in; - std::vector max(1); - max[0]=max_in; - std::vector nbins(1); - nbins[0]=nbins_in; + std::vector min(1); min[0]=min_in; + std::vector max(1); max[0]=max_in; + std::vector nbins(1); nbins[0]=nbins_in; std::vector> value_pntr(1); value_pntr[0]= Tools::make_unique(nullptr,"arg",false); - if(arePeriodic() && !ignore_periodicity) { - value_pntr[0]->setDomain(intervalMinStr(),intervalMaxStr()); - } else { - value_pntr[0]->setNotPeriodic(); - } + if(arePeriodic() && !ignore_periodicity) {value_pntr[0]->setDomain(intervalMinStr(),intervalMaxStr());} + else {value_pntr[0]->setNotPeriodic();} Grid args_grid = Grid("grid",Tools::unique2raw(value_pntr),min,max,nbins,false,false); std::vector args(args_grid.getSize(),0.0); @@ -418,7 +376,8 @@ void BasisFunctions::writeBasisFunctionsToFile(OFile& ofile_values, OFile& ofile if(arePeriodic()) { ofile_values.addConstantField("periodic").printField("periodic","true"); ofile_derivs.addConstantField("periodic").printField("periodic","true"); - } else { + } + else { ofile_values.addConstantField("periodic").printField("periodic","false"); ofile_derivs.addConstantField("periodic").printField("periodic","false"); } diff --git a/src/ves/BasisFunctions.h b/src/ves/BasisFunctions.h index 05231e3396..cb12994c45 100644 --- a/src/ves/BasisFunctions.h +++ b/src/ves/BasisFunctions.h @@ -47,7 +47,8 @@ class VesBias; class TargetDistribution; class BasisFunctions : - public Action { + public Action +{ private: // print extra info about the basis set bool print_debug_info_; @@ -102,9 +103,7 @@ class BasisFunctions : // setup various stuff void setupBF(); void setupInterval(); - void setNumericalIntegrationBins(const unsigned int nbins) { - nbins_=nbins; - } + void setNumericalIntegrationBins(const unsigned int nbins) {nbins_=nbins;} void numericalUniformIntegrals(); std::vector numericalTargetDistributionIntegralsFromGrid(const Grid*) const ; virtual void setupLabels(); @@ -115,46 +114,24 @@ class BasisFunctions : void addKeywordToList(const std::string&, const std::vector&); void addKeywordToList(const std::string&, const bool); // - void setPeriodic() { - periodic_=true; - } - void setNonPeriodic() { - periodic_=false; - } - void setIntervalBounded() { - interval_bounded_=true; - } - void setIntervalNonBounded() { - interval_bounded_=false; - } - void setType(const std::string& type_in) { - type_=type_in; - } - void setDescription(const std::string& description_in) { - description_=description_in; - } + void setPeriodic() {periodic_=true;} + void setNonPeriodic() {periodic_=false;} + void setIntervalBounded() {interval_bounded_=true;} + void setIntervalNonBounded() {interval_bounded_=false;} + void setType(const std::string& type_in) {type_=type_in;} + void setDescription(const std::string& description_in) {description_=description_in;} // void setNumberOfBasisFunctions(const unsigned int); - void setOrder(const unsigned int norder_in) { - norder_=norder_in; - } + void setOrder(const unsigned int norder_in) {norder_=norder_in;} void setIntrinsicInterval(const double, const double); void setIntrinsicInterval(const std::string&, const std::string&); void setInterval(const double, const double); void setInterval(const std::string&, const std::string&); // - double intrinsicIntervalMin() const { - return interval_intrinsic_min_; - } - double intrinsicIntervalMax() const { - return interval_intrinsic_max_; - } - std::string intrinsicIntervalMinStr() const { - return interval_intrinsic_min_str_; - } - std::string intrinsicIntervalMaxStr() const { - return interval_intrinsic_max_str_; - } + double intrinsicIntervalMin() const {return interval_intrinsic_min_;} + double intrinsicIntervalMax() const {return interval_intrinsic_max_;} + std::string intrinsicIntervalMinStr() const {return interval_intrinsic_min_str_;} + std::string intrinsicIntervalMaxStr() const {return interval_intrinsic_max_str_;} // void setUniformIntegral(const unsigned int, const double); void setUniformIntegrals(const std::vector&); @@ -167,70 +144,30 @@ class BasisFunctions : public: static void registerKeywords(Keywords&); explicit BasisFunctions(const ActionOptions&ao); - bool hasBeenSet() const { - return has_been_set; - } - std::string getType() const { - return type_; - } - std::string getDescription() const { - return description_; - } - unsigned int getOrder() const { - return norder_; - } - unsigned int getNumberOfBasisFunctions() const { - return nbasis_; - } - unsigned int numberOfBasisFunctions() const { - return nbasis_; - } - unsigned int getSize() const { - return nbasis_; - } - bool arePeriodic() const { - return periodic_; - } - bool intervalBounded() const { - return interval_bounded_; - } - double intervalMin() const { - return interval_min_; - } - double intervalMax() const { - return interval_max_; - } - double intervalRange() const { - return interval_range_; - } - double intervalMean() const { - return interval_mean_; - } - double intervalDerivf() const { - return argT_derivf_; - } - std::string intervalMinStr() const { - return interval_min_str_; - } - std::string intervalMaxStr() const { - return interval_max_str_; - } - std::vector getUniformIntegrals() const { - return uniform_integrals_; - } + bool hasBeenSet() const {return has_been_set;} + std::string getType() const {return type_;} + std::string getDescription() const {return description_;} + unsigned int getOrder() const {return norder_;} + unsigned int getNumberOfBasisFunctions() const {return nbasis_;} + unsigned int numberOfBasisFunctions() const {return nbasis_;} + unsigned int getSize() const {return nbasis_;} + bool arePeriodic() const {return periodic_;} + bool intervalBounded() const {return interval_bounded_;} + double intervalMin() const {return interval_min_;} + double intervalMax() const {return interval_max_;} + double intervalRange() const {return interval_range_;} + double intervalMean() const {return interval_mean_;} + double intervalDerivf() const {return argT_derivf_;} + std::string intervalMinStr() const {return interval_min_str_;} + std::string intervalMaxStr() const {return interval_max_str_;} + std::vector getUniformIntegrals() const {return uniform_integrals_;} std::vector getTargetDistributionIntegrals(const TargetDistribution*) const; // - std::vector getKeywordList() const { - return bf_keywords_; - } + std::vector getKeywordList() const {return bf_keywords_;} std::string getKeywordString() const; // - std::string getBasisFunctionLabel(const unsigned int index) const { - return bf_labels_[index]; - } - std::vector getBasisFunctionLabels() const { - return bf_labels_; - } + std::string getBasisFunctionLabel(const unsigned int index) const {return bf_labels_[index];} + std::vector getBasisFunctionLabels() const {return bf_labels_;} // void linkVesBias(VesBias*); void linkAction(Action*); @@ -320,7 +257,8 @@ double BasisFunctions::translateArgument(const double arg, bool& inside_interval if(argT < interval_intrinsic_min_) { inside_interval=false; argT=interval_intrinsic_min_; - } else if(argT > interval_intrinsic_max_) { + } + else if(argT > interval_intrinsic_max_) { inside_interval=false; argT=interval_intrinsic_max_; } @@ -335,7 +273,8 @@ double BasisFunctions::checkIfArgumentInsideInterval(const double arg, bool& ins if(arg < interval_min_) { inside_interval=false; argT=interval_min_; - } else if(arg > interval_max_) { + } + else if(arg > interval_max_) { inside_interval=false; argT=interval_max_; } @@ -368,9 +307,7 @@ void BasisFunctions::addKeywordToList(const std::string& keyword, const std::vec inline void BasisFunctions::addKeywordToList(const std::string& keyword, const bool value) { - if(value) { - bf_keywords_.push_back(keyword); - } + if(value) {bf_keywords_.push_back(keyword);} } diff --git a/src/ves/CoeffsBase.cpp b/src/ves/CoeffsBase.cpp index 0840cb6363..05e6ad05c1 100644 --- a/src/ves/CoeffsBase.cpp +++ b/src/ves/CoeffsBase.cpp @@ -66,7 +66,8 @@ CoeffsBase::CoeffsBase( field_shape_prefix_("shape_"), field_time_("time"), field_iteration_("iteration"), - output_fmt_("%30.16e") { + output_fmt_("%30.16e") +{ initializeIndices(indices_shape,dimension_labels); setAllCoeffsDescriptions(); } @@ -102,7 +103,8 @@ CoeffsBase::CoeffsBase( field_shape_prefix_("shape_"), field_time_("time"), field_iteration_("iteration"), - output_fmt_("%30.16e") { + output_fmt_("%30.16e") +{ plumed_massert(args_.size()==basisf_.size(),"CoeffsBase: number of arguments do not match number of basis functions"); std::vector dimension_labels(args_.size()); std::vector indices_shape(args_.size()); @@ -146,7 +148,8 @@ CoeffsBase::CoeffsBase( field_shape_prefix_("shape_"), field_time_("time"), field_iteration_("iteration"), - output_fmt_("%30.16e") { + output_fmt_("%30.16e") +{ plumed_massert(multicoeffs_args.size()==multicoeffs_basisf.size(),"Multi Coeffs: number of arguments vectors does not match number of basis functions vectors"); unsigned int num_args = multicoeffs_args[0].size(); unsigned int dim = num_args+1; @@ -213,7 +216,8 @@ void CoeffsBase::setupBasisFunctionsInfo() { } setCoeffDescription(i,desc); } - } else if(coeffs_type_==MultiCoeffs_LinearBasisSet) { + } + else if(coeffs_type_==MultiCoeffs_LinearBasisSet) { for(unsigned int i=0; i indices=getIndices(i); unsigned int mc_id = indices[ndimensions_-1]; @@ -294,9 +298,11 @@ std::string CoeffsBase::getTypeStr() const { std::string type_str=""; if(coeffs_type_==Generic) { type_str = "Generic"; - } else if(coeffs_type_==LinearBasisSet) { + } + else if(coeffs_type_==LinearBasisSet) { type_str = "LinearBasisSet"; - } else if(coeffs_type_==MultiCoeffs_LinearBasisSet) { + } + else if(coeffs_type_==MultiCoeffs_LinearBasisSet) { type_str = "MultiCoeffs_LinearBasisSet"; } return type_str; @@ -343,12 +349,10 @@ void CoeffsBase::setCoeffDescription(const std::vector& indices, c void CoeffsBase::setAllCoeffsDescriptions(const std::string& description_prefix) { for(size_t i=0; i indices=getIndices(i); - std::string is; - Tools::convert(indices[0],is); + std::string is; Tools::convert(indices[0],is); std::string desc=description_prefix+"("+is; for(unsigned int k=1; k shapeOfIndices() const { - return indices_shape_; - } - unsigned int shapeOfIndices(const unsigned int dim_index) const { - return indices_shape_[dim_index]; - } - size_t numberOfCoeffs() const { - return ncoeffs_; - } - unsigned int numberOfDimensions() const { - return ndimensions_; - } + std::vector shapeOfIndices() const {return indices_shape_;} + unsigned int shapeOfIndices(const unsigned int dim_index) const {return indices_shape_[dim_index];} + size_t numberOfCoeffs() const {return ncoeffs_;} + unsigned int numberOfDimensions() const {return ndimensions_;} // - bool isActive() const { - return active; - } - void activate() { - active=true; - } - void deactivate() { - active=false; - } + bool isActive() const {return active;} + void activate() {active=true;} + void deactivate() {active=false;} // size_t getIndex(const std::vector&) const; std::vector getIndices(const size_t) const; bool indicesExist(const std::vector&) const; // - std::string getCoeffDescription(const size_t index) const { - return coeffs_descriptions_[index]; - } + std::string getCoeffDescription(const size_t index) const {return coeffs_descriptions_[index];} std::string getCoeffDescription(const std::vector&) const; - std::vector getAllCoeffsDescriptions() const { - return coeffs_descriptions_; - } + std::vector getAllCoeffsDescriptions() const {return coeffs_descriptions_;} void setCoeffDescription(const size_t, const std::string&); void setCoeffDescription(const std::vector&, const std::string&); void setAllCoeffsDescriptions(const std::string& description_prefix="C"); void setAllCoeffsDescriptions(const std::vector&); // std::string getDimensionLabel(const unsigned int) const; - std::vector getAllDimensionLabels() const { - return dimension_labels_; - } + std::vector getAllDimensionLabels() const {return dimension_labels_;} void setDimensionLabel(const unsigned int, const std::string&); void setAllDimensionLabels(const std::string&); void setAllDimensionLabels(const std::vector&); @@ -196,34 +161,18 @@ class CoeffsBase { void getCoeffsInfoFromFile(IFile&, const bool ignore_coeffs_info=false); void checkCoeffsInfo(const std::string&, const std::string&, const unsigned int, const size_t, const std::vector&); // - void turnOnIterationCounter() { - iteration_and_time_active_=true; - } - void turnOffIterationCounter() { - iteration_and_time_active_=false; - } - bool isIterationCounterActive() const { - return iteration_and_time_active_; - } + void turnOnIterationCounter() {iteration_and_time_active_=true;} + void turnOffIterationCounter() {iteration_and_time_active_=false;} + bool isIterationCounterActive() const {return iteration_and_time_active_;} void setIterationCounter(const unsigned int); void setTime(const double); void setIterationCounterAndTime(const unsigned int, const double); - unsigned int getIterationCounter() const { - return iteration_opt; - } - double getTimeValue() const { - return time_md; - } + unsigned int getIterationCounter() const {return iteration_opt;} + double getTimeValue() const {return time_md;} // - void setOutputFmt(const std::string& ss) { - output_fmt_=ss; - } - void resetOutputFmt() { - output_fmt_="%30.16e"; - } - std::string getOutputFmt() const { - return output_fmt_; - } + void setOutputFmt(const std::string& ss) { output_fmt_=ss; } + void resetOutputFmt() {output_fmt_="%30.16e";} + std::string getOutputFmt() const {return output_fmt_;} // void replaceLabelString(const std::string&, const std::string&); protected: diff --git a/src/ves/CoeffsMatrix.cpp b/src/ves/CoeffsMatrix.cpp index a5048ed060..4531e94c94 100644 --- a/src/ves/CoeffsMatrix.cpp +++ b/src/ves/CoeffsMatrix.cpp @@ -57,7 +57,8 @@ CoeffsMatrix::CoeffsMatrix( diagonal_(diagonal), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ setupMatrix(); } @@ -77,7 +78,8 @@ CoeffsMatrix::CoeffsMatrix( diagonal_(diagonal), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ setupMatrix(); } @@ -98,7 +100,8 @@ CoeffsMatrix::CoeffsMatrix( diagonal_(diagonal), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ setupMatrix(); } @@ -116,7 +119,8 @@ CoeffsMatrix::CoeffsMatrix( diagonal_(diagonal), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ setLabels(label); setupMatrix(); } @@ -130,7 +134,8 @@ void CoeffsMatrix::setupMatrix() { ncolumns_=nrows_; if(diagonal_) { size_=nrows_; - } else { + } + else { size_=(nrows_*nrows_-nrows_)/2+nrows_; } clear(); @@ -199,9 +204,11 @@ size_t CoeffsMatrix::getMatrixIndex(const size_t index1, const size_t index2) co if(diagonal_) { // plumed_massert(index1==index2,"CoeffsMatrix: you trying to access a off-diagonal element of a diagonal coeffs matrix"); matrix_idx=index1; - } else if (index1<=index2) { + } + else if (index1<=index2) { matrix_idx=index2+index1*(nrows_-1)-index1*(index1-1)/2; - } else { + } + else { matrix_idx=index1+index2*(nrows_-1)-index2*(index2-1)/2; } return matrix_idx; @@ -272,7 +279,8 @@ CoeffsVector operator*(const CoeffsMatrix& coeffs_matrix, const CoeffsVector& co for(size_t i=0; i data; @@ -119,9 +120,7 @@ class CoeffsMatrix: void clear(); void setAllValuesToZero(); // - std::vector getDataAsVector() const { - return data; - } + std::vector getDataAsVector() const {return data;} // get value double getValue(const size_t, const size_t) const; double getValue(const std::vector&, const std::vector&) const; @@ -185,15 +184,9 @@ class CoeffsMatrix: // void randomizeValuesGaussian(int); // - void resetAveragingCounter() { - averaging_counter=0; - } - void setupExponentiallyDecayingAveraging(const unsigned int averaging_exp_decay_in) { - averaging_exp_decay_=averaging_exp_decay_in; - } - void turnOffExponentiallyDecayingAveraging() { - averaging_exp_decay_=0; - } + void resetAveragingCounter() {averaging_counter=0;} + void setupExponentiallyDecayingAveraging(const unsigned int averaging_exp_decay_in) {averaging_exp_decay_=averaging_exp_decay_in;} + void turnOffExponentiallyDecayingAveraging() { averaging_exp_decay_=0;} void resetAveraging(); void addToAverage(const CoeffsMatrix&); void addToAverage(const CoeffsMatrix&, const unsigned int); @@ -208,9 +201,7 @@ class CoeffsMatrix: void writeDataDiagonalToFile(OFile&); void writeDataFullToFile(OFile&); public: - Communicator& getCommunicator() const { - return mycomm; - } + Communicator& getCommunicator() const {return mycomm;} }; } diff --git a/src/ves/CoeffsVector.cpp b/src/ves/CoeffsVector.cpp index c3630611a1..62dde7ffa4 100644 --- a/src/ves/CoeffsVector.cpp +++ b/src/ves/CoeffsVector.cpp @@ -52,7 +52,8 @@ CoeffsVector::CoeffsVector( data(0), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ clear(); } @@ -67,7 +68,8 @@ CoeffsVector::CoeffsVector( data(0), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ clear(); } @@ -83,7 +85,8 @@ CoeffsVector::CoeffsVector( data(0), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ clear(); } @@ -96,7 +99,8 @@ CoeffsVector::CoeffsVector( data(0), averaging_counter(0), averaging_exp_decay_(0), - mycomm(cc) { + mycomm(cc) +{ clear(); } @@ -641,9 +645,7 @@ void CoeffsVector::normalizeCoeffs() { void CoeffsVector::randomizeValuesGaussian(int randomSeed) { Random rnd; - if (randomSeed<0) { - randomSeed = -randomSeed; - } + if (randomSeed<0) {randomSeed = -randomSeed;} rnd.setSeed(-randomSeed); for(size_t i=0; igetCommunicator()); } - if(append_file) { - file.enforceRestart(); + else { + file.link(coeffsvecSet[0]->getCommunicator()); } + if(append_file) { file.enforceRestart(); } file.open(filepath); writeToFile(file,coeffsvecSet,print_coeffs_descriptions); file.close(); @@ -785,11 +785,8 @@ void CoeffsVector::writeDataToFile(OFile& ofile, const std::vectorgetValue(i)); } - std::snprintf(s1.data(),s1.size(),int_fmt.c_str(),i); - ofile.printField(field_index,s1.data()); - if(print_coeffs_descriptions) { - ofile.printField(field_description," "+coeffs_descriptions[i]); - } + std::snprintf(s1.data(),s1.size(),int_fmt.c_str(),i); ofile.printField(field_index,s1.data()); + if(print_coeffs_descriptions) { ofile.printField(field_description," "+coeffs_descriptions[i]);} ofile.printField(); } ofile.fmtField(); @@ -804,9 +801,7 @@ size_t CoeffsVector::readFromFile(IFile& ifile, const bool ignore_missing_coeffs ifile.allowIgnoredFields(); size_t ncoeffs_read=0; while(ifile) { - if(!ignore_header) { - readHeaderFromFile(ifile); - } + if(!ignore_header) {readHeaderFromFile(ifile);} if(ifile) { ncoeffs_read=readDataFromFile(ifile,ignore_missing_coeffs); } @@ -819,12 +814,8 @@ size_t CoeffsVector::readOneSetFromFile(IFile& ifile, const bool ignore_header) ifile.allowIgnoredFields(); size_t ncoeffs_read=0; if(ifile) { - if(!ignore_header) { - readHeaderFromFile(ifile); - } - if(ifile) { - ncoeffs_read=readDataFromFile(ifile,false); - } + if(!ignore_header) {readHeaderFromFile(ifile);} + if(ifile) {ncoeffs_read=readDataFromFile(ifile,false);} } return ncoeffs_read; } @@ -876,14 +867,11 @@ size_t CoeffsVector::readDataFromFile(IFile& ifile, const bool ignore_missing_co data[getIndex(indices)] = coeff_tmp; ifile.scanField(field_index,idx_tmp); if(getIndex(indices)!=static_cast(idx_tmp)) { - std::string is1; - Tools::convert(idx_tmp,is1); + std::string is1; Tools::convert(idx_tmp,is1); std::string msg="ERROR: problem with indices at index " + is1 + " when reading coefficients from file"; plumed_merror(msg); } - if(ifile.FieldExist(field_description)) { - ifile.scanField(field_description,str_tmp); - } + if(ifile.FieldExist(field_description)) { ifile.scanField(field_description,str_tmp); } // ifile.scanField(); ncoeffs_read++; diff --git a/src/ves/CoeffsVector.h b/src/ves/CoeffsVector.h index 0462b80973..af77ad9816 100644 --- a/src/ves/CoeffsVector.h +++ b/src/ves/CoeffsVector.h @@ -45,7 +45,8 @@ class CoeffsMatrix; class CoeffsVector: - public CoeffsBase { + public CoeffsBase +{ public: private: std::vector data; @@ -86,16 +87,12 @@ class CoeffsVector: // ~CoeffsVector(); // - size_t getSize() const { - return numberOfCoeffs(); - } + size_t getSize() const {return numberOfCoeffs();} // clear coeffs void clear(); void setAllValuesToZero(); // - std::vector getDataAsVector() const { - return data; - } + std::vector getDataAsVector() const {return data;} // bool sameShape(CoeffsVector&) const; bool sameShape(CoeffsMatrix&) const; @@ -194,15 +191,9 @@ class CoeffsVector: // Random values void randomizeValuesGaussian(int); // - void resetAveragingCounter() { - averaging_counter=0; - } - void setupExponentiallyDecayingAveraging(const unsigned int averaging_exp_decay_in) { - averaging_exp_decay_=averaging_exp_decay_in; - } - void turnOffExponentiallyDecayingAveraging() { - averaging_exp_decay_=0; - } + void resetAveragingCounter() {averaging_counter=0;} + void setupExponentiallyDecayingAveraging(const unsigned int averaging_exp_decay_in) {averaging_exp_decay_=averaging_exp_decay_in;} + void turnOffExponentiallyDecayingAveraging() {averaging_exp_decay_=0;} void resetAveraging(); void addToAverage(const CoeffsVector&); // @@ -225,9 +216,7 @@ class CoeffsVector: void readHeaderFromFile(IFile&, const bool ignore_coeffs_info=false); size_t readDataFromFile(IFile&, const bool ignore_missing_coeffs=false); public: - Communicator& getCommunicator() const { - return mycomm; - } + Communicator& getCommunicator() const {return mycomm;} }; diff --git a/src/ves/FermiSwitchingFunction.cpp b/src/ves/FermiSwitchingFunction.cpp index 7c6d3a50e6..3e0f83061f 100644 --- a/src/ves/FermiSwitchingFunction.cpp +++ b/src/ves/FermiSwitchingFunction.cpp @@ -47,34 +47,24 @@ void FermiSwitchingFunction::set(const std::string& definition,std::string& erro } std::string name=data[0]; data.erase(data.begin()); - if(name!="FERMI") { - errormsg="only FERMI is supported"; - } + if(name!="FERMI") {errormsg="only FERMI is supported";} type=fermi; // bool found_r0=Tools::parse(data,"R_0",r0_); - if(!found_r0) { - errormsg="R_0 is required"; - } + if(!found_r0) {errormsg="R_0 is required";} // fermi_exp_max_=std::numeric_limits::max(); Tools::parse(data,"FERMI_EXP_MAX",fermi_exp_max_); // bool found_lambda=Tools::parse(data,"FERMI_LAMBDA",fermi_lambda_); - if(!found_lambda) { - errormsg="FERMI_LAMBDA is required for FERMI"; - } + if(!found_lambda) {errormsg="FERMI_LAMBDA is required for FERMI";} if( !data.empty() ) { errormsg="found the following rogue keywords in switching function input : "; - for(unsigned i=0; i0) { - init=false; - } + if(errormsg.size()>0) {init=false;} } std::string FermiSwitchingFunction::description() const { @@ -83,7 +73,8 @@ std::string FermiSwitchingFunction::description() const { if(type==fermi) { ostr<< "fermi switching function with parameter"; ostr<< " lambda="<= fermi_exp_max_) { - rdist = fermi_exp_max_; - } + if(rdist >= fermi_exp_max_) {rdist = fermi_exp_max_;} double result = 1.0/(1.0+exp(rdist)); dfunc=-fermi_lambda_*exp(rdist)*result*result; // this is because calculate() sets dfunc to the derivative divided times the distance. @@ -112,7 +101,8 @@ FermiSwitchingFunction::FermiSwitchingFunction(): r0_(0.0), invr0_(0.0), fermi_lambda_(1.0), - fermi_exp_max_(100.0) { + fermi_exp_max_(100.0) +{ } FermiSwitchingFunction::FermiSwitchingFunction(const FermiSwitchingFunction&sf): @@ -121,7 +111,8 @@ FermiSwitchingFunction::FermiSwitchingFunction(const FermiSwitchingFunction&sf): r0_(sf.r0_), invr0_(sf.invr0_), fermi_lambda_(sf.fermi_lambda_), - fermi_exp_max_(sf.fermi_exp_max_) { + fermi_exp_max_(sf.fermi_exp_max_) +{ } void FermiSwitchingFunction::set(const double r0, const double fermi_lambda, const double fermi_exp_max) { @@ -131,7 +122,8 @@ void FermiSwitchingFunction::set(const double r0, const double fermi_lambda, con fermi_lambda_=fermi_lambda; if(fermi_exp_max>0.0) { fermi_exp_max_=fermi_exp_max; - } else { + } + else { fermi_exp_max_=100.0; } diff --git a/src/ves/GridIntegrationWeights.cpp b/src/ves/GridIntegrationWeights.cpp index 21176de20d..dc2a832a3b 100644 --- a/src/ves/GridIntegrationWeights.cpp +++ b/src/ves/GridIntegrationWeights.cpp @@ -39,7 +39,8 @@ std::vector GridIntegrationWeights::getIntegrationWeights(const Grid* gr std::vector weights_tmp; if(weights_type=="trapezoidal") { weights_tmp = getOneDimensionalTrapezoidalWeights(nbins[k],dx[k],isPeriodic[k]); - } else { + } + else { plumed_merror("getIntegrationWeights: unknown weight type, the available type is trapezoidal"); } weights_perdim.push_back(weights_tmp); @@ -74,12 +75,11 @@ std::vector GridIntegrationWeights::getIntegrationWeights(const Grid* gr void GridIntegrationWeights::getOneDimensionalIntegrationPointsAndWeights(std::vector& points, std::vector& weights, const unsigned int nbins, const double min, const double max, const std::string& weights_type) { double dx = (max-min)/(static_cast(nbins)-1.0); points.resize(nbins); - for(unsigned int i=0; i GridIntegrationWeights::getOneDimensionalTrapezoidalWeights( if(!periodic) { weights_1d[0]= 0.5*dx; weights_1d[(nbins-1)]= 0.5*dx; - } else { + } + else { // as for periodic arguments the first point should be counted twice as the // grid doesn't include its periodic copy weights_1d[0]= dx; diff --git a/src/ves/GridLinearInterpolation.cpp b/src/ves/GridLinearInterpolation.cpp index f56223907e..2054a6db8d 100644 --- a/src/ves/GridLinearInterpolation.cpp +++ b/src/ves/GridLinearInterpolation.cpp @@ -38,12 +38,9 @@ double GridLinearInterpolation::getGridValueWithLinearInterpolation_1D(GridBase* double x = arg[0]; double grid_dx = grid_pntr->getDx()[0]; - double grid_min; - Tools::convert( grid_pntr->getMin()[0], grid_min); - std::vector i0(1); - i0[0] = unsigned( std::floor( (x-grid_min)/grid_dx ) ); - std::vector i1(1); - i1[0] = unsigned( std::ceil( (x-grid_min)/grid_dx ) ); + double grid_min; Tools::convert( grid_pntr->getMin()[0], grid_min); + std::vector i0(1); i0[0] = unsigned( std::floor( (x-grid_min)/grid_dx ) ); + std::vector i1(1); i1[0] = unsigned( std::ceil( (x-grid_min)/grid_dx ) ); // double x0 = grid_pntr->getPoint(i0)[0]; double x1 = grid_pntr->getPoint(i1)[0]; @@ -125,14 +122,11 @@ double GridLinearInterpolation::getGridValueAndDerivativesWithLinearInterpolatio double x = arg[0]; double grid_dx = grid_pntr->getDx()[0]; - double grid_min; - Tools::convert( grid_pntr->getMin()[0], grid_min); + double grid_min; Tools::convert( grid_pntr->getMin()[0], grid_min); double xtoindex = (x-grid_min)/grid_dx; - std::vector i0(1); - i0[0] = unsigned(std::floor(xtoindex)); - std::vector i1(1); - i1[0] = unsigned(std::ceil(xtoindex)); + std::vector i0(1); i0[0] = unsigned(std::floor(xtoindex)); + std::vector i1(1); i1[0] = unsigned(std::ceil(xtoindex)); // std::vector d0 (1), d1 (1); double x0 = grid_pntr->getPoint(i0)[0]; @@ -175,9 +169,11 @@ double GridLinearInterpolation::getGridValueWithLinearInterpolation(GridBase* gr unsigned int dim = grid_pntr->getDimension(); if(dim==1) { return getGridValueWithLinearInterpolation_1D(grid_pntr,arg); - } else if(dim==2) { + } + else if(dim==2) { return getGridValueWithLinearInterpolation_2D(grid_pntr,arg); - } else { + } + else { return getGridValueWithLinearInterpolation_ND(grid_pntr,arg); } } @@ -201,8 +197,7 @@ std::vector> GridLinearInterpolation::getAdjacentIndices(G std::vector temp_indices(2); // double grid_dx = grid_pntr->getDx()[i]; - double grid_min; - Tools::convert( grid_pntr->getMin()[i], grid_min); + double grid_min; Tools::convert( grid_pntr->getMin()[i], grid_min); double xtoindex = (arg[i]-grid_min)/grid_dx; temp_indices[0] = static_cast(std::floor(xtoindex)); temp_indices[1] = static_cast(std::ceil(xtoindex)); diff --git a/src/ves/GridLinearInterpolation.h b/src/ves/GridLinearInterpolation.h index e6e0f2bcf3..0b85ef7f10 100644 --- a/src/ves/GridLinearInterpolation.h +++ b/src/ves/GridLinearInterpolation.h @@ -55,7 +55,8 @@ double GridLinearInterpolation::linearInterpolation(const double x, const double // https://en.wikipedia.org/wiki/Linear_interpolation if(x1!=x0) { return y0 + (x-x0) * ((y1-y0)/(x1-x0)); - } else { + } + else { return y0; } } diff --git a/src/ves/GridProjWeights.h b/src/ves/GridProjWeights.h index a1ffbbd4f1..be9679ce64 100644 --- a/src/ves/GridProjWeights.h +++ b/src/ves/GridProjWeights.h @@ -32,27 +32,16 @@ namespace ves { class MarginalWeight:public WeightBase { public: explicit MarginalWeight() {} - double projectInnerLoop(double &input, double &v) { - return input+v; - } - double projectOuterLoop(double &v) { - return v; - } + double projectInnerLoop(double &input, double &v) {return input+v;} + double projectOuterLoop(double &v) {return v;} }; class FesWeight:public WeightBase { public: double beta,invbeta; - explicit FesWeight(double v) { - beta=v; - invbeta=1./beta; - } - double projectInnerLoop(double &input, double &v) { - return input+exp(-beta*v); - } - double projectOuterLoop(double &v) { - return -invbeta*std::log(v); - } + explicit FesWeight(double v) {beta=v; invbeta=1./beta;} + double projectInnerLoop(double &input, double &v) {return input+exp(-beta*v);} + double projectOuterLoop(double &v) {return -invbeta*std::log(v);} }; } diff --git a/src/ves/LinearBasisSetExpansion.cpp b/src/ves/LinearBasisSetExpansion.cpp index d0f5e5fceb..5a1446dd6e 100644 --- a/src/ves/LinearBasisSetExpansion.cpp +++ b/src/ves/LinearBasisSetExpansion.cpp @@ -73,11 +73,10 @@ LinearBasisSetExpansion::LinearBasisSetExpansion( step_of_last_fesgrid_update(-1000), log_targetdist_grid_pntr_(NULL), targetdist_grid_pntr_(NULL), - targetdist_pntr_(NULL) { + targetdist_pntr_(NULL) +{ plumed_massert(args_pntrs_.size()==basisf_pntrs_.size(),"number of arguments and basis functions do not match"); - for(unsigned int k=0; kgetNumberOfBasisFunctions(); - } + for(unsigned int k=0; kgetNumberOfBasisFunctions();} // if(bias_coeffs_pntr_==NULL) { bias_coeffs_pntr_ = new CoeffsVector(label_+".coeffs",args_pntrs_,basisf_pntrs_,mycomm_,true); @@ -90,7 +89,8 @@ LinearBasisSetExpansion::LinearBasisSetExpansion( std::string targetdist_averages_label = bias_coeffs_pntr_->getLabel(); if(targetdist_averages_label.find("coeffs")!=std::string::npos) { targetdist_averages_label.replace(targetdist_averages_label.find("coeffs"), std::string("coeffs").length(), "targetdist_averages"); - } else { + } + else { targetdist_averages_label += "_targetdist_averages"; } targetdist_averages_pntr_->setLabels(targetdist_averages_label); @@ -148,9 +148,7 @@ std::unique_ptr LinearBasisSetExpansion::setupGeneralGrid(const std::strin void LinearBasisSetExpansion::setupBiasGrid(const bool usederiv) { - if(bias_grid_pntr_) { - return; - } + if(bias_grid_pntr_) {return;} bias_grid_pntr_ = setupGeneralGrid("bias",usederiv); if(biasCutoffActive()) { bias_withoutcutoff_grid_pntr_ = setupGeneralGrid("bias_withoutcutoff",usederiv); @@ -159,9 +157,7 @@ void LinearBasisSetExpansion::setupBiasGrid(const bool usederiv) { void LinearBasisSetExpansion::setupFesGrid() { - if(fes_grid_pntr_) { - return; - } + if(fes_grid_pntr_) {return;} if(!bias_grid_pntr_) { setupBiasGrid(true); } @@ -193,7 +189,8 @@ void LinearBasisSetExpansion::updateBiasGrid() { // if(bias_grid_pntr_->hasDerivatives()) { bias_grid_pntr_->setValueAndDerivatives(l,bias,forces); - } else { + } + else { bias_grid_pntr_->setValue(l,bias); } // @@ -222,7 +219,8 @@ void LinearBasisSetExpansion::updateBiasWithoutCutoffGrid() { double bias=getBiasAndForces(args,all_inside,forces); if(bias_withoutcutoff_grid_pntr_->hasDerivatives()) { bias_withoutcutoff_grid_pntr_->setValueAndDerivatives(l,bias,forces); - } else { + } + else { bias_withoutcutoff_grid_pntr_->setValue(l,bias); } } @@ -250,7 +248,8 @@ void LinearBasisSetExpansion::updateBiasWithoutCutoffGrid() { if(bias_withoutcutoff_grid_pntr_->hasDerivatives()) { std::vector zeros(nargs_,0.0); bias_withoutcutoff_grid_pntr_->addValueAndDerivatives(l,shift,zeros); - } else { + } + else { bias_withoutcutoff_grid_pntr_->addValue(l,shift); } } @@ -288,27 +287,21 @@ void LinearBasisSetExpansion::updateFesGrid() { void LinearBasisSetExpansion::writeBiasGridToFile(OFile& ofile, const bool append_file) const { plumed_massert(bias_grid_pntr_,"the bias grid is not defined"); - if(append_file) { - ofile.enforceRestart(); - } + if(append_file) {ofile.enforceRestart();} bias_grid_pntr_->writeToFile(ofile); } void LinearBasisSetExpansion::writeBiasWithoutCutoffGridToFile(OFile& ofile, const bool append_file) const { plumed_massert(bias_withoutcutoff_grid_pntr_,"the bias without cutoff grid is not defined"); - if(append_file) { - ofile.enforceRestart(); - } + if(append_file) {ofile.enforceRestart();} bias_withoutcutoff_grid_pntr_->writeToFile(ofile); } void LinearBasisSetExpansion::writeFesGridToFile(OFile& ofile, const bool append_file) const { plumed_massert(fes_grid_pntr_!=NULL,"the FES grid is not defined"); - if(append_file) { - ofile.enforceRestart(); - } + if(append_file) {ofile.enforceRestart();} fes_grid_pntr_->writeToFile(ofile); } @@ -318,62 +311,44 @@ void LinearBasisSetExpansion::writeFesProjGridToFile(const std::vector(beta_); Grid proj_grid = fes_grid_pntr_->project(proj_arg,Fw.get()); proj_grid.setMinToZero(); - if(append_file) { - ofile.enforceRestart(); - } + if(append_file) {ofile.enforceRestart();} proj_grid.writeToFile(ofile); } void LinearBasisSetExpansion::writeTargetDistGridToFile(OFile& ofile, const bool append_file) const { - if(targetdist_grid_pntr_==NULL) { - return; - } - if(append_file) { - ofile.enforceRestart(); - } + if(targetdist_grid_pntr_==NULL) {return;} + if(append_file) {ofile.enforceRestart();} targetdist_grid_pntr_->writeToFile(ofile); } void LinearBasisSetExpansion::writeLogTargetDistGridToFile(OFile& ofile, const bool append_file) const { - if(log_targetdist_grid_pntr_==NULL) { - return; - } - if(append_file) { - ofile.enforceRestart(); - } + if(log_targetdist_grid_pntr_==NULL) {return;} + if(append_file) {ofile.enforceRestart();} log_targetdist_grid_pntr_->writeToFile(ofile); } void LinearBasisSetExpansion::writeTargetDistProjGridToFile(const std::vector& proj_arg, OFile& ofile, const bool append_file) const { - if(targetdist_grid_pntr_==NULL) { - return; - } - if(append_file) { - ofile.enforceRestart(); - } + if(targetdist_grid_pntr_==NULL) {return;} + if(append_file) {ofile.enforceRestart();} Grid proj_grid = TargetDistribution::getMarginalDistributionGrid(targetdist_grid_pntr_,proj_arg); proj_grid.writeToFile(ofile); } void LinearBasisSetExpansion::writeTargetDistributionToFile(const std::string& filename) const { - OFile of1; - OFile of2; + OFile of1; OFile of2; if(action_pntr_!=NULL) { - of1.link(*action_pntr_); - of2.link(*action_pntr_); + of1.link(*action_pntr_); of2.link(*action_pntr_); } - of1.enforceBackup(); - of2.enforceBackup(); + of1.enforceBackup(); of2.enforceBackup(); of1.open(filename); of2.open(FileBase::appendSuffix(filename,".log")); writeTargetDistGridToFile(of1); writeLogTargetDistGridToFile(of2); - of1.close(); - of2.close(); + of1.close(); of2.close(); } @@ -397,15 +372,14 @@ double LinearBasisSetExpansion::getBiasAndForces(const std::vector& args bool curr_inside=true; basisf_pntrs_in[k]->getAllValues(args_values[k],args_values_trsfrm[k],curr_inside,bf_values[k],bf_derivs[k]); // inside_interval[k]=curr_inside; - if(!curr_inside) { - all_inside=false; - } + if(!curr_inside) {all_inside=false;} forces[k]=0.0; } // size_t stride=1; size_t rank=0; - if(comm_in!=NULL) { + if(comm_in!=NULL) + { stride=comm_in->Get_size(); rank=comm_in->Get_rank(); } @@ -423,11 +397,8 @@ double LinearBasisSetExpansion::getBiasAndForces(const std::vector& args for(unsigned int k=0; k& args_ // size_t stride=1; size_t rank=0; - if(comm_in!=NULL) { + if(comm_in!=NULL) + { stride=comm_in->Get_size(); rank=comm_in->Get_rank(); } @@ -559,15 +531,9 @@ void LinearBasisSetExpansion::setupTargetDistribution(TargetDistribution* target void LinearBasisSetExpansion::updateTargetDistribution() { plumed_massert(targetdist_pntr_!=NULL,"the target distribution hasn't been setup!"); plumed_massert(targetdist_pntr_->isDynamic(),"this should only be used for dynamically updated target distributions!"); - if(targetdist_pntr_->biasGridNeeded()) { - updateBiasGrid(); - } - if(biasCutoffActive()) { - updateBiasWithoutCutoffGrid(); - } - if(targetdist_pntr_->fesGridNeeded()) { - updateFesGrid(); - } + if(targetdist_pntr_->biasGridNeeded()) {updateBiasGrid();} + if(biasCutoffActive()) {updateBiasWithoutCutoffGrid();} + if(targetdist_pntr_->fesGridNeeded()) {updateFesGrid();} targetdist_pntr_->updateTargetDist(); calculateTargetDistAveragesFromGrid(targetdist_grid_pntr_); } @@ -575,18 +541,14 @@ void LinearBasisSetExpansion::updateTargetDistribution() { void LinearBasisSetExpansion::readInRestartTargetDistribution(const std::string& grid_fname) { targetdist_pntr_->readInRestartTargetDistGrid(grid_fname); - if(biasCutoffActive()) { - targetdist_pntr_->clearLogTargetDistGrid(); - } + if(biasCutoffActive()) {targetdist_pntr_->clearLogTargetDistGrid();} } void LinearBasisSetExpansion::restartTargetDistribution() { plumed_massert(targetdist_pntr_!=NULL,"the target distribution hasn't been setup!"); plumed_massert(targetdist_pntr_->isDynamic(),"this should only be used for dynamically updated target distributions!"); - if(biasCutoffActive()) { - updateBiasWithoutCutoffGrid(); - } + if(biasCutoffActive()) {updateBiasWithoutCutoffGrid();} calculateTargetDistAveragesFromGrid(targetdist_grid_pntr_); } @@ -629,11 +591,8 @@ void LinearBasisSetExpansion::setBiasMaximumToZero() { bool LinearBasisSetExpansion::biasCutoffActive() const { - if(vesbias_pntr_!=NULL) { - return vesbias_pntr_->biasCutoffActive(); - } else { - return false; - } + if(vesbias_pntr_!=NULL) {return vesbias_pntr_->biasCutoffActive();} + else {return false;} } @@ -646,9 +605,7 @@ double LinearBasisSetExpansion::calculateReweightFactor() const { for(Grid::index_t l=0; lgetSize(); l++) { sum += integration_weights[l] * targetdist_grid_pntr_->getValue(l) * exp(+beta_*bias_grid_pntr_->getValue(l)); } - if(sum==0.0) { - sum=std::numeric_limits::min(); - } + if(sum==0.0) sum=std::numeric_limits::min(); return (1.0/beta_)*std::log(sum); } diff --git a/src/ves/LinearBasisSetExpansion.h b/src/ves/LinearBasisSetExpansion.h index ad8fc74e7b..d57fbae044 100644 --- a/src/ves/LinearBasisSetExpansion.h +++ b/src/ves/LinearBasisSetExpansion.h @@ -102,42 +102,20 @@ class LinearBasisSetExpansion { public: ~LinearBasisSetExpansion(); // - std::vector getPntrsToArguments() const { - return args_pntrs_; - } - std::vector getPntrsToBasisFunctions() const { - return basisf_pntrs_; - } - CoeffsVector* getPntrToBiasCoeffs() const { - return bias_coeffs_pntr_; - } - Grid* getPntrToBiasGrid() const { - return bias_grid_pntr_.get(); - }; - // - unsigned int getNumberOfArguments() const { - return nargs_; - }; - std::vector getNumberOfBasisFunctions() const { - return nbasisf_; - }; - size_t getNumberOfCoeffs() const { - return ncoeffs_; - }; - // - CoeffsVector& BiasCoeffs() const { - return *bias_coeffs_pntr_; - }; - CoeffsVector& TargetDistAverages() const { - return *targetdist_averages_pntr_; - }; - // - void setSerial() { - serial_=true; - } - void setParallel() { - serial_=false; - } + std::vector getPntrsToArguments() const {return args_pntrs_;} + std::vector getPntrsToBasisFunctions() const {return basisf_pntrs_;} + CoeffsVector* getPntrToBiasCoeffs() const {return bias_coeffs_pntr_;} + Grid* getPntrToBiasGrid() const {return bias_grid_pntr_.get();}; + // + unsigned int getNumberOfArguments() const {return nargs_;}; + std::vector getNumberOfBasisFunctions() const {return nbasisf_;}; + size_t getNumberOfCoeffs() const {return ncoeffs_;}; + // + CoeffsVector& BiasCoeffs() const {return *bias_coeffs_pntr_;}; + CoeffsVector& TargetDistAverages() const {return *targetdist_averages_pntr_;}; + // + void setSerial() {serial_=true;} + void setParallel() {serial_=false;} // void linkVesBias(VesBias*); void linkAction(Action*); @@ -156,27 +134,15 @@ class LinearBasisSetExpansion { // Bias grid and output stuff void setupBiasGrid(const bool usederiv=false); void updateBiasGrid(); - void resetStepOfLastBiasGridUpdate() { - step_of_last_biasgrid_update = -1000; - } - void setStepOfLastBiasGridUpdate(long long int step) { - step_of_last_biasgrid_update = step; - } - long long int getStepOfLastBiasGridUpdate() const { - return step_of_last_biasgrid_update; - } + void resetStepOfLastBiasGridUpdate() {step_of_last_biasgrid_update = -1000;} + void setStepOfLastBiasGridUpdate(long long int step) {step_of_last_biasgrid_update = step;} + long long int getStepOfLastBiasGridUpdate() const {return step_of_last_biasgrid_update;} void writeBiasGridToFile(OFile&, const bool append=false) const; // void updateBiasWithoutCutoffGrid(); - void resetStepOfLastBiasWithoutCutoffGridUpdate() { - step_of_last_biaswithoutcutoffgrid_update = -1000; - } - void setStepOfLastBiasWithoutCutoffGridUpdate(long long int step) { - step_of_last_biaswithoutcutoffgrid_update = step; - } - long long int getStepOfLastBiasWithoutCutoffGridUpdate() const { - return step_of_last_biaswithoutcutoffgrid_update; - } + void resetStepOfLastBiasWithoutCutoffGridUpdate() {step_of_last_biaswithoutcutoffgrid_update = -1000;} + void setStepOfLastBiasWithoutCutoffGridUpdate(long long int step) {step_of_last_biaswithoutcutoffgrid_update = step;} + long long int getStepOfLastBiasWithoutCutoffGridUpdate() const {return step_of_last_biaswithoutcutoffgrid_update;} void writeBiasWithoutCutoffGridToFile(OFile&, const bool append=false) const; // void setBiasMinimumToZero(); @@ -184,15 +150,9 @@ class LinearBasisSetExpansion { // void setupFesGrid(); void updateFesGrid(); - void resetStepOfLastFesGridUpdate() { - step_of_last_fesgrid_update = -1000; - } - void setStepOfLastFesGridUpdate(long long int step) { - step_of_last_fesgrid_update = step; - } - long long int getStepOfLastFesGridUpdate() const { - return step_of_last_fesgrid_update; - } + void resetStepOfLastFesGridUpdate() {step_of_last_fesgrid_update = -1000;} + void setStepOfLastFesGridUpdate(long long int step) {step_of_last_fesgrid_update = step;} + long long int getStepOfLastFesGridUpdate() const {return step_of_last_fesgrid_update;} void writeFesGridToFile(OFile&, const bool append=false) const; // void setupFesProjGrid(); @@ -203,24 +163,14 @@ class LinearBasisSetExpansion { void writeTargetDistProjGridToFile(const std::vector&, OFile&, const bool append=false) const; void writeTargetDistributionToFile(const std::string&) const; // - std::vector getGridBins() const { - return grid_bins_; - } + std::vector getGridBins() const {return grid_bins_;} void setGridBins(const std::vector&); void setGridBins(const unsigned int); // - double getBeta() const { - return beta_; - } - double getKbT() const { - return kbt_; - } - double beta() const { - return beta_; - } - double kBT() const { - return kbt_; - } + double getBeta() const {return beta_;} + double getKbT() const {return kbt_;} + double beta() const {return beta_;} + double kBT() const {return kbt_;} // void setupUniformTargetDistribution(); void setupTargetDistribution(TargetDistribution*); @@ -262,7 +212,8 @@ double LinearBasisSetExpansion::getBias(const std::vector& args_values, std::vector coeffsderivs_values_dummy(ncoeffs_); if(parallel) { return getBiasAndForces(args_values,all_inside,forces_dummy,coeffsderivs_values_dummy,basisf_pntrs_, bias_coeffs_pntr_, &mycomm_); - } else { + } + else { return getBiasAndForces(args_values,all_inside,forces_dummy,coeffsderivs_values_dummy,basisf_pntrs_, bias_coeffs_pntr_, NULL); } } @@ -272,7 +223,8 @@ inline void LinearBasisSetExpansion::getBasisSetValues(const std::vector& args_values, std::vector& basisset_values, const bool parallel) { if(parallel) { getBasisSetValues(args_values,basisset_values,basisf_pntrs_, bias_coeffs_pntr_, &mycomm_); - } else { + } + else { getBasisSetValues(args_values,basisset_values,basisf_pntrs_, bias_coeffs_pntr_, NULL); } } diff --git a/src/ves/MD_LinearExpansionPES.cpp b/src/ves/MD_LinearExpansionPES.cpp index f5e241e636..302ec631f7 100644 --- a/src/ves/MD_LinearExpansionPES.cpp +++ b/src/ves/MD_LinearExpansionPES.cpp @@ -134,9 +134,7 @@ PRINT ARG=p.x,p.y,ene FILE=colvar.data FMT=%8.4f class MD_LinearExpansionPES : public PLMD::CLTool { public: - std::string description() const override { - return "MD of a one particle on a linear expansion PES"; - } + std::string description() const override {return "MD of a one particle on a linear expansion PES";} static void registerKeywords( Keywords& keys ); explicit MD_LinearExpansionPES( const CLToolOptions& co ); int main( FILE* in, FILE* out, PLMD::Communicator& pc) override; @@ -179,7 +177,8 @@ void MD_LinearExpansionPES::registerKeywords( Keywords& keys ) { MD_LinearExpansionPES::MD_LinearExpansionPES( const CLToolOptions& co ): CLTool(co), dim(0), - dim_string_prefix("dim") { + dim_string_prefix("dim") +{ inputdata=ifile; //commandline; } @@ -245,9 +244,11 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { parseVector("temperature",temps_vec); if(temps_vec.size()==1) { temp = temps_vec[0]; - } else if(replicas > 1 && temps_vec.size()==replicas) { + } + else if(replicas > 1 && temps_vec.size()==replicas) { temp = temps_vec[inter.Get_rank()]; - } else { + } + else { error("problem with temperature keyword, you need to give either one value or a value for each replica."); } // @@ -256,9 +257,11 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { parseVector("friction",frictions_vec); if(frictions_vec.size()==1) { friction = frictions_vec[0]; - } else if(frictions_vec.size()==replicas) { + } + else if(frictions_vec.size()==replicas) { friction = frictions_vec[inter.Get_rank()]; - } else { + } + else { error("problem with friction keyword, you need to give either one value or a value for each replica."); } // @@ -266,24 +269,19 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { std::vector seeds_vec(0); parseVector("random_seed",seeds_vec); for(unsigned int i=0; i0) { - seeds_vec[i] = -seeds_vec[i]; - } + if(seeds_vec[i]>0) {seeds_vec[i] = -seeds_vec[i];} } if(replicas==1) { - if(seeds_vec.size()>1) { - error("problem with random_seed keyword, for a single replica you should only give one value"); - } + if(seeds_vec.size()>1) {error("problem with random_seed keyword, for a single replica you should only give one value");} seed = seeds_vec[0]; - } else { + } + else { if(seeds_vec.size()!=1 && seeds_vec.size()!=replicas) { error("problem with random_seed keyword, for multiple replicas you should give either one value or a separate value for each replica"); } if(seeds_vec.size()==1) { seeds_vec.resize(replicas); - for(unsigned int i=1; i interval_range(dim); for(unsigned int i=0; i 1 && input_coeffs_fnames.size()==replicas) { + } + else if(replicas > 1 && input_coeffs_fnames.size()==replicas) { diff_input_coeffs = true; input_coeffs_fname = input_coeffs_fnames[inter.Get_rank()]; - } else { + } + else { error("problem with coeffs_file keyword, you need to give either one value or a value for each replica."); } coeffs_pntr->readFromFile(input_coeffs_fname,true,true); @@ -393,10 +392,12 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { double coeffs_prefactor = 1.0; if(coeffs_prefactors.size()==1) { coeffs_prefactor = coeffs_prefactors[0]; - } else if(replicas > 1 && coeffs_prefactors.size()==replicas) { + } + else if(replicas > 1 && coeffs_prefactors.size()==replicas) { diff_input_coeffs = true; coeffs_prefactor = coeffs_prefactors[inter.Get_rank()]; - } else { + } + else { error("problem with coeffs_prefactor keyword, you need to give either one value or a value for each replica."); } coeffs_pntr->scaleAllValues(coeffs_prefactor); @@ -424,8 +425,7 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { ofile_potential.close(); if(dim>1) { for(unsigned int i=0; i proj_arg(1); proj_arg[0] = dim_string_prefix+is; auto Fw = Tools::make_unique(1/temp); @@ -488,33 +488,23 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { std::fprintf(out,"Number of steps %llu\n",nsteps); std::fprintf(out,"Timestep %f\n",tstep); std::fprintf(out,"Temperature %f",temps_vec[0]); - for(unsigned int i=1; icmd("setMPIComm",&pc.Get_comm()); - } + if(Communicator::initialized()) plumed->cmd("setMPIComm",&pc.Get_comm()); } } @@ -573,20 +561,16 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { // Setup random number generator random.setSeed(seed); - double potential, therm_eng=0; - std::vector masses(1,1); + double potential, therm_eng=0; std::vector masses(1,1); std::vector positions(1), velocities(1), forces(1); for(unsigned int k=0; kinterval_max[k]) { - positions[0][k]=interval_max[k]; - } - if(positions[0][k]interval_max[k]) {positions[0][k]=interval_max[k];} + if(positions[0][k]interval_max[k]) { positions[0][k]=interval_max[k]; velocities[0][k]=-std::abs(velocities[0][k]); @@ -662,9 +646,7 @@ int MD_LinearExpansionPES::main( FILE* in, FILE* out, PLMD::Communicator& pc) { plumed->cmd("setStopFlag",&plumedWantsToStop); plumed->cmd("calc"); //if(istep%2000==0) plumed->cmd("writeCheckPointFile"); - if(plumedWantsToStop) { - nsteps=istep; - } + if(plumedWantsToStop) nsteps=istep; } // Second step of velocity verlet diff --git a/src/ves/Opt_Adam.cpp b/src/ves/Opt_Adam.cpp index 07a1293c7b..636704e9fa 100644 --- a/src/ves/Opt_Adam.cpp +++ b/src/ves/Opt_Adam.cpp @@ -66,14 +66,10 @@ class Opt_Adam: public Optimizer { }; inline -CoeffsVector& Opt_Adam::VarCoeffs(const unsigned int coeffs_id) const { - return *var_coeffs_pntrs_[coeffs_id]; -} +CoeffsVector& Opt_Adam::VarCoeffs(const unsigned int coeffs_id) const {return *var_coeffs_pntrs_[coeffs_id];} inline -CoeffsVector& Opt_Adam::VarmaxCoeffs(const unsigned int coeffs_id) const { - return *varmax_coeffs_pntrs_[coeffs_id]; -} +CoeffsVector& Opt_Adam::VarmaxCoeffs(const unsigned int coeffs_id) const {return *varmax_coeffs_pntrs_[coeffs_id];} PLUMED_REGISTER_ACTION(Opt_Adam,"OPT_ADAM") @@ -102,7 +98,8 @@ Opt_Adam::Opt_Adam(const ActionOptions&ao): one_minus_weight_decay_(1.0), amsgrad_(false), adamw_(false), - var_coeffs_pntrs_(0) { + var_coeffs_pntrs_(0) +{ // add citation and print it to log log << " Adam type stochastic gradient decent\n"; parseFlag("AMSGRAD",amsgrad_); @@ -176,7 +173,8 @@ void Opt_Adam::coeffsUpdate(const unsigned int c_id) { for (size_t i = 0; i< VarCoeffs(c_id).getSize(); ++i) { var_coeffs_sqrt.push_back(1 / (sqrt(VarCoeffs(c_id).getValue(i)) + epsilon)); } - } else { // use VarmaxCoffs instead of VarCoeffs + } + else { // use VarmaxCoffs instead of VarCoeffs for (size_t i = 0; i< VarmaxCoeffs(c_id).getSize(); ++i) { var_coeffs_sqrt.push_back(1 / (sqrt(VarmaxCoeffs(c_id).getValue(i)) + epsilon)); } diff --git a/src/ves/Opt_BachAveragedSGD.cpp b/src/ves/Opt_BachAveragedSGD.cpp index d015d909f7..6813729417 100644 --- a/src/ves/Opt_BachAveragedSGD.cpp +++ b/src/ves/Opt_BachAveragedSGD.cpp @@ -187,9 +187,7 @@ class Opt_BachAveragedSGD : public Optimizer { std::vector> combinedgradientOFiles_; double decaying_aver_tau_; private: - CoeffsVector& CombinedGradient(const unsigned int c_id) const { - return *combinedgradient_pntrs_[c_id]; - } + CoeffsVector& CombinedGradient(const unsigned int c_id) const {return *combinedgradient_pntrs_[c_id];} double getAverDecay() const; public: static void registerKeywords(Keywords&); @@ -221,7 +219,8 @@ void Opt_BachAveragedSGD::registerKeywords(Keywords& keys) { Opt_BachAveragedSGD::Opt_BachAveragedSGD(const ActionOptions&ao): PLUMED_VES_OPTIMIZER_INIT(ao), combinedgradient_wstride_(100), - decaying_aver_tau_(0.0) { + decaying_aver_tau_(0.0) +{ log.printf(" Averaged stochastic gradient decent, see and cite "); log << plumed.cite("Bach and Moulines, NIPS 26, 773-781 (2013)"); log.printf("\n"); @@ -246,7 +245,8 @@ Opt_BachAveragedSGD::Opt_BachAveragedSGD(const ActionOptions&ao): std::string label = getGradientPntrs()[i]->getLabel(); if(label.find("gradient")!=std::string::npos) { label.replace(label.find("gradient"), std::string("gradient").length(), "combined_gradient"); - } else { + } + else { label += "_combined"; } combinedgradient_tmp->setLabels(label); @@ -258,7 +258,8 @@ Opt_BachAveragedSGD::Opt_BachAveragedSGD(const ActionOptions&ao): // if(numberOfCoeffsSets()==1) { log.printf(" Combined gradient (gradient + Hessian term) will be written out to file %s every %u iterations\n",combinedgradientOFiles_[0]->getPath().c_str(),combinedgradient_wstride_); - } else { + } + else { log.printf(" Combined gradient (gradient + Hessian term) will be written out to the following files every %u iterations:\n",combinedgradient_wstride_); for(unsigned int i=0; igetPath().c_str()); diff --git a/src/ves/Opt_Dummy.cpp b/src/ves/Opt_Dummy.cpp index cbbab223b8..58fa53cd91 100644 --- a/src/ves/Opt_Dummy.cpp +++ b/src/ves/Opt_Dummy.cpp @@ -96,7 +96,8 @@ void Opt_Dummy::registerKeywords(Keywords& keys) { Opt_Dummy::Opt_Dummy(const ActionOptions&ao): - PLUMED_VES_OPTIMIZER_INIT(ao) { + PLUMED_VES_OPTIMIZER_INIT(ao) +{ log.printf(" fake optimizer that does not update coefficients\n"); log.printf(" can be used to monitor gradient and Hessian for debugging purposes\n"); bool monitor_hessian = false; @@ -104,7 +105,8 @@ Opt_Dummy::Opt_Dummy(const ActionOptions&ao): if(monitor_hessian) { turnOnHessian(); log.printf(" the Hessian will also be monitored\n"); - } else { + } + else { turnOffHessian(); } turnOffCoeffsOutputFiles(); diff --git a/src/ves/Opt_RobbinsMonroSGD.cpp b/src/ves/Opt_RobbinsMonroSGD.cpp index 86589dace4..e045b4d91a 100644 --- a/src/ves/Opt_RobbinsMonroSGD.cpp +++ b/src/ves/Opt_RobbinsMonroSGD.cpp @@ -68,7 +68,8 @@ void Opt_RobbinsMonroSGD::registerKeywords(Keywords& keys) { Opt_RobbinsMonroSGD::Opt_RobbinsMonroSGD(const ActionOptions&ao): PLUMED_VES_OPTIMIZER_INIT(ao), - decay_constant_(1.0) { + decay_constant_(1.0) +{ parse("DECAY_CONSTANT",decay_constant_); if(decay_constant_<1.0) { plumed_merror("the value given in DECAY_CONSTANT doesn't make sense, it should be larger than 1.0"); diff --git a/src/ves/Optimizer.cpp b/src/ves/Optimizer.cpp index f0971d86c3..a62a6ba52f 100644 --- a/src/ves/Optimizer.cpp +++ b/src/ves/Optimizer.cpp @@ -82,7 +82,8 @@ Optimizer::Optimizer(const ActionOptions&ao): targetdist_output_stride_(0), targetdist_proj_output_active_(false), targetdist_proj_output_stride_(0), - isFirstStep(true) { + isFirstStep(true) +{ std::vector bias_labels(0); parseVector("BIAS",bias_labels); plumed_massert(bias_labels.size()>0,"problem with BIAS keyword"); @@ -90,9 +91,7 @@ Optimizer::Optimizer(const ActionOptions&ao): // std::string error_msg = ""; bias_pntrs_ = VesTools::getPointersFromLabels(bias_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword BIAS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword BIAS of "+getName()+": "+error_msg);} for(unsigned int i=0; ilinkOptimizer(this); @@ -117,7 +116,8 @@ Optimizer::Optimizer(const ActionOptions&ao): std::string aux_label = pntrs_coeffs[k]->getLabel(); if(aux_label.find("coeffs")!=std::string::npos) { aux_label.replace(aux_label.find("coeffs"), std::string("coeffs").length(), "aux_coeffs"); - } else { + } + else { aux_label += "_aux"; } aux_coeffs_tmp->setLabels(aux_label); @@ -158,13 +158,11 @@ Optimizer::Optimizer(const ActionOptions&ao): log.printf(" KbT: %f\n",bias_pntrs_[0]->getKbT()); log.printf(" number of coefficients: %zu\n",coeffs_pntrs_[0]->numberOfCoeffs()); if(stepsizes_.size()>0) { - if(fixed_stepsize_) { - log.printf(" using a constant step size of %f\n",stepsizes_[0]); - } else { - log.printf(" using an initial step size of %f\n",stepsizes_[0]); - } + if(fixed_stepsize_) {log.printf(" using a constant step size of %f\n",stepsizes_[0]);} + else {log.printf(" using an initial step size of %f\n",stepsizes_[0]);} } - } else { + } + else { log.printf(" optimizing %u coefficient sets from following %u VES biases:\n",ncoeffssets_,nbiases_); for(unsigned int i=0; igetLabel().c_str(),bias_pntrs_[i]->getName().c_str(),bias_pntrs_[i]->getKbT()); @@ -175,18 +173,16 @@ Optimizer::Optimizer(const ActionOptions&ao): log.printf(" used in bias %s (type %s)\n",coeffs_pntrs_[i]->getPntrToAction()->getLabel().c_str(),coeffs_pntrs_[i]->getPntrToAction()->getName().c_str()); log.printf(" number of coefficients: %zu\n",coeffs_pntrs_[i]->numberOfCoeffs()); if(stepsizes_.size()>0) { - if(fixed_stepsize_) { - log.printf(" using a constant step size of %f\n",stepsizes_[i]); - } else { - log.printf(" using an initial step size of %f\n",stepsizes_[i]); - } + if(fixed_stepsize_) {log.printf(" using a constant step size of %f\n",stepsizes_[i]);} + else {log.printf(" using an initial step size of %f\n",stepsizes_[i]);} } tot_ncoeffs += coeffs_pntrs_[i]->numberOfCoeffs(); } log.printf(" total number of coefficients: %zu\n",tot_ncoeffs); if(identical_coeffs_shape_) { log.printf(" the indices shape is identical for all coefficient sets\n"); - } else { + } + else { log.printf(" the indices shape differs between coefficient sets\n"); } } @@ -231,9 +227,7 @@ Optimizer::Optimizer(const ActionOptions&ao): bool need_stride = false; for(unsigned int i=0; idynamicTargetDistribution(); - if(dynamic_targetdists_[i]) { - need_stride = true; - } + if(dynamic_targetdists_[i]) {need_stride = true;} } parse("TARGETDIST_STRIDE",ustride_targetdist_); if(need_stride && ustride_targetdist_==0) { @@ -245,7 +239,8 @@ Optimizer::Optimizer(const ActionOptions&ao): if(ustride_targetdist_>0) { if(nbiases_==1) { log.printf(" the target distribution will be updated very %u coefficient iterations\n",ustride_targetdist_); - } else { + } + else { log.printf(" the target distribution will be updated very %u coefficient iterations for the following biases\n ",ustride_targetdist_); for(unsigned int i=0; igetLabel().c_str()); @@ -292,7 +287,8 @@ Optimizer::Optimizer(const ActionOptions&ao): std::string aver_grad_label = aver_gradient_tmp->getLabel(); if(aver_grad_label.find("gradient")!=std::string::npos) { aver_grad_label.replace(aver_grad_label.find("gradient"), std::string("gradient").length(), "aver_gradient"); - } else { + } + else { aver_grad_label += "_aver"; } aver_gradient_tmp->setLabels(aver_grad_label); @@ -310,7 +306,8 @@ Optimizer::Optimizer(const ActionOptions&ao): if(keywords.exists("COEFFS_SET_ID_PREFIX")) { parse("COEFFS_SET_ID_PREFIX",coeffssetid_prefix_); } - } else { + } + else { coeffssetid_prefix_=""; if(keywords.exists("COEFFS_SET_ID_PREFIX")) { parse("COEFFS_SET_ID_PREFIX",coeffssetid_prefix_); @@ -348,9 +345,7 @@ Optimizer::Optimizer(const ActionOptions&ao): for(unsigned int i=0; igetIterationCounter()); log.printf(" Optimization restarted at iteration %u\n",getIterationCounter()); } @@ -402,13 +398,15 @@ Optimizer::Optimizer(const ActionOptions&ao): if(coeffs_fnames.size()>0) { if(ncoeffssets_==1) { log.printf(" Coefficients will be written out to file %s every %u iterations\n",coeffsOFiles_[0]->getPath().c_str(),coeffs_wstride_); - } else { + } + else { log.printf(" Coefficients will be written out to the following files every %u iterations:\n",coeffs_wstride_); for(unsigned int i=0; igetPath().c_str()); } } - } else { + } + else { log.printf(" Output of coefficients to file has been disabled\n"); } } @@ -434,7 +432,8 @@ Optimizer::Optimizer(const ActionOptions&ao): if(gradient_fnames.size()>0) { if(ncoeffssets_==1) { log.printf(" Gradient will be written out to file %s every %u iterations\n",gradientOFiles_[0]->getPath().c_str(),gradient_wstride_); - } else { + } + else { log.printf(" Gradient will be written out to the following files every %u iterations:\n",gradient_wstride_); for(unsigned int i=0; igetPath().c_str()); @@ -464,7 +463,8 @@ Optimizer::Optimizer(const ActionOptions&ao): if(hessian_fnames.size()>0) { if(ncoeffssets_==1) { log.printf(" Hessian will be written out to file %s every %u iterations\n",hessianOFiles_[0]->getPath().c_str(),hessian_wstride_); - } else { + } + else { log.printf(" Hessian will be written out to the following files every %u iterations:\n",hessian_wstride_); for(unsigned int i=0; igetPath().c_str()); @@ -479,11 +479,8 @@ Optimizer::Optimizer(const ActionOptions&ao): std::vector mask_fnames_in; parseVector("MASK_FILE",mask_fnames_in); if(mask_fnames_in.size()==1 && ncoeffssets_>1) { - if(identical_coeffs_shape_) { - mask_fnames_in.resize(ncoeffssets_,mask_fnames_in[0]); - } else { - plumed_merror("the coefficients indices shape differs between biases so you need to give a separate file for each coefficient set\n"); - } + if(identical_coeffs_shape_) {mask_fnames_in.resize(ncoeffssets_,mask_fnames_in[0]);} + else {plumed_merror("the coefficients indices shape differs between biases so you need to give a separate file for each coefficient set\n");} } if(mask_fnames_in.size()>0 && mask_fnames_in.size()!=ncoeffssets_) { plumed_merror("Error in MASK_FILE keyword: either give one value for all biases or a separate value for each coefficient set"); @@ -503,7 +500,8 @@ Optimizer::Optimizer(const ActionOptions&ao): log.printf(" read %zu values from mask file %s\n",nread,mask_fnames_in[0].c_str()); size_t ndeactived = coeffs_mask_pntrs_[0]->countValues(0.0); log.printf(" deactived optimization of %zu coefficients\n",ndeactived); - } else { + } + else { for(unsigned int i=0; ireadFromFile(mask_fnames_in[i],true,true); log.printf(" mask for coefficient set %u:\n",i); @@ -526,13 +524,9 @@ Optimizer::Optimizer(const ActionOptions&ao): maskOFile.enforceBackup(); if(use_mwalkers_mpi_ && mwalkers_mpi_single_files_) { unsigned int r=0; - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) {r=multi_sim_comm.Get_rank();} comm.Bcast(r,0); - if(r>0) { - mask_fnames_out[i]="/dev/null"; - } + if(r>0) {mask_fnames_out[i]="/dev/null";} maskOFile.enforceSuffix(""); } maskOFile.open(mask_fnames_out[i]); @@ -589,7 +583,8 @@ Optimizer::Optimizer(const ActionOptions&ao): if(targetdist_averages_fnames.size()>0 && targetdist_averages_wstride_ > 0) { if(ncoeffssets_==1) { log.printf(" Target distribution averages will be written out to file %s every %u iterations\n",targetdist_averagesOFiles_[0]->getPath().c_str(),targetdist_averages_wstride_); - } else { + } + else { log.printf(" Target distribution averages will be written out to the following files every %u iterations:\n",targetdist_averages_wstride_); for(unsigned int i=0; igetPath().c_str()); @@ -608,7 +603,8 @@ Optimizer::Optimizer(const ActionOptions&ao): bias_pntrs_[i]->setupBiasFileOutput(); bias_pntrs_[i]->writeBiasToFile(); } - } else { + } + else { bias_output_active_=false; bias_output_stride_=1000; } @@ -623,7 +619,8 @@ Optimizer::Optimizer(const ActionOptions&ao): bias_pntrs_[i]->setupFesFileOutput(); bias_pntrs_[i]->writeFesToFile(); } - } else { + } + else { fes_output_active_=false; fes_output_stride_=1000; } @@ -638,7 +635,8 @@ Optimizer::Optimizer(const ActionOptions&ao): bias_pntrs_[i]->setupFesProjFileOutput(); bias_pntrs_[i]->writeFesProjToFile(); } - } else { + } + else { fesproj_output_active_=false; fesproj_output_stride_=1000; } @@ -674,7 +672,8 @@ Optimizer::Optimizer(const ActionOptions&ao): bias_pntrs_[i]->writeTargetDistToFile(); } } - } else { + } + else { targetdist_output_active_=false; targetdist_output_stride_=1000; } @@ -698,7 +697,8 @@ Optimizer::Optimizer(const ActionOptions&ao): bias_pntrs_[i]->writeTargetDistProjToFile(); } } - } else { + } + else { targetdist_proj_output_active_=false; targetdist_proj_output_stride_=1000; } @@ -708,52 +708,41 @@ Optimizer::Optimizer(const ActionOptions&ao): log.printf(" Output Components:\n"); log.printf(" "); if(monitor_instantaneous_gradient_) { - addComponent("gradrms"); - componentIsNotPeriodic("gradrms"); + addComponent("gradrms"); componentIsNotPeriodic("gradrms"); log.printf(" "); - addComponent("gradmax"); - componentIsNotPeriodic("gradmax"); + addComponent("gradmax"); componentIsNotPeriodic("gradmax"); } if(aver_gradient_pntrs_.size()>0) { log.printf(" "); - addComponent("avergradrms"); - componentIsNotPeriodic("avergradrms"); + addComponent("avergradrms"); componentIsNotPeriodic("avergradrms"); log.printf(" "); - addComponent("avergradmax"); - componentIsNotPeriodic("avergradmax"); + addComponent("avergradmax"); componentIsNotPeriodic("avergradmax"); } if(!fixed_stepsize_) { log.printf(" "); - addComponent("stepsize"); - componentIsNotPeriodic("stepsize"); + addComponent("stepsize"); componentIsNotPeriodic("stepsize"); getPntrToComponent("stepsize")->set( getCurrentStepSize(0) ); } - } else { + } + else { for(unsigned int i=0; i0) { log.printf(" "); - addComponent("avergradrms"+is); - componentIsNotPeriodic("avergradrms"+is); + addComponent("avergradrms"+is); componentIsNotPeriodic("avergradrms"+is); log.printf(" "); - addComponent("avergradmax"+is); - componentIsNotPeriodic("avergradmax"+is); + addComponent("avergradmax"+is); componentIsNotPeriodic("avergradmax"+is); } if(!fixed_stepsize_) { log.printf(" "); - addComponent("stepsize"+is); - componentIsNotPeriodic("stepsize"+is); + addComponent("stepsize"+is); componentIsNotPeriodic("stepsize"+is); getPntrToComponent("stepsize"+is)->set( getCurrentStepSize(i) ); } } @@ -937,7 +926,8 @@ void Optimizer::turnOnHessian() { plumed_massert(hessian_pntrs_.size()==ncoeffssets_,"problems in linking Hessians"); if(diagonal_hessian_) { log.printf(" Optimization performed using diagonal Hessian matrix\n"); - } else { + } + else { log.printf(" Optimization performed using full Hessian matrix\n"); } // @@ -1001,9 +991,8 @@ void Optimizer::update() { bias_pntrs_[i]->updateGradientAndHessian(use_mwalkers_mpi_); } for(unsigned int i=0; iisActive()) { - coeffsUpdate(i); - } else { + if(gradient_pntrs_[i]->isActive()) {coeffsUpdate(i);} + else { std::string msg = "iteration " + getIterationCounterStr(+1) + " for " + bias_pntrs_[i]->getLabel() + " - the coefficients are not updated as CV values are outside the bias intervals"; @@ -1060,7 +1049,8 @@ void Optimizer::update() { if(isTargetDistProjOutputActive() && getIterationCounter()%getTargetDistProjOutputStride()==0) { writeTargetDistProjOutputFiles(); } - } else { + } + else { isFirstStep=false; } } @@ -1081,11 +1071,10 @@ void Optimizer::updateOutputComponents() { size_t avergradient_maxabs_idx=0; getPntrToComponent("avergradmax")->set( aver_gradient_pntrs_[0]->getMaxAbsValue(avergradient_maxabs_idx) ); } - } else { + } + else { for(unsigned int i=0; iset( getCurrentStepSize(i) ); } @@ -1116,7 +1105,8 @@ void Optimizer::writeOutputFiles(const unsigned int coeffs_id) { if(gradientOFiles_.size()>0 && iter_counter%gradient_wstride_==0) { if(aver_gradient_pntrs_.size()==0) { gradient_pntrs_[coeffs_id]->writeToFile(*gradientOFiles_[coeffs_id],false); - } else { + } + else { gradient_pntrs_[coeffs_id]->writeToFile(*gradientOFiles_[coeffs_id],aver_gradient_pntrs_[coeffs_id].get(),false); } } @@ -1137,13 +1127,9 @@ void Optimizer::setupOFiles(std::vector& fnames, std::vectorlink(*this); if(multi_sim_single_files) { unsigned int r=0; - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) {r=multi_sim_comm.Get_rank();} comm.Bcast(r,0); - if(r>0) { - fnames[i]="/dev/null"; - } + if(r>0) {fnames[i]="/dev/null";} OFiles[i]->enforceSuffix(""); } OFiles[i]->open(fnames[i]); @@ -1157,7 +1143,8 @@ void Optimizer::readCoeffsFromFiles(const std::vector& fnames, cons plumed_assert(fnames.size()==ncoeffssets_); if(ncoeffssets_==1) { log.printf(" Read in coefficients from file "); - } else { + } + else { log.printf(" Read in coefficients from files:\n"); } for(unsigned int i=0; i& fnames, cons size_t ncoeffs_read = coeffs_pntrs_[i]->readFromFile(ifile,false,false); if(ncoeffssets_==1) { log.printf("%s (read %zu of %zu values)\n", ifile.getPath().c_str(),ncoeffs_read,coeffs_pntrs_[i]->numberOfCoeffs()); - } else { + } + else { log.printf(" coefficient set %u: %s (read %zu of %zu values)\n",i,ifile.getPath().c_str(),ncoeffs_read,coeffs_pntrs_[i]->numberOfCoeffs()); } ifile.close(); @@ -1186,7 +1174,8 @@ void Optimizer::readCoeffsFromFiles(const std::vector& fnames, cons } aux_coeffs_pntrs_[i]->readFromFile(ifile,false,false); ifile.close(); - } else { + } + else { AuxCoeffs(i).setValues( Coeffs(i) ); } } @@ -1194,9 +1183,7 @@ void Optimizer::readCoeffsFromFiles(const std::vector& fnames, cons void Optimizer::addCoeffsSetIDsToFilenames(std::vector& fnames, std::string& coeffssetid_prefix) { - if(ncoeffssets_==1) { - return; - } + if(ncoeffssets_==1) {return;} // if(fnames.size()==1) { fnames.resize(ncoeffssets_,fnames[0]); @@ -1204,8 +1191,7 @@ void Optimizer::addCoeffsSetIDsToFilenames(std::vector& fnames, std plumed_assert(fnames.size()==ncoeffssets_); // for(unsigned int i=0; i getStepSizes() const; std::vector getCurrentStepSizes() const; @@ -199,126 +192,62 @@ class Optimizer : void apply() override {}; void calculate() override {}; void update() override; - unsigned int getNumberOfDerivatives() override { - return 0; - } + unsigned int getNumberOfDerivatives() override {return 0;} // - bool fixedStepSize() const { - return fixed_stepsize_; - } - bool dynamicStepSize() const { - return !fixed_stepsize_; - } + bool fixedStepSize() const {return fixed_stepsize_;} + bool dynamicStepSize() const {return !fixed_stepsize_;} // - bool useHessian() const { - return use_hessian_; - } - bool diagonalHessian() const { - return diagonal_hessian_; - } + bool useHessian() const {return use_hessian_;} + bool diagonalHessian() const {return diagonal_hessian_;} // - bool useMultipleWalkers() const { - return use_mwalkers_mpi_; - } + bool useMultipleWalkers() const {return use_mwalkers_mpi_;} // - std::vector getBiasPntrs() const { - return bias_pntrs_; - } - std::vector getCoeffsPntrs() const { - return coeffs_pntrs_; - } - std::vector getAuxCoeffsPntrs() const { - return Tools::unique2raw(aux_coeffs_pntrs_); - } - std::vector getGradientPntrs()const { - return gradient_pntrs_; - } - std::vector getHessianPntrs() const { - return hessian_pntrs_; - } - std::vector getCoeffsMaskPntrs() const { - return Tools::unique2raw(coeffs_mask_pntrs_); - } - std::vector getTargetDistAveragesPntrs() const { - return targetdist_averages_pntrs_; - } + std::vector getBiasPntrs() const {return bias_pntrs_;} + std::vector getCoeffsPntrs() const {return coeffs_pntrs_;} + std::vector getAuxCoeffsPntrs() const {return Tools::unique2raw(aux_coeffs_pntrs_);} + std::vector getGradientPntrs()const {return gradient_pntrs_;} + std::vector getHessianPntrs() const {return hessian_pntrs_;} + std::vector getCoeffsMaskPntrs() const {return Tools::unique2raw(coeffs_mask_pntrs_);} + std::vector getTargetDistAveragesPntrs() const {return targetdist_averages_pntrs_;} // - bool isBiasOutputActive() const { - return bias_output_active_; - } - unsigned int getBiasOutputStride() const { - return bias_output_stride_; - } - void setBiasOutputStride(unsigned int stride) { - bias_output_stride_=stride; - } + bool isBiasOutputActive() const {return bias_output_active_;} + unsigned int getBiasOutputStride() const {return bias_output_stride_;} + void setBiasOutputStride(unsigned int stride) {bias_output_stride_=stride;} void writeBiasOutputFiles() const; // - bool isFesOutputActive() const { - return fes_output_active_; - } - unsigned int getFesOutputStride() const { - return fes_output_stride_; - } - void setFesOutputStride(unsigned int stride) { - fes_output_stride_=stride; - } + bool isFesOutputActive() const {return fes_output_active_;} + unsigned int getFesOutputStride() const {return fes_output_stride_;} + void setFesOutputStride(unsigned int stride) {fes_output_stride_=stride;} void writeFesOutputFiles() const; // - bool isFesProjOutputActive() const { - return fesproj_output_active_; - } - unsigned int getFesProjOutputStride() const { - return fesproj_output_stride_; - } - void setFesProjOutputStride(unsigned int stride) { - fesproj_output_stride_=stride; - } + bool isFesProjOutputActive() const {return fesproj_output_active_;} + unsigned int getFesProjOutputStride() const {return fesproj_output_stride_;} + void setFesProjOutputStride(unsigned int stride) {fesproj_output_stride_=stride;} void writeFesProjOutputFiles() const; // - bool isTargetDistOutputActive() const { - return targetdist_output_active_; - } - unsigned int getTargetDistOutputStride() const { - return targetdist_output_stride_; - } - void setTargetDistOutputStride(unsigned int stride) { - targetdist_output_stride_=stride; - } + bool isTargetDistOutputActive() const {return targetdist_output_active_;} + unsigned int getTargetDistOutputStride() const {return targetdist_output_stride_;} + void setTargetDistOutputStride(unsigned int stride) {targetdist_output_stride_=stride;} void writeTargetDistOutputFiles() const; // - bool isTargetDistProjOutputActive() const { - return targetdist_proj_output_active_; - } - unsigned int getTargetDistProjOutputStride() const { - return targetdist_proj_output_stride_; - } - void setTargetDistProjOutputStride(unsigned int stride) { - targetdist_proj_output_stride_=stride; - } + bool isTargetDistProjOutputActive() const {return targetdist_proj_output_active_;} + unsigned int getTargetDistProjOutputStride() const {return targetdist_proj_output_stride_;} + void setTargetDistProjOutputStride(unsigned int stride) {targetdist_proj_output_stride_=stride;} void writeTargetDistProjOutputFiles() const; // }; inline -double Optimizer::StepSize(const unsigned int coeffs_id) const { - return stepsizes_[coeffs_id]; -} +double Optimizer::StepSize(const unsigned int coeffs_id) const {return stepsizes_[coeffs_id];} inline -CoeffsVector& Optimizer::Coeffs(const unsigned int coeffs_id) const { - return *coeffs_pntrs_[coeffs_id]; -} +CoeffsVector& Optimizer::Coeffs(const unsigned int coeffs_id) const {return *coeffs_pntrs_[coeffs_id];} inline -CoeffsVector& Optimizer::AuxCoeffs(const unsigned int coeffs_id) const { - return *aux_coeffs_pntrs_[coeffs_id]; -} +CoeffsVector& Optimizer::AuxCoeffs(const unsigned int coeffs_id) const {return *aux_coeffs_pntrs_[coeffs_id];} inline -CoeffsVector& Optimizer::Gradient(const unsigned int coeffs_id) const { - return *gradient_pntrs_[coeffs_id]; -} +CoeffsVector& Optimizer::Gradient(const unsigned int coeffs_id) const {return *gradient_pntrs_[coeffs_id];} inline CoeffsMatrix& Optimizer::Hessian(const unsigned int coeffs_id) const { @@ -327,29 +256,19 @@ CoeffsMatrix& Optimizer::Hessian(const unsigned int coeffs_id) const { } inline -CoeffsVector& Optimizer::CoeffsMask(const unsigned int coeffs_id) const { - return *coeffs_mask_pntrs_[coeffs_id]; -} +CoeffsVector& Optimizer::CoeffsMask(const unsigned int coeffs_id) const {return *coeffs_mask_pntrs_[coeffs_id];} inline -std::vector Optimizer::getStepSizes() const { - return stepsizes_; -} +std::vector Optimizer::getStepSizes() const {return stepsizes_;} inline -std::vector Optimizer::getCurrentStepSizes() const { - return current_stepsizes; -} +std::vector Optimizer::getCurrentStepSizes() const {return current_stepsizes;} inline -double Optimizer::getStepSize(const unsigned int coeffs_id) const { - return stepsizes_[coeffs_id]; -} +double Optimizer::getStepSize(const unsigned int coeffs_id) const {return stepsizes_[coeffs_id];} inline -double Optimizer::getCurrentStepSize(const unsigned int coeffs_id) const { - return current_stepsizes[coeffs_id]; -} +double Optimizer::getCurrentStepSize(const unsigned int coeffs_id) const {return current_stepsizes[coeffs_id];} inline void Optimizer::setStepSizes(const std::vector& stepsizes_in) { @@ -374,24 +293,16 @@ void Optimizer::setCurrentStepSizes(const std::vector& current_stepsizes } inline -unsigned int Optimizer::getIterationCounter() const { - return iter_counter; -} +unsigned int Optimizer::getIterationCounter() const {return iter_counter;} inline -double Optimizer::getIterationCounterDbl() const { - return static_cast(iter_counter); -} +double Optimizer::getIterationCounterDbl() const {return static_cast(iter_counter);} inline -void Optimizer::increaseIterationCounter() { - iter_counter++; -} +void Optimizer::increaseIterationCounter() {iter_counter++;} inline -void Optimizer::setIterationCounter(const unsigned int iter_counter_in) { - iter_counter = iter_counter_in; -} +void Optimizer::setIterationCounter(const unsigned int iter_counter_in) {iter_counter = iter_counter_in;} template @@ -406,8 +317,7 @@ bool Optimizer::parseMultipleValues(const std::string& keyword, std::vector& identical_values=true; } if(values.size()>0 && values.size()!=ncoeffssets_) { - std::string s1; - Tools::convert(ncoeffssets_,s1); + std::string s1; Tools::convert(ncoeffssets_,s1); plumed_merror("Error in " + keyword + " keyword: either give 1 common value for all coefficient sets or " + s1 + " separate value for each set"); } return identical_values; diff --git a/src/ves/OutputBasisFunctions.cpp b/src/ves/OutputBasisFunctions.cpp index 5f47f92f5f..0a4231581d 100644 --- a/src/ves/OutputBasisFunctions.cpp +++ b/src/ves/OutputBasisFunctions.cpp @@ -81,7 +81,8 @@ plumed driver --plumed plumed.dat --igro configuration.gro class OutputBasisFunctions : - public Action { + public Action +{ std::vector bf_pntrs; public: explicit OutputBasisFunctions(const ActionOptions&); @@ -115,18 +116,15 @@ void OutputBasisFunctions::registerKeywords(Keywords& keys) { OutputBasisFunctions::OutputBasisFunctions(const ActionOptions&ao): Action(ao), - bf_pntrs(0) { + bf_pntrs(0) +{ std::vector basisset_labels(0); parseVector("BASIS_FUNCTIONS",basisset_labels); - if(basisset_labels.size()>1) { - plumed_merror("Only one basis set label allowed in keyword BASIS_FUNCTIONS of "+getName()); - } + if(basisset_labels.size()>1) {plumed_merror("Only one basis set label allowed in keyword BASIS_FUNCTIONS of "+getName());} std::string error_msg = ""; bf_pntrs = VesTools::getPointersFromLabels(basisset_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword BASIS_FUNCTIONS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword BASIS_FUNCTIONS of "+getName()+": "+error_msg);} unsigned int nbins = 1000; parse("GRID_BINS",nbins); @@ -165,14 +163,10 @@ OutputBasisFunctions::OutputBasisFunctions(const ActionOptions&ao): targetdist_pntrs.push_back(NULL); std::string targetdist_label=""; for(int i=1;; i++) { - if(!parseNumbered("TARGET_DISTRIBUTION",i,targetdist_label)) { - break; - } + if(!parseNumbered("TARGET_DISTRIBUTION",i,targetdist_label)) {break;} std::string error_msg = ""; TargetDistribution* pntr_tmp = VesTools::getPointerFromLabel(targetdist_label,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword TARGET_DISTRIBUTION of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword TARGET_DISTRIBUTION of "+getName()+": "+error_msg);} targetdist_pntrs.push_back(pntr_tmp); } checkRead(); @@ -189,17 +183,15 @@ OutputBasisFunctions::OutputBasisFunctions(const ActionOptions&ao): ofile_values.close(); ofile_derivs.close(); // - std::vector grid_min(1); - grid_min[0]=bf_pntrs[0]->intervalMinStr(); - std::vector grid_max(1); - grid_max[0]=bf_pntrs[0]->intervalMaxStr(); - std::vector grid_bins(1); - grid_bins[0]=nbins; + std::vector grid_min(1); grid_min[0]=bf_pntrs[0]->intervalMinStr(); + std::vector grid_max(1); grid_max[0]=bf_pntrs[0]->intervalMaxStr(); + std::vector grid_bins(1); grid_bins[0]=nbins; std::vector> arguments(1); arguments[0]= Tools::make_unique(nullptr,"arg",false); if(bf_pntrs[0]->arePeriodic() && !ignore_periodicity) { arguments[0]->setDomain(bf_pntrs[0]->intervalMinStr(),bf_pntrs[0]->intervalMaxStr()); - } else { + } + else { arguments[0]->setNotPeriodic(); } @@ -209,8 +201,7 @@ OutputBasisFunctions::OutputBasisFunctions(const ActionOptions&ao): ofile_targetdist_aver.open(fname_targetdist_aver); for(unsigned int i=0; isetupGrids(Tools::unique2raw(arguments),grid_min,grid_max,grid_bins); @@ -221,9 +212,7 @@ OutputBasisFunctions::OutputBasisFunctions(const ActionOptions&ao): std::vector bf_integrals = bf_pntrs[0]->getTargetDistributionIntegrals(targetdist_pntrs[i]); CoeffsVector targetdist_averages = CoeffsVector("aver.targetdist-"+is,Tools::unique2raw(arguments),bf_pntrs,comm,false); targetdist_averages.setValues(bf_integrals); - if(fmt_targetdist_aver.size()>0) { - targetdist_averages.setOutputFmt(fmt_targetdist_aver); - } + if(fmt_targetdist_aver.size()>0) {targetdist_averages.setOutputFmt(fmt_targetdist_aver);} targetdist_averages.writeToFile(ofile_targetdist_aver,true); if(targetdist_pntrs[i]!=NULL) { Grid* targetdist_grid_pntr = targetdist_pntrs[i]->getTargetDistGridPntr(); diff --git a/src/ves/OutputFesBias.cpp b/src/ves/OutputFesBias.cpp index 33ed4c64f1..8a4160b7e1 100644 --- a/src/ves/OutputFesBias.cpp +++ b/src/ves/OutputFesBias.cpp @@ -121,7 +121,8 @@ void OutputFesBias::registerKeywords(Keywords& keys) { OutputFesBias::OutputFesBias(const ActionOptions&ao): - Action(ao) { + Action(ao) +{ std::vector bias_labels; parseVector("BIAS",bias_labels); @@ -131,9 +132,7 @@ OutputFesBias::OutputFesBias(const ActionOptions&ao): std::string error_msg = ""; std::vector bias_pntrs = VesTools::getPointersFromLabels(bias_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword BIAS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword BIAS of "+getName()+": "+error_msg);} for(unsigned int i=0; inumberOfCoeffsSets()>1) { diff --git a/src/ves/OutputTargetDistribution.cpp b/src/ves/OutputTargetDistribution.cpp index e7d3286b8c..8fced37e8e 100644 --- a/src/ves/OutputTargetDistribution.cpp +++ b/src/ves/OutputTargetDistribution.cpp @@ -79,7 +79,8 @@ plumed driver --plumed plumed.dat --igro configuration.gro class OutputTargetDistribution : - public Action { + public Action +{ public: explicit OutputTargetDistribution(const ActionOptions&); void calculate() override {} @@ -104,7 +105,8 @@ void OutputTargetDistribution::registerKeywords(Keywords& keys) { } OutputTargetDistribution::OutputTargetDistribution(const ActionOptions&ao): - Action(ao) { + Action(ao) +{ std::string targetdist_fname; parse("TARGETDIST_FILE",targetdist_fname); @@ -125,9 +127,7 @@ OutputTargetDistribution::OutputTargetDistribution(const ActionOptions&ao): std::vector grid_periodicity(nargs); parseVector("GRID_PERIODICITY",grid_periodicity); - if(grid_periodicity.size()==0) { - grid_periodicity.assign(nargs,"NO"); - } + if(grid_periodicity.size()==0) {grid_periodicity.assign(nargs,"NO");} std::string fmt_grids="%14.9f"; parse("FMT_GRIDS",fmt_grids); @@ -148,26 +148,23 @@ OutputTargetDistribution::OutputTargetDistribution(const ActionOptions&ao): // std::vector> arguments(nargs); for(unsigned int i=0; i < nargs; i++) { - std::string is; - Tools::convert(i+1,is); - if(nargs==1) { - is=""; - } + std::string is; Tools::convert(i+1,is); + if(nargs==1) {is="";} arguments[i]= Tools::make_unique(nullptr,"arg"+is,false); if(grid_periodicity[i]=="YES") { arguments[i]->setDomain(grid_min[i],grid_max[i]); - } else if(grid_periodicity[i]=="NO") { + } + else if(grid_periodicity[i]=="NO") { arguments[i]->setNotPeriodic(); - } else { + } + else { plumed_merror("wrong value given in GRID_PERIODICITY, either specify YES or NO"); } } std::string error_msg = ""; TargetDistribution* targetdist_pntr = VesTools::getPointerFromLabel(targetdist_label,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword TARGET_DISTRIBUTION of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword TARGET_DISTRIBUTION of "+getName()+": "+error_msg);} // if(targetdist_pntr->isDynamic()) { plumed_merror(getName() + " only works for static target distributions"); diff --git a/src/ves/TD_Chi.cpp b/src/ves/TD_Chi.cpp index 679f02fa26..c28b515141 100644 --- a/src/ves/TD_Chi.cpp +++ b/src/ves/TD_Chi.cpp @@ -107,39 +107,28 @@ TD_Chi::TD_Chi(const ActionOptions& ao): minima_(0), sigma_(0), kappa_(0), - normalization_(0) { + normalization_(0) +{ parseVector("MINIMUM",minima_); parseVector("SIGMA",sigma_); for(unsigned int k=0; k kappa_int(0); parseVector("KAPPA",kappa_int); - if(kappa_int.size()==0) { - plumed_merror(getName()+": some problem with KAPPA keyword, should given as positive integer larger than 1"); - } + if(kappa_int.size()==0) {plumed_merror(getName()+": some problem with KAPPA keyword, should given as positive integer larger than 1");} kappa_.resize(kappa_int.size()); for(unsigned int k=0; k(kappa_int[k]); } setDimension(minima_.size()); - if(getDimension()>1) { - plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action."); - } - if(sigma_.size()!=getDimension()) { - plumed_merror(getName()+": the SIGMA keyword does not match the given dimension in MINIMUM"); - } - if(kappa_.size()!=getDimension()) { - plumed_merror(getName()+": the KAPPA keyword does not match the given dimension in MINIMUM"); - } + if(getDimension()>1) {plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action.");} + if(sigma_.size()!=getDimension()) {plumed_merror(getName()+": the SIGMA keyword does not match the given dimension in MINIMUM");} + if(kappa_.size()!=getDimension()) {plumed_merror(getName()+": the KAPPA keyword does not match the given dimension in MINIMUM");} normalization_.resize(getDimension()); for(unsigned int k=0; k& argument) const { double value = 1.0; for(unsigned int k=0; k kappa_int(0); parseVector("KAPPA",kappa_int); - if(kappa_int.size()==0) { - plumed_merror(getName()+": some problem with KAPPA keyword, should given as positive integer larger than 2"); - } + if(kappa_int.size()==0) {plumed_merror(getName()+": some problem with KAPPA keyword, should given as positive integer larger than 2");} kappa_.resize(kappa_int.size()); for(unsigned int k=0; k(kappa_int[k]); } setDimension(minima_.size()); - if(getDimension()>1) { - plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action."); - } - if(sigma_.size()!=getDimension()) { - plumed_merror(getName()+": the SIGMA keyword does not match the given dimension in MINIMUM"); - } - if(kappa_.size()!=getDimension()) { - plumed_merror(getName()+": the KAPPA keyword does not match the given dimension in MINIMUM"); - } + if(getDimension()>1) {plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action.");} + if(sigma_.size()!=getDimension()) {plumed_merror(getName()+": the SIGMA keyword does not match the given dimension in MINIMUM");} + if(kappa_.size()!=getDimension()) {plumed_merror(getName()+": the KAPPA keyword does not match the given dimension in MINIMUM");} normalization_.resize(getDimension()); for(unsigned int k=0; k& argument) const { double value = 1.0; for(unsigned int k=0; k0) { cv_var_idx_.push_back(cv_idx-1); - } else if(curr_var==fes_var_str_) { + } + else if(curr_var==fes_var_str_) { use_fes_=true; setDynamic(); setFesGridNeeded(); - } else if(curr_var==kbt_var_str_) { + } + else if(curr_var==kbt_var_str_) { use_kbt_=true; - } else if(curr_var==beta_var_str_) { + } + else if(curr_var==beta_var_str_) { use_beta_=true; - } else { + } + else { plumed_merror(getName()+": problem with parsing formula with lepton, cannot recognise the variable "+curr_var); } } @@ -207,8 +213,7 @@ TD_Custom::TD_Custom(const ActionOptions& ao): cv_var_str_.resize(cv_var_idx_.size()); cv_var_lepton_refs_.resize(cv_var_str_.size()); for(unsigned int j=0; j integration_weights = GridIntegrationWeights::getIntegrationWeights(getTargetDistGridPntr()); @@ -268,27 +269,22 @@ void TD_Custom::updateGrid() { for(Grid::index_t l=0; l point = targetDistGrid().getPoint(l); for(unsigned int k=0; kgetValue(l); - } + if(fes_var_lepton_ref_) {*fes_var_lepton_ref_ = getFesGridPntr()->getValue(l);} } double value = expression.evaluate(); - if(value<0.0 && !isTargetDistGridShiftedToZero()) { - plumed_merror(getName()+": The target distribution function gives negative values. You should change the definition of the function used for the target distribution to avoid this. You can also use the SHIFT_TO_ZERO keyword to avoid this problem."); - } + if(value<0.0 && !isTargetDistGridShiftedToZero()) {plumed_merror(getName()+": The target distribution function gives negative values. You should change the definition of the function used for the target distribution to avoid this. You can also use the SHIFT_TO_ZERO keyword to avoid this problem.");} targetDistGrid().setValue(l,value); norm += integration_weights[l]*value; logTargetDistGrid().setValue(l,-std::log(value)); } if(norm>0.0) { targetDistGrid().scaleAllValuesAndDerivatives(1.0/norm); - } else if(!isTargetDistGridShiftedToZero()) { + } + else if(!isTargetDistGridShiftedToZero()) { plumed_merror(getName()+": The target distribution function cannot be normalized proberly. You should change the definition of the function used for the target distribution to avoid this. You can also use the SHIFT_TO_ZERO keyword to avoid this problem."); } logTargetDistGrid().setMinToZero(); diff --git a/src/ves/TD_Exponential.cpp b/src/ves/TD_Exponential.cpp index 58920949d6..e3b1f5107a 100644 --- a/src/ves/TD_Exponential.cpp +++ b/src/ves/TD_Exponential.cpp @@ -97,23 +97,18 @@ void TD_Exponential::registerKeywords(Keywords& keys) { TD_Exponential::TD_Exponential(const ActionOptions& ao): PLUMED_VES_TARGETDISTRIBUTION_INIT(ao), minima_(0), - lambda_(0) { + lambda_(0) +{ parseVector("MINIMUM",minima_); parseVector("LAMBDA",lambda_); for(unsigned int k=0; k1) { - plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action."); - } - if(lambda_.size()!=getDimension()) { - plumed_merror(getName()+": the LAMBDA keyword does not match the given dimension in MINIMUM"); - } + if(getDimension()>1) {plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action.");} + if(lambda_.size()!=getDimension()) {plumed_merror(getName()+": the LAMBDA keyword does not match the given dimension in MINIMUM");} checkRead(); } @@ -122,9 +117,7 @@ double TD_Exponential::getValue(const std::vector& argument) const { double value = 1.0; for(unsigned int k=0; k tmp_center; - if(!parseNumberedVector("CENTER",i,tmp_center) ) { - break; - } + if(!parseNumberedVector("CENTER",i,tmp_center) ) {break;} centers_.push_back(tmp_center); } for(unsigned int i=1;; i++) { std::vector tmp_sigma; - if(!parseNumberedVector("SIGMA",i,tmp_sigma) ) { - break; - } + if(!parseNumberedVector("SIGMA",i,tmp_sigma) ) {break;} for(unsigned int k=0; k tmp_lambda; - if(!parseNumberedVector("LAMBDA",i,tmp_lambda) ) { - break; - } + if(!parseNumberedVector("LAMBDA",i,tmp_lambda) ) {break;} for(unsigned int k=0; k tmp_center; - if(!parseNumberedVector("CENTER",i,tmp_center) ) { - break; - } + if(!parseNumberedVector("CENTER",i,tmp_center) ) {break;} centers_.push_back(tmp_center); } for(unsigned int i=1;; i++) { std::vector tmp_sigma; - if(!parseNumberedVector("SIGMA",i,tmp_sigma) ) { - break; - } + if(!parseNumberedVector("SIGMA",i,tmp_sigma) ) {break;} sigmas_.push_back(tmp_sigma); } @@ -238,7 +235,8 @@ TD_Gaussian::TD_Gaussian(const ActionOptions& ao): parseNumberedVector("CORRELATION",(i+1),corr); if(corr.size()>0) { diagonal_ = false; - } else { + } + else { corr.assign(1,0.0); } correlation_[i] = corr; @@ -259,20 +257,14 @@ TD_Gaussian::TD_Gaussian(const ActionOptions& ao): } // parseVector("WEIGHTS",weights_); - if(weights_.size()==0) { - weights_.assign(centers_.size(),1.0); - } + if(weights_.size()==0) {weights_.assign(centers_.size(),1.0);} if(centers_.size()!=weights_.size()) { plumed_merror(getName()+": there has to be as many weights given in WEIGHTS as numbered CENTER keywords"); } // double sum_weights=0.0; - for(unsigned int i=0; i& argument) const { for(unsigned int i=0; i& argument, const for(unsigned int k=0; k1) { - plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action."); - } - if(scale_.size()!=getDimension()) { - plumed_merror(getName()+": the SCALE keyword does not match the given dimension in MINIMA"); - } - if(shape_.size()!=getDimension()) { - plumed_merror(getName()+": the SHAPE keyword does not match the given dimension in MINIMA"); - } + if(getDimension()>1) {plumed_merror(getName()+": only defined for one dimension, for multiple dimensions it should be used in combination with the TD_PRODUCT_DISTRIBUTION action.");} + if(scale_.size()!=getDimension()) {plumed_merror(getName()+": the SCALE keyword does not match the given dimension in MINIMA");} + if(shape_.size()!=getDimension()) {plumed_merror(getName()+": the SHAPE keyword does not match the given dimension in MINIMA");} normalization_.resize(getDimension()); for(unsigned int k=0; k& argume double arg=(argument[k]-center[k])/scale[k]; double tx; if(shape_[k]!=0.0) { - if( shape_[k]>0 && argument[k] <= (center[k]-scale[k]/shape[k]) ) { - return 0.0; - } - if( shape_[k]<0 && argument[k] > (center[k]-scale[k]/shape[k]) ) { - return 0.0; - } + if( shape_[k]>0 && argument[k] <= (center[k]-scale[k]/shape[k]) ) {return 0.0;} + if( shape_[k]<0 && argument[k] > (center[k]-scale[k]/shape[k]) ) {return 0.0;} tx = pow( (1.0+arg*shape[k]), -1.0/shape[k] ); - } else { + } + else { tx = exp(-arg); } value *= normalization[k] * pow(tx,shape[k]+1.0) * exp(-tx); diff --git a/src/ves/TD_GeneralizedNormal.cpp b/src/ves/TD_GeneralizedNormal.cpp index 3b373e3dda..29925c27ab 100644 --- a/src/ves/TD_GeneralizedNormal.cpp +++ b/src/ves/TD_GeneralizedNormal.cpp @@ -133,35 +133,26 @@ TD_GeneralizedNormal::TD_GeneralizedNormal(const ActionOptions& ao): betas_(0), normalization_(0), weights_(0), - ncenters_(0) { + ncenters_(0) +{ for(unsigned int i=1;; i++) { std::vector tmp_center; - if(!parseNumberedVector("CENTER",i,tmp_center) ) { - break; - } + if(!parseNumberedVector("CENTER",i,tmp_center) ) {break;} centers_.push_back(tmp_center); } for(unsigned int i=1;; i++) { std::vector tmp_alpha; - if(!parseNumberedVector("ALPHA",i,tmp_alpha) ) { - break; - } + if(!parseNumberedVector("ALPHA",i,tmp_alpha) ) {break;} for(unsigned int k=0; k tmp_beta; - if(!parseNumberedVector("BETA",i,tmp_beta) ) { - break; - } + if(!parseNumberedVector("BETA",i,tmp_beta) ) {break;} for(unsigned int k=0; k(nullptr,arglabels[i],false); if(argperiodic[i]) { arguments[i]->setDomain(argmin[i],argmax[i]); - } else { + } + else { arguments[i]->setNotPeriodic(); } } - IFile gridfile; - gridfile.open(filename); + IFile gridfile; gridfile.open(filename); if(has_deriv) { distGrid_=GridBase::create(gridlabel,Tools::unique2raw(arguments),gridfile,false,true,true); - } else { + } + else { distGrid_=GridBase::create(gridlabel,Tools::unique2raw(arguments),gridfile,false,false,false); } gridfile.close(); @@ -194,9 +190,7 @@ TD_Grid::TD_Grid(const ActionOptions& ao): Tools::convert(distGrid_->getMin()[i],minima_[i]); Tools::convert(distGrid_->getMax()[i],maxima_[i]); periodic_[i] = argperiodic[i]; - if(periodic_[i]) { - maxima_[i]-=distGrid_->getDx()[i]; - } + if(periodic_[i]) {maxima_[i]-=distGrid_->getDx()[i];} } } @@ -208,9 +202,11 @@ double TD_Grid::getValue(const std::vector& argument) const { for(unsigned int k=0; k maxima_[k])) { return outside; - } else if(argument[k] < minima_[k]) { + } + else if(argument[k] < minima_[k]) { arg[k] = minima_[k]; - } else if(argument[k] > maxima_[k]) { + } + else if(argument[k] > maxima_[k]) { arg[k] =maxima_[k]; } } diff --git a/src/ves/TD_LinearCombination.cpp b/src/ves/TD_LinearCombination.cpp index d9072f5add..3ba559433f 100644 --- a/src/ves/TD_LinearCombination.cpp +++ b/src/ves/TD_LinearCombination.cpp @@ -166,52 +166,35 @@ TD_LinearCombination::TD_LinearCombination(const ActionOptions& ao): distribution_pntrs_(0), grid_pntrs_(0), weights_(0), - ndist_(0) { + ndist_(0) +{ std::vector targetdist_labels; parseVector("DISTRIBUTIONS",targetdist_labels); std::string error_msg = ""; distribution_pntrs_ = VesTools::getPointersFromLabels(targetdist_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword DISTRIBUTIONS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword DISTRIBUTIONS of "+getName()+": "+error_msg);} for(unsigned int i=0; iisDynamic()) { - setDynamic(); - } - if(distribution_pntrs_[i]->fesGridNeeded()) { - setFesGridNeeded(); - } - if(distribution_pntrs_[i]->biasGridNeeded()) { - setBiasGridNeeded(); - } + if(distribution_pntrs_[i]->isDynamic()) {setDynamic();} + if(distribution_pntrs_[i]->fesGridNeeded()) {setFesGridNeeded();} + if(distribution_pntrs_[i]->biasGridNeeded()) {setBiasGridNeeded();} } ndist_ = distribution_pntrs_.size(); grid_pntrs_.assign(ndist_,NULL); - if(ndist_==0) { - plumed_merror(getName()+ ": no distributions are given."); - } - if(ndist_==1) { - plumed_merror(getName()+ ": giving only one distribution does not make sense."); - } + if(ndist_==0) {plumed_merror(getName()+ ": no distributions are given.");} + if(ndist_==1) {plumed_merror(getName()+ ": giving only one distribution does not make sense.");} // parseVector("WEIGHTS",weights_); - if(weights_.size()==0) { - weights_.assign(distribution_pntrs_.size(),1.0); - } + if(weights_.size()==0) {weights_.assign(distribution_pntrs_.size(),1.0);} if(distribution_pntrs_.size()!=weights_.size()) { plumed_merror(getName()+ ": there has to be as many weights given in WEIGHTS as the number of target distribution labels given in DISTRIBUTIONS"); } // double sum_weights=0.0; - for(unsigned int i=0; igetValue(l); } - if(value==0.0) { - value=std::numeric_limits::denorm_min(); - } + if(value==0.0) value=std::numeric_limits::denorm_min(); targetDistGrid().setValue(l,value); logTargetDistGrid().setValue(l,-std::log(value)); } diff --git a/src/ves/TD_Multicanonical.cpp b/src/ves/TD_Multicanonical.cpp index 0ae235d6fc..6434ce102b 100644 --- a/src/ves/TD_Multicanonical.cpp +++ b/src/ves/TD_Multicanonical.cpp @@ -179,7 +179,8 @@ TD_Multicanonical::TD_Multicanonical(const ActionOptions& ao): sigma_(0.0), steps_temp_(20), epsilon_(10.0), - smoothening_(true) { + smoothening_(true) +{ log.printf(" Multicanonical target distribution"); log.printf("\n"); log.printf(" Please read and cite "); @@ -197,17 +198,11 @@ TD_Multicanonical::TD_Multicanonical(const ActionOptions& ao): parse("MAX_TEMP",max_temp_); log.printf(" temperatures between %f and %f will be explored \n",min_temp_,max_temp_); parseVector("SIGMA",sigma_); - if(sigma_.size()==0) { - smoothening_=false; - } - if(smoothening_ && (sigma_.size()<1 || sigma_.size()>2) ) { - plumed_merror(getName()+": SIGMA takes 1 or 2 values as input."); - } + if(sigma_.size()==0) smoothening_=false; + if(smoothening_ && (sigma_.size()<1 || sigma_.size()>2) ) plumed_merror(getName()+": SIGMA takes 1 or 2 values as input."); if (smoothening_) { log.printf(" the target distribution will be smoothed using sigma values"); - for(unsigned i=0; i& argument) const { void TD_Multicanonical::updateGrid() { if (getStep() == 0) { - if(targetDistGrid().getDimension()>2 || targetDistGrid().getDimension()<1) { - plumed_merror(getName()+" works only with 1 or 2 arguments, i.e. energy, or energy and CV"); - } - if(smoothening_ && sigma_.size()!=targetDistGrid().getDimension()) { - plumed_merror(getName()+": mismatch between SIGMA dimension and number of arguments"); - } + if(targetDistGrid().getDimension()>2 || targetDistGrid().getDimension()<1) plumed_merror(getName()+" works only with 1 or 2 arguments, i.e. energy, or energy and CV"); + if(smoothening_ && sigma_.size()!=targetDistGrid().getDimension()) plumed_merror(getName()+": mismatch between SIGMA dimension and number of arguments"); // Use uniform TD std::vector integration_weights = GridIntegrationWeights::getIntegrationWeights(getTargetDistGridPntr()); double norm = 0.0; @@ -352,18 +343,14 @@ void TD_Multicanonical::updateGrid() { double value = 1.0; double tmp; if(argument < minimum) { - if (smoothening_) { - tmp = GaussianSwitchingFunc(argument,minimum,sigma_[0]); - } else { - tmp = exp(-1.0*epsilon_); - } - } else if(argument > maximum) { - if (smoothening_) { - tmp = GaussianSwitchingFunc(argument,maximum,sigma_[0]); - } else { - tmp = exp(-1.0*epsilon_); - } - } else { + if (smoothening_) tmp = GaussianSwitchingFunc(argument,minimum,sigma_[0]); + else tmp = exp(-1.0*epsilon_); + } + else if(argument > maximum) { + if (smoothening_) tmp = GaussianSwitchingFunc(argument,maximum,sigma_[0]); + else tmp = exp(-1.0*epsilon_); + } + else { tmp = 1.0; } value *= tmp; @@ -429,28 +416,16 @@ void TD_Multicanonical::updateGrid() { deltaBin[1]=std::floor(6*sigma_[1]/dx[1]);; // For energy minBin[0]=i - deltaBin[0]; - if (minBin[0] < 0) { - minBin[0]=0; - } - if (minBin[0] > (nbin[0]-1)) { - minBin[0]=nbin[0]-1; - } + if (minBin[0] < 0) minBin[0]=0; + if (minBin[0] > (nbin[0]-1)) minBin[0]=nbin[0]-1; maxBin[0]=i + deltaBin[0]; - if (maxBin[0] > (nbin[0]-1)) { - maxBin[0]=nbin[0]-1; - } + if (maxBin[0] > (nbin[0]-1)) maxBin[0]=nbin[0]-1; // For volume minBin[1]=j - deltaBin[1]; - if (minBin[1] < 0) { - minBin[1]=0; - } - if (minBin[1] > (nbin[1]-1)) { - minBin[1]=nbin[1]-1; - } + if (minBin[1] < 0) minBin[1]=0; + if (minBin[1] > (nbin[1]-1)) minBin[1]=nbin[1]-1; maxBin[1]=j + deltaBin[1]; - if (maxBin[1] > (nbin[1]-1)) { - maxBin[1]=nbin[1]-1; - } + if (maxBin[1] > (nbin[1]-1)) maxBin[1]=nbin[1]-1; for(unsigned l=minBin[0]; l indices_prime(2); @@ -479,9 +454,7 @@ void TD_Multicanonical::updateGrid() { norm += integration_weights[l]*value; } targetDistGrid().scaleAllValuesAndDerivatives(1.0/norm); - } else { - plumed_merror(getName()+": Number of arguments for this target distribution must be 1 or 2"); - } + } else plumed_merror(getName()+": Number of arguments for this target distribution must be 1 or 2"); } updateLogTargetDistGrid(); } @@ -491,7 +464,8 @@ double TD_Multicanonical::GaussianSwitchingFunc(const double argument, const dou if(sigma>0.0) { double arg=(argument-center)/sigma; return exp(-0.5*arg*arg); - } else { + } + else { return 0.0; } } diff --git a/src/ves/TD_MultithermalMultibaric.cpp b/src/ves/TD_MultithermalMultibaric.cpp index e034d68aa9..cd9ba0ffef 100644 --- a/src/ves/TD_MultithermalMultibaric.cpp +++ b/src/ves/TD_MultithermalMultibaric.cpp @@ -257,7 +257,8 @@ TD_MultithermalMultibaric::TD_MultithermalMultibaric(const ActionOptions& ao): epsilon_(10.0), smoothening_(true), steps_temp_(20), - steps_pressure_(20) { + steps_pressure_(20) +{ log.printf(" Multithermal-multibaric target distribution"); log.printf("\n"); @@ -282,17 +283,11 @@ TD_MultithermalMultibaric::TD_MultithermalMultibaric(const ActionOptions& ao): parse("PRESSURE",press_); log.printf(" pressure of the barostat should have been set to %f. Please check this in the MD engine \n",press_); parseVector("SIGMA",sigma_); - if(sigma_.size()==0) { - smoothening_=false; - } - if(smoothening_ && (sigma_.size()<2 || sigma_.size()>3) ) { - plumed_merror(getName()+": SIGMA takes 2 or 3 values as input."); - } + if(sigma_.size()==0) smoothening_=false; + if(smoothening_ && (sigma_.size()<2 || sigma_.size()>3) ) plumed_merror(getName()+": SIGMA takes 2 or 3 values as input."); if (smoothening_) { log.printf(" the target distribution will be smoothed using sigma values"); - for(unsigned i=0; i& argument) void TD_MultithermalMultibaric::updateGrid() { if (getStep() == 0) { - if(targetDistGrid().getDimension()>3 || targetDistGrid().getDimension()<2) { - plumed_merror(getName()+" works only with 2 or 3 arguments, i.e. energy and volume, or energy, volume, and CV"); - } - if(smoothening_ && sigma_.size()!=targetDistGrid().getDimension()) { - plumed_merror(getName()+": mismatch between SIGMA dimension and number of arguments"); - } + if(targetDistGrid().getDimension()>3 || targetDistGrid().getDimension()<2) plumed_merror(getName()+" works only with 2 or 3 arguments, i.e. energy and volume, or energy, volume, and CV"); + if(smoothening_ && sigma_.size()!=targetDistGrid().getDimension()) plumed_merror(getName()+": mismatch between SIGMA dimension and number of arguments"); // Use uniform TD std::vector integration_weights = GridIntegrationWeights::getIntegrationWeights(getTargetDistGridPntr()); double norm = 0.0; @@ -389,16 +380,10 @@ void TD_MultithermalMultibaric::updateGrid() { for(unsigned k=0; k (nbin[k]-1)) { - minBin[k]=nbin[k]-1; - } + if (minBin[k] < 0) minBin[k]=0; + if (minBin[k] > (nbin[k]-1)) minBin[k]=nbin[k]-1; maxBin[k]=indices[k] + deltaBin; - if (maxBin[k] > (nbin[k]-1)) { - maxBin[k]=nbin[k]-1; - } + if (maxBin[k] > (nbin[k]-1)) maxBin[k]=nbin[k]-1; } if (dim==2) { for(unsigned l=minBin[0]; l0.0) { double arg=(argument-center)/sigma; return exp(-0.5*arg*arg); - } else { + } + else { return 0.0; } } diff --git a/src/ves/TD_ProductCombination.cpp b/src/ves/TD_ProductCombination.cpp index 0ab72722cb..746a28d73c 100644 --- a/src/ves/TD_ProductCombination.cpp +++ b/src/ves/TD_ProductCombination.cpp @@ -152,36 +152,25 @@ TD_ProductCombination::TD_ProductCombination(const ActionOptions& ao): PLUMED_VES_TARGETDISTRIBUTION_INIT(ao), distribution_pntrs_(0), grid_pntrs_(0), - ndist_(0) { + ndist_(0) +{ std::vector targetdist_labels; parseVector("DISTRIBUTIONS",targetdist_labels); std::string error_msg = ""; distribution_pntrs_ = VesTools::getPointersFromLabels(targetdist_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword DISTRIBUTIONS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword DISTRIBUTIONS of "+getName()+": "+error_msg);} for(unsigned int i=0; iisDynamic()) { - setDynamic(); - } - if(distribution_pntrs_[i]->fesGridNeeded()) { - setFesGridNeeded(); - } - if(distribution_pntrs_[i]->biasGridNeeded()) { - setBiasGridNeeded(); - } + if(distribution_pntrs_[i]->isDynamic()) {setDynamic();} + if(distribution_pntrs_[i]->fesGridNeeded()) {setFesGridNeeded();} + if(distribution_pntrs_[i]->biasGridNeeded()) {setBiasGridNeeded();} } ndist_ = distribution_pntrs_.size(); grid_pntrs_.assign(ndist_,NULL); - if(ndist_==0) { - plumed_merror(getName()+ ": no distributions are given."); - } - if(ndist_==1) { - plumed_merror(getName()+ ": giving only one distribution does not make sense."); - } + if(ndist_==0) {plumed_merror(getName()+ ": no distributions are given.");} + if(ndist_==1) {plumed_merror(getName()+ ": giving only one distribution does not make sense.");} // checkRead(); } @@ -215,9 +204,7 @@ void TD_ProductCombination::updateGrid() { for(unsigned int i=0; igetValue(l); } - if(value<0.0 && !isTargetDistGridShiftedToZero()) { - plumed_merror(getName()+": The target distribution function gives negative values. You should change the definition of the target distribution to avoid this. You can also use the SHIFT_TO_ZERO keyword to avoid this problem."); - } + if(value<0.0 && !isTargetDistGridShiftedToZero()) {plumed_merror(getName()+": The target distribution function gives negative values. You should change the definition of the target distribution to avoid this. You can also use the SHIFT_TO_ZERO keyword to avoid this problem.");} norm += integration_weights[l]*value; targetDistGrid().setValue(l,value); logTargetDistGrid().setValue(l,-std::log(value)); @@ -225,7 +212,8 @@ void TD_ProductCombination::updateGrid() { if(norm>0.0) { targetDistGrid().scaleAllValuesAndDerivatives(1.0/norm); - } else if(!isTargetDistGridShiftedToZero()) { + } + else if(!isTargetDistGridShiftedToZero()) { plumed_merror(getName()+": The target distribution function cannot be normalized proberly. You should change the definition of the target distribution to avoid this. You can also use the SHIFT_TO_ZERO keyword to avoid this problem."); } logTargetDistGrid().setMinToZero(); diff --git a/src/ves/TD_ProductDistribution.cpp b/src/ves/TD_ProductDistribution.cpp index 393c7a3b92..083538baa5 100644 --- a/src/ves/TD_ProductDistribution.cpp +++ b/src/ves/TD_ProductDistribution.cpp @@ -116,26 +116,19 @@ TD_ProductDistribution::TD_ProductDistribution(const ActionOptions& ao): PLUMED_VES_TARGETDISTRIBUTION_INIT(ao), distribution_pntrs_(0), grid_pntrs_(0), - ndist_(0) { + ndist_(0) +{ std::vector targetdist_labels; parseVector("DISTRIBUTIONS",targetdist_labels); std::string error_msg = ""; distribution_pntrs_ = VesTools::getPointersFromLabels(targetdist_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword DISTRIBUTIONS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword DISTRIBUTIONS of "+getName()+": "+error_msg);} for(unsigned int i=0; iisDynamic()) { - setDynamic(); - } - if(distribution_pntrs_[i]->fesGridNeeded()) { - setFesGridNeeded(); - } - if(distribution_pntrs_[i]->biasGridNeeded()) { - setBiasGridNeeded(); - } + if(distribution_pntrs_[i]->isDynamic()) {setDynamic();} + if(distribution_pntrs_[i]->fesGridNeeded()) {setFesGridNeeded();} + if(distribution_pntrs_[i]->biasGridNeeded()) {setBiasGridNeeded();} } ndist_ = distribution_pntrs_.size(); diff --git a/src/ves/TD_Uniform.cpp b/src/ves/TD_Uniform.cpp index 96373d2199..8b40a63723 100644 --- a/src/ves/TD_Uniform.cpp +++ b/src/ves/TD_Uniform.cpp @@ -208,53 +208,43 @@ TD_Uniform::TD_Uniform(const ActionOptions& ao): minima_(0), maxima_(0), sigma_min_(0), - sigma_max_(0) { + sigma_max_(0) +{ parseVector("MINIMA",minima_); parseVector("MAXIMA",maxima_); parseVector("SIGMA_MINIMA",sigma_min_); parseVector("SIGMA_MAXIMA",sigma_max_); - if(minima_.size()==0 && sigma_min_.size()>0) { - plumed_merror(getName()+": you cannot give SIGMA_MINIMA if MINIMA is not given"); - } - if(maxima_.size()==0 && sigma_max_.size()>0) { - plumed_merror(getName()+": you cannot give SIGMA_MAXIMA if MAXIMA is not given"); - } + if(minima_.size()==0 && sigma_min_.size()>0) {plumed_merror(getName()+": you cannot give SIGMA_MINIMA if MINIMA is not given");} + if(maxima_.size()==0 && sigma_max_.size()>0) {plumed_merror(getName()+": you cannot give SIGMA_MAXIMA if MAXIMA is not given");} if(minima_.size()>0 && maxima_.size()>0) { // both MINIMA and MAXIMA given, do all checks - if(minima_.size()!=maxima_.size()) { - plumed_merror(getName()+": MINIMA and MAXIMA do not have the same number of values."); - } + if(minima_.size()!=maxima_.size()) {plumed_merror(getName()+": MINIMA and MAXIMA do not have the same number of values.");} setDimension(minima_.size()); for(unsigned int k=0; kmaxima_[k]) { plumed_merror(getName()+": error in MINIMA and MAXIMA keywords, one of the MINIMA values is larger than the corresponding MAXIMA values"); } } - } else if(minima_.size()>0 && maxima_.size()==0) { + } + else if(minima_.size()>0 && maxima_.size()==0) { // only MINIMA given, MAXIMA assigned later on. setDimension(minima_.size()); - } else if(maxima_.size()>0 && minima_.size()==0) { + } + else if(maxima_.size()>0 && minima_.size()==0) { // only MAXIMA given, MINIMA assigned later on. setDimension(maxima_.size()); - } else if(maxima_.size()==0 && minima_.size()==0) { + } + else if(maxima_.size()==0 && minima_.size()==0) { // neither MAXIMA nor MINIMA givenm, both assigned later on. setDimension(0); } - if(sigma_min_.size()==0) { - sigma_min_.assign(getDimension(),0.0); - } - if(sigma_max_.size()==0) { - sigma_max_.assign(getDimension(),0.0); - } - if(sigma_min_.size()!=getDimension()) { - plumed_merror(getName()+": SIGMA_MINIMA has the wrong number of values"); - } - if(sigma_max_.size()!=getDimension()) { - plumed_merror(getName()+": SIGMA_MAXIMA has the wrong number of values"); - } + if(sigma_min_.size()==0) {sigma_min_.assign(getDimension(),0.0);} + if(sigma_max_.size()==0) {sigma_max_.assign(getDimension(),0.0);} + if(sigma_min_.size()!=getDimension()) {plumed_merror(getName()+": SIGMA_MINIMA has the wrong number of values");} + if(sigma_max_.size()!=getDimension()) {plumed_merror(getName()+": SIGMA_MAXIMA has the wrong number of values");} // setForcedNormalization(); checkRead(); @@ -265,16 +255,12 @@ void TD_Uniform::setupAdditionalGrids(const std::vector& arguments, cons if(minima_.size()==0) { minima_.assign(getDimension(),0.0); - for(unsigned int k=0; k& argument) const { double tmp; if(argument[k] < minima_[k]) { tmp = GaussianSwitchingFunc(argument[k],minima_[k],sigma_min_[k]); - } else if(argument[k] > maxima_[k]) { + } + else if(argument[k] > maxima_[k]) { tmp = GaussianSwitchingFunc(argument[k],maxima_[k],sigma_max_[k]); - } else { + } + else { tmp = 1.0; } value *= tmp; @@ -302,7 +290,8 @@ double TD_Uniform::GaussianSwitchingFunc(const double argument, const double cen if(sigma>0.0) { double arg=(argument-center)/sigma; return exp(-0.5*arg*arg); - } else { + } + else { return 0.0; } } diff --git a/src/ves/TD_VonMises.cpp b/src/ves/TD_VonMises.cpp index dbf1ed1b18..d14f2d890c 100644 --- a/src/ves/TD_VonMises.cpp +++ b/src/ves/TD_VonMises.cpp @@ -131,19 +131,16 @@ TD_VonMises::TD_VonMises(const ActionOptions& ao): normalization_(0), weights_(0), periods_(0), - ncenters_(0) { + ncenters_(0) +{ for(unsigned int i=1;; i++) { std::vector tmp_center; - if(!parseNumberedVector("CENTER",i,tmp_center) ) { - break; - } + if(!parseNumberedVector("CENTER",i,tmp_center) ) {break;} centers_.push_back(tmp_center); } for(unsigned int i=1;; i++) { std::vector tmp_sigma; - if(!parseNumberedVector("SIGMA",i,tmp_sigma) ) { - break; - } + if(!parseNumberedVector("SIGMA",i,tmp_sigma) ) {break;} sigmas_.push_back(tmp_sigma); } // @@ -157,12 +154,8 @@ TD_VonMises::TD_VonMises(const ActionOptions& ao): // // check centers and sigmas for(unsigned int i=0; i arg(1); - arg[0]= points[l]; + std::vector arg(1); arg[0]= points[l]; sum += weights[l] * VonMisesDiagonal(arg,centers,kappas,periods,norm); } return 1.0/sum; diff --git a/src/ves/TD_WellTempered.cpp b/src/ves/TD_WellTempered.cpp index a7096eaacf..7d921b2830 100644 --- a/src/ves/TD_WellTempered.cpp +++ b/src/ves/TD_WellTempered.cpp @@ -121,7 +121,8 @@ void TD_WellTempered::registerKeywords(Keywords& keys) { TD_WellTempered::TD_WellTempered(const ActionOptions& ao): PLUMED_VES_TARGETDISTRIBUTION_INIT(ao), - bias_factor_(0.0) { + bias_factor_(0.0) +{ log.printf(" Well-tempered target distribution, see and cite "); log << plumed.cite("Valsson and Parrinello, J. Chem. Theory Comput. 11, 1996-2002 (2015)"); log << plumed.cite("Barducci, Bussi, and Parrinello, Phys. Rev. Lett. 100, 020603 (2008)"); diff --git a/src/ves/TargetDistribution.cpp b/src/ves/TargetDistribution.cpp index d3ded1be13..805ed5e7c1 100644 --- a/src/ves/TargetDistribution.cpp +++ b/src/ves/TargetDistribution.cpp @@ -65,7 +65,8 @@ TargetDistribution::TargetDistribution(const ActionOptions&ao): fes_grid_pntr_(NULL), static_grid_calculated(false), allow_bias_cutoff_(true), - bias_cutoff_active_(false) { + bias_cutoff_active_(false) +{ // if(keywords.exists("WELLTEMPERED_FACTOR")) { double welltempered_factor=0.0; @@ -74,7 +75,8 @@ TargetDistribution::TargetDistribution(const ActionOptions&ao): if(welltempered_factor>0.0) { auto pntr = Tools::make_unique(welltempered_factor); targetdist_modifer_pntrs_.emplace_back(std::move(pntr)); - } else if(welltempered_factor<0.0) { + } + else if(welltempered_factor<0.0) { plumed_merror(getName()+": negative value in WELLTEMPERED_FACTOR does not make sense"); } } @@ -82,9 +84,7 @@ TargetDistribution::TargetDistribution(const ActionOptions&ao): if(keywords.exists("SHIFT_TO_ZERO")) { parseFlag("SHIFT_TO_ZERO",shift_targetdist_to_zero_); if(shift_targetdist_to_zero_) { - if(bias_cutoff_active_) { - plumed_merror(getName()+": using SHIFT_TO_ZERO with bias cutoff is not allowed."); - } + if(bias_cutoff_active_) {plumed_merror(getName()+": using SHIFT_TO_ZERO with bias cutoff is not allowed.");} check_nonnegative_=false; } } @@ -93,9 +93,7 @@ TargetDistribution::TargetDistribution(const ActionOptions&ao): bool force_normalization=false; parseFlag("NORMALIZE",force_normalization); if(force_normalization) { - if(shift_targetdist_to_zero_) { - plumed_merror(getName()+" with label "+getLabel()+": using NORMALIZE with SHIFT_TO_ZERO is not needed, the target distribution will be automatically normalized."); - } + if(shift_targetdist_to_zero_) {plumed_merror(getName()+" with label "+getLabel()+": using NORMALIZE with SHIFT_TO_ZERO is not needed, the target distribution will be automatically normalized.");} setForcedNormalization(); } } @@ -177,13 +175,12 @@ void TargetDistribution::setupGrids(const std::vector& arguments, const void TargetDistribution::calculateStaticDistributionGrid() { - if(static_grid_calculated && !bias_cutoff_active_) { - return; - } + if(static_grid_calculated && !bias_cutoff_active_) {return;} // plumed_massert(isStatic(),"this should only be used for static distributions"); plumed_massert(targetdist_grid_pntr_,"the grids have not been setup using setupGrids"); plumed_massert(log_targetdist_grid_pntr_,"the grids have not been setup using setupGrids"); - for(Grid::index_t l=0; lgetSize(); l++) { + for(Grid::index_t l=0; lgetSize(); l++) + { std::vector argument = targetdist_grid_pntr_->getPoint(l); double value = getValue(argument); targetdist_grid_pntr_->setValue(l,value); @@ -219,9 +216,7 @@ Grid TargetDistribution::getMarginalDistributionGrid(Grid* grid_pntr, const std: std::vector args_index(0); for(unsigned int i=0; i 1.0+normalization_thrshold) { - std::string norm_str; - Tools::convert(normalization,norm_str); + std::string norm_str; Tools::convert(normalization,norm_str); std::string msg = "the target distribution grid is not proberly normalized, integrating over the grid gives: " + norm_str + " - You can avoid this problem by using the NORMALIZE keyword"; warning(msg); } @@ -282,16 +270,13 @@ void TargetDistribution::updateTargetDist() { const double nonnegative_thrshold = -0.02; double grid_min_value = targetdist_grid_pntr_->getMinValue(); if(grid_min_value integration_weights = GridIntegrationWeights::getIntegrationWeights(targetdist_grid_pntr_.get()); double norm = 0.0; - for(Grid::index_t l=0; lgetSize(); l++) { + for(Grid::index_t l=0; lgetSize(); l++) + { double value = targetdist_grid_pntr_->getValue(l); double bias = getBiasWithoutCutoffGridPntr()->getValue(l); double deriv_factor_swf = 0.0; @@ -329,7 +315,8 @@ void TargetDistribution::applyTargetDistModiferToGrid(TargetDistModifer* modifer // std::vector integration_weights = GridIntegrationWeights::getIntegrationWeights(targetdist_grid_pntr_.get()); double norm = 0.0; - for(Grid::index_t l=0; lgetSize(); l++) { + for(Grid::index_t l=0; lgetSize(); l++) + { double value = targetdist_grid_pntr_->getValue(l); std::vector cv_values = targetdist_grid_pntr_->getPoint(l); value = modifer_pntr->getModifedTargetDistValue(value,cv_values); @@ -343,7 +330,8 @@ void TargetDistribution::applyTargetDistModiferToGrid(TargetDistModifer* modifer void TargetDistribution::updateLogTargetDistGrid() { - for(Grid::index_t l=0; lgetSize(); l++) { + for(Grid::index_t l=0; lgetSize(); l++) + { log_targetdist_grid_pntr_->setValue(l,-std::log(targetdist_grid_pntr_->getValue(l))); } log_targetdist_grid_pntr_->setMinToZero(); @@ -378,18 +366,16 @@ void TargetDistribution::clearLogTargetDistGrid() { void TargetDistribution::checkNanAndInf() { - for(Grid::index_t l=0; lgetSize(); l++) { + for(Grid::index_t l=0; lgetSize(); l++) + { double value = targetdist_grid_pntr_->getValue(l); if(std::isnan(value) || std::isinf(value)) { - std::string vs; - Tools::convert(value,vs); + std::string vs; Tools::convert(value,vs); std::vector p = targetdist_grid_pntr_->getPoint(l); - std::string ps; - Tools::convert(p[0],ps); + std::string ps; Tools::convert(p[0],ps); ps = "(" + ps; for(unsigned int k=1; k0.0) { kbt_=plumed.getAtoms().getKBoltzmann()*temp; - } else { + } + else { kbt_=plumed.getAtoms().getKbT(); } if(kbt_>0.0) { @@ -113,15 +115,14 @@ VesBias::VesBias(const ActionOptions&ao): if(targetdist_labels.size()>1) { plumed_merror(getName()+" with label "+getLabel()+": multiple target distribution labels not allowed"); } - } else if(keywords.exists("TARGET_DISTRIBUTIONS")) { + } + else if(keywords.exists("TARGET_DISTRIBUTIONS")) { parseVector("TARGET_DISTRIBUTIONS",targetdist_labels); } std::string error_msg = ""; targetdist_pntrs_ = VesTools::getPointersFromLabels(targetdist_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Problem with target distribution in "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Problem with target distribution in "+getName()+": "+error_msg);} for(unsigned int i=0; ilinkVesBias(this); @@ -187,9 +188,7 @@ VesBias::VesBias(const ActionOptions&ao): if(keywords.exists("PROJ_ARG")) { std::vector proj_arg; for(int i=1;; i++) { - if(!parseNumberedVector("PROJ_ARG",i,proj_arg)) { - break; - } + if(!parseNumberedVector("PROJ_ARG",i,proj_arg)) {break;} // checks if(proj_arg.size() > (getNumberOfArguments()-1) ) { plumed_merror("PROJ_ARG must be a subset of ARG"); @@ -204,8 +203,7 @@ VesBias::VesBias(const ActionOptions&ao): } } if(!found) { - std::string s1; - Tools::convert(i,s1); + std::string s1; Tools::convert(i,s1); std::string error = "PROJ_ARG" + s1 + ": label " + proj_arg[k] + " is not among the arguments given in ARG"; plumed_merror(error); } @@ -218,8 +216,7 @@ VesBias::VesBias(const ActionOptions&ao): if(keywords.exists("CALC_REWEIGHT_FACTOR")) { parseFlag("CALC_REWEIGHT_FACTOR",calc_reweightfactor_); if(calc_reweightfactor_) { - addComponent("rct"); - componentIsNotPeriodic("rct"); + addComponent("rct"); componentIsNotPeriodic("rct"); updateReweightFactor(); } } @@ -387,7 +384,8 @@ bool VesBias::readCoeffsFromFiles() { plumed_massert(coeffs_fnames.size()==ncoeffssets_,"COEFFS keyword is of the wrong size"); if(ncoeffssets_==1) { log.printf(" Read in coefficients from file "); - } else { + } + else { log.printf(" Read in coefficients from files:\n"); } for(unsigned int i=0; isetIterationCounterAndTime(0,getTime()); if(ncoeffssets_==1) { log.printf("%s (read %zu of %zu values)\n", ifile.getPath().c_str(),ncoeffs_read,coeffs_pntrs_[i]->numberOfCoeffs()); - } else { + } + else { log.printf(" coefficient %u: %s (read %zu of %zu values)\n",i,ifile.getPath().c_str(),ncoeffs_read,coeffs_pntrs_[i]->numberOfCoeffs()); } ifile.close(); @@ -420,9 +419,7 @@ void VesBias::updateGradientAndHessian(const bool use_mwalkers_mpi) { comm.Sum(sampled_cross_averages[k]); if(use_mwalkers_mpi) { double walker_weight=1.0; - if(aver_counters[k]==0) { - walker_weight=0.0; - } + if(aver_counters[k]==0) {walker_weight=0.0;} multiSimSumAverages(k,walker_weight); } // NOTE: this assumes that all walkers have the same TargetDist, might change later on!! @@ -446,9 +443,7 @@ void VesBias::updateGradientAndHessian(const bool use_mwalkers_mpi) { // is zero unsigned int total_samples = aver_counters[k]; if(use_mwalkers_mpi) { - if(comm.Get_rank()==0) { - multi_sim_comm.Sum(total_samples); - } + if(comm.Get_rank()==0) {multi_sim_comm.Sum(total_samples);} comm.Bcast(total_samples,0); } if(total_samples==0) { @@ -481,9 +476,7 @@ void VesBias::multiSimSumAverages(const unsigned int c_id, const double walker_w multi_sim_comm.Sum(sampled_cross_averages[c_id]); double norm_weights = walker_weight; multi_sim_comm.Sum(norm_weights); - if(norm_weights>0.0) { - norm_weights=1.0/norm_weights; - } + if(norm_weights>0.0) {norm_weights=1.0/norm_weights;} for(size_t i=0; igetIterationCounter(); - } else { + } + else { iteration = getCoeffsPntrs()[0]->getIterationCounter(); } return iteration; @@ -570,7 +564,8 @@ void VesBias::linkOptimizer(Optimizer* optimizer_pntr_in) { // if(optimizer_pntr_==NULL) { optimizer_pntr_ = optimizer_pntr_in; - } else { + } + else { std::string err_msg = "VES bias " + getLabel() + " of type " + getName() + " has already been linked with optimizer " + optimizer_pntr_->getLabel() + " of type " + optimizer_pntr_->getName() + ". You cannot link two optimizer to the same VES bias."; plumed_merror(err_msg); } @@ -625,18 +620,12 @@ std::unique_ptr VesBias::getOFile(const std::string& filepath, const bool auto ofile_pntr = Tools::make_unique(); std::string fp = filepath; ofile_pntr->link(*static_cast(this)); - if(enforce_backup) { - ofile_pntr->enforceBackup(); - } + if(enforce_backup) {ofile_pntr->enforceBackup();} if(multi_sim_single_file) { unsigned int r=0; - if(comm.Get_rank()==0) { - r=multi_sim_comm.Get_rank(); - } + if(comm.Get_rank()==0) {r=multi_sim_comm.Get_rank();} comm.Bcast(r,0); - if(r>0) { - fp="/dev/null"; - } + if(r>0) {fp="/dev/null";} ofile_pntr->enforceSuffix(""); } ofile_pntr->open(fp); @@ -714,12 +703,9 @@ void VesBias::setupBiasCutoff(const double bias_cutoff_value, const double fermi // double fermi_exp_max = 100.0; // - std::string str_bias_cutoff_value; - VesTools::convertDbl2Str(bias_cutoff_value,str_bias_cutoff_value); - std::string str_fermi_lambda; - VesTools::convertDbl2Str(fermi_lambda,str_fermi_lambda); - std::string str_fermi_exp_max; - VesTools::convertDbl2Str(fermi_exp_max,str_fermi_exp_max); + std::string str_bias_cutoff_value; VesTools::convertDbl2Str(bias_cutoff_value,str_bias_cutoff_value); + std::string str_fermi_lambda; VesTools::convertDbl2Str(fermi_lambda,str_fermi_lambda); + std::string str_fermi_exp_max; VesTools::convertDbl2Str(fermi_exp_max,str_fermi_exp_max); std::string swfunc_keywords = "FERMI R_0=" + str_bias_cutoff_value + " FERMI_LAMBDA=" + str_fermi_lambda + " FERMI_EXP_MAX=" + str_fermi_exp_max; // std::string swfunc_errors=""; diff --git a/src/ves/VesBias.h b/src/ves/VesBias.h index 5b2f891dc0..c7c0ec0ff3 100644 --- a/src/ves/VesBias.h +++ b/src/ves/VesBias.h @@ -58,7 +58,8 @@ to include functions related to the variational approach. */ class VesBias: - public bias::Bias { + public bias::Bias +{ private: unsigned int ncoeffssets_; std::vector> coeffs_pntrs_; @@ -133,9 +134,7 @@ class VesBias: void addCoeffsSet(std::unique_ptr); // std::string getCoeffsSetLabelString(const std::string&, const unsigned int coeffs_id = 0) const; - void clearCoeffsPntrsVector() { - coeffs_pntrs_.clear(); - } + void clearCoeffsPntrsVector() {coeffs_pntrs_.clear();} void addToSampledAverages(const std::vector&, const unsigned int c_id = 0); void setTargetDistAverages(const std::vector&, const unsigned int coeffs_id = 0); void setTargetDistAverages(const CoeffsVector&, const unsigned int coeffs_id= 0); @@ -162,83 +161,39 @@ class VesBias: static void useProjectionArgKeywords(Keywords&); static void useReweightFactorKeywords(Keywords&); // - std::vector getCoeffsPntrs() const { - return Tools::unique2raw(coeffs_pntrs_); - } - std::vector getTargetDistAveragesPntrs() const { - return Tools::unique2raw(targetdist_averages_pntrs_); - } - std::vector getGradientPntrs()const { - return Tools::unique2raw(gradient_pntrs_); - } - std::vector getHessianPntrs() const { - return Tools::unique2raw(hessian_pntrs_); - } - std::vector getTargetDistributionPntrs() const { - return targetdist_pntrs_; - } + std::vector getCoeffsPntrs() const {return Tools::unique2raw(coeffs_pntrs_);} + std::vector getTargetDistAveragesPntrs() const {return Tools::unique2raw(targetdist_averages_pntrs_);} + std::vector getGradientPntrs()const {return Tools::unique2raw(gradient_pntrs_);} + std::vector getHessianPntrs() const {return Tools::unique2raw(hessian_pntrs_);} + std::vector getTargetDistributionPntrs() const {return targetdist_pntrs_;} // - CoeffsVector* getCoeffsPntr(const unsigned int coeffs_id = 0) const { - return coeffs_pntrs_[coeffs_id].get(); - } - CoeffsVector* getTargetDistAveragesPntr(const unsigned int coeffs_id = 0) const { - return targetdist_averages_pntrs_[coeffs_id].get(); - } - CoeffsVector* getGradientPntr(const unsigned int coeffs_id = 0)const { - return gradient_pntrs_[coeffs_id].get(); - } - CoeffsMatrix* getHessianPntr(const unsigned int coeffs_id = 0) const { - return hessian_pntrs_[coeffs_id].get(); - } + CoeffsVector* getCoeffsPntr(const unsigned int coeffs_id = 0) const {return coeffs_pntrs_[coeffs_id].get();} + CoeffsVector* getTargetDistAveragesPntr(const unsigned int coeffs_id = 0) const {return targetdist_averages_pntrs_[coeffs_id].get();} + CoeffsVector* getGradientPntr(const unsigned int coeffs_id = 0)const {return gradient_pntrs_[coeffs_id].get();} + CoeffsMatrix* getHessianPntr(const unsigned int coeffs_id = 0) const {return hessian_pntrs_[coeffs_id].get();} // - unsigned int getNumberOfTargetDistributionPntrs() const { - return targetdist_pntrs_.size(); - } + unsigned int getNumberOfTargetDistributionPntrs() const {return targetdist_pntrs_.size();} // - size_t numberOfCoeffs(const unsigned int coeffs_id = 0) const { - return coeffs_pntrs_[coeffs_id]->numberOfCoeffs(); - } - size_t totalNumberOfCoeffs() const { - return ncoeffs_total_; - } - unsigned int numberOfCoeffsSets() const { - return ncoeffssets_; - } - double getKbT() const { - return kbt_; - } + size_t numberOfCoeffs(const unsigned int coeffs_id = 0) const {return coeffs_pntrs_[coeffs_id]->numberOfCoeffs();} + size_t totalNumberOfCoeffs() const {return ncoeffs_total_;} + unsigned int numberOfCoeffsSets() const {return ncoeffssets_;} + double getKbT() const {return kbt_;} double getBeta() const; // - CoeffsVector& Coeffs(const unsigned int coeffs_id = 0) const { - return *coeffs_pntrs_[coeffs_id]; - } - CoeffsVector& TargetDistAverages(const unsigned int coeffs_id = 0) const { - return *targetdist_averages_pntrs_[coeffs_id]; - } - CoeffsVector& Gradient(const unsigned int coeffs_id = 0) const { - return *gradient_pntrs_[coeffs_id]; - } - CoeffsMatrix& Hessian(const unsigned int coeffs_id = 0) const { - return *hessian_pntrs_[coeffs_id]; - } + CoeffsVector& Coeffs(const unsigned int coeffs_id = 0) const {return *coeffs_pntrs_[coeffs_id];} + CoeffsVector& TargetDistAverages(const unsigned int coeffs_id = 0) const {return *targetdist_averages_pntrs_[coeffs_id];} + CoeffsVector& Gradient(const unsigned int coeffs_id = 0) const {return *gradient_pntrs_[coeffs_id];} + CoeffsMatrix& Hessian(const unsigned int coeffs_id = 0) const {return *hessian_pntrs_[coeffs_id];} // size_t getCoeffsIndex(const std::vector& indices, const unsigned int coeffs_id = 0) const; std::vector getCoeffsIndices(const size_t index, const unsigned int coeffs_id = 0) const; size_t getHessianIndex(const size_t index1, const size_t index2, const unsigned int coeffs_id = 0) const; // - bool computeHessian() const { - return compute_hessian_; - } - bool diagonalHessian() const { - return diagonal_hessian_; - } + bool computeHessian() const {return compute_hessian_;} + bool diagonalHessian() const {return diagonal_hessian_;} // - bool optimizeCoeffs() const { - return optimize_coeffs_; - } - Optimizer* getOptimizerPntr() const { - return optimizer_pntr_; - } + bool optimizeCoeffs() const {return optimize_coeffs_;} + Optimizer* getOptimizerPntr() const {return optimizer_pntr_;} bool useMultipleWalkers() const; // unsigned int getIterationCounter() const; @@ -253,142 +208,66 @@ class VesBias: void enableHessian(const bool diagonal_hessian=true); void disableHessian(); // - void enableMultipleCoeffsSets() { - use_multiple_coeffssets_=true; - } + void enableMultipleCoeffsSets() {use_multiple_coeffssets_=true;} // - void enableDynamicTargetDistribution() { - dynamic_targetdist_=true; - } - void disableDynamicTargetDistribution() { - dynamic_targetdist_=false; - } - bool dynamicTargetDistribution() const { - return dynamic_targetdist_; - } + void enableDynamicTargetDistribution() {dynamic_targetdist_=true;} + void disableDynamicTargetDistribution() {dynamic_targetdist_=false;} + bool dynamicTargetDistribution() const {return dynamic_targetdist_;} // - std::vector getGridBins() const { - return grid_bins_; - } + std::vector getGridBins() const {return grid_bins_;} void setGridBins(const std::vector&); void setGridBins(const unsigned int); - std::vector getGridMax() const { - return grid_max_; - } + std::vector getGridMax() const {return grid_max_;} void setGridMax(const std::vector&); - std::vector getGridMin() const { - return grid_min_; - } + std::vector getGridMin() const {return grid_min_;} void setGridMin(const std::vector&); // - bool filenamesIncludeIterationNumber() const { - return filenames_have_iteration_number_; - } - void enableIterationNumberInFilenames() { - filenames_have_iteration_number_=true; - } + bool filenamesIncludeIterationNumber() const {return filenames_have_iteration_number_;} + void enableIterationNumberInFilenames() {filenames_have_iteration_number_=true;} // std::string getIterationFilenameSuffix() const; std::string getCoeffsSetFilenameSuffix(const unsigned int coeffs_id) const; std::string getCurrentOutputFilename(const std::string&, const std::string& suffix="") const; - std::string getBiasOutputFilename() const { - return bias_filename_; - } + std::string getBiasOutputFilename() const {return bias_filename_;} std::string getCurrentBiasOutputFilename(const std::string& suffix="") const; - std::string getFesOutputFilename() const { - return fes_filename_; - } + std::string getFesOutputFilename() const {return fes_filename_;} std::string getCurrentFesOutputFilename(const std::string& suffix="") const; - std::string getTargetDistOutputFilename() const { - return targetdist_filename_; - } + std::string getTargetDistOutputFilename() const {return targetdist_filename_;} std::string getCurrentTargetDistOutputFilename(const std::string& suffix="") const; // - void enableBiasFileOutput() { - bias_fileoutput_active_=true; - } - void disableBiasFileOutput() { - bias_fileoutput_active_=false; - } - bool isBiasFileOutputActive() const { - return bias_fileoutput_active_; - } - std::string getBiasFileFmt() const { - return bias_file_fmt_; - } + void enableBiasFileOutput() {bias_fileoutput_active_=true;} + void disableBiasFileOutput() {bias_fileoutput_active_=false;} + bool isBiasFileOutputActive() const {return bias_fileoutput_active_;} + std::string getBiasFileFmt() const {return bias_file_fmt_;} // - void enableFesFileOutput() { - fes_fileoutput_active_=true; - } - void disableFesFileOutput() { - fes_fileoutput_active_=false; - } - bool isFesFileOutputActive() const { - return fes_fileoutput_active_; - } - std::string getFesFileFmt() const { - return fes_file_fmt_; - } + void enableFesFileOutput() {fes_fileoutput_active_=true;} + void disableFesFileOutput() {fes_fileoutput_active_=false;} + bool isFesFileOutputActive() const {return fes_fileoutput_active_;} + std::string getFesFileFmt() const {return fes_file_fmt_;} // - void enableFesProjFileOutput() { - fesproj_fileoutput_active_=true; - } - void disableFesFileProjOutput() { - fesproj_fileoutput_active_=false; - } - bool isFesProjFileOutputActive() const { - return fesproj_fileoutput_active_; - } + void enableFesProjFileOutput() {fesproj_fileoutput_active_=true;} + void disableFesFileProjOutput() {fesproj_fileoutput_active_=false;} + bool isFesProjFileOutputActive() const {return fesproj_fileoutput_active_;} // - void enableDynamicTargetDistFileOutput() { - dynamic_targetdist_fileoutput_active_=true; - } - void disableDynamicTargetDistFileOutput() { - dynamic_targetdist_fileoutput_active_=false; - } - bool isDynamicTargetDistFileOutputActive() const { - return dynamic_targetdist_fileoutput_active_; - } - std::string getTargetDistFileFmt() const { - return targetdist_file_fmt_; - } - std::string getTargetDistRestartFileFmt() const { - return targetdist_restart_file_fmt_; - } + void enableDynamicTargetDistFileOutput() {dynamic_targetdist_fileoutput_active_=true;} + void disableDynamicTargetDistFileOutput() {dynamic_targetdist_fileoutput_active_=false;} + bool isDynamicTargetDistFileOutputActive() const {return dynamic_targetdist_fileoutput_active_;} + std::string getTargetDistFileFmt() const {return targetdist_file_fmt_;} + std::string getTargetDistRestartFileFmt() const {return targetdist_restart_file_fmt_;} // - void enableStaticTargetDistFileOutput() { - static_targetdist_fileoutput_active_=true; - } - void disableStaticTargetDistFileOutput() { - static_targetdist_fileoutput_active_=false; - } - bool isStaticTargetDistFileOutputActive() const { - return static_targetdist_fileoutput_active_; - } + void enableStaticTargetDistFileOutput() {static_targetdist_fileoutput_active_=true;} + void disableStaticTargetDistFileOutput() {static_targetdist_fileoutput_active_=false;} + bool isStaticTargetDistFileOutputActive() const {return static_targetdist_fileoutput_active_;} // - std::vector< std::vector > getProjectionArguments() const { - return projection_args_; - } - std::vector getProjectionArgument(unsigned int i) const { - return projection_args_[i]; - } - unsigned int getNumberOfProjectionArguments() const { - return projection_args_.size(); - } + std::vector< std::vector > getProjectionArguments() const {return projection_args_;} + std::vector getProjectionArgument(unsigned int i) const {return projection_args_[i];} + unsigned int getNumberOfProjectionArguments() const {return projection_args_.size();} // void setupBiasCutoff(const double, const double); - bool biasCutoffActive() const { - return bias_cutoff_active_; - } - double getBiasCutoffValue() const { - return bias_cutoff_value_; - } - void setCurrentBiasMaxValue(const double max_value) { - bias_current_max_value=max_value; - } - double getCurrentBiasMaxValue() const { - return bias_current_max_value; - } + bool biasCutoffActive() const {return bias_cutoff_active_;} + double getBiasCutoffValue() const {return bias_cutoff_value_;} + void setCurrentBiasMaxValue(const double max_value) {bias_current_max_value=max_value;} + double getCurrentBiasMaxValue() const {return bias_current_max_value;} double getBiasCutoffSwitchingFunction(const double, double&) const; double getBiasCutoffSwitchingFunction(const double) const; void applyBiasCutoff(double&, std::vector&) const; @@ -418,26 +297,18 @@ class VesBias: // void updateReweightFactor(); virtual double calculateReweightFactor() const; - bool isReweightFactorCalculated() const { - return calc_reweightfactor_; - } + bool isReweightFactorCalculated() const {return calc_reweightfactor_;} }; inline -size_t VesBias::getCoeffsIndex(const std::vector& indices, const unsigned int coeffs_id) const { - return coeffs_pntrs_[coeffs_id]->getIndex(indices); -} +size_t VesBias::getCoeffsIndex(const std::vector& indices, const unsigned int coeffs_id) const {return coeffs_pntrs_[coeffs_id]->getIndex(indices);} inline -std::vector VesBias::getCoeffsIndices(const size_t index, const unsigned int coeffs_id) const { - return coeffs_pntrs_[coeffs_id]->getIndices(index); -} +std::vector VesBias::getCoeffsIndices(const size_t index, const unsigned int coeffs_id) const {return coeffs_pntrs_[coeffs_id]->getIndices(index);} inline -size_t VesBias::getHessianIndex(const size_t index1, const size_t index2, const unsigned int coeffs_id) const { - return hessian_pntrs_[coeffs_id]->getMatrixIndex(index1,index2); -} +size_t VesBias::getHessianIndex(const size_t index1, const size_t index2, const unsigned int coeffs_id) const {return hessian_pntrs_[coeffs_id]->getMatrixIndex(index1,index2);} inline @@ -521,8 +392,7 @@ bool VesBias::parseMultipleValues(const std::string& keyword, std::vector& va identical_values=true; } if(values.size()>0 && values.size()!=nvalues) { - std::string s1; - Tools::convert(nvalues,s1); + std::string s1; Tools::convert(nvalues,s1); plumed_merror("Error in " + keyword + " keyword: either give 1 common parameter value or " + s1 + " separate parameter values"); } return identical_values; diff --git a/src/ves/VesDeltaF.cpp b/src/ves/VesDeltaF.cpp index 8226dc30a8..3e756f24e4 100644 --- a/src/ves/VesDeltaF.cpp +++ b/src/ves/VesDeltaF.cpp @@ -222,13 +222,15 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) , afterCalculate_(false) , mean_counter_(0) , av_counter_(0) - , work_(0) { + , work_(0) +{ //set beta const double Kb=plumed.getAtoms().getKBoltzmann(); double temp=0; parse("TEMP",temp); double KbT=Kb*temp; - if(KbT==0) { + if(KbT==0) + { KbT=plumed.getAtoms().getKbT(); plumed_massert(KbT>0,"your MD engine does not pass the temperature to plumed, you must specify it using TEMP"); } @@ -240,11 +242,11 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) std::string funcl="file.free"; //typical name given by sum_hills std::vector fes_names; - for(unsigned n=0;; n++) { //NB: here we start from FILE_F0 not from FILE_F1 + for(unsigned n=0;; n++)//NB: here we start from FILE_F0 not from FILE_F1 + { std::string filename; - if(!parseNumbered("FILE_F",n,filename)) { + if(!parseNumbered("FILE_F",n,filename)) break; - } fes_names.push_back(filename); IFile gridfile; gridfile.open(filename); @@ -262,7 +264,8 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) alpha_size_=grid_p_.size()-1; sym_alpha_size_=alpha_size_*(alpha_size_+1)/2; //useful for symmetric matrix [alpha_size_]x[alpha_size_] //check for consistency with first local free energy - for(unsigned n=1; ngetSize()==grid_p_[0]->getSize(),error_tag); plumed_massert(grid_p_[n]->getMin()==grid_p_[0]->getMin(),error_tag); @@ -272,10 +275,10 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) bool no_mintozero=false; parseFlag("NO_MINTOZERO",no_mintozero); - if(!no_mintozero) { - for(unsigned n=0; nsetMinToZero(); - } } bool normalize=false; parseFlag("NORMALIZE",normalize); @@ -284,18 +287,20 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) //convert the FESs to probability distributions //NB: the spline interpolation will be done on the probability distributions, not on the given FESs const unsigned ncv=getNumberOfArguments(); //just for ease - for(unsigned n=0; ngetSize(); t++) { + for(unsigned n=0; ngetSize(); t++) + { std::vector der(ncv); const double val=std::exp(-beta_*grid_p_[n]->getValueAndDerivatives(t,der)); - for(unsigned s=0; ssetValueAndDerivatives(t,val,der); norm_[n]+=val; } c_norm[n]=1./beta_*std::log(norm_[n]); - if(normalize) { + if(normalize) + { grid_p_[n]->scaleAllValuesAndDerivatives(1./norm_[n]); norm_[n]=1; } @@ -305,11 +310,10 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) double biasfactor=0; parse("BIASFACTOR",biasfactor); plumed_massert(biasfactor==0 || biasfactor>1,"BIASFACTOR must be zero (for uniform target) or greater than one"); - if(biasfactor==0) { + if(biasfactor==0) inv_gamma_=0; - } else { + else inv_gamma_=1./biasfactor; - } tg_counter_=0; tg_stride_=1; parse("TG_STRIDE",tg_stride_); @@ -328,31 +332,31 @@ VesDeltaF::VesDeltaF(const ActionOptions&ao) mean_weight_tau_=0; parse("TAU_MEAN",mean_weight_tau_); - if(mean_weight_tau_!=1) { //set it to 1 for basic SGD + if(mean_weight_tau_!=1) //set it to 1 for basic SGD + { plumed_massert((mean_weight_tau_==0 || mean_weight_tau_>av_stride_),"TAU_MEAN is rescaled with AV_STRIDE, so it has to be greater"); mean_weight_tau_/=av_stride_; //this way you can look at the number of simulation steps to choose TAU_MEAN } parseVector("INITIAL_ALPHA",mean_alpha_); - if(mean_alpha_.size()>0) { + if(mean_alpha_.size()>0) + { plumed_massert(mean_alpha_.size()==alpha_size_,"provide one INITIAL_ALPHA for each basin beyond the first one"); - } else { - mean_alpha_.resize(alpha_size_,0); } + else + mean_alpha_.resize(alpha_size_,0); inst_alpha_=mean_alpha_; exp_alpha_.resize(alpha_size_); - for(unsigned i=0; i1) { //if each walker has more than one processor update them all + if(comm.Get_size()>1) //if each walker has more than one processor update them all comm.Bcast(NumWalkers_,0); - } } checkRead(); //restart if needed - if(getRestart()) { + if(getRestart()) + { IFile ifile; ifile.link(*this); - if(NumWalkers_>1) { + if(NumWalkers_>1) ifile.enforceSuffix(""); - } - if(ifile.FileExist(alphaFileName)) { + if(ifile.FileExist(alphaFileName)) + { log.printf(" Restarting from: %s\n",alphaFileName.c_str()); log.printf(" all options (also PRINT_STRIDE) must be consistent!\n"); log.printf(" any INITIAL_ALPHA will be overwritten\n"); ifile.open(alphaFileName); double time; std::vector damping(alpha_size_); - while(ifile.scanField("time",time)) { //room for improvements: only last line is important - for(unsigned i=0; i1) { - if(comm.Get_rank()==0 && multi_sim_comm.Get_rank()>0) { - alphaFileName="/dev/null"; //only first walker writes on file - } + if(NumWalkers_>1) + { + if(comm.Get_rank()==0 && multi_sim_comm.Get_rank()>0) + alphaFileName="/dev/null"; //only first walker writes on file alphaOfile_.enforceSuffix(""); } alphaOfile_.open(alphaFileName); - if(fmt.length()>0) { + if(fmt.length()>0) alphaOfile_.fmtField(" "+fmt); - } //add other output components - addComponent("rct"); - componentIsNotPeriodic("rct"); - addComponent("work"); - componentIsNotPeriodic("work"); + addComponent("rct"); componentIsNotPeriodic("rct"); + addComponent("work"); componentIsNotPeriodic("work"); //print some info log.printf(" Temperature T: %g\n",1./(Kb*beta_)); log.printf(" Beta (1/Kb*T): %g\n",beta_); log.printf(" Local free energy basins files and normalization constants:\n"); - for(unsigned n=0; n1) { + if(mean_weight_tau_>1) log.printf(" Exponentially decaying average with weight=tau/av_stride=%d\n",mean_weight_tau_); - } - if(mean_weight_tau_==1) { + if(mean_weight_tau_==1) log.printf(" +++ WARNING +++ setting TAU_MEAN=1 is equivalent to use simple SGD, without mean alpha nor hessian contribution\n"); - } log.printf(" Initial guess for alpha:\n"); - for(unsigned i=0; i1) { + if(NumParallel_>1) log.printf(" Using multiple threads per simulation: %d\n",NumParallel_); - } - if(multiple_walkers) { + if(multiple_walkers) + { log.printf(" -- MULTIPLE_WALKERS: multiple simulations will combine statistics for the optimization\n"); - if(NumWalkers_>1) { + if(NumWalkers_>1) + { log.printf(" number of walkers: %d\n",NumWalkers_); log.printf(" walker rank: %d\n",multi_sim_comm.Get_rank()); //only comm.Get_rank()=0 prints, so this is fine - } else { - log.printf(" +++ WARNING +++ only one replica found: are you sure you are running MPI-connected simulations?\n"); } + else + log.printf(" +++ WARNING +++ only one replica found: are you sure you are running MPI-connected simulations?\n"); } log.printf(" Bibliography "); log<0) { + if(inv_gamma_>0) log< cv(ncv); - for(unsigned s=0; sgetValueAndDerivatives(cv,der_prob_[n]); - } tot_prob_=prob_[0]; - for(unsigned i=0; i dV_dAlpha(alpha_size_); std::vector d2V_dAlpha2(sym_alpha_size_); - for(unsigned i=0; igetSize(); t+=NumParallel_) { - //TODO can we recycle some code? + for(Grid::index_t t=rank_; tgetSize(); t+=NumParallel_) + { //TODO can we recycle some code? std::vector prob(grid_p_.size()); - for(unsigned n=0; ngetValue(t); - } double tot_prob=prob[0]; - for(unsigned i=0; i dV_dAlpha(alpha_size_); std::vector d2V_dAlpha2(sym_alpha_size_); - for(unsigned i=0; i1) { + if(NumParallel_>1) + { comm.Sum(Z_tg); comm.Sum(tg_dV_dAlpha_); comm.Sum(tg_d2V_dAlpha2_); } - for(unsigned i=0; iset(-1./beta_*std::log(Z_tg/Z_0)); //Z_tg is the best available estimate of Z_V } -void VesDeltaF::update_alpha() { +void VesDeltaF::update_alpha() +{ //combining the averages of multiple walkers - if(NumWalkers_>1) { - if(comm.Get_rank()==0) { //sum only once: in the first rank of each walker + if(NumWalkers_>1) + { + if(comm.Get_rank()==0) //sum only once: in the first rank of each walker + { multi_sim_comm.Sum(av_dV_dAlpha_); multi_sim_comm.Sum(av_dV_dAlpha_prod_); multi_sim_comm.Sum(av_d2V_dAlpha2_); - for(unsigned i=0; i1) { //if there are more ranks for each walker, everybody has to know + if(comm.Get_size()>1)//if there are more ranks for each walker, everybody has to know + { comm.Bcast(av_dV_dAlpha_,0); comm.Bcast(av_dV_dAlpha_prod_,0); comm.Bcast(av_d2V_dAlpha2_,0); @@ -668,9 +664,11 @@ void VesDeltaF::update_alpha() { //build the gradient and the Hessian of the functional std::vector grad_omega(alpha_size_); std::vector hess_omega(sym_alpha_size_); - for(unsigned i=0; i0 && mean_weight_tau_0 && mean_weight_tau_ damping(alpha_size_); - for(unsigned i=0; i basisf_labels; parseMultipleValues("BASIS_FUNCTIONS",basisf_labels,nargs_); checkRead(); std::string error_msg = ""; basisf_pntrs_ = VesTools::getPointersFromLabels(basisf_labels,plumed.getActionSet(),error_msg); - if(error_msg.size()>0) { - plumed_merror("Error in keyword BASIS_FUNCTIONS of "+getName()+": "+error_msg); - } + if(error_msg.size()>0) {plumed_merror("Error in keyword BASIS_FUNCTIONS of "+getName()+": "+error_msg);} // std::vector args_pntrs = getArguments(); @@ -359,7 +358,8 @@ VesLinearExpansion::VesLinearExpansion(const ActionOptions&ao): for(unsigned int i=0; iisPeriodic() && !(basisf_pntrs_[i]->arePeriodic()) ) { plumed_merror("argument "+args_pntrs[i]->getName()+" is periodic while the basis functions " + basisf_pntrs_[i]->getLabel()+ " are not. You need to use the COMBINE action to remove the periodicity of the argument if you want to use these basis functions"); - } else if(!(args_pntrs[i]->isPeriodic()) && basisf_pntrs_[i]->arePeriodic() ) { + } + else if(!(args_pntrs[i]->isPeriodic()) && basisf_pntrs_[i]->arePeriodic() ) { log.printf(" warning: argument %s is not periodic while the basis functions %s used for it are periodic\n",args_pntrs[i]->getName().c_str(),basisf_pntrs_[i]->getLabel().c_str()); } } @@ -381,13 +381,13 @@ VesLinearExpansion::VesLinearExpansion(const ActionOptions&ao): log.printf(" using an uniform target distribution: \n"); bias_expansion_pntr_->setupUniformTargetDistribution(); disableStaticTargetDistFileOutput(); - } else if(getNumberOfTargetDistributionPntrs()==1) { - if(biasCutoffActive()) { - getTargetDistributionPntrs()[0]->setupBiasCutoff(); - } + } + else if(getNumberOfTargetDistributionPntrs()==1) { + if(biasCutoffActive()) {getTargetDistributionPntrs()[0]->setupBiasCutoff();} bias_expansion_pntr_->setupTargetDistribution(getTargetDistributionPntrs()[0]); log.printf(" using target distribution of type %s with label %s \n",getTargetDistributionPntrs()[0]->getName().c_str(),getTargetDistributionPntrs()[0]->getLabel().c_str()); - } else { + } + else { plumed_merror("problem with the TARGET_DISTRIBUTION keyword, either give no label or just one label."); } setTargetDistAverages(bias_expansion_pntr_->TargetDistAverages()); @@ -401,8 +401,7 @@ VesLinearExpansion::VesLinearExpansion(const ActionOptions&ao): VesLinearExpansion::writeBiasToFile(); } - addComponent("force2"); - componentIsNotPeriodic("force2"); + addComponent("force2"); componentIsNotPeriodic("force2"); valueForce2_=getPntrToComponent("force2"); } diff --git a/src/ves/VesTools.cpp b/src/ves/VesTools.cpp index a126df55a5..8969454dc4 100644 --- a/src/ves/VesTools.cpp +++ b/src/ves/VesTools.cpp @@ -46,8 +46,7 @@ void VesTools::copyGridValues(GridBase* grid_pntr_orig, GridBase* grid_pntr_copy unsigned int VesTools::getGridFileInfo(const std::string& filepath, std::string& grid_label, std::vector& arg_labels, std::vector& arg_min, std::vector& arg_max, std::vector& arg_periodic, std::vector& arg_nbins, bool& derivatives) { - IFile ifile; - ifile.open(filepath); + IFile ifile; ifile.open(filepath); std::vector fields; ifile.scanFieldList(fields); ifile.allowIgnoredFields(); @@ -59,7 +58,8 @@ unsigned int VesTools::getGridFileInfo(const std::string& filepath, std::string& derivatives = false; nargs = i-1; break; - } else if(fields[i]=="der_"+fields[0]) { + } + else if(fields[i]=="der_"+fields[0]) { derivatives = true; nargs = i-1; break; @@ -79,9 +79,7 @@ unsigned int VesTools::getGridFileInfo(const std::string& filepath, std::string& ifile.scanField("max_"+arg_labels[i],arg_max[i]); std::string str_periodic; ifile.scanField("periodic_"+arg_labels[i],str_periodic); - if(str_periodic=="true") { - arg_periodic[i]=true; - } + if(str_periodic=="true") {arg_periodic[i]=true;} int nbins; ifile.scanField("nbins_"+arg_labels[i],nbins); arg_nbins[i] = static_cast(nbins); diff --git a/src/ves/VesTools.h b/src/ves/VesTools.h index 8ee52cea79..926c641e1e 100644 --- a/src/ves/VesTools.h +++ b/src/ves/VesTools.h @@ -72,9 +72,7 @@ void VesTools::convertDbl2Str(const double value,std::string& str) { inline unsigned int log2(unsigned value) { unsigned int result = 0; - while(value >>= 1) { - result++; - } + while(value >>= 1) result++; return result; } @@ -114,11 +112,10 @@ std::vector VesTools::getPointersFromLabels(const std::vector& a if(missing.size()>0) { if(missing.size()==1) { error_msg = "label "+missing[0]+" does not exist\n"; - } else if(missing.size()>1) { + } + else if(missing.size()>1) { std::string tmp=""; - for(unsigned int j=0; j avail_action_pntrs = actionset.select(); @@ -127,7 +124,8 @@ std::vector VesTools::getPointersFromLabels(const std::vector& a for(unsigned int i=0; igetName() + " with label " + avail_action_pntrs[i]->getLabel() + "\n"; } - } else { + } + else { error_msg += " Hint! no actions defined in the input file that can be used here, they should be defined before this actions\n"; } } diff --git a/src/ves/WaveletGrid.cpp b/src/ves/WaveletGrid.cpp index efde4de3ae..6f6b42eabf 100644 --- a/src/ves/WaveletGrid.cpp +++ b/src/ves/WaveletGrid.cpp @@ -42,9 +42,7 @@ std::unique_ptr WaveletGrid::setupGrid(const unsigned order, unsigned grid unsigned maxsupport = order*2 -1; // determine needed recursion depth for specified size unsigned recursion_number = 0; - while (maxsupport*(1U< WaveletGrid::setupGrid(const unsigned order, unsigned grid std::vector g_coeffs = getFilterCoefficients(order, false, type); g_Matvec = setupMatrices(g_coeffs); gridvarname = typeToString(type,true)+std::to_string(order)+"_psi"; - } else { + } + else { gridvarname = typeToString(type,true)+std::to_string(order)+"_phi"; } @@ -85,8 +84,7 @@ std::unique_ptr WaveletGrid::setupGrid(const unsigned order, unsigned grid std::vector> WaveletGrid::setupMatrices(const std::vector& coeffs) { Matrix M0, M1; const int N = coeffs.size() -1; - M0.resize(N,N); - M1.resize(N,N); + M0.resize(N,N); M1.resize(N,N); for (int i = 0; i < N; ++i) { for (int j = 0; j < N; ++j) { int shift = 2*i -j; @@ -135,12 +133,9 @@ std::vector WaveletGrid::getEigenvector(const Matrix &A, const d std::vector iwork(8*N); // Transfer the matrix to the local array and substract eigenvalue - for (int i=0; i( A(j,i) ); - if (i==j) { - da[i*N+j] -= eigenvalue; - } + if (i==j) da[i*N+j] -= eigenvalue; } // This optimizes the size of the work array used in lapack singular value decomposition @@ -149,17 +144,14 @@ std::vector WaveletGrid::getEigenvector(const Matrix &A, const d plumed_lapack_dgesdd( "A", &N, &N, da.data(), &N, S.data(), U.data(), &N, VT.data(), &N, work.data(), &lwork, iwork.data(), &info ); // Retrieve correct sizes for work and reallocate - lwork=static_cast(work[0]); - work.resize(lwork); + lwork=static_cast(work[0]); work.resize(lwork); // This does the singular value decomposition plumed_lapack_dgesdd( "A", &N, &N, da.data(), &N, S.data(), U.data(), &N, VT.data(), &N, work.data(), &lwork, iwork.data(), &info ); // fill eigenvector with last column of VT std::vector eigenvector(N); - for (int i=0; i>& h_Matve std::vector temp_values; // multiply matrices by 2 if derivatives are calculated (assumes ascending order) - if (derivnum != 0) - for (auto& M : h_Matvec) { - M *= 2; - } + if (derivnum != 0) for (auto& M : h_Matvec) M *= 2; if (use_mother_wavelet) { wavelet_map.reserve(bins_per_int); - if (derivnum != 0) - for (auto& M : g_Matvec) { - M *= 2; - } + if (derivnum != 0) for (auto& M : g_Matvec) M *= 2; } // fill the first two datasets by hand @@ -245,11 +231,8 @@ void WaveletGrid::fillGridFromMaps(std::unique_ptr& grid, const BinaryMap& WaveletGrid::Type WaveletGrid::stringToType(std::string& type_str) { std::unordered_map typemap = { {"DAUBECHIES", Type::db}, {"SYMLETS", Type::sym} }; - try { - return typemap.at(type_str); - } catch(const std::out_of_range& e) { - plumed_merror("The specified wavelet type "+type_str+" is not implemented."); - } + try { return typemap.at(type_str); } + catch(const std::out_of_range& e) {plumed_merror("The specified wavelet type "+type_str+" is not implemented."); } } diff --git a/src/vesselbase/ActionWithAveraging.cpp b/src/vesselbase/ActionWithAveraging.cpp index 438abb8763..0d28dbdd2c 100644 --- a/src/vesselbase/ActionWithAveraging.cpp +++ b/src/vesselbase/ActionWithAveraging.cpp @@ -30,12 +30,8 @@ namespace PLMD { namespace vesselbase { void ActionWithAveraging::registerKeywords( Keywords& keys ) { - Action::registerKeywords( keys ); - ActionPilot::registerKeywords( keys ); - ActionAtomistic::registerKeywords( keys ); - ActionWithArguments::registerKeywords( keys ); - ActionWithValue::registerKeywords( keys ); - ActionWithVessel::registerKeywords( keys ); + Action::registerKeywords( keys ); ActionPilot::registerKeywords( keys ); ActionAtomistic::registerKeywords( keys ); + ActionWithArguments::registerKeywords( keys ); ActionWithValue::registerKeywords( keys ); ActionWithVessel::registerKeywords( keys ); keys.add("compulsory","STRIDE","1","the frequency with which the data should be collected and added to the quantity being averaged"); keys.add("compulsory","CLEAR","0","the frequency with which to clear all the accumulated data. The default value " "of 0 implies that all the data will be used and that the grid will never be cleared"); @@ -57,13 +53,12 @@ ActionWithAveraging::ActionWithAveraging( const ActionOptions& ao ): normalization(t), useRunAllTasks(false), clearstride(0), - lweight(0),cweight(0) { + lweight(0),cweight(0) +{ if( keywords.exists("CLEAR") ) { parse("CLEAR",clearstride); if( clearstride>0 ) { - if( clearstride%getStride()!=0 ) { - error("CLEAR parameter must be a multiple of STRIDE"); - } + if( clearstride%getStride()!=0 ) error("CLEAR parameter must be a multiple of STRIDE"); log.printf(" clearing grid every %u steps \n",clearstride); } } @@ -75,59 +70,38 @@ ActionWithAveraging::ActionWithAveraging( const ActionOptions& ao ): } } if( my_analysis_object ) { - if( getStride()!=1 ) { - error("stride should not have been set when calculating average from analysis data"); - } - setStride(0); - addDependency( my_analysis_object ); + if( getStride()!=1 ) error("stride should not have been set when calculating average from analysis data"); + setStride(0); addDependency( my_analysis_object ); } } if( keywords.exists("LOGWEIGHTS") ) { - std::vector wwstr; - parseVector("LOGWEIGHTS",wwstr); - if( wwstr.size()>0 ) { - log.printf(" reweighting using weights from "); - } + std::vector wwstr; parseVector("LOGWEIGHTS",wwstr); + if( wwstr.size()>0 ) log.printf(" reweighting using weights from "); std::vector arg( getArguments() ); for(unsigned i=0; i(wwstr[i]); - if( !val ) { - error("could not find value named"); - } + if( !val ) error("could not find value named"); bias::ReweightBase* iswham=dynamic_cast( val ); - if( iswham && iswham->buildsWeightStore() ) { - error("to use wham you must gather data using COLLECT_FRAMES"); - } + if( iswham && iswham->buildsWeightStore() ) error("to use wham you must gather data using COLLECT_FRAMES"); weights.push_back( val->copyOutput(val->getLabel()) ); arg.push_back( val->copyOutput(val->getLabel()) ); log.printf("%s ",wwstr[i].c_str() ); } - if( wwstr.size()>0 ) { - log.printf("\n"); - } else { - log.printf(" weights are all equal to one\n"); - } + if( wwstr.size()>0 ) log.printf("\n"); + else log.printf(" weights are all equal to one\n"); requestArguments( arg ); } if( keywords.exists("NORMALIZATION") ) { - std::string normstr; - parse("NORMALIZATION",normstr); - if( normstr=="true" ) { - normalization=t; - } else if( normstr=="false" ) { - normalization=f; - } else if( normstr=="ndata" ) { - normalization=ndata; - } else { - error("invalid instruction for NORMALIZATION flag should be true, false, or ndata"); - } + std::string normstr; parse("NORMALIZATION",normstr); + if( normstr=="true" ) normalization=t; + else if( normstr=="false" ) normalization=f; + else if( normstr=="ndata" ) normalization=ndata; + else error("invalid instruction for NORMALIZATION flag should be true, false, or ndata"); } } bool ActionWithAveraging::ignoreNormalization() const { - if( normalization==f ) { - return true; - } + if( normalization==f ) return true; return false; } @@ -135,8 +109,7 @@ void ActionWithAveraging::setAveragingAction( std::unique_ptr a // cppcheck-suppress danglingLifetime myaverage=av_vessel.get(); addVessel( std::move(av_vessel) ); - useRunAllTasks=usetasks; - resizeFunctions(); + useRunAllTasks=usetasks; resizeFunctions(); } void ActionWithAveraging::lockRequests() { @@ -150,9 +123,7 @@ void ActionWithAveraging::unlockRequests() { } unsigned ActionWithAveraging::getNumberOfQuantities() const { - if( my_analysis_object ) { - return getNumberOfArguments()+2; - } + if( my_analysis_object ) return getNumberOfArguments()+2; return 2; } @@ -161,111 +132,69 @@ void ActionWithAveraging::calculateNumericalDerivatives(PLMD::ActionWithValue*) } void ActionWithAveraging::update() { - if( (clearstride!=1 && getStep()==0) || (!onStep() && !my_analysis_object) ) { - return; - } + if( (clearstride!=1 && getStep()==0) || (!onStep() && !my_analysis_object) ) return; if( my_analysis_object ) { analysis::ReadAnalysisFrames* myfram = dynamic_cast( my_analysis_object ); - if( !activated && !myfram && !onStep() ) { - return ; - } else if( !activated && !my_analysis_object->onStep() ) { - return ; - } + if( !activated && !myfram && !onStep() ) return ; + else if( !activated && !my_analysis_object->onStep() ) return ; } // Clear if it is time to reset if( myaverage ) { - if( myaverage->wasreset() ) { - clearAverage(); - } + if( myaverage->wasreset() ) clearAverage(); } // Calculate the weight for all reweighting if ( weights.size()>0 && !my_analysis_object ) { - double sum=0; - for(unsigned i=0; iget(); - } - lweight=sum; - cweight = exp( sum ); + double sum=0; for(unsigned i=0; iget(); + lweight=sum; cweight = exp( sum ); } else { - lweight=0; - cweight=1.0; + lweight=0; cweight=1.0; } // Prepare the task list for averaging if( my_analysis_object ) { - for(unsigned i=getFullNumberOfTasks(); igetNumberOfDataPoints(); ++i) { - addTaskToList(i); - } - deactivateAllTasks(); - cweight=0; + for(unsigned i=getFullNumberOfTasks(); igetNumberOfDataPoints(); ++i) addTaskToList(i); + deactivateAllTasks(); cweight=0; for(unsigned i=0; igetNumberOfDataPoints(); ++i) { - taskFlags[i]=1; - cweight += my_analysis_object->getWeight(i); + taskFlags[i]=1; cweight += my_analysis_object->getWeight(i); } lockContributors(); } // Prepare to do the averaging prepareForAveraging(); // Run all the tasks (if required - if( my_analysis_object || useRunAllTasks ) { - runAllTasks(); - } + if( my_analysis_object || useRunAllTasks ) runAllTasks(); // This the averaging if it is not done using task list - else { - performOperations( true ); - } + else performOperations( true ); // Update the norm - double normt = cweight; - if( !my_analysis_object && normalization==ndata ) { - normt = 1; - } - if( myaverage && my_analysis_object ) { - myaverage->setNorm( normt ); - } else if( myaverage ) { - myaverage->setNorm( normt + myaverage->getNorm() ); - } + double normt = cweight; if( !my_analysis_object && normalization==ndata ) normt = 1; + if( myaverage && my_analysis_object ) myaverage->setNorm( normt ); + else if( myaverage ) myaverage->setNorm( normt + myaverage->getNorm() ); // Finish the averaging finishAveraging(); // By resetting here we are ensuring that the grid will be cleared at the start of the next step if( myaverage ) { - if( getStride()==0 || (clearstride>0 && getStep()%clearstride==0) ) { - myaverage->reset(); - } + if( getStride()==0 || (clearstride>0 && getStep()%clearstride==0) ) myaverage->reset(); } } void ActionWithAveraging::performTask( const unsigned& task_index, const unsigned& current, MultiValue& myvals ) const { if( my_analysis_object ) { const analysis::DataCollectionObject& mystore=my_analysis_object->getStoredData( current, false ); - for(unsigned i=0; igetName() ) ); - } + for(unsigned i=0; igetName() ) ); myvals.setValue( 0, my_analysis_object->getWeight(current) ); - if( normalization==f ) { - myvals.setValue( 1+getNumberOfArguments(), 1.0 ); - } else { - myvals.setValue( 1+getNumberOfArguments(), 1.0 / cweight ); - } + if( normalization==f ) myvals.setValue( 1+getNumberOfArguments(), 1.0 ); else myvals.setValue( 1+getNumberOfArguments(), 1.0 / cweight ); accumulateAverage( myvals ); } else { runTask( current, myvals ); } } -void ActionWithAveraging::clearAverage() { - plumed_assert( myaverage->wasreset() ); - myaverage->clear(); -} +void ActionWithAveraging::clearAverage() { plumed_assert( myaverage->wasreset() ); myaverage->clear(); } -void ActionWithAveraging::performOperations( const bool& from_update ) { - plumed_error(); -} +void ActionWithAveraging::performOperations( const bool& from_update ) { plumed_error(); } void ActionWithAveraging::runFinalJobs() { - if( my_analysis_object && getStride()==0 ) { - activated=true; - update(); - } + if( my_analysis_object && getStride()==0 ) { activated=true; update(); } } } diff --git a/src/vesselbase/ActionWithAveraging.h b/src/vesselbase/ActionWithAveraging.h index 14e8da2424..1032716568 100644 --- a/src/vesselbase/ActionWithAveraging.h +++ b/src/vesselbase/ActionWithAveraging.h @@ -49,7 +49,8 @@ class ActionWithAveraging : public ActionAtomistic, public ActionWithArguments, public ActionWithValue, - public ActionWithVessel { + public ActionWithVessel +{ friend class AveragingVessel; private: /// The vessel which is used to compute averages @@ -80,9 +81,7 @@ class ActionWithAveraging : void lockRequests() override; void unlockRequests() override; void calculateNumericalDerivatives(PLMD::ActionWithValue*) override; - unsigned getNumberOfDerivatives() override { - return 0; - } + unsigned getNumberOfDerivatives() override { return 0; } unsigned getNumberOfQuantities() const override; unsigned getNumberOfArguments() const override; /// Overwrite ActionWithArguments getArguments() so that we don't return the bias @@ -98,9 +97,7 @@ class ActionWithAveraging : /// Does the calculation void performTask( const unsigned& task_index, const unsigned& current, MultiValue& myvals ) const override; /// - virtual void runTask( const unsigned& current, MultiValue& myvals ) const { - plumed_error(); - } + virtual void runTask( const unsigned& current, MultiValue& myvals ) const { plumed_error(); } /// virtual void accumulateAverage( MultiValue& myvals ) const {} /// This is done once the averaging is finished @@ -119,9 +116,7 @@ unsigned ActionWithAveraging::getNumberOfArguments() const { inline std::vector ActionWithAveraging::getArguments() { std::vector arg_vals( ActionWithArguments::getArguments() ); - for(unsigned i=0; i(mlab); - if(!mves) { - error("action labelled " + mlab + " does not exist or does not have vessels"); - } + if(!mves) error("action labelled " + mlab + " does not exist or does not have vessels"); addDependency(mves); ActionWithValue* aval=dynamic_cast( this ); if(aval) { if( aval->checkNumericalDerivatives() ) { ActionWithValue* aval2=dynamic_cast( mves ); - plumed_assert( aval2 ); - aval2->useNumericalDerivatives(); + plumed_assert( aval2 ); aval2->useNumericalDerivatives(); } } if( type=="bridge" ) { ActionWithVessel* aves=dynamic_cast( this ); - plumed_assert(aves); - myBridgeVessel = mves->addBridgingVessel( aves ); + plumed_assert(aves); myBridgeVessel = mves->addBridgingVessel( aves ); arguments = dynamic_cast( myBridgeVessel ); } else if( type=="store" ) { arguments = dynamic_cast( mves->buildDataStashes( NULL ) ); @@ -86,8 +81,7 @@ void ActionWithInputVessel::calculateNumericalDerivatives( ActionWithValue* a ) } void ActionWithInputVessel::applyBridgeForces( const std::vector& bb ) { - plumed_dbg_assert( myBridgeVessel ); - addBridgeForces( bb ); + plumed_dbg_assert( myBridgeVessel ); addBridgeForces( bb ); } } diff --git a/src/vesselbase/ActionWithVessel.cpp b/src/vesselbase/ActionWithVessel.cpp index c99ae31c78..175df0f23d 100644 --- a/src/vesselbase/ActionWithVessel.cpp +++ b/src/vesselbase/ActionWithVessel.cpp @@ -59,17 +59,12 @@ ActionWithVessel::ActionWithVessel(const ActionOptions&ao): dertime(true), contributorsAreUnlocked(false), weightHasDerivatives(false), - mydata(NULL) { - maxderivatives=309; - parse("MAXDERIVATIVES",maxderivatives); - if( keywords.exists("SERIAL") ) { - parseFlag("SERIAL",serial); - } else { - serial=true; - } - if(serial) { - log.printf(" doing calculation in serial\n"); - } + mydata(NULL) +{ + maxderivatives=309; parse("MAXDERIVATIVES",maxderivatives); + if( keywords.exists("SERIAL") ) parseFlag("SERIAL",serial); + else serial=true; + if(serial)log.printf(" doing calculation in serial\n"); if( keywords.exists("LOWMEM") ) { plumed_assert( !keywords.exists("HIGHMEM") ); parseFlag("LOWMEM",lowmem); @@ -80,28 +75,21 @@ ActionWithVessel::ActionWithVessel(const ActionOptions&ao): } if( keywords.exists("HIGHMEM") ) { plumed_assert( !keywords.exists("LOWMEM") ); - bool highmem; - parseFlag("HIGHMEM",highmem); + bool highmem; parseFlag("HIGHMEM",highmem); lowmem=!highmem; - if(!lowmem) { - log.printf(" increasing the memory requirements\n"); - } + if(!lowmem) log.printf(" increasing the memory requirements\n"); } tolerance=nl_tolerance=epsilon; - if( keywords.exists("TOL") ) { - parse("TOL",tolerance); - } + if( keywords.exists("TOL") ) parse("TOL",tolerance); if( tolerance>epsilon) { log.printf(" Ignoring contributions less than %f \n",tolerance); } parseFlag("TIMINGS",timers); - stopwatch.start(); - stopwatch.pause(); + stopwatch.start(); stopwatch.pause(); } ActionWithVessel::~ActionWithVessel() { - stopwatch.start(); - stopwatch.stop(); + stopwatch.start(); stopwatch.stop(); if(timers) { log.printf("timings for action %s with label %s \n", getName().c_str(), getLabel().c_str() ); log< vv_ptr ) { // In the original code, the dynamically casted pointer was deleted here. // Now that vv_ptr is a unique_ptr, the object will be deleted automatically when // exiting this routine. - if(dynamic_cast(vv_ptr.get())) { - return; - } + if(dynamic_cast(vv_ptr.get())) return; vv_ptr->checkRead(); StoreDataVessel* mm=dynamic_cast( vv_ptr.get() ); - if( mydata && mm ) { - error("cannot have more than one StoreDataVessel in one action"); - } else if( mm ) { - mydata=mm; - } else { - dertime_can_be_off=false; - } + if( mydata && mm ) error("cannot have more than one StoreDataVessel in one action"); + else if( mm ) mydata=mm; + else dertime_can_be_off=false; // Ownership is transferred to functions functions.emplace_back(std::move(vv_ptr)); @@ -147,8 +129,7 @@ BridgeVessel* ActionWithVessel::addBridgingVessel( ActionWithVessel* tome ) { VesselOptions da("","",0,"",this); auto bv=Tools::make_unique(da); bv->setOutputAction( tome ); - tome->actionIsBridged=true; - dertime_can_be_off=false; + tome->actionIsBridged=true; dertime_can_be_off=false; // store this pointer in order to return it later. // notice that I cannot access this with functions.tail().get() // since functions contains pointers to a different class (Vessel) @@ -160,17 +141,13 @@ BridgeVessel* ActionWithVessel::addBridgingVessel( ActionWithVessel* tome ) { StoreDataVessel* ActionWithVessel::buildDataStashes( ActionWithVessel* actionThatUses ) { if(mydata) { - if( actionThatUses ) { - mydata->addActionThatUses( actionThatUses ); - } + if( actionThatUses ) mydata->addActionThatUses( actionThatUses ); return mydata; } VesselOptions da("","",0,"",this); auto mm=Tools::make_unique(da); - if( actionThatUses ) { - mm->addActionThatUses( actionThatUses ); - } + if( actionThatUses ) mm->addActionThatUses( actionThatUses ); addVessel(std::move(mm)); // Make sure resizing of vessels is done @@ -180,40 +157,30 @@ StoreDataVessel* ActionWithVessel::buildDataStashes( ActionWithVessel* actionTha } void ActionWithVessel::addTaskToList( const unsigned& taskCode ) { - fullTaskList.push_back( taskCode ); - taskFlags.push_back(0); + fullTaskList.push_back( taskCode ); taskFlags.push_back(0); plumed_assert( fullTaskList.size()==taskFlags.size() ); } void ActionWithVessel::readVesselKeywords() { // Set maxderivatives if it is too big - if( maxderivatives>getNumberOfDerivatives() ) { - maxderivatives=getNumberOfDerivatives(); - } + if( maxderivatives>getNumberOfDerivatives() ) maxderivatives=getNumberOfDerivatives(); // Loop over all keywords find the vessels and create appropriate functions for(unsigned i=0; i0 ) { - resizeFunctions(); - } + if( functions.size()>0 ) resizeFunctions(); } void ActionWithVessel::resizeFunctions() { - for(unsigned i=0; iresize(); - } + for(unsigned i=0; iresize(); } void ActionWithVessel::needsDerivatives() { // Turn on the derivatives and resize - noderiv=false; - resizeFunctions(); + noderiv=false; resizeFunctions(); // Setting contributors unlocked here ensures that link cells are ignored - contributorsAreUnlocked=true; - contributorsAreUnlocked=false; + contributorsAreUnlocked=true; contributorsAreUnlocked=false; // And turn on the derivatives in all actions on which we are dependent for(unsigned i=0; i( getDependencies()[i] ); - if(vv) { - vv->needsDerivatives(); - } + if(vv) vv->needsDerivatives(); } } void ActionWithVessel::lockContributors() { nactive_tasks = 0; for(unsigned i=0; i0 ) { - nactive_tasks++; - } + if( taskFlags[i]>0 ) nactive_tasks++; } unsigned n=0; @@ -271,47 +228,33 @@ void ActionWithVessel::lockContributors() { plumed_dbg_assert( n==nactive_tasks ); for(unsigned i=0; i( functions[i].get() ); - if( bb ) { - bb->copyTaskFlags(); - } + if( bb ) bb->copyTaskFlags(); } // Resize mydata to accommodate all active tasks - if( mydata ) { - mydata->resize(); - } + if( mydata ) mydata->resize(); contributorsAreUnlocked=false; } void ActionWithVessel::deactivateAllTasks() { - contributorsAreUnlocked=true; - nactive_tasks = 0; + contributorsAreUnlocked=true; nactive_tasks = 0; taskFlags.assign(taskFlags.size(),0); } bool ActionWithVessel::taskIsCurrentlyActive( const unsigned& index ) const { - plumed_dbg_assert( index0); + plumed_dbg_assert( index0); } void ActionWithVessel::doJobsRequiredBeforeTaskList() { // Do any preparatory stuff for functions - for(unsigned j=0; jprepare(); - } + for(unsigned j=0; jprepare(); } unsigned ActionWithVessel::getSizeOfBuffer( unsigned& bufsize ) { - for(unsigned i=0; isetBufferStart( bufsize ); - } - if( buffer.size()!=bufsize ) { - buffer.resize( bufsize ); - } + for(unsigned i=0; isetBufferStart( bufsize ); + if( buffer.size()!=bufsize ) buffer.resize( bufsize ); if( mydata ) { unsigned dsize=mydata->getSizeOfDerivativeList(); - if( der_list.size()!=dsize ) { - der_list.resize( dsize ); - } + if( der_list.size()!=dsize ) der_list.resize( dsize ); } return bufsize; } @@ -320,48 +263,32 @@ void ActionWithVessel::runAllTasks() { plumed_massert( !contributorsAreUnlocked && functions.size()>0, "you must have a call to readVesselKeywords somewhere" ); unsigned stride=comm.Get_size(); unsigned rank=comm.Get_rank(); - if(serial) { - stride=1; - rank=0; - } + if(serial) { stride=1; rank=0; } // Make sure jobs are done - if(timers) { - stopwatch.start("1 Prepare Tasks"); - } + if(timers) stopwatch.start("1 Prepare Tasks"); doJobsRequiredBeforeTaskList(); - if(timers) { - stopwatch.stop("1 Prepare Tasks"); - } + if(timers) stopwatch.stop("1 Prepare Tasks"); // Get number of threads for OpenMP unsigned nt=OpenMP::getNumThreads(); - if( nt*stride*2>nactive_tasks || !threadSafe()) { - nt=1; - } + if( nt*stride*2>nactive_tasks || !threadSafe()) nt=1; // Get size for buffer unsigned bsize=0, bufsize=getSizeOfBuffer( bsize ); // Clear buffer buffer.assign( buffer.size(), 0.0 ); // Switch off calculation of derivatives in main loop - if( dertime_can_be_off ) { - dertime=false; - } + if( dertime_can_be_off ) dertime=false; - if(timers) { - stopwatch.start("2 Loop over tasks"); - } + if(timers) stopwatch.start("2 Loop over tasks"); #pragma omp parallel num_threads(nt) { std::vector omp_buffer; - if( nt>1 ) { - omp_buffer.resize( bufsize, 0.0 ); - } + if( nt>1 ) omp_buffer.resize( bufsize, 0.0 ); MultiValue myvals( getNumberOfQuantities(), getNumberOfDerivatives() ); MultiValue bvals( getNumberOfQuantities(), getNumberOfDerivatives() ); - myvals.clearAll(); - bvals.clearAll(); + myvals.clearAll(); bvals.clearAll(); #pragma omp for nowait schedule(dynamic) for(unsigned i=rank; i1) - for(unsigned i=0; i1) for(unsigned i=0; i0 ) { - comm.Sum( buffer ); - } + if( !serial && buffer.size()>0 ) comm.Sum( buffer ); // MPI Gather index stores if( mydata && !lowmem && !noderiv ) { - comm.Sum( der_list ); - mydata->setActiveValsAndDerivatives( der_list ); + comm.Sum( der_list ); mydata->setActiveValsAndDerivatives( der_list ); } // Update the elements that are makign contributions to the sum here // this causes problems if we do it in prepare - if(timers) { - stopwatch.stop("3 MPI gather"); - } + if(timers) stopwatch.stop("3 MPI gather"); - if(timers) { - stopwatch.start("4 Finishing computations"); - } + if(timers) stopwatch.start("4 Finishing computations"); finishComputations( buffer ); - if(timers) { - stopwatch.stop("4 Finishing computations"); - } + if(timers) stopwatch.stop("4 Finishing computations"); } void ActionWithVessel::transformBridgedDerivatives( const unsigned& current, MultiValue& invals, MultiValue& outvals ) const { @@ -437,38 +348,28 @@ void ActionWithVessel::calculateAllVessels( const unsigned& taskCode, MultiValue // Calculate returns a bool that tells us if this particular // quantity is contributing more than the tolerance functions[j]->calculate( taskCode, functions[j]->transformDerivatives(taskCode, myvals, bvals), buffer, der_list ); - if( !actionIsBridged ) { - bvals.clearAll(); - } + if( !actionIsBridged ) bvals.clearAll(); } return; } void ActionWithVessel::finishComputations( const std::vector& buffer ) { // Set the final value of the function - for(unsigned j=0; jfinish( buffer ); - } + for(unsigned j=0; jfinish( buffer ); } bool ActionWithVessel::getForcesFromVessels( std::vector& forcesToApply ) { #ifndef NDEBUG - if( forcesToApply.size()>0 ) { - plumed_dbg_assert( forcesToApply.size()==getNumberOfDerivatives() ); - } + if( forcesToApply.size()>0 ) plumed_dbg_assert( forcesToApply.size()==getNumberOfDerivatives() ); #endif - if(tmpforces.size()!=forcesToApply.size() ) { - tmpforces.resize( forcesToApply.size() ); - } + if(tmpforces.size()!=forcesToApply.size() ) tmpforces.resize( forcesToApply.size() ); forcesToApply.assign( forcesToApply.size(),0.0 ); bool wasforced=false; for(unsigned i=0; iapplyForce( tmpforces )) ) { wasforced=true; - for(unsigned j=0; jgetName().find(mynam)!=std::string::npos ) { - if( target<0 ) { - target=i; - } else { - error("found more than one " + mynam + " object in action"); - } + if( target<0 ) target=i; + else error("found more than one " + mynam + " object in action"); } } plumed_assert(target>=0); diff --git a/src/vesselbase/ActionWithVessel.h b/src/vesselbase/ActionWithVessel.h index 2c35edf446..32859b84b9 100644 --- a/src/vesselbase/ActionWithVessel.h +++ b/src/vesselbase/ActionWithVessel.h @@ -151,9 +151,7 @@ class ActionWithVessel : public virtual Action { /// Are derivatives required for this quantity bool derivativesAreRequired() const ; /// Is this action thread safe - virtual bool threadSafe() const { - return true; - } + virtual bool threadSafe() const { return true; } /// Finish running all the calculations virtual void finishComputations( const std::vector& buffer ); /// Are the base quantities periodic @@ -185,9 +183,7 @@ class ActionWithVessel : public virtual Action { /// Ensure that data required in other vessels is stored StoreDataVessel* buildDataStashes( ActionWithVessel* actionThatUses ); /// Apply forces from bridge vessel - this is rarely used - currently only in ActionVolume - virtual void applyBridgeForces( const std::vector& bb ) { - plumed_error(); - } + virtual void applyBridgeForces( const std::vector& bb ) { plumed_error(); } /// These are overwritten in MultiColvarFunction // virtual void activateIndexes( const unsigned&, const unsigned&, const std::vector& ){} /// Return a particular named vessel @@ -197,12 +193,8 @@ class ActionWithVessel : public virtual Action { /// Return the position in the current task list unsigned getPositionInCurrentTaskList( const unsigned& myind ) const ; /// These normalizes vectors and is used in StoreDataVessel - virtual void normalizeVector( std::vector& vals ) const { - plumed_error(); - } - virtual void normalizeVectorDerivatives( MultiValue& myvals ) const { - plumed_error(); - } + virtual void normalizeVector( std::vector& vals ) const { plumed_error(); } + virtual void normalizeVectorDerivatives( MultiValue& myvals ) const { plumed_error(); } }; inline @@ -286,14 +278,10 @@ bool ActionWithVessel::weightWithDerivatives() const { inline unsigned ActionWithVessel::getPositionInCurrentTaskList( const unsigned& myind ) const { - if( nactive_tasks==fullTaskList.size() ) { - return myind; - } + if( nactive_tasks==fullTaskList.size() ) return myind; for(unsigned i=0; iisPeriodic() ) { - error("MIN is not a meaningful option for periodic variables"); - } - parse("BETA",beta); - usetol=true; + FunctionVessel(da) +{ + if( getAction()->isPeriodic() ) error("MIN is not a meaningful option for periodic variables"); + parse("BETA",beta); usetol=true; } std::string AltMin::value_descriptor() { - std::string str_beta; - Tools::convert( beta, str_beta ); + std::string str_beta; Tools::convert( beta, str_beta ); return "the minimum value. Beta is equal to " + str_beta; } double AltMin::calcTransform( const double& val, double& dv ) const { - double f = exp( -beta*val ); - dv = -beta*f; - return f; + double f = exp( -beta*val ); dv = -beta*f; return f; } double AltMin::finalTransform( const double& val, double& dv ) { - dv = - 1.0 /(beta*val); - return -std::log( val ) / beta; + dv = - 1.0 /(beta*val); return -std::log( val ) / beta; } } diff --git a/src/vesselbase/AveragingVessel.cpp b/src/vesselbase/AveragingVessel.cpp index 8bde732515..9e2cc6c26d 100644 --- a/src/vesselbase/AveragingVessel.cpp +++ b/src/vesselbase/AveragingVessel.cpp @@ -31,19 +31,16 @@ void AveragingVessel::registerKeywords( Keywords& keys ) { AveragingVessel::AveragingVessel( const vesselbase::VesselOptions& vo ): Vessel(vo), - wascleared(true) { + wascleared(true) +{ if( getAction() ) { ActionWithAveraging* myav = dynamic_cast( getAction() ); - plumed_assert( myav ); - unormalised = myav->ignoreNormalization(); + plumed_assert( myav ); unormalised = myav->ignoreNormalization(); } } void AveragingVessel::finish( const std::vector& buffer ) { - wascleared=false; - for(unsigned i=1; i& forces ) override { - return false; - } + bool applyForce( std::vector& forces ) override { return false; } }; inline void AveragingVessel::setDataElement( const unsigned& myelem, const double& value ) { plumed_dbg_assert( myelem<1+data.size() ); - wascleared=false; - data[1+myelem]=value; + wascleared=false; data[1+myelem]=value; } inline void AveragingVessel::addDataElement( const unsigned& myelem, const double& value ) { plumed_dbg_assert( myelem<1+data.size() ); - wascleared=false; - data[1+myelem]+=value; + wascleared=false; data[1+myelem]+=value; } inline double AveragingVessel::getDataElement( const unsigned& myelem ) const { plumed_dbg_assert( myelemisPeriodic(); - double min, max; - std::string str_min, str_max; + double min, max; std::string str_min, str_max; if( isPeriodic ) { getAction()->retrieveDomain( str_min, str_max ); - Tools::convert(str_min,min); - Tools::convert(str_max,max); + Tools::convert(str_min,min); Tools::convert(str_max,max); } - parseFlag("NORM",norm); - std::string errormsg; + parseFlag("NORM",norm); std::string errormsg; hist.set( getAllInput(),errormsg ); - if( !isPeriodic ) { - hist.isNotPeriodic(); - } else { - hist.isPeriodic( min, max ); - } - if( errormsg.size()!=0 ) { - error( errormsg ); - } + if( !isPeriodic ) hist.isNotPeriodic(); + else hist.isPeriodic( min, max ); + if( errormsg.size()!=0 ) error( errormsg ); } std::string Between::value_descriptor() { - if(norm) { - return "the fraction of values " + hist.description(); - } + if(norm) return "the fraction of values " + hist.description(); return "the number of values " + hist.description(); } double Between::calcTransform( const double& val, double& dv ) const { - double f = hist.calculate(val, dv); - return f; + double f = hist.calculate(val, dv); return f; } double Between::getCutoff() { diff --git a/src/vesselbase/BridgeVessel.cpp b/src/vesselbase/BridgeVessel.cpp index 1b6d2e6636..33ee559cb5 100644 --- a/src/vesselbase/BridgeVessel.cpp +++ b/src/vesselbase/BridgeVessel.cpp @@ -33,7 +33,8 @@ BridgeVessel::BridgeVessel( const VesselOptions& da ): // in_normal_calculate(false) myOutputAction(NULL), myOutputValues(NULL), - my_tmp_val(0,0) { + my_tmp_val(0,0) +{ } void BridgeVessel::resize() { @@ -46,12 +47,9 @@ void BridgeVessel::resize() { // from a bridge if( myOutputAction->mydata ) { unsigned dsize=(myOutputAction->mydata)->getSizeOfDerivativeList(); - if( getAction()->der_list.size()!=dsize ) { - getAction()->der_list.resize( dsize ); - } + if( getAction()->der_list.size()!=dsize ) getAction()->der_list.resize( dsize ); } - unsigned tmp=0; - resizeBuffer( myOutputAction->getSizeOfBuffer( tmp ) ); + unsigned tmp=0; resizeBuffer( myOutputAction->getSizeOfBuffer( tmp ) ); } void BridgeVessel::setOutputAction( ActionWithVessel* myact ) { @@ -86,9 +84,7 @@ MultiValue& BridgeVessel::transformDerivatives( const unsigned& current, MultiVa void BridgeVessel::calculate( const unsigned& current, MultiValue& myvals, std::vector& buffer, std::vector& der_list ) const { // in_normal_calculate=true; - if( myvals.get(0)getTolerance() ) { - return; - } + if( myvals.get(0)getTolerance() ) return; myOutputAction->calculateAllVessels( current, myvals, myvals, buffer, der_list ); return; } @@ -113,32 +109,22 @@ void BridgeVessel::completeNumericalDerivatives() { Matrix tmpder( myOutputValues->getNumberOfComponents(), nextra ); ActionWithVessel* vval=dynamic_cast( myOutputAction ); for(unsigned i=0; ibridgeVariable=i; - getAction()->calculate(); - for(int j=0; jgetNumberOfComponents(); ++j) { - tmpder(j,i) = myOutputValues->getOutputQuantity(j); - } + vval->bridgeVariable=i; getAction()->calculate(); + for(int j=0; jgetNumberOfComponents(); ++j) tmpder(j,i) = myOutputValues->getOutputQuantity(j); } - vval->bridgeVariable=nextra; - getAction()->calculate(); - plumed_assert( inum==mynumerical_values.size() ); - inum=0; // Reset inum now that we have finished calling calculate + vval->bridgeVariable=nextra; getAction()->calculate(); + plumed_assert( inum==mynumerical_values.size() ); inum=0; // Reset inum now that we have finished calling calculate std::vector base( myOutputValues->getNumberOfComponents() ); - for(int j=0; jgetNumberOfComponents(); ++j) { - base[j] = myOutputValues->getOutputQuantity(j); - } + for(int j=0; jgetNumberOfComponents(); ++j) base[j] = myOutputValues->getOutputQuantity(j); const double delta=std::sqrt(epsilon); ActionAtomistic* aa=dynamic_cast( getAction() ); unsigned nvals=myOutputValues->getNumberOfComponents(); - for(unsigned j=0; jcopyOutput(j) )->clearDerivatives(); - } + for(unsigned j=0; jcopyOutput(j) )->clearDerivatives(); if( aa ) { ActionWithArguments* aarg=dynamic_cast( getAction() ); - plumed_assert( !aarg ); - Tensor box=aa->getBox(); + plumed_assert( !aarg ); Tensor box=aa->getBox(); unsigned natoms=aa->getNumberOfAtoms(); for(unsigned j=0; jcopyOutput(j) )->get(); @@ -148,15 +134,11 @@ void BridgeVessel::completeNumericalDerivatives() { ( myOutputValues->copyOutput(j) )->addDerivative(i,d); } Tensor virial; - for(int i=0; i<3; i++) - for(int k=0; k<3; k++) { + for(int i=0; i<3; i++) for(int k=0; k<3; k++) { virial(i,k)=( mynumerical_values[ nvals*(3*natoms + 3*i + k) + j ]-ref)/delta; } virial=-matmul(box.transpose(),virial); - for(int i=0; i<3; i++) - for(int k=0; k<3; k++) { - ( myOutputValues->copyOutput(j) )->addDerivative(3*natoms+3*k+i,virial(k,i)); - } + for(int i=0; i<3; i++) for(int k=0; k<3; k++) ( myOutputValues->copyOutput(j) )->addDerivative(3*natoms+3*k+i,virial(k,i)); } } } else { @@ -175,40 +157,30 @@ void BridgeVessel::completeNumericalDerivatives() { for(unsigned j=0; jgetNumberOfDerivatives(); igetNumberOfDerivatives(); ++i) { - ( myOutputValues->copyOutput(j) )->addDerivative( i, (tmpder(j,k)-base[j])/std::sqrt(epsilon) ); - k++; + ( myOutputValues->copyOutput(j) )->addDerivative( i, (tmpder(j,k)-base[j])/std::sqrt(epsilon) ); k++; } } } bool BridgeVessel::applyForce( std::vector& outforces ) { - bool hasforce=false; - outforces.assign(outforces.size(),0.0); + bool hasforce=false; outforces.assign(outforces.size(),0.0); unsigned ndertot = myOutputAction->getNumberOfDerivatives(); unsigned nextra = ndertot - getAction()->getNumberOfDerivatives(); std::vector forces( ndertot ), eforces( nextra, 0.0 ); for(unsigned i=0; igetNumberOfVessels(); ++i) { if( ( myOutputAction->getPntrToVessel(i) )->applyForce( forces ) ) { hasforce=true; - for(unsigned j=0; japplyBridgeForces( eforces ); - } + if(hasforce) myOutputAction->applyBridgeForces( eforces ); return hasforce; } void BridgeVessel::copyTaskFlags() { myOutputAction->deactivateAllTasks(); - for(unsigned i=0; inactive_tasks; ++i) { - myOutputAction->taskFlags[ getAction()->indexOfTaskInFullList[i] ] = 1; - } + for(unsigned i=0; inactive_tasks; ++i) myOutputAction->taskFlags[ getAction()->indexOfTaskInFullList[i] ] = 1; myOutputAction->lockContributors(); } diff --git a/src/vesselbase/FunctionVessel.cpp b/src/vesselbase/FunctionVessel.cpp index 7ca5b5d03f..e197155c0c 100644 --- a/src/vesselbase/FunctionVessel.cpp +++ b/src/vesselbase/FunctionVessel.cpp @@ -32,7 +32,8 @@ void FunctionVessel::registerKeywords( Keywords& keys ) { FunctionVessel::FunctionVessel( const VesselOptions& da ): ValueVessel(da), norm(false), - usetol(false) { + usetol(false) +{ diffweight=getAction()->weightHasDerivatives; } @@ -57,27 +58,17 @@ void FunctionVessel::calculate( const unsigned& current, MultiValue& myvals, std double dval, f=calcTransform( myvals.get(mycomp), dval ); if( norm ) { - if( usetol && weightderivativesAreRequired() && diffweight ) { - myvals.chainRule( 0, 1, 1, 0, 1.0, bufstart, buffer ); - } + if( getAction()->derivativesAreRequired() && diffweight ) myvals.chainRule( 0, 1, 1, 0, 1.0, bufstart, buffer ); } double contr=weight*f; - if( usetol && contrderivativesAreRequired() && std::fabs(dval)>0.0 ) { - myvals.chainRule( mycomp, 0, 1, 0, weight*dval, bufstart, buffer ); - } + if( diffweight ) myvals.chainRule( 0, 0, 1, 0, f, bufstart, buffer ); + if( getAction()->derivativesAreRequired() && std::fabs(dval)>0.0 ) myvals.chainRule( mycomp, 0, 1, 0, weight*dval, bufstart, buffer ); return; } @@ -97,21 +88,15 @@ void FunctionVessel::finish( const std::vector& buffer ) { } else if( norm ) { double dv, val=finalTransform( buffer[bufstart], dv), weight=buffer[bufstart+1+nderivatives]; getFinalValue()->set( val / weight ); - for(unsigned i=0; iaddDerivative( i, buffer[bufstart+1+i]/weight ); - } + for(unsigned i=0; iaddDerivative( i, buffer[bufstart+1+i]/weight ); } else { - double dv, val=finalTransform( buffer[bufstart], dv); - getFinalValue()->set( val ); - for(unsigned i=0; iaddDerivative( i, dv*buffer[bufstart+1+i] ); - } + double dv, val=finalTransform( buffer[bufstart], dv); getFinalValue()->set( val ); + for(unsigned i=0; iaddDerivative( i, dv*buffer[bufstart+1+i] ); } } double FunctionVessel::finalTransform( const double& val, double& dv ) { - dv=1.0; - return val; + dv=1.0; return val; } } diff --git a/src/vesselbase/Highest.cpp b/src/vesselbase/Highest.cpp index ddef09d2b3..c75a29382b 100644 --- a/src/vesselbase/Highest.cpp +++ b/src/vesselbase/Highest.cpp @@ -46,7 +46,8 @@ void Highest::reserveKeyword( Keywords& keys ) { } Highest::Highest( const VesselOptions& da ) : - OrderingVessel(da) { + OrderingVessel(da) +{ } std::string Highest::value_descriptor() { diff --git a/src/vesselbase/Histogram.cpp b/src/vesselbase/Histogram.cpp index 9e0020ce5d..eb5a0921b6 100644 --- a/src/vesselbase/Histogram.cpp +++ b/src/vesselbase/Histogram.cpp @@ -49,21 +49,14 @@ void Histogram::reserveKeyword( Keywords& keys ) { } Histogram::Histogram( const VesselOptions& da ): - ShortcutVessel(da) { - bool norm; - parseFlag("NORM",norm); - std::string normstr=""; - if(norm) { - normstr=" NORM"; - } - std::string compstr; - parse("COMPONENT",compstr); + ShortcutVessel(da) +{ + bool norm; parseFlag("NORM",norm); std::string normstr=""; + if(norm) normstr=" NORM"; + std::string compstr; parse("COMPONENT",compstr); normstr+=" COMPONENT=" + compstr; - std::vector bins; - HistogramBead::generateBins( getAllInput(), bins ); - for(unsigned i=0; i bins; HistogramBead::generateBins( getAllInput(), bins ); + for(unsigned i=0; iisPeriodic() ) { - error("LESS_THAN is not a meaningful option for periodic variables"); - } - std::string errormsg; - sf.set( getAllInput(), errormsg ); - if( errormsg.size()!=0 ) { - error( errormsg ); - } + if( getAction()->isPeriodic() ) error("LESS_THAN is not a meaningful option for periodic variables"); + std::string errormsg; sf.set( getAllInput(), errormsg ); + if( errormsg.size()!=0 ) error( errormsg ); } std::string LessThan::value_descriptor() { @@ -59,9 +55,7 @@ std::string LessThan::value_descriptor() { } double LessThan::calcTransform( const double& val, double& dv ) const { - double f = sf.calculate(val, dv); - dv*=val; - return f; + double f = sf.calculate(val, dv); dv*=val; return f; } double LessThan::getCutoff() { diff --git a/src/vesselbase/Lowest.cpp b/src/vesselbase/Lowest.cpp index c8761c2cbc..f17d9411a5 100644 --- a/src/vesselbase/Lowest.cpp +++ b/src/vesselbase/Lowest.cpp @@ -46,7 +46,8 @@ void Lowest::reserveKeyword( Keywords& keys ) { } Lowest::Lowest( const VesselOptions& da ) : - OrderingVessel(da) { + OrderingVessel(da) +{ } std::string Lowest::value_descriptor() { diff --git a/src/vesselbase/Max.cpp b/src/vesselbase/Max.cpp index 512dfa9395..0d6b3c886c 100644 --- a/src/vesselbase/Max.cpp +++ b/src/vesselbase/Max.cpp @@ -56,33 +56,26 @@ void Max::reserveKeyword( Keywords& keys ) { } Max::Max( const VesselOptions& da ) : - FunctionVessel(da) { - if( getAction()->isPeriodic() ) { - error("max is not a meaningful option for periodic variables"); - } + FunctionVessel(da) +{ + if( getAction()->isPeriodic() ) error("max is not a meaningful option for periodic variables"); parse("BETA",beta); - if( diffweight ) { - error("can't calculate max if weight is differentiable"); - } + if( diffweight ) error("can't calculate max if weight is differentiable"); } std::string Max::value_descriptor() { - std::string str_beta; - Tools::convert( beta, str_beta ); + std::string str_beta; Tools::convert( beta, str_beta ); return "the maximum value. Beta is equal to " + str_beta; } double Max::calcTransform( const double& val, double& dv ) const { - double f = exp(val/beta); - dv=f/beta; - return f; + double f = exp(val/beta); dv=f/beta; return f; } double Max::finalTransform( const double& val, double& dv ) { double dist=beta*std::log( val ); - dv = beta/val; - return dist; + dv = beta/val; return dist; } } diff --git a/src/vesselbase/Mean.cpp b/src/vesselbase/Mean.cpp index dcfae0fa31..651123fd23 100644 --- a/src/vesselbase/Mean.cpp +++ b/src/vesselbase/Mean.cpp @@ -48,10 +48,9 @@ void Mean::reserveKeyword( Keywords& keys ) { } Mean::Mean( const vesselbase::VesselOptions& da ) : - FunctionVessel(da) { - if( getAction()->isPeriodic() ) { - error("MEAN cannot be used with periodic variables"); - } + FunctionVessel(da) +{ + if( getAction()->isPeriodic() ) error("MEAN cannot be used with periodic variables"); norm=true; // Makes sure we calculate the average } @@ -60,8 +59,7 @@ std::string Mean::value_descriptor() { } double Mean::calcTransform( const double& val, double& dv ) const { - dv=1.0; - return val; + dv=1.0; return val; } } diff --git a/src/vesselbase/Min.cpp b/src/vesselbase/Min.cpp index 987d97f5a8..a314978939 100644 --- a/src/vesselbase/Min.cpp +++ b/src/vesselbase/Min.cpp @@ -55,33 +55,27 @@ void Min::reserveKeyword( Keywords& keys ) { } Min::Min( const VesselOptions& da ) : - FunctionVessel(da) { - if( getAction()->isPeriodic() ) { - error("min is not a meaningful option for periodic variables"); - } + FunctionVessel(da) +{ + if( getAction()->isPeriodic() ) error("min is not a meaningful option for periodic variables"); parse("BETA",beta); - if( diffweight ) { - error("can't calculate min if weight is differentiable"); - } + if( diffweight ) error("can't calculate min if weight is differentiable"); } std::string Min::value_descriptor() { - std::string str_beta; - Tools::convert( beta, str_beta ); + std::string str_beta; Tools::convert( beta, str_beta ); return "the minimum value. Beta is equal to " + str_beta; } double Min::calcTransform( const double& val, double& dv ) const { - double f = exp(beta/val); - dv=f/(val*val); + double f = exp(beta/val); dv=f/(val*val); return f; } double Min::finalTransform( const double& val, double& dv ) { double dist=beta/std::log( val ); - dv = dist*dist/val; - return dist; + dv = dist*dist/val; return dist; } } diff --git a/src/vesselbase/Moments.cpp b/src/vesselbase/Moments.cpp index 628e736f6a..2ce413a778 100644 --- a/src/vesselbase/Moments.cpp +++ b/src/vesselbase/Moments.cpp @@ -71,45 +71,31 @@ void Moments::reserveKeyword( Keywords& keys ) { } Moments::Moments( const vesselbase::VesselOptions& da) : - Vessel(da) { + Vessel(da) +{ mystash = getAction()->buildDataStashes( NULL ); ActionWithValue* a=dynamic_cast( getAction() ); plumed_massert(a,"cannot create passable values as base action does not inherit from ActionWithValue"); - std::vector moments; - std::string valstr = "moment-"; - parse("COMPONENT",mycomponent); - parseVector("MOMENTS",moments); - if( getNumericalLabel()!=0 ) { - std::string numstr; - Tools::convert( mycomponent, numstr); - valstr = "moment-" + numstr + "-"; - } - if( moments.size()==0 ) { - moments=Tools::getWords(getAllInput(),"\t\n ,"); - } - Tools::interpretRanges(moments); - unsigned nn; + std::vector moments; std::string valstr = "moment-"; + parse("COMPONENT",mycomponent); parseVector("MOMENTS",moments); + if( getNumericalLabel()!=0 ) { std::string numstr; Tools::convert( mycomponent, numstr); valstr = "moment-" + numstr + "-"; } + if( moments.size()==0 ) moments=Tools::getWords(getAllInput(),"\t\n ,"); + Tools::interpretRanges(moments); unsigned nn; for(unsigned i=0; iaddComponentWithDerivatives( valstr + moments[i] ); a->componentIsNotPeriodic( valstr + moments[i] ); value_out.push_back( a->copyOutput( a->getNumberOfComponents()-1 ) ); Tools::convert( moments[i], nn ); - if( nn<2 ) { - error("moments are only possible for m>=2" ); - } - powers.push_back( nn ); - std::string num; - Tools::convert(powers[i],num); + if( nn<2 ) error("moments are only possible for m>=2" ); + powers.push_back( nn ); std::string num; Tools::convert(powers[i],num); } } void Moments::resize() { resizeBuffer(0); if( getAction()->derivativesAreRequired() ) { - for(unsigned i=0; iresizeDerivatives( getAction()->getNumberOfDerivatives() ); - } + for(unsigned i=0; iresizeDerivatives( getAction()->getNumberOfDerivatives() ); } } @@ -123,8 +109,7 @@ std::string Moments::description() { descri = descri + "\n value " + getAction()->getLabel() + "." + "moment-" + num + " contains the " + num + "th moment of the distribution"; } } else { - std::string numlab; - Tools::convert( mycomponent, numlab ); + std::string numlab; Tools::convert( mycomponent, numlab ); descri = "value " + getAction()->getLabel() + "." + "moment-" + numlab + "-" + num + " contains the " + num + "th moment for the distribution of component " + numlab; for(unsigned i=1; i& buffer ) { unsigned nvals=getAction()->getFullNumberOfTasks(); std::vector myvalues( getAction()->getNumberOfQuantities() ); - double mean=0; - Value myvalue; + double mean=0; Value myvalue; if( getAction()->isPeriodic() ) { - std::string str_min, str_max; - getAction()->retrieveDomain( str_min, str_max ); - double pfactor, min, max; - Tools::convert(str_min,min); - Tools::convert(str_max,max); - pfactor = 2*pi / ( max-min ); - myvalue.setDomain( str_min, str_max ); + std::string str_min, str_max; getAction()->retrieveDomain( str_min, str_max ); + double pfactor, min, max; Tools::convert(str_min,min); Tools::convert(str_max,max); + pfactor = 2*pi / ( max-min ); myvalue.setDomain( str_min, str_max ); double sinsum=0, cossum=0, val; for(unsigned i=0; igetNumberOfStoredValues(); ++i) { mystash->retrieveSequentialValue( i, false, myvalues ); val=pfactor*( myvalues[mycomponent] - min ); - sinsum+=std::sin(val); - cossum+=std::cos(val); + sinsum+=std::sin(val); cossum+=std::cos(val); } mean = 0.5 + std::atan2( sinsum / static_cast( nvals ), cossum / static_cast( nvals ) ) / (2*pi); mean = min + (max-min)*mean; } else { for(unsigned i=0; igetNumberOfStoredValues(); ++i) { - mystash->retrieveSequentialValue( i, false, myvalues ); - mean+=myvalues[mycomponent]; + mystash->retrieveSequentialValue( i, false, myvalues ); mean+=myvalues[mycomponent]; } - mean/=static_cast( nvals ); - myvalue.setNotPeriodic(); + mean/=static_cast( nvals ); myvalue.setNotPeriodic(); } for(unsigned npow=0; npow& buffer ) { } double moment=0; - MultiValue myvals( getAction()->getNumberOfQuantities(), getAction()->getNumberOfDerivatives() ); - myvals.clearAll(); + MultiValue myvals( getAction()->getNumberOfQuantities(), getAction()->getNumberOfDerivatives() ); myvals.clearAll(); for(unsigned i=0; igetNumberOfStoredValues(); ++i) { mystash->retrieveSequentialValue( i, false, myvalues ); double tmp=myvalue.difference( mean, myvalues[mycomponent] ); @@ -194,23 +170,18 @@ void Moments::finish( const std::vector& buffer ) { myvals.clearAll(); } } - if( value_out[npow]->getNumberOfDerivatives()>0 ) { - value_out[npow]->chainRule( powers[npow] / static_cast( nvals ) ); - } + if( value_out[npow]->getNumberOfDerivatives()>0 ) value_out[npow]->chainRule( powers[npow] / static_cast( nvals ) ); value_out[npow]->set( moment / static_cast( nvals ) ); } } bool Moments::applyForce( std::vector& forces ) { std::vector tmpforce( forces.size() ); - forces.assign(forces.size(),0.0); - bool wasforced=false; + forces.assign(forces.size(),0.0); bool wasforced=false; for(unsigned i=0; iapplyForce( tmpforce ) ) { wasforced=true; - for(unsigned j=0; jisPeriodic() ) { - error("more than is not a meaningful option for periodic variables"); - } - std::string errormsg; - sf.set( getAllInput(), errormsg ); - if( errormsg.size()!=0 ) { - error( errormsg ); - } + if( getAction()->isPeriodic() ) error("more than is not a meaningful option for periodic variables"); + std::string errormsg; sf.set( getAllInput(), errormsg ); + if( errormsg.size()!=0 ) error( errormsg ); } std::string MoreThan::value_descriptor() { @@ -73,9 +69,7 @@ std::string MoreThan::value_descriptor() { } double MoreThan::calcTransform( const double& val, double& dv ) const { - double f = 1.0 - sf.calculate(val, dv); - dv*=-val; - return f; + double f = 1.0 - sf.calculate(val, dv); dv*=-val; return f; } } diff --git a/src/vesselbase/OrderingVessel.cpp b/src/vesselbase/OrderingVessel.cpp index 7981410e12..26a92227cf 100644 --- a/src/vesselbase/OrderingVessel.cpp +++ b/src/vesselbase/OrderingVessel.cpp @@ -31,42 +31,35 @@ void OrderingVessel::registerKeywords( Keywords& keys ) { } OrderingVessel::OrderingVessel( const VesselOptions& da ) : - ValueVessel(da) { + ValueVessel(da) +{ mydata = getAction()->buildDataStashes( NULL ); for(unsigned i=0; igetNumberOfVessels(); ++i) { - if( getAction()->getPntrToVessel(i)->getName()==getName() ) { + if( getAction()->getPntrToVessel(i)->getName()==getName() ) error("calculating lowest/highest value multiple times serves no purpose"); - } } } void OrderingVessel::resize() { resizeBuffer( 0 ); - if( getAction()->derivativesAreRequired() ) { - getFinalValue()->resizeDerivatives( getAction()->getNumberOfDerivatives() ); - } + if( getAction()->derivativesAreRequired() ) getFinalValue()->resizeDerivatives( getAction()->getNumberOfDerivatives() ); } void OrderingVessel::finish( const std::vector& buffer ) { std::vector values( getAction()->getNumberOfQuantities() ); mydata->retrieveSequentialValue( 0, false, values ); - double min=values[mycomp]; - unsigned mini=getAction()->getPositionInFullTaskList(0); + double min=values[mycomp]; unsigned mini=getAction()->getPositionInFullTaskList(0); for(unsigned i=1; igetNumberOfStoredValues(); ++i) { mydata->retrieveSequentialValue( i, false, values ); double newval = values[mycomp]; - if( compare( newval, min ) ) { - min=newval; - mini=getAction()->getPositionInFullTaskList(i); - } + if( compare( newval, min ) ) { min=newval; mini=getAction()->getPositionInFullTaskList(i); } } setOutputValue( min ); if( getAction()->derivativesAreRequired() ) { MultiValue myvals( getAction()->getNumberOfQuantities(), getAction()->getNumberOfDerivatives() ); - mydata->retrieveDerivatives( mini, false, myvals ); - Value* fval=getFinalValue(); + mydata->retrieveDerivatives( mini, false, myvals ); Value* fval=getFinalValue(); for(unsigned i=0; isetDerivative( ider, myvals.getDerivative(mycomp,ider) ); diff --git a/src/vesselbase/ShortcutVessel.cpp b/src/vesselbase/ShortcutVessel.cpp index d3d411c31b..e7147f1da7 100644 --- a/src/vesselbase/ShortcutVessel.cpp +++ b/src/vesselbase/ShortcutVessel.cpp @@ -26,21 +26,19 @@ namespace PLMD { namespace vesselbase { void ShortcutVessel::registerKeywords( Keywords& keys ) { - Vessel::registerKeywords( keys ); - keys.remove("LABEL"); + Vessel::registerKeywords( keys ); keys.remove("LABEL"); plumed_assert( keys.size()==0 ); } ShortcutVessel::ShortcutVessel( const VesselOptions& da): - Vessel(da) { + Vessel(da) +{ } void ShortcutVessel::addVessel( const std::string& name, const std::string& input ) { unsigned numlab=1; for(unsigned i=0; i<(getAction()->functions).size(); ++i) { - if( (getAction()->functions[i])->getName()==name ) { - numlab++; - } + if( (getAction()->functions[i])->getName()==name ) numlab++; } getAction()->addVessel( name, input, numlab ); } diff --git a/src/vesselbase/ShortcutVessel.h b/src/vesselbase/ShortcutVessel.h index 7811ffb6a2..016f0ef50f 100644 --- a/src/vesselbase/ShortcutVessel.h +++ b/src/vesselbase/ShortcutVessel.h @@ -37,21 +37,11 @@ class ShortcutVessel : public Vessel { public: static void registerKeywords( Keywords& keys ); explicit ShortcutVessel( const VesselOptions& ); - std::string description() override { - return ""; - } - void resize() override { - plumed_error(); - } - void calculate( const unsigned& taskCode, MultiValue& myvals, std::vector& buffer, std::vector& der_index ) const override { - plumed_error(); - } - void finish( const std::vector& buffer ) override { - plumed_error(); - } - bool applyForce( std::vector& forces ) override { - plumed_error(); - } + std::string description() override { return ""; } + void resize() override { plumed_error(); } + void calculate( const unsigned& taskCode, MultiValue& myvals, std::vector& buffer, std::vector& der_index ) const override { plumed_error(); } + void finish( const std::vector& buffer ) override { plumed_error(); } + bool applyForce( std::vector& forces ) override { plumed_error(); } }; } diff --git a/src/vesselbase/StoreDataVessel.cpp b/src/vesselbase/StoreDataVessel.cpp index b8e3fb4bad..956b037cc3 100644 --- a/src/vesselbase/StoreDataVessel.cpp +++ b/src/vesselbase/StoreDataVessel.cpp @@ -25,21 +25,18 @@ namespace PLMD { namespace vesselbase { void StoreDataVessel::registerKeywords( Keywords& keys ) { - Vessel::registerKeywords(keys); - keys.remove("LABEL"); + Vessel::registerKeywords(keys); keys.remove("LABEL"); } StoreDataVessel::StoreDataVessel( const VesselOptions& da ): Vessel(da), max_lowmem_stash(3), vecsize(0), - nspace(0) { + nspace(0) +{ ActionWithValue* myval=dynamic_cast( getAction() ); - if( !myval ) { - hasderiv=false; - } else { - hasderiv=!myval->doNotCalculateDerivatives(); - } + if( !myval ) hasderiv=false; + else hasderiv=!myval->doNotCalculateDerivatives(); } void StoreDataVessel::addActionThatUses( ActionWithVessel* actionThatUses ) { @@ -65,12 +62,10 @@ void StoreDataVessel::resize() { void StoreDataVessel::storeValues( const unsigned& myelem, MultiValue& myvals, std::vector& buffer ) const { plumed_dbg_assert( vecsize>0 ); - unsigned jelem = getAction()->getPositionInCurrentTaskList( myelem ); - plumed_dbg_assert( jelemgetPositionInCurrentTaskList( myelem ); plumed_dbg_assert( jelemgetFullNumberOfTasks()==getNumberOfStoredValues() ) { der_list[jelem]=myvals.getNumberActive(); unsigned kder = getNumberOfStoredValues() + jelem * ( nspace - 1 ); - for(unsigned j=0; j& values ) const { plumed_dbg_assert( values.size()==vecsize ); unsigned ibuf = jelem * vecsize * nspace; - for(unsigned i=0; i2 ) { - getAction()->normalizeVector( values ); - } + for(unsigned i=0; i2 ) getAction()->normalizeVector( values ); } void StoreDataVessel::retrieveValueWithIndex( const unsigned& myelem, const bool& normed, std::vector& values ) const { @@ -136,9 +115,7 @@ void StoreDataVessel::retrieveValueWithIndex( const unsigned& myelem, const bool double StoreDataVessel::retrieveWeightWithIndex( const unsigned& myelem ) const { plumed_dbg_assert( vecsize>0 ); - unsigned jelem = getStoreIndex( myelem ); - unsigned ibuf = jelem * vecsize * nspace; - return local_buffer[ibuf]; + unsigned jelem = getStoreIndex( myelem ); unsigned ibuf = jelem * vecsize * nspace; return local_buffer[ibuf]; } void StoreDataVessel::retrieveDerivatives( const unsigned& myelem, const bool& normed, MultiValue& myvals ) { @@ -147,9 +124,7 @@ void StoreDataVessel::retrieveDerivatives( const unsigned& myelem, const bool& n myvals.clearAll(); if( getAction()->lowmem ) { recalculateStoredQuantity( myelem, myvals ); - if( normed ) { - getAction()->normalizeVectorDerivatives( myvals ); - } + if( normed ) getAction()->normalizeVectorDerivatives( myvals ); } else { unsigned jelem = getAction()->getPositionInCurrentTaskList( myelem ); // Retrieve the derivatives for elements 0 and 1 - weight and norm @@ -158,20 +133,14 @@ void StoreDataVessel::retrieveDerivatives( const unsigned& myelem, const bool& n unsigned kder = getNumberOfStoredValues() + jelem * ( nspace - 1 ); for(unsigned j=0; jnormalizeVectorDerivatives( myvals ); - } + if( normed ) getAction()->normalizeVectorDerivatives( myvals ); // Now ensure appropriate parts of list are activated myvals.emptyActiveMembers(); unsigned kder = getNumberOfStoredValues() + jelem * ( nspace - 1 ); - for(unsigned j=0; jepsilon ) { storeValues( current, myvals, buffer ); - if( !(getAction()->lowmem) && getAction()->derivativesAreRequired() ) { - storeDerivatives( current, myvals, buffer, der_list ); - } + if( !(getAction()->lowmem) && getAction()->derivativesAreRequired() ) storeDerivatives( current, myvals, buffer, der_list ); } return; @@ -190,29 +157,22 @@ void StoreDataVessel::calculate( const unsigned& current, MultiValue& myvals, st void StoreDataVessel::finish( const std::vector& buffer ) { // Store the buffer locally - for(unsigned i=0; i& der_index ) { if( !getAction()->lowmem && getAction()->derivativesAreRequired() ) { - for(unsigned i=0; i& values ) const ; void retrieveValueWithIndex( const unsigned& myelem, const bool& normed, std::vector& values ) const ; @@ -109,9 +107,7 @@ class StoreDataVessel : public Vessel { /// Do all resizing of data void resize() override; /// - std::string description() override { - return ""; - } + std::string description() override { return ""; } /// Get the number of derivatives for the ith value unsigned getNumberOfDerivatives( const unsigned& ); /// Get the size of the derivative list @@ -127,9 +123,7 @@ class StoreDataVessel : public Vessel { /// Activate indexes (this is used at end of chain rule) virtual void activateIndices( ActionWithVessel* ) {} /// Forces on vectors should always be applied elsewhere - bool applyForce(std::vector&) override { - return false; - } + bool applyForce(std::vector&) override { return false; } /// Get the number of data users unsigned getNumberOfDataUsers() const ; /// Get one of the ith data user @@ -157,9 +151,7 @@ unsigned StoreDataVessel::getNumberOfDerivativeSpacesPerComponent() const { inline bool StoreDataVessel::storedValueIsActive( const unsigned& iatom ) const { - if( !getAction()->taskIsCurrentlyActive( iatom ) ) { - return false; - } + if( !getAction()->taskIsCurrentlyActive( iatom ) ) return false; unsigned jatom = getStoreIndex( iatom ); plumed_dbg_assert( jatomepsilon; @@ -177,22 +169,16 @@ unsigned StoreDataVessel::getNumberOfStoredValues() const { inline unsigned StoreDataVessel::getStoreIndex( const unsigned& ind ) const { - if( getAction()->nactive_tasks==getAction()->getFullNumberOfTasks() ) { - return ind; - } + if( getAction()->nactive_tasks==getAction()->getFullNumberOfTasks() ) return ind; // Binary search for required element - faster scaling than sequential search unsigned l=0, r=getAction()->nactive_tasks-1; for(unsigned i=0; inactive_tasks; ++i) { plumed_assert( l<=r ); unsigned m = std::floor( (l + r)/2 ); - if( ind==getAction()->indexOfTaskInFullList[m] ) { - return m; - } else if( getAction()->indexOfTaskInFullList[m]indexOfTaskInFullList[m]>ind ) { - r=m-1; - } + if( ind==getAction()->indexOfTaskInFullList[m] ) return m; + else if( getAction()->indexOfTaskInFullList[m]indexOfTaskInFullList[m]>ind ) r=m-1; } plumed_merror("requested task is not active"); } @@ -214,8 +200,7 @@ unsigned StoreDataVessel::getNumberOfDataUsers() const { inline ActionWithVessel* StoreDataVessel::getDataUser( const unsigned& idata ) { - plumed_dbg_assert( idata( getAction() ); plumed_massert(a,"cannot create passable values as base action does not inherit from ActionWithValue"); @@ -52,23 +53,17 @@ ValueVessel::ValueVessel( const VesselOptions& da ): } std::string ValueVessel::description() { - if( final_value->getName()==getAction()->getLabel() ) { - return "value " + getAction()->getLabel() + " contains " + value_descriptor(); - } - std::string compstr; - Tools::convert(mycomp,compstr); + if( final_value->getName()==getAction()->getLabel() ) return "value " + getAction()->getLabel() + " contains " + value_descriptor(); + std::string compstr; Tools::convert(mycomp,compstr); return "value " + getAction()->getLabel() + "." + getLabel() + " is obtained by taking the " + compstr + "th component and finding " + value_descriptor(); } bool ValueVessel::applyForce( std::vector& forces ) { std::vector tmpforce( forces.size() ); - forces.assign(forces.size(),0.0); - bool wasforced=false; + forces.assign(forces.size(),0.0); bool wasforced=false; if( final_value->applyForce( tmpforce ) ) { wasforced=true; - for(unsigned j=0; j0) { mylabel=da.mylabel; } else { - if( keywords.exists("LABEL") ) { - parse("LABEL",mylabel); - } + if( keywords.exists("LABEL") ) parse("LABEL",mylabel); if( mylabel.length()==0 && numlab>=0 ) { - mylabel=transformName( myname ); - std::string nn; - if(numlab>0) { - Tools::convert( numlab, nn ); - mylabel = mylabel + "-" + nn; - } + mylabel=transformName( myname ); std::string nn; + if(numlab>0) { Tools::convert( numlab, nn ); mylabel = mylabel + "-" + nn; } } } } @@ -107,8 +100,7 @@ std::string Vessel::getAllInput() { for(unsigned i=0; i0) { - msg = msg + ", "; - } + if(i>0) msg = msg + ", "; msg = msg + line[i]; } error(msg); } finished_read=true; std::string describe=description(); - if( describe.length()>0 && action ) { - action->log.printf(" %s\n", describe.c_str() ); - } + if( describe.length()>0 && action ) action->log.printf(" %s\n", describe.c_str() ); } [[noreturn]] void Vessel::error( const std::string& msg ) { if( action ) { action->log.printf("ERROR for keyword %s in action %s with label %s : %s \n \n",myname.c_str(), (action->getName()).c_str(), (action->getLabel()).c_str(), msg.c_str() ); - if(finished_read) { - keywords.print( action->log ); - } + if(finished_read) keywords.print( action->log ); plumed_merror("ERROR for keyword " + myname + " in action " + action->getName() + " with label " + action->getLabel() + " : " + msg ); } else { plumed_merror("ERROR: " + msg); diff --git a/src/vesselbase/Vessel.h b/src/vesselbase/Vessel.h index 42838ab6f8..04ab6b0520 100644 --- a/src/vesselbase/Vessel.h +++ b/src/vesselbase/Vessel.h @@ -158,8 +158,7 @@ void Vessel::parse(const std::string&key, T&t ) { plumed_massert(keywords.exists(key),"keyword " + key + " has not been registered"); // Now try to read the keyword - bool found=Tools::parse(line,key,t); - std::string def; + bool found=Tools::parse(line,key,t); std::string def; if ( !found && keywords.style(key,"compulsory") ) { if( keywords.getDefaultValue(key,def) ) { plumed_massert( def.length()!=0 && Tools::convertNoexcept(def,t), "default value is dubious"); @@ -173,23 +172,16 @@ template void Vessel::parseVector(const std::string&key,std::vector&t) { // Check keyword has been registered plumed_massert(keywords.exists(key), "keyword " + key + " has not been registered"); - unsigned size=t.size(); - bool skipcheck=false; - if(size==0) { - skipcheck=true; - } + unsigned size=t.size(); bool skipcheck=false; + if(size==0) skipcheck=true; // Now try to read the keyword - bool found; - std::string def; - T val; + bool found; std::string def; T val; found=Tools::parseVector(line,key,t); // Check vectors size is correct (not if this is atoms or ARG) if( !keywords.style(key,"atoms") && found ) { - if( !skipcheck && t.size()!=size ) { - error("vector read in for keyword " + key + " has the wrong size"); - } + if( !skipcheck && t.size()!=size ) error("vector read in for keyword " + key + " has the wrong size"); } // If it isn't read and it is compulsory see if a default value was specified @@ -198,9 +190,7 @@ void Vessel::parseVector(const std::string&key,std::vector&t) { if( def.length()==0 || !Tools::convertNoexcept(def,val) ) { plumed_merror("weird default value for keyword " + key ); } else { - for(unsigned i=0; i0) { std::string names=""; - for(const auto & p : m) { - names+=p.first+" "; - } + for(const auto & p : m) names+=p.first+" "; std::cerr<<"WARNING: Vessel "+ names +" has not been properly unregistered. This might lead to memory leak!!\n"; } } @@ -44,8 +42,7 @@ VesselRegister& vesselRegister() { void VesselRegister::remove(creator_pointer f) { for(auto p=m.begin(); p!=m.end(); ++p) { if((*p).second==f) { - m.erase(p); - break; + m.erase(p); break; } } } @@ -61,17 +58,14 @@ void VesselRegister::add(std::string keyword,creator_pointer f,keyword_pointer k } bool VesselRegister::check(const std::string & key) { - if( m.count(key)>0 ) { - return true; - } + if( m.count(key)>0 ) return true; return false; } std::unique_ptr VesselRegister::create(std::string keyword, const VesselOptions&da) { std::unique_ptr df; if(check(keyword)) { - Keywords keys; - mk[keyword](keys); + Keywords keys; mk[keyword](keys); VesselOptions nda( da,keys ); df=m[keyword](nda); } diff --git a/src/wrapper/Plumed.h b/src/wrapper/Plumed.h index 40691255eb..d65d1a52e8 100644 --- a/src/wrapper/Plumed.h +++ b/src/wrapper/Plumed.h @@ -895,9 +895,7 @@ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_init(plumed_error* error) __PLU /** Finalize error - should be called when an error is raised to avoid leaks */ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_finalize(plumed_error error) __PLUMED_WRAPPER_CXX_NOEXCEPT { - if(!error.code) { - return; - } + if(!error.code) return; if(error.nested) { plumed_error_finalize(*error.nested); plumed_free(error.nested); @@ -926,9 +924,7 @@ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_set_bad_alloc(plumed_error*erro /** Recursive merge (for internal usage) */ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_recursive_merge(plumed_error* error,char*buffer,const char*join,__PLUMED_WRAPPER_STD size_t*len) __PLUMED_WRAPPER_CXX_NOEXCEPT { - if(error->nested) { - plumed_error_recursive_merge(error->nested,buffer,join,len); - } + if(error->nested) plumed_error_recursive_merge(error->nested,buffer,join,len); __PLUMED_WRAPPER_STD strncat(buffer,plumed_error_what(*error),*len); *len -= __PLUMED_WRAPPER_STD strlen(plumed_error_what(*error)); __PLUMED_WRAPPER_STD strncat(buffer,join,*len); @@ -947,9 +943,7 @@ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_merge_with_nested(plumed_error* plumed_error*e; /* If exception is not nested, nothing to do */ - if(!error->nested) { - return; - } + if(!error->nested) return; /* Accumulate the total length of the concatenated message */ len_join=__PLUMED_WRAPPER_STD strlen(join); @@ -979,9 +973,7 @@ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_merge_with_nested(plumed_error* error->what=new_buffer; /* Deallocate the previous message */ - if(error->what_buffer) { - plumed_free(error->what_buffer); - } + if(error->what_buffer) plumed_free(error->what_buffer); error->what_buffer=new_buffer; /* Finalize the chain of nested exceptions */ @@ -997,9 +989,7 @@ __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_merge_with_nested(plumed_error* /** Rethrow error (calling abort) */ __PLUMED_WRAPPER_CXX_NORETURN __PLUMED_WRAPPER_STATIC_INLINE void plumed_error_rethrow(plumed_error h) { - if(h.nested) { - plumed_error_merge_with_nested(&h); - } + if(h.nested) plumed_error_merge_with_nested(&h); __PLUMED_WRAPPER_STD fprintf(stderr,"Terminate due to exception. Code: %d\n%s\n",h.code,plumed_error_what(h)); __PLUMED_WRAPPER_STD abort(); } @@ -1757,65 +1747,33 @@ class Plumed { finalize_plumed_error finalize(h); /* grab the message */ const char* msg=plumed_error_what(h); - if(h.code==1) { - f(Plumed::Invalid(msg)); - } + if(h.code==1) f(Plumed::Invalid(msg)); /* logic errors */ if(h.code>=10100 && h.code<10200) { - if(h.code>=10105 && h.code<10110) { - f(::std::invalid_argument(msg)); - } - if(h.code>=10110 && h.code<10115) { - f(::std::domain_error(msg)); - } - if(h.code>=10115 && h.code<10120) { - f(::std::length_error(msg)); - } - if(h.code>=10120 && h.code<10125) { - f(::std::out_of_range(msg)); - } + if(h.code>=10105 && h.code<10110) f(::std::invalid_argument(msg)); + if(h.code>=10110 && h.code<10115) f(::std::domain_error(msg)); + if(h.code>=10115 && h.code<10120) f(::std::length_error(msg)); + if(h.code>=10120 && h.code<10125) f(::std::out_of_range(msg)); f(::std::logic_error(msg)); } /* runtime errors */ if(h.code>=10200 && h.code<10300) { - if(h.code>=10205 && h.code<10210) { - f(::std::range_error(msg)); - } - if(h.code>=10210 && h.code<10215) { - f(::std::overflow_error(msg)); - } - if(h.code>=10215 && h.code<10220) { - f(::std::underflow_error(msg)); - } + if(h.code>=10205 && h.code<10210) f(::std::range_error(msg)); + if(h.code>=10210 && h.code<10215) f(::std::overflow_error(msg)); + if(h.code>=10215 && h.code<10220) f(::std::underflow_error(msg)); #if __cplusplus > 199711L && __PLUMED_WRAPPER_LIBCXX11 - if(h.code==10220) { - f(::std::system_error(h.error_code,::std::generic_category(),msg)); - } - if(h.code==10221) { - f(::std::system_error(h.error_code,::std::system_category(),msg)); - } - if(h.code==10222) { - f(::std::system_error(h.error_code,::std::iostream_category(),msg)); - } - if(h.code==10223) { - f(::std::system_error(h.error_code,::std::future_category(),msg)); - } + if(h.code==10220) f(::std::system_error(h.error_code,::std::generic_category(),msg)); + if(h.code==10221) f(::std::system_error(h.error_code,::std::system_category(),msg)); + if(h.code==10222) f(::std::system_error(h.error_code,::std::iostream_category(),msg)); + if(h.code==10223) f(::std::system_error(h.error_code,::std::future_category(),msg)); #endif if(h.code>=10230 && h.code<10240) { #if __cplusplus > 199711L && __PLUMED_WRAPPER_LIBCXX11 // These cases are probably useless as it looks like this should always be std::iostream_category - if(h.code==10230) { - f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::generic_category()))); - } - if(h.code==10231) { - f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::system_category()))); - } - if(h.code==10232) { - f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::iostream_category()))); - } - if(h.code==10233) { - f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::future_category()))); - } + if(h.code==10230) f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::generic_category()))); + if(h.code==10231) f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::system_category()))); + if(h.code==10232) f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::iostream_category()))); + if(h.code==10233) f(::std::ios_base::failure(msg,::std::error_code(h.error_code,::std::future_category()))); #endif f(::std::ios_base::failure(msg)); } @@ -1823,49 +1781,29 @@ class Plumed { } /* "bad" errors */ /* "< ::" space required in C++ < 11 */ - if(h.code>=11000 && h.code<11100) { - f(add_buffer_to< ::std::bad_typeid>(msg)); - } - if(h.code>=11100 && h.code<11200) { - f(add_buffer_to< ::std::bad_cast>(msg)); - } + if(h.code>=11000 && h.code<11100) f(add_buffer_to< ::std::bad_typeid>(msg)); + if(h.code>=11100 && h.code<11200) f(add_buffer_to< ::std::bad_cast>(msg)); #if __cplusplus > 199711L && __PLUMED_WRAPPER_LIBCXX11 - if(h.code>=11200 && h.code<11300) { - f(add_buffer_to< ::std::bad_weak_ptr>(msg)); - } - if(h.code>=11300 && h.code<11400) { - f(add_buffer_to< ::std::bad_function_call>(msg)); - } + if(h.code>=11200 && h.code<11300) f(add_buffer_to< ::std::bad_weak_ptr>(msg)); + if(h.code>=11300 && h.code<11400) f(add_buffer_to< ::std::bad_function_call>(msg)); #endif if(h.code>=11400 && h.code<11500) { #if __cplusplus > 199711L && __PLUMED_WRAPPER_LIBCXX11 - if(h.code>=11410 && h.code<11420) { - f(add_buffer_to< ::std::bad_array_new_length>(msg)); - } + if(h.code>=11410 && h.code<11420) f(add_buffer_to< ::std::bad_array_new_length>(msg)); #endif f(add_buffer_to< ::std::bad_alloc>(msg)); } - if(h.code>=11500 && h.code<11600) { - f(add_buffer_to< ::std::bad_exception>(msg)); - } + if(h.code>=11500 && h.code<11600) f(add_buffer_to< ::std::bad_exception>(msg)); /* lepton error */ - if(h.code>=19900 && h.code<20000) { - f(Plumed::LeptonException(msg)); - } + if(h.code>=19900 && h.code<20000) f(Plumed::LeptonException(msg)); /* plumed exceptions */ if(h.code>=20000 && h.code<30000) { /* debug - only raised with debug options */ - if(h.code>=20100 && h.code<20200) { - f(Plumed::ExceptionDebug(msg)); - } + if(h.code>=20100 && h.code<20200) f(Plumed::ExceptionDebug(msg)); /* error - runtime check */ - if(h.code>=20200 && h.code<20300) { - f(Plumed::ExceptionError(msg)); - } + if(h.code>=20200 && h.code<20300) f(Plumed::ExceptionError(msg)); /* error - type error */ - if(h.code>=20300 && h.code<20400) { - f(Plumed::ExceptionTypeError(msg)); - } + if(h.code>=20300 && h.code<20400) f(Plumed::ExceptionTypeError(msg)); f(Plumed::Exception(msg)); } /* fallback for any other exception */ @@ -1920,9 +1858,7 @@ class Plumed { When using C++11 nested exceptions, we need to rethrow recursively */ try { - if(h.nested) { - rethrow(*h.nested); /* recursive throw */ - } + if(h.nested) rethrow(*h.nested); /* recursive throw */ } catch(...) { exception_dispatch(h,rethrow_nested()); } @@ -1931,9 +1867,7 @@ class Plumed { /* When using C++<11 exceptions, we merge the message and then throw the resulting exception */ - if(h.nested) { - plumed_error_merge_with_nested(&h); - } + if(h.nested) plumed_error_merge_with_nested(&h); exception_dispatch(h,rethrow_not_nested()); #endif } @@ -2038,13 +1972,12 @@ class Plumed { Base class used to rethrow PLUMED exceptions. */ class Exception : - public ::std::exception { + public ::std::exception + { ::std::string msg; public: __PLUMED_WRAPPER_CXX_EXPLICIT Exception(const char* msg): msg(msg) {} - const char* what() const __PLUMED_WRAPPER_CXX_NOEXCEPT __PLUMED_WRAPPER_CXX_OVERRIDE { - return msg.c_str(); - } + const char* what() const __PLUMED_WRAPPER_CXX_NOEXCEPT __PLUMED_WRAPPER_CXX_OVERRIDE {return msg.c_str();} #if ! (__cplusplus > 199711L) /* Destructor should be declared in order to have the correct throw() before C++11 */ /* see https://stackoverflow.com/questions/50025862/why-is-the-stdexception-destructor-not-noexcept */ @@ -2130,13 +2063,12 @@ class Plumed { */ class LeptonException : - public ::std::exception { + public ::std::exception + { ::std::string msg; public: __PLUMED_WRAPPER_CXX_EXPLICIT LeptonException(const char* msg): msg(msg) {} - const char* what() const __PLUMED_WRAPPER_CXX_NOEXCEPT __PLUMED_WRAPPER_CXX_OVERRIDE { - return msg.c_str(); - } + const char* what() const __PLUMED_WRAPPER_CXX_NOEXCEPT __PLUMED_WRAPPER_CXX_OVERRIDE {return msg.c_str();} #if ! (__cplusplus > 199711L) /* Destructor should be declared in order to have the correct throw() before C++11 */ /* see https://stackoverflow.com/questions/50025862/why-is-the-stdexception-destructor-not-noexcept */ @@ -2156,33 +2088,27 @@ class Plumed { template class add_buffer_to: - public T { - char msg[__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER]; - \ + public T + { + char msg[__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER]; \ public: __PLUMED_WRAPPER_CXX_EXPLICIT add_buffer_to(const char * msg) __PLUMED_WRAPPER_CXX_NOEXCEPT { this->msg[0]='\0'; __PLUMED_WRAPPER_STD strncat(this->msg,msg,__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1); this->msg[__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1]='\0'; - if(PlumedGetenvExceptionsDebug() && __PLUMED_WRAPPER_STD strlen(msg) > __PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1) { - __PLUMED_WRAPPER_STD fprintf(stderr,"+++ WARNING: message will be truncated\n"); - } + if(PlumedGetenvExceptionsDebug() && __PLUMED_WRAPPER_STD strlen(msg) > __PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1) __PLUMED_WRAPPER_STD fprintf(stderr,"+++ WARNING: message will be truncated\n"); } add_buffer_to(const add_buffer_to & other) __PLUMED_WRAPPER_CXX_NOEXCEPT { msg[0]='\0'; __PLUMED_WRAPPER_STD memcpy(msg,other.msg,__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER); } add_buffer_to & operator=(const add_buffer_to & other) __PLUMED_WRAPPER_CXX_NOEXCEPT { - if(this==&other) { - return *this; - } + if(this==&other) return *this; msg[0]='\0'; __PLUMED_WRAPPER_STD memcpy(msg,other.msg,__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER); return *this; } - const char* what() const __PLUMED_WRAPPER_CXX_NOEXCEPT __PLUMED_WRAPPER_CXX_OVERRIDE { - return msg; - } + const char* what() const __PLUMED_WRAPPER_CXX_NOEXCEPT __PLUMED_WRAPPER_CXX_OVERRIDE {return msg;} #if ! (__cplusplus > 199711L) /* Destructor should be declared in order to have the correct throw() before C++11 */ /* see https://stackoverflow.com/questions/50025862/why-is-the-stdexception-destructor-not-noexcept */ @@ -2221,12 +2147,8 @@ class Plumed { __PLUMED_WRAPPER_CXX_EXPLICIT SafePtr(const plumed_safeptr & safe,__PLUMED_WRAPPER_STD size_t nelem=0, const __PLUMED_WRAPPER_STD size_t* shape=__PLUMED_WRAPPER_CXX_NULLPTR) __PLUMED_WRAPPER_CXX_NOEXCEPT { this->safe=safe; buffer[0]='\0'; - if(nelem>0) { - this->safe.nelem=nelem; - } - if(shape) { - this->safe.shape=const_cast<__PLUMED_WRAPPER_STD size_t*>(shape); - } + if(nelem>0) this->safe.nelem=nelem; + if(shape) this->safe.shape=const_cast<__PLUMED_WRAPPER_STD size_t*>(shape); } #if __cplusplus > 199711L @@ -2492,14 +2414,16 @@ Plumed()__PLUMED_WRAPPER_CXX_NOEXCEPT : if the created object is still in scope. */ __PLUMED_WRAPPER_CXX_EXPLICIT Plumed(const char*c)__PLUMED_WRAPPER_CXX_NOEXCEPT : - main(plumed_create_reference_f(c)) { + main(plumed_create_reference_f(c)) + { } /** Create a reference from a void* pointer. Available as of PLUMED 2.5. */ __PLUMED_WRAPPER_CXX_EXPLICIT Plumed(void*v)__PLUMED_WRAPPER_CXX_NOEXCEPT : - main(plumed_create_reference_v(v)) { + main(plumed_create_reference_v(v)) + { } /** @@ -2512,7 +2436,8 @@ __PLUMED_WRAPPER_CXX_EXPLICIT Plumed(void*v)__PLUMED_WRAPPER_CXX_NOEXCEPT : if the created object is still in scope. */ __PLUMED_WRAPPER_CXX_EXPLICIT Plumed(plumed p)__PLUMED_WRAPPER_CXX_NOEXCEPT : - main(plumed_create_reference(p)) { + main(plumed_create_reference(p)) + { } /** Copy constructor. @@ -2520,7 +2445,8 @@ __PLUMED_WRAPPER_CXX_EXPLICIT Plumed(plumed p)__PLUMED_WRAPPER_CXX_NOEXCEPT : Takes a reference, incrementing the reference counter of the corresponding object. */ Plumed(const Plumed& p)__PLUMED_WRAPPER_CXX_NOEXCEPT : - main(plumed_create_reference(p.main)) { + main(plumed_create_reference(p.main)) + { } /** Assignment operator. Available as of PLUMED 2.5. @@ -2530,9 +2456,7 @@ Plumed(const Plumed& p)__PLUMED_WRAPPER_CXX_NOEXCEPT : Plumed&operator=(const Plumed&p) __PLUMED_WRAPPER_CXX_NOEXCEPT { if(this != &p) { // the check is needed to avoid calling plumed_finalize on moved objects - if(main.p) { - plumed_finalize(main); - } + if(main.p) plumed_finalize(main); main=plumed_create_reference(p.main); } return *this; @@ -2549,7 +2473,8 @@ Plumed(const Plumed& p)__PLUMED_WRAPPER_CXX_NOEXCEPT : Only if move semantics is enabled. */ Plumed(Plumed&&p)__PLUMED_WRAPPER_CXX_NOEXCEPT : - main(p.main) { + main(p.main) + { p.main.p=nullptr; } /** Move assignment. Available as of PLUMED 2.5. @@ -2558,9 +2483,7 @@ Plumed(Plumed&&p)__PLUMED_WRAPPER_CXX_NOEXCEPT : Plumed& operator=(Plumed&&p)__PLUMED_WRAPPER_CXX_NOEXCEPT { if(this != &p) { // the check is needed to avoid calling plumed_finalize on moved objects - if(main.p) { - plumed_finalize(main); - } + if(main.p) plumed_finalize(main); main=p.main; p.main.p=nullptr; } @@ -2774,9 +2697,7 @@ Plumed(Plumed&&p)__PLUMED_WRAPPER_CXX_NOEXCEPT : rethrow(); } /* plumed_error_rethrow is finalizing */ - if(!error && error_cxx.code!=0) { - plumed_error_rethrow_cxx(error_cxx); - } + if(!error && error_cxx.code!=0) plumed_error_rethrow_cxx(error_cxx); } public: @@ -2835,9 +2756,7 @@ Plumed(Plumed&&p)__PLUMED_WRAPPER_CXX_NOEXCEPT : */ template void cmd(const char*key,T* val, std::initializer_list shape) { - if(shape.size()>4) { - throw Plumed::ExceptionTypeError("Maximum shape size is 4"); - } + if(shape.size()>4) throw Plumed::ExceptionTypeError("Maximum shape size is 4"); std::array shape_; unsigned j=0; for(auto i : shape) { @@ -2879,9 +2798,7 @@ Plumed(Plumed&&p)__PLUMED_WRAPPER_CXX_NOEXCEPT : #endif ~Plumed() __PLUMED_WRAPPER_CXX_NOEXCEPT { // the check is needed to avoid calling plumed_finalize on moved objects - if(main.p) { - plumed_finalize(main); - } + if(main.p) plumed_finalize(main); } /** @@ -3396,9 +3313,7 @@ void* plumed_attempt_dlopen(const char*path,int mode) { } __PLUMED_WRAPPER_STD strncpy(pathcopy,path,strlenpath+1); pc=pathcopy+strlenpath-6; - while(pc>=pathcopy && __PLUMED_WRAPPER_STD memcmp(pc,"Kernel",6)) { - pc--; - } + while(pc>=pathcopy && __PLUMED_WRAPPER_STD memcmp(pc,"Kernel",6)) pc--; if(pc>=pathcopy) { __PLUMED_WRAPPER_STD memmove(pc, pc+6, __PLUMED_WRAPPER_STD strlen(pc)-5); __PLUMED_FPRINTF(stderr,"+++ This error is expected if you are trying to load a kernel <=2.4\n"); @@ -3412,9 +3327,7 @@ void* plumed_attempt_dlopen(const char*path,int mode) { __PLUMED_WRAPPER_STD fclose(fp); dlerror(); p=dlopen(pathcopy,mode); - if(!p) { - __PLUMED_FPRINTF(stderr,"+++ An error occurred. Message from dlopen(): %s +++\n",dlerror()); - } + if(!p) __PLUMED_FPRINTF(stderr,"+++ An error occurred. Message from dlopen(): %s +++\n",dlerror()); } plumed_free(pathcopy); } @@ -3462,9 +3375,7 @@ void plumed_search_symbols(void* handle, plumed_plumedmain_function_holder* f,pl */ debug=__PLUMED_GETENV("PLUMED_LOAD_DEBUG"); table_ptr=(plumed_symbol_table_type*) dlsym(handle,"plumed_symbol_table"); - if(table_ptr) { - functions=table_ptr->functions; - } + if(table_ptr) functions=table_ptr->functions; if(debug) { if(table_ptr) { __PLUMED_FPRINTF(stderr,"+++ plumed_symbol_table version %i found at %p +++\n",table_ptr->version,(void*)table_ptr); @@ -3487,29 +3398,17 @@ void plumed_search_symbols(void* handle, plumed_plumedmain_function_holder* f,pl __PLUMED_SEARCH_FUNCTION(tmpptr,handle,functions.finalize,"plumedmain_finalize",debug); __PLUMED_SEARCH_FUNCTION(tmpptr,handle,functions.finalize,"plumed_plumedmain_finalize",debug); if(functions.create && functions.cmd && functions.finalize) { - if(debug) { - __PLUMED_FPRINTF(stderr,"+++ PLUMED was loaded correctly +++\n"); - } + if(debug) __PLUMED_FPRINTF(stderr,"+++ PLUMED was loaded correctly +++\n"); *f=functions; - if(table) { - *table=table_ptr; - } + if(table) *table=table_ptr; } else { - if(!functions.create) { - __PLUMED_FPRINTF(stderr,"+++ Pointer to (plumed_)plumedmain_create not found +++\n"); - } - if(!functions.cmd) { - __PLUMED_FPRINTF(stderr,"+++ Pointer to (plumed_)plumedmain_cmd not found +++\n"); - } - if(!functions.finalize) { - __PLUMED_FPRINTF(stderr,"+++ Pointer to (plumed_)plumedmain_finalize not found +++\n"); - } + if(!functions.create) __PLUMED_FPRINTF(stderr,"+++ Pointer to (plumed_)plumedmain_create not found +++\n"); + if(!functions.cmd) __PLUMED_FPRINTF(stderr,"+++ Pointer to (plumed_)plumedmain_cmd not found +++\n"); + if(!functions.finalize) __PLUMED_FPRINTF(stderr,"+++ Pointer to (plumed_)plumedmain_finalize not found +++\n"); f->create=__PLUMED_WRAPPER_CXX_NULLPTR; f->cmd=__PLUMED_WRAPPER_CXX_NULLPTR; f->finalize=__PLUMED_WRAPPER_CXX_NULLPTR; - if(table) { - *table=__PLUMED_WRAPPER_CXX_NULLPTR; - } + if(table) *table=__PLUMED_WRAPPER_CXX_NULLPTR; } } __PLUMED_WRAPPER_INTERNALS_END @@ -3576,30 +3475,18 @@ void plumed_retrieve_functions(plumed_plumedmain_function_holder* functions, plu This makes the symbols hardcoded and independent of a mis-set PLUMED_KERNEL variable. */ plumed_symbol_table_type* ptr=plumed_symbol_table_reexport(); - if(plumed_symbol_table_ptr) { - *plumed_symbol_table_ptr=ptr; - } - if(handle) { - *handle=__PLUMED_WRAPPER_CXX_NULLPTR; - } - if(functions) { - *functions=ptr->functions; - } + if(plumed_symbol_table_ptr) *plumed_symbol_table_ptr=ptr; + if(handle) *handle=__PLUMED_WRAPPER_CXX_NULLPTR; + if(functions) *functions=ptr->functions; #elif ! defined(__PLUMED_HAS_DLOPEN) /* When dlopen is not available, we hard code them to NULL */ __PLUMED_FPRINTF(stderr,"+++ PLUMED has been compiled without dlopen and without a static kernel +++\n"); plumed_plumedmain_function_holder g= {__PLUMED_WRAPPER_CXX_NULLPTR,__PLUMED_WRAPPER_CXX_NULLPTR,__PLUMED_WRAPPER_CXX_NULLPTR}; - if(plumed_symbol_table_ptr) { - *plumed_symbol_table_ptr=__PLUMED_WRAPPER_CXX_NULLPTR; - } - if(handle) { - *handle=__PLUMED_WRAPPER_CXX_NULLPTR; - } - if(functions) { - *functions=g; - } + if(plumed_symbol_table_ptr) *plumed_symbol_table_ptr=__PLUMED_WRAPPER_CXX_NULLPTR; + if(handle) *handle=__PLUMED_WRAPPER_CXX_NULLPTR; + if(functions) *functions=g; #else /* On the other hand, for runtime binding, we use dlsym to find the relevant functions. @@ -3617,12 +3504,8 @@ void plumed_retrieve_functions(plumed_plumedmain_function_holder* functions, plu p=__PLUMED_WRAPPER_CXX_NULLPTR; debug=__PLUMED_GETENV("PLUMED_LOAD_DEBUG"); dlopenmode=0; - if(plumed_symbol_table_ptr) { - *plumed_symbol_table_ptr=__PLUMED_WRAPPER_CXX_NULLPTR; - } - if(handle) { - *handle=__PLUMED_WRAPPER_CXX_NULLPTR; - } + if(plumed_symbol_table_ptr) *plumed_symbol_table_ptr=__PLUMED_WRAPPER_CXX_NULLPTR; + if(handle) *handle=__PLUMED_WRAPPER_CXX_NULLPTR; #ifdef __PLUMED_DEFAULT_KERNEL /* This variable allows a default path for the kernel to be hardcoded. @@ -3634,52 +3517,34 @@ void plumed_retrieve_functions(plumed_plumedmain_function_holder* functions, plu /* This is required to add quotes */ #define PLUMED_QUOTE_DIRECT(name) #name #define PLUMED_QUOTE(macro) PLUMED_QUOTE_DIRECT(macro) - if(! (path && (*path) )) { - path=PLUMED_QUOTE(__PLUMED_DEFAULT_KERNEL); - } + if(! (path && (*path) )) path=PLUMED_QUOTE(__PLUMED_DEFAULT_KERNEL); #endif if(path && (*path)) { __PLUMED_FPRINTF(stderr,"+++ Loading the PLUMED kernel runtime +++\n"); __PLUMED_FPRINTF(stderr,"+++ PLUMED_KERNEL=\"%s\" +++\n",path); - if(debug) { - __PLUMED_FPRINTF(stderr,"+++ Loading with mode RTLD_NOW"); - } + if(debug) __PLUMED_FPRINTF(stderr,"+++ Loading with mode RTLD_NOW"); dlopenmode=RTLD_NOW; if(__PLUMED_GETENV("PLUMED_LOAD_NAMESPACE") && !__PLUMED_WRAPPER_STD strcmp(__PLUMED_GETENV("PLUMED_LOAD_NAMESPACE"),"LOCAL")) { dlopenmode=dlopenmode|RTLD_LOCAL; - if(debug) { - __PLUMED_FPRINTF(stderr,"|RTLD_LOCAL"); - } + if(debug) __PLUMED_FPRINTF(stderr,"|RTLD_LOCAL"); } else { dlopenmode=dlopenmode|RTLD_GLOBAL; - if(debug) { - __PLUMED_FPRINTF(stderr,"|RTLD_GLOBAL"); - } + if(debug) __PLUMED_FPRINTF(stderr,"|RTLD_GLOBAL"); } #ifdef RTLD_DEEPBIND #if __PLUMED_WRAPPER_ENABLE_RTLD_DEEPBIND if(!__PLUMED_GETENV("PLUMED_LOAD_NODEEPBIND")) { dlopenmode=dlopenmode|RTLD_DEEPBIND; - if(debug) { - __PLUMED_FPRINTF(stderr,"|RTLD_DEEPBIND"); - } + if(debug) __PLUMED_FPRINTF(stderr,"|RTLD_DEEPBIND"); } #endif #endif - if(debug) { - __PLUMED_FPRINTF(stderr," +++\n"); - } + if(debug) __PLUMED_FPRINTF(stderr," +++\n"); p=plumed_attempt_dlopen(path,dlopenmode); - if(p) { - plumed_search_symbols(p,&g,plumed_symbol_table_ptr); - } - } - if(handle) { - *handle=p; - } - if(functions) { - *functions=g; + if(p) plumed_search_symbols(p,&g,plumed_symbol_table_ptr); } + if(handle) *handle=p; + if(functions) *functions=g; #endif } __PLUMED_WRAPPER_INTERNALS_END @@ -3739,12 +3604,8 @@ __PLUMED_WRAPPER_INTERNALS_END __PLUMED_WRAPPER_INTERNALS_BEGIN int plumed_check_pimpl(plumed_implementation*pimpl) { - if(!pimpl) { - return 0; - } - if(__PLUMED_WRAPPER_STD memcmp(pimpl->magic,"pLuMEd",6)) { - return 0; - } + if(!pimpl) return 0; + if(__PLUMED_WRAPPER_STD memcmp(pimpl->magic,"pLuMEd",6)) return 0; return 1; } __PLUMED_WRAPPER_INTERNALS_END @@ -3768,9 +3629,7 @@ plumed plumed_create(void) { #endif /* note if handle should not be dlclosed */ pimpl->dlclose=1; - if(__PLUMED_GETENV("PLUMED_LOAD_DLCLOSE") && !__PLUMED_WRAPPER_STD strcmp(__PLUMED_GETENV("PLUMED_LOAD_DLCLOSE"),"no")) { - pimpl->dlclose=0; - } + if(__PLUMED_GETENV("PLUMED_LOAD_DLCLOSE") && !__PLUMED_WRAPPER_STD strcmp(__PLUMED_GETENV("PLUMED_LOAD_DLCLOSE"),"no")) pimpl->dlclose=0; /* in case of failure, return */ /* the resulting object should be plumed_finalized, though you cannot use plumed_cmd */ if(!pimpl->functions.create) { @@ -3798,9 +3657,7 @@ plumed plumed_create_dlopen(const char*path) { dlopenmode=RTLD_NOW|RTLD_LOCAL; #ifdef RTLD_DEEPBIND #if __PLUMED_WRAPPER_ENABLE_RTLD_DEEPBIND - if(!__PLUMED_GETENV("PLUMED_LOAD_NODEEPBIND")) { - dlopenmode=dlopenmode|RTLD_DEEPBIND; - } + if(!__PLUMED_GETENV("PLUMED_LOAD_NODEEPBIND")) dlopenmode=dlopenmode|RTLD_DEEPBIND; #endif #endif #else @@ -3848,9 +3705,7 @@ plumed plumed_create_dlopen2(const char*path,int mode) { /* handler */ void* dlhandle; dlhandle=__PLUMED_WRAPPER_CXX_NULLPTR; - if(path) { - dlhandle=plumed_attempt_dlopen(path,mode); - } + if(path) dlhandle=plumed_attempt_dlopen(path,mode); /* a NULL handle implies the file could not be loaded */ if(dlhandle) { p=plumed_create_dlsym(dlhandle); @@ -3918,9 +3773,7 @@ void plumed_cmd(plumed p,const char*key,const void*val) { assert(plumed_check_pimpl(pimpl)); if(!pimpl->p) { __PLUMED_FPRINTF(stderr,"+++ ERROR: You are trying to use an invalid plumed object. +++\n"); - if(pimpl->used_plumed_kernel) { - __PLUMED_FPRINTF(stderr,"+++ Check your PLUMED_KERNEL environment variable. +++\n"); - } + if(pimpl->used_plumed_kernel) __PLUMED_FPRINTF(stderr,"+++ Check your PLUMED_KERNEL environment variable. +++\n"); __PLUMED_WRAPPER_STD abort(); } assert(pimpl->functions.create); @@ -3954,13 +3807,9 @@ void plumed_cmd_safe_nothrow(plumed p,const char*key,plumed_safeptr safe,plumed_ assert(pimpl->functions.cmd); assert(pimpl->functions.finalize); /* execute */ - if(pimpl->table && pimpl->table->version>2) { - (*(pimpl->table->cmd_safe_nothrow))(pimpl->p,key,safe,nothrow); - } else if(pimpl->table && pimpl->table->version>1) { - (*(pimpl->table->cmd_nothrow))(pimpl->p,key,safe.ptr,nothrow); - } else { - (*(pimpl->functions.cmd))(pimpl->p,key,safe.ptr); - } + if(pimpl->table && pimpl->table->version>2) (*(pimpl->table->cmd_safe_nothrow))(pimpl->p,key,safe,nothrow); + else if(pimpl->table && pimpl->table->version>1) (*(pimpl->table->cmd_nothrow))(pimpl->p,key,safe.ptr,nothrow); + else (*(pimpl->functions.cmd))(pimpl->p,key,safe.ptr); } __PLUMED_WRAPPER_C_END @@ -3984,20 +3833,15 @@ void plumed_cmd_safe(plumed p,const char*key,plumed_safeptr safe) { assert(plumed_check_pimpl(pimpl)); if(!pimpl->p) { __PLUMED_FPRINTF(stderr,"+++ ERROR: You are trying to use an invalid plumed object. +++\n"); - if(pimpl->used_plumed_kernel) { - __PLUMED_FPRINTF(stderr,"+++ Check your PLUMED_KERNEL environment variable. +++\n"); - } + if(pimpl->used_plumed_kernel) __PLUMED_FPRINTF(stderr,"+++ Check your PLUMED_KERNEL environment variable. +++\n"); __PLUMED_WRAPPER_STD abort(); } assert(pimpl->functions.create); assert(pimpl->functions.cmd); assert(pimpl->functions.finalize); /* execute */ - if(pimpl->table && pimpl->table->version>2) { - (*(pimpl->table->cmd_safe))(pimpl->p,key,safe); - } else { - (*(pimpl->functions.cmd))(pimpl->p,key,safe.ptr); - } + if(pimpl->table && pimpl->table->version>2) (*(pimpl->table->cmd_safe))(pimpl->p,key,safe); + else (*(pimpl->functions.cmd))(pimpl->p,key,safe.ptr); } __PLUMED_WRAPPER_C_END @@ -4013,13 +3857,9 @@ void plumed_finalize(plumed p) { #endif /* with PLUMED > 2.8, we can use an internal reference counter which is thread safe */ if(pimpl->p && pimpl->table && pimpl->table->version>3) { - if(pimpl->table->delete_reference(pimpl->p)>0) { - return; - } + if(pimpl->table->delete_reference(pimpl->p)>0) return; } else { - if(--pimpl->refcount>0) { - return; - } + if(--pimpl->refcount>0) return; } /* to allow finalizing an invalid plumed object, we only call finalize if the object is valid */ @@ -4033,9 +3873,7 @@ void plumed_finalize(plumed p) { #ifdef __PLUMED_HAS_DLOPEN /* dlclose library */ if(pimpl->dlhandle && pimpl->dlclose) { - if(__PLUMED_GETENV("PLUMED_LOAD_DEBUG")) { - __PLUMED_FPRINTF(stderr,"+++ Unloading library\n"); - } + if(__PLUMED_GETENV("PLUMED_LOAD_DEBUG")) __PLUMED_FPRINTF(stderr,"+++ Unloading library\n"); dlclose(pimpl->dlhandle); } #endif @@ -4053,11 +3891,8 @@ int plumed_valid(plumed p) { /* obtain pimpl */ pimpl=(plumed_implementation*) p.p; assert(plumed_check_pimpl(pimpl)); - if(pimpl->p) { - return 1; - } else { - return 0; - } + if(pimpl->p) return 1; + else return 0; } __PLUMED_WRAPPER_C_END @@ -4092,9 +3927,7 @@ void* plumed_malloc(__PLUMED_WRAPPER_STD size_t size) { void* ptr; ptr=__PLUMED_WRAPPER_STD malloc(size); #if __PLUMED_WRAPPER_DEBUG_REFCOUNT - if(ptr) { - fprintf(stderr,"plumed_malloc: %p\n",ptr); - } + if(ptr) fprintf(stderr,"plumed_malloc: %p\n",ptr); #endif return ptr; } @@ -4142,11 +3975,8 @@ void plumed_gfinalize(void) { } int plumed_ginitialized(void) { - if(plumed_gmain.p) { - return 1; - } else { - return 0; - } + if(plumed_gmain.p) return 1; + else return 0; } int plumed_gvalid() {