amath
1.8.5
Simple command line calculator
acsch.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 acsch.c
32
* @brief Inverse hyperbolic cosecant function
33
*/
34
35
#
include
"prim.h"
36
37
/**
38
* @brief Inverse hyperbolic cosecant function
39
* @details
40
* <pre>
41
* Method
42
* 1+sqrt(1+x*x)
43
* acsch(x) = ln( --------------- )
44
* x
45
* when x is 0
46
* acsch(x) = NaN
47
* </pre>
48
*/
49
double
acsch
(
double
x)
50
{
51
double
a, b, c, d, e, f;
52
53
if
(
TRIG_INEXACT
(x))
54
{
55
return
NAN
;
56
}
57
58
a = x * x;
59
b = a + 1.0;
60
c =
sqrt
(
b
)
;
61
d = 1.0 + c;
62
e = d / x;
63
f =
log
(
e
)
;
64
return
f;
65
}
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
acsch
double acsch(double x)
Inverse hyperbolic cosecant function.
Definition:
acsch.c:49
TRIG_INEXACT
#define TRIG_INEXACT(x)
Definition:
prim.h:48
NAN
#define NAN
Definition:
mathr.h:53
src
real
acsch.c
Generated by
1.8.13