使用 Double.Epsilon 确定浮点数的相等性
MSDN 文档建议使用大于 Double.Epsilon 常量的值来建立确定两个浮点数是否相等时可接受的绝对差值。然而,这个建议引起了一些混乱。
Double.Epsilon 在比较中有实际用途吗?
MSDN 的措辞导致了对 Double 实际用途的误解。埃普西隆。如提供的答案中所述,Double.Epsilon 表示最小的可表示非非正规浮点值,不为 0。它仅表示截断误差的最小大小,而不是可接受的比较余量。
计算适合相等比较的 Epsilon
对于相等比较,更实用的方法是使用 epsilon基于所比较的值的大小。例如:
public static bool AboutEqual(double x, double y) { double epsilon = Math.Max(Math.Abs(x), Math.Abs(y)) * 1E-15; return Math.Abs(x - y) <p>此方法使用两个数字的绝对值中较大的一个乘以一个小常数 (1E-15) 来确定可接受的比较余量。</p><p><strong>考虑大于和小于比较</strong></p><p>对于大于或小于等比较,原理相同适用。 epsilon 应根据比较数字的大小来计算,以考虑潜在的截断错误。</p><p><strong>相等和不等式比较的最佳实现</strong></p><p>总之,Double .Epsilon 不能直接用作浮点比较的可接受的相等、大于、小于、小于或等于或大于或等于比较的余量数字。相反,应该计算特定于上下文的 epsilon 以确保准确的比较。</p>
以上是我应该如何比较浮点数的相等和不相等?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文详细介绍了C函数返回类型,包括基本(int,float,char等),派生(数组,指针,结构)和void类型。 编译器通过函数声明和返回语句确定返回类型,执行

Gulc是一个高性能的C库,优先考虑最小开销,积极的内衬和编译器优化。 其设计非常适合高频交易和嵌入式系统等关键应用程序,其设计强调简单性,模型

本文详细介绍了字符串案例转换的C功能。 它可以通过ctype.h的toupper()和tolower()解释,并通过字符串迭代并处理零终端。 常见的陷阱,例如忘记ctype.h和修改字符串文字是

本文解释了C函数声明与定义,参数传递(按值和指针),返回值以及常见的陷阱,例如内存泄漏和类型不匹配。 它强调了声明对模块化和省份的重要性

本文研究C函数返回值存储。 较小的返回值通常存储在寄存器中以备速度;较大的值可能会使用指针来记忆(堆栈或堆),影响寿命并需要手动内存管理。直接ACC

本文分析了形容词“独特”的多方面用途,探索其语法功能,常见的短语(例如,“不同于”,“完全不同”),以及在正式与非正式中的细微应用

本文详细介绍了c中有效的STL算法用法。 它强调了数据结构选择(向量与列表),算法复杂性分析(例如,std :: sort vs. std vs. std :: partial_sort),迭代器用法和并行执行。 常见的陷阱

本文解释了C标准模板库(STL),重点关注其核心组件:容器,迭代器,算法和函子。 它详细介绍了这些如何交互以启用通用编程,提高代码效率和可读性t


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3汉化版
中文版,非常好用

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Dreamweaver Mac版
视觉化网页开发工具