factor/library/math/arc-trig-hyp.factor

25 lines
835 B
Factor

! Copyright (C) 2004, 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: math
USING: kernel math math-internals ;
! Inverse trigonometric functions:
! acos asec asin acosec atan acot
! Inverse hyperbolic functions:
! acosh asech asinh acosech atanh acoth
: acosh dup sq 1 - sqrt + log ; inline
: asech recip acosh ; inline
: asinh dup sq 1 + sqrt + log ; inline
: acosech recip asinh ; inline
: atanh dup 1 + swap 1 - neg / log 2 / ; inline
: acoth recip atanh ; inline
: <=1 ( x -- ? ) dup complex? [ drop f ] [ abs 1 <= ] ifte ; inline
: asin dup <=1 [ fasin ] [ i * asinh -i * ] ifte ; inline
: acos dup <=1 [ facos ] [ asin pi 2 / swap - ] ifte ; inline
: atan dup <=1 [ fatan ] [ i * atanh i * ] ifte ; inline
: asec recip acos ; inline
: acosec recip asin ; inline
: acot recip atan ; inline