| Alternative 1 | |
|---|---|
| Accuracy | 98.9% |
| Cost | 832 |
\[\frac{x}{y} + \left(-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 (+ (/ x 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 (x / y) + (-2.0 + ((2.0 + (2.0 / z)) / t));
}
real(8) function code(x, y, z, t)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
code = (x / y) + ((2.0d0 + ((z * 2.0d0) * (1.0d0 - t))) / (t * z))
end function
real(8) function code(x, y, z, t)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
code = (x / y) + ((-2.0d0) + ((2.0d0 + (2.0d0 / z)) / t))
end function
public static double code(double x, double y, double z, double t) {
return (x / y) + ((2.0 + ((z * 2.0) * (1.0 - t))) / (t * z));
}
public static double code(double x, double y, double z, double t) {
return (x / y) + (-2.0 + ((2.0 + (2.0 / z)) / t));
}
def code(x, y, z, t): return (x / y) + ((2.0 + ((z * 2.0) * (1.0 - t))) / (t * z))
def code(x, y, z, t): return (x / 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 Float64(Float64(x / y) + Float64(-2.0 + Float64(Float64(2.0 + Float64(2.0 / z)) / t))) end
function tmp = code(x, y, z, t) tmp = (x / y) + ((2.0 + ((z * 2.0) * (1.0 - t))) / (t * z)); end
function tmp = code(x, y, z, t) tmp = (x / y) + (-2.0 + ((2.0 + (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[(N[(x / 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}
\frac{x}{y} + \left(-2 + \frac{2 + \frac{2}{z}}{t}\right)
Herbie found 13 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Results
| Original | 86.4% |
|---|---|
| Target | 98.9% |
| Herbie | 98.9% |
Initial program 90.0%
Simplified99.5%
[Start]90.0% | \[ \frac{x}{y} + \frac{2 + \left(z \cdot 2\right) \cdot \left(1 - t\right)}{t \cdot z}
\] |
|---|---|
sub-neg [=>]90.0% | \[ \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 [=>]90.0% | \[ \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 [=>]90.0% | \[ \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+ [=>]90.0% | \[ \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 [<=]90.0% | \[ \frac{x}{y} + \frac{\color{blue}{\left(2 + z \cdot 2\right) - t \cdot \left(z \cdot 2\right)}}{t \cdot z}
\] |
div-sub [=>]77.9% | \[ \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* [=>]77.9% | \[ \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/ [<=]77.9% | \[ \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.4% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} - \color{blue}{1} \cdot 2\right)
\] |
metadata-eval [=>]99.4% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} - \color{blue}{2}\right)
\] |
sub-neg [=>]99.4% | \[ \frac{x}{y} + \color{blue}{\left(\frac{2 + z \cdot 2}{t \cdot z} + \left(-2\right)\right)}
\] |
metadata-eval [=>]99.4% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} + \color{blue}{-2}\right)
\] |
metadata-eval [<=]99.4% | \[ \frac{x}{y} + \left(\frac{2 + z \cdot 2}{t \cdot z} + \color{blue}{2 \cdot -1}\right)
\] |
+-commutative [<=]99.4% | \[ \frac{x}{y} + \color{blue}{\left(2 \cdot -1 + \frac{2 + z \cdot 2}{t \cdot z}\right)}
\] |
metadata-eval [=>]99.4% | \[ \frac{x}{y} + \left(\color{blue}{-2} + \frac{2 + z \cdot 2}{t \cdot z}\right)
\] |
associate-/l/ [<=]99.5% | \[ \frac{x}{y} + \left(-2 + \color{blue}{\frac{\frac{2 + z \cdot 2}{z}}{t}}\right)
\] |
Final simplification99.5%
| Alternative 1 | |
|---|---|
| Accuracy | 98.9% |
| Cost | 832 |
| Alternative 2 | |
|---|---|
| Accuracy | 74.8% |
| Cost | 1489 |
| Alternative 3 | |
|---|---|
| Accuracy | 63.0% |
| Cost | 1244 |
| Alternative 4 | |
|---|---|
| Accuracy | 63.0% |
| Cost | 1244 |
| Alternative 5 | |
|---|---|
| Accuracy | 66.1% |
| Cost | 1244 |
| Alternative 6 | |
|---|---|
| Accuracy | 84.9% |
| Cost | 1106 |
| Alternative 7 | |
|---|---|
| Accuracy | 91.4% |
| Cost | 841 |
| Alternative 8 | |
|---|---|
| Accuracy | 64.7% |
| Cost | 840 |
| Alternative 9 | |
|---|---|
| Accuracy | 78.8% |
| Cost | 713 |
| Alternative 10 | |
|---|---|
| Accuracy | 52.8% |
| Cost | 712 |
| Alternative 11 | |
|---|---|
| Accuracy | 60.1% |
| Cost | 585 |
| Alternative 12 | |
|---|---|
| Accuracy | 35.6% |
| Cost | 456 |
| Alternative 13 | |
|---|---|
| Accuracy | 19.9% |
| Cost | 64 |
herbie shell --seed 2023272
(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))))