\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)}\frac{1}{\frac{y + z \cdot \left(b - y\right)}{y \cdot x + z \cdot \left(t - a\right)}}(FPCore (x y z t a b) :precision binary64 (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))))
(FPCore (x y z t a b) :precision binary64 (/ 1.0 (/ (+ y (* z (- b y))) (+ (* y x) (* z (- t a))))))
double code(double x, double y, double z, double t, double a, double b) {
return (((double) (((double) (x * y)) + ((double) (z * ((double) (t - a)))))) / ((double) (y + ((double) (z * ((double) (b - y)))))));
}
double code(double x, double y, double z, double t, double a, double b) {
return (1.0 / (((double) (y + ((double) (z * ((double) (b - y)))))) / ((double) (((double) (y * x)) + ((double) (z * ((double) (t - a))))))));
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
Results
| Original | 22.9 |
|---|---|
| Target | 17.7 |
| Herbie | 23.0 |
Initial program Error: 22.9 bits
rmApplied clear-numError: 23.0 bits
Final simplificationError: 23.0 bits
herbie shell --seed 2020203
(FPCore (x y z t a b)
:name "Development.Shake.Progress:decay from shake-0.15.5"
:precision binary64
:herbie-target
(- (/ (+ (* z t) (* y x)) (+ y (* z (- b y)))) (/ a (+ (- b y) (/ y z))))
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))))