PHPerKaigi 2025

bcdiv

(PHP 4, PHP 5, PHP 7, PHP 8)

bcdiv2つの任意精度数値で除算を行う

説明

bcdiv(string $num1, string $num2, ?int $scale = null): string

num1num2 で除算します。

パラメータ

num1

被除数を表す文字列。

num2

割る数を表す文字列。

scale
This parameter is used to set the number of digits after the decimal place in the result. If null, it will default to the default scale set with bcscale(), or fallback to the value of the bcmath.scale INI directive.

戻り値

除算結果を文字列で返します。 num20 の場合は null を返します。

エラー / 例外

This function throws a ValueError in the following cases:

  • num1 or num2 is not a well-formed BCMath numeric string.
  • scale is outside the valid range.

This function throws a DivisionByZeroError exception if num2 is 0.

変更履歴

バージョン 説明
8.0.0 scale は、nullable になりました。

例1 bcdiv() の例

<?php

echo bcdiv('105', '6.55957', 3); // 16.007

?>

参考

  • bcmul() - 2つの任意精度数値の乗算を行う

add a note

User Contributed Notes 1 note

up
0
MM
17 years ago
Perhaps some one can find useful this function to compute the modular inverse of a integer (extended euclidean algorithm):

function invmod($a,$b) {
$n=$b;
$x=0; $lx=1; $y=1; $ly=0;
while ($b) {
$t=$b;
$q=bcdiv($a,$b,0);
$b=bcmod($a,$b);
$a=$t;
$t=$x; $x=bcsub($lx,bcmod(bcmul($q,$x),$n)); $lx=$t;
$t=$y; $y=bcsub($ly,bcmod(bcmul($q,$y),$n)); $ly=$t;
}
if (bccomp($lx,0) == -1)
$lx=bcadd($lx,$n);
return $lx;
}

// verify

$n="2447995268898324993537772139997802321";
$t="64941057316178801556773346239351236811";
$m="123456789";
$i=invmod($t,$n);
// (t*m)*inv(t) is m
echo bcmod(bcmul(bcmod(bcmul($t,$m),$n),$i),$n) == $m;
To Top