Преобразование из int в (16-разрядное) __m128i

У меня есть следующий код как часть программы, но когда я компилирую его, я получаю следующую ошибку:

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) но, к сожалению, он используется только для 32-битных элементов, в то время как у меня есть 16-битные элементы (вектор размером 8).

1 ответ

Решение

Наконец, я обнаружил, что это обновление работает правильно

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]);

Спасибо вам всем

Другие вопросы по тегам