DDS  ver. 3.6
Scheduler.h
Go to the documentation of this file.
1 // Copyright 2014 GSI, Inc. All rights reserved.
2 //
3 //
4 //
5 #ifndef __DDS__SSHScheduler__
6 #define __DDS__SSHScheduler__
7 
8 // DDS
9 #include "AgentChannel.h"
10 #include "ChannelInfo.h"
11 #include "TopoCore.h"
12 #include "TopoTask.h"
13 // STD
14 #include <vector>
15 
16 namespace dds
17 {
18  namespace commander_cmd
19  {
20  class CScheduler
21  {
22  public:
23  struct SSchedule
24  {
26  : m_taskID(0)
27  {
28  }
29 
30  uint64_t m_taskID;
33  };
34 
35  using ScheduleVector_t = std::vector<SSchedule>;
36  using CollectionMap_t = std::map<size_t, std::vector<uint64_t>, std::greater<size_t>>;
37  using weakChannelInfoVector_t = std::vector<dds::protocol_api::SWeakChannelInfo<CAgentChannel>>;
38 
39  private:
40  // Map tuple<agent ID, host name, worker id> to vector of channel indeces.
41  using hostToChannelMap_t = std::map<std::tuple<uint64_t, std::string, std::string>, std::vector<size_t>>;
42  // Map pair<host name, task/collection name> to counter.
43  using hostCounterMap_t = std::map<std::pair<std::string, std::string>, size_t>;
44 
45  public:
46  CScheduler();
47  ~CScheduler();
48 
49  void makeSchedule(const topology_api::CTopoCore& _topology, const weakChannelInfoVector_t& _channels);
50 
51  void makeSchedule(const topology_api::CTopoCore& _topology,
52  const weakChannelInfoVector_t& _channels,
53  const topology_api::CTopoCore::IdSet_t& _addedTasks,
54  const topology_api::CTopoCore::IdSet_t& _addedCollections);
55 
56  const ScheduleVector_t& getSchedule() const;
57 
58  static bool hostPatternMatches(const std::string& _hostPattern, const std::string& _host);
59 
60  std::string toString();
61 
62  private:
63  void makeScheduleImpl(const topology_api::CTopoCore& _topology,
64  const weakChannelInfoVector_t& _channels,
65  const topology_api::CTopoCore::IdSet_t* _addedTasks,
66  const topology_api::CTopoCore::IdSet_t* _addedCollections);
67 
68  void scheduleCollections(const topology_api::CTopoCore& _topology,
69  const weakChannelInfoVector_t& _channels,
70  hostToChannelMap_t& _hostToChannelMap,
71  std::set<uint64_t>& _scheduledTasks,
72  const CollectionMap_t& _collectionMap,
73  size_t _numRequirements,
74  hostCounterMap_t& _hostCounterMap);
75 
76  void scheduleTasks(const topology_api::CTopoCore& _topology,
77  const weakChannelInfoVector_t& _channels,
78  hostToChannelMap_t& _hostToChannelMap,
79  std::set<uint64_t>& _scheduledTasks,
80  const std::set<uint64_t>& _tasksInCollections,
81  size_t _numRequirements,
82  const topology_api::CTopoCore::IdSet_t* _addedTasks,
83  hostCounterMap_t& _hostCounterMap);
84 
85  bool checkRequirements(const topology_api::CTopoRequirement::PtrVector_t& _requirements,
86  const std::string& _hostName,
87  const std::string& _wnName,
88  const std::string& _elementName,
89  hostCounterMap_t& _hostCounterMap) const;
90 
91  private:
92  ScheduleVector_t m_schedule;
93  };
94  } // namespace commander_cmd
95 } // namespace dds
96 
97 #endif /* defined(__DDS__SSHScheduler__) */
topology_api::STopoRuntimeTask m_taskInfo
Definition: Scheduler.h:31
std::string toString()
Definition: Scheduler.cpp:363
std::map< size_t, std::vector< uint64_t >, std::greater< size_t > > CollectionMap_t
Definition: Scheduler.h:36
std::vector< SSchedule > ScheduleVector_t
Definition: Scheduler.h:35
Definition: Scheduler.h:20
Definition: TopoTask.h:101
uint64_t m_taskID
Definition: Scheduler.h:30
std::vector< dds::protocol_api::SWeakChannelInfo< CAgentChannel > > weakChannelInfoVector_t
Definition: Scheduler.h:37
const ScheduleVector_t & getSchedule() const
Definition: Scheduler.cpp:350
~CScheduler()
Definition: Scheduler.cpp:27
Miscellaneous functions and helpers are located here.
Definition: AgentConnectionManager.h:13
Definition: TopoCore.h:25
void makeSchedule(const topology_api::CTopoCore &_topology, const weakChannelInfoVector_t &_channels)
Definition: Scheduler.cpp:31
CScheduler()
Definition: Scheduler.cpp:23
static bool hostPatternMatches(const std::string &_hostPattern, const std::string &_host)
Definition: Scheduler.cpp:355
Definition: ChannelInfo.h:38
dds::protocol_api::SWeakChannelInfo< CAgentChannel > m_weakChannelInfo
Definition: Scheduler.h:32
SSchedule()
Definition: Scheduler.h:25
std::set< Id_t > IdSet_t
Note that ID is of type uint_64. ID is calculated using CRC64 algorithm.
Definition: TopoCore.h:30
std::vector< CTopoRequirement::Ptr_t > PtrVector_t
Definition: TopoRequirement.h:32