\sin \left(x + \varepsilon\right) - \sin x
\mathsf{fma}\left(\sin x, \mathsf{log1p}\left(\mathsf{expm1}\left(\cos \varepsilon - 1\right)\right), \cos x \cdot \sin \varepsilon\right)double f(double x, double eps) {
double r132129 = x;
double r132130 = eps;
double r132131 = r132129 + r132130;
double r132132 = sin(r132131);
double r132133 = sin(r132129);
double r132134 = r132132 - r132133;
return r132134;
}
double f(double x, double eps) {
double r132135 = x;
double r132136 = sin(r132135);
double r132137 = eps;
double r132138 = cos(r132137);
double r132139 = 1.0;
double r132140 = r132138 - r132139;
double r132141 = expm1(r132140);
double r132142 = log1p(r132141);
double r132143 = cos(r132135);
double r132144 = sin(r132137);
double r132145 = r132143 * r132144;
double r132146 = fma(r132136, r132142, r132145);
return r132146;
}




Bits error versus x




Bits error versus eps
| Original | 37.1 |
|---|---|
| Target | 14.6 |
| Herbie | 0.5 |
Initial program 37.1
rmApplied sin-sum22.3
rmApplied *-un-lft-identity22.3
Applied *-un-lft-identity22.3
Applied distribute-lft-out--22.3
Simplified0.4
rmApplied log1p-expm1-u0.5
Final simplification0.5
herbie shell --seed 2019346 +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)))