本文介绍了如何检查位值是否等于1?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个正在运行的OpenCL内核。如何检查变量中选定位置的位是否等于1?

例如,我发现在C#中可以使用代码like thisuint转换为包含位的字符串:

// Here we will store our bit

string bit;

// Unsigned integer that will be converted

uint hex = 0xfffffffe;

// Perform conversion and store our string containing bits

string str = uint2bits(hex);

// Print all bits "11111111111111111111111111111110"

Console.WriteLine(str);

// Now get latest bit from string

bit = str.Substring(31, 1);

// And print it to console

Console.WriteLine(bit);

// This function converts uint to string containing bits

public static string uint2bits(uint x) {
    char[] bits = new char[64];
    int i = 0;
    while (x != 0) {
        bits[i++] = (x & 1) == 1 ? '1' : '0';
        x >>= 1;
    }
    Array.Reverse(bits, 0, i);
    return new string(bits);
}

如何像上面的代码一样制作内核内部?

__kernel void hello(global read_only uint* param) {

/*

Do something with "param"

...

*/

int bit;
int index = 31;

/*

Store bit value ("0" or "1") at variable "bit"

...

*/

if (bit == 1) {

// ...

} else {

// ...

}

// Or maybe something more easy to check a bit value at "index" in "param" ... ?

}

在哪里可以了解更多有关这方面的信息?

推荐答案

您可以通过使用1<<b进行掩码,并将结果与零进行比较来检查数字中的位b设置为1还是设置为0:

static bool isBitSet(uint n, uint b) {
    return (n & (1U << b)) != 0;
}
1 << b的二进制数值由第b位置中的单个1组成,从后面开始从零开始计数,其他所有位置均为零。当您使用按位AND运算符&将此掩码应用于n时,您会得到一个数字n位,所有其他位置均为零。因此,当nb位设置为零时,整个操作的结果为零,否则为非零值。

这篇关于如何检查位值是否等于1?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-21 06:51