Backend#

Backends are used by objects that implement the Parallel interface to carry out their deferred computations.

Enqueue Computation#

To enqueue a Deferred computation for backend processing:

public enqueue(Deferred $deferred, ?Closure $after = null) : void

Example

use Rubix\ML\Deferred;

$deferred = new Deferred(function ($input) {
    return $input ** 2;
}, 2.5);

$after = function ($result) {
    echo 'done';
};

$backend->enqueue($deferred, $after);

Process Queue#

Process the queue of deferred computations:

public process() : array

*Example

$results = $backend->process();

var_dump($results);
array(1) {
    [0]=> float(6.25)
}

Flush Queue#

Sometimes it might be necesary to remove leftover items from the queue before proceeding. In such a case the flush() method will clear the queue of Deferred computations.

public flush(): void

Example

$backend->flush();