\frac{\left(-b\right) - \sqrt{b \cdot b - 4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\begin{array}{l}
\mathbf{if}\;b \le -3.38405533627000167 \cdot 10^{63}:\\
\;\;\;\;-1 \cdot \frac{c}{b}\\
\mathbf{elif}\;b \le -1.35946401585134441 \cdot 10^{-202}:\\
\;\;\;\;\frac{\frac{4 \cdot \left(a \cdot c\right)}{2 \cdot a}}{\sqrt{b \cdot b - 4 \cdot \left(a \cdot c\right)} - b}\\
\mathbf{elif}\;b \le 1.1960235610197161 \cdot 10^{130}:\\
\;\;\;\;{\left(\frac{\left(-b\right) - \sqrt{b \cdot b - 4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\right)}^{1}\\
\mathbf{else}:\\
\;\;\;\;-1 \cdot \frac{b}{a}\\
\end{array}double f(double a, double b, double c) {
double r76736 = b;
double r76737 = -r76736;
double r76738 = r76736 * r76736;
double r76739 = 4.0;
double r76740 = a;
double r76741 = c;
double r76742 = r76740 * r76741;
double r76743 = r76739 * r76742;
double r76744 = r76738 - r76743;
double r76745 = sqrt(r76744);
double r76746 = r76737 - r76745;
double r76747 = 2.0;
double r76748 = r76747 * r76740;
double r76749 = r76746 / r76748;
return r76749;
}
double f(double a, double b, double c) {
double r76750 = b;
double r76751 = -3.384055336270002e+63;
bool r76752 = r76750 <= r76751;
double r76753 = -1.0;
double r76754 = c;
double r76755 = r76754 / r76750;
double r76756 = r76753 * r76755;
double r76757 = -1.3594640158513444e-202;
bool r76758 = r76750 <= r76757;
double r76759 = 4.0;
double r76760 = a;
double r76761 = r76760 * r76754;
double r76762 = r76759 * r76761;
double r76763 = 2.0;
double r76764 = r76763 * r76760;
double r76765 = r76762 / r76764;
double r76766 = r76750 * r76750;
double r76767 = r76766 - r76762;
double r76768 = sqrt(r76767);
double r76769 = r76768 - r76750;
double r76770 = r76765 / r76769;
double r76771 = 1.196023561019716e+130;
bool r76772 = r76750 <= r76771;
double r76773 = -r76750;
double r76774 = r76773 - r76768;
double r76775 = r76774 / r76764;
double r76776 = 1.0;
double r76777 = pow(r76775, r76776);
double r76778 = r76750 / r76760;
double r76779 = r76753 * r76778;
double r76780 = r76772 ? r76777 : r76779;
double r76781 = r76758 ? r76770 : r76780;
double r76782 = r76752 ? r76756 : r76781;
return r76782;
}




Bits error versus a




Bits error versus b




Bits error versus c
Results
| Original | 34.8 |
|---|---|
| Target | 21.2 |
| Herbie | 8.9 |
if b < -3.384055336270002e+63Initial program 57.7
Taylor expanded around -inf 3.4
if -3.384055336270002e+63 < b < -1.3594640158513444e-202Initial program 35.3
rmApplied div-inv35.3
rmApplied flip--35.4
Simplified17.6
Simplified17.6
rmApplied associate-*l/16.9
Simplified16.8
if -1.3594640158513444e-202 < b < 1.196023561019716e+130Initial program 10.6
rmApplied div-inv10.7
rmApplied pow110.7
Applied pow110.7
Applied pow-prod-down10.7
Simplified10.6
if 1.196023561019716e+130 < b Initial program 56.0
rmApplied div-inv56.0
rmApplied flip--63.9
Simplified62.8
Simplified62.8
Taylor expanded around 0 3.1
Final simplification8.9
herbie shell --seed 2020033
(FPCore (a b c)
:name "The quadratic formula (r2)"
:precision binary64
:herbie-target
(if (< b 0.0) (/ c (* a (/ (+ (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))) (/ (- (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))
(/ (- (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))