\sin \left(x + \varepsilon\right) - \sin x
\begin{array}{l}
\mathbf{if}\;\varepsilon \le -8.78183908127777317 \cdot 10^{-9} \lor \neg \left(\varepsilon \le 1.19054048034770088 \cdot 10^{-8}\right):\\
\;\;\;\;\left(\sin x \cdot \cos \varepsilon + \cos x \cdot \sin \varepsilon\right) - \sin x\\
\mathbf{else}:\\
\;\;\;\;2 \cdot \left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \cos \left(\frac{1}{2} \cdot \mathsf{fma}\left(x, 2, \varepsilon\right)\right)\right)\\
\end{array}double f(double x, double eps) {
double r169694 = x;
double r169695 = eps;
double r169696 = r169694 + r169695;
double r169697 = sin(r169696);
double r169698 = sin(r169694);
double r169699 = r169697 - r169698;
return r169699;
}
double f(double x, double eps) {
double r169700 = eps;
double r169701 = -8.781839081277773e-09;
bool r169702 = r169700 <= r169701;
double r169703 = 1.1905404803477009e-08;
bool r169704 = r169700 <= r169703;
double r169705 = !r169704;
bool r169706 = r169702 || r169705;
double r169707 = x;
double r169708 = sin(r169707);
double r169709 = cos(r169700);
double r169710 = r169708 * r169709;
double r169711 = cos(r169707);
double r169712 = sin(r169700);
double r169713 = r169711 * r169712;
double r169714 = r169710 + r169713;
double r169715 = r169714 - r169708;
double r169716 = 2.0;
double r169717 = 0.5;
double r169718 = r169717 * r169700;
double r169719 = sin(r169718);
double r169720 = fma(r169707, r169716, r169700);
double r169721 = r169717 * r169720;
double r169722 = cos(r169721);
double r169723 = r169719 * r169722;
double r169724 = r169716 * r169723;
double r169725 = r169706 ? r169715 : r169724;
return r169725;
}




Bits error versus x




Bits error versus eps
| Original | 37.1 |
|---|---|
| Target | 15.2 |
| Herbie | 0.4 |
if eps < -8.781839081277773e-09 or 1.1905404803477009e-08 < eps Initial program 30.1
rmApplied sin-sum0.5
if -8.781839081277773e-09 < eps < 1.1905404803477009e-08Initial program 44.4
rmApplied diff-sin44.4
Simplified0.3
rmApplied expm1-log1p-u0.4
Simplified0.4
Taylor expanded around inf 0.3
Final simplification0.4
herbie shell --seed 2020046 +o rules:numerics
(FPCore (x eps)
:name "2sin (example 3.3)"
:precision binary64
:herbie-target
(* 2 (* (cos (+ x (/ eps 2))) (sin (/ eps 2))))
(- (sin (+ x eps)) (sin x)))