// 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 /* Floating-point arcsine and arccosine. They are implemented by computing the arctangent after appropriate range reduction. */ // Asin returns the arcsine, in radians, of x. // // Special cases are: // // Asin(±0) = ±0 // Asin(x) = NaN if x < -1 or x > 1 func Asin(x float64) float64 { if haveArchAsin { return archAsin(x) } return asin(x) } func asin(x float64) float64 { if x == 0 { return x // special case } sign := false if x < 0 { x = -x sign = true } if x > 1 { return NaN() // special case } temp := Sqrt(1 - x*x) if x > 0.7 { temp = Pi/2 - satan(temp/x) } else { temp = satan(x / temp) } if sign { temp = -temp } return temp } // Acos returns the arccosine, in radians, of x. // // Special case is: // // Acos(x) = NaN if x < -1 or x > 1 func Acos(x float64) float64 { if haveArchAcos { return archAcos(x) } return acos(x) } func acos(x float64) float64 { return Pi/2 - Asin(x) }