FPU到底是如何使用的呢?

[复制链接]
1736|16
 楼主| wangjiahao88 发表于 2016-4-22 20:49 | 显示全部楼层 |阅读模式
FPU到底是如何使用的呢?
是不是可以直接定义浮点运算,就算是FPU了?
按照这个道理来说,8BIT的也可以计算浮点数啊?
huangqi412 发表于 2016-4-24 22:26 来自手机 | 显示全部楼层
硬件浮点单元   就像51有8位硬件乘除法
huangqi412 发表于 2016-4-24 22:27 来自手机 | 显示全部楼层
你编译结果有相关指令就是用了硬件乘除法  你也可以通过加减移位来实现乘除
myidear 发表于 2016-4-25 09:02 | 显示全部楼层
huangqi412 发表于 2016-4-24 22:26
硬件浮点单元   就像51有8位硬件乘除法

51有硬件乘除法么?哪个芯片,我看看去
liutongda 发表于 2016-4-25 17:58 | 显示全部楼层
左右移位只能实现乘除2,乘除其他数据,有什么好的办法呢?
原味_郭 发表于 2016-4-26 10:51 | 显示全部楼层
有个FPU浮点运算单元,直接库函数使能了就好了。
dongbaohui 发表于 2016-4-26 15:38 | 显示全部楼层
myidear 发表于 2016-4-25 09:02
51有硬件乘除法么?哪个芯片,我看看去

51基本没有硬件乘法器的,FPU就更不用说了。只能其他地方进行优化了。
cnb12345 发表于 2016-4-26 16:25 | 显示全部楼层
l科科1987 发表于 2016-4-26 17:35 | 显示全部楼层
liutongda 发表于 2016-4-25 17:58
左右移位只能实现乘除2,乘除其他数据,有什么好的办法呢?

可以用大数算法试试。
Dennis-Zhou 发表于 2016-4-26 19:52 | 显示全部楼层
8 bit是肯定可以计算浮点的,但是速度估计是计算乘法的好几倍。
playergatsby 发表于 2016-4-27 15:44 | 显示全部楼层
Dennis-Zhou 发表于 2016-4-26 19:52
8 bit是肯定可以计算浮点的,但是速度估计是计算乘法的好几倍。

要想快,就要移位和查表,千万不要用浮点型。
叶覃 发表于 2016-4-30 22:20 | 显示全部楼层
l科科1987 发表于 2016-4-26 17:35
可以用大数算法试试。

什么是大树算法呢?我看网上说是字符串的乘除。
Dennis-Zhou 发表于 2016-5-22 12:11 | 显示全部楼层
playergatsby 发表于 2016-4-27 15:44
要想快,就要移位和查表,千万不要用浮点型。

乘法计算有时候不能移位和查表得,这个如何解决呢?
l科科1987 发表于 2016-5-22 20:54 | 显示全部楼层
dongbaohui 发表于 2016-4-26 15:38
51基本没有硬件乘法器的,FPU就更不用说了。只能其他地方进行优化了。

51就是看算法了,只要你算法优化的好,和有FPU差不多的。
playergatsby 发表于 2016-6-27 21:01 | 显示全部楼层
l科科1987 发表于 2016-5-22 20:54
51就是看算法了,只要你算法优化的好,和有FPU差不多的。

只能说速度快很多,和FPU相比,还是差距很大的。有浮点的芯片,一个浮点指令也就几个周期而已。
jouney316 发表于 2016-6-28 07:42 | 显示全部楼层
开启了FPU,也不意味着可以无限的浮点运算,这样功耗会增加很多的吧
 楼主| wangjiahao88 发表于 2016-7-7 16:08 | 显示全部楼层
开启了FPU 功耗不会增加很多……
您需要登录后才可以回帖 登录 | 注册

本版积分规则

500

主题

7585

帖子

31

粉丝
快速回复 在线客服 返回列表 返回顶部