Changeset 3af1f0 for src


Ignore:
Timestamp:
Apr 8, 2009, 11:25:03 AM (17 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:
d67150
Parents:
ca2587
Message:

MoleculeListClass::Enumerate() lists center and size of molecule, fix of MoleculeListClass::ReturnIndex()

  • MoleculeListClass::Enumerate(): Vector Center and size (greatest distance from center) is also given
  • MoleculeListClass::ReturnIndex(): BUGFIX - counter instead of molecule::IndexNr was still used
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/moleculelist.cpp

    rca2587 r3af1f0  
    128128  atom *Walker = NULL;
    129129  int Counts[MAX_ELEMENTS];
     130  double size=0;
     131  Vector Origin;
    130132
    131133  // header
    132   *out << "Index\tName\tNo.Atoms\tformula" << endl;
     134  *out << "Index\tName\t\tAtoms\tFormula\tCenter\tSize" << endl;
    133135  cout << Verbose(0) << "-----------------------------------------------" << endl;
    134136  if (ListOfMolecules.size() == 0)
    135137    *out << "\tNone" << endl;
    136138  else {
     139    Origin.Zero();
    137140    for (MoleculeList::iterator ListRunner = ListOfMolecules.begin(); ListRunner != ListOfMolecules.end(); ListRunner++) {
    138141      // reset element counts
    139142      for (int j = 0; j<MAX_ELEMENTS;j++)
    140143        Counts[j] = 0;
    141       // count atoms per element
     144      // count atoms per element and determine size of bounding sphere
     145      size=0.;
    142146      Walker = (*ListRunner)->start;
    143147      while (Walker->next != (*ListRunner)->end) {
    144148        Walker = Walker->next;
    145149        Counts[Walker->type->Z]++;
     150        if (Walker->x.DistanceSquared(&Origin) > size)
     151          size = Walker->x.DistanceSquared(&Origin);
    146152      }
    147153      // output Index, Name, number of atoms, chemical formula
    148154      *out << ((*ListRunner)->ActiveFlag ? "*" : " ") << (*ListRunner)->IndexNr << "\t" << (*ListRunner)->name << "\t\t" << (*ListRunner)->AtomCount << "\t";
    149155      Elemental = (*ListRunner)->elemente->end;
    150       while(Elemental != (*ListRunner)->elemente->start) {
     156      while(Elemental->previous != (*ListRunner)->elemente->start) {
    151157        Elemental = Elemental->previous;
    152158        if (Counts[Elemental->Z] != 0)
    153159          *out << Elemental->symbol << Counts[Elemental->Z];
    154160      }
    155       *out << endl;
     161      // Center and size
     162      *out << "\t" << (*ListRunner)->Center << "\t" << sqrt(size) << endl;
    156163    }
    157164  }
     
    164171molecule * MoleculeListClass::ReturnIndex(int index)
    165172{
    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;
     173  for(MoleculeList::iterator ListRunner = ListOfMolecules.begin(); ListRunner != ListOfMolecules.end(); ListRunner++)
     174    if ((*ListRunner)->IndexNr == index)
     175      return (*ListRunner);
     176  return NULL;
    173177};
    174178
Note: See TracChangeset for help on using the changeset viewer.