\frac{x - y}{z - y} \cdot t\frac{\sqrt[3]{x - y} \cdot \sqrt[3]{x - y}}{\sqrt[3]{z - y} \cdot \sqrt[3]{z - y}} \cdot \left(\frac{\sqrt[3]{x - y}}{\sqrt[3]{z - y}} \cdot t\right)double f(double x, double y, double z, double t) {
double r645958 = x;
double r645959 = y;
double r645960 = r645958 - r645959;
double r645961 = z;
double r645962 = r645961 - r645959;
double r645963 = r645960 / r645962;
double r645964 = t;
double r645965 = r645963 * r645964;
return r645965;
}
double f(double x, double y, double z, double t) {
double r645966 = x;
double r645967 = y;
double r645968 = r645966 - r645967;
double r645969 = cbrt(r645968);
double r645970 = r645969 * r645969;
double r645971 = z;
double r645972 = r645971 - r645967;
double r645973 = cbrt(r645972);
double r645974 = r645973 * r645973;
double r645975 = r645970 / r645974;
double r645976 = r645969 / r645973;
double r645977 = t;
double r645978 = r645976 * r645977;
double r645979 = r645975 * r645978;
return r645979;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.4 |
|---|---|
| Target | 2.3 |
| Herbie | 1.1 |
Initial program 2.4
rmApplied add-cube-cbrt3.4
Applied add-cube-cbrt3.1
Applied times-frac3.1
Applied associate-*l*1.1
Final simplification1.1
herbie shell --seed 2020046
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cput from hsignal-0.2.7.1"
:precision binary64
:herbie-target
(/ t (/ (- z y) (- x y)))
(* (/ (- x y) (- z y)) t))