PHP 5.4.31 Released

gmp_init

(PHP 4 >= 4.0.4, PHP 5)

gmp_initGMP 数を作成する

説明

GMP gmp_init ( mixed $number [, int $base = 0 ] )

整数または文字列から GMP 数を生成します。

パラメータ

number

整数値あるいは文字列。文字列表現には、 十進数か十六進数、あるいは八進数を使用可能です。

base

基数。

基数には 2 から 36 までの値を指定することができます。 基数を 0 (デフォルト値) にすると、最初の文字に応じて実際の基数を決定します。 最初の二文字が 0x あるいは 0X の場合は十六進数、それ以外で最初の文字が "0" の場合は八進数、 それ以外の場合は十進数となります。

返り値

PHP 5.5 以前は GMP 数リソースを、そして PHP 5.6 以降は GMP オブジェクトを返します。

変更履歴

バージョン 説明
5.3.2 base が拡張され、2 から 36 までだったのが 2 から 62 までおよび -2 から -36 までとなりました。
4.1.0 オプションのパラメータ base が追加されました。

注意

注意:

PHP 5.3.2 以降で拡張された基数を使うには、 PHP を GMP 4.2.0 以降と組み合わせてコンパイルしなければなりません。

例1 GMP 数の作成

<?php
$a 
gmp_init(123456);
$b gmp_init("0xFFFFDEBACDFEDF7200");
?>

注意

注意:

gmp_add() のような GMP 関数において、GMP 数を指定するところに整数または文字列を使用したい場合には、 この関数をコールする必要はありません。この場合、変換が必要な場合には、 gmp_init() と同様の方法で関数の引数は自動的に GMP 数に変換されます。

add a note add a note

User Contributed Notes 6 notes

up
0
marcus at synchromedia dot co dot uk
2 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.
up
0
karl dot debisschop at pearson dot com
3 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");'

Resource id #4

> php -r '$v = gmp_init("0b83", 17); print("$v\n");'

[nothing prints]

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");'

Resource id #4
up
0
charlie at oblivion dot cz
7 years ago
gmp_* functions don't accept strings with a leading '+':
<?php
echo gmp_strval(gmp_init('+42'));      #0
echo gmp_strval(gmp_add('42', '+42')); #42
echo bcadd('+42', '+42');              #84
?>
up
0
php at richardneill dot org
7 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.
}
?>
up
0
php at richardneill dot org
7 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.
up
0
thomas dot hebinck at digionline dot de
8 years ago
If you call a gmp_* function directly with an interger as parameter, this integer MUST NOT be 0:

for($i=-1;$i<=1;$i++) {  echo gmp_strval(gmp_add(2,gmp_mul(1,$i))) . ' ';  }

The result is 1 0 3 (wrong)

In this case you have to use gmp_init():

for($i=-1;$i<=1;$i++) {  echo gmp_strval(gmp_add(2,gmp_mul(1,gmp_init($i)))) . ' ';  }

The result is 1 2 3 (right)

Happy number crunching! :-)
To Top