\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\begin{array}{l}
\mathbf{if}\;b \le -1.52779163831840318 \cdot 10^{117}:\\
\;\;\;\;1 \cdot \left(\frac{c}{b} - \frac{b}{a}\right)\\
\mathbf{elif}\;b \le -6.31275544544182218 \cdot 10^{-270}:\\
\;\;\;\;\frac{1}{\frac{2 \cdot a}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\
\mathbf{elif}\;b \le 6.7411875700484855 \cdot 10^{112}:\\
\;\;\;\;\frac{1}{2} \cdot \frac{\frac{c \cdot 4}{1}}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;-1 \cdot \frac{c}{b}\\
\end{array}double f(double a, double b, double c) {
double r89016 = b;
double r89017 = -r89016;
double r89018 = r89016 * r89016;
double r89019 = 4.0;
double r89020 = a;
double r89021 = r89019 * r89020;
double r89022 = c;
double r89023 = r89021 * r89022;
double r89024 = r89018 - r89023;
double r89025 = sqrt(r89024);
double r89026 = r89017 + r89025;
double r89027 = 2.0;
double r89028 = r89027 * r89020;
double r89029 = r89026 / r89028;
return r89029;
}
double f(double a, double b, double c) {
double r89030 = b;
double r89031 = -1.5277916383184032e+117;
bool r89032 = r89030 <= r89031;
double r89033 = 1.0;
double r89034 = c;
double r89035 = r89034 / r89030;
double r89036 = a;
double r89037 = r89030 / r89036;
double r89038 = r89035 - r89037;
double r89039 = r89033 * r89038;
double r89040 = -6.312755445441822e-270;
bool r89041 = r89030 <= r89040;
double r89042 = 1.0;
double r89043 = 2.0;
double r89044 = r89043 * r89036;
double r89045 = -r89030;
double r89046 = r89030 * r89030;
double r89047 = 4.0;
double r89048 = r89047 * r89036;
double r89049 = r89048 * r89034;
double r89050 = r89046 - r89049;
double r89051 = sqrt(r89050);
double r89052 = r89045 + r89051;
double r89053 = r89044 / r89052;
double r89054 = r89042 / r89053;
double r89055 = 6.7411875700484855e+112;
bool r89056 = r89030 <= r89055;
double r89057 = r89042 / r89043;
double r89058 = r89034 * r89047;
double r89059 = r89058 / r89042;
double r89060 = r89045 - r89051;
double r89061 = r89059 / r89060;
double r89062 = r89057 * r89061;
double r89063 = -1.0;
double r89064 = r89063 * r89035;
double r89065 = r89056 ? r89062 : r89064;
double r89066 = r89041 ? r89054 : r89065;
double r89067 = r89032 ? r89039 : r89066;
return r89067;
}




Bits error versus a




Bits error versus b




Bits error versus c
Results
| Original | 34.5 |
|---|---|
| Target | 21.4 |
| Herbie | 6.7 |
if b < -1.5277916383184032e+117Initial program 51.3
Taylor expanded around -inf 3.7
Simplified3.7
if -1.5277916383184032e+117 < b < -6.312755445441822e-270Initial program 8.4
rmApplied clear-num8.6
if -6.312755445441822e-270 < b < 6.7411875700484855e+112Initial program 31.9
rmApplied flip-+31.9
Simplified16.8
rmApplied *-un-lft-identity16.8
Applied *-un-lft-identity16.8
Applied times-frac16.8
Applied times-frac16.8
Simplified16.8
Simplified21.4
rmApplied associate-/r*16.0
Simplified9.5
if 6.7411875700484855e+112 < b Initial program 60.3
Taylor expanded around inf 1.8
Final simplification6.7
herbie shell --seed 2020064 +o rules:numerics
(FPCore (a b c)
:name "The quadratic formula (r1)"
:precision binary64
:herbie-target
(if (< b 0.0) (/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)) (/ c (* a (/ (- (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)))))
(/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)))