| Alternative 1 | |
|---|---|
| Accuracy | 72.4% |
| Cost | 1251 |
(FPCore (x y) :precision binary64 (/ (* (* x 2.0) y) (- x y)))
(FPCore (x y) :precision binary64 (if (or (<= x -5e+22) (not (<= x 1e-47))) (/ y (fma (/ y x) -0.5 0.5)) (* x (* -2.0 (/ y (- y x))))))
double code(double x, double y) {
return ((x * 2.0) * y) / (x - y);
}
double code(double x, double y) {
double tmp;
if ((x <= -5e+22) || !(x <= 1e-47)) {
tmp = y / fma((y / x), -0.5, 0.5);
} else {
tmp = x * (-2.0 * (y / (y - x)));
}
return tmp;
}
function code(x, y) return Float64(Float64(Float64(x * 2.0) * y) / Float64(x - y)) end
function code(x, y) tmp = 0.0 if ((x <= -5e+22) || !(x <= 1e-47)) tmp = Float64(y / fma(Float64(y / x), -0.5, 0.5)); else tmp = Float64(x * Float64(-2.0 * Float64(y / Float64(y - x)))); end return tmp end
code[x_, y_] := N[(N[(N[(x * 2.0), $MachinePrecision] * y), $MachinePrecision] / N[(x - y), $MachinePrecision]), $MachinePrecision]
code[x_, y_] := If[Or[LessEqual[x, -5e+22], N[Not[LessEqual[x, 1e-47]], $MachinePrecision]], N[(y / N[(N[(y / x), $MachinePrecision] * -0.5 + 0.5), $MachinePrecision]), $MachinePrecision], N[(x * N[(-2.0 * N[(y / N[(y - x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\frac{\left(x \cdot 2\right) \cdot y}{x - y}
\begin{array}{l}
\mathbf{if}\;x \leq -5 \cdot 10^{+22} \lor \neg \left(x \leq 10^{-47}\right):\\
\;\;\;\;\frac{y}{\mathsf{fma}\left(\frac{y}{x}, -0.5, 0.5\right)}\\
\mathbf{else}:\\
\;\;\;\;x \cdot \left(-2 \cdot \frac{y}{y - x}\right)\\
\end{array}
| Original | 75.6% |
|---|---|
| Target | 99.4% |
| Herbie | 99.8% |
if x < -4.9999999999999996e22 or 9.9999999999999997e-48 < x Initial program 74.9%
Simplified99.7%
[Start]74.9 | \[ \frac{\left(x \cdot 2\right) \cdot y}{x - y}
\] |
|---|---|
*-commutative [=>]74.9 | \[ \frac{\color{blue}{y \cdot \left(x \cdot 2\right)}}{x - y}
\] |
associate-/l* [=>]99.6 | \[ \color{blue}{\frac{y}{\frac{x - y}{x \cdot 2}}}
\] |
div-sub [=>]99.6 | \[ \frac{y}{\color{blue}{\frac{x}{x \cdot 2} - \frac{y}{x \cdot 2}}}
\] |
sub-neg [=>]99.6 | \[ \frac{y}{\color{blue}{\frac{x}{x \cdot 2} + \left(-\frac{y}{x \cdot 2}\right)}}
\] |
+-commutative [=>]99.6 | \[ \frac{y}{\color{blue}{\left(-\frac{y}{x \cdot 2}\right) + \frac{x}{x \cdot 2}}}
\] |
distribute-neg-frac [=>]99.6 | \[ \frac{y}{\color{blue}{\frac{-y}{x \cdot 2}} + \frac{x}{x \cdot 2}}
\] |
neg-mul-1 [=>]99.6 | \[ \frac{y}{\frac{\color{blue}{-1 \cdot y}}{x \cdot 2} + \frac{x}{x \cdot 2}}
\] |
*-commutative [=>]99.6 | \[ \frac{y}{\frac{\color{blue}{y \cdot -1}}{x \cdot 2} + \frac{x}{x \cdot 2}}
\] |
times-frac [=>]99.6 | \[ \frac{y}{\color{blue}{\frac{y}{x} \cdot \frac{-1}{2}} + \frac{x}{x \cdot 2}}
\] |
metadata-eval [=>]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \color{blue}{-0.5} + \frac{x}{x \cdot 2}}
\] |
metadata-eval [<=]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \color{blue}{\left(-0.5\right)} + \frac{x}{x \cdot 2}}
\] |
metadata-eval [<=]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\color{blue}{\frac{1}{2}}\right) + \frac{x}{x \cdot 2}}
\] |
*-inverses [<=]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{\color{blue}{\frac{y}{y}}}{2}\right) + \frac{x}{x \cdot 2}}
\] |
associate-/r* [<=]99.5 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\color{blue}{\frac{y}{y \cdot 2}}\right) + \frac{x}{x \cdot 2}}
\] |
*-commutative [<=]99.5 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{y}{\color{blue}{2 \cdot y}}\right) + \frac{x}{x \cdot 2}}
\] |
associate-/r* [=>]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{y}{2 \cdot y}\right) + \color{blue}{\frac{\frac{x}{x}}{2}}}
\] |
*-inverses [=>]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{y}{2 \cdot y}\right) + \frac{\color{blue}{1}}{2}}
\] |
*-inverses [<=]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{y}{2 \cdot y}\right) + \frac{\color{blue}{\frac{y}{y}}}{2}}
\] |
associate-/r* [<=]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{y}{2 \cdot y}\right) + \color{blue}{\frac{y}{y \cdot 2}}}
\] |
*-commutative [<=]99.6 | \[ \frac{y}{\frac{y}{x} \cdot \left(-\frac{y}{2 \cdot y}\right) + \frac{y}{\color{blue}{2 \cdot y}}}
\] |
fma-def [=>]99.6 | \[ \frac{y}{\color{blue}{\mathsf{fma}\left(\frac{y}{x}, -\frac{y}{2 \cdot y}, \frac{y}{2 \cdot y}\right)}}
\] |
if -4.9999999999999996e22 < x < 9.9999999999999997e-48Initial program 76.5%
Simplified99.9%
[Start]76.5 | \[ \frac{\left(x \cdot 2\right) \cdot y}{x - y}
\] |
|---|---|
*-lft-identity [<=]76.5 | \[ \color{blue}{1 \cdot \frac{\left(x \cdot 2\right) \cdot y}{x - y}}
\] |
*-inverses [<=]76.5 | \[ \color{blue}{\frac{y}{y}} \cdot \frac{\left(x \cdot 2\right) \cdot y}{x - y}
\] |
associate-/l* [=>]99.9 | \[ \frac{y}{y} \cdot \color{blue}{\frac{x \cdot 2}{\frac{x - y}{y}}}
\] |
*-commutative [=>]99.9 | \[ \frac{y}{y} \cdot \frac{\color{blue}{2 \cdot x}}{\frac{x - y}{y}}
\] |
associate-*l/ [<=]99.8 | \[ \frac{y}{y} \cdot \color{blue}{\left(\frac{2}{\frac{x - y}{y}} \cdot x\right)}
\] |
associate-*r* [=>]99.8 | \[ \color{blue}{\left(\frac{y}{y} \cdot \frac{2}{\frac{x - y}{y}}\right) \cdot x}
\] |
*-commutative [<=]99.8 | \[ \color{blue}{\left(\frac{2}{\frac{x - y}{y}} \cdot \frac{y}{y}\right)} \cdot x
\] |
*-commutative [=>]99.8 | \[ \color{blue}{x \cdot \left(\frac{2}{\frac{x - y}{y}} \cdot \frac{y}{y}\right)}
\] |
*-inverses [=>]99.8 | \[ x \cdot \left(\frac{2}{\frac{x - y}{y}} \cdot \color{blue}{1}\right)
\] |
*-rgt-identity [=>]99.8 | \[ x \cdot \color{blue}{\frac{2}{\frac{x - y}{y}}}
\] |
associate-/l* [<=]99.8 | \[ x \cdot \color{blue}{\frac{2 \cdot y}{x - y}}
\] |
sub-neg [=>]99.8 | \[ x \cdot \frac{2 \cdot y}{\color{blue}{x + \left(-y\right)}}
\] |
+-commutative [=>]99.8 | \[ x \cdot \frac{2 \cdot y}{\color{blue}{\left(-y\right) + x}}
\] |
neg-sub0 [=>]99.8 | \[ x \cdot \frac{2 \cdot y}{\color{blue}{\left(0 - y\right)} + x}
\] |
associate-+l- [=>]99.8 | \[ x \cdot \frac{2 \cdot y}{\color{blue}{0 - \left(y - x\right)}}
\] |
sub0-neg [=>]99.8 | \[ x \cdot \frac{2 \cdot y}{\color{blue}{-\left(y - x\right)}}
\] |
neg-mul-1 [=>]99.8 | \[ x \cdot \frac{2 \cdot y}{\color{blue}{-1 \cdot \left(y - x\right)}}
\] |
times-frac [=>]99.9 | \[ x \cdot \color{blue}{\left(\frac{2}{-1} \cdot \frac{y}{y - x}\right)}
\] |
metadata-eval [=>]99.9 | \[ x \cdot \left(\color{blue}{-2} \cdot \frac{y}{y - x}\right)
\] |
Final simplification99.8%
| Alternative 1 | |
|---|---|
| Accuracy | 72.4% |
| Cost | 1251 |
| Alternative 2 | |
|---|---|
| Accuracy | 92.9% |
| Cost | 841 |
| Alternative 3 | |
|---|---|
| Accuracy | 99.9% |
| Cost | 841 |
| Alternative 4 | |
|---|---|
| Accuracy | 99.8% |
| Cost | 840 |
| Alternative 5 | |
|---|---|
| Accuracy | 50.5% |
| Cost | 192 |
herbie shell --seed 2023141
(FPCore (x y)
:name "Linear.Projection:perspective from linear-1.19.1.3, B"
:precision binary64
:herbie-target
(if (< x -1.7210442634149447e+81) (* (/ (* 2.0 x) (- x y)) y) (if (< x 83645045635564430.0) (/ (* x 2.0) (/ (- x y) y)) (* (/ (* 2.0 x) (- x y)) y)))
(/ (* (* x 2.0) y) (- x y)))