x + \frac{y \cdot \left(z - x\right)}{t}x + \frac{\frac{\frac{y}{\sqrt[3]{t}}}{\sqrt[3]{t}}}{\sqrt[3]{\sqrt[3]{t}} \cdot \sqrt[3]{\sqrt[3]{t}}} \cdot \frac{z - x}{\sqrt[3]{\sqrt[3]{t}}}double f(double x, double y, double z, double t) {
double r25269106 = x;
double r25269107 = y;
double r25269108 = z;
double r25269109 = r25269108 - r25269106;
double r25269110 = r25269107 * r25269109;
double r25269111 = t;
double r25269112 = r25269110 / r25269111;
double r25269113 = r25269106 + r25269112;
return r25269113;
}
double f(double x, double y, double z, double t) {
double r25269114 = x;
double r25269115 = y;
double r25269116 = t;
double r25269117 = cbrt(r25269116);
double r25269118 = r25269115 / r25269117;
double r25269119 = r25269118 / r25269117;
double r25269120 = cbrt(r25269117);
double r25269121 = r25269120 * r25269120;
double r25269122 = r25269119 / r25269121;
double r25269123 = z;
double r25269124 = r25269123 - r25269114;
double r25269125 = r25269124 / r25269120;
double r25269126 = r25269122 * r25269125;
double r25269127 = r25269114 + r25269126;
return r25269127;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.8 |
|---|---|
| Target | 1.9 |
| Herbie | 2.7 |
Initial program 6.8
rmApplied add-cube-cbrt7.3
Applied times-frac2.9
rmApplied *-un-lft-identity2.9
Applied cbrt-prod2.9
Applied *-un-lft-identity2.9
Applied times-frac2.9
Applied associate-*r*2.9
Simplified2.9
rmApplied add-cube-cbrt3.1
Applied *-un-lft-identity3.1
Applied times-frac3.1
Applied associate-*r*2.7
Simplified2.7
Final simplification2.7
herbie shell --seed 2019174
(FPCore (x y z t)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, D"
:herbie-target
(- x (+ (* x (/ y t)) (* (- z) (/ y t))))
(+ x (/ (* y (- z x)) t)))