\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\frac{\sqrt[3]{x}}{\sqrt[3]{y - z} \cdot \sqrt[3]{y - z}} \cdot \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y - z}} \cdot \frac{\sqrt[3]{x}}{t - z}\right)double f(double x, double y, double z, double t) {
double r913810 = x;
double r913811 = y;
double r913812 = z;
double r913813 = r913811 - r913812;
double r913814 = t;
double r913815 = r913814 - r913812;
double r913816 = r913813 * r913815;
double r913817 = r913810 / r913816;
return r913817;
}
double f(double x, double y, double z, double t) {
double r913818 = x;
double r913819 = cbrt(r913818);
double r913820 = y;
double r913821 = z;
double r913822 = r913820 - r913821;
double r913823 = cbrt(r913822);
double r913824 = r913823 * r913823;
double r913825 = r913819 / r913824;
double r913826 = r913819 / r913823;
double r913827 = t;
double r913828 = r913827 - r913821;
double r913829 = r913819 / r913828;
double r913830 = r913826 * r913829;
double r913831 = r913825 * r913830;
return r913831;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.3 |
|---|---|
| Target | 8.2 |
| Herbie | 1.2 |
Initial program 7.3
rmApplied add-cube-cbrt7.9
Applied times-frac1.7
rmApplied add-cube-cbrt1.9
Applied times-frac1.9
Applied associate-*l*1.2
Final simplification1.2
herbie shell --seed 2020060 +o rules:numerics
(FPCore (x y z t)
:name "Data.Random.Distribution.Triangular:triangularCDF from random-fu-0.2.6.2, B"
:precision binary64
:herbie-target
(if (< (/ x (* (- y z) (- t z))) 0.0) (/ (/ x (- y z)) (- t z)) (* x (/ 1 (* (- y z) (- t z)))))
(/ x (* (- y z) (- t z))))