どのように使用します__m256d
か?
3〜64ビット精度のコンポーネント(、、、および)を_mm256_add_pd
持つ単純なクラスでIntelAVX命令を使用したいとします。これを使用する正しい方法は何ですか?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:'value':__declspec(align( '32'))を含む正式なパラメーターは整列されません
エラー、それはあなたがクラス内にレジスタを保持することはできないと私に信じさせます__m256
、代わりにそれらはローカルとして宣言されるべきですか?