- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经使用 DeBruijn 算法对 64 位进行了位扫描正向/反向扫描,但无法存档 128 位,__uint128_t。有什么解决办法吗?提前致谢!
仅供引用,使用 DeBruijn 算法向前/向后扫描 64 位的代码:
constexpr std::uint32_t
bitScanForward<std::uint64_t>(std::uint64_t n) noexcept {
constexpr std::uint32_t seq[] = {
0, 47, 1, 56, 48, 27, 2, 60, 57, 49, 41, 37, 28, 16, 3, 61,
54, 58, 35, 52, 50, 42, 21, 44, 38, 32, 29, 23, 17, 11, 4, 62,
46, 55, 26, 59, 40, 36, 15, 53, 34, 51, 20, 43, 31, 22, 10, 45,
25, 39, 14, 33, 19, 30, 9, 24, 13, 18, 8, 12, 7, 6, 5, 63};
return seq[((n ^ (n - 1)) * 0x03f79d71b4cb0a89ULL) >> 58];
}
constexpr std::uint32_t
bitScanReverse<std::uint64_t>(std::uint64_t n) noexcept {
n |= n >> 1;
n |= n >> 2;
n |= n >> 4;
n |= n >> 8;
n |= n >> 16;
n |= n >> 32;
constexpr std::uint32_t seq[] = {
0, 47, 1, 56, 48, 27, 2, 60, 57, 49, 41, 37, 28, 16, 3, 61,
54, 58, 35, 52, 50, 42, 21, 44, 38, 32, 29, 23, 17, 11, 4, 62,
46, 55, 26, 59, 40, 36, 15, 53, 34, 51, 20, 43, 31, 22, 10, 45,
25, 39, 14, 33, 19, 30, 9, 24, 13, 18, 8, 12, 7, 6, 5, 63};
return seq[(n * 0x03f79d71b4cb0a89ULL) >> 58];
}
最佳答案
可以使 64 位 BitScanReverse
适应 128 位情况,但这不会非常高效,因为 128 位乘法运算相对昂贵,正如@Marc Glisse 在他的评论中已经指出的那样。
不过,您可以使用 64 位 BitScanReverse
/BitScanForward
作为构建 block 一个可移植的 128 位 bsf
/bsr
:
#include<stdint.h>
#include<stdio.h>
int bitScanReverse(uint64_t n);
int bitScanForward(uint64_t n);
int bsr_u128 (__uint128_t u) {
uint64_t hi = u >> 64;
uint64_t lo = u;
int hi_neq_0 = (hi != 0);
uint64_t hi_or_lo = hi_neq_0 ? hi : lo;
int bsr_hi_or_lo = bitScanReverse(hi_or_lo);
return bsr_hi_or_lo + (hi_neq_0 << 6);
}
int bsf_u128 (__uint128_t u) {
uint64_t hi = u >> 64;
uint64_t lo = u;
int lo_eq_0 = (lo == 0);
uint64_t hi_or_lo = lo_eq_0 ? hi : lo;
int bsf_hi_or_lo = bitScanForward(hi_or_lo);
return bsf_hi_or_lo + (lo_eq_0 << 6);
}
int bitScanReverse(uint64_t n){
n |= n >> 1;
n |= n >> 2;
n |= n >> 4;
n |= n >> 8;
n |= n >> 16;
n |= n >> 32;
static int seq[] = {
0, 47, 1, 56, 48, 27, 2, 60, 57, 49, 41, 37, 28, 16, 3, 61,
54, 58, 35, 52, 50, 42, 21, 44, 38, 32, 29, 23, 17, 11, 4, 62,
46, 55, 26, 59, 40, 36, 15, 53, 34, 51, 20, 43, 31, 22, 10, 45,
25, 39, 14, 33, 19, 30, 9, 24, 13, 18, 8, 12, 7, 6, 5, 63};
return seq[(n * 0x03f79d71b4cb0a89ULL) >> 58];
}
int bitScanForward(uint64_t n){
static int seq[] = {
0, 47, 1, 56, 48, 27, 2, 60, 57, 49, 41, 37, 28, 16, 3, 61,
54, 58, 35, 52, 50, 42, 21, 44, 38, 32, 29, 23, 17, 11, 4, 62,
46, 55, 26, 59, 40, 36, 15, 53, 34, 51, 20, 43, 31, 22, 10, 45,
25, 39, 14, 33, 19, 30, 9, 24, 13, 18, 8, 12, 7, 6, 5, 63};
return seq[((n ^ (n - 1)) * 0x03f79d71b4cb0a89ULL) >> 58];
}
int main(){
__uint128_t t = 1;
__uint64_t hi, lo;
int i;
for (i=0;i<129;i++){
lo = t;
hi = t>>64;
printf("%3i %016lX %016lX bsr = %3i bsf = %3i\n",i,hi,lo,bsr_u128(t),bsf_u128(t));
t=t+t;
}
t = 1;
printf("\nThe zero input case is similar in the 64 bit and the 128 bit case:\n\n");
for (i=0;i<65;i++){
lo = t;
printf("%3i %016lX bsr = %3i bsf = %3i\n",i,lo,bitScanReverse(t),bitScanForward(t));
t=t+t;
}
return 0;
}
在 x86 上,这会产生相当高效的代码,例如 (gcc -O3 -m64 -march=nehalem):
bsf_u128:
xor eax, eax
test rdi, rdi
cmove rdi, rsi
sete al
sal eax, 6
lea rsi, [rdi-1]
xor rsi, rdi
movabs rdi, 285870213051386505
imul rsi, rdi
shr rsi, 58
add eax, DWORD PTR seq.31934[0+rsi*4]
ret
为了测试代码,在不同位置设置了一个位。输出是:
$ ./a.exe
0 0000000000000000 0000000000000001 bsr = 0 bsf = 0
1 0000000000000000 0000000000000002 bsr = 1 bsf = 1
2 0000000000000000 0000000000000004 bsr = 2 bsf = 2
....
62 0000000000000000 4000000000000000 bsr = 62 bsf = 62
63 0000000000000000 8000000000000000 bsr = 63 bsf = 63
64 0000000000000001 0000000000000000 bsr = 64 bsf = 64
65 0000000000000002 0000000000000000 bsr = 65 bsf = 65
....
126 4000000000000000 0000000000000000 bsr = 126 bsf = 126
127 8000000000000000 0000000000000000 bsr = 127 bsf = 127
128 0000000000000000 0000000000000000 bsr = 0 bsf = 127
The zero input case is similar in the 64 bit and the 128 bit case:
0 0000000000000001 bsr = 0 bsf = 0
1 0000000000000002 bsr = 1 bsf = 1
2 0000000000000004 bsr = 2 bsf = 2
....
62 4000000000000000 bsr = 62 bsf = 62
63 8000000000000000 bsr = 63 bsf = 63
64 0000000000000000 bsr = 0 bsf = 63
高效的 128 位 bsf
/bsr
的另一个解决方案是回收这个问题中讨论的想法: Counting the number of leading zeros in a 128-bit integer
关于c++ - 如何向前和向后扫描 __uint128_t(128 位)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52657851/
使用 C# (VS2008) 和 WIA - 扫描到 TIFF 格式; 当我在平板或文档进纸器上使用扫描仪扫描 1 页时,该方法执行没有任何问题。当我将多个表单加载到进纸器时,扫描第一页后执行停止(保
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
给定一个列表 :: [(Foo, Bar)] ,我想在 Bar 上执行 scanl1 s,但保留他们的 Foo “标签”。 IE。我想要一个类型为 :: [(a, b)] -> ([b] -> [c]
我有一个 HBase 表,我需要从多个范围获取结果。例如,我可能需要从不同范围获取数据,例如第 1-6 行、100-150..... 我知道对于每次扫描,我可以定义开始行和停止行。但是如果我有 6 个
我看到了这段代码。我是 C 语言的新手,所以请原谅。 while下面的循环将继续循环 if i = SIZE,则 == 是无关紧要的,因为它根本不会被执行。如果 i 小于 SIZE 那么 scanf(
这是一个关于编译过程的相当技术性的问题ABAP代码。 我知道有ABAP解析器和扫描器类实际上调用 C 内核函数来完成实际工作。然后就是代码补全事务的功能,该事务以 ABAP 列表或 XML 的形式返回
给定以下程序: int main(){ float x = non_det_float(); float y = NAN; if (isnan(y) && x == 1.0f){
我在工作中使用由供应商生成的二维码。实际上我需要通过网站手动记录所有这些项目。 QR 码包含所有这些数据,所以我想创建一个自动执行操作的应用。 例如,二维码表示“AAA|BBB|CCC|123”。我想
我有一个像这样的字符串:@"ololo width: 350px jijiji width:440px ... text=12... "我想将@"width: "之后的所有数字替换为280。所以在扫描
我在玩 scanf 时遇到了一个小问题……更具体地说,我想读取整个输入,然后忽略其余部分。让我告诉你我的意思: #include int main(void) { int number_of
我正在使用 matlab/octave 创建扫描/线性调频信号,我的结束信号似乎以错误的频率结束。我该如何修复它,以便信号以正确的频率结束。 PS:我不能在 Octave 音程中使用 chirp 命令
我正在寻找一个可以扫描 WiFi 网络并打印所有 SSID 的程序。我试过 scapy 但我失败了。我正在使用 pyCharm 编辑器。 我试过这段代码: from scapy.all import
概述 Linux 完全是用于大型服务器的最流行和最安全的操作系统之一。尽管它被广泛使用,但它仍然容易受到网络攻击。黑客以服务器为目标,窃取有价值的信息。所以迫切需要开发反黑客方法来应对安全漏洞和恶
如何获取我的 Git 存储库的某种统计信息? 我目前在 BitBucket 中托管 Git 存储库,想查找以下详细信息: 提交总数 使用过的编程语言 每种编程语言的总代码行数 您认为这可以实现吗?还是
我目前正在使用以下代码来扫描作为申请表的一部分上传的文件: $safe_path = escapeshellarg($dir . $file); $command = '/usr/bin/clamsc
我在存储库中有十几个项目。存储库结构如下所示: / ------- + project1 +------- trunk +------- tags +----
我正在使用 Dynamo DB 并想使用过滤器扫描一个表。例如,是否可以使用全局二级索引仅扫描表中的特定行? 最佳答案 这不可能!扫描始终针对基表中的所有行,当您扫描索引表作为响应时,您将仅获得该索引
我正在尝试从这里使用 SOLStumbler:Accessing & Using the MobileWiFi.framework扫描 wifi 网络。我知道苹果不支持这一点,但它是用于教育目的和实验
我知道 iPhone 蓝牙功能在 3.0 之前无法通过 SDK 访问,但是需要多长时间才能找到该区域的设备?它取决于该区域的设备数量吗?如果范围内有大约 5 个设备,扫描发现所有设备是否需要花费 30
我正在使用Elasticsearch 6.2,并且有一些查询可以分析大量文档。我正在对索引内的一个字段进行排序。 Elasticsearch检查10.000个文档(默认配置值),然后将它们分页返回。
我是一名优秀的程序员,十分优秀!