- Timestamp:
- Dec 28, 2011, 3:25:49 PM (14 years ago)
- 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:
- 401f90
- Parents:
- afa9d8
- git-author:
- Frederik Heber <heber@…> (12/23/11 15:17:07)
- git-committer:
- Frederik Heber <heber@…> (12/28/11 15:25:49)
- Location:
- src
- Files:
- 
      - 6 edited
 
 - 
          
  Descriptors/AtomOfMoleculeSelectionDescriptor.cpp (modified) (1 diff)
- 
          
  Dynamics/LinearInterpolationBetweenSteps.hpp (modified) (1 diff)
- 
          
  Dynamics/MinimiseConstrainedPotential.cpp (modified) (14 diffs)
- 
          
  Dynamics/MinimiseConstrainedPotential.hpp (modified) (3 diffs)
- 
          
  Dynamics/VerletForceIntegration.hpp (modified) (1 diff)
- 
          
  molecule.hpp (modified) (4 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      src/Descriptors/AtomOfMoleculeSelectionDescriptor.cpprafa9d8 radb5cda 53 53 iter != instance.endMoleculeSelection(); 54 54 ++iter) { 55 transform(iter->second->begin(), 56 iter->second->end(), 57 back_inserter(res), 58 _take<atom*,molecule::atomSet::value_type>::get); 55 std::copy(iter->second->begin(), iter->second->end(), res.begin()); 59 56 } 60 57 return res; 
- 
      src/Dynamics/LinearInterpolationBetweenSteps.hpprafa9d8 radb5cda 55 55 if (!MapByIdentity) { 56 56 LOG(1, "STATUS: Constructing atom mapping from start to end position."); 57 molecule::atomSet atoms_list; 58 for (typename AtomSetMixin<Set>::const_iterator iter = atoms.begin(); 59 iter != atoms.end(); ++iter) 60 atoms_list.insert(*iter); 61 MinimiseConstrainedPotential Minimiser(atoms_list, PermutationMap); 57 MinimiseConstrainedPotential Minimiser(atoms, PermutationMap); 62 58 Minimiser(startstep, endstep, IsAngstroem); 63 59 } else { 
- 
      src/Dynamics/MinimiseConstrainedPotential.cpprafa9d8 radb5cda 40 40 41 41 MinimiseConstrainedPotential::MinimiseConstrainedPotential( 42 molecule::atomSet&_atoms,42 World::AtomComposite &_atoms, 43 43 std::map<atom*, atom *> &_PermutationMap) : 44 44 atoms(_atoms), … … 59 59 PermutationMap.clear(); 60 60 DoubleList.clear(); 61 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {61 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 62 62 DistanceList[*iter].clear(); 63 63 } … … 90 90 LOG(2, "Starting round " << ++round << ", at current potential " << OldPotential << " ... "); 91 91 OlderPotential = OldPotential; 92 molecule::atomSet::const_iterator iter;92 World::AtomComposite::const_iterator iter; 93 93 do { 94 94 iter = atoms.begin(); … … 105 105 //LOG(2, "Current Walker: " << *(*iter) << " with old/next candidate " << *Sprinter << "/" << *DistanceIterators[(*iter)]->second << "."); 106 106 // find source of the new target 107 molecule::atomSet::const_iterator runner = atoms.begin();107 World::AtomComposite::const_iterator runner = atoms.begin(); 108 108 for (; runner != atoms.end(); ++runner) { // find the source whose toes we might be stepping on (Walker's new target should be in use by another already) 109 109 if (PermutationMap[(*runner)] == DistanceIterators[(*iter)]->second) { … … 165 165 void MinimiseConstrainedPotential::FillDistanceList() 166 166 { 167 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {168 for ( molecule::atomSet::const_iterator runner = atoms.begin(); runner != atoms.end(); ++runner) {167 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 168 for (World::AtomComposite::const_iterator runner = atoms.begin(); runner != atoms.end(); ++runner) { 169 169 DistanceList[(*iter)].insert( DistancePair((*iter)->getPositionAtStep(startstep).distance((*runner)->getPositionAtStep(endstep)), (*runner)) ); 170 170 } … … 174 174 void MinimiseConstrainedPotential::CreateInitialLists() 175 175 { 176 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {176 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 177 177 StepList[(*iter)] = DistanceList[(*iter)].begin(); // stores the step to the next iterator that could be a possible next target 178 178 PermutationMap[(*iter)] = DistanceList[(*iter)].begin()->second; // always pick target with the smallest distance … … 185 185 void MinimiseConstrainedPotential::MakeInjectivePermutation() 186 186 { 187 molecule::atomSet::const_iterator iter = atoms.begin();187 World::AtomComposite::const_iterator iter = atoms.begin(); 188 188 DistanceMap::iterator NewBase; 189 189 double Potential = fabs(ConstrainedPotential()); … … 204 204 Potential = TryNextNearestNeighbourForInjectivePermutation((*iter), Potential); 205 205 } 206 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {206 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 207 207 // now each single entry in the DoubleList should be <=1 208 208 if (DoubleList[*iter] > 1) { … … 216 216 unsigned int MinimiseConstrainedPotential::CalculateDoubleList() 217 217 { 218 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter)218 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) 219 219 DoubleList[*iter] = 0; 220 220 unsigned int doubles = 0; 221 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter)221 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) 222 222 DoubleList[ PermutationMap[*iter] ]++; 223 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter)223 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) 224 224 if (DoubleList[*iter] > 1) 225 225 doubles++; … … 235 235 zeile1 << "PermutationMap: "; 236 236 zeile2 << " "; 237 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {237 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 238 238 zeile1 << (*iter)->getName() << " "; 239 239 zeile2 << (PermutationMap[*iter])->getName() << " "; 240 240 } 241 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {241 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 242 242 std::map<atom *, unsigned int>::const_iterator value_iter = DoubleList.find(*iter); 243 243 if (value_iter->second > (unsigned int)1) … … 255 255 // go through every atom 256 256 atom *Runner = NULL; 257 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {257 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 258 258 // first term: distance to target 259 259 Runner = PermutationMap[(*iter)]; // find target point … … 299 299 { 300 300 double result = 0.; 301 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {301 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 302 302 if ((PermutationMap[Walker] == PermutationMap[(*iter)]) && (Walker < (*iter))) { 303 303 // atom *Sprinter = PermutationMap[Walker->nr]; … … 324 324 double Norm1, Norm2, tmp, result = 0.; 325 325 326 for ( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {326 for (World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 327 327 if ((*iter) == Walker) // hence, we only go up to the Walker, not beyond (similar to i=0; i<j; i++) 328 328 break; … … 407 407 /// evaluate forces (only the distance to target dependent part) with the final PermutationMap 408 408 LOG(1, "Calculating forces and adding onto ForceMatrix ... "); 409 for( molecule::atomSet::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) {409 for(World::AtomComposite::const_iterator iter = atoms.begin(); iter != atoms.end(); ++iter) { 410 410 atom *Sprinter = PermutationMap[(*iter)]; 411 411 // set forces 
- 
      src/Dynamics/MinimiseConstrainedPotential.hpprafa9d8 radb5cda 19 19 #include <map> 20 20 21 #include " molecule.hpp"21 #include "World.hpp" 22 22 23 23 /** Structure to contain parameters needed for evaluation of constraint potential. … … 33 33 * @return 34 34 */ 35 MinimiseConstrainedPotential( molecule::atomSet&_atoms, std::map<atom*, atom *> &_PermutationMap);35 MinimiseConstrainedPotential(World::AtomComposite &_atoms, std::map<atom*, atom *> &_PermutationMap); 36 36 37 37 /** Destructor. … … 79 79 typedef std::pair < DistanceMap::iterator, bool> DistanceTestPair; 80 80 81 molecule::atomSetatoms;81 World::AtomComposite atoms; 82 82 int startstep; //!< start configuration (MDStep in atom::trajectory) 83 83 int endstep; //!< end configuration (MDStep in atom::trajectory) 
- 
      src/Dynamics/VerletForceIntegration.hpprafa9d8 radb5cda 98 98 // calculate forces and potential 99 99 std::map<atom *, atom*> PermutationMap; 100 molecule::atomSet atoms_list; 101 for (typename AtomSetMixin<T>::const_iterator iter = atoms.begin(); 102 iter != atoms.end(); ++iter) 103 atoms_list.insert(*iter); 104 MinimiseConstrainedPotential Minimiser(atoms_list, PermutationMap); 100 MinimiseConstrainedPotential Minimiser(atoms, PermutationMap); 105 101 //double ConstrainedPotentialEnergy = 106 102 Minimiser(DoConstrainedMD, 0, IsAngstroem); 
- 
      src/molecule.hpprafa9d8 radb5cda 78 78 79 79 public: 80 typedef ATOMSET(std::set) atomSet;81 80 typedef std::set<atomId_t> atomIdSet; 82 81 typedef boost::transform_iterator<FromIdToAtom, atomIdSet::iterator, atom *, atomId_t> iterator; … … 84 83 85 84 const periodentafel * const elemente; //!< periodic table with each element 86 // old deprecated atom handling87 //atom *start; //!< start of atom list88 //atom *end; //!< end of atom list89 //bond *first; //!< start of bond list90 //bond *last; //!< end of bond list91 85 int MDSteps; //!< The number of MD steps in Trajectories 92 86 mutable int NoNonHydrogen; //!< number of non-hydrogen atoms in molecule … … 94 88 mutable int NoCyclicBonds; //!< number of cyclic bonds in molecule, by DepthFirstSearchAnalysis() 95 89 bool ActiveFlag; //!< in a MoleculeListClass used to discern active from inactive molecules 96 //Vector Center; //!< Center of molecule in a global box97 90 int IndexNr; //!< index of molecule in a MoleculeListClass 98 91 char name[MAXSTRINGSIZE]; //!< arbitrary name … … 105 98 atomIdSet atomIds; //<!set of atomic ids to check uniqueness of atoms 106 99 protected: 107 //void CountAtoms();108 /**109 * this iterator type should be used for internal variables, \110 * since it will not lock111 */112 typedef atomSet::iterator internal_iterator;113 100 114 101 molecule(const periodentafel * const teil); 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
