* * 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 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 ($input != 2 && ($input % 2) == 0) { return false; } for ($i = 3; $i <= ceil(sqrt((float) $input)); $i += 2) { if (($input % $i) == 0) { return false; } } return true; } }