\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a}\begin{array}{l}
\mathbf{if}\;\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a} \le -2.9221707761679003 \cdot 10^{-8}:\\
\;\;\;\;\frac{\frac{\mathsf{fma}\left(b, b, -\left(b \cdot b - \left(3 \cdot a\right) \cdot c\right)\right)}{\left(-b\right) - \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}}{3 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;-0.5 \cdot \frac{c}{b}\\
\end{array}double f(double a, double b, double c) {
double r96150 = b;
double r96151 = -r96150;
double r96152 = r96150 * r96150;
double r96153 = 3.0;
double r96154 = a;
double r96155 = r96153 * r96154;
double r96156 = c;
double r96157 = r96155 * r96156;
double r96158 = r96152 - r96157;
double r96159 = sqrt(r96158);
double r96160 = r96151 + r96159;
double r96161 = r96160 / r96155;
return r96161;
}
double f(double a, double b, double c) {
double r96162 = b;
double r96163 = -r96162;
double r96164 = r96162 * r96162;
double r96165 = 3.0;
double r96166 = a;
double r96167 = r96165 * r96166;
double r96168 = c;
double r96169 = r96167 * r96168;
double r96170 = r96164 - r96169;
double r96171 = sqrt(r96170);
double r96172 = r96163 + r96171;
double r96173 = r96172 / r96167;
double r96174 = -2.9221707761679003e-08;
bool r96175 = r96173 <= r96174;
double r96176 = -r96170;
double r96177 = fma(r96162, r96162, r96176);
double r96178 = r96163 - r96171;
double r96179 = r96177 / r96178;
double r96180 = r96179 / r96167;
double r96181 = -0.5;
double r96182 = r96168 / r96162;
double r96183 = r96181 * r96182;
double r96184 = r96175 ? r96180 : r96183;
return r96184;
}



Bits error versus a



Bits error versus b



Bits error versus c
if (/ (+ (- b) (sqrt (- (* b b) (* (* 3.0 a) c)))) (* 3.0 a)) < -2.9221707761679003e-08Initial program 22.1
rmApplied flip-+22.1
Simplified21.4
if -2.9221707761679003e-08 < (/ (+ (- b) (sqrt (- (* b b) (* (* 3.0 a) c)))) (* 3.0 a)) Initial program 54.2
Taylor expanded around inf 4.7
Final simplification10.2
herbie shell --seed 2020059 +o rules:numerics
(FPCore (a b c)
:name "Cubic critical, medium range"
:precision binary64
:pre (and (< 1.11022e-16 a 9.0072e+15) (< 1.11022e-16 b 9.0072e+15) (< 1.11022e-16 c 9.0072e+15))
(/ (+ (- b) (sqrt (- (* b b) (* (* 3 a) c)))) (* 3 a)))