\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\end{array}\begin{array}{l}
\mathbf{if}\;b \le -2.2572095326645574 \cdot 10^{165}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \left(2 \cdot \frac{a \cdot c}{b} - b\right)}\\
\end{array}\\
\mathbf{elif}\;b \le 7.98976121086484385 \cdot 10^{108}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \left|\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}\right| \cdot \sqrt{\left(\sqrt[3]{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}} \cdot \sqrt[3]{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}}\right) \cdot \sqrt[3]{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}}}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \left(b - 2 \cdot \frac{a \cdot c}{b}\right)}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\end{array}double f(double a, double b, double c) {
double r48118 = b;
double r48119 = 0.0;
bool r48120 = r48118 >= r48119;
double r48121 = -r48118;
double r48122 = r48118 * r48118;
double r48123 = 4.0;
double r48124 = a;
double r48125 = r48123 * r48124;
double r48126 = c;
double r48127 = r48125 * r48126;
double r48128 = r48122 - r48127;
double r48129 = sqrt(r48128);
double r48130 = r48121 - r48129;
double r48131 = 2.0;
double r48132 = r48131 * r48124;
double r48133 = r48130 / r48132;
double r48134 = r48131 * r48126;
double r48135 = r48121 + r48129;
double r48136 = r48134 / r48135;
double r48137 = r48120 ? r48133 : r48136;
return r48137;
}
double f(double a, double b, double c) {
double r48138 = b;
double r48139 = -2.2572095326645574e+165;
bool r48140 = r48138 <= r48139;
double r48141 = 0.0;
bool r48142 = r48138 >= r48141;
double r48143 = -r48138;
double r48144 = r48138 * r48138;
double r48145 = 4.0;
double r48146 = a;
double r48147 = r48145 * r48146;
double r48148 = c;
double r48149 = r48147 * r48148;
double r48150 = r48144 - r48149;
double r48151 = sqrt(r48150);
double r48152 = r48143 - r48151;
double r48153 = 2.0;
double r48154 = r48153 * r48146;
double r48155 = r48152 / r48154;
double r48156 = r48153 * r48148;
double r48157 = r48146 * r48148;
double r48158 = r48157 / r48138;
double r48159 = r48153 * r48158;
double r48160 = r48159 - r48138;
double r48161 = r48143 + r48160;
double r48162 = r48156 / r48161;
double r48163 = r48142 ? r48155 : r48162;
double r48164 = 7.989761210864844e+108;
bool r48165 = r48138 <= r48164;
double r48166 = cbrt(r48150);
double r48167 = fabs(r48166);
double r48168 = cbrt(r48166);
double r48169 = r48168 * r48168;
double r48170 = r48169 * r48168;
double r48171 = sqrt(r48170);
double r48172 = r48167 * r48171;
double r48173 = r48143 - r48172;
double r48174 = r48173 / r48154;
double r48175 = r48143 + r48151;
double r48176 = r48156 / r48175;
double r48177 = r48142 ? r48174 : r48176;
double r48178 = r48138 - r48159;
double r48179 = r48143 - r48178;
double r48180 = r48179 / r48154;
double r48181 = r48142 ? r48180 : r48176;
double r48182 = r48165 ? r48177 : r48181;
double r48183 = r48140 ? r48163 : r48182;
return r48183;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -2.2572095326645574e+165Initial program 36.2
Taylor expanded around -inf 6.2
if -2.2572095326645574e+165 < b < 7.989761210864844e+108Initial program 9.1
rmApplied add-cube-cbrt9.3
Applied sqrt-prod9.3
Simplified9.3
rmApplied add-cube-cbrt9.4
if 7.989761210864844e+108 < b Initial program 48.9
Taylor expanded around inf 9.8
Final simplification8.9
herbie shell --seed 2020047 +o rules:numerics
(FPCore (a b c)
:name "jeff quadratic root 1"
:precision binary64
(if (>= b 0.0) (/ (- (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)) (/ (* 2 c) (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))))))