0

我是 C++ 编程的初学者,我的任务是在 C++ 中实现定点数学运算。在这里,我正在尝试实现一个函数 isnan() 如果数字不是数字则返回 true,否则将返回 false。

测试文件

#include "fixed_point_header.h"
int main()
{
fp::fixed_point<long long int, 63> a=fp::fixed_point<long long int, 63>::positive_infinity(); // will assign positive infinity value to a from an function from header 
fp::fixed_point<long long int, 63> b=fp::fixed_point<long long int, 63>::negative_infinity(); // will assign positive infinity value to b from an function from header 
float nan=fp::fixed_point<long long int, 63>::isnan(a,b);
printf( "fixed point nan value  == %f\n", float (nan));
} 

在标题中,如果添加了正无穷大值和负无穷大值,我想做类似于下面显示的代码,isnan 函数应该返回 1,否则返回 0。

头文件

#include fixed_point_header
static fp::fixed_point<FP, I, F> isnan (fp::fixed_point<FP, I, F> x,fp::fixed_point<FP, I, F> y){
/*if ( x + y ) happens, ie. x and y are infinities
      {
 should return 1; }
       else {
 should return 0; }
      } */

谁能告诉如何进行?或者如何解决这个范式

4

1 回答 1

0

我正在尝试实现一个函数 isnan() 如果数字不是数字则返回 true,否则将返回 false。

这很简单;定义一个保留值来表示nan(就像你对无穷大一样),并与之比较:

bool isnan(fixed_point x) {
    return x == fixed_point::nan();
}

如果添加了正无穷和负无穷值,我想做一些类似于下面显示的代码,isnan 函数应该返回 1 else 0

加法运算符有责任检查输入并nan在适当时返回:

fixed_point operator+(fixed_point x, fixed_point y) {
    if (x == fixed_point::nan() || y == fixed_point::nan()) {
        return nan;
    }
    if (x == fixed_point::positive_infinity()) {
        return y == fixed_point::negative_infinity() ? fixed_point::nan() : x;
    }
    // and so on
}

然后测试main变为:

bool nan = fixed_point::isnan(a+b);
于 2013-05-13T13:39:15.693 回答