将范围转换为位数组
我正在用 C# 编写一段对时间要求严格的代码,它要求我将定义包含范围的两个无符号整数转换为位字段。 例如:
uint x1 = 3;
uint x2 = 9;
//defines the range [3-9]
// 98 7654 3
//must be converted to: 0000 0011 1111 1000
它可能有助于以相反的顺序可视化位。
此范围的最大值是运行时给出的参数,我们将其称为 max_val
。 因此,位域变量应定义为大小等于 max_val/32 的 UInt32
数组:
UInt32 MAX_DIV_32 = max_val / 32;
UInt32[] bitArray = new UInt32[MAX_DIV_32];
给定由变量 x1
定义的范围> 和 x2
,执行此转换的最快方法是什么?
I'm writing a time-critical piece of code in C# that requires me to convert two unsigned integers that define an inclusive range into a bit field. Ex:
uint x1 = 3;
uint x2 = 9;
//defines the range [3-9]
// 98 7654 3
//must be converted to: 0000 0011 1111 1000
It may help to visualize the bits in reverse order
The maximum value for this range is a parameter given at run-time which we'll call max_val
. Therefore, the bit field variable ought to be defined as a UInt32
array with size equal to max_val/32
:
UInt32 MAX_DIV_32 = max_val / 32;
UInt32[] bitArray = new UInt32[MAX_DIV_32];
Given a range defined by the variables x1
and x2
, what is the fastest way to perform this conversion?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(6)
尝试这个。 计算必须用全 1 填充的数组项的范围,并通过迭代该范围来完成此操作。 最后在两个边框上设置项目。
也许代码不是 100% 正确,但这个想法应该可行。
刚刚测试了一下,发现三个bug。 开始索引处的计算需要 mod 32,而结束索引处的 32 必须是 31,并且是逻辑与,而不是赋值来处理开始索引和结束索引相同的情况。 应该是相当快的。
只需在阵列上均匀分布 x1 和 x2 对其进行基准测试即可。
Windows XP 主机上的 Intel Core 2 Duo E8400 3.0 GHz、MS VirtualPC 和 Server 2003 R2。
又一优化 x % 32 == x & 31 但我无法衡量性能提升。 由于我的测试仅进行了 10,000,000 次迭代,因此波动相当高。 而且我在 VirtualPC 中运行,这使得情况变得更加不可预测。
Try this. Calculate the range of array items that must be filled with all ones and do this by iterating over this range. Finally set the items at both borders.
May be the code is not 100% correct, but the idea should work.
Just tested it and found three bugs. The calculation at start index required a mod 32 and at end index the 32 must be 31 and a logical and instead of a assignment to handle the case of start and end index being the same. Should be quite fast.
Just benchmarked it with equal distribution of x1 and x2 over the array.
Intel Core 2 Duo E8400 3.0 GHz, MS VirtualPC with Server 2003 R2 on Windows XP host.
One more optimazation x % 32 == x & 31 but I am unable to meassure a performance gain. Because of only 10.000.000 iterations in my test the fluctuations are quite high. And I am running in VirtualPC making the situation even more unpredictable.
我将 BitArray 中的整个位范围设置为 true 或 false 的解决方案:
My solution for setting a whole range of bits in a BitArray to true or false:
你可以尝试:
You could try:
是否有理由不使用 System.Collections.BitArray 类而不使用 UInt32[]? 否则,我会尝试这样的事情:
Is there a reason not to use the System.Collections.BitArray class instead of a UInt32[]? Otherwise, I'd try something like this:
我很无聊,尝试使用
char
数组进行操作,并使用Convert.ToUInt32(string, int)
从基数转换为uint
2.一个简单的基准测试表明,我的方法比 Angrey Jim 的方法快大约 5%(即使您用位移位替换第二个 Pow)。
如果满足以下条件,则可能是最容易转换为生成
uint
数组的方法:上限太大,无法放入单个int
中。 这有点神秘,但我相信它有效。I was bored enough to try doing it with a
char
array and usingConvert.ToUInt32(string, int)
to convert to auint
from base 2.A simple benchmark shows that my method is about 5% faster than Angrey Jim's (even if you replace second Pow with a bit shift.)
It is probably the easiest to convert to producing a
uint
array if the upper bound is too big to fit into a singleint
. It's a little cryptic but I believe it works.尝试这个:
Try this: