\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 -9.088000531423294 \cdot 10^{+152}:\\
\;\;\;\;\frac{c}{b} - \frac{b}{a}\\
\mathbf{elif}\;b \le 9.354082991670835 \cdot 10^{-125}:\\
\;\;\;\;\frac{\left(\sqrt{\mathsf{fma}\left(a \cdot -4, c, b \cdot b\right)} - b\right) \cdot \frac{1}{2}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\
\end{array}double f(double a, double b, double c) {
double r2164940 = b;
double r2164941 = -r2164940;
double r2164942 = r2164940 * r2164940;
double r2164943 = 4.0;
double r2164944 = a;
double r2164945 = r2164943 * r2164944;
double r2164946 = c;
double r2164947 = r2164945 * r2164946;
double r2164948 = r2164942 - r2164947;
double r2164949 = sqrt(r2164948);
double r2164950 = r2164941 + r2164949;
double r2164951 = 2.0;
double r2164952 = r2164951 * r2164944;
double r2164953 = r2164950 / r2164952;
return r2164953;
}
double f(double a, double b, double c) {
double r2164954 = b;
double r2164955 = -9.088000531423294e+152;
bool r2164956 = r2164954 <= r2164955;
double r2164957 = c;
double r2164958 = r2164957 / r2164954;
double r2164959 = a;
double r2164960 = r2164954 / r2164959;
double r2164961 = r2164958 - r2164960;
double r2164962 = 9.354082991670835e-125;
bool r2164963 = r2164954 <= r2164962;
double r2164964 = -4.0;
double r2164965 = r2164959 * r2164964;
double r2164966 = r2164954 * r2164954;
double r2164967 = fma(r2164965, r2164957, r2164966);
double r2164968 = sqrt(r2164967);
double r2164969 = r2164968 - r2164954;
double r2164970 = 0.5;
double r2164971 = r2164969 * r2164970;
double r2164972 = r2164971 / r2164959;
double r2164973 = -r2164957;
double r2164974 = r2164973 / r2164954;
double r2164975 = r2164963 ? r2164972 : r2164974;
double r2164976 = r2164956 ? r2164961 : r2164975;
return r2164976;
}




Bits error versus a




Bits error versus b




Bits error versus c
| Original | 32.9 |
|---|---|
| Target | 20.3 |
| Herbie | 10.3 |
if b < -9.088000531423294e+152Initial program 60.4
Simplified60.4
Taylor expanded around -inf 1.5
if -9.088000531423294e+152 < b < 9.354082991670835e-125Initial program 10.9
Simplified10.9
rmApplied *-un-lft-identity10.9
Applied div-inv11.1
Applied times-frac11.1
Simplified11.1
Simplified11.1
rmApplied associate-*r/10.9
if 9.354082991670835e-125 < b Initial program 49.8
Simplified49.8
Taylor expanded around inf 11.9
Simplified11.9
Final simplification10.3
herbie shell --seed 2019153 +o rules:numerics
(FPCore (a b c)
:name "The quadratic formula (r1)"
:herbie-target
(if (< b 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)))