\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 r19800123 = x;
double r19800124 = y;
double r19800125 = r19800123 - r19800124;
double r19800126 = z;
double r19800127 = r19800126 - r19800124;
double r19800128 = r19800125 / r19800127;
double r19800129 = t;
double r19800130 = r19800128 * r19800129;
return r19800130;
}
double f(double x, double y, double z, double t) {
double r19800131 = x;
double r19800132 = y;
double r19800133 = r19800131 - r19800132;
double r19800134 = cbrt(r19800133);
double r19800135 = r19800134 * r19800134;
double r19800136 = z;
double r19800137 = r19800136 - r19800132;
double r19800138 = cbrt(r19800137);
double r19800139 = r19800138 * r19800138;
double r19800140 = r19800135 / r19800139;
double r19800141 = r19800134 / r19800138;
double r19800142 = t;
double r19800143 = r19800141 * r19800142;
double r19800144 = r19800140 * r19800143;
return r19800144;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.4 |
|---|---|
| Target | 2.4 |
| 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 2019172 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cput from hsignal-0.2.7.1"
:herbie-target
(/ t (/ (- z y) (- x y)))
(* (/ (- x y) (- z y)) t))