1

プログラムの一部として次のコードがありますが、コンパイルすると次のエラーが発生します。

cannot convert ‘int’ to ‘__m128i {aka __vector(2) long long int}’ in assignment

コードの場所:

int t;
int s;
__m128i *array;
__m128i vector;

posix_memalign ((void **) &array, BYTE_ALIGNMENT, n * m * sizeof(__m128i) );

int l=0;
for (int i=0; i<n; i++)
{
  for (int j=0; j<m; j++)
  {
    array[l] = (condition) ? t : s;   // fill the array elements with s or t 
    l++;
  }
}
vector = _mm_load_si128( &array[index]);

問題はこの行にあります

array[l] = (condition) ? t : s;

命令を見つけました__m128i _mm_cvtsi32_si128(int a)が、残念ながら、16 ビット要素 (サイズ 8 のベクトル) があるのに対し、32 ビット要素のみに使用されます。

4

1 に答える 1

0

最後に、このアップデートが正常に機能していることを確認しました

int t;
int s;
int16_t *array;
__m128i vector;

posix_memalign ((void **) &array, BYTE_ALIGNMENT, n * m * sizeof(int16_t) );

int l=0;
for (int i=0; i<n; i++)
{
  for (int j=0; j<m; j++)
  {
    array[l] = (condition) ? t : s;   // fill the array elements with s or t 
    l++;
  }
}
vector = _mm_load_si128( (__m128i*)&array[index]);

皆様ありがとうございました

于 2015-01-31T22:32:33.603 に答える