\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\frac{\sqrt[3]{\left(y - z\right) + 1} \cdot \sqrt[3]{\left(y - z\right) + 1}}{\sqrt[3]{z} \cdot \sqrt[3]{z}} \cdot \frac{x}{\frac{\sqrt[3]{z}}{\sqrt[3]{\left(y - z\right) + 1}}}double f(double x, double y, double z) {
double r593645 = x;
double r593646 = y;
double r593647 = z;
double r593648 = r593646 - r593647;
double r593649 = 1.0;
double r593650 = r593648 + r593649;
double r593651 = r593645 * r593650;
double r593652 = r593651 / r593647;
return r593652;
}
double f(double x, double y, double z) {
double r593653 = y;
double r593654 = z;
double r593655 = r593653 - r593654;
double r593656 = 1.0;
double r593657 = r593655 + r593656;
double r593658 = cbrt(r593657);
double r593659 = r593658 * r593658;
double r593660 = cbrt(r593654);
double r593661 = r593660 * r593660;
double r593662 = r593659 / r593661;
double r593663 = x;
double r593664 = r593660 / r593658;
double r593665 = r593663 / r593664;
double r593666 = r593662 * r593665;
return r593666;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 10.2 |
|---|---|
| Target | 0.6 |
| Herbie | 1.4 |
Initial program 10.2
rmApplied associate-/l*3.1
rmApplied add-cube-cbrt3.9
Applied add-cube-cbrt3.8
Applied times-frac3.8
Applied *-un-lft-identity3.8
Applied times-frac1.4
Simplified1.4
Final simplification1.4
herbie shell --seed 2020039 +o rules:numerics
(FPCore (x y z)
:name "Diagrams.TwoD.Segment.Bernstein:evaluateBernstein from diagrams-lib-1.3.0.3"
:precision binary64
:herbie-target
(if (< x -2.71483106713436e-162) (- (* (+ 1 y) (/ x z)) x) (if (< x 3.874108816439546e-197) (* (* x (+ (- y z) 1)) (/ 1 z)) (- (* (+ 1 y) (/ x z)) x)))
(/ (* x (+ (- y z) 1)) z))