\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 -63362873442066488610789523456:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \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}}}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{c}{b} - \frac{b}{a}\right) \cdot 1\\
\end{array}\\
\mathbf{elif}\;b \le 63580190853209333432320:\\
\;\;\;\;\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) + \left(\sqrt[3]{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}} \cdot \sqrt[3]{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\right) \cdot \sqrt[3]{\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}{\mathsf{fma}\left(2, \frac{c}{\frac{b}{a}}, b \cdot -2\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 r861112 = b;
double r861113 = 0.0;
bool r861114 = r861112 >= r861113;
double r861115 = 2.0;
double r861116 = c;
double r861117 = r861115 * r861116;
double r861118 = -r861112;
double r861119 = r861112 * r861112;
double r861120 = 4.0;
double r861121 = a;
double r861122 = r861120 * r861121;
double r861123 = r861122 * r861116;
double r861124 = r861119 - r861123;
double r861125 = sqrt(r861124);
double r861126 = r861118 - r861125;
double r861127 = r861117 / r861126;
double r861128 = r861118 + r861125;
double r861129 = r861115 * r861121;
double r861130 = r861128 / r861129;
double r861131 = r861114 ? r861127 : r861130;
return r861131;
}
double f(double a, double b, double c) {
double r861132 = b;
double r861133 = -6.336287344206649e+28;
bool r861134 = r861132 <= r861133;
double r861135 = 0.0;
bool r861136 = r861132 >= r861135;
double r861137 = 2.0;
double r861138 = c;
double r861139 = r861137 * r861138;
double r861140 = -r861132;
double r861141 = r861132 * r861132;
double r861142 = 4.0;
double r861143 = a;
double r861144 = r861142 * r861143;
double r861145 = r861144 * r861138;
double r861146 = r861141 - r861145;
double r861147 = cbrt(r861146);
double r861148 = sqrt(r861147);
double r861149 = r861147 * r861147;
double r861150 = sqrt(r861149);
double r861151 = r861148 * r861150;
double r861152 = r861140 - r861151;
double r861153 = r861139 / r861152;
double r861154 = r861138 / r861132;
double r861155 = r861132 / r861143;
double r861156 = r861154 - r861155;
double r861157 = 1.0;
double r861158 = r861156 * r861157;
double r861159 = r861136 ? r861153 : r861158;
double r861160 = 6.358019085320933e+22;
bool r861161 = r861132 <= r861160;
double r861162 = sqrt(r861146);
double r861163 = r861140 - r861162;
double r861164 = r861139 / r861163;
double r861165 = cbrt(r861162);
double r861166 = r861165 * r861165;
double r861167 = r861166 * r861165;
double r861168 = r861140 + r861167;
double r861169 = r861137 * r861143;
double r861170 = r861168 / r861169;
double r861171 = r861136 ? r861164 : r861170;
double r861172 = r861138 / r861155;
double r861173 = -2.0;
double r861174 = r861132 * r861173;
double r861175 = fma(r861137, r861172, r861174);
double r861176 = r861139 / r861175;
double r861177 = r861162 + r861140;
double r861178 = r861177 / r861169;
double r861179 = r861136 ? r861176 : r861178;
double r861180 = r861161 ? r861171 : r861179;
double r861181 = r861134 ? r861159 : r861180;
return r861181;
}



Bits error versus a



Bits error versus b



Bits error versus c
if b < -6.336287344206649e+28Initial program 34.8
Taylor expanded around -inf 11.6
Simplified7.2
Taylor expanded around 0 7.0
Simplified7.0
rmApplied add-cube-cbrt7.0
Applied sqrt-prod7.0
if -6.336287344206649e+28 < b < 6.358019085320933e+22Initial program 9.8
rmApplied add-cube-cbrt10.3
if 6.358019085320933e+22 < b Initial program 23.6
Taylor expanded around inf 7.4
Simplified4.5
Final simplification7.7
herbie shell --seed 2019192 +o rules:numerics
(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))))