电子产业
数字化服务平台

扫码下载
手机洽洽

  • 微信小程序

    让找料更便捷

  • APP

    随时找料

    即刻洽谈

    点击下载PC版
  • 公众号

    电子元器件

    采购信息平台

  • 移动端

    生意随身带

    随时随地找货

  • 华强商城公众号

    一站式电子元器件

    采购平台

  • 芯八哥公众号

    半导体行业观察第一站

基于ARM的除法运算优化策略(2)

来源:-- 作者:-- 浏览:395

标签:

摘要:下面将更加偏重于从数学和理论的角度分析,把重复除法转换成乘法运算。 下面来区分精确数学意义上的除法和整型除法运算: ◇n/d,即整数n被分成整数d份,结果趋向于O(与C语言相同);◇n%d,即n被d除之后的余数,就是n--d(n/d);◇n/d=n·d-1,即真正数学意义上的n被d除。 当使用整型除法时,

下面将更加偏重于从数学和理论的角度分析,把重复除法转换成乘法运算。


下面来区分精确数学意义上的除法和整型除法运算:

◇n/d,即整数n被分成整数d份,结果趋向于O(与C语言相同);

◇n%d,即n被d除之后的余数,就是n--d(n/d);

◇n/d=n·d-1,即真正数学意义上的n被d除。


当使用整型除法时,最容易估算d-1值的方法是计算232/d。然后,就可以估算n/d为:

(n(232/d))/232 (1)


在执行n的乘法时,需要精确到64位。对于这种方法,会出现如下问题:

◇为了计算232/d,由于一个unsigned int类型的数据放不下232,编译器要使用64位long long类型的数,而且必须指定除法为(1 ull<<32)/d。这种64位的除法比32位的除法执行起来要慢得多。

◇如果d碰巧是1,那么232/d就不再适合于un—signed int数据类型。


上面的做法似乎很好,而且解决了这两个问题。那么,再来看一下用(232一1)/d代替232/d。

s=0xffffffff ul/d (2

型号 厂商 价格
EPCOS 爱普科斯 /
STM32F103RCT6 ST ¥461.23
STM32F103C8T6 ST ¥84
STM32F103VET6 ST ¥426.57
STM32F103RET6 ST ¥780.82
STM8S003F3P6 ST ¥10.62
STM32F103VCT6 ST ¥275.84
STM32F103CBT6 ST ¥130.66
STM32F030C8T6 ST ¥18.11
N76E003AT20 NUVOTON ¥9.67
Baidu
map