不能直接用 == 比较浮点数,因为其二进制近似表示导致 0.1+0.2≠0.3(实际为 0.30000000000000004),== 判断会错误返回 false;应使用 std::abs(a - b)
为什么不能直接用
==比较两个float或double浮点数在内存中是二进制近似表示,很多十进制小数(比如
0.1)根本无法精确存储。哪怕只是简单计算,如0.1 + 0.2,结果也不是严格等于0.3,而是类似0.30000000000000004。直接用==判断会返回false,即使数学上“应该相等”。这不是 bug,是 IEEE 754 的固有特性。用
std::abs(a - b) 是最常用但有陷阱的方法最直观的做法是判断差值的绝对值是否小于某个阈值
epsilon:bool is_close(double a, double b, double eps = 1e-9) { return std::abs(a - b) < eps; }但它只适用于数量级接近 0 的数。一旦
a和b很大(比如1e10),1e-9就远小于机器精度,导致永远返回true;反过来,如果它们非常小(比如1e-20),1e-9又太大,可能漏判。所以固定epsilon不具备尺度不变性。
eps应根据输入数量级动态调整,而不是硬编码- 对
0.0附近比较,绝对误差法仍可用;但跨数量级时必须转向相对误差- 标准库没有提供通用的
is_close(C++23 才加入std::is_close,目前多数项目还得自己写)更鲁棒的写法:结合相对误差与绝对误差(推荐工业级用法)
NumPy 的
isclose和 Python 标准库的思路已被广泛验证:同时检查相对误差和绝对误差,取其一满足即判定为“足够接近”:立即学习“C++免费学习笔记(深入)”;
bool is_close(double a, double b, double rel_tol = 1e-9, double abs_tol = 1e-12) { if (std::abs(a - b) <= abs_tol) return true; return std::abs(a - b) <= rel_tol * std::max(std::abs(a), std::abs(b)); }这种写法能自然覆盖极端情况:
- 当
a和b都接近 0(比如1e-15),abs_tol起主导作用- 当它们较大(比如
1e6),rel_tol控制精度,避免被舍入误差淹没std::max(std::abs(a), std::abs(b))确保分母不为零,且选择更稳妥的尺度基准C++23 的
std::is_close怎么用?注意它还没普及C++23 引入了
中的std::is_close,接口与上面一致:#includestd::is_close(a, b, 1e-9, 1e-12); // 返回 bool 但目前主流编译器(GCC 13、Clang 16、MSVC 19.35)仅部分支持,且需显式开启
-std=c++23并确认标准库实现已跟进。生产环境建议暂不依赖,优先使用自定义版本。真正容易被忽略的是:浮点比较从来不是“是否相等”,而是“在当前上下文下是否可视为等价”。这个“上下文”包括数据来源(传感器?仿真?用户输入?)、后续运算敏感度、以及你愿意容忍的误差范围 —— 这些都得由人定,没法交给一个通用函数全自动决定。
0
0
相关文章
如何使用SWIG为c++代码自动生成多语言绑定? (Python/Java/C#)
C++如何为Python编写扩展模块_使用pybind11无缝连接C++与Python
如何用pybind11处理c++的std::vector和Python的list? (自动类型转换)
C++ libtorch_C++中使用PyTorch的LibTorch库指南
c++怎么调用python代码_c++ Python.h头文件引入与函数执行【方法】
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。
772
2023.06.15
python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。
765
2023.07.25
Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。
679
2023.07.31
Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。
570
2023.08.04
eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。
579
2023.08.04
scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。
751
2023.08.11
热门下载
相关下载
精品课程
最新文章






