浮點數比較大小

2021-06-19 08:59:11 字數 1824 閱讀 5593

在數**算當中經常會涉及到判斷兩個數是否相等的情況 

對於整數很好處理 a==b這樣的乙個語句就可以

解決全部的問題 

但是對於浮點數是不同的 

首先,浮點數在計算機當中的二進位制表達方式就決定了大多數浮點數都是無法精確的表達的 

現在的計算機大部分都是

數字計算機,不是模擬機,數字機的離散化的資料表示方法自然無法精確表達大部分的資料量的。 

其次計算機浮點數的精度在單精度float型別下,只有7位,在進行浮點運算的時候,這個精度往往會導致運算的結果和實際期望的結果之間有誤差 

因為前兩個原因,我們很難用 a==b來判定兩個浮點數是否相同 

很自然,我們可以想到 fabs(a-b) < epsilon 這樣的一種判別方法 

但是這種判別方法穩妥嗎? 

它也不穩妥。 

首先, epsilon是乙個絕對的資料,也就是誤差分析當中說說的絕對誤差 

使用乙個固定的數值,對於float型別可以表達的整個數域來說是不可以的 

比如epsilon取值為0.0001,而a和b的數值大小也是0.0001附近的,那麼顯然不合適 

另外對於a和b大小是10000這樣的資料的時候,它也不合適,因為10000和10001也可以認為是相等的呢 

適合它的情況只是a或者b在1或者0附近的時候 

既然絕對誤差不可以,那麼自然的我們就會想到了相對誤差 

bool isequal(float a, float b, float relerror )  

這樣寫還不完善,因為是拿固定的第乙個引數做比較的,那麼在呼叫 

isequal(a, b, relerror ) 和 isequal(b, a, relerror ) 的時候,可能得到不同的結果 

同時如果第乙個引數是0的話,就有可能是除0溢位 

這個可以改造 

把除數選取為a和b當中絕對數值較大的即可 

bool isequal(float a, float b, relerror ) 

; 使用相對誤差就很完善嗎? 

也不是, 在某些特殊情況下, 相對誤差也不能代表全部 

比如在判斷空間三點是否共線的時候,使用判斷點到另外兩個點形成的線段的距離的方法的時候 

只用相對誤差是不夠的,應為線段距離可能很段,也可能很長,點到線段的距離,以及線段的長度做綜合比較的時候,需要相對誤差和絕對誤差結合的方式才可以 

相對完整的比較演算法應該如下: 

bool isequal(float a, float b, float abserror, float relerror ) 

這樣才相對完整  

參照msdn定義:

/* compile options needed: none. value of c is printed with a decimal

point precision of 10 and 6 (printf rounded value by default) to

show the difference

*/#include

// define your own tolerance

const double epsilon = 1.00e-07;
const float   flt_epsilon  = 1.192092896e-07f;
const double  dbl_epsilon  = 2.2204460492503131e-016;

#define float_eq(x,v) (((v - epsilon) < x) && (x <( v + epsilon)))

int main()

浮點數比較大小

浮點數比較大小,由於精度問題,所以直接比較有時可能會出錯。單精度數7位有效數字。float 雙精度數16位有效數字。double 單精度數的尾數用23位儲存,加上預設的小數點前的1位1,2 23 1 16777216。因為 10 7 16777216 10 8,所以說單精度浮點數的有效位數是7位。雙...

PHP浮點數比較大小

php 比較運算子用於比較兩個值 數字或字串 等於 x y 如果 x 等於 y,則返回 true。全等 完全相同 x y 如果 x 等於 y,且它們型別相同,則返回 true。a 0.58 100 b 58 var dump a 輸出 float 58 var dump b 輸出 int 58 va...

浮點數比較大小的問題

浮點數比較大小,由於精度問題,所以直接比較有時可能會出錯。單精度數7位有效數字。float 雙精度數16位有效數字。double 單精度數的尾數用23位儲存,加上預設的小數點前的1位1,2 23 1 16777216。因為 10 7 16777216 10 8,所以說單精度浮點數的有效位數是7位。雙...