8958|9

6423

帖子

16

TA的资源

版主

楼主
 

ARM汇编实现“1”位计数 [复制链接]

           你是否有过对变量中“1”位的计数需求呢?有时候需要对若干变量中的“1”进行计数。如果单纯的进行移位与那效率就太低了。对一个word移位三十二次再进行与然后比较加计数,看过一回反汇编,对一个word进行“1”位计数要250+条指令周期。下面介绍一个用汇编实现的arm“1”位计数高效代码。
      3位分组计算:把32位字分成3位的组,每一组的和是两位大小的数,并行计算这些3位组,然后用对数方式加起来。
     这个操作一共占用10个周期,加两个常数建立周期。
   
此帖出自编程基础论坛

最新回复

多谢赐教,,,  详情 回复 发表于 2015-4-22 20:17

赞赏

1

查看全部赞赏

点赞 关注(2)
个人签名training
 

回复
举报

6423

帖子

16

TA的资源

版主

来自 10楼
 
  1. UINT32 bit1count(UINT32 n)

  2. {

  3.          UINT32 t;

  4.     UINT32 m = 0x49249249;



  5.     t = n & (m << 1);

  6.     n = n - (t >> 1);

  7.     t = n & (m >> 1);

  8.     n = n + t;



  9.     m = 0xc71c71c7;

  10.     n = n + (n >> 3);

  11.     n = n & m;



  12.     n = n + (n >> 6);

  13.     n = n + (n >> 12);

  14.     n = n + (n >> 24);

  15.     n = (n & 0x3f);

  16.         

  17.          return n;

  18. }
复制代码
C语言版来啦

此帖出自编程基础论坛
 
个人签名training
 
 

回复

21

帖子

1

TA的资源

一粒金砂(中级)

沙发
 
如果按8bit分为一组然后去查表呢?是不是更快?我只要查4次。内存占用也还好,也就256字节。
此帖出自编程基础论坛

点评

可以写个c看一下反汇编有多少条指令能够做完这件事情  详情 回复 发表于 2015-4-20 22:33
你算算呢,你需要移四次位,至少做三次与,关键是你的查表,你要遍历你的表,这个指令不少啊,遍历四次表,还要做加法,想想多得就不少,肯定不会更快  详情 回复 发表于 2015-4-20 22:33
 
 
 

回复

6423

帖子

16

TA的资源

版主

板凳
 
zouguolvyi 发表于 2015-4-20 19:08
如果按8bit分为一组然后去查表呢?是不是更快?我只要查4次。内存占用也还好,也就256字节。

你算算呢,你需要移四次位,至少做三次与,关键是你的查表,你要遍历你的表,这个指令不少啊,遍历四次表,还要做加法,想想多得就不少,肯定不会更快
此帖出自编程基础论坛

点评

char Table[256] = {0, 1, 1, 2, 1, 2, 2, 3,..........8}; // 0, 1, 2, 3, 4, 5, 6, 7,..........255 int Get1Bits(int nSmble) { int nCounts = 0; for(int i=0; i < 32; i+=8) { nCounts +  详情 回复 发表于 2015-4-21 11:03
 
个人签名training
 
 

回复

6423

帖子

16

TA的资源

版主

4
 
zouguolvyi 发表于 2015-4-20 19:08
如果按8bit分为一组然后去查表呢?是不是更快?我只要查4次。内存占用也还好,也就256字节。

可以写个c看一下反汇编有多少条指令能够做完这件事情
此帖出自编程基础论坛

点评

其实你对汇编的了解还不够啊。  详情 回复 发表于 2015-4-21 11:05
 
个人签名training
 
 

回复

21

帖子

1

TA的资源

一粒金砂(中级)

5
 
白丁 发表于 2015-4-20 22:33
你算算呢,你需要移四次位,至少做三次与,关键是你的查表,你要遍历你的表,这个指令不少啊,遍历四次表,还要做加法,想想多得就不少,肯定不会更快

char Table[256] =
        {0, 1, 1, 2, 1, 2, 2, 3,..........8};
//         0, 1, 2, 3, 4, 5, 6, 7,..........255

int Get1Bits(int nSmble)
{
        int nCounts = 0;

        for(int i=0; i < 32; i+=8)
        {
                  nCounts += Table[((unsigned char)(nSmble >> i))]
        }

   return nCounts;
}

此帖出自编程基础论坛

点评

[attachimg]195421[/attachimg]  详情 回复 发表于 2015-4-21 16:11
 
 
 

回复

21

帖子

1

TA的资源

一粒金砂(中级)

6
 
白丁 发表于 2015-4-20 22:33
可以写个c看一下反汇编有多少条指令能够做完这件事情

其实你对汇编的了解还不够啊。
此帖出自编程基础论坛
 
 
 

回复

6423

帖子

16

TA的资源

版主

7
 
zouguolvyi 发表于 2015-4-21 11:03
char Table[256] =
        {0, 1, 1, 2, 1, 2, 2, 3,..........8};
//         0, 1, 2, 3, 4, 5, 6, 7,..........255

int Get1Bits(int nSmble)
{
        int nCounts = 0;

        for(int i=0; i < 32; i+=8)
        {
                  nCounts += Table[((unsigned char)(nSmble >> i))]
        }

   return nCounts;
}


此帖出自编程基础论坛
 
个人签名training
 
 

回复

21

帖子

1

TA的资源

一粒金砂(中级)

8
 
多谢赐教,,,
此帖出自编程基础论坛

点评

谈不上谈不上,我对汇编也不熟  详情 回复 发表于 2015-4-22 20:43
 
 
 

回复

6423

帖子

16

TA的资源

版主

9
 

谈不上谈不上,我对汇编也不熟
此帖出自编程基础论坛
 
个人签名training
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表