Hedgehog  3.1.0
A library to generate hybrid pipeline workflow systems
Loading...
Searching...
No Matches
scheduler.h
Go to the documentation of this file.
1// NIST-developed software is provided by NIST as a public service. You may use, copy and distribute copies of the
2// software in any medium, provided that you keep intact this entire notice. You may improve, modify and create
3// derivative works of the software or any portion of the software, and you may copy and distribute such modifications
4// or works. Modified works should carry a notice stating that you changed the software and should note the date and
5// nature of any such change. Please explicitly acknowledge the National Institute of Standards and Technology as the
6// source of the software. NIST-developed software is expressly provided "AS IS." NIST MAKES NO WARRANTY OF ANY KIND,
7// EXPRESS, IMPLIED, IN FACT OR ARISING BY OPERATION OF LAW, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTY OF
8// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT AND DATA ACCURACY. NIST NEITHER REPRESENTS NOR
9// WARRANTS THAT THE OPERATION OF THE SOFTWARE WILL BE UNINTERRUPTED OR ERROR-FREE, OR THAT ANY DEFECTS WILL BE
10// CORRECTED. NIST DOES NOT WARRANT OR MAKE ANY REPRESENTATIONS REGARDING THE USE OF THE SOFTWARE OR THE RESULTS
11// THEREOF, INCLUDING BUT NOT LIMITED TO THE CORRECTNESS, ACCURACY, RELIABILITY, OR USEFULNESS OF THE SOFTWARE. You
12// are solely responsible for determining the appropriateness of using and distributing the software and you assume
13// all risks associated with its use, including but not limited to the risks and costs of program errors, compliance
14// with applicable laws, damage to or loss of data, programs or equipment, and the unavailability or interruption of
15// operation. This software is not intended to be used in any situation where a failure could cause risk of injury or
16// damage to property. The software developed by NIST employees is not subject to copyright protection within the
17// United States.
18
19
20
21#ifndef HEDGEHOG_SCHEDULER_H
22#define HEDGEHOG_SCHEDULER_H
23
24#include <memory>
25#include <set>
26
27#include "../../core/abstractions/base/node/node_abstraction.h"
29namespace hh {
30
32class Scheduler {
33
34 public:
36 Scheduler() = default;
37
39 virtual ~Scheduler() = default;
40
43 [[nodiscard]] virtual std::unique_ptr<Scheduler> create() const = 0;
44
48 virtual void spawnThreads(std::set<core::abstraction::NodeAbstraction *> const &cores, bool waitForInitialization) = 0;
49
51 virtual void joinAll() = 0;
52};
53
54}
55#endif //HEDGEHOG_SCHEDULER_H
Hedgehog main namespace.
Scheduler abstraction to manage graph's threads.
Definition: scheduler.h:32
virtual void joinAll()=0
Method waiting for all graph's threads termination, called when Graph::waitForTermination() is called...
virtual ~Scheduler()=default
Scheduler default destructor.
virtual void spawnThreads(std::set< core::abstraction::NodeAbstraction * > const &cores, bool waitForInitialization)=0
Spawn the threads of a graph.
Scheduler()=default
Scheduler default constructor.
virtual std::unique_ptr< Scheduler > create() const =0
Definition of virtual constructor.