Ken Thompson | 2181098 | 2008-03-28 13:56:47 -0700 | [diff] [blame] | 1 | // Copyright 2009 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 | |
Rob Pike | 4331293 | 2008-06-27 17:06:23 -0700 | [diff] [blame] | 5 | package math |
Ken Thompson | 2181098 | 2008-03-28 13:56:47 -0700 | [diff] [blame] | 6 | |
Rob Pike | 1a13f9b | 2011-09-29 09:54:20 -0700 | [diff] [blame] | 7 | // Abs returns the absolute value of x. |
Charles L. Dorian | a0690b6 | 2010-02-01 22:21:40 -0800 | [diff] [blame] | 8 | // |
| 9 | // Special cases are: |
Charles L. Dorian | c8d2544 | 2011-11-28 13:04:52 -0800 | [diff] [blame] | 10 | // Abs(±Inf) = +Inf |
Rob Pike | 1a13f9b | 2011-09-29 09:54:20 -0700 | [diff] [blame] | 11 | // Abs(NaN) = NaN |
Brad Fitzpatrick | 6f8a665 | 2015-10-29 15:13:58 +0000 | [diff] [blame] | 12 | func Abs(x float64) float64 { |
Brad Fitzpatrick | a59a275 | 2015-10-29 13:02:28 -0700 | [diff] [blame] | 13 | // TODO: once golang.org/issue/13095 is fixed, change this to: |
Brad Fitzpatrick | 6f8a665 | 2015-10-29 15:13:58 +0000 | [diff] [blame] | 14 | // return Float64frombits(Float64bits(x) &^ (1 << 63)) |
| 15 | // But for now, this generates better code and can also be inlined: |
Brad Fitzpatrick | a59a275 | 2015-10-29 13:02:28 -0700 | [diff] [blame] | 16 | if x < 0 { |
Robert Griesemer | 40621d5 | 2009-11-09 12:07:39 -0800 | [diff] [blame] | 17 | return -x |
Brad Fitzpatrick | a59a275 | 2015-10-29 13:02:28 -0700 | [diff] [blame] | 18 | } |
| 19 | if x == 0 { |
Rob Pike | 1a13f9b | 2011-09-29 09:54:20 -0700 | [diff] [blame] | 20 | return 0 // return correctly abs(-0) |
Ken Thompson | 2181098 | 2008-03-28 13:56:47 -0700 | [diff] [blame] | 21 | } |
Robert Griesemer | a3d1045 | 2009-12-15 15:35:38 -0800 | [diff] [blame] | 22 | return x |
Ken Thompson | 2181098 | 2008-03-28 13:56:47 -0700 | [diff] [blame] | 23 | } |