| Alternative 1 | |
|---|---|
| Accuracy | 98.1% |
| Cost | 7360 |
\[\mathsf{fma}\left(x, y, \frac{z}{\frac{16}{t}}\right) + \left(c - \frac{a}{\frac{4}{b}}\right)
\]

(FPCore (x y z t a b c) :precision binary64 (+ (- (+ (* x y) (/ (* z t) 16.0)) (/ (* a b) 4.0)) c))
(FPCore (x y z t a b c) :precision binary64 (fma t (/ z 16.0) (fma x y (- c (* b (/ a 4.0))))))
double code(double x, double y, double z, double t, double a, double b, double c) {
return (((x * y) + ((z * t) / 16.0)) - ((a * b) / 4.0)) + c;
}
double code(double x, double y, double z, double t, double a, double b, double c) {
return fma(t, (z / 16.0), fma(x, y, (c - (b * (a / 4.0)))));
}
function code(x, y, z, t, a, b, c) return Float64(Float64(Float64(Float64(x * y) + Float64(Float64(z * t) / 16.0)) - Float64(Float64(a * b) / 4.0)) + c) end
function code(x, y, z, t, a, b, c) return fma(t, Float64(z / 16.0), fma(x, y, Float64(c - Float64(b * Float64(a / 4.0))))) end
code[x_, y_, z_, t_, a_, b_, c_] := N[(N[(N[(N[(x * y), $MachinePrecision] + N[(N[(z * t), $MachinePrecision] / 16.0), $MachinePrecision]), $MachinePrecision] - N[(N[(a * b), $MachinePrecision] / 4.0), $MachinePrecision]), $MachinePrecision] + c), $MachinePrecision]
code[x_, y_, z_, t_, a_, b_, c_] := N[(t * N[(z / 16.0), $MachinePrecision] + N[(x * y + N[(c - N[(b * N[(a / 4.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\left(\left(x \cdot y + \frac{z \cdot t}{16}\right) - \frac{a \cdot b}{4}\right) + c
\mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, c - b \cdot \frac{a}{4}\right)\right)
Herbie found 16 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Initial program 98.8%
Simplified99.6%
[Start]98.8 | \[ \left(\left(x \cdot y + \frac{z \cdot t}{16}\right) - \frac{a \cdot b}{4}\right) + c
\] |
|---|---|
associate-+l- [=>]98.8 | \[ \color{blue}{\left(x \cdot y + \frac{z \cdot t}{16}\right) - \left(\frac{a \cdot b}{4} - c\right)}
\] |
+-commutative [=>]98.8 | \[ \color{blue}{\left(\frac{z \cdot t}{16} + x \cdot y\right)} - \left(\frac{a \cdot b}{4} - c\right)
\] |
associate--l+ [=>]98.8 | \[ \color{blue}{\frac{z \cdot t}{16} + \left(x \cdot y - \left(\frac{a \cdot b}{4} - c\right)\right)}
\] |
associate-*l/ [<=]98.8 | \[ \color{blue}{\frac{z}{16} \cdot t} + \left(x \cdot y - \left(\frac{a \cdot b}{4} - c\right)\right)
\] |
*-commutative [=>]98.8 | \[ \color{blue}{t \cdot \frac{z}{16}} + \left(x \cdot y - \left(\frac{a \cdot b}{4} - c\right)\right)
\] |
fma-def [=>]99.6 | \[ \color{blue}{\mathsf{fma}\left(t, \frac{z}{16}, x \cdot y - \left(\frac{a \cdot b}{4} - c\right)\right)}
\] |
fma-neg [=>]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \color{blue}{\mathsf{fma}\left(x, y, -\left(\frac{a \cdot b}{4} - c\right)\right)}\right)
\] |
neg-sub0 [=>]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, \color{blue}{0 - \left(\frac{a \cdot b}{4} - c\right)}\right)\right)
\] |
associate-+l- [<=]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, \color{blue}{\left(0 - \frac{a \cdot b}{4}\right) + c}\right)\right)
\] |
neg-sub0 [<=]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, \color{blue}{\left(-\frac{a \cdot b}{4}\right)} + c\right)\right)
\] |
+-commutative [=>]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, \color{blue}{c + \left(-\frac{a \cdot b}{4}\right)}\right)\right)
\] |
unsub-neg [=>]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, \color{blue}{c - \frac{a \cdot b}{4}}\right)\right)
\] |
*-commutative [=>]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, c - \frac{\color{blue}{b \cdot a}}{4}\right)\right)
\] |
associate-*r/ [<=]99.6 | \[ \mathsf{fma}\left(t, \frac{z}{16}, \mathsf{fma}\left(x, y, c - \color{blue}{b \cdot \frac{a}{4}}\right)\right)
\] |
Final simplification99.6%
| Alternative 1 | |
|---|---|
| Accuracy | 98.1% |
| Cost | 7360 |
| Alternative 2 | |
|---|---|
| Accuracy | 64.3% |
| Cost | 3308 |
| Alternative 3 | |
|---|---|
| Accuracy | 66.3% |
| Cost | 3048 |
| Alternative 4 | |
|---|---|
| Accuracy | 62.4% |
| Cost | 1488 |
| Alternative 5 | |
|---|---|
| Accuracy | 36.4% |
| Cost | 1380 |
| Alternative 6 | |
|---|---|
| Accuracy | 60.4% |
| Cost | 1372 |
| Alternative 7 | |
|---|---|
| Accuracy | 62.0% |
| Cost | 1360 |
| Alternative 8 | |
|---|---|
| Accuracy | 87.9% |
| Cost | 1352 |
| Alternative 9 | |
|---|---|
| Accuracy | 89.4% |
| Cost | 1352 |
| Alternative 10 | |
|---|---|
| Accuracy | 85.9% |
| Cost | 1225 |
| Alternative 11 | |
|---|---|
| Accuracy | 87.9% |
| Cost | 1225 |
| Alternative 12 | |
|---|---|
| Accuracy | 97.8% |
| Cost | 1088 |
| Alternative 13 | |
|---|---|
| Accuracy | 36.4% |
| Cost | 984 |
| Alternative 14 | |
|---|---|
| Accuracy | 35.7% |
| Cost | 456 |
| Alternative 15 | |
|---|---|
| Accuracy | 22.3% |
| Cost | 64 |
herbie shell --seed 2023160
(FPCore (x y z t a b c)
:name "Diagrams.Solve.Polynomial:quartForm from diagrams-solve-0.1, C"
:precision binary64
(+ (- (+ (* x y) (/ (* z t) 16.0)) (/ (* a b) 4.0)) c))