double f(double a, double b, double c) {
double r6612533 = b;
double r6612534 = -r6612533;
double r6612535 = r6612533 * r6612533;
double r6612536 = 4.0;
double r6612537 = a;
double r6612538 = r6612536 * r6612537;
double r6612539 = c;
double r6612540 = r6612538 * r6612539;
double r6612541 = r6612535 - r6612540;
double r6612542 = sqrt(r6612541);
double r6612543 = r6612534 + r6612542;
double r6612544 = 2.0;
double r6612545 = r6612544 * r6612537;
double r6612546 = r6612543 / r6612545;
return r6612546;
}
double f(double a, double b, double c) {
double r6612547 = b;
double r6612548 = 0.14479379060563602;
bool r6612549 = r6612547 <= r6612548;
double r6612550 = r6612547 * r6612547;
double r6612551 = 4.0;
double r6612552 = c;
double r6612553 = a;
double r6612554 = r6612552 * r6612553;
double r6612555 = r6612551 * r6612554;
double r6612556 = r6612550 - r6612555;
double r6612557 = sqrt(r6612556);
double r6612558 = r6612556 * r6612557;
double r6612559 = r6612550 * r6612547;
double r6612560 = r6612558 - r6612559;
double r6612561 = 2.0;
double r6612562 = r6612561 * r6612553;
double r6612563 = r6612547 * r6612557;
double r6612564 = r6612550 + r6612563;
double r6612565 = r6612557 * r6612557;
double r6612566 = r6612564 + r6612565;
double r6612567 = r6612562 * r6612566;
double r6612568 = r6612560 / r6612567;
double r6612569 = r6612552 / r6612547;
double r6612570 = -r6612569;
double r6612571 = r6612549 ? r6612568 : r6612570;
return r6612571;
}
\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\begin{array}{l}
\mathbf{if}\;b \le 0.14479379060563602:\\
\;\;\;\;\frac{\left(b \cdot b - 4 \cdot \left(c \cdot a\right)\right) \cdot \sqrt{b \cdot b - 4 \cdot \left(c \cdot a\right)} - \left(b \cdot b\right) \cdot b}{\left(2 \cdot a\right) \cdot \left(\left(b \cdot b + b \cdot \sqrt{b \cdot b - 4 \cdot \left(c \cdot a\right)}\right) + \sqrt{b \cdot b - 4 \cdot \left(c \cdot a\right)} \cdot \sqrt{b \cdot b - 4 \cdot \left(c \cdot a\right)}\right)}\\
\mathbf{else}:\\
\;\;\;\;-\frac{c}{b}\\
\end{array}


Bits error versus a



Bits error versus b



Bits error versus c
if b < 0.14479379060563602Initial program 22.8
Simplified22.8
rmApplied flip3--22.9
Applied associate-/l/22.9
Simplified22.2
if 0.14479379060563602 < b Initial program 47.2
Simplified47.2
Taylor expanded around inf 9.6
Simplified9.6
Final simplification11.3
herbie shell --seed 2019101
(FPCore (a b c)
:name "Quadratic roots, medium range"
:pre (and (< 1.1102230246251565e-16 a 9007199254740992.0) (< 1.1102230246251565e-16 b 9007199254740992.0) (< 1.1102230246251565e-16 c 9007199254740992.0))
(/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)))