\frac{\left(\frac{8}{3} \cdot \sin \left(x \cdot 0.5\right)\right) \cdot \sin \left(x \cdot 0.5\right)}{\sin x}\left(\frac{1}{\sqrt[3]{3} \cdot \sqrt[3]{3}} \cdot \left(\frac{8}{\sqrt[3]{3}} \cdot \sin \left(x \cdot 0.5\right)\right)\right) \cdot \frac{\sin \left(0.5 \cdot x\right)}{\sin x}double f(double x) {
double r547044 = 8.0;
double r547045 = 3.0;
double r547046 = r547044 / r547045;
double r547047 = x;
double r547048 = 0.5;
double r547049 = r547047 * r547048;
double r547050 = sin(r547049);
double r547051 = r547046 * r547050;
double r547052 = r547051 * r547050;
double r547053 = sin(r547047);
double r547054 = r547052 / r547053;
return r547054;
}
double f(double x) {
double r547055 = 1.0;
double r547056 = 3.0;
double r547057 = cbrt(r547056);
double r547058 = r547057 * r547057;
double r547059 = r547055 / r547058;
double r547060 = 8.0;
double r547061 = r547060 / r547057;
double r547062 = x;
double r547063 = 0.5;
double r547064 = r547062 * r547063;
double r547065 = sin(r547064);
double r547066 = r547061 * r547065;
double r547067 = r547059 * r547066;
double r547068 = r547063 * r547062;
double r547069 = sin(r547068);
double r547070 = sin(r547062);
double r547071 = r547069 / r547070;
double r547072 = r547067 * r547071;
return r547072;
}




Bits error versus x
Results
| Original | 14.8 |
|---|---|
| Target | 0.3 |
| Herbie | 0.6 |
Initial program 14.8
rmApplied *-un-lft-identity14.8
Applied times-frac0.5
Simplified0.5
Simplified0.5
rmApplied add-cube-cbrt0.5
Applied *-un-lft-identity0.5
Applied times-frac0.8
Applied associate-*l*0.6
Final simplification0.6
herbie shell --seed 2020039 +o rules:numerics
(FPCore (x)
:name "Graphics.Rasterific.Svg.PathConverter:segmentToBezier from rasterific-svg-0.2.3.1, A"
:precision binary64
:herbie-target
(/ (/ (* 8 (sin (* x 0.5))) 3) (/ (sin x) (sin (* x 0.5))))
(/ (* (* (/ 8 3) (sin (* x 0.5))) (sin (* x 0.5))) (sin x)))