2010-12-03 12:34:57 +08: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
|
|
|
|
|
|
|
|
/*
|
|
|
|
Floating-point arcsine and arccosine.
|
|
|
|
|
|
|
|
They are implemented by computing the arctangent
|
|
|
|
after appropriate range reduction.
|
|
|
|
*/
|
|
|
|
|
2013-11-07 03:49:01 +08:00
|
|
|
// Asin returns the arcsine, in radians, of x.
|
2010-12-03 12:34:57 +08:00
|
|
|
//
|
|
|
|
// Special cases are:
|
|
|
|
// Asin(±0) = ±0
|
|
|
|
// Asin(x) = NaN if x < -1 or x > 1
|
|
|
|
func Asin(x float64) float64 {
|
2012-01-12 09:31:45 +08:00
|
|
|
return libc_asin(x)
|
|
|
|
}
|
|
|
|
|
2021-07-31 05:28:58 +08:00
|
|
|
//extern asin
|
|
|
|
func libc_asin(float64) float64
|
|
|
|
|
2012-01-12 09:31:45 +08:00
|
|
|
func asin(x float64) float64 {
|
2010-12-03 12:34:57 +08:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2013-11-07 03:49:01 +08:00
|
|
|
// Acos returns the arccosine, in radians, of x.
|
2010-12-03 12:34:57 +08:00
|
|
|
//
|
|
|
|
// Special case is:
|
|
|
|
// Acos(x) = NaN if x < -1 or x > 1
|
2012-01-12 09:31:45 +08:00
|
|
|
func Acos(x float64) float64 {
|
|
|
|
return libc_acos(x)
|
|
|
|
}
|
|
|
|
|
2021-07-31 05:28:58 +08:00
|
|
|
//extern acos
|
|
|
|
func libc_acos(float64) float64
|
|
|
|
|
2012-01-12 09:31:45 +08:00
|
|
|
func acos(x float64) float64 {
|
|
|
|
return Pi/2 - Asin(x)
|
|
|
|
}
|