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







Bits error versus x







Bits error versus y







Bits error versus z







Bits error versus t
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
| Alternative 1 | |
|---|---|
| Accuracy | 0.0 |
| Cost | 832 |
| Alternative 2 | |
|---|---|
| Accuracy | 0.4 |
| Cost | 1280 |
| Alternative 3 | |
|---|---|
| Accuracy | 32.4 |
| Cost | 1088 |
Initial program 0.0
rmApplied *-un-lft-identity_binary64_232660.0
rmApplied *-un-lft-identity_binary64_232660.0
Applied associate-*l*_binary64_232070.0
rmApplied *-un-lft-identity_binary64_232660.0
Final simplification0.0
herbie shell --seed 2020322
(FPCore (x y z t)
:name "Data.Metrics.Snapshot:quantile from metrics-0.3.0.2"
:precision binary64
:herbie-target
(+ x (+ (* t (- y z)) (* (- x) (- y z))))
(+ x (* (- y z) (- t x))))