\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.390658213785421360285622940547871300736 \cdot 10^{101}:\\
\;\;\;\;\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(\frac{2 \cdot a}{\frac{b}{c}} - b\right) + \left(-b\right)}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \le 1.042426094136287989665052757228371789389 \cdot 10^{152}:\\
\;\;\;\;\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{\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{2 \cdot a}{\frac{b}{c}}\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}{2 \cdot a}\\
\end{array}double f(double a, double b, double c) {
double r926245 = b;
double r926246 = 0.0;
bool r926247 = r926245 >= r926246;
double r926248 = 2.0;
double r926249 = c;
double r926250 = r926248 * r926249;
double r926251 = -r926245;
double r926252 = r926245 * r926245;
double r926253 = 4.0;
double r926254 = a;
double r926255 = r926253 * r926254;
double r926256 = r926255 * r926249;
double r926257 = r926252 - r926256;
double r926258 = sqrt(r926257);
double r926259 = r926251 - r926258;
double r926260 = r926250 / r926259;
double r926261 = r926251 + r926258;
double r926262 = r926248 * r926254;
double r926263 = r926261 / r926262;
double r926264 = r926247 ? r926260 : r926263;
return r926264;
}
double f(double a, double b, double c) {
double r926265 = b;
double r926266 = -1.3906582137854214e+101;
bool r926267 = r926265 <= r926266;
double r926268 = 0.0;
bool r926269 = r926265 >= r926268;
double r926270 = 2.0;
double r926271 = c;
double r926272 = r926270 * r926271;
double r926273 = -r926265;
double r926274 = r926265 * r926265;
double r926275 = 4.0;
double r926276 = a;
double r926277 = r926275 * r926276;
double r926278 = r926277 * r926271;
double r926279 = r926274 - r926278;
double r926280 = sqrt(r926279);
double r926281 = r926273 - r926280;
double r926282 = r926272 / r926281;
double r926283 = r926270 * r926276;
double r926284 = r926265 / r926271;
double r926285 = r926283 / r926284;
double r926286 = r926285 - r926265;
double r926287 = r926286 + r926273;
double r926288 = r926287 / r926283;
double r926289 = r926269 ? r926282 : r926288;
double r926290 = 1.042426094136288e+152;
bool r926291 = r926265 <= r926290;
double r926292 = sqrt(r926280);
double r926293 = r926292 * r926292;
double r926294 = r926273 - r926293;
double r926295 = r926272 / r926294;
double r926296 = r926280 + r926273;
double r926297 = r926296 / r926283;
double r926298 = r926269 ? r926295 : r926297;
double r926299 = r926265 - r926285;
double r926300 = r926273 - r926299;
double r926301 = r926272 / r926300;
double r926302 = r926269 ? r926301 : r926297;
double r926303 = r926291 ? r926298 : r926302;
double r926304 = r926267 ? r926289 : r926303;
return r926304;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -1.3906582137854214e+101Initial program 48.2
Taylor expanded around -inf 10.3
Simplified3.6
if -1.3906582137854214e+101 < b < 1.042426094136288e+152Initial program 8.6
rmApplied add-sqr-sqrt8.6
Applied sqrt-prod8.7
if 1.042426094136288e+152 < b Initial program 37.5
Taylor expanded around inf 6.3
Simplified1.8
Final simplification6.6
herbie shell --seed 2019172
(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))))