Changeset e32fa6 for src/Filling


Ignore:
Timestamp:
Mar 30, 2012, 9:18:26 AM (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, Candidate_v1.7.0, 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:
4fbc4eb
Parents:
68abe5
git-author:
Frederik Heber <heber@…> (03/27/12 13:53:10)
git-committer:
Frederik Heber <heber@…> (03/30/12 09:18:26)
Message:

Modified Filler:operator() such that Inserters only modify position, not clone.

Location:
src/Filling
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • src/Filling/Filler.cpp

    r68abe5 re32fa6  
    9696  }
    9797
    98   // skip first node (as we must keep the original atoms)
    99   NodeSet::iterator iter = ++FillNodes.begin();
     98  // clone clusters
     99  std::vector<ClusterInterface::Cluster_impl> clusters(FillNodes.size());
     100  std::vector<ClusterInterface::Cluster_impl>::iterator clusteriter = clusters.begin();
     101  *clusteriter = cluster;
     102  clusteriter++;
     103  std::generate_n(clusteriter, FillNodes.size()-1,
     104      boost::bind(&ClusterInterface::clone, boost::cref(cluster), boost::ref(copyMethod), zeroVec) );
    100105
    101   // fill all other true nodes
    102   std::for_each(iter , FillNodes.end(),
    103       boost::bind(&Inserter::operator(), boost::cref(inserter), boost::ref(copyMethod), boost::cref(cluster), _1) );
     106  // insert each cluster by abusing std::search a bit:
     107  // we look for the subsequence of FillNodes inside clusters. If Inserter always
     108  // returns true, we'll have the iterator pointing at first cluster
     109  std::vector<ClusterInterface::Cluster_impl>::const_iterator inserteriter =
     110    std::search(clusters.begin(), clusters.end(), FillNodes.begin(), FillNodes.end(),
     111        boost::bind(&Inserter::operator(), boost::cref(inserter), _1, _2));
     112  if( inserteriter != clusters.begin()) {
     113    ELOG(1, "Not all cloned clusters could be successfully inserted.");
     114    return false;
     115  }
    104116
    105   // give statment whether at least \a cluster was placed
     117  // give final statment on whether at least \a single cluster has been placed
    106118  if ( FillNodes.size() != 0)
    107119    return true;
    108120  else
    109121    return false;
     122}
    110123
    111   // move cluster to first node
    112   cluster->translate(*FillNodes.begin());
    113 }
  • src/Filling/Inserter/Inserter.cpp

    r68abe5 re32fa6  
    4646{}
    4747
    48 bool Inserter::operator()(CopyAtomsInterface &copyMethod, ClusterInterface::Cluster_impl cluster, const Vector &offset) const
     48bool Inserter::operator()(ClusterInterface::Cluster_impl cluster, const Vector &offset) const
    4949{
    50   return impl->operator()(copyMethod, cluster, offset);
     50  return impl->operator()(cluster, offset);
    5151}
    5252
  • src/Filling/Inserter/Inserter.hpp

    r68abe5 re32fa6  
    1919#include "Filling/ClusterInterface.hpp"
    2020
    21 class CopyAtomsInterface;
    2221class Vector;
    2322
     
    3837  Inserter(impl_ptr);
    3938  ~Inserter();
    40   bool operator()(CopyAtomsInterface &copyMethod, ClusterInterface::Cluster_impl cluster, const Vector &offset) const;
     39  bool operator()(ClusterInterface::Cluster_impl cluster, const Vector &offset) const;
    4140
    4241protected:
  • src/Filling/Inserter/InserterBase.hpp

    r68abe5 re32fa6  
    1717#include "Filling/ClusterInterface.hpp"
    1818
    19 class CopyAtomsInterface;
    2019class Vector;
    2120
     
    2928  virtual ~InserterBase() {}
    3029
    31   virtual bool operator()(CopyAtomsInterface &copyMethod, ClusterInterface::Cluster_impl cluster, const Vector &offset) const = 0;
     30  virtual bool operator()(ClusterInterface::Cluster_impl cluster, const Vector &offset) const = 0;
    3231
    3332};
  • src/Filling/Inserter/SimpleInserter.cpp

    r68abe5 re32fa6  
    2323#include "SimpleInserter.hpp"
    2424
    25 #include "Atom/CopyAtoms/CopyAtomsInterface.hpp"
    26 
    2725/** Constructor for class SimpleInserter.
    2826 *
     
    3937/** Inserter operator that simply enacts ClusterInterface::clone().
    4038 *
    41  * @param copyMethod functor for copying atoms
    4239 * @param offset
    4340 * @return always true
    4441 */
    45 bool SimpleInserter::operator()(CopyAtomsInterface &copyMethod, ClusterInterface::Cluster_impl cluster, const Vector &offset) const
     42bool SimpleInserter::operator()(ClusterInterface::Cluster_impl cluster, const Vector &offset) const
    4643{
    47   ClusterInterface::Cluster_impl newcluster(cluster->clone(copyMethod, offset));
     44  cluster->translate(offset);
    4845
    49   return (newcluster != NULL);
     46  return true;
    5047}
  • src/Filling/Inserter/SimpleInserter.hpp

    r68abe5 re32fa6  
    2626  ~SimpleInserter();
    2727
    28   bool operator()(CopyAtomsInterface &copyMethod, ClusterInterface::Cluster_impl cluster, const Vector &offset) const;
     28  bool operator()(ClusterInterface::Cluster_impl cluster, const Vector &offset) const;
    2929};
    3030
Note: See TracChangeset for help on using the changeset viewer.