\sin \left(x + \varepsilon\right) - \sin x
\begin{array}{l}
\mathbf{if}\;\varepsilon \le -4.4887063267839754 \cdot 10^{-09}:\\
\;\;\;\;\left(\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon\right) - \sin x\\
\mathbf{elif}\;\varepsilon \le 1.2991744042388225 \cdot 10^{-08}:\\
\;\;\;\;2 \cdot \left(\sin \left(\frac{\varepsilon}{2}\right) \cdot \cos \left(\frac{x + \left(x + \varepsilon\right)}{2}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\cos x \cdot \sin \varepsilon - \sin x\right) + \sin x \cdot \cos \varepsilon\\
\end{array}double f(double x, double eps) {
double r3234803 = x;
double r3234804 = eps;
double r3234805 = r3234803 + r3234804;
double r3234806 = sin(r3234805);
double r3234807 = sin(r3234803);
double r3234808 = r3234806 - r3234807;
return r3234808;
}
double f(double x, double eps) {
double r3234809 = eps;
double r3234810 = -4.4887063267839754e-09;
bool r3234811 = r3234809 <= r3234810;
double r3234812 = x;
double r3234813 = sin(r3234812);
double r3234814 = cos(r3234809);
double r3234815 = r3234813 * r3234814;
double r3234816 = cos(r3234812);
double r3234817 = sin(r3234809);
double r3234818 = r3234816 * r3234817;
double r3234819 = r3234815 + r3234818;
double r3234820 = r3234819 - r3234813;
double r3234821 = 1.2991744042388225e-08;
bool r3234822 = r3234809 <= r3234821;
double r3234823 = 2.0;
double r3234824 = r3234809 / r3234823;
double r3234825 = sin(r3234824);
double r3234826 = r3234812 + r3234809;
double r3234827 = r3234812 + r3234826;
double r3234828 = r3234827 / r3234823;
double r3234829 = cos(r3234828);
double r3234830 = r3234825 * r3234829;
double r3234831 = r3234823 * r3234830;
double r3234832 = r3234818 - r3234813;
double r3234833 = r3234832 + r3234815;
double r3234834 = r3234822 ? r3234831 : r3234833;
double r3234835 = r3234811 ? r3234820 : r3234834;
return r3234835;
}




Bits error versus x




Bits error versus eps
Results
| Original | 37.2 |
|---|---|
| Target | 15.1 |
| Herbie | 0.4 |
if eps < -4.4887063267839754e-09Initial program 30.2
rmApplied sin-sum0.5
if -4.4887063267839754e-09 < eps < 1.2991744042388225e-08Initial program 44.4
rmApplied diff-sin44.4
Simplified0.3
if 1.2991744042388225e-08 < eps Initial program 30.2
rmApplied sin-sum0.5
Applied associate--l+0.5
Final simplification0.4
herbie shell --seed 2019137
(FPCore (x eps)
:name "2sin (example 3.3)"
:herbie-target
(* 2 (* (cos (+ x (/ eps 2))) (sin (/ eps 2))))
(- (sin (+ x eps)) (sin x)))