2

我正在尝试使用比较操作的结果添加到 SSE 变量。我刚刚意识到,_mm_cmplt_ps如果结果为真,则在使用该操作时,它会返回一个 NAN,因为 0xffffffff 无法表示,这对我没有用:

__m128 va;
__m128 vb;
__m128 result =_mm_set1_ps(0.0f);
vb = _mm_cmplt_ps(va,vb);
result = _mm_add_ps(result,vb);  // problem is that I would like to convert vb to 1.0's and 0.0's
4

1 回答 1

8

您可以将比较掩码应用于 1.0 值的向量,例如

__m128  va, vb;
__m128  vcmp = _mm_cmplt_ps(va, vb);
__m128  vresult = _mm_and_ps(_mm_set1_ps(1.0f), vcmp);
于 2013-04-04T10:59:59.257 回答