\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\end{array}\begin{array}{l}
\mathbf{if}\;b \le -2.025649824816678368861606895534923213042 \cdot 10^{153}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{c}{b} - \frac{b}{a}\right) \cdot 1\\
\end{array}\\
\mathbf{elif}\;b \le 3.628799960716311990444092539387346352569 \cdot 10^{50}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{\sqrt{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}} \cdot \sqrt{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c} \cdot \sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}}} \cdot \sqrt{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \left(b - \frac{a \cdot c}{b} \cdot 2\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(\frac{a \cdot c}{b} \cdot 2 - b\right) + \left(-b\right)}{2 \cdot a}\\
\end{array}double f(double a, double b, double c) {
double r877045 = b;
double r877046 = 0.0;
bool r877047 = r877045 >= r877046;
double r877048 = 2.0;
double r877049 = c;
double r877050 = r877048 * r877049;
double r877051 = -r877045;
double r877052 = r877045 * r877045;
double r877053 = 4.0;
double r877054 = a;
double r877055 = r877053 * r877054;
double r877056 = r877055 * r877049;
double r877057 = r877052 - r877056;
double r877058 = sqrt(r877057);
double r877059 = r877051 - r877058;
double r877060 = r877050 / r877059;
double r877061 = r877051 + r877058;
double r877062 = r877048 * r877054;
double r877063 = r877061 / r877062;
double r877064 = r877047 ? r877060 : r877063;
return r877064;
}
double f(double a, double b, double c) {
double r877065 = b;
double r877066 = -2.0256498248166784e+153;
bool r877067 = r877065 <= r877066;
double r877068 = 0.0;
bool r877069 = r877065 >= r877068;
double r877070 = 2.0;
double r877071 = c;
double r877072 = r877070 * r877071;
double r877073 = -r877065;
double r877074 = r877065 * r877065;
double r877075 = 4.0;
double r877076 = a;
double r877077 = r877075 * r877076;
double r877078 = r877077 * r877071;
double r877079 = r877074 - r877078;
double r877080 = sqrt(r877079);
double r877081 = r877073 - r877080;
double r877082 = r877072 / r877081;
double r877083 = r877071 / r877065;
double r877084 = r877065 / r877076;
double r877085 = r877083 - r877084;
double r877086 = 1.0;
double r877087 = r877085 * r877086;
double r877088 = r877069 ? r877082 : r877087;
double r877089 = 3.628799960716312e+50;
bool r877090 = r877065 <= r877089;
double r877091 = cbrt(r877079);
double r877092 = sqrt(r877091);
double r877093 = r877091 * r877091;
double r877094 = sqrt(r877093);
double r877095 = r877092 * r877094;
double r877096 = sqrt(r877095);
double r877097 = sqrt(r877080);
double r877098 = r877096 * r877097;
double r877099 = r877073 - r877098;
double r877100 = r877072 / r877099;
double r877101 = r877080 + r877073;
double r877102 = r877070 * r877076;
double r877103 = r877101 / r877102;
double r877104 = r877069 ? r877100 : r877103;
double r877105 = r877076 * r877071;
double r877106 = r877105 / r877065;
double r877107 = r877106 * r877070;
double r877108 = r877065 - r877107;
double r877109 = r877073 - r877108;
double r877110 = r877072 / r877109;
double r877111 = r877107 - r877065;
double r877112 = r877111 + r877073;
double r877113 = r877112 / r877102;
double r877114 = r877069 ? r877110 : r877113;
double r877115 = r877090 ? r877104 : r877114;
double r877116 = r877067 ? r877088 : r877115;
return r877116;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -2.0256498248166784e+153Initial program 63.6
Taylor expanded around -inf 10.4
Taylor expanded around 0 2.0
Simplified2.0
if -2.0256498248166784e+153 < b < 3.628799960716312e+50Initial program 8.7
rmApplied add-sqr-sqrt8.7
Applied sqrt-prod8.8
rmApplied add-cube-cbrt8.9
Applied sqrt-prod8.9
if 3.628799960716312e+50 < b Initial program 26.2
Taylor expanded around -inf 26.2
Taylor expanded around inf 7.6
Final simplification7.8
herbie shell --seed 2019179
(FPCore (a b c)
:name "jeff quadratic root 2"
(if (>= b 0.0) (/ (* 2.0 c) (- (- b) (sqrt (- (* b b) (* (* 4.0 a) c))))) (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a))))