Changeset fb255d for src/Fragmentation/Automation/Pool
- Timestamp:
- Jul 2, 2012, 7:54:10 AM (13 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:
- 2344a3
- Parents:
- d6b12c
- git-author:
- Frederik Heber <heber@…> (02/29/12 17:39:33)
- git-committer:
- Frederik Heber <heber@…> (07/02/12 07:54:10)
- Location:
- src/Fragmentation/Automation/Pool
- Files:
- 
      - 2 edited
 
 - 
          
  WorkerPool.cpp (modified) (7 diffs)
- 
          
  WorkerPool.hpp (modified) (3 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      src/Fragmentation/Automation/Pool/WorkerPool.cpprd6b12c rfb255d 28 28 #include "CodePatterns/Info.hpp" 29 29 #include "CodePatterns/Log.hpp" 30 #include "CodePatterns/Observer/Channels.hpp" 30 31 #include "Connection.hpp" 31 32 … … 36 37 * 37 38 */ 38 WorkerPool::WorkerPool() 39 {} 39 WorkerPool::WorkerPool() : 40 Observable("WorkerPool") 41 { 42 // observable stuff 43 Channels *OurChannel = new Channels; 44 NotificationChannels.insert( std::make_pair(this, OurChannel) ); 45 // add instance for each notification type 46 for (size_t type = 0; type < NotificationType_MAX; ++type) 47 OurChannel->addChannel(type); 48 } 40 49 41 50 /** Destructor for class WorkerPool. … … 121 130 bool WorkerPool::addWorker(const WorkerAddress& address) 122 131 { 132 OBSERVE; 133 NOTIFY(WorkerAdded); 123 134 std::pair<Pool_t::iterator, bool> inserter = 124 135 pool.insert( address ); … … 126 137 LOG(1, "INFO: Successfully added "+toString(address)+" to pool."); 127 138 idle_queue.insert( make_pair( default_priority, address ) ); 139 NOTIFY(WorkerIdle); 128 140 return true; 129 141 } else { … … 142 154 Pool_t::iterator iter = pool.find( address ); 143 155 if (iter != pool.end()) { 156 OBSERVE; 157 NOTIFY(WorkerRemoved); 144 158 Idle_Queue_t::iterator idleiter = getIdleWorker(address); 145 159 if (idleiter != idle_queue.end()) … … 168 182 void WorkerPool::removeAllWorkers() 169 183 { 184 OBSERVE; 185 NOTIFY(WorkerRemoved); 170 186 // empty pool and queue 171 187 idle_queue.clear(); … … 211 227 { 212 228 if (isWorkerBusy(address)) { 229 OBSERVE; 230 NOTIFY(WorkerIdle); 213 231 Busy_Queue_t::const_iterator iter = busy_queue.find(address); 214 232 const priority_t priority = iter->second; 
- 
      src/Fragmentation/Automation/Pool/WorkerPool.hpprd6b12c rfb255d 18 18 #include <string> 19 19 20 #include "CodePatterns/Observer/Observable.hpp" 21 20 22 #include "WorkerAddress.hpp" 21 23 … … 28 30 * 29 31 */ 30 class WorkerPool 32 class WorkerPool : public Observable 31 33 { 32 34 //!> grant unit test access … … 35 37 WorkerPool(); 36 38 ~WorkerPool(); 39 40 enum NotificationType { 41 WorkerIdle, 42 WorkerAdded, 43 WorkerRemoved, 44 NotificationType_MAX // denotes the maximum of available notification types 45 }; 37 46 38 47 bool addWorker(const WorkerAddress &address); 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
