...

Source file src/runtime/float.go

     1	// Copyright 2017 The Go Authors. All rights reserved.
     2	// Use of this source code is governed by a BSD-style
     3	// license that can be found in the LICENSE file.
     4	
     5	package runtime
     6	
     7	import "unsafe"
     8	
     9	var inf = float64frombits(0x7FF0000000000000)
    10	
    11	// isNaN reports whether f is an IEEE 754 ``not-a-number'' value.
    12	func isNaN(f float64) (is bool) {
    13		// IEEE 754 says that only NaNs satisfy f != f.
    14		return f != f
    15	}
    16	
    17	// isFinite reports whether f is neither NaN nor an infinity.
    18	func isFinite(f float64) bool {
    19		return !isNaN(f - f)
    20	}
    21	
    22	// isInf reports whether f is an infinity.
    23	func isInf(f float64) bool {
    24		return !isNaN(f) && !isFinite(f)
    25	}
    26	
    27	// Abs returns the absolute value of x.
    28	//
    29	// Special cases are:
    30	//	Abs(±Inf) = +Inf
    31	//	Abs(NaN) = NaN
    32	func abs(x float64) float64 {
    33		const sign = 1 << 63
    34		return float64frombits(float64bits(x) &^ sign)
    35	}
    36	
    37	// copysign returns a value with the magnitude
    38	// of x and the sign of y.
    39	func copysign(x, y float64) float64 {
    40		const sign = 1 << 63
    41		return float64frombits(float64bits(x)&^sign | float64bits(y)&sign)
    42	}
    43	
    44	// Float64bits returns the IEEE 754 binary representation of f.
    45	func float64bits(f float64) uint64 {
    46		return *(*uint64)(unsafe.Pointer(&f))
    47	}
    48	
    49	// Float64frombits returns the floating point number corresponding
    50	// the IEEE 754 binary representation b.
    51	func float64frombits(b uint64) float64 {
    52		return *(*float64)(unsafe.Pointer(&b))
    53	}
    54	

View as plain text