PHP.mk документација

GMP функции

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

ref.gmp.php PHP.net прокси Преводот е вчитан
Оригинал на PHP.net
Патека ref.gmp.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + преведен приказ Кодовите, табелите и белешките остануваат читливи во истиот тек.
GMP функции

Референца за `ref.gmp.php` со подобрена типографија и навигација.

ref.gmp.php

GMP функции

Види Исто така

Повеќе математички функции може да се најдат во Математички проширувања section

Содржина

  • gmp_abs — Апсолутна вредност
  • gmp_add — Собирање броеви
  • gmp_and — Бинарно И
  • gmp_binomial — Пресметува биномен коефициент
  • gmp_clrbit — Бришење бит
  • gmp_cmp — Споредување броеви
  • gmp_com — Пресметува еден комплемент
  • gmp_div — Алијас на gmp_div_q
  • gmp_div_q — Делење броеви
  • gmp_div_qr — Делење броеви и добивање количник и остаток
  • gmp_div_r — Остаток од делењето на броеви
  • gmp_divexact — Точно делење на броеви
  • gmp_export — Експортирање во бинарен стринг
  • gmp_fact — Факториел
  • gmp_gcd — Пресметај GCD
  • gmp_gcdext — Пресметај GCD и множители
  • gmp_hamdist — Хеминг растојание
  • gmp_import — Увоз од бинарен стринг
  • gmp_init — Креирај GMP број
  • gmp_intval — Конвертирај GMP број во цел број
  • gmp_invert — Инверзија по модул
  • gmp_jacobi — Јакоби симбол
  • gmp_kronecker — Кронекер симбол
  • gmp_lcm — Пресметај LCM
  • gmp_legendre — Лежандров симбол
  • gmp_mod — Модуларна операција
  • gmp_mul — Множи броеви
  • gmp_neg — Негирај број
  • gmp_nextprime — Најди следниот прост број
  • gmp_or — Бинарно И
  • gmp_perfect_power — Проверка за совршен степен
  • gmp_perfect_square — Проверка за совршен квадрат
  • gmp_popcount — Број на население
  • gmp_pow — Подигни број на степен
  • gmp_powm — Подигни број на степен со модул
  • gmp_prob_prime — Провери дали бројот е „веројатно прост“
  • gmp_random — Случаен број
  • gmp_random_bits — Случаен број
  • gmp_random_range — Земи рамномерно избран цел број
  • gmp_random_seed — Постави го RNG семето
  • gmp_root — Земи го целобројниот дел од n-тиот корен
  • gmp_rootrem — Земи го целобројниот дел и остатокот од n-тиот корен
  • gmp_scan0 — Барај 0
  • gmp_scan1 — Барај 1
  • gmp_setbit — Постави бит
  • gmp_sign — Знак на бројот
  • gmp_sqrt — Пресметај квадратен корен
  • gmp_sqrtrem — Квадратен корен со остаток
  • gmp_strval — Претвори GMP број во стринг
  • gmp_sub — Одземи броеви
  • gmp_testbit — Тестирај дали е поставен бит
  • gmp_xor — Битови XOR

Белешки од корисници 2 забелешки

Испринтај ги сите преостанати податоци на покажувач на gz-датотека
пред 15 години
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.

<?php
// 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).

<?php
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.
richard-slater.co.uk
пред 22 години
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.

<?php
  function isBitSet($bitMask, $bitMap)
  {
    return (bool) gmp_intval(gmp_div(gmp_and($bitMask, $bitMap),$bitMask));
  }
?>
Навигација

Прелистувај сродни теми и функции.

На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.