\sin \left(x + \varepsilon\right) - \sin x
\mathsf{fma}\left(\sin x, \sqrt[3]{{\left(\frac{{\left(\cos \varepsilon\right)}^{3} - 1}{\mathsf{fma}\left(\cos \varepsilon, \cos \varepsilon + 1, 1\right)}\right)}^{3}}, \cos x \cdot \sin \varepsilon\right) + \mathsf{fma}\left(-\sin x, 1, \sin x \cdot 1\right)double f(double x, double eps) {
double r145479 = x;
double r145480 = eps;
double r145481 = r145479 + r145480;
double r145482 = sin(r145481);
double r145483 = sin(r145479);
double r145484 = r145482 - r145483;
return r145484;
}
double f(double x, double eps) {
double r145485 = x;
double r145486 = sin(r145485);
double r145487 = eps;
double r145488 = cos(r145487);
double r145489 = 3.0;
double r145490 = pow(r145488, r145489);
double r145491 = 1.0;
double r145492 = r145490 - r145491;
double r145493 = r145488 + r145491;
double r145494 = fma(r145488, r145493, r145491);
double r145495 = r145492 / r145494;
double r145496 = pow(r145495, r145489);
double r145497 = cbrt(r145496);
double r145498 = cos(r145485);
double r145499 = sin(r145487);
double r145500 = r145498 * r145499;
double r145501 = fma(r145486, r145497, r145500);
double r145502 = -r145486;
double r145503 = r145486 * r145491;
double r145504 = fma(r145502, r145491, r145503);
double r145505 = r145501 + r145504;
return r145505;
}




Bits error versus x




Bits error versus eps
| Original | 36.5 |
|---|---|
| Target | 14.8 |
| Herbie | 0.5 |
Initial program 36.5
rmApplied sin-sum21.6
Applied associate--l+21.6
rmApplied *-un-lft-identity21.6
Applied prod-diff21.6
Applied associate-+r+21.6
Simplified0.4
rmApplied flip3--0.4
Simplified0.4
Simplified0.4
rmApplied add-cbrt-cube0.5
Applied add-cbrt-cube0.5
Applied cbrt-undiv0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019362 +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)))