\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.0088663643419234 \cdot 10^{78}:\\
\;\;\;\;\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{2 \cdot \left(\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{c}{\sqrt[3]{b}}\right) - 2 \cdot b}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \le 3461964491124549:\\
\;\;\;\;\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{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}} \cdot \sqrt{\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}{2 \cdot \frac{a \cdot c}{b} - 2 \cdot b}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\end{array}double f(double a, double b, double c) {
double r32926 = b;
double r32927 = 0.0;
bool r32928 = r32926 >= r32927;
double r32929 = 2.0;
double r32930 = c;
double r32931 = r32929 * r32930;
double r32932 = -r32926;
double r32933 = r32926 * r32926;
double r32934 = 4.0;
double r32935 = a;
double r32936 = r32934 * r32935;
double r32937 = r32936 * r32930;
double r32938 = r32933 - r32937;
double r32939 = sqrt(r32938);
double r32940 = r32932 - r32939;
double r32941 = r32931 / r32940;
double r32942 = r32932 + r32939;
double r32943 = r32929 * r32935;
double r32944 = r32942 / r32943;
double r32945 = r32928 ? r32941 : r32944;
return r32945;
}
double f(double a, double b, double c) {
double r32946 = b;
double r32947 = -1.0088663643419234e+78;
bool r32948 = r32946 <= r32947;
double r32949 = 0.0;
bool r32950 = r32946 >= r32949;
double r32951 = 2.0;
double r32952 = c;
double r32953 = r32951 * r32952;
double r32954 = -r32946;
double r32955 = r32946 * r32946;
double r32956 = 4.0;
double r32957 = a;
double r32958 = r32956 * r32957;
double r32959 = r32958 * r32952;
double r32960 = r32955 - r32959;
double r32961 = sqrt(r32960);
double r32962 = r32954 - r32961;
double r32963 = r32953 / r32962;
double r32964 = cbrt(r32946);
double r32965 = r32964 * r32964;
double r32966 = r32957 / r32965;
double r32967 = r32952 / r32964;
double r32968 = r32966 * r32967;
double r32969 = r32951 * r32968;
double r32970 = 2.0;
double r32971 = r32970 * r32946;
double r32972 = r32969 - r32971;
double r32973 = r32951 * r32957;
double r32974 = r32972 / r32973;
double r32975 = r32950 ? r32963 : r32974;
double r32976 = 3461964491124549.0;
bool r32977 = r32946 <= r32976;
double r32978 = sqrt(r32961);
double r32979 = r32978 * r32978;
double r32980 = r32954 + r32979;
double r32981 = r32980 / r32973;
double r32982 = r32950 ? r32963 : r32981;
double r32983 = r32957 * r32952;
double r32984 = r32983 / r32946;
double r32985 = r32951 * r32984;
double r32986 = r32985 - r32971;
double r32987 = r32953 / r32986;
double r32988 = r32954 + r32961;
double r32989 = r32988 / r32973;
double r32990 = r32950 ? r32987 : r32989;
double r32991 = r32977 ? r32982 : r32990;
double r32992 = r32948 ? r32975 : r32991;
return r32992;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -1.0088663643419234e+78Initial program 42.4
Taylor expanded around -inf 10.0
rmApplied add-cube-cbrt10.0
Applied times-frac4.2
if -1.0088663643419234e+78 < b < 3461964491124549.0Initial program 9.5
rmApplied add-sqr-sqrt9.5
Applied sqrt-prod9.6
if 3461964491124549.0 < b Initial program 24.2
Taylor expanded around inf 8.5
Final simplification8.3
herbie shell --seed 2020027 +o rules:numerics
(FPCore (a b c)
:name "jeff quadratic root 2"
:precision binary64
(if (>= b 0.0) (/ (* 2 c) (- (- b) (sqrt (- (* b b) (* (* 4 a) c))))) (/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a))))