\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.550162015746626746000974336574470460524 \cdot 10^{150}:\\
\;\;\;\;1 \cdot \left(\frac{c}{b} - \frac{b}{a}\right)\\
\mathbf{elif}\;b \le 1.61145084478121505718169973575148582501 \cdot 10^{-34}:\\
\;\;\;\;\frac{1}{\frac{2 \cdot a}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}\\
\mathbf{else}:\\
\;\;\;\;-1 \cdot \frac{c}{b}\\
\end{array}double f(double a, double b, double c) {
double r65967 = b;
double r65968 = -r65967;
double r65969 = r65967 * r65967;
double r65970 = 4.0;
double r65971 = a;
double r65972 = r65970 * r65971;
double r65973 = c;
double r65974 = r65972 * r65973;
double r65975 = r65969 - r65974;
double r65976 = sqrt(r65975);
double r65977 = r65968 + r65976;
double r65978 = 2.0;
double r65979 = r65978 * r65971;
double r65980 = r65977 / r65979;
return r65980;
}
double f(double a, double b, double c) {
double r65981 = b;
double r65982 = -1.5501620157466267e+150;
bool r65983 = r65981 <= r65982;
double r65984 = 1.0;
double r65985 = c;
double r65986 = r65985 / r65981;
double r65987 = a;
double r65988 = r65981 / r65987;
double r65989 = r65986 - r65988;
double r65990 = r65984 * r65989;
double r65991 = 1.611450844781215e-34;
bool r65992 = r65981 <= r65991;
double r65993 = 1.0;
double r65994 = 2.0;
double r65995 = r65994 * r65987;
double r65996 = r65981 * r65981;
double r65997 = 4.0;
double r65998 = r65997 * r65987;
double r65999 = r65998 * r65985;
double r66000 = r65996 - r65999;
double r66001 = sqrt(r66000);
double r66002 = r66001 - r65981;
double r66003 = r65995 / r66002;
double r66004 = r65993 / r66003;
double r66005 = -1.0;
double r66006 = r66005 * r65986;
double r66007 = r65992 ? r66004 : r66006;
double r66008 = r65983 ? r65990 : r66007;
return r66008;
}




Bits error versus a




Bits error versus b




Bits error versus c
Results
| Original | 34.1 |
|---|---|
| Target | 21.2 |
| Herbie | 9.9 |
if b < -1.5501620157466267e+150Initial program 62.9
Simplified62.9
Taylor expanded around -inf 1.7
Simplified1.7
if -1.5501620157466267e+150 < b < 1.611450844781215e-34Initial program 13.6
Simplified13.6
rmApplied clear-num13.7
if 1.611450844781215e-34 < b Initial program 55.0
Simplified55.0
Taylor expanded around inf 7.0
Final simplification9.9
herbie shell --seed 2019325
(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)))