从 int 转换为(16 位)__m128i
converting from int to (16-bit) __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 的向量)。
终于,我发现这个更新工作正常
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]);
谢谢大家
我有以下代码作为程序的一部分,但是当我编译它时出现以下错误:
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 的向量)。
终于,我发现这个更新工作正常
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]);
谢谢大家