mcordingley/Regression

View on GitHub
src/Algorithm/GradientDescent/StoppingCriteria/MaxTime.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

declare(strict_types = 1);

namespace MCordingley\Regression\Algorithm\GradientDescent\StoppingCriteria;

/**
 * Run the descent for a certain amount of time before stopping. Goes well with
 * some criteria that checks for convergence within an instance of `Any` to cap
 * the amount of time that a descent can run. Nice to make sure that a descent
 * doesn't become runaway on a production server.
 *
 * @package MCordingley\Regression\Algorithm\GradientDescent\StoppingCriteria
 */
final class MaxTime implements StoppingCriteria
{
    /** @var int */
    private $seconds;

    /** @var int */
    private $startTime;

    /**
     * @param int $seconds
     */
    public function __construct(int $seconds)
    {
        $this->seconds = $seconds;
    }

    /**
     * @param array $gradient
     * @param array $coefficients
     * @return bool
     */
    public function converged(array $gradient, array $coefficients): bool
    {
        $time = time();

        if (!$this->startTime) {
            $this->startTime = $time;
        }

        $elapsed = $time - $this->startTime;

        return $elapsed >= $this->seconds;
    }
}