
質問です。
C++でプログラムを実行したところ,
ごく希に-1.#IND00 という値が入っている変数がありました.
デバッグのため,値が-1.#IND00 となったらデバッグプリントを表示したいのですが、
どのようにやればよいでしょうか?
環境は.net 2003です。
ちなみに、
float fx = 0.0;
float r;
・・・・rに計算結果を格納
if(r == -2.0f/fx || r == 2.0f/fx || r == fx/fx || r == -fx/fx){
}としてみたところダメでした。
どなたかよろしくお願いします。
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
INDっては初めて見たので調べてみたのですが、infともNaNとも違うものなんでしょうか?
> if(r == -2.0f/fx || r == 2.0f/fx || r == fx/fx || r == -fx/fx){
if (_isnan(r) || _isinf(r))
ではダメですか?
あと、調べていてみつかったのですが vc++の場合
fpclassifyはありませんが _fpclassという関数があって、
これが同じような判定をしてくれるようです。
/* IEEE recommended functions */
_CRTIMP double __cdecl _copysign (double, double);
_CRTIMP double __cdecl _chgsign (double);
_CRTIMP double __cdecl _scalb(double, long);
_CRTIMP double __cdecl _logb(double);
_CRTIMP double __cdecl _nextafter(double, double);
_CRTIMP int __cdecl _finite(double);
_CRTIMP int __cdecl _isnan(double);
_CRTIMP int __cdecl _fpclass(double);
#define _FPCLASS_SNAN 0x0001 /* signaling NaN */
#define _FPCLASS_QNAN 0x0002 /* quiet NaN */
#define _FPCLASS_NINF 0x0004 /* negative infinity */
#define _FPCLASS_NN 0x0008 /* negative normal */
#define _FPCLASS_ND 0x0010 /* negative denormal */
#define _FPCLASS_NZ 0x0020 /* -0 */
#define _FPCLASS_PZ 0x0040 /* +0 */
#define _FPCLASS_PD 0x0080 /* positive denormal */
#define _FPCLASS_PN 0x0100 /* positive normal */
#define _FPCLASS_PINF 0x0200 /* positive infinity */
positive normal でも negative normal でも±0でもないのを
引っ掛ければよい?
参考URL:http://msdn2.microsoft.com/ja-jp/library/39s1cck …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
至急です! マクロ定義で #defi...
-
C言語を実行すると-infが出てき...
-
2次方程式の解を求めるプログ...
-
-1.#IND00と出てしまうのですが...
-
c言語のコンパイルエラー canno...
-
C言語の型による処理速度の違い
-
doubleの変数にintとintの割り...
-
C言語の複素数についてです。
-
DWORDの警告
-
物体が往復する動きを作りたい
-
浮動小数点の定数
-
3次方程式の求解プログラム(...
-
-1.#IND00 をデバッグしたい
-
2分法で方程式の複数の解を自...
-
数値を指数部と仮数部に分離したい
-
c言語で、繰り返し文の中で、0....
-
linux RedHatでC言語
-
C言語で台形公式を使った二重積...
-
c言語
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
C言語を実行すると-infが出てき...
-
doubleの変数にintとintの割り...
-
float型とdouble型の変数の違い...
-
c言語で、繰り返し文の中で、0....
-
至急です! マクロ定義で #defi...
-
C 開放してるのにエラー(doubl...
-
C言語の型による処理速度の違い
-
C言語 関数プロトタイプ宣言の...
-
float と double
-
ラグランジュの補間法のCプログ...
-
C言語のプログラムで#include<m...
-
c言語のコンパイルエラー canno...
-
2分法で方程式の複数の解を自...
-
2次方程式の解を求めるプログ...
-
C言語で台形公式を使った二重積...
-
Cプログラミングの問題です。ニ...
-
物体が往復する動きを作りたい
-
関数におけるif文とreturn文に...
-
doubleは常に%lfとするべきなのか
おすすめ情報