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







Bits error versus x







Bits error versus y







Bits error versus z







Bits error versus t
Results
| Alternative 1 | |
|---|---|
| Error | 16.2 |
| Cost | 1361 |
| Alternative 2 | |
|---|---|
| Error | 30.8 |
| Cost | 192 |
| Alternative 3 | |
|---|---|
| Error | 61.1 |
| Cost | 64 |
| Alternative 4 | |
|---|---|
| Error | 61.7 |
| Cost | 64 |


Initial program 0.0
rmApplied flip--_binary64_823727.3
rmApplied *-un-lft-identity_binary64_826227.3
Applied *-un-lft-identity_binary64_826227.3
Applied times-frac_binary64_826827.3
Simplified27.3
Simplified0.0
rmApplied pow1_binary64_83230.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2021040
(FPCore (x y z t)
:name "Linear.V3:cross from linear-1.19.1.3"
:precision binary64
(- (* x y) (* z t)))