gpt4 book ai didi

c++ - 上交所加成产生垃圾

转载 作者:太空宇宙 更新时间:2023-11-04 12:05:46 24 4
gpt4 key购买 nike

我正在尝试比较 SSE float[4] 添加与标准 float[4] 添加。我试过这个:

#include <iostream>
#include <vector>

struct Point4
{
Point4()
{
data[0] = 0;
data[1] = 0;
data[2] = 0;
data[3] = 0;
}

float data[4];
};

static float SumOfDifferences(const Point4& a, const Point4& b)
{
// This function only returns the sum of the sum of the components
float sumValues = 0.0f;
for(unsigned int i = 0; i < 4; ++i)
{
sumValues += a.data[i] + b.data[i];
}
return sumValues;
}

void Standard()
{
Point4 a;
a.data[0] = 1;
a.data[1] = 2;
a.data[2] = 3;
a.data[3] = 4;

Point4 b;
b.data[0] = 1;
b.data[1] = 6;
b.data[2] = 3;
b.data[3] = 5;

float total = 0.0f;
for(unsigned int i = 0; i < 1e6; ++i)
{
total += SumOfDifferences(a, b);
}

std::cout << "total: " << total << std::endl;
}

void Vectorized()
{
typedef int v4sf __attribute__ (( vector_size(4*sizeof(float)) ));

v4sf a;
float* aPointer = (float*)&a;
aPointer[0] = 1; aPointer[1] = 2; aPointer[2] = 3; aPointer[3] = 4;

v4sf b;
float* bPointer = (float*)&b;
bPointer[0] = 1; bPointer[1] = 2; bPointer[2] = 3; bPointer[3] = 4;

float total = 0.0f;
v4sf result;
float* resultPointer = (float*)&result;

for(unsigned int i = 0; i < 1e6; ++i)
{
result = a + b; // Vectorized operation

// Sum the components of the result (this is done with the "total += " in the Standard() loop
for(unsigned int component = 0; component < 4; ++component)
{
total += resultPointer[component];
}
}

std::cout << "total: " << total << std::endl;
}

int main()
{

// Standard();

Vectorized();

return 0;
}

但 Vectorized() 函数的输出为“inf”。当我逐步使用调试器时,“结果”的值似乎是垃圾(我希望它们是 (0, 4, 0, 1) )。我哪里出错了?

最佳答案

尝试 typedef float v4sf __attribute__ (( vector_size(4*sizeof(float)) ));
结果是 2e+07。

关于c++ - 上交所加成产生垃圾,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12183806/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com