相关疑难解决方法(0)

__m128i变量是零吗?

如何测试__m128i变量在SSE-2和更早版本的处理器上是否具有任何非零值?

c c++ sse intel simd

11
推荐指数
2
解决办法
3596
查看次数

检查XMM寄存器是否全部为零

有没有办法检查__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);
Run Code Online (Sandbox Code Playgroud)

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

基于Harold的评论,这是解决方案:


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

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

c++ simd intrinsics

10
推荐指数
1
解决办法
2745
查看次数

如何检查AVX内在__m256的inf

检查AVX内在函数__m256(8的向量float)是否包含任何内容的最佳方法是什么inf?我试过了

__m256 X=_mm256_set1_ps(1.0f/0.0f);
_mm256_cmp_ps(X,X,_CMP_EQ_OQ);
Run Code Online (Sandbox Code Playgroud)

但相比之下true.请注意,此方法将找到nan(与之比较false).所以一种方法是检查X!=nan && 0*X==nan:

__m256 Y=_mm256_mul_ps(X,_mm256_setzero_ps());   // 0*X=nan if X=inf
_mm256_andnot_ps(_mm256_cmp_ps(Y,Y,_CMP_EQ_OQ),
                 _mm256_cmp_ps(X,X,_CMP_EQ_OQ));
Run Code Online (Sandbox Code Playgroud)

但是,这看起来有点冗长.有更快的方法吗?

c c++ sse intrinsics avx

3
推荐指数
1
解决办法
1437
查看次数

标签 统计

c++ ×3

c ×2

intrinsics ×2

simd ×2

sse ×2

avx ×1

intel ×1