我有一个具有 16 位值的 __m128i 寄存器(向量 A),其内容为:
{100,26,26,26,26,26,26,100} // A Vector
现在我减去向量
{82,82,82,82,82,82,82,82}
随着指示
_mm_sub_epi16(a_vec,_mm_set1_epi16(82))
预期的结果应该是以下向量
{18,-56,-56,-56,-56,-56,-56,18}
但我明白了
{18,65480,65480,65480,65480,65480,65480,18}
如何解决向量被视为已签名的问题?
A Vector 是由以下指令创建的:
__m128i a_vec = _mm_srli_epi16(_mm_unpacklo_epi8(score_vec_8bit, score_vec_8bit), 8)