(FPCore (x y) :precision binary64 (/ (* (* x 2.0) y) (- x y)))
(FPCore (x y)
:precision binary64
(let* ((t_0 (/ (* (* x 2.0) y) (- x y))) (t_1 (/ x (fma 0.5 (/ x y) -0.5))))
(if (<= t_0 -208120357.65945)
t_1
(if (<= t_0 -1.0684883610804224e-303)
t_0
(if (<= t_0 0.0) t_1 (if (<= t_0 5.448508932801663e-60) t_0 t_1))))))double code(double x, double y) {
return ((x * 2.0) * y) / (x - y);
}
double code(double x, double y) {
double t_0 = ((x * 2.0) * y) / (x - y);
double t_1 = x / fma(0.5, (x / y), -0.5);
double tmp;
if (t_0 <= -208120357.65945) {
tmp = t_1;
} else if (t_0 <= -1.0684883610804224e-303) {
tmp = t_0;
} else if (t_0 <= 0.0) {
tmp = t_1;
} else if (t_0 <= 5.448508932801663e-60) {
tmp = t_0;
} else {
tmp = t_1;
}
return tmp;
}
function code(x, y) return Float64(Float64(Float64(x * 2.0) * y) / Float64(x - y)) end
function code(x, y) t_0 = Float64(Float64(Float64(x * 2.0) * y) / Float64(x - y)) t_1 = Float64(x / fma(0.5, Float64(x / y), -0.5)) tmp = 0.0 if (t_0 <= -208120357.65945) tmp = t_1; elseif (t_0 <= -1.0684883610804224e-303) tmp = t_0; elseif (t_0 <= 0.0) tmp = t_1; elseif (t_0 <= 5.448508932801663e-60) tmp = t_0; else tmp = t_1; end return tmp end
code[x_, y_] := N[(N[(N[(x * 2.0), $MachinePrecision] * y), $MachinePrecision] / N[(x - y), $MachinePrecision]), $MachinePrecision]
code[x_, y_] := Block[{t$95$0 = N[(N[(N[(x * 2.0), $MachinePrecision] * y), $MachinePrecision] / N[(x - y), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(x / N[(0.5 * N[(x / y), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$0, -208120357.65945], t$95$1, If[LessEqual[t$95$0, -1.0684883610804224e-303], t$95$0, If[LessEqual[t$95$0, 0.0], t$95$1, If[LessEqual[t$95$0, 5.448508932801663e-60], t$95$0, t$95$1]]]]]]
\frac{\left(x \cdot 2\right) \cdot y}{x - y}
\begin{array}{l}
t_0 := \frac{\left(x \cdot 2\right) \cdot y}{x - y}\\
t_1 := \frac{x}{\mathsf{fma}\left(0.5, \frac{x}{y}, -0.5\right)}\\
\mathbf{if}\;t_0 \leq -208120357.65945:\\
\;\;\;\;t_1\\
\mathbf{elif}\;t_0 \leq -1.0684883610804224 \cdot 10^{-303}:\\
\;\;\;\;t_0\\
\mathbf{elif}\;t_0 \leq 0:\\
\;\;\;\;t_1\\
\mathbf{elif}\;t_0 \leq 5.448508932801663 \cdot 10^{-60}:\\
\;\;\;\;t_0\\
\mathbf{else}:\\
\;\;\;\;t_1\\
\end{array}




Bits error versus x




Bits error versus y
| Original | 14.9 |
|---|---|
| Target | 0.3 |
| Herbie | 0.6 |
if (/.f64 (*.f64 (*.f64 x 2) y) (-.f64 x y)) < -208120357.65944999 or -1.06848836108042239e-303 < (/.f64 (*.f64 (*.f64 x 2) y) (-.f64 x y)) < -0.0 or 5.4485089328016631e-60 < (/.f64 (*.f64 (*.f64 x 2) y) (-.f64 x y)) Initial program 35.9
Simplified0.6
if -208120357.65944999 < (/.f64 (*.f64 (*.f64 x 2) y) (-.f64 x y)) < -1.06848836108042239e-303 or -0.0 < (/.f64 (*.f64 (*.f64 x 2) y) (-.f64 x y)) < 5.4485089328016631e-60Initial program 0.6
Final simplification0.6
herbie shell --seed 2022150
(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)))