Golang : Compare floating-point numbers
It has been a while since I need to compare two float numbers. Golang's math/big
package has function to compare floating-point numbers. Bear in mind that comparing float numbers can be tricky because most floating point numbers will end up imprecise due to rounding errors. What most people will do is to ignore the imprecision if it is small enough.
So, is the a way to compare two float numbers in Golang? Yes, see this example code :
package main
import (
"fmt"
"math/big"
)
func main() {
// change these value and play around
float1 := 123.4568
float2 := 123.45678
// convert float to type math/big.Float
var bigFloat1 = big.NewFloat(float1)
var bigFloat2 = big.NewFloat(float2)
fmt.Printf("Big Float1 : %0.5f \n", bigFloat1)
fmt.Printf("Big Float2 : %0.5f \n", bigFloat2)
// compare bigFloat1 to bigFloat2
result := bigFloat1.Cmp(bigFloat2)
// -1 if x < y
if result < 0 {
fmt.Println("bigFloat 1 less than bigFloat2")
}
// 0 if x == y
if result == 0 {
fmt.Println("bigFloat 1 equals to bigFloat2")
}
// +1 if x > y
if result > 0 {
fmt.Println("bigFloat 1 more than bigFloat2")
}
}
Output :
Big Float1 : 123.45680
Big Float2 : 123.45678
bigFloat 1 more than bigFloat2
Good to know, see http://floating-point-gui.de/errors/comparison/
Reference :
See also : Golang : Round float to precision example
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+16.2k CodeIgniter/PHP : Create directory if does not exist example
+25.5k Golang : Convert IP address string to long ( unsigned 32-bit integer )
+19.6k Golang : How to get time from unix nano example
+19.1k Golang : Fix cannot download, $GOPATH not set error
+5.7k Golang : Extract unicode string from another unicode string example
+27.1k Golang : dial tcp: too many colons in address
+19.6k Golang : Convert(cast) bytes.Buffer or bytes.NewBuffer type to io.Reader
+13.1k Golang : Verify token from Google Authenticator App
+27.3k PHP : Count number of JSON items/objects
+13.2k Golang : Get constant name from value
+33.3k Golang : All update packages with go get command
+4.8k Golang : Display packages names during compilation