x - \frac{y \cdot \left(z - t\right)}{a}x - \frac{y}{\frac{\sqrt[3]{a}}{\sqrt[3]{z - t}} \cdot \frac{\sqrt[3]{a}}{\sqrt[3]{z - t}}} \cdot \frac{\sqrt[3]{z - t}}{\sqrt[3]{a}}double f(double x, double y, double z, double t, double a) {
double r18253057 = x;
double r18253058 = y;
double r18253059 = z;
double r18253060 = t;
double r18253061 = r18253059 - r18253060;
double r18253062 = r18253058 * r18253061;
double r18253063 = a;
double r18253064 = r18253062 / r18253063;
double r18253065 = r18253057 - r18253064;
return r18253065;
}
double f(double x, double y, double z, double t, double a) {
double r18253066 = x;
double r18253067 = y;
double r18253068 = a;
double r18253069 = cbrt(r18253068);
double r18253070 = z;
double r18253071 = t;
double r18253072 = r18253070 - r18253071;
double r18253073 = cbrt(r18253072);
double r18253074 = r18253069 / r18253073;
double r18253075 = r18253074 * r18253074;
double r18253076 = r18253067 / r18253075;
double r18253077 = r18253073 / r18253069;
double r18253078 = r18253076 * r18253077;
double r18253079 = r18253066 - r18253078;
return r18253079;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.3 |
|---|---|
| Target | 0.8 |
| Herbie | 1.3 |
Initial program 6.3
rmApplied add-cube-cbrt6.8
Applied times-frac3.2
rmApplied *-un-lft-identity3.2
Applied cbrt-prod3.2
Applied add-cube-cbrt3.3
Applied times-frac3.3
Applied associate-*r*1.9
Simplified1.3
Final simplification1.3
herbie shell --seed 2019170
(FPCore (x y z t a)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, F"
:herbie-target
(if (< y -1.0761266216389975e-10) (- x (/ 1.0 (/ (/ a (- z t)) y))) (if (< y 2.894426862792089e-49) (- x (/ (* y (- z t)) a)) (- x (/ y (/ a (- z t))))))
(- x (/ (* y (- z t)) a)))