
在处理numpy浮点数数组时,由于浮点数的内在精度问题,直接使用`==`进行相等性判断往往不可靠。本文将详细介绍如何利用`numpy.isclose`函数,通过设置绝对容差(`atol`)和相对容差(`rtol`),实现对浮点数数组的健壮且灵活的近似相等比较,从而有效解决不同精度浮点数间的比较难题,确保数据处理的准确性。
浮点数在计算机内部的表示方式决定了它们无法精确表示所有实数。因此,即使两个浮点数在数学上应该相等,由于计算或存储过程中的微小差异,它们在计算机中可能略有不同。例如,0.1 + 0.2在Python中并不精确等于0.3。当涉及到NumPy数组时,这种问题变得尤为突出,尤其是在需要比较来自不同源或经过不同计算路径的浮点数数组时。
考虑以下场景:
import numpy as np e = np.array([0.8292222222222225, 0.1310000000000003]) print(e[0]) # 输出: 0.8292222222222225 print(e[0] == 0.829225) # 输出: False
尽管0.8292222222222225和0.829225在肉眼看来非常接近,但直接的==操作符会返回Fa
lse,因为它们的二进制表示不完全相同。用户可能希望将这些值视为“相等”,以进行逻辑判断或数据筛选。在这种情况下,我们需要的不是改变浮点数的底层精度(np.set_printoptions仅影响显示,不改变数值本身),而是进行一种“近似相等”的比较。
为了解决浮点数比较的固有问题,NumPy提供了numpy.isclose函数。这个函数允许我们在一定的容差范围内判断两个数组的对应元素是否“足够接近”,从而避免了直接相等性判断的局限性。
numpy.isclose的基本语法如下:
numpy.isclose(a, b, rtol=1e-05, atol=1e-08, equal_nan=False)
isclose的判断逻辑是:如果abs(a - b)
PictoGraphic
AI驱动的矢量插图库和插图生成平台
133
查看详情
选择合适的容差值是使用numpy.isclose的关键。
绝对容差 (atol): atol指定了两个数值之间允许的最大绝对差值。它适用于以下情况:
相对容差 (rtol): rtol指定了两个数值之间允许的最大相对差值。它适用于以下情况:
通常情况下,我们同时使用atol和rtol,以覆盖各种数值范围。
让我们使用numpy.isclose来解决前面提到的浮点数比较问题。
import numpy as np
a = np.array([0.8292222222222225, 0.1310000000000003])
b = np.array([0.8293, 0.132]) # 另一个数组,包含略有不同的值
print("原始数组 a:", a)
print("原始数组 b:", b)
# 示例 1: 使用较大的绝对容差 (atol=1e-3)
# 允许的误差范围较大,例如小数点后3位以内
print("\n使用 atol=1e-3 进行比较:")
result_1e3 = np.isclose(a, b, atol=1e-3)
print(result_1e3)
# 预期输出: [ True True]
# 解释: 0.82922... 和 0.8293 差值约 0.00007,小于 0.001 (1e-3)。
# 0.13100... 和 0.132 差值约 0.001,等于 0.001 (1e-3)。
# 示例 2: 使用中等绝对容差 (atol=1e-4)
# 允许的误差范围缩小,例如小数点后4位以内
print("\n使用 atol=1e-4 进行比较:")
result_1e4 = np.isclose(a, b, atol=1e-4)
print(result_1e4)
# 预期输出: [ True False]
# 解释: 第一个元素仍为 True。第二个元素 0.13100... 和 0.132 差值约 0.001,大于 0.0001 (1e-4)。
# 示例 3: 使用较小的绝对容差 (atol=1e-5)
# 允许的误差范围进一步缩小,例如小数点后5位以内
print("\n使用 atol=1e-5 进行比较:")
result_1e5 = np.isclose(a, b, atol=1e-5)
print(result_1e5)
# 预期输出: [False False]
# 解释: 第一个元素 0.82922... 和 0.8293 差值约 0.00007,大于 0.00001 (1e-5)。
# 第二个元素 0.13100... 和 0.132 差值约 0.001,远大于 0.00001 (1e-5)。
# 示例 4: 结合 atol 和 rtol
# 假设我们希望在数值较大时使用相对误差,数值较小时使用绝对误差
c = np.array([1000.00001, 0.0000001])
d = np.array([1000.00002, 0.0000002])
print("\n结合 atol 和 rtol 进行比较:")
# 默认 rtol=1e-5, atol=1e-8
result_default = np.isclose(c, d)
print(f"默认容差: {result_default}") # 第一个元素 (1000.00001 vs 1000.00002) 差值 1e-5, 相对误差 1e-5 / 1000 = 1e-8, 满足 rtol。
# 第二个元素 (1e-7 vs 2e-7) 差值 1e-7, 满足 atol=1e-8? 不满足,因为 1e-7 > 1e-8。
# abs(1e-7 - 2e-7) = 1e-7
# atol + rtol * abs(b) = 1e-8 + 1e-5 * 2e-7 = 1e-8 + 2e-12 ≈ 1e-8
# 1e-7 > 1e-8,所以第二个为 False。
# 预期输出: [ True False]
result_custom = np.isclose(c, d, rtol=1e-7, atol=1e-6)
print(f"自定义容差 (rtol=1e-7, atol=1e-6): {result_custom}")
# 预期输出: [ True True]
# 解释: 第一个元素:差值 1e-5。rtol=1e-7, abs(b)=1000.00002。rtol*abs(b) = 1e-7 * 1000 = 1e-4。
# 1e-5 <= (1e-6 + 1e-4) 为 True。
# 第二个元素:差值 1e-7。atol=1e-6。1e-7 <= 1e-6 为 True。在NumPy中进行浮点数数组的相等性检查时,直接使用==操作符是不可靠的。numpy.isclose函数提供了一个强大而灵活的解决方案,通过引入绝对容差(atol)和相对容差(rtol),允许我们在可接受的误差范围内判断浮点数是否近似相等。理解并正确配置这些容差参数,是确保数值比较准确性和健壮性的关键。
以上就是NumPy浮点数数组的精确比较:告别直接相等判断的详细内容,更多请关注其它相关文章!
相关文章:
文本文档写html代码怎么运行_文本文档html代码运行步骤【教程】
J*aScript动态修改指定div内所有a标签样式指南
QQ邮箱官方网页版登录 QQ邮箱个人邮箱快速访问
J*aScript打印功能_j*ascript输出控制
必由学官网快捷入口 必由学网页版在线学习平台
Win10双系统截图高效法 截屏快捷键速记【技巧】
抖音极速版最新版本 抖音极速版官方下载地址
163邮箱官方主页登录 直达网易邮箱登录核心页面
照顾宝贝2小游戏点击立即在线玩
AO3官方镜像站点汇总 AO3同人作品网页版直达链接
如何使用Rector自动化升级旧代码_通过Composer安装和配置Rector进行代码重构
如何在复杂的电商平台中优雅地管理共享资源并确保正确重定向,使用spryker-shop/resource-share-page模块助你一臂之力
台积电1.4nm工艺A14瞄准2028:10年来性能提升80%
C++如何比较两个字符串_C++ string compare函数与操作符对比
C++的std::forward_list怎么用_C++ STL中单向链表容器的特点与应用
PHP:根据嵌套关联数组项值动态添加新键值对
qq浏览器打开空白页怎么办 qq浏览器启动后显示白屏的解决教程
Win11输入法不见了怎么办_Windows11恢复语言栏显示方法
在Socket.IO连接中实现Access Token自动更新与动态重连
UC浏览器如何安装插件 UC浏览器添加扩展程序详细教程【进阶】
c++如何使用chrono库处理时间_c++标准库时间与日期操作
Lar*el Migration:重命名列后添加新列的正确操作顺序
c++如何实现一个简单的ECS框架_c++数据驱动设计与游戏开发
Node.js 中使用 node-cron 实现定时 API 数据抓取与处理
天眼查怎么看公司融资情况 天眼查企业融资历史查询步骤【攻略】
React项目中导航栏Logo自适应布局:避免裁剪与布局溢出
Win11怎么查看显卡显存 Win11显示适配器属性及专用视频内存查询
J*aScript教程:根据元素文本内容动态设置背景色
葱吃多了会怎样 葱吃多了会伤胃吗
谷歌浏览器无痕模式怎么开 Chrome开启无痕浏览设置方法【教程】
J*aScript map 方法中处理循环元素为空数组的策略
win11如何加载ICC颜色配置文件 Win11校色文件安装与显示器色彩管理【指南】
微信客户端如何收红包_微信客户端接收红包使用教程
TikTok国际版官网直达_TikTok国际版官网直达进入在线观看
Bilibili动漫最新防封地址发布-Bilibili动漫2025年最稳正版入口推荐
俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问
PostgreSQL海量数据高效导入策略:Python与Django实践指南
HTML转PPT成品工具有哪些?HTML网页转PPT成品工具大全
蛙漫画网页版全站入口 蛙漫热门作品免费浏览
淘宝支付提示失败如何解决 淘宝支付流程优化方法
b站如何看历史记录_b站观看历史找回方法
铁路12306改签能改到更早的车次吗_铁路12306改签提前车次规则
Mudbox图层蒙版怎么用_Mudbox图层蒙版数字雕刻应用技巧
手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析
Excel Power Pivot如何处理XML数据源 构建高级数据模型
CSS Grid如何控制元素对齐_align-items与justify-items组合使用
微信网页版官方入口教程 微信网页版网页版快速登录步骤
Selenium Python中处理点击后新窗口加载冻结问题的策略与实践
Lar*el用户头像管理:实现图片缩放、存储与旧文件安全删除的最佳实践
yandex入口引擎手机版 yandex安卓版下载入口