\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 -3.15361850781839612 \cdot 10^{-6}:\\
\;\;\;\;\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 r69931 = b;
double r69932 = -r69931;
double r69933 = r69931 * r69931;
double r69934 = 3.0;
double r69935 = a;
double r69936 = r69934 * r69935;
double r69937 = c;
double r69938 = r69936 * r69937;
double r69939 = r69933 - r69938;
double r69940 = sqrt(r69939);
double r69941 = r69932 + r69940;
double r69942 = r69941 / r69936;
return r69942;
}
double f(double a, double b, double c) {
double r69943 = b;
double r69944 = -r69943;
double r69945 = r69943 * r69943;
double r69946 = 3.0;
double r69947 = a;
double r69948 = r69946 * r69947;
double r69949 = c;
double r69950 = r69948 * r69949;
double r69951 = r69945 - r69950;
double r69952 = sqrt(r69951);
double r69953 = r69944 + r69952;
double r69954 = r69953 / r69948;
double r69955 = -3.153618507818396e-06;
bool r69956 = r69954 <= r69955;
double r69957 = -r69951;
double r69958 = fma(r69943, r69943, r69957);
double r69959 = r69944 - r69952;
double r69960 = r69958 / r69959;
double r69961 = r69960 / r69948;
double r69962 = -0.5;
double r69963 = r69949 / r69943;
double r69964 = r69962 * r69963;
double r69965 = r69956 ? r69961 : r69964;
return r69965;
}



Bits error versus a



Bits error versus b



Bits error versus c
if (/ (+ (- b) (sqrt (- (* b b) (* (* 3.0 a) c)))) (* 3.0 a)) < -3.153618507818396e-06Initial program 17.4
rmApplied flip-+17.5
Simplified16.7
if -3.153618507818396e-06 < (/ (+ (- b) (sqrt (- (* b b) (* (* 3.0 a) c)))) (* 3.0 a)) Initial program 41.2
Taylor expanded around inf 12.4
Final simplification14.7
herbie shell --seed 2020083 +o rules:numerics
(FPCore (a b c)
:name "Cubic critical, narrow range"
:precision binary64
:pre (and (< 1.0536712127723509e-08 a 94906265.62425156) (< 1.0536712127723509e-08 b 94906265.62425156) (< 1.0536712127723509e-08 c 94906265.62425156))
(/ (+ (- b) (sqrt (- (* b b) (* (* 3 a) c)))) (* 3 a)))