* * For the full copyright and license information, please view the "LICENSE.md" * file that was distributed with this source code. */ declare(strict_types=1); namespace Respect\Validation\Rules; use function ceil; use function is_numeric; use function sqrt; /** * Validates whether the input is a prime number. * * @author Alexandre Gomes Gaigalas * @author Camilo Teixeira de Melo * @author Henrique Moody * @author Ismael Elias * @author Kleber Hamada Sato */ final class PrimeNumber extends AbstractRule { /** * {@inheritdoc} */ public function validate($input): bool { if (!is_numeric($input) || $input <= 1) { return false; } if (2 != $input && 0 == ($input % 2)) { return false; } for ($i = 3; $i <= ceil(sqrt((float) $input)); $i += 2) { if (0 == ($input % $i)) { return false; } } return true; } }