
(FPCore (a b c) :precision binary64 (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))
double code(double a, double b, double c) {
return (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
code = (-b + sqrt(((b * b) - ((4.0d0 * a) * c)))) / (2.0d0 * a)
end function
public static double code(double a, double b, double c) {
return (-b + Math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
def code(a, b, c): return (-b + math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a)
function code(a, b, c) return Float64(Float64(Float64(-b) + sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a)) end
function tmp = code(a, b, c) tmp = (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a); end
code[a_, b_, c_] := N[(N[((-b) + N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 9 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (a b c) :precision binary64 (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))
double code(double a, double b, double c) {
return (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
code = (-b + sqrt(((b * b) - ((4.0d0 * a) * c)))) / (2.0d0 * a)
end function
public static double code(double a, double b, double c) {
return (-b + Math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
def code(a, b, c): return (-b + math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a)
function code(a, b, c) return Float64(Float64(Float64(-b) + sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a)) end
function tmp = code(a, b, c) tmp = (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a); end
code[a_, b_, c_] := N[(N[((-b) + N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}
\end{array}
(FPCore (a b c)
:precision binary64
(let* ((t_0 (* (/ (pow c 4.0) (pow b 6.0)) 20.0))
(t_1 (pow (/ c b) 3.0))
(t_2 (- (* b b) (* (* a c) 4.0)))
(t_3 (fma b b (* -4.0 (* a c))))
(t_4 (/ (* c c) b))
(t_5 (+ t_2 (+ (* b b) (* b (sqrt t_2)))))
(t_6 (/ c (/ b 0.0))))
(if (<= b 0.025)
(/
(/ (/ (- (pow t_3 3.0) (pow b 6.0)) (+ (pow b 3.0) (pow t_3 1.5))) t_5)
(* a 2.0))
(/
(/
(fma
a
(* (* b c) -6.0)
(fma
(* a a)
(fma -2.0 t_4 (fma 8.0 t_4 (* b 0.0)))
(fma
(pow a 3.0)
(fma -4.0 t_1 (fma -2.0 t_6 (fma 8.0 t_1 (* b 0.0))))
(*
(pow a 4.0)
(fma
-2.0
t_6
(fma
-2.0
(/ (* c c) (/ (pow b 3.0) 0.0))
(fma
-0.5
(* b t_0)
(fma 16.0 (/ (pow c 4.0) (pow b 5.0)) (* b (- t_0 t_0))))))))))
t_5)
(* a 2.0)))))
double code(double a, double b, double c) {
double t_0 = (pow(c, 4.0) / pow(b, 6.0)) * 20.0;
double t_1 = pow((c / b), 3.0);
double t_2 = (b * b) - ((a * c) * 4.0);
double t_3 = fma(b, b, (-4.0 * (a * c)));
double t_4 = (c * c) / b;
double t_5 = t_2 + ((b * b) + (b * sqrt(t_2)));
double t_6 = c / (b / 0.0);
double tmp;
if (b <= 0.025) {
tmp = (((pow(t_3, 3.0) - pow(b, 6.0)) / (pow(b, 3.0) + pow(t_3, 1.5))) / t_5) / (a * 2.0);
} else {
tmp = (fma(a, ((b * c) * -6.0), fma((a * a), fma(-2.0, t_4, fma(8.0, t_4, (b * 0.0))), fma(pow(a, 3.0), fma(-4.0, t_1, fma(-2.0, t_6, fma(8.0, t_1, (b * 0.0)))), (pow(a, 4.0) * fma(-2.0, t_6, fma(-2.0, ((c * c) / (pow(b, 3.0) / 0.0)), fma(-0.5, (b * t_0), fma(16.0, (pow(c, 4.0) / pow(b, 5.0)), (b * (t_0 - t_0)))))))))) / t_5) / (a * 2.0);
}
return tmp;
}
function code(a, b, c) t_0 = Float64(Float64((c ^ 4.0) / (b ^ 6.0)) * 20.0) t_1 = Float64(c / b) ^ 3.0 t_2 = Float64(Float64(b * b) - Float64(Float64(a * c) * 4.0)) t_3 = fma(b, b, Float64(-4.0 * Float64(a * c))) t_4 = Float64(Float64(c * c) / b) t_5 = Float64(t_2 + Float64(Float64(b * b) + Float64(b * sqrt(t_2)))) t_6 = Float64(c / Float64(b / 0.0)) tmp = 0.0 if (b <= 0.025) tmp = Float64(Float64(Float64(Float64((t_3 ^ 3.0) - (b ^ 6.0)) / Float64((b ^ 3.0) + (t_3 ^ 1.5))) / t_5) / Float64(a * 2.0)); else tmp = Float64(Float64(fma(a, Float64(Float64(b * c) * -6.0), fma(Float64(a * a), fma(-2.0, t_4, fma(8.0, t_4, Float64(b * 0.0))), fma((a ^ 3.0), fma(-4.0, t_1, fma(-2.0, t_6, fma(8.0, t_1, Float64(b * 0.0)))), Float64((a ^ 4.0) * fma(-2.0, t_6, fma(-2.0, Float64(Float64(c * c) / Float64((b ^ 3.0) / 0.0)), fma(-0.5, Float64(b * t_0), fma(16.0, Float64((c ^ 4.0) / (b ^ 5.0)), Float64(b * Float64(t_0 - t_0)))))))))) / t_5) / Float64(a * 2.0)); end return tmp end
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(N[Power[c, 4.0], $MachinePrecision] / N[Power[b, 6.0], $MachinePrecision]), $MachinePrecision] * 20.0), $MachinePrecision]}, Block[{t$95$1 = N[Power[N[(c / b), $MachinePrecision], 3.0], $MachinePrecision]}, Block[{t$95$2 = N[(N[(b * b), $MachinePrecision] - N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(b * b + N[(-4.0 * N[(a * c), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[(N[(c * c), $MachinePrecision] / b), $MachinePrecision]}, Block[{t$95$5 = N[(t$95$2 + N[(N[(b * b), $MachinePrecision] + N[(b * N[Sqrt[t$95$2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$6 = N[(c / N[(b / 0.0), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, 0.025], N[(N[(N[(N[(N[Power[t$95$3, 3.0], $MachinePrecision] - N[Power[b, 6.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[b, 3.0], $MachinePrecision] + N[Power[t$95$3, 1.5], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / t$95$5), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(a * N[(N[(b * c), $MachinePrecision] * -6.0), $MachinePrecision] + N[(N[(a * a), $MachinePrecision] * N[(-2.0 * t$95$4 + N[(8.0 * t$95$4 + N[(b * 0.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(N[Power[a, 3.0], $MachinePrecision] * N[(-4.0 * t$95$1 + N[(-2.0 * t$95$6 + N[(8.0 * t$95$1 + N[(b * 0.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(N[Power[a, 4.0], $MachinePrecision] * N[(-2.0 * t$95$6 + N[(-2.0 * N[(N[(c * c), $MachinePrecision] / N[(N[Power[b, 3.0], $MachinePrecision] / 0.0), $MachinePrecision]), $MachinePrecision] + N[(-0.5 * N[(b * t$95$0), $MachinePrecision] + N[(16.0 * N[(N[Power[c, 4.0], $MachinePrecision] / N[Power[b, 5.0], $MachinePrecision]), $MachinePrecision] + N[(b * N[(t$95$0 - t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / t$95$5), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{{c}^{4}}{{b}^{6}} \cdot 20\\
t_1 := {\left(\frac{c}{b}\right)}^{3}\\
t_2 := b \cdot b - \left(a \cdot c\right) \cdot 4\\
t_3 := \mathsf{fma}\left(b, b, -4 \cdot \left(a \cdot c\right)\right)\\
t_4 := \frac{c \cdot c}{b}\\
t_5 := t_2 + \left(b \cdot b + b \cdot \sqrt{t_2}\right)\\
t_6 := \frac{c}{\frac{b}{0}}\\
\mathbf{if}\;b \leq 0.025:\\
\;\;\;\;\frac{\frac{\frac{{t_3}^{3} - {b}^{6}}{{b}^{3} + {t_3}^{1.5}}}{t_5}}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\mathsf{fma}\left(a, \left(b \cdot c\right) \cdot -6, \mathsf{fma}\left(a \cdot a, \mathsf{fma}\left(-2, t_4, \mathsf{fma}\left(8, t_4, b \cdot 0\right)\right), \mathsf{fma}\left({a}^{3}, \mathsf{fma}\left(-4, t_1, \mathsf{fma}\left(-2, t_6, \mathsf{fma}\left(8, t_1, b \cdot 0\right)\right)\right), {a}^{4} \cdot \mathsf{fma}\left(-2, t_6, \mathsf{fma}\left(-2, \frac{c \cdot c}{\frac{{b}^{3}}{0}}, \mathsf{fma}\left(-0.5, b \cdot t_0, \mathsf{fma}\left(16, \frac{{c}^{4}}{{b}^{5}}, b \cdot \left(t_0 - t_0\right)\right)\right)\right)\right)\right)\right)\right)}{t_5}}{a \cdot 2}\\
\end{array}
\end{array}
if b < 0.025000000000000001Initial program 89.1%
Simplified89.1%
*-commutative89.1%
metadata-eval89.1%
distribute-lft-neg-in89.1%
distribute-rgt-neg-in89.1%
*-commutative89.1%
fma-neg89.1%
associate-*l*89.1%
Applied egg-rr89.1%
flip3--88.9%
add-sqr-sqrt89.1%
Applied egg-rr89.1%
flip--88.9%
Applied egg-rr89.4%
pow-sqr89.3%
fma-def90.3%
*-commutative90.3%
metadata-eval90.3%
pow-sqr90.0%
metadata-eval90.0%
+-commutative90.0%
fma-def90.0%
*-commutative90.0%
Simplified90.0%
if 0.025000000000000001 < b Initial program 52.8%
Simplified52.8%
*-commutative52.8%
metadata-eval52.8%
distribute-lft-neg-in52.8%
distribute-rgt-neg-in52.8%
*-commutative52.8%
fma-neg52.8%
associate-*l*52.8%
Applied egg-rr52.8%
flip3--52.6%
add-sqr-sqrt52.6%
Applied egg-rr52.6%
Taylor expanded in a around 0 93.5%
Simplified93.5%
Final simplification93.3%
(FPCore (a b c)
:precision binary64
(let* ((t_0 (- (* b b) (* (* a c) 4.0))) (t_1 (fma b b (* -4.0 (* a c)))))
(if (<= b 0.0305)
(/
(/
(/ (- (pow t_1 3.0) (pow b 6.0)) (+ (pow b 3.0) (pow t_1 1.5)))
(+ t_0 (+ (* b b) (* b (sqrt t_0)))))
(* a 2.0))
(fma
-2.0
(* (/ (* a a) (pow b 5.0)) (pow c 3.0))
(-
(-
(* -5.0 (/ (pow a 3.0) (/ (pow b 7.0) (pow c 4.0))))
(* (* c c) (/ a (pow b 3.0))))
(/ c b))))))
double code(double a, double b, double c) {
double t_0 = (b * b) - ((a * c) * 4.0);
double t_1 = fma(b, b, (-4.0 * (a * c)));
double tmp;
if (b <= 0.0305) {
tmp = (((pow(t_1, 3.0) - pow(b, 6.0)) / (pow(b, 3.0) + pow(t_1, 1.5))) / (t_0 + ((b * b) + (b * sqrt(t_0))))) / (a * 2.0);
} else {
tmp = fma(-2.0, (((a * a) / pow(b, 5.0)) * pow(c, 3.0)), (((-5.0 * (pow(a, 3.0) / (pow(b, 7.0) / pow(c, 4.0)))) - ((c * c) * (a / pow(b, 3.0)))) - (c / b)));
}
return tmp;
}
function code(a, b, c) t_0 = Float64(Float64(b * b) - Float64(Float64(a * c) * 4.0)) t_1 = fma(b, b, Float64(-4.0 * Float64(a * c))) tmp = 0.0 if (b <= 0.0305) tmp = Float64(Float64(Float64(Float64((t_1 ^ 3.0) - (b ^ 6.0)) / Float64((b ^ 3.0) + (t_1 ^ 1.5))) / Float64(t_0 + Float64(Float64(b * b) + Float64(b * sqrt(t_0))))) / Float64(a * 2.0)); else tmp = fma(-2.0, Float64(Float64(Float64(a * a) / (b ^ 5.0)) * (c ^ 3.0)), Float64(Float64(Float64(-5.0 * Float64((a ^ 3.0) / Float64((b ^ 7.0) / (c ^ 4.0)))) - Float64(Float64(c * c) * Float64(a / (b ^ 3.0)))) - Float64(c / b))); end return tmp end
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(b * b), $MachinePrecision] - N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(b * b + N[(-4.0 * N[(a * c), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, 0.0305], N[(N[(N[(N[(N[Power[t$95$1, 3.0], $MachinePrecision] - N[Power[b, 6.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[b, 3.0], $MachinePrecision] + N[Power[t$95$1, 1.5], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 + N[(N[(b * b), $MachinePrecision] + N[(b * N[Sqrt[t$95$0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(a * a), $MachinePrecision] / N[Power[b, 5.0], $MachinePrecision]), $MachinePrecision] * N[Power[c, 3.0], $MachinePrecision]), $MachinePrecision] + N[(N[(N[(-5.0 * N[(N[Power[a, 3.0], $MachinePrecision] / N[(N[Power[b, 7.0], $MachinePrecision] / N[Power[c, 4.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(N[(c * c), $MachinePrecision] * N[(a / N[Power[b, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(c / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := b \cdot b - \left(a \cdot c\right) \cdot 4\\
t_1 := \mathsf{fma}\left(b, b, -4 \cdot \left(a \cdot c\right)\right)\\
\mathbf{if}\;b \leq 0.0305:\\
\;\;\;\;\frac{\frac{\frac{{t_1}^{3} - {b}^{6}}{{b}^{3} + {t_1}^{1.5}}}{t_0 + \left(b \cdot b + b \cdot \sqrt{t_0}\right)}}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(-2, \frac{a \cdot a}{{b}^{5}} \cdot {c}^{3}, \left(-5 \cdot \frac{{a}^{3}}{\frac{{b}^{7}}{{c}^{4}}} - \left(c \cdot c\right) \cdot \frac{a}{{b}^{3}}\right) - \frac{c}{b}\right)\\
\end{array}
\end{array}
if b < 0.030499999999999999Initial program 89.1%
Simplified89.1%
*-commutative89.1%
metadata-eval89.1%
distribute-lft-neg-in89.1%
distribute-rgt-neg-in89.1%
*-commutative89.1%
fma-neg89.1%
associate-*l*89.1%
Applied egg-rr89.1%
flip3--88.9%
add-sqr-sqrt89.1%
Applied egg-rr89.1%
flip--88.9%
Applied egg-rr89.4%
pow-sqr89.3%
fma-def90.3%
*-commutative90.3%
metadata-eval90.3%
pow-sqr90.0%
metadata-eval90.0%
+-commutative90.0%
fma-def90.0%
*-commutative90.0%
Simplified90.0%
if 0.030499999999999999 < b Initial program 52.8%
Taylor expanded in a around 0 93.2%
Simplified93.2%
Taylor expanded in c around 0 93.2%
associate-/l*93.2%
Simplified93.2%
Final simplification93.0%
(FPCore (a b c)
:precision binary64
(let* ((t_0 (- (* b b) (* (* a c) 4.0))))
(if (<= b 0.022)
(/
(/
(- (pow (fma b b (* -4.0 (* a c))) 1.5) (pow b 3.0))
(+ t_0 (+ (* b b) (* b (sqrt t_0)))))
(* a 2.0))
(fma
-2.0
(* (/ (* a a) (pow b 5.0)) (pow c 3.0))
(-
(-
(* -5.0 (/ (pow a 3.0) (/ (pow b 7.0) (pow c 4.0))))
(* (* c c) (/ a (pow b 3.0))))
(/ c b))))))
double code(double a, double b, double c) {
double t_0 = (b * b) - ((a * c) * 4.0);
double tmp;
if (b <= 0.022) {
tmp = ((pow(fma(b, b, (-4.0 * (a * c))), 1.5) - pow(b, 3.0)) / (t_0 + ((b * b) + (b * sqrt(t_0))))) / (a * 2.0);
} else {
tmp = fma(-2.0, (((a * a) / pow(b, 5.0)) * pow(c, 3.0)), (((-5.0 * (pow(a, 3.0) / (pow(b, 7.0) / pow(c, 4.0)))) - ((c * c) * (a / pow(b, 3.0)))) - (c / b)));
}
return tmp;
}
function code(a, b, c) t_0 = Float64(Float64(b * b) - Float64(Float64(a * c) * 4.0)) tmp = 0.0 if (b <= 0.022) tmp = Float64(Float64(Float64((fma(b, b, Float64(-4.0 * Float64(a * c))) ^ 1.5) - (b ^ 3.0)) / Float64(t_0 + Float64(Float64(b * b) + Float64(b * sqrt(t_0))))) / Float64(a * 2.0)); else tmp = fma(-2.0, Float64(Float64(Float64(a * a) / (b ^ 5.0)) * (c ^ 3.0)), Float64(Float64(Float64(-5.0 * Float64((a ^ 3.0) / Float64((b ^ 7.0) / (c ^ 4.0)))) - Float64(Float64(c * c) * Float64(a / (b ^ 3.0)))) - Float64(c / b))); end return tmp end
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(b * b), $MachinePrecision] - N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, 0.022], N[(N[(N[(N[Power[N[(b * b + N[(-4.0 * N[(a * c), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 1.5], $MachinePrecision] - N[Power[b, 3.0], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 + N[(N[(b * b), $MachinePrecision] + N[(b * N[Sqrt[t$95$0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(a * a), $MachinePrecision] / N[Power[b, 5.0], $MachinePrecision]), $MachinePrecision] * N[Power[c, 3.0], $MachinePrecision]), $MachinePrecision] + N[(N[(N[(-5.0 * N[(N[Power[a, 3.0], $MachinePrecision] / N[(N[Power[b, 7.0], $MachinePrecision] / N[Power[c, 4.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(N[(c * c), $MachinePrecision] * N[(a / N[Power[b, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(c / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := b \cdot b - \left(a \cdot c\right) \cdot 4\\
\mathbf{if}\;b \leq 0.022:\\
\;\;\;\;\frac{\frac{{\left(\mathsf{fma}\left(b, b, -4 \cdot \left(a \cdot c\right)\right)\right)}^{1.5} - {b}^{3}}{t_0 + \left(b \cdot b + b \cdot \sqrt{t_0}\right)}}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(-2, \frac{a \cdot a}{{b}^{5}} \cdot {c}^{3}, \left(-5 \cdot \frac{{a}^{3}}{\frac{{b}^{7}}{{c}^{4}}} - \left(c \cdot c\right) \cdot \frac{a}{{b}^{3}}\right) - \frac{c}{b}\right)\\
\end{array}
\end{array}
if b < 0.021999999999999999Initial program 89.1%
Simplified89.1%
*-commutative89.1%
metadata-eval89.1%
distribute-lft-neg-in89.1%
distribute-rgt-neg-in89.1%
*-commutative89.1%
fma-neg89.1%
associate-*l*89.1%
Applied egg-rr89.1%
flip3--88.9%
add-sqr-sqrt89.1%
Applied egg-rr89.1%
sub-neg89.1%
sqrt-pow289.3%
cancel-sign-sub-inv89.3%
metadata-eval89.3%
*-commutative89.3%
metadata-eval89.3%
Applied egg-rr89.3%
sub-neg89.3%
fma-def90.0%
*-commutative90.0%
Simplified90.0%
if 0.021999999999999999 < b Initial program 52.8%
Taylor expanded in a around 0 93.2%
Simplified93.2%
Taylor expanded in c around 0 93.2%
associate-/l*93.2%
Simplified93.2%
Final simplification93.0%
(FPCore (a b c)
:precision binary64
(let* ((t_0 (- (* b b) (* (* a c) 4.0))))
(if (<= b 0.178)
(/ (/ (- t_0 (* b b)) (+ b (sqrt t_0))) (* a 2.0))
(-
(- (/ (* (* a a) -2.0) (/ (pow b 5.0) (pow c 3.0))) (/ c b))
(* (* c c) (/ a (pow b 3.0)))))))
double code(double a, double b, double c) {
double t_0 = (b * b) - ((a * c) * 4.0);
double tmp;
if (b <= 0.178) {
tmp = ((t_0 - (b * b)) / (b + sqrt(t_0))) / (a * 2.0);
} else {
tmp = ((((a * a) * -2.0) / (pow(b, 5.0) / pow(c, 3.0))) - (c / b)) - ((c * c) * (a / pow(b, 3.0)));
}
return tmp;
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
real(8) :: t_0
real(8) :: tmp
t_0 = (b * b) - ((a * c) * 4.0d0)
if (b <= 0.178d0) then
tmp = ((t_0 - (b * b)) / (b + sqrt(t_0))) / (a * 2.0d0)
else
tmp = ((((a * a) * (-2.0d0)) / ((b ** 5.0d0) / (c ** 3.0d0))) - (c / b)) - ((c * c) * (a / (b ** 3.0d0)))
end if
code = tmp
end function
public static double code(double a, double b, double c) {
double t_0 = (b * b) - ((a * c) * 4.0);
double tmp;
if (b <= 0.178) {
tmp = ((t_0 - (b * b)) / (b + Math.sqrt(t_0))) / (a * 2.0);
} else {
tmp = ((((a * a) * -2.0) / (Math.pow(b, 5.0) / Math.pow(c, 3.0))) - (c / b)) - ((c * c) * (a / Math.pow(b, 3.0)));
}
return tmp;
}
def code(a, b, c): t_0 = (b * b) - ((a * c) * 4.0) tmp = 0 if b <= 0.178: tmp = ((t_0 - (b * b)) / (b + math.sqrt(t_0))) / (a * 2.0) else: tmp = ((((a * a) * -2.0) / (math.pow(b, 5.0) / math.pow(c, 3.0))) - (c / b)) - ((c * c) * (a / math.pow(b, 3.0))) return tmp
function code(a, b, c) t_0 = Float64(Float64(b * b) - Float64(Float64(a * c) * 4.0)) tmp = 0.0 if (b <= 0.178) tmp = Float64(Float64(Float64(t_0 - Float64(b * b)) / Float64(b + sqrt(t_0))) / Float64(a * 2.0)); else tmp = Float64(Float64(Float64(Float64(Float64(a * a) * -2.0) / Float64((b ^ 5.0) / (c ^ 3.0))) - Float64(c / b)) - Float64(Float64(c * c) * Float64(a / (b ^ 3.0)))); end return tmp end
function tmp_2 = code(a, b, c) t_0 = (b * b) - ((a * c) * 4.0); tmp = 0.0; if (b <= 0.178) tmp = ((t_0 - (b * b)) / (b + sqrt(t_0))) / (a * 2.0); else tmp = ((((a * a) * -2.0) / ((b ^ 5.0) / (c ^ 3.0))) - (c / b)) - ((c * c) * (a / (b ^ 3.0))); end tmp_2 = tmp; end
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(b * b), $MachinePrecision] - N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, 0.178], N[(N[(N[(t$95$0 - N[(b * b), $MachinePrecision]), $MachinePrecision] / N[(b + N[Sqrt[t$95$0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[(N[(a * a), $MachinePrecision] * -2.0), $MachinePrecision] / N[(N[Power[b, 5.0], $MachinePrecision] / N[Power[c, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(c / b), $MachinePrecision]), $MachinePrecision] - N[(N[(c * c), $MachinePrecision] * N[(a / N[Power[b, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := b \cdot b - \left(a \cdot c\right) \cdot 4\\
\mathbf{if}\;b \leq 0.178:\\
\;\;\;\;\frac{\frac{t_0 - b \cdot b}{b + \sqrt{t_0}}}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{\left(a \cdot a\right) \cdot -2}{\frac{{b}^{5}}{{c}^{3}}} - \frac{c}{b}\right) - \left(c \cdot c\right) \cdot \frac{a}{{b}^{3}}\\
\end{array}
\end{array}
if b < 0.17799999999999999Initial program 86.6%
Simplified86.6%
*-commutative86.6%
metadata-eval86.6%
distribute-lft-neg-in86.6%
distribute-rgt-neg-in86.6%
*-commutative86.6%
fma-neg86.6%
associate-*l*86.6%
Applied egg-rr86.6%
flip--86.6%
add-sqr-sqrt88.0%
Applied egg-rr88.0%
if 0.17799999999999999 < b Initial program 52.4%
Taylor expanded in b around inf 91.0%
associate-+r+91.0%
mul-1-neg91.0%
unsub-neg91.0%
mul-1-neg91.0%
unsub-neg91.0%
associate-/l*91.0%
associate-*r/91.0%
unpow291.0%
associate-/l*91.0%
associate-/r/91.0%
unpow291.0%
Simplified91.0%
Final simplification90.8%
(FPCore (a b c)
:precision binary64
(let* ((t_0 (* (* a c) 4.0)) (t_1 (- (* b b) t_0)))
(if (<= b 3.715)
(/ (/ (- t_1 (* b b)) (+ b (sqrt t_1))) (* a 2.0))
(/ (/ t_0 (- (- b) (+ b (* c (/ (* a -2.0) b))))) (* a 2.0)))))
double code(double a, double b, double c) {
double t_0 = (a * c) * 4.0;
double t_1 = (b * b) - t_0;
double tmp;
if (b <= 3.715) {
tmp = ((t_1 - (b * b)) / (b + sqrt(t_1))) / (a * 2.0);
} else {
tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0);
}
return tmp;
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = (a * c) * 4.0d0
t_1 = (b * b) - t_0
if (b <= 3.715d0) then
tmp = ((t_1 - (b * b)) / (b + sqrt(t_1))) / (a * 2.0d0)
else
tmp = (t_0 / (-b - (b + (c * ((a * (-2.0d0)) / b))))) / (a * 2.0d0)
end if
code = tmp
end function
public static double code(double a, double b, double c) {
double t_0 = (a * c) * 4.0;
double t_1 = (b * b) - t_0;
double tmp;
if (b <= 3.715) {
tmp = ((t_1 - (b * b)) / (b + Math.sqrt(t_1))) / (a * 2.0);
} else {
tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0);
}
return tmp;
}
def code(a, b, c): t_0 = (a * c) * 4.0 t_1 = (b * b) - t_0 tmp = 0 if b <= 3.715: tmp = ((t_1 - (b * b)) / (b + math.sqrt(t_1))) / (a * 2.0) else: tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0) return tmp
function code(a, b, c) t_0 = Float64(Float64(a * c) * 4.0) t_1 = Float64(Float64(b * b) - t_0) tmp = 0.0 if (b <= 3.715) tmp = Float64(Float64(Float64(t_1 - Float64(b * b)) / Float64(b + sqrt(t_1))) / Float64(a * 2.0)); else tmp = Float64(Float64(t_0 / Float64(Float64(-b) - Float64(b + Float64(c * Float64(Float64(a * -2.0) / b))))) / Float64(a * 2.0)); end return tmp end
function tmp_2 = code(a, b, c) t_0 = (a * c) * 4.0; t_1 = (b * b) - t_0; tmp = 0.0; if (b <= 3.715) tmp = ((t_1 - (b * b)) / (b + sqrt(t_1))) / (a * 2.0); else tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0); end tmp_2 = tmp; end
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision]}, Block[{t$95$1 = N[(N[(b * b), $MachinePrecision] - t$95$0), $MachinePrecision]}, If[LessEqual[b, 3.715], N[(N[(N[(t$95$1 - N[(b * b), $MachinePrecision]), $MachinePrecision] / N[(b + N[Sqrt[t$95$1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision], N[(N[(t$95$0 / N[((-b) - N[(b + N[(c * N[(N[(a * -2.0), $MachinePrecision] / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(a \cdot c\right) \cdot 4\\
t_1 := b \cdot b - t_0\\
\mathbf{if}\;b \leq 3.715:\\
\;\;\;\;\frac{\frac{t_1 - b \cdot b}{b + \sqrt{t_1}}}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{t_0}{\left(-b\right) - \left(b + c \cdot \frac{a \cdot -2}{b}\right)}}{a \cdot 2}\\
\end{array}
\end{array}
if b < 3.7149999999999999Initial program 78.4%
Simplified78.5%
*-commutative78.5%
metadata-eval78.5%
distribute-lft-neg-in78.5%
distribute-rgt-neg-in78.5%
*-commutative78.5%
fma-neg78.4%
associate-*l*78.4%
Applied egg-rr78.4%
flip--78.7%
add-sqr-sqrt80.5%
Applied egg-rr80.5%
if 3.7149999999999999 < b Initial program 49.9%
Taylor expanded in b around inf 35.9%
associate-/l*35.9%
Simplified35.9%
flip-+35.9%
associate-*r/35.9%
associate-*r/35.9%
associate-*r/35.9%
Applied egg-rr35.9%
sqr-neg35.9%
associate-/r/35.9%
*-commutative35.9%
associate-/r/35.9%
*-commutative35.9%
associate-/r/35.9%
*-commutative35.9%
Simplified35.9%
Taylor expanded in b around inf 87.5%
Final simplification86.3%
(FPCore (a b c)
:precision binary64
(let* ((t_0 (* (* a c) 4.0)))
(if (<= b 0.185)
(/ (- (sqrt (- (* b b) t_0)) b) (* a 2.0))
(/ (/ t_0 (- (- b) (+ b (* c (/ (* a -2.0) b))))) (* a 2.0)))))
double code(double a, double b, double c) {
double t_0 = (a * c) * 4.0;
double tmp;
if (b <= 0.185) {
tmp = (sqrt(((b * b) - t_0)) - b) / (a * 2.0);
} else {
tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0);
}
return tmp;
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
real(8) :: t_0
real(8) :: tmp
t_0 = (a * c) * 4.0d0
if (b <= 0.185d0) then
tmp = (sqrt(((b * b) - t_0)) - b) / (a * 2.0d0)
else
tmp = (t_0 / (-b - (b + (c * ((a * (-2.0d0)) / b))))) / (a * 2.0d0)
end if
code = tmp
end function
public static double code(double a, double b, double c) {
double t_0 = (a * c) * 4.0;
double tmp;
if (b <= 0.185) {
tmp = (Math.sqrt(((b * b) - t_0)) - b) / (a * 2.0);
} else {
tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0);
}
return tmp;
}
def code(a, b, c): t_0 = (a * c) * 4.0 tmp = 0 if b <= 0.185: tmp = (math.sqrt(((b * b) - t_0)) - b) / (a * 2.0) else: tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0) return tmp
function code(a, b, c) t_0 = Float64(Float64(a * c) * 4.0) tmp = 0.0 if (b <= 0.185) tmp = Float64(Float64(sqrt(Float64(Float64(b * b) - t_0)) - b) / Float64(a * 2.0)); else tmp = Float64(Float64(t_0 / Float64(Float64(-b) - Float64(b + Float64(c * Float64(Float64(a * -2.0) / b))))) / Float64(a * 2.0)); end return tmp end
function tmp_2 = code(a, b, c) t_0 = (a * c) * 4.0; tmp = 0.0; if (b <= 0.185) tmp = (sqrt(((b * b) - t_0)) - b) / (a * 2.0); else tmp = (t_0 / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0); end tmp_2 = tmp; end
code[a_, b_, c_] := Block[{t$95$0 = N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision]}, If[LessEqual[b, 0.185], N[(N[(N[Sqrt[N[(N[(b * b), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision], N[(N[(t$95$0 / N[((-b) - N[(b + N[(c * N[(N[(a * -2.0), $MachinePrecision] / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(a \cdot c\right) \cdot 4\\
\mathbf{if}\;b \leq 0.185:\\
\;\;\;\;\frac{\sqrt{b \cdot b - t_0} - b}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{t_0}{\left(-b\right) - \left(b + c \cdot \frac{a \cdot -2}{b}\right)}}{a \cdot 2}\\
\end{array}
\end{array}
if b < 0.185Initial program 86.3%
Simplified86.3%
*-commutative86.3%
metadata-eval86.3%
distribute-lft-neg-in86.3%
distribute-rgt-neg-in86.3%
*-commutative86.3%
fma-neg86.3%
associate-*l*86.3%
Applied egg-rr86.3%
if 0.185 < b Initial program 52.2%
Taylor expanded in b around inf 36.6%
associate-/l*36.6%
Simplified36.6%
flip-+36.5%
associate-*r/36.5%
associate-*r/36.5%
associate-*r/36.5%
Applied egg-rr36.5%
sqr-neg36.5%
associate-/r/36.5%
*-commutative36.5%
associate-/r/36.5%
*-commutative36.5%
associate-/r/36.5%
*-commutative36.5%
Simplified36.5%
Taylor expanded in b around inf 86.0%
Final simplification86.0%
(FPCore (a b c) :precision binary64 (/ (/ (* (* a c) 4.0) (- (- b) (+ b (* c (/ (* a -2.0) b))))) (* a 2.0)))
double code(double a, double b, double c) {
return (((a * c) * 4.0) / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0);
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
code = (((a * c) * 4.0d0) / (-b - (b + (c * ((a * (-2.0d0)) / b))))) / (a * 2.0d0)
end function
public static double code(double a, double b, double c) {
return (((a * c) * 4.0) / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0);
}
def code(a, b, c): return (((a * c) * 4.0) / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0)
function code(a, b, c) return Float64(Float64(Float64(Float64(a * c) * 4.0) / Float64(Float64(-b) - Float64(b + Float64(c * Float64(Float64(a * -2.0) / b))))) / Float64(a * 2.0)) end
function tmp = code(a, b, c) tmp = (((a * c) * 4.0) / (-b - (b + (c * ((a * -2.0) / b))))) / (a * 2.0); end
code[a_, b_, c_] := N[(N[(N[(N[(a * c), $MachinePrecision] * 4.0), $MachinePrecision] / N[((-b) - N[(b + N[(c * N[(N[(a * -2.0), $MachinePrecision] / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(a * 2.0), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\frac{\left(a \cdot c\right) \cdot 4}{\left(-b\right) - \left(b + c \cdot \frac{a \cdot -2}{b}\right)}}{a \cdot 2}
\end{array}
Initial program 55.0%
Taylor expanded in b around inf 36.5%
associate-/l*36.5%
Simplified36.5%
flip-+36.5%
associate-*r/36.5%
associate-*r/36.5%
associate-*r/36.5%
Applied egg-rr36.5%
sqr-neg36.5%
associate-/r/36.5%
*-commutative36.5%
associate-/r/36.5%
*-commutative36.5%
associate-/r/36.5%
*-commutative36.5%
Simplified36.5%
Taylor expanded in b around inf 83.3%
Final simplification83.3%
(FPCore (a b c) :precision binary64 (/ (- c) b))
double code(double a, double b, double c) {
return -c / b;
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
code = -c / b
end function
public static double code(double a, double b, double c) {
return -c / b;
}
def code(a, b, c): return -c / b
function code(a, b, c) return Float64(Float64(-c) / b) end
function tmp = code(a, b, c) tmp = -c / b; end
code[a_, b_, c_] := N[((-c) / b), $MachinePrecision]
\begin{array}{l}
\\
\frac{-c}{b}
\end{array}
Initial program 55.0%
Taylor expanded in b around inf 65.3%
mul-1-neg65.3%
distribute-neg-frac65.3%
Simplified65.3%
Final simplification65.3%
(FPCore (a b c) :precision binary64 (/ c b))
double code(double a, double b, double c) {
return c / b;
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
code = c / b
end function
public static double code(double a, double b, double c) {
return c / b;
}
def code(a, b, c): return c / b
function code(a, b, c) return Float64(c / b) end
function tmp = code(a, b, c) tmp = c / b; end
code[a_, b_, c_] := N[(c / b), $MachinePrecision]
\begin{array}{l}
\\
\frac{c}{b}
\end{array}
Initial program 55.0%
Taylor expanded in b around -inf 11.5%
+-commutative11.5%
mul-1-neg11.5%
unsub-neg11.5%
Simplified11.5%
Taylor expanded in c around inf 1.6%
Final simplification1.6%
herbie shell --seed 2023293
(FPCore (a b c)
:name "Quadratic roots, narrow range"
:precision binary64
:pre (and (and (and (< 1.0536712127723509e-8 a) (< a 94906265.62425156)) (and (< 1.0536712127723509e-8 b) (< b 94906265.62425156))) (and (< 1.0536712127723509e-8 c) (< c 94906265.62425156)))
(/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))