这是一个相当基本的问题,但我有点糊涂了。我在一个图书馆工作,它使用复数。到目前为止,我在MacOS10.8和Ubuntu10.04下使用了我的实现(通过在Man上使用llvm,在Ubuntu下使用gcc )。昨天,我在另一台机器上试用了icpc (icc/2013.3),而复杂的数字紧固部分失败了。
我用这个简单的例子解决了这个问题:
#include <iostream>
#include <complex>
using namespace std;
int main(int argc, char* argv[])
{
std::complex<double> tmpcmplxnumber(26.0,0.0);
cout << "Number: " << tmpcmplxnumber << endl;
std::complex<double> newcmplxnumber = 1.0 - tmpcmplxnumber;
cout << "New Number: " << newcmplxnumber << endl;
cout << "Sqrt of New Number: " << sqrt(newcmplxnumber) << endl;
return 0;
}gcc输出(两台机器):
Number: (26,0)
New Number: (-25,-0)
Sqrt of New Number: (0,-5)icpc产出:
Number: (26,0)
New Number: (-25,0)
Sqrt of New Number: (0,5)如果我得到正确的通知gcc执行ISO标准,所以结果应该是正确的(所有的签名-零的东西.因此,icpc的实现是“错误的”,还是存在针对该特定问题的标志?
更新我知道,这两个结果是有效的,从数学角度来看,但我需要gcc的结果时,也使用icpc。
发布于 2013-05-24 08:51:02
sqrt通常是非负平方根,它是数学中的“平方根”符号。
根据(草案)标准(26.4.8,复杂超车),
如果参数是负数实数,则返回的值位于正虚轴上。
看来gcc在这里是有错的。
https://stackoverflow.com/questions/16730716
复制相似问题