\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.2724541866372811 \cdot 10^{165}:\\
\;\;\;\;\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{\frac{2 \cdot \frac{a \cdot c}{b} - 2 \cdot b}{2}}{a}\\
\end{array}\\
\mathbf{elif}\;b \le 3.2649111998892948 \cdot 10^{111}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \left|\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}\right| \cdot \sqrt{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}{2}}{a}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \left(b - 2 \cdot \left(\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{c}{\sqrt[3]{b}}\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\frac{\left(b \cdot b - \left(4 \cdot a\right) \cdot c\right) - b \cdot b}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + b}}{2}}{a}\\
\end{array}double f(double a, double b, double c) {
double r28279 = b;
double r28280 = 0.0;
bool r28281 = r28279 >= r28280;
double r28282 = 2.0;
double r28283 = c;
double r28284 = r28282 * r28283;
double r28285 = -r28279;
double r28286 = r28279 * r28279;
double r28287 = 4.0;
double r28288 = a;
double r28289 = r28287 * r28288;
double r28290 = r28289 * r28283;
double r28291 = r28286 - r28290;
double r28292 = sqrt(r28291);
double r28293 = r28285 - r28292;
double r28294 = r28284 / r28293;
double r28295 = r28285 + r28292;
double r28296 = r28282 * r28288;
double r28297 = r28295 / r28296;
double r28298 = r28281 ? r28294 : r28297;
return r28298;
}
double f(double a, double b, double c) {
double r28299 = b;
double r28300 = -2.272454186637281e+165;
bool r28301 = r28299 <= r28300;
double r28302 = 0.0;
bool r28303 = r28299 >= r28302;
double r28304 = 2.0;
double r28305 = c;
double r28306 = r28304 * r28305;
double r28307 = -r28299;
double r28308 = r28299 * r28299;
double r28309 = 4.0;
double r28310 = a;
double r28311 = r28309 * r28310;
double r28312 = r28311 * r28305;
double r28313 = r28308 - r28312;
double r28314 = sqrt(r28313);
double r28315 = r28307 - r28314;
double r28316 = r28306 / r28315;
double r28317 = r28310 * r28305;
double r28318 = r28317 / r28299;
double r28319 = r28304 * r28318;
double r28320 = 2.0;
double r28321 = r28320 * r28299;
double r28322 = r28319 - r28321;
double r28323 = r28322 / r28304;
double r28324 = r28323 / r28310;
double r28325 = r28303 ? r28316 : r28324;
double r28326 = 3.264911199889295e+111;
bool r28327 = r28299 <= r28326;
double r28328 = cbrt(r28313);
double r28329 = fabs(r28328);
double r28330 = sqrt(r28328);
double r28331 = r28329 * r28330;
double r28332 = r28307 - r28331;
double r28333 = r28306 / r28332;
double r28334 = r28314 - r28299;
double r28335 = r28334 / r28304;
double r28336 = r28335 / r28310;
double r28337 = r28303 ? r28333 : r28336;
double r28338 = cbrt(r28299);
double r28339 = r28338 * r28338;
double r28340 = r28310 / r28339;
double r28341 = r28305 / r28338;
double r28342 = r28340 * r28341;
double r28343 = r28304 * r28342;
double r28344 = r28299 - r28343;
double r28345 = r28307 - r28344;
double r28346 = r28306 / r28345;
double r28347 = r28313 - r28308;
double r28348 = r28314 + r28299;
double r28349 = r28347 / r28348;
double r28350 = r28349 / r28304;
double r28351 = r28350 / r28310;
double r28352 = r28303 ? r28346 : r28351;
double r28353 = r28327 ? r28337 : r28352;
double r28354 = r28301 ? r28325 : r28353;
return r28354;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -2.272454186637281e+165Initial program 64.0
Simplified64.0
Taylor expanded around -inf 10.2
if -2.272454186637281e+165 < b < 3.264911199889295e+111Initial program 9.2
Simplified9.2
rmApplied add-cube-cbrt9.4
Applied sqrt-prod9.4
Simplified9.4
if 3.264911199889295e+111 < b Initial program 31.6
Simplified31.6
Taylor expanded around inf 6.2
rmApplied add-cube-cbrt6.2
Applied times-frac2.2
rmApplied flip--2.2
Simplified2.2
Final simplification7.9
herbie shell --seed 2020047
(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))))