[解決済み] floatを別の変数にコピーすると、両者は等しくなるのでしょうか?
2022-04-24 12:39:56
質問
を使用することは知っています。
==
を使用して浮動小数点型変数の等質性をチェックするのは良い方法とは言えません。ただ、次のような記述でそれを知りたいのです。
float x = ...
float y = x;
assert(y == x)
以降
y
からコピーされます。
x
というアサーションは真になるのでしょうか?
どのように解決するのですか?
また
assert(NaN==NaN);
kmdreko さんの指摘するような場合、x87-math では、80bit の浮動小数点が一時的にメモリに格納され、後でレジスタに格納されている値と比較されるような状況がありえます。
最小限の例として、gcc9.2 のコンパイル時に
-O2 -m32
:
#include <cassert>
int main(int argc, char**){
float x = 1.f/(argc+2);
volatile float y = x;
assert(x==y);
}
ゴッドボルト・デモ https://godbolt.org/z/X-Xt4R
は
volatile
を持たせるのに十分なレジスタープレッシャーをかけることができれば、おそらく省略可能でしょう。
y
を保存し、メモリから再ロードします(ただし、コンパイラを十分に混乱させ、比較を完全に省略することはできません)。
GCC FAQリファレンスを参照してください。
関連
-
[解決済み】なぜ、サイズ8の初期化されていない値を使用するのでしょうか?
-
[解決済み] Double vs. BigDecimal?
-
[解決済み] C++11では、標準化されたメモリモデルが導入されました。その意味するところは?そして、C++プログラミングにどのような影響を与えるのでしょうか?
-
[解決済み] なぜC++はPythonよりもstdinからの行の読み込みが遅いのですか?
-
[解決済み] なぜ、オブジェクトそのものではなく、ポインタを使用しなければならないのですか?
-
[解決済み] C++で仮想関数が必要な理由とは?
-
[解決済み] 除算を強制的に浮動小数点にするにはどうしたらいいですか?除算は0に切り捨てられ続けますか?
-
[解決済み] JavaScriptで浮動小数点数の精度を扱うには?
-
[解決済み】画像処理。コカ・コーラ缶」認識のためのアルゴリズム改良
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】getline()が何らかの入力の後に使用されると動作しない 【重複あり
-
[解決済み】C-stringを使用すると警告が表示される。"ローカル変数に関連するスタックメモリのアドレスが返される"
-
[解決済み] 非常に基本的なC++プログラムの問題 - バイナリ式への無効なオペランド
-
[解決済み】「std::operator」で「operator<<」にマッチするものがない。
-
[解決済み】Visual C++で "Debug Assertion failed "の原因となる行を見つける。
-
[解決済み】リンカーエラーです。"リンカ入力ファイルはリンクが行われていないため未使用"、そのファイル内の関数への未定義参照
-
[解決済み] 解決済み] `pthread_create' への未定義の参照 [重複] [重複
-
[解決済み] 数値定数の前にunqualified-idを付けて、数値を定義することを期待する。
-
[解決済み】エラー。引数リストに一致するコンストラクタのインスタンスがない
-
[解決済み】IEEE754のNaN値に対して、すべての比較がfalseを返す根拠は何ですか?