* * For the full copyright and license information, please view the LICENSE file * that was distributed with this source code. */ declare(strict_types=1); namespace Respect\Validation\Rules; use function is_numeric; /** * Validates whether the input follows the Fibonacci integer sequence. * * @author Danilo Correa * @author Henrique Moody * @author Samuel Heinzmann */ final class Fibonacci extends AbstractRule { /** * {@inheritDoc} */ public function validate($input): bool { if (!is_numeric($input)) { return false; } $sequence = [0, 1]; $position = 1; while ($input > $sequence[$position]) { ++$position; $sequence[$position] = $sequence[$position - 1] + $sequence[$position - 2]; } return $sequence[$position] === (int) $input; } }