PHP Doku:: Division zweier Zahlen beliebiger Genauigkeit - function.bcdiv.html

Verlauf / Chronik / History: (1) anzeigen

Sie sind hier:
Doku-StartseitePHP-HandbuchFunktionsreferenzMathematische ErweiterungenBCMath Arbitrary Precision MathematicsBC Math Funktionenbcdiv

Ein Service von Reinhard Neidl - Webprogrammierung.

BC Math Funktionen

<<bccomp

bcmod>>

bcdiv

(PHP 4, PHP 5)

bcdivDivision zweier Zahlen beliebiger Genauigkeit

Beschreibung

string bcdiv ( string $left_operand , string $right_operand [, int $scale ] )

Dividiert left_operand durch right_operand.

Parameter-Liste

left_operand

Der linke Operand in Stringform.

right_operand

Der rechte Operand 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 right_operand 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


5 BenutzerBeiträge:
- Beiträge aktualisieren...
Anonymous
26.09.2010 19:05
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'

?>
no at answer dot com
5.07.2008 22:06
If you don't have bcmath installed and you need to use bcdiv() with a defined precision / scale you may need this function:

if( !function_exists( "bcdiv" ) )
{
    function bcdiv( $first, $second, $scale = 0 )
    {
        $res = $first / $second;
        return round( $res, $scale );
    }
}
MM
18.01.2008 12:29
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;
Gautam
29.08.2007 16:56
<?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
?>
cristianDOTzuddas]NOSPAM[gmailDOTcom
24.07.2005 14:10
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



PHP Powered Diese Seite bei php.net
The PHP manual text and comments are covered by the Creative Commons Attribution 3.0 License © the PHP Documentation Group - Impressum - mail("TO:Reinhard Neidl",...)