\frac{x}{y} \cdot \left(z - t\right) + t\left(\left(\frac{\sqrt[3]{z - t}}{\sqrt[3]{y}} \cdot x\right) \cdot \left(\frac{\sqrt[3]{z - t}}{\sqrt[3]{y}} \cdot \frac{\sqrt[3]{z - t}}{\sqrt[3]{y}}\right) + \frac{\mathsf{fma}\left(t, -1, t\right) \cdot x}{y}\right) + tdouble f(double x, double y, double z, double t) {
double r20674932 = x;
double r20674933 = y;
double r20674934 = r20674932 / r20674933;
double r20674935 = z;
double r20674936 = t;
double r20674937 = r20674935 - r20674936;
double r20674938 = r20674934 * r20674937;
double r20674939 = r20674938 + r20674936;
return r20674939;
}
double f(double x, double y, double z, double t) {
double r20674940 = z;
double r20674941 = t;
double r20674942 = r20674940 - r20674941;
double r20674943 = cbrt(r20674942);
double r20674944 = y;
double r20674945 = cbrt(r20674944);
double r20674946 = r20674943 / r20674945;
double r20674947 = x;
double r20674948 = r20674946 * r20674947;
double r20674949 = r20674946 * r20674946;
double r20674950 = r20674948 * r20674949;
double r20674951 = -1.0;
double r20674952 = fma(r20674941, r20674951, r20674941);
double r20674953 = r20674952 * r20674947;
double r20674954 = r20674953 / r20674944;
double r20674955 = r20674950 + r20674954;
double r20674956 = r20674955 + r20674941;
return r20674956;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 2.1 |
|---|---|
| Target | 2.3 |
| Herbie | 1.6 |
Initial program 2.1
rmApplied add-cube-cbrt2.2
Applied add-sqr-sqrt32.8
Applied prod-diff32.8
Applied distribute-lft-in32.8
Simplified2.1
Simplified2.0
rmApplied *-un-lft-identity2.0
Applied add-cube-cbrt2.6
Applied times-frac2.6
Applied add-cube-cbrt2.7
Applied times-frac1.8
Simplified1.9
Simplified1.6
Final simplification1.6
herbie shell --seed 2019174 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cget from hsignal-0.2.7.1"
:herbie-target
(if (< z 2.759456554562692e-282) (+ (* (/ x y) (- z t)) t) (if (< z 2.326994450874436e-110) (+ (* x (/ (- z t) y)) t) (+ (* (/ x y) (- z t)) t)))
(+ (* (/ x y) (- z t)) t))