amath
1.8.5
Simple command line calculator
aver.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 aver.c
32
* @brief Inverse versed sine function
33
*/
34
35
#
include
"prim.h"
36
37
/**
38
* @brief Inverse versed sine function
39
*/
40
double
aver
(
double
x)
41
{
42
double
a, b, c, d;
43
44
if
(x < 0.0 || x > 2.0)
45
{
46
return
NAN
;
47
}
48
49
a = 2.0 * x - x * x;
50
b =
sqrt
(
a
)
;
51
c = 1.0 - x;
52
53
if
(
TRIG_INEXACT
(c))
54
{
55
return
INFP
;
56
}
57
58
d =
atan
(
b / c
)
;
59
return
d;
60
}
sqrt
double sqrt(double x)
Square root function.
Definition:
sqrt.c:119
INFP
#define INFP
Definition:
mathr.h:51
TRIG_INEXACT
#define TRIG_INEXACT(x)
Definition:
prim.h:48
NAN
#define NAN
Definition:
mathr.h:53
atan
double atan(double x)
Inverse tangent function.
Definition:
atan.c:103
aver
double aver(double x)
Inverse versed sine function.
Definition:
aver.c:40
src
real
aver.c
Generated by
1.8.13