У меня есть следующий код, как часть программы, но когда я скомпилировать его я получаю следующее сообщение об ошибке:преобразование из 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).
Вы пытались использовать явное приведение типа '__m128i'? –
Вы имеете в виду? массив [l] = (условие)? (__m128i) t: (__m128i) s; Ошибка: Ошибка: невозможно преобразовать между различными значениями вектора – MROF
Вы ищете что-то вроде: '_mm_set1_epi16()' – Mysticial