| Alternative 1 | |
|---|---|
| Accuracy | 99.0% |
| Cost | 260 |
\[\begin{array}{l}
\mathbf{if}\;a \leq -4 \cdot 10^{-292}:\\
\;\;\;\;-a\\
\mathbf{else}:\\
\;\;\;\;a\\
\end{array}
\]
(FPCore (a b) :precision binary64 (sqrt (- (* a a) (* b b))))
(FPCore (a b) :precision binary64 (if (<= a -4e-292) (fma 0.5 (/ b (/ a b)) (- a)) a))
double code(double a, double b) {
return sqrt(((a * a) - (b * b)));
}
double code(double a, double b) {
double tmp;
if (a <= -4e-292) {
tmp = fma(0.5, (b / (a / b)), -a);
} else {
tmp = a;
}
return tmp;
}
function code(a, b) return sqrt(Float64(Float64(a * a) - Float64(b * b))) end
function code(a, b) tmp = 0.0 if (a <= -4e-292) tmp = fma(0.5, Float64(b / Float64(a / b)), Float64(-a)); else tmp = a; end return tmp end
code[a_, b_] := N[Sqrt[N[(N[(a * a), $MachinePrecision] - N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
code[a_, b_] := If[LessEqual[a, -4e-292], N[(0.5 * N[(b / N[(a / b), $MachinePrecision]), $MachinePrecision] + (-a)), $MachinePrecision], a]
\sqrt{a \cdot a - b \cdot b}
\begin{array}{l}
\mathbf{if}\;a \leq -4 \cdot 10^{-292}:\\
\;\;\;\;\mathsf{fma}\left(0.5, \frac{b}{\frac{a}{b}}, -a\right)\\
\mathbf{else}:\\
\;\;\;\;a\\
\end{array}
| Original | 50.8% |
|---|---|
| Target | 99.2% |
| Herbie | 99.3% |
if a < -4.0000000000000002e-292Initial program 51.1%
Taylor expanded in a around -inf 94.3%
Simplified99.9%
[Start]94.3 | \[ 0.5 \cdot \frac{{b}^{2}}{a} + -1 \cdot a
\] |
|---|---|
fma-def [=>]94.3 | \[ \color{blue}{\mathsf{fma}\left(0.5, \frac{{b}^{2}}{a}, -1 \cdot a\right)}
\] |
unpow2 [=>]94.3 | \[ \mathsf{fma}\left(0.5, \frac{\color{blue}{b \cdot b}}{a}, -1 \cdot a\right)
\] |
associate-/l* [=>]99.9 | \[ \mathsf{fma}\left(0.5, \color{blue}{\frac{b}{\frac{a}{b}}}, -1 \cdot a\right)
\] |
mul-1-neg [=>]99.9 | \[ \mathsf{fma}\left(0.5, \frac{b}{\frac{a}{b}}, \color{blue}{-a}\right)
\] |
if -4.0000000000000002e-292 < a Initial program 48.2%
Taylor expanded in a around inf 99.4%
Final simplification99.6%
| Alternative 1 | |
|---|---|
| Accuracy | 99.0% |
| Cost | 260 |
| Alternative 2 | |
|---|---|
| Accuracy | 50.1% |
| Cost | 64 |
herbie shell --seed 2023152
(FPCore (a b)
:name "bug366, discussion (missed optimization)"
:precision binary64
:herbie-target
(* (sqrt (+ (fabs a) (fabs b))) (sqrt (- (fabs a) (fabs b))))
(sqrt (- (* a a) (* b b))))