Ocean
|
This class implements a worker able to distribute function calls over different threads. More...
#include <Worker.h>
Data Structures | |
class | WorkerThread |
This class implements a thread with an explicit external thread function. More... | |
Public Types | |
enum | LoadType : uint32_t { TYPE_ONE_CORE , TYPE_HALF_CORES , TYPE_ALL_BUT_ONE_CORE , TYPE_ALL_CORES , TYPE_DOUBLE_CORES , TYPE_CUSTOM } |
Definition of CPU load types. More... | |
typedef Caller< void > | Function |
Definition of a worker function caller object for standard functions to be distributed. | |
typedef Caller< bool > | AbortableFunction |
Definition of a worker function caller object for abort functions. | |
typedef std::vector< Function > | Functions |
Definition of a vector holding worker functions. | |
typedef std::vector< unsigned int > | StartIndices |
Definition of a vector holding indices. | |
Public Member Functions | |
Worker (const LoadType loadType=TYPE_ALL_CORES, const unsigned int maximalNumberCores=16u) | |
Creates a new worker object. | |
Worker (const unsigned int numberCores, const LoadType loadType) | |
Creates a new worker object with a custom amount of worker threads. | |
~Worker () | |
Destructs a worker object. | |
unsigned int | threads () const |
Returns the number of threads this worker uses. | |
bool | executeFunction (const Function &function, const unsigned int first, const unsigned int size, const unsigned int firstIndex=(unsigned int)(-1), const unsigned int sizeIndex=(unsigned int)(-1), const unsigned int minimalIterations=1u, const unsigned int threadIndex=(unsigned int)(-1)) |
Executes a callback function separable by two function parameters. | |
bool | executeFunctions (const Functions &functions) |
Executes several callback functions concurrently. | |
bool | executeAbortableFunction (const AbortableFunction &abortableFunction, const unsigned int abortIndex, const unsigned int maximalExecutions=0u) |
Executes an abortable function on several CPU cores. | |
bool | executeSeparableAndAbortableFunction (const AbortableFunction &separableAbortableFunction, const unsigned int first, const unsigned int size, const unsigned int firstIndex, const unsigned int sizeIndex, const unsigned int abortIndex, const unsigned int minimalIterations=1) |
Executes an abortable and separable function on several CPU cores. | |
StartIndices | separation (const unsigned int first, const unsigned int size, const unsigned int minimalIterations=1u) |
Returns a separation this worker would apply to execute a distributable function. | |
operator bool () const | |
Returns whether this worker uses more than one thread to distribute a function. | |
operator Worker * () const | |
Explicit worker pointer operator. | |
Protected Types | |
typedef std::vector< WorkerThread * > | WorkerThreads |
Definition of a vector holding worker threads. | |
Protected Member Functions | |
Worker (const Worker &worker)=delete | |
Disabled copy constructor. | |
Worker & | operator= (const Worker &worker)=delete |
Disabled copy operator. | |
Protected Attributes | |
WorkerThreads | workerThreads_ |
Worker threads. | |
Signals | signals_ |
Worker signals determining whether all thread finished their work. | |
Lock | lock_ |
Worker lock. | |
This class implements a worker able to distribute function calls over different threads.
Thus, this worker object can be used to distribute complex operations to several CPU cores to speed up the entire computation significantly.
The worker provides several modes to distribute the computational load of a complex operation.
Function call my be made faster by using subsets of the entire data by individual CPU cores only.
Further, this worker supports abortable functions executing the same function several times and stops all other threads if the first function receives a valid result.
For more details several code examples are provided:
typedef Caller<bool> Ocean::Worker::AbortableFunction |
Definition of a worker function caller object for abort functions.
typedef Caller<void> Ocean::Worker::Function |
Definition of a worker function caller object for standard functions to be distributed.
Standard functions allow the computation using a subset of the entire data.
typedef std::vector<Function> Ocean::Worker::Functions |
Definition of a vector holding worker functions.
typedef std::vector<unsigned int> Ocean::Worker::StartIndices |
Definition of a vector holding indices.
|
protected |
Definition of a vector holding worker threads.
enum Ocean::Worker::LoadType : uint32_t |
Definition of CPU load types.
|
explicit |
Creates a new worker object.
The load type defines the number of cores to be used, however the worker will not address more than 'maximalNumberCores'.
loadType | Load type used for this worker, must not be TYPE_CUSTOM |
maximalNumberCores | The maximal number of cores to be used, with range [1, infinity) |
Ocean::Worker::Worker | ( | const unsigned int | numberCores, |
const LoadType | loadType | ||
) |
Creates a new worker object with a custom amount of worker threads.
numberCores | The number of threads to use, with range [1, infinity) |
loadType | Must be TYPE_CUSTOM |
Ocean::Worker::~Worker | ( | ) |
Destructs a worker object.
|
protecteddelete |
Disabled copy constructor.
worker | Object which would be copied |
bool Ocean::Worker::executeAbortableFunction | ( | const AbortableFunction & | abortableFunction, |
const unsigned int | abortIndex, | ||
const unsigned int | maximalExecutions = 0u |
||
) |
Executes an abortable function on several CPU cores.
The function must provide an abort parameter. The parameter is a pointer to a boolean state initialized with False.
abortableFunction | Function supporting an abort state to terminate the function explicitly |
abortIndex | Index of the abort parameter |
maximalExecutions | Number of maximal CPU core executions |
bool Ocean::Worker::executeFunction | ( | const Function & | function, |
const unsigned int | first, | ||
const unsigned int | size, | ||
const unsigned int | firstIndex = (unsigned int)(-1) , |
||
const unsigned int | sizeIndex = (unsigned int)(-1) , |
||
const unsigned int | minimalIterations = 1u , |
||
const unsigned int | threadIndex = (unsigned int)(-1) |
||
) |
Executes a callback function separable by two function parameters.
The first separable function parameter defines the start point.
The second separable function parameter defines the number of iterations for the specified start point.
This example shows how to use the worker object in combination with a distributable function:
Output for a CPU with 4 cores would be e.g. (the order of the output may vary):
Function call handling bytes: 0, 255
Function call handling bytes: 256, 511
Function call handling bytes: 512, 767
Function call handling bytes: 768, 1023
function | Separable function to be execute |
first | First function parameter |
size | Size function parameter |
firstIndex | Index of the worker function parameter receiving the start value, if -1 than the index will be set to the second last parameter, otherwise with range [0, function.parameters()) |
sizeIndex | Index of the worker function parameter receiving the number value, if -1 than the index will be set to the last parameter, otherwise with range [0, function.parameters()) |
minimalIterations | Minimal number of iterations assigned to one internal thread |
threadIndex | Optional index of the worker function parameter receiving the index of the individual thread |
bool Ocean::Worker::executeFunctions | ( | const Functions & | functions | ) |
Executes several callback functions concurrently.
This example shows how to use the worker object in combination with several individual callback functions:
Output (the order of the output may vary):
Function0 call with value: 9
Function1 call with value: world
Function0 call with value: 101
Function1 call with value: hallo
functions | Callback function to execute |
bool Ocean::Worker::executeSeparableAndAbortableFunction | ( | const AbortableFunction & | separableAbortableFunction, |
const unsigned int | first, | ||
const unsigned int | size, | ||
const unsigned int | firstIndex, | ||
const unsigned int | sizeIndex, | ||
const unsigned int | abortIndex, | ||
const unsigned int | minimalIterations = 1 |
||
) |
Executes an abortable and separable function on several CPU cores.
The function must be separable by two function parameters and must provide an abort parameter allowing to stop the function execution immediately.
separableAbortableFunction | Function supporting an separation and aborting |
first | The first function parameter |
size | The size function parameter |
firstIndex | Index of the worker function parameter receiving the start value |
sizeIndex | Index of the worker function parameter receiving the number value |
abortIndex | Index of the abort parameter |
minimalIterations | Minimal number of iterations assigned to one internal thread |
|
inlineexplicit |
Returns whether this worker uses more than one thread to distribute a function.
|
inline |
Explicit worker pointer operator.
Disabled copy operator.
worker | Object which would be copied |
StartIndices Ocean::Worker::separation | ( | const unsigned int | first, |
const unsigned int | size, | ||
const unsigned int | minimalIterations = 1u |
||
) |
Returns a separation this worker would apply to execute a distributable function.
first | The first function parameter |
size | The size function parameter |
minimalIterations | Minimal number of iterations assigned to one internal thread |
unsigned int Ocean::Worker::threads | ( | ) | const |
Returns the number of threads this worker uses.
|
protected |
Worker signals determining whether all thread finished their work.
|
protected |
Worker threads.