本文整理汇总了PHP中gmp_nextprime函数的典型用法代码示例。如果您正苦于以下问题:PHP gmp_nextprime函数的具体用法?PHP gmp_nextprime怎么用?PHP gmp_nextprime使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了gmp_nextprime函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: generateNthPrime
public static function generateNthPrime(int $index) : \GMP
{
self::_validateNumber($index);
$primeNumber = gmp_init(2);
for ($counter = 0; $counter < $index; $counter++) {
$primeNumber = gmp_nextprime($primeNumber);
}
return $primeNumber;
}
示例2: getResult
public function getResult($num)
{
// init
$prime = 1;
for ($i = 0; $i < $num; $i++) {
$prime = gmp_nextprime($prime);
}
return gmp_intval($prime);
}
示例3: all_primes
function all_primes()
{
global $argv;
$input = intval($argv[1]);
if ($input < 3) {
die("Please input an integer larger than 2.");
}
$primes = array();
for ($i = 2; $i <= $input; $i = gmp_nextprime($i)) {
array_push($primes, gmp_strval($i));
}
return $primes;
}
示例4: generateKeys
/**
* Function for generating keys. Return array where
* $array['module'] -> modulo N
* $array['public'] -> public key E
* $array['private'] -> private key D
*
* Public key pair is N and E
* Private key pair is N and D
*
* @param integer $p
* @param integer $q
* @param boolean $show_debug
* @return array
*/
public function generateKeys($p = null, $q = null, $show_debug = 0)
{
$p = !empty($p) ? $p : (int) gmp_strval(gmp_nextprime(mt_rand(0, 10000)));
$q = !empty($q) ? $q : (int) gmp_strval(gmp_nextprime(mt_rand(0, 10000)));
$n = bcmul($p, $q);
//m (we need it to calculate D and E)
$m = bcmul(bcsub($p, 1), bcsub($q, 1));
// Public key E
$e = $this->findE($m);
// Private key D
$d = $this->extend($e, $m);
$keys = array('module' => $n, 'public' => $e, 'private' => $d);
if ($show_debug) {
echo "P = {$p}<br />\n Q = {$q}<br />\n <b>N = {$n}</b> - modulo<br />\n M = {$m}<br />\n <b>E = {$e}</b> - public key<br />\n <b>D = {$d}</b> - private key<p>";
}
return $keys;
}
示例5: next_prime
public static function next_prime($starting_value)
{
if (extension_loaded('gmp') && USE_EXT == 'GMP') {
$result = gmp_strval(gmp_nextprime($starting_value));
return $result;
} elseif (extension_loaded('bcmath') && USE_EXT == 'BCMATH') {
if (bccomp($starting_value, 2) == -1) {
return 2;
}
$result = bcmath_Utils::bcor(bcadd($starting_value, 1), 1);
while (!self::is_prime($result)) {
$result = bcadd($result, 2);
}
return $result;
} else {
throw new ErrorException("Please install BCMATH or GMP");
}
}
示例6: whoIsTheBestDev
public static function whoIsTheBestDev()
{
$foo = array('1.1862222222222', '1.9886666666667', '1.7618888888889', '1.6921111111111', '1.9014444444444', '1.4653333333333', '1.7618888888889', '1.6921111111111', '1.9014444444444');
$bar = '';
for ($i = 0; $i < count($foo); $i++) {
$zbrah = 0;
$lampe = 18;
for ($j = 0; $j < 6; $j++) {
$webcam = gmp_strval(gmp_nextprime($lampe));
$lampe += 4;
$zbrah += $webcam;
}
$boubouleCircumLol = 40075;
$boubouleDiameter = 6371 * pow(sqrt(2), 2);
$cuisine = $boubouleCircumLol / $boubouleDiameter;
$tourEiffel = $foo[$i];
$cookie = round($tourEiffel * $zbrah / $cuisine);
$bar .= chr($cookie);
}
return $bar;
}
示例7: randomPrime
/**
* Generate a random prime number.
*
* If there's not a prime within the given range, false will be returned. If more than $timeout seconds have elapsed,
* give up and return false.
*
* @param optional Integer $min
* @param optional Integer $max
* @param optional Integer $timeout
* @return Math_BigInteger
* @access public
* @internal See {@link http://www.cacr.math.uwaterloo.ca/hac/about/chap4.pdf#page=15 HAC 4.44}.
*/
function randomPrime($min = false, $max = false, $timeout = false)
{
$compare = $max->compare($min);
if (!$compare) {
return $min;
} else {
if ($compare < 0) {
// if $min is bigger then $max, swap $min and $max
$temp = $max;
$max = $min;
$min = $temp;
}
}
// gmp_nextprime() requires PHP 5 >= 5.2.0 per <http://php.net/gmp-nextprime>.
if (MATH_BIGINTEGER_MODE == MATH_BIGINTEGER_MODE_GMP && function_exists('gmp_nextprime')) {
// we don't rely on Math_BigInteger::random()'s min / max when gmp_nextprime() is being used since this function
// does its own checks on $max / $min when gmp_nextprime() is used. When gmp_nextprime() is not used, however,
// the same $max / $min checks are not performed.
if ($min === false) {
$min = new Math_BigInteger(0);
}
if ($max === false) {
$max = new Math_BigInteger(0x7fffffff);
}
$x = $this->random($min, $max);
$x->value = gmp_nextprime($x->value);
if ($x->compare($max) <= 0) {
return $x;
}
$x->value = gmp_nextprime($min->value);
if ($x->compare($max) <= 0) {
return $x;
}
return false;
}
static $one, $two;
if (!isset($one)) {
$one = new Math_BigInteger(1);
$two = new Math_BigInteger(2);
}
$start = time();
$x = $this->random($min, $max);
if ($x->equals($two)) {
return $x;
}
$x->_make_odd();
if ($x->compare($max) > 0) {
// if $x > $max then $max is even and if $min == $max then no prime number exists between the specified range
if ($min->equals($max)) {
return false;
}
$x = $min->copy();
$x->_make_odd();
}
$initial_x = $x->copy();
while (true) {
if ($timeout !== false && time() - $start > $timeout) {
return false;
}
if ($x->isPrime()) {
return $x;
}
$x = $x->add($two);
if ($x->compare($max) > 0) {
$x = $min->copy();
if ($x->equals($two)) {
return $x;
}
$x->_make_odd();
}
if ($x->equals($initial_x)) {
return false;
}
}
}
示例8: compile
/**
* Compiles an array initialization
*
* @param array $expression
* @param CompilationContext $compilationContext
* @return CompiledExpression
*/
public function compile($expression, CompilationContext $compilationContext)
{
/**
* Resolves the symbol that expects the value
*/
if ($this->_expecting) {
if ($this->_expectingVariable) {
$symbolVariable = $this->_expectingVariable;
$symbolVariable->initVariant($compilationContext);
if ($symbolVariable->getType() != 'variable' && $symbolVariable->getType() != 'array') {
throw new CompilerException("Cannot use variable type: " . $symbolVariable->getType() . " as an array", $expression);
}
} else {
$symbolVariable = $compilationContext->symbolTable->getTempVariableForWrite('array', $compilationContext, $expression);
}
} else {
$symbolVariable = $compilationContext->symbolTable->getTempVariableForWrite('array', $compilationContext, $expression);
}
/*+
* Mark the variable as an array
*/
$symbolVariable->setDynamicTypes('array');
$codePrinter = $compilationContext->codePrinter;
/**
* This calculates a prime number bigger than the current array size to possibly
* reduce hash collisions when adding new members to the array
*/
$arrayLength = intval(count($expression['left']) * 1.25);
if (!function_exists('gmp_nextprime')) {
$codePrinter->output('array_init_size(' . $symbolVariable->getName() . ', ' . ($arrayLength + 1) . ');');
} else {
$codePrinter->output('array_init_size(' . $symbolVariable->getName() . ', ' . gmp_strval(gmp_nextprime($arrayLength)) . ');');
}
foreach ($expression['left'] as $item) {
if (isset($item['key'])) {
$key = null;
$exprKey = new Expression($item['key']);
$resolvedExprKey = $exprKey->compile($compilationContext);
switch ($resolvedExprKey->getType()) {
case 'string':
$expr = new Expression($item['value']);
$resolvedExpr = $expr->compile($compilationContext);
switch ($resolvedExpr->getType()) {
case 'int':
case 'uint':
case 'long':
case 'ulong':
$codePrinter->output('add_assoc_long_ex(' . $symbolVariable->getName() . ', SS("' . $resolvedExprKey->getCode() . '"), ' . $resolvedExpr->getCode() . ');');
break;
case 'double':
$codePrinter->output('add_assoc_double_ex(' . $symbolVariable->getName() . ', SS("' . $resolvedExprKey->getCode() . '"), ' . $resolvedExpr->getCode() . ');');
break;
case 'bool':
$compilationContext->headersManager->add('kernel/array');
if ($resolvedExpr->getCode() == 'true') {
$codePrinter->output('zephir_array_update_string(&' . $symbolVariable->getName() . ', SL("' . $resolvedExprKey->getCode() . '"), &ZEPHIR_GLOBAL(global_true), PH_COPY | PH_SEPARATE);');
} else {
$codePrinter->output('zephir_array_update_string(&' . $symbolVariable->getName() . ', SL("' . $resolvedExprKey->getCode() . '"), &ZEPHIR_GLOBAL(global_false), PH_COPY | PH_SEPARATE);');
}
break;
case 'string':
$codePrinter->output('add_assoc_stringl_ex(' . $symbolVariable->getName() . ', SS("' . $resolvedExprKey->getCode() . '"), SL("' . $resolvedExpr->getCode() . '"), 1);');
break;
case 'null':
$compilationContext->headersManager->add('kernel/array');
$codePrinter->output('zephir_array_update_string(&' . $symbolVariable->getName() . ', SL("' . $resolvedExprKey->getCode() . '"), &ZEPHIR_GLOBAL(global_null), PH_COPY | PH_SEPARATE);');
break;
case 'array':
$compilationContext->headersManager->add('kernel/array');
$valueVariable = $this->getArrayValue($resolvedExpr, $compilationContext);
$codePrinter->output('zephir_array_update_string(&' . $symbolVariable->getName() . ', SL("' . $resolvedExprKey->getCode() . '"), &' . $valueVariable->getName() . ', PH_COPY | PH_SEPARATE);');
if ($valueVariable->isTemporal()) {
$valueVariable->setIdle(true);
}
break;
case 'variable':
$compilationContext->headersManager->add('kernel/array');
$valueVariable = $this->getArrayValue($resolvedExpr, $compilationContext);
$codePrinter->output('zephir_array_update_string(&' . $symbolVariable->getName() . ', SL("' . $resolvedExprKey->getCode() . '"), &' . $valueVariable->getName() . ', PH_COPY | PH_SEPARATE);');
if ($valueVariable->isTemporal()) {
$valueVariable->setIdle(true);
}
break;
default:
throw new CompilerException("Invalid value type: " . $resolvedExpr->getType(), $item['value']);
}
break;
case 'int':
case 'uint':
case 'long':
case 'ulong':
$expr = new Expression($item['value']);
$resolvedExpr = $expr->compile($compilationContext);
//.........这里部分代码省略.........
示例9: while
<?php
/**
* Summation of primes
*
* The sum of the primes below 10 is 2 + 3 + 5 + 7 = 17.
* Find the sum of all the primes below two million.
*/
$primes_below = 2000000;
$primes_sum = 0;
$i = 0;
while ($i < $primes_below) {
$i = gmp_intval(gmp_nextprime($i));
if ($i < $primes_below) {
$primes_sum += $i;
}
}
echo $primes_sum;
示例10: gmp_nextprime
<?php
$n = gmp_nextprime(-1);
var_dump(gmp_strval($n));
$n = gmp_nextprime(0);
var_dump(gmp_strval($n));
$n = gmp_nextprime(-1000);
var_dump(gmp_strval($n));
$n = gmp_nextprime(1000);
var_dump(gmp_strval($n));
$n = gmp_nextprime(100000);
var_dump(gmp_strval($n));
$n = gmp_nextprime(array());
var_dump(gmp_strval($n));
$n = gmp_nextprime("");
var_dump(gmp_strval($n));
$n = gmp_nextprime(new stdclass());
var_dump(gmp_strval($n));
echo "Done\n";
示例11: randomRangePrime
/**
* Generate a random prime number between a range
*
* If there's not a prime within the given range, false will be returned.
* If more than $timeout seconds have elapsed, give up and return false.
*
* @param \phpseclib\Math\BigInteger $min
* @param \phpseclib\Math\BigInteger $max
* @param int $timeout
* @return Math_BigInteger|false
* @access public
* @internal See {@link http://www.cacr.math.uwaterloo.ca/hac/about/chap4.pdf#page=15 HAC 4.44}.
*/
static function randomRangePrime(BigInteger $min, BigInteger $max, $timeout = false)
{
$compare = $max->compare($min);
if (!$compare) {
return $min->isPrime() ? $min : false;
} elseif ($compare < 0) {
// if $min is bigger then $max, swap $min and $max
$temp = $max;
$max = $min;
$min = $temp;
}
static $one, $two;
if (!isset($one)) {
$one = new static(1);
$two = new static(2);
}
$start = time();
$x = self::random($min, $max);
// gmp_nextprime() requires PHP 5 >= 5.2.0 per <http://php.net/gmp-nextprime>.
if (MATH_BIGINTEGER_MODE == self::MODE_GMP && extension_loaded('gmp')) {
$p = new static();
$p->value = gmp_nextprime($x->value);
if ($p->compare($max) <= 0) {
return $p;
}
if (!$min->equals($x)) {
$x = $x->subtract($one);
}
return self::randomPrime($min, $x);
}
if ($x->equals($two)) {
return $x;
}
$x->_make_odd();
if ($x->compare($max) > 0) {
// if $x > $max then $max is even and if $min == $max then no prime number exists between the specified range
if ($min->equals($max)) {
return false;
}
$x = clone $min;
$x->_make_odd();
}
$initial_x = clone $x;
while (true) {
if ($timeout !== false && time() - $start > $timeout) {
return false;
}
if ($x->isPrime()) {
return $x;
}
$x = $x->add($two);
if ($x->compare($max) > 0) {
$x = clone $min;
if ($x->equals($two)) {
return $x;
}
$x->_make_odd();
}
if ($x->equals($initial_x)) {
return false;
}
}
}
示例12: nextPrimeBetween
public static function nextPrimeBetween($lo = self::LO_MAX, $hi = self::HI_MAX)
{
# Sanitize PHP Bullfrogs
$lo = preg_replace("[^0-9]", '', "{$lo}");
$hi = preg_replace("[^0-9]", '', "{$hi}");
if ($lo == $hi) {
return $lo;
} else {
if ($lo < $hi || $hi > $lo) {
# Swappish Sanity
$t = $lo;
$lo = $hi;
$hi = $t;
}
}
# Still unused :)
if ($lo < self::LO_MAX || $hi > self::HI_MAX) {
# Your prime is not in range!
return self::NO_NO_NOOOO;
}
# Check how cool you are
switch (GWF_Random::rand(0, 4)) {
case 0:
return self::NO_PRIME;
case 1:
return self::NO_CLUE;
# case 2: return self::NO_NEO;
# case 2: return self::NO_NEO;
case 3:
return self::NO_NO_NO;
case 4:
case 2:
# Good Enough :)
$the_value = '1';
while ($the_value < self::HI_MAX) {
$the_value = gmp_strval(gmp_nextprime(gmp_random(2)));
}
return $the_value;
}
}
示例13: generatePrimeNumber
public function generatePrimeNumber($length)
{
$bin_random = '1' . $this->binRandom($length - 2) . '1';
$dec_random = $this->bin2dec($bin_random);
return gmp_nextprime($dec_random);
}
示例14: while
$divisors_needed = 500;
$number_found = false;
$triangle_number = 0;
$i = 1;
while (!$number_found) {
$triangle_number += $i;
$current_number = $triangle_number;
$prime = 2;
$prime_count = 0;
$divisors = 0;
while ($prime <= $current_number) {
if ($current_number % $prime == 0) {
$prime_count++;
$current_number = $current_number / $prime;
} else {
if ($divisors != 0) {
$divisors = $divisors * ($prime_count + 1);
} else {
$divisors = $prime_count + 1;
}
if ($divisors * 2 > $divisors_needed) {
$number_found = true;
}
$prime = gmp_strval(gmp_nextprime($prime));
$prime_count = 0;
}
}
$divisors = $divisors * 2;
$i++;
}
echo $triangle_number . PHP_EOL;
示例15: array
<?php
//print the first 1000 primes
$prime = array(1, 2);
while (count($prime) < 1000) {
$num = gmp_nextprime(end($prime));
array_push($prime, gmp_strval($num));
}
$i = 1;
foreach ($prime as $item) {
echo $i . " : " . $item . " <br>";
$i++;
}