\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.359953003549156817553996908233908949771 \cdot 10^{103}:\\
\;\;\;\;-1 \cdot \frac{c}{b}\\
\mathbf{elif}\;b \le 2.094358742794727790656239317142702500789 \cdot 10^{-239}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - 4 \cdot \left(a \cdot c\right)}}\\
\mathbf{elif}\;b \le 5.099089738165329086098741767888130630655 \cdot 10^{67}:\\
\;\;\;\;\frac{-b}{2 \cdot a} - \frac{\sqrt{b \cdot b - 4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;1 \cdot \left(\frac{c}{b} - \frac{b}{a}\right)\\
\end{array}double f(double a, double b, double c) {
double r74573 = b;
double r74574 = -r74573;
double r74575 = r74573 * r74573;
double r74576 = 4.0;
double r74577 = a;
double r74578 = c;
double r74579 = r74577 * r74578;
double r74580 = r74576 * r74579;
double r74581 = r74575 - r74580;
double r74582 = sqrt(r74581);
double r74583 = r74574 - r74582;
double r74584 = 2.0;
double r74585 = r74584 * r74577;
double r74586 = r74583 / r74585;
return r74586;
}
double f(double a, double b, double c) {
double r74587 = b;
double r74588 = -3.359953003549157e+103;
bool r74589 = r74587 <= r74588;
double r74590 = -1.0;
double r74591 = c;
double r74592 = r74591 / r74587;
double r74593 = r74590 * r74592;
double r74594 = 2.094358742794728e-239;
bool r74595 = r74587 <= r74594;
double r74596 = 2.0;
double r74597 = r74596 * r74591;
double r74598 = -r74587;
double r74599 = r74587 * r74587;
double r74600 = 4.0;
double r74601 = a;
double r74602 = r74601 * r74591;
double r74603 = r74600 * r74602;
double r74604 = r74599 - r74603;
double r74605 = sqrt(r74604);
double r74606 = r74598 + r74605;
double r74607 = r74597 / r74606;
double r74608 = 5.099089738165329e+67;
bool r74609 = r74587 <= r74608;
double r74610 = r74596 * r74601;
double r74611 = r74598 / r74610;
double r74612 = r74605 / r74610;
double r74613 = r74611 - r74612;
double r74614 = 1.0;
double r74615 = r74587 / r74601;
double r74616 = r74592 - r74615;
double r74617 = r74614 * r74616;
double r74618 = r74609 ? r74613 : r74617;
double r74619 = r74595 ? r74607 : r74618;
double r74620 = r74589 ? r74593 : r74619;
return r74620;
}




Bits error versus a




Bits error versus b




Bits error versus c
Results
| Original | 33.9 |
|---|---|
| Target | 20.8 |
| Herbie | 6.8 |
if b < -3.359953003549157e+103Initial program 59.7
Taylor expanded around -inf 2.5
if -3.359953003549157e+103 < b < 2.094358742794728e-239Initial program 30.7
rmApplied clear-num30.7
rmApplied flip--30.8
Applied associate-/r/30.8
Applied associate-/r*30.8
Simplified15.4
Taylor expanded around 0 9.6
if 2.094358742794728e-239 < b < 5.099089738165329e+67Initial program 8.0
rmApplied div-sub8.0
if 5.099089738165329e+67 < b Initial program 40.5
Taylor expanded around inf 5.4
Simplified5.4
Final simplification6.8
herbie shell --seed 2019304 +o rules:numerics
(FPCore (a b c)
:name "quadm (p42, negative)"
: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)))