硬汉嵌入式论坛

 找回密码
 立即注册
查看: 1510|回复: 2
收起左侧

关于float的数值比较

[复制链接]

38

主题

82

回帖

196

积分

初级会员

积分
196
发表于 2018-11-18 09:34:40 | 显示全部楼层 |阅读模式
最近在看armfly的dsp文档,里面似乎没有讲到两个浮点数如何比较,arm的库里面似乎也没看到有类似的函数。

1. 尾数是不存最高位的,因为一般是1。那如果要表示0怎么办?因为“第24位”尾数说不定就是1呀~~~
2. 例如同样是1,IEEE754标准的浮点都会有不同的表示(只要指数位是0即可),也就是实际内存的数值是不一样的。C语言在比较时会怎么处理呢?
3. 还有一种情况是精度问题,网上有些说用 if(_fabs( value ) < EPSILON) 来判断value 是否为0(EPSILON据说是float的最小步进值),我不太理解浮点数表达0为何会有精度问题?

欢迎大家拍砖!!
回复

使用道具 举报

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
106771
QQ
发表于 2018-11-18 10:26:37 | 显示全部楼层
问题1和2
你用MDK写个0.0f看看单精度四字节的表达和0.0时双精度八字节的表达值

问题3
浮点数无法精准比较,因为本身的表达方式在保存二进制数值时就不是精确的。

回复

使用道具 举报

38

主题

82

回帖

196

积分

初级会员

积分
196
 楼主| 发表于 2018-11-18 17:48:37 | 显示全部楼层
eric2013 发表于 2018-11-18 10:26
问题1和2
你用MDK写个0.0f看看单精度四字节的表达和0.0时双精度八字节的表达值

float32 和 float64的0.0f 内存上面显示都是0... TAT
回复

使用道具 举报

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

本版积分规则

QQ|小黑屋|Archiver|手机版|硬汉嵌入式论坛

GMT+8, 2024-5-5 16:24 , Processed in 0.189631 second(s), 25 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表