| Alternative 1 | |
|---|---|
| Accuracy | 99.4% |
| Cost | 7232 |
\[\mathsf{fma}\left(x, \frac{1}{y}, -2 + \frac{2 + \frac{2}{z}}{t}\right)
\]

(FPCore (x y z t) :precision binary64 (+ (/ x y) (/ (+ 2.0 (* (* z 2.0) (- 1.0 t))) (* t z))))
(FPCore (x y z t) :precision binary64 (fma x (/ 1.0 y) (+ -2.0 (/ (+ 2.0 (/ 2.0 z)) t))))
double code(double x, double y, double z, double t) {
return (x / y) + ((2.0 + ((z * 2.0) * (1.0 - t))) / (t * z));
}
double code(double x, double y, double z, double t) {
return fma(x, (1.0 / y), (-2.0 + ((2.0 + (2.0 / z)) / t)));
}
function code(x, y, z, t) return Float64(Float64(x / y) + Float64(Float64(2.0 + Float64(Float64(z * 2.0) * Float64(1.0 - t))) / Float64(t * z))) end
function code(x, y, z, t) return fma(x, Float64(1.0 / y), Float64(-2.0 + Float64(Float64(2.0 + Float64(2.0 / z)) / t))) end
code[x_, y_, z_, t_] := N[(N[(x / y), $MachinePrecision] + N[(N[(2.0 + N[(N[(z * 2.0), $MachinePrecision] * N[(1.0 - t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t * z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
code[x_, y_, z_, t_] := N[(x * N[(1.0 / y), $MachinePrecision] + N[(-2.0 + N[(N[(2.0 + N[(2.0 / z), $MachinePrecision]), $MachinePrecision] / t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\frac{x}{y} + \frac{2 + \left(z \cdot 2\right) \cdot \left(1 - t\right)}{t \cdot z}
\mathsf{fma}\left(x, \frac{1}{y}, -2 + \frac{2 + \frac{2}{z}}{t}\right)
Herbie found 11 alternatives:
| Alternative | Accuracy | Speedup |
|---|
| Original | 86.9% |
|---|---|
| Target | 99.2% |
| Herbie | 99.4% |
Initial program 86.2%
Simplified99.2%
[Start]86.2% | \[ \frac{x}{y} + \frac{2 + \left(z \cdot 2\right) \cdot \left(1 - t\right)}{t \cdot z}
\] |
|---|---|
sub-neg [=>]86.2% | \[ \frac{x}{y} + \frac{2 + \left(z \cdot 2\right) \cdot \color{blue}{\left(1 + \left(-t\right)\right)}}{t \cdot z}
\] |
distribute-rgt-in [=>]86.2% | \[ \frac{x}{y} + \frac{2 + \color{blue}{\left(1 \cdot \left(z \cdot 2\right) + \left(-t\right) \cdot \left(z \cdot 2\right)\right)}}{t \cdot z}
\] |
*-lft-identity [=>]86.2% | \[ \frac{x}{y} + \frac{2 + \left(\color{blue}{z \cdot 2} + \left(-t\right) \cdot \left(z \cdot 2\right)\right)}{t \cdot z}
\] |
associate-+r+ [=>]86.2% | \[ \frac{x}{y} + \frac{\color{blue}{\left(2 + z \cdot 2\right) + \left(-t\right) \cdot \left(z \cdot 2\right)}}{t \cdot z}
\] |
cancel-sign-sub-inv [<=]86.2% | \[ \frac{x}{y} + \frac{\color{blue}{\left(2 + z \cdot 2\right) - t \cdot \left(z \cdot 2\right)}}{t \cdot z}
\] |
div-sub [=>]78.0% | \[ \frac{x}{y} + \color{blue}{\left(\frac{2 + z \cdot 2}{t \cdot z} - \frac{t \cdot \left(z \cdot 2\right)}{t \cdot z}\right)}
\] |
associate-*r* [=>]78.0% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} - \frac{\color{blue}{\left(t \cdot z\right) \cdot 2}}{t \cdot z}\right)
\] |
associate-*l/ [<=]78.0% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} - \color{blue}{\frac{t \cdot z}{t \cdot z} \cdot 2}\right)
\] |
*-inverses [=>]99.1% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} - \color{blue}{1} \cdot 2\right)
\] |
metadata-eval [=>]99.1% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} - \color{blue}{2}\right)
\] |
sub-neg [=>]99.1% | \[ \frac{x}{y} + \color{blue}{\left(\frac{2 + z \cdot 2}{t \cdot z} + \left(-2\right)\right)}
\] |
metadata-eval [=>]99.1% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} + \color{blue}{-2}\right)
\] |
metadata-eval [<=]99.1% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} + \color{blue}{2 \cdot -1}\right)
\] |
+-commutative [<=]99.1% | \[ \frac{x}{y} + \color{blue}{\left(2 \cdot -1 + \frac{2 + z \cdot 2}{t \cdot z}\right)}
\] |
metadata-eval [=>]99.1% | \[ \frac{x}{y} + \left(\color{blue}{-2} + \frac{2 + z \cdot 2}{t \cdot z}\right)
\] |
associate-/l/ [<=]99.2% | \[ \frac{x}{y} + \left(-2 + \color{blue}{\frac{\frac{2 + z \cdot 2}{z}}{t}}\right)
\] |
Applied egg-rr99.4%
[Start]99.2% | \[ \frac{x}{y} + \left(-2 + \frac{2 + \frac{2}{z}}{t}\right)
\] |
|---|---|
div-inv [=>]99.0% | \[ \color{blue}{x \cdot \frac{1}{y}} + \left(-2 + \frac{2 + \frac{2}{z}}{t}\right)
\] |
fma-def [=>]99.4% | \[ \color{blue}{\mathsf{fma}\left(x, \frac{1}{y}, -2 + \frac{2 + \frac{2}{z}}{t}\right)}
\] |
Final simplification99.4%
| Alternative 1 | |
|---|---|
| Accuracy | 99.4% |
| Cost | 7232 |
| Alternative 2 | |
|---|---|
| Accuracy | 70.5% |
| Cost | 1488 |
| Alternative 3 | |
|---|---|
| Accuracy | 98.4% |
| Cost | 969 |
| Alternative 4 | |
|---|---|
| Accuracy | 65.3% |
| Cost | 841 |
| Alternative 5 | |
|---|---|
| Accuracy | 78.7% |
| Cost | 841 |
| Alternative 6 | |
|---|---|
| Accuracy | 65.3% |
| Cost | 840 |
| Alternative 7 | |
|---|---|
| Accuracy | 99.2% |
| Cost | 832 |
| Alternative 8 | |
|---|---|
| Accuracy | 61.5% |
| Cost | 716 |
| Alternative 9 | |
|---|---|
| Accuracy | 80.6% |
| Cost | 713 |
| Alternative 10 | |
|---|---|
| Accuracy | 46.9% |
| Cost | 712 |
| Alternative 11 | |
|---|---|
| Accuracy | 19.2% |
| Cost | 192 |
herbie shell --seed 2023171
(FPCore (x y z t)
:name "Data.HashTable.ST.Basic:computeOverhead from hashtables-1.2.0.2"
:precision binary64
:herbie-target
(- (/ (+ (/ 2.0 z) 2.0) t) (- 2.0 (/ x y)))
(+ (/ x y) (/ (+ 2.0 (* (* z 2.0) (- 1.0 t))) (* t z))))