gtsam
3rdparty
cephes
cephes
sinpi.c
Go to the documentation of this file.
1
/*
2
* Implement sin(pi * x) and cos(pi * x) for real x. Since the periods
3
* of these functions are integral (and thus representable in double
4
* precision), it's possible to compute them with greater accuracy
5
* than sin(x) and cos(x).
6
*/
7
#include "
mconf.h
"
8
9
10
/* Compute sin(pi * x). */
11
double
sinpi
(
double
x
)
12
{
13
double
s
= 1.0;
14
double
r;
15
16
if
(
x
< 0.0) {
17
x
= -
x
;
18
s
= -1.0;
19
}
20
21
r =
fmod
(
x
, 2.0);
22
if
(r < 0.5) {
23
return
s
*
sin
(
M_PI
*r);
24
}
25
else
if
(r > 1.5) {
26
return
s
*
sin
(
M_PI
*(r - 2.0));
27
}
28
else
{
29
return
-
s
*
sin
(
M_PI
*(r - 1.0));
30
}
31
}
32
33
34
/* Compute cos(pi * x) */
35
double
cospi
(
double
x
)
36
{
37
double
r;
38
39
if
(
x
< 0.0) {
40
x
= -
x
;
41
}
42
43
r =
fmod
(
x
, 2.0);
44
if
(r == 0.5) {
45
// We don't want to return -0.0
46
return
0.0;
47
}
48
if
(r < 1.0) {
49
return
-
sin
(
M_PI
*(r - 0.5));
50
}
51
else
{
52
return
sin
(
M_PI
*(r - 1.5));
53
}
54
}
s
RealScalar s
Definition:
level1_cplx_impl.h:126
ceres::sin
Jet< T, N > sin(const Jet< T, N > &f)
Definition:
jet.h:439
x
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy x
Definition:
gnuplot_common_settings.hh:12
Eigen::bfloat16_impl::fmod
EIGEN_STRONG_INLINE EIGEN_DEVICE_FUNC bfloat16 fmod(const bfloat16 &a, const bfloat16 &b)
Definition:
BFloat16.h:567
mconf.h
M_PI
#define M_PI
Definition:
mconf.h:117
cospi
double cospi(double x)
Definition:
sinpi.c:35
sinpi
double sinpi(double x)
Definition:
sinpi.c:11
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:04:13