ホームページ php教程 php手册 PHP_php の基本における不正確な浮動小数点計算、比較、丸めの解決策

PHP_php の基本における不正確な浮動小数点計算、比較、丸めの解決策

May 16, 2016 am 09:00 AM
丸め 浮動小数点数

浮動小数点計算結果の比較
浮動小数点計算の例は次のとおりです。

コードをコピー コードは次のとおりです。

$a = 0.2 0.7;
$b = 0.9;
var_dump($a == $b);

出力される結果は次のとおりです: bool(false)。つまり、ここでの 0.2 0.7 という計算結果は 0.9 と等しくなく、明らかに常識に反しています。

この問題に関して、公式 PHP マニュアルには次のように書かれていました: 明らかに、0.2 のような単純な小数は、多少の精度を失わずに内部バイナリ形式に変換することはできません。これは、有限の桁数で特定の小数を正確に表現することが不可能であるという事実と関係しています。たとえば、10 進数の 1/3 は 0.3333333… となります。

上記の変数を倍精度形式で出力します:

コードをコピー コードは次のとおりです。

$a = 0.2 0.7;
$b = 0.9;
printf("%0.20f", $a);
echo '
';
printf("%0.20f", $b);

出力結果は次のとおりです。

コードをコピー コードは次のとおりです。

0.89999999999999991118
0.90000000000000002220

明らかに、ここでは浮動小数点データとして精度の一部が失われており、完全に正確であることはできません。したがって、浮動小数点数の結果が最後の桁まで正確であると決して信じないでください。また、2 つの浮動小数点数が等しいかどうかを比較しないでください。これは PHP の問題ではなく、コンピュータの内部浮動小数点数処理の問題であることに注意してください。 C や JAVA などの言語でも同じ問題が発生します。

したがって、2 つの浮動小数点数を比較するには、比較する前に必要な精度の範囲内で浮動小数点数を制御する必要があるため、bcadd() 関数を使用して浮動小数点数を加算し、精度を (文字列に) 変換します。 p>

コードをコピー コードは次のとおりです。

var_dump(bcadd(0.2,0.7,1) == 0.9); // 出力: bool(true)

浮動小数点数の丸め

記事「PHP 丸め関数 ceil および Floor」には、次の例があります。

コードをコピー コードは次のとおりです。

echo ceil(2.1/0.7); // 出力: 4
?>

浮動小数点数の計算に関する上記の説明を経て、これは不正確な浮動小数点数の計算結果が原因であることがわかりました。

コードをコピー コードは次のとおりです。

printf("%0.20f", (2.1/0.7)); // 出力: 3.00000000000000044409
?>

浮動小数点数の計算に関する上記の説明の後、これは不正確な浮動小数点数の計算結果が原因であることがわかりました。そのため、round() 関数を使用してそれに対処できます。

コードをコピー コードは次のとおりです。

echo ceil(round((2.1/0.7),1) );
?>

round() 関数は指定された精度に従って丸めますが、小数点以下 1 桁を保持しても丸め結果には影響しません。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPで文字列を10進数に変換する方法 PHPで文字列を10進数に変換する方法 Mar 22, 2023 pm 03:22 PM

PHP は、Web 開発の分野で広く使用されている強力なプログラミング言語です。非常に一般的な状況の 1 つは、文字列を 10 進数に変換する必要があることです。これはデータ処理を行うときに非常に便利です。この記事では、PHPで文字列を10進数に変換する方法を説明します。

PHPの浮動小数点数の丸め方法 PHPの浮動小数点数の丸め方法 Mar 21, 2024 am 09:21 AM

この記事では、PHP の浮動小数点数の四捨五入方法について詳しく解説しますが、非常に実践的だと編集者が考えたので、参考として共有しますので、この記事を読んで何かを得ることができれば幸いです。 PHP 浮動小数点丸めの概要 コンピュータでは、浮動小数点数は小数点とそれに続く指数として表されますが、多くの場合、限られた桁数の近似値で格納されます。浮動小数点数を特定の精度に丸める必要がある場合、それを行う方法がいくつかあります。方法 1.round() 関数round() 関数は、浮動小数点数を最も近い整数に丸めます。浮動小数点数とオプションの精度パラメータを受け入れます。例: $num=1.55;echoround($num);//出力: 2echoround($num,1)

strconv.FormatFloat 関数を使用して浮動小数点数を文字列に変換します strconv.FormatFloat 関数を使用して浮動小数点数を文字列に変換します Jul 25, 2023 am 11:45 AM

strconv.FormatFloat 関数を使用して、浮動小数点数を文字列に変換します。Go 言語では、出力またはストレージのニーズに応じて、浮動小数点数を文字列型に変換する必要がよくあります。 strconv パッケージは Go 言語で提供されており、その中の FormatFloat 関数は浮動小数点数を文字列型に変換できます。 FormatFloat 関数は 3 つのパラメータを取ります。f は変換される浮動小数点数を表し、fmt は形式を表し、prec は保持する小数点以下の桁数を表します。このうち、fパラメータは

PHP 浮動小数点計算エラーの原因と回避方法 PHP 浮動小数点計算エラーの原因と回避方法 Feb 27, 2024 pm 06:33 PM

人気のサーバーサイド スクリプト言語である PHP では、浮動小数点計算を実行するときに精度の低下や計算エラーの問題が頻繁に発生し、プログラムの精度と安定性に影響を与える可能性があります。この記事では、PHP 浮動小数点計算エラーの原因を調査し、いくつかの回避戦略を提案し、参考として具体的なコード例を示します。 1. PHP 浮動小数点計算エラーの理由 コンピューターでは、浮動小数点数は 2 進数形式で表現されますが、2 進数ではすべての 10 進数を正確に表現できないため、浮動小数点数が不正確になります。

PHPで割り算と丸めを行う方法 PHPで割り算と丸めを行う方法 Mar 21, 2023 pm 02:52 PM

コンピューター プログラミングの発展に伴い、日常のプログラミング作業で除算や四捨五入を実行する必要があるシナリオに遭遇することがあります。 PHP プログラミングでは、この目的を達成するためにさまざまな方法を使用できます。

PHP BCMath の徹底解説: 数値演算の可能性を解き放つ PHP BCMath の徹底解説: 数値演算の可能性を解き放つ Feb 23, 2024 am 09:10 AM

:1. BCMath の概要 BCMath は、PHP に組み込まれた拡張ライブラリであり、特に大きな整数および浮動小数点数の演算を処理するために使用されます。加算、減算、乗算、除算、平方、平方根などのさまざまな数学演算を実行するための豊富な関数を提供し、複数の基底でのデジタル表現をサポートします。 2. BCMath の利点 PHP がネイティブに提供する算術演算子や関数と比較して、BCMath には主に次の利点があります: 高精度: BCMath の演算結果はより多くの有効桁数を保持できるため、大きな数値を含む計算に役立ちます。より広い範囲: BCMath は、PHP のネイティブ データ型よりも大きな数値を処理できるため、オーバーフローや精度の低下の問題を回避できます。より豊富な機能: BCMath が提供する

C# の Math.Round 関数を使用して浮動小数点数を丸めます C# の Math.Round 関数を使用して浮動小数点数を丸めます Nov 18, 2023 pm 02:17 PM

C# で Math.Round 関数を使用して浮動小数点数を丸めるには、特定のコード例が必要です。C# プログラミング言語では、浮動小数点数を丸める必要がある場合があります。現時点では、Math.Round 関数を使用してこの機能を実現できます。 Math.Round 関数は、数学的計算に使用される C# の組み込み関数であり、その主な機能は、指定された浮動小数点数を四捨五入することです。 Math.Round 関数の一般的な形式は次のとおりです。 Math.Round(doub

PHPで文字列をfloatに変換する方法 PHPで文字列をfloatに変換する方法 Mar 27, 2024 pm 12:48 PM

文字列を浮動小数点数に変換するのは PHP の一般的な操作であり、組み込みメソッドを使用して実行できます。文字列を浮動小数点数に正常に変換するには、まず文字列が有効な浮動小数点形式であることを確認してください。以下では、PHP で文字列を浮動小数点数に変換する方法を詳しく説明し、具体的なコード例を示します。 1. (float) キャストを使用する PHP で文字列を浮動小数点数に変換する最も簡単な方法は、キャストを使用することです。強制的に変換するには、文字列の前に (float) を追加します。これにより、PHP が自動的に変換します。

See all articles