\sin \left(x + \varepsilon\right) - \sin x
\sin x \cdot \frac{{\left(\cos \varepsilon\right)}^{3} - 1}{\cos \varepsilon \cdot \left(\cos \varepsilon + 1\right) + 1} + \cos x \cdot \sin \varepsilondouble f(double x, double eps) {
double r153736 = x;
double r153737 = eps;
double r153738 = r153736 + r153737;
double r153739 = sin(r153738);
double r153740 = sin(r153736);
double r153741 = r153739 - r153740;
return r153741;
}
double f(double x, double eps) {
double r153742 = x;
double r153743 = sin(r153742);
double r153744 = eps;
double r153745 = cos(r153744);
double r153746 = 3.0;
double r153747 = pow(r153745, r153746);
double r153748 = 1.0;
double r153749 = r153747 - r153748;
double r153750 = r153745 + r153748;
double r153751 = r153745 * r153750;
double r153752 = r153751 + r153748;
double r153753 = r153749 / r153752;
double r153754 = r153743 * r153753;
double r153755 = cos(r153742);
double r153756 = sin(r153744);
double r153757 = r153755 * r153756;
double r153758 = r153754 + r153757;
return r153758;
}




Bits error versus x




Bits error versus eps
Results
| Original | 36.5 |
|---|---|
| Target | 14.8 |
| Herbie | 0.4 |
Initial program 36.5
rmApplied sin-sum21.6
Applied associate--l+21.6
Taylor expanded around inf 21.6
Simplified0.4
rmApplied flip3--0.4
Simplified0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019362
(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)))