\frac{x}{y} \cdot \left(z - t\right) + t\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\sqrt[3]{y} \cdot \sqrt[3]{y}} \cdot \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}} \cdot \left(z - t\right)\right) + tdouble f(double x, double y, double z, double t) {
double r264615 = x;
double r264616 = y;
double r264617 = r264615 / r264616;
double r264618 = z;
double r264619 = t;
double r264620 = r264618 - r264619;
double r264621 = r264617 * r264620;
double r264622 = r264621 + r264619;
return r264622;
}
double f(double x, double y, double z, double t) {
double r264623 = x;
double r264624 = cbrt(r264623);
double r264625 = r264624 * r264624;
double r264626 = y;
double r264627 = cbrt(r264626);
double r264628 = r264627 * r264627;
double r264629 = r264625 / r264628;
double r264630 = r264624 / r264627;
double r264631 = z;
double r264632 = t;
double r264633 = r264631 - r264632;
double r264634 = r264630 * r264633;
double r264635 = r264629 * r264634;
double r264636 = r264635 + r264632;
return r264636;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.2 |
|---|---|
| Target | 2.4 |
| Herbie | 1.0 |
Initial program 2.2
rmApplied add-cube-cbrt2.7
Applied add-cube-cbrt2.9
Applied times-frac2.9
Applied associate-*l*1.0
Final simplification1.0
herbie shell --seed 2019323 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cget from hsignal-0.2.7.1"
:precision binary64
:herbie-target
(if (< z 2.759456554562692e-282) (+ (* (/ x y) (- z t)) t) (if (< z 2.326994450874436e-110) (+ (* x (/ (- z t) y)) t) (+ (* (/ x y) (- z t)) t)))
(+ (* (/ x y) (- z t)) t))