// 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 sine and cosine. | |
They are implemented by computing the arctangent | |
after appropriate range reduction. | |
*/ | |
// Asin returns the arcsine of x. | |
func Asin(x float64) float64 { | |
sign := false | |
if x < 0 { | |
x = -x | |
sign = true | |
} | |
if x > 1 { | |
return NaN() | |
} | |
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 of x. | |
func Acos(x float64) float64 { return Pi/2 - Asin(x) } |