Ignore:
Timestamp:
Mar 2, 2011, 9:48:20 PM (14 years ago)
Author:
Frederik Heber <heber@…>
Branches:
Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
Children:
341f22
Parents:
eb33c4
Message:

Rewrote VerletForceIntegration into a functor in Dynamics/.

  • we now have the regression test working with checking against an integrated file which has not been checked though (just by eye and logged output to make sense, not against other code).
Location:
src/Actions/MoleculeAction
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/MoleculeAction/VerletIntegrationAction.cpp

    reb33c4 r435065  
    2020#include "CodePatterns/MemDebug.hpp"
    2121
     22#include "atom.hpp"
     23#include "AtomSet.hpp"
    2224#include "CodePatterns/Log.hpp"
     25#include "CodePatterns/Verbose.hpp"
     26#include "Dynamics/VerletForceIntegration.hpp"
    2327#include "molecule.hpp"
    24 #include "CodePatterns/Verbose.hpp"
    2528#include "World.hpp"
    2629
     30#include <vector>
    2731#include <iostream>
    2832#include <fstream>
     
    3842/** =========== define the function ====================== */
    3943Action::state_ptr MoleculeVerletIntegrationAction::performCall() {
    40   molecule *mol = NULL;
    41 
    4244  // obtain information
    4345  getParametersfromValueStorage();
    4446
    45   for (World::MoleculeSelectionIterator iter = World::getInstance().beginMoleculeSelection(); iter != World::getInstance().endMoleculeSelection(); ++iter) {
    46     mol = iter->second;
    47     DoLog(1) && (Log() << Verbose(1) << "Parsing forces file and Verlet integrating." << endl);
    48     // TODO: sollte besser stream nutzen, nicht filename direkt (es sei denn, ist prefix), besser fuer unit test
    49     char outputname[MAXSTRINGSIZE];
    50     strcpy(outputname, params.forcesfile.string().c_str());
    51     if (!mol->VerletForceIntegration(outputname, *(World::getInstance().getConfig()), 0))
     47
     48  DoLog(1) && (Log() << Verbose(1) << "Parsing forces file and Verlet integrating." << endl);
     49  // TODO: sollte besser stream nutzen, nicht filename direkt (es sei denn, ist prefix), besser fuer unit test
     50  char outputname[MAXSTRINGSIZE];
     51  strcpy(outputname, params.forcesfile.string().c_str());
     52  AtomSetMixin<std::vector<atom *> > set(World::getInstance().getSelectedAtoms());
     53  for (int step = 0; step < params.MDSteps; ++step) {
     54    VerletForceIntegration<std::vector<atom *> > Verlet(set, params.Deltat, step, false);
     55    if (!Verlet(outputname, 1, 0, params.FixedCenterOfMass))
    5256      DoLog(2) && (Log() << Verbose(2) << "File " << params.forcesfile << " not found." << endl);
    5357    else
    5458      DoLog(2) && (Log() << Verbose(2) << "File " << params.forcesfile << " found and parsed." << endl);
    5559  }
     60
    5661  return Action::success;
    5762}
  • src/Actions/MoleculeAction/VerletIntegrationAction.def

    reb33c4 r435065  
    1212// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1313// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    14 #define paramtypes (boost::filesystem::path)
    15 #define paramtokens ("verlet-integration")
    16 #define paramdescriptions ("perform verlet integration of a given force file")
     14#define paramtypes (boost::filesystem::path)(double)(int)(bool)
     15#define paramtokens ("verlet-integration")("deltat")("MDSteps")("keep-fixed-CenterOfMass")
     16#define paramdescriptions ("perform verlet integration of a given force file")("time step width")("number of MDSteps to integrate")("whether forces and velocities shall be corrected such that center of mass remains at rest")
    1717#undef paramdefaults
    18 #define paramreferences (forcesfile)
     18#define paramreferences (forcesfile)(Deltat)(MDSteps)(FixedCenterOfMass)
    1919
    2020#undef statetypes
Note: See TracChangeset for help on using the changeset viewer.