Changeset 74ec1f for src/Atom


Ignore:
Timestamp:
Feb 17, 2012, 3:24:17 PM (13 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:
3f7587
Parents:
bb645c
git-author:
Frederik Heber <heber@…> (01/05/12 11:54:22)
git-committer:
Frederik Heber <heber@…> (02/17/12 15:24:17)
Message:

BUGFIX: Added new channel BondDegreeChanged to AtomObservable, added some BondsChanged notifications.

Location:
src/Atom
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • TabularUnified src/Atom/atom_bondedparticle.cpp

    rbb645c r74ec1f  
    129129void BondedParticle::removeAllBonds()
    130130{
    131   OBSERVE;
    132   NOTIFY(BondedParticle::BondsChanged);
    133131  for (size_t index = 0; index < ListOfBonds.size(); ++index)
    134132  {
     
    137135        iter = ListOfBonds[index].begin()) {
    138136      delete (*iter);
    139       // erase is done by bond::~bond()
     137      // unregister/NOTIFY is done by bond::~bond()
    140138    }
    141139  }
     
    152150  if (Binder != NULL) {
    153151    if (Binder->Contains(this)) {
    154       if (WorldTime::getTime() == _step)
    155         NOTIFY(AtomObservable::BondsChanged);
    156152      //LOG(3,"INFO: Registering bond "<< *Binder << " with atom " << *this << " at step " << _step);
    157153      if (ListOfBonds.size() <= _step)
    158154        ListOfBonds.resize(_step+1);
    159155      ListOfBonds[_step].push_back(Binder);
     156      if (WorldTime::getTime() == _step)
     157        NOTIFY(AtomObservable::BondsChanged);
    160158      status = true;
    161159    } else {
     
    179177  const int step = ContainsBondAtStep(Binder);
    180178  if (step != -1) {
    181     NOTIFY(AtomObservable::BondsChanged);
    182179    //LOG(0,"INFO: Unregistering bond "<< *Binder << " from list " << &ListOfBonds << " of atom " << *this << " at step " << step);
    183180    ListOfBonds[step].remove(Binder);
     
    194191void BondedParticle::UnregisterAllBond(const unsigned int _step)
    195192{
     193  OBSERVE;
    196194  ListOfBonds[_step].clear();
    197195}
     
    204202{
    205203  OBSERVE;
    206   if (WorldTime::getTime() == _step)
    207     NOTIFY(AtomObservable::BondsChanged);
    208204  //LOG(3,"INFO: Clearing all bonds of " << *this << ": " << ListOfBonds[_step]);
    209205  for (BondList::iterator iter = (ListOfBonds[_step]).begin();
     
    248244{
    249245  OBSERVE;
    250   NOTIFY(AtomObservable::BondsChanged);
     246  NOTIFY(AtomObservable::BondDegreeChanged);
    251247  int NoBonds = 0;
    252248  int OtherNoBonds = 0;
     
    287283{
    288284  OBSERVE;
    289   NOTIFY(BondedParticle::BondsChanged);
     285  NOTIFY(BondedParticle::BondDegreeChanged);
    290286  for (std::vector<BondList>::iterator Runner = ListOfBonds.begin();
    291287      Runner != ListOfBonds.end();
  • TabularUnified src/Atom/atom_observable.hpp

    rbb645c r74ec1f  
    3434    PropertyChanged,  // some other property changed
    3535    BondsChanged,     // list of bonds has changed
     36    BondDegreeChanged,     // bond degree has changed
    3637    NotificationType_MAX  // denotes the maximum of available notification types
    3738  };
Note: See TracChangeset for help on using the changeset viewer.