Changeset 36ec71 for src/moleculelist.cpp
- Timestamp:
- Jul 24, 2009, 10:38:32 AM (16 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:
- d30402
- Parents:
- 042f82 (diff), 51c910 (diff)
 Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
 Use the(diff)links above to see all the changes relative to each parent.
- git-author:
- Frederik Heber <heber@…> (07/23/09 14:23:32)
- git-committer:
- Frederik Heber <heber@…> (07/24/09 10:38:32)
- File:
- 
      - 1 edited
 
 - 
          
  src/moleculelist.cpp (modified) (4 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      src/moleculelist.cppr042f82 r36ec71 35 35 * \return true - add successful 36 36 */ 37 boolMoleculeListClass::insert(molecule *mol)37 void MoleculeListClass::insert(molecule *mol) 38 38 { 39 39 mol->IndexNr = MaxIndex++; 40 40 ListOfMolecules.push_back(mol); 41 return true;42 41 }; 43 42 … … 128 127 atom *Walker = NULL; 129 128 int Counts[MAX_ELEMENTS]; 129 double size=0; 130 Vector Origin; 130 131 131 132 // header 132 *out << "Index\tName\t No.Atoms\tformula" << endl;133 *out << "Index\tName\t\tAtoms\tFormula\tCenter\tSize" << endl; 133 134 cout << Verbose(0) << "-----------------------------------------------" << endl; 134 135 if (ListOfMolecules.size() == 0) 135 136 *out << "\tNone" << endl; 136 137 else { 138 Origin.Zero(); 137 139 for (MoleculeList::iterator ListRunner = ListOfMolecules.begin(); ListRunner != ListOfMolecules.end(); ListRunner++) { 138 140 // reset element counts 139 141 for (int j = 0; j<MAX_ELEMENTS;j++) 140 142 Counts[j] = 0; 141 // count atoms per element 143 // count atoms per element and determine size of bounding sphere 144 size=0.; 142 145 Walker = (*ListRunner)->start; 143 146 while (Walker->next != (*ListRunner)->end) { 144 147 Walker = Walker->next; 145 148 Counts[Walker->type->Z]++; 149 if (Walker->x.DistanceSquared(&Origin) > size) 150 size = Walker->x.DistanceSquared(&Origin); 146 151 } 147 152 // output Index, Name, number of atoms, chemical formula 148 153 *out << ((*ListRunner)->ActiveFlag ? "*" : " ") << (*ListRunner)->IndexNr << "\t" << (*ListRunner)->name << "\t\t" << (*ListRunner)->AtomCount << "\t"; 149 154 Elemental = (*ListRunner)->elemente->end; 150 while(Elemental != (*ListRunner)->elemente->start) {155 while(Elemental->previous != (*ListRunner)->elemente->start) { 151 156 Elemental = Elemental->previous; 152 157 if (Counts[Elemental->Z] != 0) 153 158 *out << Elemental->symbol << Counts[Elemental->Z]; 154 159 } 155 *out << endl; 160 // Center and size 161 *out << "\t" << (*ListRunner)->Center << "\t" << sqrt(size) << endl; 156 162 } 157 163 } … … 164 170 molecule * MoleculeListClass::ReturnIndex(int index) 165 171 { 166 int count = 1; 167 MoleculeList::iterator ListRunner = ListOfMolecules.begin(); 168 for(; ((ListRunner != ListOfMolecules.end()) && (count < index)); ListRunner++); 169 if (count == index) 170 return (*ListRunner); 171 else 172 return NULL; 172 for(MoleculeList::iterator ListRunner = ListOfMolecules.begin(); ListRunner != ListOfMolecules.end(); ListRunner++) 173 if ((*ListRunner)->IndexNr == index) 174 return (*ListRunner); 175 return NULL; 173 176 }; 174 177 … … 565 568 * \param *configuration standard configuration to attach atoms in fragment molecule to. 566 569 * \param *SortIndex Index to map from the BFS labeling to the sequence how of Ion_Type in the config 570 * \param DoPeriodic true - call ScanForPeriodicCorrection, false - don't 571 * \param DoCentering true - call molecule::CenterEdge(), false - don't 567 572 * \return true - success (each file was written), false - something went wrong. 568 573 */ 569 bool MoleculeListClass::OutputConfigForListOfFragments(ofstream *out, 570 config *configuration, int *SortIndex) 574 bool MoleculeListClass::OutputConfigForListOfFragments(ofstream *out, config *configuration, int *SortIndex) 571 575 { 572 576 ofstream outputFragment; 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
