source: src/Fragmentation/Automation/SpecificFragmentController.hpp@ 732507

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
Last change on this file since 732507 was 732507, checked in by Frederik Heber <heber@…>, 11 years ago

SpecificFragmentController now contains template ResultContainer.

  • Results are received as soon as possible (so far we waited until all are done).
  • Results are converted directly and stored in map with JobId's with specific result type internally.
  • NOTE: each specific controller needs to implement a getter, the member variable of the ResultContainer type and the virtual waitForResults() which just redirects to ResultContainer::waitForResults().
  • Property mode set to 100644
File size: 2.8 KB
Line 
1/*
2 * SpecificFragmentController.hpp
3 *
4 * Created on: Aug 27, 2012
5 * Author: heber
6 */
7
8#ifndef SPECIFICFRAGMENTCONTROLLER_HPP_
9#define SPECIFICFRAGMENTCONTROLLER_HPP_
10
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
17#include "JobMarket/Controller/FragmentController.hpp"
18#include "JobMarket/types.hpp"
19#include "JobMarket/Results/FragmentResult.hpp"
20
21#include <map>
22#include <string>
23#include <vector>
24
25/** This class extends FragmentController by some commodity functions used
26 * within FragmentationAutomationAction.
27 *
28 */
29class SpecificFragmentController : public FragmentController
30{
31public:
32 SpecificFragmentController(boost::asio::io_service &_io_service) :
33 FragmentController(_io_service),
34 io_service(_io_service)
35 {}
36
37 virtual ~SpecificFragmentController()
38 {}
39
40 void requestIds(const size_t numberjobs);
41 virtual void waitforResults(const size_t NoExpectedResults)=0;
42 void RunService(const std::string message);
43
44 /// getter and setter
45
46 void setHost(const std::string &_host) { host = _host; }
47 void setPort(const std::string &_port) { port = _port; }
48
49protected:
50
51 /** Container for the results received from the server.
52 *
53 * These are received bit by bit until all jobs are calculated.
54 * This struct takes of the waiting.
55 *
56 */
57 template <typename T>
58 struct ResultContainer {
59 /** cycle to wait for results
60 *
61 * \param NoExpectedResults number of expected results
62 * \param io_service service used for waiting
63 * \param callback ref to call controller functions
64 */
65 void waitforResults(
66 const size_t NoExpectedResults,
67 boost::asio::io_service &io_service,
68 SpecificFragmentController &callback);
69
70 /** Internal function to receive results if some are present.
71 *
72 * \param callback ref to call controller functions
73 * \return number of received results
74 */
75 size_t receiveResults(SpecificFragmentController &callback);
76
77 /** Extracts specific Data type from received vector of FragmentResults.
78 *
79 * @param results results to extract specific Data type from
80 * @param fragmentData on return array filled with extracted specific Data type
81 */
82 void ConvertFragmentResultTo(
83 const std::vector<FragmentResult::ptr> &results,
84 std::vector<T> &fragmentData);
85
86 /** Clears all internally stored results.
87 *
88 */
89 void clear()
90 { IdData.clear(); }
91
92 //!> internal container for the received data
93 std::map<JobId_t, T> IdData;
94 };
95
96protected:
97 //!> hostname of the server to control
98 std::string host;
99 //!> port of the server to control
100 std::string port;
101 //!> reference to io_service for internal purposes
102 boost::asio::io_service &io_service;
103};
104
105#include "SpecificFragmentController_ResultContainer_impl.hpp"
106
107#endif /* SPECIFICFRAGMENTCONTROLLER_HPP_ */
Note: See TracBrowser for help on using the repository browser.