bcdiv

(PHP 4, PHP 5, PHP 7)

bcdivDivision zweier Zahlen beliebiger Genauigkeit

Beschreibung

string bcdiv ( string $dividend , string $divisor [, int $scale = 0 ] )

Dividiert dividend durch divisor.

Parameter-Liste

dividend

Der Dividend in Stringform.

divisor

Der Divisor in Stringform.

scale

Dieser optionale Parameter kann benutzt werden, um die Anzahl der Nachkommastellen im Ergebnis festzulegen. Sie können mit Hilfe der bcscale()-Funktion auch einen globalen Vorgabewert für alle Funktionen festlegen.

Rückgabewerte

Gibt das Ergebnis der Division als String zurück. Wenn der Parameter divisor 0 ist, wird NULL zurückgegeben.

Beispiele

Beispiel #1 bcdiv()-Beispiel

<?php

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

?>

Siehe auch

  • bcmul() - Multiplikation zweier Zahlen beliebiger Genauigkeit

add a note add a note

User Contributed Notes 4 notes

up
5
Anonymous
7 years ago
The custom bcdiv function listed at the top of this page produces very different results from bcdiv, as it rounds instead of truncating the result. Consider the following:

<?php

function bcdiv_cust( $first, $second, $scale = 0 )
{
   
$res = $first / $second;
    return
round( $res, $scale );
}

echo
bcdiv('1','2','0') . " vs. " bcdiv_cust('1','2','0');  // prints '0 vs. 1'

?>
up
2
Gautam
10 years ago
<?php
//converting in to required precision of decimal points
$result= bcdiv(89.99999999997,2.57865741235478,2);
echo
"$result"// 34.90 result with 2 decimal points
?>
up
1
MM
10 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;
up
-1
cristianDOTzuddas]NOSPAM[gmailDOTcom
12 years ago
Decimal to binary conversion, using BC Math.
Note: this function is VERY slow if the decimal number is too big!

<?
function bc_decbin($dec_str) {
    if (strlen($dec_str)>0) {
        $bin_str = '';
        do {
            if (((int)$dec_str[strlen($dec_str)-1] % 2) === 0)
                $bin_str .= '0';
            else
                $bin_str .= '1';
           
            $dec_str = bcdiv($dec_str, '2');
        } while ($dec_str!='0');
       
        return strrev($bin_str);
    }
    else
        return null;
}
?>

-----
Cristian
www.CodeFlower.com
To Top