主题: 反向查询表
查看单个帖子
旧 2019-12-10, 20:30   #1
poster
高级会员
 
注册日期: 2019-11-21
帖子: 3,006
声望力: 66
poster 正向着好的方向发展
帖子 反向查询表

这是前一个SO问题的跟进问题 。现在,我将其扩展为8位。我使用Amro的解决方案将位扩展为8位。现在,我想以相反的方式将8位转换回单位。

我只设法实现for循环的反向使用,这在应用程序中花费了很多时间。

有更快的方法吗?



回答:

由于您使用的是我上次建议的解决方案,因此,假设您有一个由这些“位”组成的N×8矩阵,其中每一行代表一个8位二进制数。要以矢量化方式转换为十进制,其操作非常简单:

禄 M = randi([0 1], [5 8]) %# 5 random 8-bit numbers M = 1 0 1 0 1 0 1 1 0 1 1 0 1 1 1 0 1 1 0 1 1 0 1 1 1 0 0 0 0 1 1 0 1 0 0 1 0 1 1 0禄 d = bin2dec( num2str(M) ) d = 171 110 219 134 150 替代解决方案:

d = sum( bsxfun(@times, M, power(2,7:-1:0)), 2)

更多&回答...
poster 当前离线   回复时引用此帖