微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

visual-c-std :: isfinite在MSVC上

C 11和C 11标准定义了
std::isfinite
功能. Visual Studio 2012似乎并没有提供它作为的一部分
cmath或math.h,但是有amp_math.h
seems to provide this function.

isd是否与std :: isfinite可互换?该
文档并不涉及使用NAN调用时的行为
我没有一个VS编译器来测试这个.

解决方法

正如Marius已经指出的那样,来自amp_math.h的isfinite将用于C AMP,它是与CUDA或OpenCL类似的多核架构上的并行计算的MS扩展.而且由于此功能只能用于实际的AMP限制功能(通常是GPU内核),因此对您而言并不常用.

不幸VS 2012不支持C11数学和浮点控制功能.但是,一旦你认识到你在VC上实现了特殊的代码,你可以使用< float.h>中的_finite(或者更确切地说,_finite),这是至少VS 2003所支持的MS-secific功能.但是请记住,_finite只需要双倍,因此转换任何非双参数(尽管VC似乎没有适当的长双重),其所有的含义(而INF和安静的NaN应该被转换没有问题,m不知道在转换中的信号NaN上的陷阱是否也是直接调用std ::有限的).

VC的标准库有other such functions,因为缺乏C11 / C99支持(如_isnan等). (为什么他们拒绝在这功能前面删除那个下划线,并在_controlfp周围放置一个简单的< cfenv>包装器,从而更接近完成C 11的支持一个完全不同的问题.)

编辑:除此之外,检查INF和NaNs的直接方法也可能会起作用:

template<typename T> bool isfinite(T arg)
{
    return arg == arg && 
           arg != std::numeric_limits<T>::infinity() &&
           arg != -std::numeric_limits<T>::infinity();
}

但是,当然也有可能陷入信号NaN的同样的暗示(尽管我不得不承认,我不太熟悉信号NaNs和浮点异常的复杂性).

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐