当前位置: 首页>>代码示例>>PHP>>正文


PHP gmp_nextprime函数代码示例

本文整理汇总了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;
 }
开发者ID:campestrini,项目名称:PhpExercise,代码行数:9,代码来源:Calculator.php

示例2: getResult

 public function getResult($num)
 {
     // init
     $prime = 1;
     for ($i = 0; $i < $num; $i++) {
         $prime = gmp_nextprime($prime);
     }
     return gmp_intval($prime);
 }
开发者ID:alegriaghost,项目名称:project_euler,代码行数:9,代码来源:p007.php

示例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;
}
开发者ID:Joeventures,项目名称:addaprime,代码行数:13,代码来源:addaprime.php

示例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;
 }
开发者ID:cityware,项目名称:city-security,代码行数:31,代码来源:Rsa.php

示例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");
     }
 }
开发者ID:zebbra2014,项目名称:bitcoin-webskin-1,代码行数:18,代码来源:PHPCoinAddress.php

示例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;
 }
开发者ID:boulama,项目名称:DreamVids,代码行数:21,代码来源:utils.php

示例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;
         }
     }
 }
开发者ID:katopenzz,项目名称:openemr,代码行数:88,代码来源:BigInteger.php

示例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);
//.........这里部分代码省略.........
开发者ID:NumbDai,项目名称:zephir,代码行数:101,代码来源:NativeArray.php

示例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;
开发者ID:KarolisGie,项目名称:projecteuler,代码行数:18,代码来源:10.php

示例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";
开发者ID:badlamer,项目名称:hhvm,代码行数:19,代码来源:gmp_nextprime.php

示例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;
         }
     }
 }
开发者ID:andreybolonin,项目名称:phpseclib,代码行数:76,代码来源:BigInteger.php

示例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;
     }
 }
开发者ID:sinfocol,项目名称:gwf3,代码行数:40,代码来源:GWF_Prime.php

示例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);
 }
开发者ID:kemoycampbell,项目名称:PHP-RSA,代码行数:6,代码来源:GMP.php

示例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;
开发者ID:KarolisGie,项目名称:projecteuler,代码行数:31,代码来源:12.php

示例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++;
}
开发者ID:prosa85,项目名称:usingPHP,代码行数:13,代码来源:prime1000.php


注:本文中的gmp_nextprime函数示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。