\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 r102055 = b;
double r102056 = -r102055;
double r102057 = r102055 * r102055;
double r102058 = 4.0;
double r102059 = a;
double r102060 = r102058 * r102059;
double r102061 = c;
double r102062 = r102060 * r102061;
double r102063 = r102057 - r102062;
double r102064 = sqrt(r102063);
double r102065 = r102056 + r102064;
double r102066 = 2.0;
double r102067 = r102066 * r102059;
double r102068 = r102065 / r102067;
return r102068;
}
double f(double a, double b, double c) {
double r102069 = b;
double r102070 = -1.5501620157466267e+150;
bool r102071 = r102069 <= r102070;
double r102072 = 1.0;
double r102073 = c;
double r102074 = r102073 / r102069;
double r102075 = a;
double r102076 = r102069 / r102075;
double r102077 = r102074 - r102076;
double r102078 = r102072 * r102077;
double r102079 = 1.611450844781215e-34;
bool r102080 = r102069 <= r102079;
double r102081 = 1.0;
double r102082 = 2.0;
double r102083 = r102082 * r102075;
double r102084 = r102069 * r102069;
double r102085 = 4.0;
double r102086 = r102085 * r102075;
double r102087 = r102086 * r102073;
double r102088 = r102084 - r102087;
double r102089 = sqrt(r102088);
double r102090 = r102089 - r102069;
double r102091 = r102083 / r102090;
double r102092 = r102081 / r102091;
double r102093 = -1.0;
double r102094 = r102093 * r102074;
double r102095 = r102080 ? r102092 : r102094;
double r102096 = r102071 ? r102078 : r102095;
return r102096;
}




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
Taylor expanded around -inf 1.7
Simplified1.7
if -1.5501620157466267e+150 < b < 1.611450844781215e-34Initial program 13.6
rmApplied clear-num13.7
Simplified13.7
if 1.611450844781215e-34 < b Initial program 55.0
Taylor expanded around inf 7.0
Final simplification9.9
herbie shell --seed 2019325 +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)))