我有一组0和1的集合,表示为最初用sample(c(0,1), n, replace=TRUE)创建的列表,其中n是二进制数的长度。我目前正在使用BCD转换器将二进制数转换为十进制数,如下所示:
BCD.to.Decimal <- function(binaryNumb)
{
binaryLength = length(binaryNumb)
decimalNumb = 0
for(i in 1:binaryLength)
{
if ( binaryNumb[i] == 1)
decimalNumb = decimalNumb + 2^(binaryLength - i)
}
decimalNumb
}我想使用GrayCode.To.Decimal转换器,它的工作与我的BCD.to.Decimal转换器相同,但使用格雷代码代替。
注意:速度对此很重要,我想以最有效的方式来做。我知道我的BCD转换器可能不是最有效的,它只是最简单的,如果你有一种更有效的方法来处理BCD转换,我也会感兴趣的。
什么是灰色代码?:代码
发布于 2013-11-29 03:03:51
这是我问题的简单解决方案,这个算法最终比最初出现的要简单得多。所使用的算法可以找到这里。
GrayCode.to.Decimal <- function(grayNumb)
{
binaryNumb = vector("numeric",length(grayNumb))
binaryNumb[1] = grayNumb[1]
for (i in 2:length(grayNumb))
{
binaryNumb[i] = xor(grayNumb[i], binaryNumb[i - 1])
}
return(Binary.to.Decimal(binaryNumb))
}此代码将将代码转换为二进制代码,然后可以使用二进制转换将其转换为十进制数。我选择使用注释部分中的flodel提供的代码。
Binary.to.Decimal <- function(binaryNumb)
{
L = length(binaryNumb)
sum(2L^(seq_along(binaryNumb)-1L) * rev(binaryNumb))
}发布于 2013-11-18 12:39:29
嗯,在这个Wiki页面上有一个转换算法,尽管是在c中,所以您必须移植它。
同样,在wiki页面上,有一个链接http://aggregate.org/MAGIC/#Gray%20Code%20Conversion,它列出了许多转换算法,其中大多数看起来很容易编码。
顺便说一句,哦,随便吧:GA::grey2binary和GA::binary2grey已经存在了。巴哈:-)
ETA -我很幸运通过Mr.Google找到了这个,但是总的来说,包sos是一个很好的R-搜索工具。
https://stackoverflow.com/questions/20038185
复制相似问题