你怎么用__m256d
?
假设我想在具有 3-64 位精度组件(、、和)_mm256_add_pd
的简单类上使用英特尔 AVX 指令。使用它的正确方法是什么?Vector3
double
x
y
z
由于x
和是该类的成员y
, _我可以用变量声明它们吗?z
Vector3
union
__m256d
union Vector3
{
struct { double x,y,z ; } ;
__m256d _register ; // the Intel register?
} ;
那我可以去吗:
Vector3 add( const Vector3& o )
{
Vector3 result;
result._register = _mm256_add_pd( _register, o._register ) ; // add 'em
return result;
}
这行得通吗?还是我需要申报临时工,
Vector3 add( const Vector3& o )
{
__m256d d1 = *(__m256d*)(&x) ; // ? Cast to __m256d?
__m256d d2 = *(__m256d*)(&o.x) ; // ? Cast to __m256d?
__m256d result = _mm256_add_pd( d1, d2 ) ; // add 'em
return Vector3( result ) ; // make a ctor that accepts __m256d?
}
编辑
我想出了这个例子,
#include <stdio.h>
#include <intrin.h>
int main()
{
__m256d a, b, res;
for( int i = 0; i < sizeof(__m256d)/sizeof(double); i++ )
{
a.m256d_f64[i] = i ;
b.m256d_f64[i] = 2*i ;
}
// Perform __4__ adds.
res = _mm256_add_pd(a, b);
for( int i = 0; i < sizeof(__m256d)/sizeof(double); i++ )
{
printf("%f + %f = %f\n", a.m256d_f64[i], b.m256d_f64[i], res.m256d_f64[i]);
}
puts("");
}
我想现在的问题是,是否会 自动_mm256_add_pd
执行加载操作,或者如果我不将我的寄存器声明为接近使用它们的地方的本地人,会不会出现问题?(我怕酒店房间/书桌抽屉类型问题)__m256d
编辑2:
我尝试__m256
在我相当大的项目中添加一个寄存器,我得到了一大堆
错误 C2719:“值”:带有 __declspec(align('32')) 的形式参数将不会对齐
错误,它让我相信你不能在一个类中保留__m256
寄存器,而是应该将它们声明为本地人?