diff options
author | Jakob Kaivo <jkk@ung.org> | 2019-02-08 18:42:39 -0500 |
---|---|---|
committer | Jakob Kaivo <jkk@ung.org> | 2019-02-08 18:42:39 -0500 |
commit | 7ef8a7379f7f7d09e71ccae2a0b688c3cd80423f (patch) | |
tree | 092ab0aed1769117fd7b28b8592f6f96b0e0d5af /src/math/cos.c | |
parent | 6acf19370e8adff79cd83b257d3f04aeaf2a59dd (diff) |
merge sources into single tree
Diffstat (limited to 'src/math/cos.c')
-rw-r--r-- | src/math/cos.c | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/math/cos.c b/src/math/cos.c new file mode 100644 index 00000000..0690b6ee --- /dev/null +++ b/src/math/cos.c @@ -0,0 +1,51 @@ +# define TGSOURCE "cos.c" +#include <math.h> +#include "nonstd/tgmath.h" +#include "errno.h" + +/** cosine **/ +TYPE TGFN(cos)(TYPE x) +{ + int MAXLOOPS = 10; + int factorial = 1; + int i; + TYPE cosine = 1.0; + TYPE power = 1.0; + + if (0) { + errno = ERANGE; /* The result cannot be represented */ + /* RETURN_FAILURE(CONSTANT(HUGE_VAL), A range error occurred); */ + return TGHUGE; + } + + /* TODO: make sure x is in the right domain */ + /* TODO: tweak number of loops */ + + /* cos x = 1 - x^2/2! + x^4/4! -x^6/6! ... */ + for (i = 1; i < MAXLOOPS; i++) { + power = power * x; + factorial = factorial * i; + + if (i % 4 == 0) { + cosine += power / factorial; + } else if (i % 4 == 2) { + cosine -= power / factorial; + } + } + + /* RETURN_SUCCESS(the cosine of ARGUMENT(x)); */ + return cosine; +} + +/*** +compute cosine of ARGUMENT(x), in radians. +***/ + +/* +IMPLEMENTATION(The value returned on a domain error, CONSTANT(HUGE_VAL)) +LINK(m) +*/ +/* +STDC(1) +*/ + |