gmp_random
Эта функция объявлена УСТАРЕВШЕЙ начиная с PHP 7.2.0 и была УДАЛЕНА в версии PHP 8.0.0. Использовать эту функцию крайне не рекомендуется.
Описание
gmp_random ( int $limiter = 20 ): GMP
Генерирует случайное число. Число будет лежать в пределах от нуля до (2 ** n) — 1, где n — это число, представляющее из себя произведение числа limiter и количества бит в лимбе (limb). Если число limiter отрицательное, то будет возвращён отрицательный результат.
Лимб (дословно конечность) — внутренний GMP механизм. Технически это часть числа, помещающаяся в одно машинное слово. Количество бит в нем может различаться в разных системах. В основном это либо 32, либо 64, но это не гарантируется.
Предостережение
Функция не создаёт криптографически защищённые значения и не должна использоваться для криптографических целей или целей, требующих, чтобы возвращаемые значения были недоступны для разгадывания.
Если нужна криптографически безопасная случайная последовательность, можно использовать класс Random\Randomizer с движком Random\Engine\Secure . Для простых сценариев существуют функции random_int() и random_bytes() с удобным API криптографически безопасного генератора псевдослучайных чисел ( CSPRNG ), поддерживаемого операционной системой.
Список параметров
Объект GMP , целое число ( int ) или числовая строка ( string ).
Введение
Эти функции позволяют работать целыми числами произвольной точности с использованием библиотеки GNU MP.
Эти функции были введены в PHP 4.0.4.
Примечание: в основном функции GMP принимают GMP-количество аргументов, определённое далее как resource. Однако большая часть этих функций принимает также числовые и строковые аргументы, которые можно конвертировать в числа. Также, если если имеется более быстрая функция, работающая с целочисленными аргументами, она может использоваться вместо более медленной функции, если предоставляемые аргументы являются целыми числами. Это делается прозрачно, так что вы можете использовать целые числа в каждой функции, ожидающей GMP-числа. См. также функцию gmp_init().
Если вы хотите явно специфицировать большое целое число, специфицируйте его как строку. Если вы это не сделаете, PHP будет интерпретировать сначала целочисленный литерал, возможно, с потерей точности, даже перед использованием GMP.
Требования
Вы можете загрузить библиотеку GMP с http://www.swox.com/gmp/. Этот сайт содержит также учебник по GMP.
Вам понадобится версия GMP 2 или новее для использования этих функций. Некоторые функции могут потребовать использования самой последней версии библиотеки GMP.
Установка
Чтобы эти функции работали, вы обязаны скомпилировать PHP с поддержкой GMP, используя опцию
--with-gmp.
Конфигурация
Это расширение не определяет никаких директив конфигурации.
Типы ресурсов
Это расширение не определяет никакие типы ресурсов.
Предопределённые константы
Эти константы определены данным расширением и будут доступны только в том случае, если либо вкомпилированы в РНР, либо динамически загружены на этапе прогона.
GMP_ROUND_ZERO (integer) GMP_ROUND_PLUSINF (integer) GMP_ROUND_MINUSINF (integer)
Примеры
Пример 1. Функция вычисления факториала с использованием GMP
print gmp_strval (fact (1000)) . "\n"; ?>
Факториал 1000 будет вычислен (довольно большое число) весьма быстро.
См. также
Содержание gmp_abs — абсолютное значение gmp_add — складывает числа gmp_and — логическое AND gmp_clrbit — очищает бит gmp_cmp — сравнивает числа gmp_com — высчитывает дополнение/complement a gmp_div_q — делит числа gmp_div_qr — делит числа и получает частное и остаток gmp_div_r — остаток от деления чисел gmp_div — делит числа gmp_divexact — точное деление чисел gmp_fact — факториал gmp_gcd — вычисляет GCD gmp_gcdext — вычисляет GCD и множители gmp_hamdist — Hamming distance (математики, переводите. ) gmp_init — создаёт GMP-число gmp_intval — конвертирует GMP-число в целое/integer gmp_invert — инвертирует по modulo gmp_jacobi — символ Jacobi gmp_legendre — символ Legendre gmp_mod — операция Modulo gmp_mul — умножает числа gmp_neg — отрицает число gmp_or — логическое OR gmp_perfect_square — проверка точности квадрата gmp_popcount — счёт заполнения gmp_pow — возводит число в степень gmp_powm — возводит число в степень с modulo gmp_prob_prime — проверяет, является ли число «probably prime» gmp_random — случайное число gmp_scan0 — сканирует 0 gmp_scan1 — сканирует 1 gmp_setbit — устанавливает бит gmp_sign — знак числа gmp_sqrt — квадратный корень gmp_sqrtrm — квадратный корень с остатком gmp_strval — конвертирует GMP-число в строку gmp_sub — вычитает числа gmp_xor — логическое XOR Оглавление
GMP Функции
I made a function that can be used for converting numbers to any base you wish.. instead of returning a string of pre-defined index of characters (i.e. 0-9a-z) you could simply make your own of any length using the array of indexes it returns.
I looked around and didn’t see anybody made one, I needed one for a simple compression algorithm with only numbers, I’ve not actually made it yet but this was an initial idea.
// ConvertBase function explained:
// we add an array item $Input%$Base floored and divide $Input by $Base floored.
// repeat until $Input is no longer above 0.
function ConvertBase ( $Input , $Base = 10 ) <
$Input = gmp_init ( $Input );
$Result =array();
for( $i = 0 ; $i < 1 || gmp_sign ( $Input )== 1 ; $i ++) <
$Result []= gmp_intval ( gmp_mod ( $Input , $Base ));
$Input = gmp_div_q ( $Input , $Base );
>
$Result = array_reverse ( $Result );
return( $Result );
>
// an example how gmp_strval($. 36); could be achieved:
// the funny emergency number from The IT Crowd
// (leading zeroes aren’t liked in gmp_init though)
$Input = ‘1189998819991197253’ ;
// our example 36 characters used in gmp_strval($. 36);
$Chars = ‘0123456789abcdefghijklmnopqrstuvwxyz’ ;
// count the $Chars so they’re all used
// or use your own number less than the length of $Chars
$Base = strlen ( $Chars );
// perform
$Result = ConvertBase ( $Input , $Base );
// replace the resulting index with the corrosponding characters of the index in $Chars
for( $i = 0 ; $i < count ( $Result ); $i ++)
$Result [ $i ]= $Chars < $Result [ $i ]>;
// compare
printf ( «gmp_strval: %s\r\n» , gmp_strval ( $Input , 36 ));
printf ( «BaseConvert: %s\r\n» , implode ( $Result ));
/* OUTPUT:
gmp_strval: 91h7dixfq6h1
BaseConvert: 91h7dixfq6h1
*/
?>
The example shows a familiar result of course, but the idea of this function was so that you can use whatever base you wish, and display entirely your own output to represent any number of choice.
Also, for those who wish to do bitwise shifting, it’s quite simple.. to shift left, just multiply the number by pow(2,x), and to shift right, divide by pow(2,x).
function gmp_shiftl ( $x , $n ) < // shift left
return( gmp_mul ( $x , gmp_pow ( 2 , $n )));
>
function gmp_shiftr ( $x , $n ) < // shift right
return( gmp_div ( $x , gmp_pow ( 2 , $n )));
>
?>
Have fun,
Nitrogen.
19 years ago
For those (like me) who are trying to do bit masking with very large numbers, here is a useful function to do the work for you.
function isBitSet ( $bitMask , $bitMap )
return (bool) gmp_intval ( gmp_div ( gmp_and ( $bitMask , $bitMap ), $bitMask ));
>
?>
17 years ago
Here’s a quick and dirty way to use simple GMP functions with PHP without recompiling. It is dependent upon the use of the exec() function, so make sure you can use exec(). While in safe mode you must consider the safe_mode_exec_dir directive. And don’t simply pass user input to the exec function without validating the input first!
Download and Install GMP as instructed in README and INSTALL files.
On my MAC OS X Server, I just did the following:
./configure
make
make check
make install
This installed it in the /usr/local directory. There were some errors, but not with any functions I needed.
Within the gmp-4.#.# cd into the demos directory. Then compile pexpr.c by typing:
make pexpr
This is a simple expressions parser which serves as a simple interface to some of the basic GMP functions.
You can test it then like:
./pexpr «102394874783 * 23498748»;
Now you may interface with it using PHP’s exec() function.
- Copyright © 2001-2024 The PHP Group
- My PHP.net
- Contact
- Other PHP.net sites
- Privacy policy
gmp_init
Целое число или строка. Число, заданное строкой может быть десятичным, шестнадцатеричным или восьмеричным.
Основание системы счисления.
Основание может варьироваться от 2 до 62. Если основание 0 (по умолчанию), основание будет определено, исходя из первых символов: если первые два символа 0x или 0X , число будет интерпретировано как шестнадцатеричное, если первые два символа — 0b or 0B , предполагается двоичный, если первый символ «0», то как восьмеричное, в остальных случаях числа будут восприниматься как десятичные. Для оснований до 36 регистр игнорируется; буквы верхнего и нижнего регистра имеют одинаковое значение. Для оснований от 37 до 62 заглавные буквы представляют обычные от 10 до 35, а строчные буквы — от 36 до 61.
Возвращаемые значения
Примеры
Пример #1 Создание GMP числа
$a = gmp_init ( 123456 );
$b = gmp_init ( «0xFFFFDEBACDFEDF7200» );
?>?php
Примечания
Замечание:
Нет необходимости явно вызывать эту функцию, если требуется вставить целое число или строку на место GMP числа в GMP функциях, как например gmp_add() . Аргументы функций автоматически преобразуются в GMP числа, если такое преобразование требуется и оно возможно, по тем же правилам, что и в gmp_init() .
Смотрите также
- GMP::__construct() — Создает GMP-число
User Contributed Notes 7 notes
17 years ago
Here’s a way to parse a decimal (eg 3.25) into an integer and exponent:
if (preg_match(«/^[0-9]+\.[0-9]+$/»,$input)) <
//Input is a base-10 decimal. Multiply as necessary to remove the decimal
//point. Convert that to a gmp_resource, then decrement the exponent
//to compensate.
$pieces=explode(«.», $input); //Split at the d.p.
$input=»$pieces[0]$pieces[1]»; //Remove the decimal point.
$input=ltrim($input,’0′);
//Remove any leading zeros, or gmp_init will parse the number as octal.
if ($input==») < //Deal with "0.0" which would otherwise be ''.
$input=0;
>
$integer=gmp_init($input);
$ns_exponent=-strlen($pieces[1]);
//exponent = (-) the number of characters after the decimal point.
>
?>
12 years ago
Unless the base is 16, gpm_init will fail if the string begins with «0b».
> php -r ‘$v = gmp_init(«b83», 17); print(«$v\n»);’
> php -r ‘$v = gmp_init(«0b83», 17); print(«$v\n»);’
In may case, where I am explicitly specifying the base, the solution is to apply ltrim first:
> php -r ‘$v = gmp_init(ltrim(«0b83», «0»), 17); print(«$v\n»);’
12 years ago
I discovered that the gmp functions use [0-9a-f] up to base 16, but [0-9A-Za-z] (i.e. upper case first) from bases 17 to 62. This differs from most of the base-62 implementations I’ve found that tend to use lower case first.
17 years ago
Note: Leading zeros will make gmp_init parse this as octal.
Thus gmp_init(010) becomes 8.
$a=010; //8
$b=»010″ + 0; //10
$c=gmp_strval(gmp_init(010)); //8
$d=gmp_strval(gmp_init(«010»)); //8
This behaviour is inconsistent: either $d should equal $b, or
$b should equal $a.
1 year ago
Missing from the documentation: gmp_init() return false in case it failed to parse $num
var_dump ( gmp_init ( «» ));
// returns «bool(false)» and not a GMP object as hinted by the documentation, it also triggers a Warning «PHP Warning: gmp_init(): Unable to convert variable to GMP — string is not an integer in php shell code on line 1»
16 years ago
gmp_* functions don’t accept strings with a leading ‘+’:
echo gmp_strval ( gmp_init ( ‘+42’ )); #0
echo gmp_strval ( gmp_add ( ’42’ , ‘+42’ )); #42
echo bcadd ( ‘+42’ , ‘+42’ ); #84
?>
18 years ago
If you call a gmp_* function directly with an interger as parameter, this integer MUST NOT be 0:
The result is 1 0 3 (wrong)
In this case you have to use gmp_init():
The result is 1 2 3 (right)
Happy number crunching! 🙂
- Copyright © 2001-2024 The PHP Group
- My PHP.net
- Contact
- Other PHP.net sites
- Privacy policy