Changeset c4f43e for src/Fragmentation
- Timestamp:
- Jul 2, 2012, 7:54:13 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, 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:
- 917be8
- Parents:
- e11611
- git-author:
- Frederik Heber <heber@…> (04/19/12 21:06:07)
- git-committer:
- Frederik Heber <heber@…> (07/02/12 07:54:13)
- Location:
- src/Fragmentation/Automation
- Files:
-
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Fragmentation/Automation/FragmentController.cpp
re11611 rc4f43e 86 86 * @param host address of server 87 87 * @param service port/service of server 88 */ 89 void FragmentController::requestId( 90 const std::string &host, 91 const std::string &service) 88 * @param NumberIds number of desired ids to request with this connect 89 */ 90 void FragmentController::requestIds( 91 const std::string &host, 92 const std::string &service, 93 const size_t NumberIds) 92 94 { 93 95 GetNextJobIdOperation *getnextid = static_cast<GetNextJobIdOperation *>( 94 96 Commands.getByName("getnextjobid")); 97 (*getnextid).setDesiredIds(NumberIds); 95 98 (*getnextid)(host,service); 96 99 } -
src/Fragmentation/Automation/FragmentController.hpp
re11611 rc4f43e 43 43 size_t getExitflag() const; 44 44 45 void requestId (const std::string &host, const std::string &service);45 void requestIds(const std::string &host, const std::string &service, const size_t NumberIds); 46 46 JobId_t getAvailableId(); 47 47 void addJobs(std::vector<FragmentJob::ptr> &jobs); -
src/Fragmentation/Automation/FragmentScheduler.cpp
re11611 rc4f43e 26 26 #include "CodePatterns/MemDebug.hpp" 27 27 28 #include <algorithm> 28 29 #include <boost/bind.hpp> 29 30 #include <boost/lexical_cast.hpp> … … 345 346 case GetNextJobId: 346 347 { 347 const JobId_t nextid = globalId.getNextId(); 348 LOG(1, "INFO: Sending next available job id " << nextid << " to controller ..."); 349 conn->async_write(nextid, 348 LOG(1, "INFO: Receiving number of desired job ids from controller ..."); 349 conn->async_read(NumberIds, 350 350 boost::bind(&FragmentScheduler::ControllerListener_t::handle_GetNextJobIdState, this, 351 351 boost::asio::placeholders::error, conn)); … … 462 462 { 463 463 Info info(__FUNCTION__); 464 465 std::vector<JobId_t> nextids( NumberIds, JobId::IllegalJob); 466 std::generate(nextids.begin(), nextids.end(), 467 boost::bind(&GlobalJobId::getNextId, boost::ref(globalId))); 468 LOG(1, "INFO: Sending next available job ids " << nextids << " to controller ..."); 469 conn->async_write(nextids, 470 boost::bind(&FragmentScheduler::ControllerListener_t::handle_SendIds, this, 471 boost::asio::placeholders::error, conn)); 472 } 473 474 /** Controller callback function when free job ids have been sent. 475 * 476 * \param e error code if something went wrong 477 * \param conn reference with the connection 478 */ 479 void FragmentScheduler::ControllerListener_t::handle_SendIds(const boost::system::error_code& e, connection_ptr conn) 480 { 481 Info info(__FUNCTION__); 464 482 // do nothing 465 LOG(1, "INFO: Sent next available job id.");483 LOG(1, "INFO: Ids have been sent."); 466 484 } 467 485 -
src/Fragmentation/Automation/FragmentScheduler.hpp
re11611 rc4f43e 147 147 void handle_GetNextJobIdState(const boost::system::error_code& e, connection_ptr conn); 148 148 149 /// Controller callback function when free job ids have been sent. 150 void handle_SendIds(const boost::system::error_code& e, connection_ptr conn); 151 149 152 /// Controller callback function when result has been received. 150 153 void handle_SendResults(const boost::system::error_code& e, connection_ptr conn); … … 159 162 //!> number of jobs that are waiting to be and are calculated, required for returning status 160 163 std::vector<size_t> jobInfo; 164 165 //!> number of job ids request from controller; 166 size_t NumberIds; 161 167 162 168 //!> choice -
src/Fragmentation/Automation/Operations/Controllers/GetNextJobIdOperation.cpp
re11611 rc4f43e 46 46 { 47 47 // Successfully established connection. Give choice. 48 48 enum ControllerChoices choice = GetNextJobId; 49 49 connection_.async_write(choice, 50 boost::bind(&GetNextJobIdOperation::handle_ ReceiveNextId, this,50 boost::bind(&GetNextJobIdOperation::handle_SendNumberIds, this, 51 51 boost::asio::placeholders::error)); 52 52 } else if (endpoint_iterator != boost::asio::ip::tcp::resolver::iterator()) { … … 65 65 } 66 66 67 /** Callback function when doneJobs have been received.67 /** Callback function when sending number of desired job ids. 68 68 * 69 69 * \param e error code if something went wrong 70 70 */ 71 void GetNextJobIdOperation::handle_ ReceiveNextId(const boost::system::error_code& e)71 void GetNextJobIdOperation::handle_SendNumberIds(const boost::system::error_code& e) 72 72 { 73 73 Info info(__FUNCTION__); … … 76 76 // The connection::async_read() function will automatically 77 77 // decode the data that is written to the underlying socket. 78 LOG(1, "INFO: Obtaining next available job id ..."); 79 connection_.async_read(nextid, 78 LOG(1, "INFO: Requesting " << NumberIds << " ids ..."); 79 connection_.async_write(NumberIds, 80 boost::bind(&GetNextJobIdOperation::handle_ReceiveNextIds, this, 81 boost::asio::placeholders::error)); 82 } 83 else 84 { 85 // An error occurred. 86 ELOG(1, e.message()); 87 } 88 } 89 90 /** Callback function when doneJobs have been received. 91 * 92 * \param e error code if something went wrong 93 */ 94 void GetNextJobIdOperation::handle_ReceiveNextIds(const boost::system::error_code& e) 95 { 96 Info info(__FUNCTION__); 97 if (!e) 98 { 99 // The connection::async_read() function will automatically 100 // decode the data that is written to the underlying socket. 101 LOG(1, "INFO: Obtaining a bunch of available job ids ..."); 102 connection_.async_read(ids, 80 103 boost::bind(&GetNextJobIdOperation::handle_FinishOperation, this, 81 104 boost::asio::placeholders::error)); … … 97 120 98 121 // place id into nextids 99 nextids.push_back(nextid); 100 nextid = JobId::IllegalJob; 122 nextids.insert(nextids.end(), ids.begin(), ids.end()); 123 ids.clear(); 124 NumberIds = 0; 101 125 102 126 // and finish operation -
src/Fragmentation/Automation/Operations/Controllers/GetNextJobIdOperation.hpp
re11611 rc4f43e 30 30 /// Constructor for class GetNextJobIdOperation. 31 31 GetNextJobIdOperation(Connection &_connection) : 32 AsyncOperation(std::string("getnextjobid"), _connection), 33 nextid(JobId::IllegalJob) 32 AsyncOperation(std::string("getnextjobid"), _connection) 34 33 {} 35 34 /// Destructor for class GetNextJobIdOperation … … 41 40 boost::asio::ip::tcp::resolver::iterator endpoint_iterator); 42 41 43 /// Callback function when doneJobs have been received. 44 void handle_ReceiveNextId(const boost::system::error_code& e); 42 /// Callback function when sending number of desired job ids. 43 void handle_SendNumberIds(const boost::system::error_code& e); 44 45 /// Callback function when new job ids have been received. 46 void handle_ReceiveNextIds(const boost::system::error_code& e); 47 48 /// setter for the desired number of ids on next connect 49 void setDesiredIds(const size_t _number) { 50 NumberIds = _number; 51 } 45 52 46 53 /// Getter for nextid … … 56 63 void handle_FinishOperation(const boost::system::error_code& e); 57 64 58 /// current jobs left to calculate and currently calculated results 65 private: 66 //!> number of desired job ids 67 size_t NumberIds; 68 69 //!> temporary for a bunch of received ids 70 std::vector<JobId_t> ids; 71 72 //!> number of received job ids 59 73 std::list<JobId_t> nextids; 60 61 // temporary for receiving another job id62 JobId_t nextid;63 74 }; 64 75 -
src/Fragmentation/Automation/controller.cpp
re11611 rc4f43e 233 233 } else { 234 234 // get an id for every filename 235 for (int argcount = 4; argcount < argc; ++argcount) { 236 controller.requestId(argv[1], argv[2]); 237 } 235 controller.requestIds(argv[1], argv[2], argc-4); 238 236 } 239 237 break; … … 245 243 ELOG(1, "'createjobs' requires two options: [command] [argument]."); 246 244 } else { 247 controller.requestId (argv[1], argv[2]);245 controller.requestIds(argv[1], argv[2], 1); 248 246 } 249 247 break;
Note:
See TracChangeset
for help on using the changeset viewer.