c语言定点小数除法,一步步解剖FOC之定点小数运算!

原标题:一步步解剖FOC之定点小数运算!

一步步解剖FOC之定点小数运算!

许多MCU 芯片只支持整数运算,如果要在这些芯片上进行小数运算,定点运算应该是最佳选择了;此外即使芯片支持浮点数,定点小数运算也是最佳的速度选择。所谓定点小数运算,就是将小数点位置固定,用整数的方式来进行运算;由于小数点的位置是固定的,所以就没有必要储存它。既然没有储存小数点的位置,那么计算机当然就不知道小数点的位置,所以这个小数点的位置是我们写程序的人自己需要牢记的。那么,如何将小数表示成整数呢?

处理器整数以二进制形式存储,首先要了解如何将小数转换成二进制!假定MCU 是16位,因最高位是符号位,那么有效位就只有15位(不考虑符号则16位)。即小数点之后可以有0~15 位。我们把小数点之后有n位叫做Qn,例如小数点之后有12位叫做Q12 格式的定点小数,而Q0就是我们所说的整数:

3b4e9d30d0ccd2328ae11187e3b98ec4.png

以Q12 格式为例,Q12 的正数的最大值是0111.111111111111,第一个0是符号位,后面的数都是1,那么这个数是十进制的多少呢? 请看下面的运算:

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值