10

有没有办法检查__m128i变量中的所有位/字节/字等是否为 0?
在我的应用程序中,我必须检查__m128i变量中包含的所有整数是否为零。我必须提取它们并分别比较它们吗?


编辑:

我现在正在做的是:

int next = 0;
do{
    //some code

    next = idata.m128i_i32[0] + idata.m128i_i32[1] + idata.m128i_i32[2] + idata.m128i_i32[3];
}while(next > 0);

我需要的是检查是否idata全为零,而不必访问每个单独的元素,如果它们是则退出循环......


根据哈罗德的评论,这是解决方案:

__m128i idata = _mm_setr_epi32(i,j,k,l);
do{
    //some code
}while( !_mm_testz_si128(idata, idata) );

如果每个 DW 的所有低位idata都为 0,这将退出循环......谢谢哈罗德!

4

2 回答 2

9

_mm_testz_si128 是 SSE4.1,在某些 CPU(例如 Intel Atom、AMD Phenom)上不受支持

这是一个与 SSE2 兼容的变体

inline bool isAllZeros(__m128i xmm) {
    return _mm_movemask_epi8(_mm_cmpeq_epi8(xmm, _mm_setzero_si128())) == 0xFFFF;
}
于 2012-04-20T16:49:48.773 回答
4

就像 Paul R 对我原来的帖子发表的评论一样:

“您不需要为 的第二个参数初始化一个虚拟参数PTEST,也就是说,_mm_testz_si128(idata, _mm_set1_epi32(0xFFFF))您可以只针对自身测试一个值。”

ptest用一条指令完成整个工作。

这有帮助。

于 2012-12-05T12:44:04.990 回答