source: src/Actions/Process.cpp@ cd5047

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
Last change on this file since cd5047 was cd5047, checked in by Tillmann Crueger <crueger@…>, 16 years ago

Added Logging capabilities to Observer Framework

  • Property mode set to 100644
File size: 1.8 KB
Line 
1/*
2 * Process.cpp
3 *
4 * Created on: Feb 17, 2010
5 * Author: crueger
6 */
7
8#include "Process.hpp"
9
10using namespace std;
11
12Process::Process(int _maxSteps, std::string _name, bool _doRegister) :
13 Observable("Process"),
14 Action(_name,_doRegister),
15 maxSteps(_maxSteps),
16 active(false),
17 starts(false),
18 stops(false)
19{}
20
21Process::~Process()
22{
23 // make sure everybody knows we have stoped
24 stop();
25}
26
27
28bool Process::isRunning(){
29 return active;
30}
31
32bool Process::doesStart(){
33 return starts;
34}
35
36bool Process::doesStop(){
37 return stops;
38}
39
40int Process::getCurrStep(){
41 OBSERVE;
42 return currStep;
43}
44
45void Process::setCurrStep(int _currStep){
46 currStep = _currStep;
47}
48
49float Process::getDoneRatio() {
50 if(getMaxSteps())
51 return ((float)getCurrStep()/(float)getMaxSteps())*100.0;
52 else
53 return 0;
54}
55
56int Process::getMaxSteps(){
57 return maxSteps;
58}
59
60void Process::setMaxSteps(int _maxSteps){
61 maxSteps = _maxSteps;
62}
63
64void Process::start(){
65 starts = true;
66 {
67 // we forcibly sign on all observers
68 set<Observer*>::iterator iter;
69 for(iter=processObservers.begin();iter!=processObservers.end();++iter){
70 this->signOn((*iter));
71 }
72 }
73 // only this small part should be observed
74 {
75 OBSERVE;
76 currStep=0;
77 }
78 starts = false;
79 active = true;
80}
81
82void Process::step(){
83 OBSERVE;
84 currStep++;
85}
86
87void Process::stop(){
88 active=false;
89 stops = true;
90 {
91 OBSERVE;
92 currStep=0;
93 }
94 {
95 // when we are done we forcibly sign off all observers
96 set<Observer*>::iterator iter;
97 for(iter=processObservers.begin();iter!=processObservers.end();++iter){
98 this->signOff((*iter));
99 }
100 }
101 stops = false;
102}
103
104// static stuff
105
106set<Observer*> Process::processObservers;
107
108void Process::AddObserver(Observer *obs){
109 processObservers.insert(obs);
110}
111void Process::RemoveObserver(Observer *obs){
112 processObservers.erase(obs);
113}
114
Note: See TracBrowser for help on using the repository browser.