\frac{\left(\frac{8}{3} \cdot \sin \left(x \cdot 0.5\right)\right) \cdot \sin \left(x \cdot 0.5\right)}{\sin x}\mathsf{log1p}\left(\mathsf{expm1}\left(\frac{\sin \left(x \cdot 0.5\right)}{\frac{3}{8}}\right)\right) \cdot \frac{\sin \left(x \cdot 0.5\right)}{\sin x}double f(double x) {
double r462775 = 8.0;
double r462776 = 3.0;
double r462777 = r462775 / r462776;
double r462778 = x;
double r462779 = 0.5;
double r462780 = r462778 * r462779;
double r462781 = sin(r462780);
double r462782 = r462777 * r462781;
double r462783 = r462782 * r462781;
double r462784 = sin(r462778);
double r462785 = r462783 / r462784;
return r462785;
}
double f(double x) {
double r462786 = x;
double r462787 = 0.5;
double r462788 = r462786 * r462787;
double r462789 = sin(r462788);
double r462790 = 3.0;
double r462791 = 8.0;
double r462792 = r462790 / r462791;
double r462793 = r462789 / r462792;
double r462794 = expm1(r462793);
double r462795 = log1p(r462794);
double r462796 = sin(r462786);
double r462797 = r462789 / r462796;
double r462798 = r462795 * r462797;
return r462798;
}




Bits error versus x
Results
| Original | 14.6 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
Initial program 14.6
rmApplied *-un-lft-identity14.6
Applied times-frac0.5
Simplified0.3
rmApplied pow10.3
rmApplied log1p-expm1-u0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019179 +o rules:numerics
(FPCore (x)
:name "Graphics.Rasterific.Svg.PathConverter:segmentToBezier from rasterific-svg-0.2.3.1, A"
:herbie-target
(/ (/ (* 8.0 (sin (* x 0.5))) 3.0) (/ (sin x) (sin (* x 0.5))))
(/ (* (* (/ 8.0 3.0) (sin (* x 0.5))) (sin (* x 0.5))) (sin x)))