PHP 7.4.8 Released!

bcscale

(PHP 4, PHP 5, PHP 7)

bcscaleすべての BC 演算関数におけるデフォルトのスケールを設定/取得する

説明

bcscale ( int $scale ) : int

デフォルトのスケールを設定します。これ以降、 BC 演算関数で明示的にスケールを指定しなかった場合にこの値を使用します。

bcscale ( void ) : int

現在のスケールを取得します。

パラメータ

scale

スケール。

返り値

スケールを設定する場合は、古いスケールを返します。 そうでない場合、現在のスケールを返します。

変更履歴

バージョン 説明
7.3.0 bcscale() は、現在のスケールを取得するために 使えるようになりました。スケールを設定する場合は、古いスケールの値を返します。 これより前のバージョンでは、 scale の指定が強制され、 bcscale() は常に TRUE を返していました。

例1 bcscale() の例

<?php

// デフォルトのスケールを 3 とします
bcscale(3);
echo 
bcdiv('105''6.55957'); // 16.007

// これは、bcscale() を使用せずにおなじ結果を得ます
echo bcdiv('105''6.55957'3); // 16.007

?>

add a note add a note

User Contributed Notes 8 notes

up
15
sicerwork at aliyun dot com
3 years ago
Executing bcsacle() will change the scale value of fpm.conf, not only the current process.
up
17
mwgamera at gmail dot com
12 years ago
These functions DO NOT round off your values. No arbitrary precision libraries do it this way. It stops calculating after reaching scale of decimal places, which mean that your value is cut off after scale number of digits, not rounded. To do the rounding use something like this:
<?php
       
function bcround($number, $scale=0) {
               
$fix = "5";
                for (
$i=0;$i<$scale;$i++) $fix="0$fix";
               
$number = bcadd($number, "0.$fix", $scale+1);
                return   
bcdiv($number, "1.0",    $scale);
        }
?>
up
6
ravenswd at gmail dot com
8 years ago
Simple, easy way to remove excess trailing zeros using rtrim:
<php>
  // $total is the result of a bcmath calculation
  if ( strpos($total, '.') !== false ):
    $total = rtrim($total, '0');
    $total = rtrim($total, '.');
  endif;
</php>
up
6
herslyadam at gmail dot com
6 years ago
edited bcround function with negative number support:
<?php
function bcround($number, $scale=0) {
    if(
$scale < 0) $scale = 0;
   
$sign = '';
    if(
bccomp('0', $number, 64) == 1) $sign = '-';
   
$increment = $sign . '0.' . str_repeat('0', $scale) . '5';
   
$number = bcadd($number, $increment, $scale+1);
    return
bcadd($number, '0', $scale);
}
?>
up
2
nemesarial at gmail dot com
5 years ago
To remove trailing zeros when using large bcscale number can be done by casting to float when ready to display the number.

<?php
bcscale
(15);
$a=123.456;
$b=0.123;

$_ab=bcadd($a,$b);
echo
$_ab;
// 123.579000000000000

$ab = (float)$_ab;
echo
$ab;
// 123.579

?>
up
2
invincible at limitedintelligence dot com
14 years ago
If you don't set the default scale, be careful when you're chaining together several BC math functions - since by default, these functions will round off your values, losing accuracy very quickly:

<?php
$a
= 1.234
$b
= 2.345
$c
= 7.890

$ab
= bcmul($a,$b);           // 2
$abc = bcmul($ab,$c);

echo
$abc;                 // 15
?>

... compare with the answer you get when you use more decimal places:

<?php
$a
= 1.234
$b
= 2.345
$c
= 7.890

bcscale
(15);
$ab = bcmul($a,$b);           // 2.893730
$abc = bcmul($ab,$c);

echo
$abc;                 // 22.83152970
?>
up
1
yan dot uniko dot 102 at gmail dot com
15 days ago
Does not work with big scale values, but accept INT as type, but can not process the max INT value, by example for calculate the cube root:

<?php

echo pow(1331, 1/3); // 11 (11^3=1331)
echo bcpow(1331, bcdiv(1, 3, PHP_INT_MAX)); // 1 ??
echo bcdiv(1, 3, PHP_INT_MAX); // 0 ??
up
-5
rastislav dot bostik at bwd21 dot cz
8 years ago
Previously stated one liner trailing 0 removing using rtrim() works fine except following class of subcases:

<?php
echo rtrim('100.0000', '0.'); // 1 instead 100
echo rtrim('1230.00000000', '0.'); // 123 instead 1230
?>

What seems to be working to me is using regular expression replacement. Althought it`s probably not that fast as rtrim(), I hope it should be more reliable:

<?php
function removeFloatNumStringZeroTrailer($input) {
   
$patterns = array('/[\.][0]+$/','/([\.][0-9]*[1-9])([0]*)$/');
   
$replaces = array('','$1');
    return
preg_replace($patterns,$replaces,$input);
}

echo
removeFloatNumStringZeroTrailer('100.0000'); // says 100
echo removeFloatNumStringZeroTrailer('1230.00000000'); // says 1230
?>
To Top