amath
1.8.5
Simple command line calculator
asech.c
Go to the documentation of this file.
1
/*-
2
* Copyright (c) 2014-2018 Carsten Sonne Larsen <cs@innolan.net>
3
* All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
7
* are met:
8
* 1. Redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer.
10
* 2. Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
*
14
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
15
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
18
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24
*
25
* Project homepage:
26
* https://amath.innolan.net
27
*
28
*/
29
30
/**
31
* @file asech.c
32
* @brief Inverse hyperbolic secant function
33
*/
34
35
#
include
"prim.h"
36
37
/**
38
* @brief Inverse hyperbolic secant function
39
* @details
40
* <pre>
41
* Method
42
* 1+sqrt(1-x*x)
43
* asech(x) = ln( --------------- )
44
* x
45
* when x <= 0
46
* asech(x) = NaN
47
*
48
* when x > 1
49
* asech(x) = NaN
50
* </pre>
51
*/
52
double
asech
(
double
x)
53
{
54
double
a, b, c, d, e, f;
55
56
if
(
TRIG_INEXACT
(x) || x < 0.0 || x > 1.0)
57
{
58
return
NAN
;
59
}
60
61
a = x * x;
62
b = 1.0 - a;
63
c =
sqrt
(
b
)
;
64
d = 1.0 + c;
65
e = d / x;
66
f =
log
(
e
)
;
67
return
f;
68
}
log
double log(double x)
Natural logarithm function (base e)
Definition:
log.c:109
sqrt
double sqrt(double x)
Square root function.
Definition:
sqrt.c:119
asech
double asech(double x)
Inverse hyperbolic secant function.
Definition:
asech.c:52
TRIG_INEXACT
#define TRIG_INEXACT(x)
Definition:
prim.h:48
NAN
#define NAN
Definition:
mathr.h:53
src
real
asech.c
Generated by
1.8.13