Rust编程中的浮点数比较

缘由:在看Rust编写的代码,发现了一行浮点数等于比较的代码,于是编辑如下内容。
在Rust中,进行浮点数比较时需要特别小心,因为浮点数由于精度限制无法精确表示小数,可能会导致直接比较(如 ==)的结果不符合预期。这里是一些注意事项和常见的解决方案:
1. 避免直接使用 == 或 != 比较
浮点数运算中的精度误差,可能导致直接比较不准确。例如:
let a = 0.1 + 0.2;
let b = 0.3;
println!("{}", a == b); // 输出: false
虽然理论上 a 和 b 应该相等,但计算误差会让它们的值稍有不同。因此,避免使用 == 或 != 直接比较浮点数。
2. 使用允许误差(误差容限)进行比较
通常,在比较浮点数时引入一个允许的误差范围(即误差容限)。例如,如果两个浮点数的差异在某个很小的范围内,就可以认为它们相等。
fn approx_equal(a: f64, b: f64, epsilon: f64) -> bool {(a - b).abs() < epsilon
}fn main() {let a = 0.1 + 0.2;let b = 0.3;println!("{}", approx_equal(a, b, 1e-10)); // 输出: true
}
这里 epsilon 是误差容限,根据实际情况选择合适的值,比如 1e-10 或更小的值。
3. 使用 f64::EPSILON 或 f32::EPSILON
Rust 提供了 f64::EPSILON 和 f32::EPSILON,表示浮点数计算中能表示的最小差值。通常 EPSILON 可以作为误差容限的基础,不过更常见的是在其基础上进行放大:
fn approx_equal(a: f64, b: f64) -> bool {(a - b).abs() < f64::EPSILON * 10.0 // 放大 epsilon 以确保误差范围足够
}
4. 使用内置的 f64::total_cmp
如果需要对浮点数进行排序,可以使用 total_cmp 方法。这个方法会考虑特殊的浮点数情况,比如 NaN 和 -0.0,避免精度误差对排序结果的影响:
fn main() {let mut values = vec![0.1 + 0.2, 0.3];values.sort_by(|a, b| a.total_cmp(b));println!("{:?}", values);
}
5. 尽量避免不必要的浮点计算
尽量避免将多个浮点计算组合在一起,特别是涉及较小或较大的数。浮点数计算误差是累积的,因此计算越复杂,误差越明显。
6. 避免与 NaN 进行比较
任何浮点数与 NaN(非数)进行比较都会返回 false。如果可能存在 NaN 值,应提前检查和处理。
let x = f64::NAN;
if x.is_nan() {println!("x is NaN");
}
总结
浮点数的精度误差是比较时的一大挑战。在 Rust 中进行浮点数比较时,应尽量避免直接比较,使用误差容限或 total_cmp 方法。
相关文章:
Rust编程中的浮点数比较
缘由:在看Rust编写的代码,发现了一行浮点数等于比较的代码,于是编辑如下内容。 在Rust中,进行浮点数比较时需要特别小心,因为浮点数由于精度限制无法精确表示小数,可能会导致直接比较(如 &…...
java访问华为网管软件iMaster NCE的北向接口
最近做的一个项目,需要读取华为一个叫iMaster NCE的网管软件的北向接口。这个iMaster NCE(以下简称NCE)用于管理项目的整个网络,尤其是光网络。业主要求我们访问该软件提供的对外接口,读取一些网络信息,比如…...
UV紫外相机
在产业设备领域,运用相机进行检测的需求很大,应用也很多样,对于图像传感器性能的期望逐年提升。在这样的背景下,可拍摄紫外线(UV:Ultra Violet)图像的相机拥有越来越广泛的应用场景。将UV照明和…...
第十八届联合国世界旅游组织/亚太旅游协会旅游趋势与展望大会在广西桂林开幕
10月19日,第十八届联合国世界旅游组织/亚太旅游协会旅游趋势与展望大会(以下简称“大会”)在广西桂林开幕,来自美国、英国、德国、俄罗斯、柬埔寨等25个国家约120名政府官员、专家学者和旅游业界精英齐聚一堂,围绕“亚洲及太平洋地区旅游业&a…...
Effective Java(第三版) _ 创建和销毁对象
一、前言 《Effective Java》 这本书,在刚从事 Java 开发的时候就被老师推荐阅读过,当时囫囵吞枣的看了一部分,不是特别的理解,也就搁置了,现在已经更新到第三版了,简单翻阅了一下,发现有些条例…...
你的EA无法运行的几种常见原因
大多数情况下,EA正常运行是指其能够自动开仓交易,毕竟EA的主要目的是根据某种策略自动进行交易。如果从网上下载或其他途径获得的EA在开始时能够正常交易,但在修改参数后却不再交易,可能的问题是什么呢?下面列举了一些…...
通过自定义指令实现图片懒加载
前提:使用到了VueUse插件。 先创建自定义插件文件夹 // 定义懒加载插件 import { useIntersectionObserver } from vueuse/core // 这个是VueUse里的一个方法export const lazyPlugin {install(app) {// 懒加载指令逻辑 定义全局指令app.directive(img-lazy, {mo…...
QT项目-仿QQ聊天(带宠物系统)
目录 一,项目介绍 二,开发环境 三,涉及技术 四,项目效果示例图 1,登录界面 2,主界面 3,聊天界面 4,功能界面 5,宠物界面 一,项目介绍 这是一个基于u…...
前端算法题:3216. 交换后字典序最小的字符串(力扣每日一题)
今日题目为:3216. 交换后字典序最小的字符串 题目详情: 给你一个仅由数字组成的字符串 s,在最多交换一次 相邻 且具有相同 奇偶性 的数字后,返回可以得到的字典序最小的字符串。 如果两个数字都是奇数或都是偶数,则…...
29.1 时序监控和日志监控的对比,分析日志监控的核心诉求
本节重点介绍 : 监控系统分类时序监控和日志监控的对比轻量日志监控系统的诉求 监控系统分类 监控系统按照原理和作用大致可以分为三类 日志类(Log)调用链类(Tracing)度量类(Metrics) 日志类(…...
git仓库分支
操作 切换分支 git checkout 1.2.5 git checkout 1.3.0 使用命令切换分支之后,代码内容加载过后也是切换好的...
多模态机器学习在精准健康中的应用--九五小庞
这篇综述文章探讨了将多模态数据融合应用于医疗诊断和预后预测的最新研究进展。 本文作者们确定了三个主要的研究问题:多模态数据融合在健康领域的文献特征是什么?用于分析多模态健康数据的不同分析技术、方法和策略是什么?不同类型的异构数…...
提升网站速度与性能优化的有效策略与实践
内容概要 在数字化快速发展的今天,网站速度与性能优化显得尤为重要,它直接影响用户的浏览体验。用户在访问网站时,往往希望能够迅速获取信息,若加载时间过长,轻易可能导致他们转向其他更为流畅的网站。因此࿰…...
MySQL索引从基础到原理,看这一篇就够了
https://developer.aliyun.com/article/841106 https://zhuanlan.zhihu.com/p/29118331 索引创建使用总结 因为索引对于改善查询性能的作用是巨大的,所以我们的目标是尽量使用索引。 1. 索引的创建 • 1、在用于 where 判断 order 排序和 join 的(on)字段上创…...
普通高考预报名上传蓝底证件照手机自拍方法详解
普通高考预报名过程中,上传一张合规的蓝底证件照是必不可少的一步。本文将详细介绍如何使用手机自拍并使用工具来制作符合要求的蓝底证件照。注意,目前仅有广东等个别省份允许特定类型考生使用自拍照上传(例如普高预报名阶段、学考报名&#…...
Webserver(2.3)exec函数族
目录 exec函数族介绍execl函数execlp函数 exec函数族介绍 c语言中没有重载,因为不允许同名函数 一系列功能相似的函数称为函数族 exec函数族的作用是根据指定的文件名找到可执行文件,并用它来取代调用进程的内容。 程序在运行的时候,fork一…...
LeetCode Hot100 - 子串篇
前言 挑战一个月刷完力扣的hot100,记录一下每题的思路~ 这次是子串相关的题目 (1)560. 和为 K 的子数组 ①暴力枚举,使用一个变量sum记录以l开头r结尾的情况 class Solution {public int subarraySum(int[] nums, int k) {int r…...
【Android】Convenient ADB Commands
Install adb install -r <path>Uninstall adb uninstall <pkg>Start adb shell am start -n <pkg>/.SplashActivityStop adb shell am force-stop <pkg>Reset adb shell pm clear <pkg>Reboot adb rebootShutdown adb reboot -p...
elementUI 时间控件控制时间选择
选择时间大于当前月或小于2024年一月禁止选择 <el-form-item label"成交月份:" label-width"105px" ><div class"block"><el-date-pickerv-model"formData.deal_month"type"month":picker-options"pick…...
什么是x86架构,什么是arm架构
什么是 x86 架构? x86 架构是一种经典的指令集架构(ISA),最早由英特尔在 1978 年推出,主要用于 PC、服务器等领域。 它是一种复杂指令集计算(CISC)架构,支持大量的复杂指令和操作&…...
django flask+uniapp的个人理财家庭财务收支系统422vl 小程序
目录技术栈选择与分工数据库设计后端实现要点前端UniApp开发开发里程碑计划部署方案性能优化措施测试策略项目技术支持可定制开发之功能创新亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作技术栈选择与分工 后端框架采用DjangoFlask组…...
AI辅助开发实战:基于Chatbot和Agent的智能编程助手设计与实现
背景痛点:传统开发流程的效率瓶颈 在软件开发过程中,开发者常常需要处理大量重复性、模式化的工作。这些工作不仅消耗时间,也容易因疲劳导致错误。 样板代码编写:无论是创建新的CRUD接口、数据模型,还是初始化项目结…...
两级式光伏并网逆变器低电压穿越LVRT仿真模型:改进MPPT、改进电流环、DSOGI锁相环与电流前馈控制(仿真+配套设计说明文档+参考文献)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
银河麒麟系统下QT5.12.10环境配置避坑指南(附linuxdeployqt打包实战)
银河麒麟系统下QT5.12.10开发环境全流程配置与深度优化指南 在国产操作系统生态快速发展的今天,银河麒麟作为主流国产OS之一,其上的QT开发环境搭建却常让开发者陷入"依赖地狱"和兼容性迷局。本文将彻底解决三个核心痛点:如何正确选…...
scrapy学习
conda create -n scrapy-309 python3.09conda activate scrapy-309pip install scrapy2.6.3 Twisted22.10.0 urllib31.26.18 parsel1.7.0 -i https://pypi.tuna.tsinghua.edu.cn/simple创建项目scrapy startproject baidu_spiderscrapy genspider baidu https://www.baidu.com启…...
金融问答合规最后窗口期:Dify 0.12+版本强制启用的3项新审计日志字段,错过将无法通过Q3银保监现场检查
第一章:金融问答合规最后窗口期的监管背景与紧迫性近年来,金融行业智能问答系统爆发式增长,但其输出内容的准确性、可追溯性与风险提示完整性持续引发监管关注。2023年10月《金融领域生成式人工智能应用监管指引(试行)…...
《QGIS快速入门与应用基础》221:项目面板:布局元素管理
作者:翰墨之道,毕业于国际知名大学空间信息与计算机专业,获硕士学位,现任国内时空智能领域资深专家、CSDN知名技术博主。多年来深耕地理信息与时空智能核心技术研发,精通 QGIS、GrassGIS、OSG、OsgEarth、UE、Cesium、OpenLayers、Leaflet、MapBox 等主流工具与框架,兼具…...
若依框架实战:基于Mybatis与ruoyi-vue实现OA系统一对一关联查询
1. 从零开始理解一对一关联查询 刚接触OA系统开发时,我最头疼的就是各种表单之间的数据关联。比如立项申请需要关联具体项目信息,每次都要来回切换页面查询,效率特别低。后来发现Mybatis的一对一关联查询能完美解决这个问题,今天就…...
RVC低成本GPU部署方案:单卡3090/4090下显存占用与训练耗时实测
RVC低成本GPU部署方案:单卡3090/4090下显存占用与训练耗时实测 1. 引言:当AI翻唱遇上消费级显卡 最近,AI语音转换工具RVC(Retrieval-based-Voice-Conversion)火得一塌糊涂。无论是想用偶像的声音唱自己的歌ÿ…...
自定义同花顺K线周期快捷键:从入门到精通
1. 为什么要自定义同花顺K线周期快捷键? 作为一个用了同花顺5年的老股民,我深知快捷键的重要性。记得刚开始炒股那会儿,每次切换K线周期都要用鼠标点来点去,手忙脚乱不说,还经常错过最佳买卖点。后来发现同花顺默认的K…...
