色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

比較Java中相等性的雙精度值。

瀏覽:169日期:2024-04-25 13:40:56
如何解決比較Java中相等性的雙精度值。?

您可以嘗試使用10 -15數(shù)量級(jí)的增量值,但是您會(huì)注意到某些計(jì)算會(huì)產(chǎn)生較大的舍入誤差。此外,您進(jìn)行的操作越多,累積的舍入誤差就越大。

一種特別糟糕的情況是,如果減去兩個(gè)幾乎相等的數(shù)字,例如1.0000000001-1.0并將結(jié)果與??0.0000000001進(jìn)行比較

因此,幾乎沒有希望找到適用于所有情況的通用方法。您始終必須計(jì)算出在特定應(yīng)用中可以期望的精度,然后如果結(jié)果比該精度更接近,則認(rèn)為結(jié)果相等。

例如輸出

public class Main { public static double delta(double d1, double d2) {return Math.abs(d1- d2) / Math.max(Math.abs(d1), Math.abs(d2)); } public static void main(String[] args) {System.out.println(delta(0.1*0.1, 0.01));System.out.println(delta(1.0000000001 - 1.0, 0.0000000001)); }}

1.7347234759768068E-168.274036411668976E-8

間隔算術(shù)可用于跟蹤累積的舍入誤差。但是實(shí)際上,錯(cuò)誤間隔過于悲觀,因?yàn)橛袝r(shí)舍入錯(cuò)誤也會(huì)相互抵消。

解決方法

我想從那些double在Java中使用原始相等性有更多經(jīng)驗(yàn)的人那里獲得一些建議。使用d1 ==d2兩次雙打d1,d2由于可能的舍入誤差而不夠。

我的問題是:

Java Double.compare(d1,d2) == 0在某種程度上處理舍入錯(cuò)誤嗎?如1.7文檔中所述,0如果d1數(shù)值等于,則返回值d2。有人確定它們?cè)跀?shù)值上相等是什么意思嗎?

對(duì)某些增量值使用相對(duì)誤差計(jì)算,您會(huì)建議使用通用的增量值(不是特定于應(yīng)用程序)嗎?請(qǐng)參見下面的示例。

以下是考慮相對(duì)誤差的用于檢查相等性的通用函數(shù)。delta您建議從簡(jiǎn)單的+,-,/,*操作中捕獲大多數(shù)舍入誤差的價(jià)值是什么?

public static boolean isEqual(double d1,double d2) { return d1 == d2 || isRelativelyEqual(d1,d2);}private static boolean isRelativelyEqual(double d1,double d2) { return delta > Math.abs(d1- d2) / Math.max(Math.abs(d1),Math.abs(d2));}

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 在线观看国产精品日本不卡网 | 久久久久国产成人精品亚洲午夜 | 日本三级香港三级人妇99 | 曰本黄大片 | 美女张开腿让男人 | 手机看片午夜 | 国产毛片网站 | 免费一区二区三区久久 | 国产东北色老头老太性视频 | 日本欧美不卡一区二区三区在线 | 国产色a在线观看 | 免费一级毛片在线播放欧美 | 色咪味成人网 | 在线观看香蕉免费啪在线观看 | 国产欧美va欧美va香蕉在线 | 美国做受三级的视频播放 | 99视频免费看 | 成人免费精品视频 | 综合图片亚洲网友自拍10p | 国产精品亚洲精品久久成人 | 免费看a视频 | 加勒比日本道 | 性午夜| 国产亚洲精品aaa大片 | 亚洲一区二区三区在线网站 | 久草网首页 | 一级毛片牲交大片 | 久久久久综合给合狠狠狠 | 欧美精品videos | 欧美级毛片| 国产亚洲精品yxsp | 亚洲欧美日韩三级 | 国产精品亚洲片夜色在线 | 顶级毛片在线手机免费看 | 日本高清免费视频www | 欧美成人免费全部观看天天性色 | 中日韩精品视频在线观看 | a级毛片毛片免费观看永久 a级毛片毛片免费很很综合 | 日本肥老妇色xxxxx日本老妇 | 亚洲精品推荐 | 国产在线播放一区 |