2010-12-03 04:34:57 +00:00
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package math
|
|
|
|
|
2011-10-26 23:57:58 +00:00
|
|
|
// Abs returns the absolute value of x.
|
2010-12-03 04:34:57 +00:00
|
|
|
//
|
|
|
|
// Special cases are:
|
2011-12-13 19:16:27 +00:00
|
|
|
// Abs(±Inf) = +Inf
|
2011-10-26 23:57:58 +00:00
|
|
|
// Abs(NaN) = NaN
|
2012-02-07 19:26:30 +00:00
|
|
|
|
|
|
|
//extern fabs
|
|
|
|
func libc_fabs(float64) float64
|
|
|
|
|
2011-10-26 23:57:58 +00:00
|
|
|
func Abs(x float64) float64 {
|
2012-01-12 01:31:45 +00:00
|
|
|
return libc_fabs(x)
|
|
|
|
}
|
|
|
|
|
|
|
|
func abs(x float64) float64 {
|
2016-02-03 21:58:02 +00:00
|
|
|
// TODO: once golang.org/issue/13095 is fixed, change this to:
|
|
|
|
// return Float64frombits(Float64bits(x) &^ (1 << 63))
|
|
|
|
// But for now, this generates better code and can also be inlined:
|
|
|
|
if x < 0 {
|
2010-12-03 04:34:57 +00:00
|
|
|
return -x
|
2016-02-03 21:58:02 +00:00
|
|
|
}
|
|
|
|
if x == 0 {
|
2011-10-26 23:57:58 +00:00
|
|
|
return 0 // return correctly abs(-0)
|
2010-12-03 04:34:57 +00:00
|
|
|
}
|
|
|
|
return x
|
|
|
|
}
|