\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 -1.3596472614638946 \cdot 10^{154}:\\
\;\;\;\;\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{2 \cdot \frac{a \cdot c}{b} - 2 \cdot b}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \le 1.99367341058046332 \cdot 10^{77}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{\sqrt{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{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \left(b - 2 \cdot \left(\left(\left(\sqrt[3]{\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{\sqrt[3]{c} \cdot \sqrt[3]{c}}{\sqrt[3]{\sqrt{b}}}} \cdot \sqrt[3]{\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{\sqrt[3]{c} \cdot \sqrt[3]{c}}{\sqrt[3]{\sqrt{b}}}}\right) \cdot \sqrt[3]{\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{\sqrt[3]{c} \cdot \sqrt[3]{c}}{\sqrt[3]{\sqrt{b}}}}\right) \cdot \frac{\sqrt[3]{c}}{\sqrt[3]{\sqrt{b}}}\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\end{array}double f(double a, double b, double c) {
double r31258 = b;
double r31259 = 0.0;
bool r31260 = r31258 >= r31259;
double r31261 = 2.0;
double r31262 = c;
double r31263 = r31261 * r31262;
double r31264 = -r31258;
double r31265 = r31258 * r31258;
double r31266 = 4.0;
double r31267 = a;
double r31268 = r31266 * r31267;
double r31269 = r31268 * r31262;
double r31270 = r31265 - r31269;
double r31271 = sqrt(r31270);
double r31272 = r31264 - r31271;
double r31273 = r31263 / r31272;
double r31274 = r31264 + r31271;
double r31275 = r31261 * r31267;
double r31276 = r31274 / r31275;
double r31277 = r31260 ? r31273 : r31276;
return r31277;
}
double f(double a, double b, double c) {
double r31278 = b;
double r31279 = -1.3596472614638946e+154;
bool r31280 = r31278 <= r31279;
double r31281 = 0.0;
bool r31282 = r31278 >= r31281;
double r31283 = 2.0;
double r31284 = c;
double r31285 = r31283 * r31284;
double r31286 = -r31278;
double r31287 = r31278 * r31278;
double r31288 = 4.0;
double r31289 = a;
double r31290 = r31288 * r31289;
double r31291 = r31290 * r31284;
double r31292 = r31287 - r31291;
double r31293 = sqrt(r31292);
double r31294 = r31286 - r31293;
double r31295 = r31285 / r31294;
double r31296 = r31289 * r31284;
double r31297 = r31296 / r31278;
double r31298 = r31283 * r31297;
double r31299 = 2.0;
double r31300 = r31299 * r31278;
double r31301 = r31298 - r31300;
double r31302 = r31283 * r31289;
double r31303 = r31301 / r31302;
double r31304 = r31282 ? r31295 : r31303;
double r31305 = 1.9936734105804633e+77;
bool r31306 = r31278 <= r31305;
double r31307 = sqrt(r31293);
double r31308 = r31307 * r31307;
double r31309 = r31286 - r31308;
double r31310 = r31285 / r31309;
double r31311 = r31286 + r31293;
double r31312 = r31311 / r31302;
double r31313 = r31282 ? r31310 : r31312;
double r31314 = cbrt(r31278);
double r31315 = r31314 * r31314;
double r31316 = r31289 / r31315;
double r31317 = cbrt(r31284);
double r31318 = r31317 * r31317;
double r31319 = sqrt(r31278);
double r31320 = cbrt(r31319);
double r31321 = r31318 / r31320;
double r31322 = r31316 * r31321;
double r31323 = cbrt(r31322);
double r31324 = r31323 * r31323;
double r31325 = r31324 * r31323;
double r31326 = r31317 / r31320;
double r31327 = r31325 * r31326;
double r31328 = r31283 * r31327;
double r31329 = r31278 - r31328;
double r31330 = r31286 - r31329;
double r31331 = r31285 / r31330;
double r31332 = r31282 ? r31331 : r31312;
double r31333 = r31306 ? r31313 : r31332;
double r31334 = r31280 ? r31304 : r31333;
return r31334;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -1.3596472614638946e+154Initial program 64.0
Taylor expanded around -inf 10.9
if -1.3596472614638946e+154 < b < 1.9936734105804633e+77Initial program 8.8
rmApplied add-sqr-sqrt8.8
Applied sqrt-prod8.9
if 1.9936734105804633e+77 < b Initial program 27.1
Taylor expanded around inf 7.0
rmApplied add-cube-cbrt7.0
Applied times-frac2.9
rmApplied add-sqr-sqrt2.9
Applied cbrt-prod2.9
Applied add-cube-cbrt2.9
Applied times-frac2.9
Applied associate-*r*2.9
rmApplied add-cube-cbrt2.9
Final simplification7.5
herbie shell --seed 2020021
(FPCore (a b c)
:name "jeff quadratic root 2"
:precision binary64
(if (>= b 0.0) (/ (* 2 c) (- (- b) (sqrt (- (* b b) (* (* 4 a) c))))) (/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a))))