\sin \left(x + \varepsilon\right) - \sin x
\begin{array}{l}
\mathbf{if}\;\varepsilon \le -1.755630184432992 \cdot 10^{-08}:\\
\;\;\;\;\left(\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon\right) - \sin x\\
\mathbf{elif}\;\varepsilon \le 7.800526234462867 \cdot 10^{-25}:\\
\;\;\;\;2 \cdot \left(\sin \left(\frac{\varepsilon}{2}\right) \cdot \cos \left(\frac{x + \left(x + \varepsilon\right)}{2}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon\right) - \sin x\\
\end{array}double f(double x, double eps) {
double r4013477 = x;
double r4013478 = eps;
double r4013479 = r4013477 + r4013478;
double r4013480 = sin(r4013479);
double r4013481 = sin(r4013477);
double r4013482 = r4013480 - r4013481;
return r4013482;
}
double f(double x, double eps) {
double r4013483 = eps;
double r4013484 = -1.755630184432992e-08;
bool r4013485 = r4013483 <= r4013484;
double r4013486 = x;
double r4013487 = sin(r4013486);
double r4013488 = cos(r4013483);
double r4013489 = r4013487 * r4013488;
double r4013490 = cos(r4013486);
double r4013491 = sin(r4013483);
double r4013492 = r4013490 * r4013491;
double r4013493 = r4013489 + r4013492;
double r4013494 = r4013493 - r4013487;
double r4013495 = 7.800526234462867e-25;
bool r4013496 = r4013483 <= r4013495;
double r4013497 = 2.0;
double r4013498 = r4013483 / r4013497;
double r4013499 = sin(r4013498);
double r4013500 = r4013486 + r4013483;
double r4013501 = r4013486 + r4013500;
double r4013502 = r4013501 / r4013497;
double r4013503 = cos(r4013502);
double r4013504 = r4013499 * r4013503;
double r4013505 = r4013497 * r4013504;
double r4013506 = r4013496 ? r4013505 : r4013494;
double r4013507 = r4013485 ? r4013494 : r4013506;
return r4013507;
}




Bits error versus x




Bits error versus eps
Results
| Original | 37.1 |
|---|---|
| Target | 15.3 |
| Herbie | 0.7 |
if eps < -1.755630184432992e-08 or 7.800526234462867e-25 < eps Initial program 29.9
rmApplied sin-sum1.1
if -1.755630184432992e-08 < eps < 7.800526234462867e-25Initial program 45.1
rmApplied diff-sin45.1
Simplified0.3
Final simplification0.7
herbie shell --seed 2019135 +o rules:numerics
(FPCore (x eps)
:name "2sin (example 3.3)"
:herbie-target
(* 2 (* (cos (+ x (/ eps 2))) (sin (/ eps 2))))
(- (sin (+ x eps)) (sin x)))