\sin \left(x + \varepsilon\right) - \sin x
\mathsf{fma}\left(\sin x, \sqrt[3]{{\left(\cos \varepsilon - 1\right)}^{3}}, \cos x \cdot \sin \varepsilon\right)double f(double x, double eps) {
double r120187 = x;
double r120188 = eps;
double r120189 = r120187 + r120188;
double r120190 = sin(r120189);
double r120191 = sin(r120187);
double r120192 = r120190 - r120191;
return r120192;
}
double f(double x, double eps) {
double r120193 = x;
double r120194 = sin(r120193);
double r120195 = eps;
double r120196 = cos(r120195);
double r120197 = 1.0;
double r120198 = r120196 - r120197;
double r120199 = 3.0;
double r120200 = pow(r120198, r120199);
double r120201 = cbrt(r120200);
double r120202 = cos(r120193);
double r120203 = sin(r120195);
double r120204 = r120202 * r120203;
double r120205 = fma(r120194, r120201, r120204);
return r120205;
}




Bits error versus x




Bits error versus eps
| Original | 37.3 |
|---|---|
| Target | 15.3 |
| Herbie | 0.4 |
Initial program 37.3
rmApplied sin-sum21.9
Applied associate--l+21.9
Taylor expanded around inf 21.9
Simplified0.4
rmApplied add-cbrt-cube0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020049 +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)))