\frac{\left(\left(-b_2\right) - \left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)\right)}{a}\begin{array}{l}
\mathbf{if}\;b_2 \le -0.3563232421875:\\
\;\;\;\;\frac{\frac{a \cdot c + \left(\left(-b_2\right) + b_2\right) \cdot \left(\left(-b_2\right) + \left(-b_2\right)\right)}{a}}{\left(-b_2\right) + \sqrt{b_2 \cdot b_2 - a \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(-b_2\right) - \sqrt{\frac{b_2 \cdot b_2 + a \cdot c}{\frac{b_2 \cdot b_2 + a \cdot c}{b_2 \cdot b_2 - a \cdot c}}}}{a}\\
\end{array}double f(double a, double b_2, double c) {
double r730089 = b_2;
double r730090 = -r730089;
double r730091 = r730089 * r730089;
double r730092 = a;
double r730093 = c;
double r730094 = r730092 * r730093;
double r730095 = r730091 - r730094;
double r730096 = sqrt(r730095);
double r730097 = r730090 - r730096;
double r730098 = r730097 / r730092;
return r730098;
}
double f(double a, double b_2, double c) {
double r730099 = b_2;
double r730100 = -0.3563232421875;
bool r730101 = r730099 <= r730100;
double r730102 = a;
double r730103 = c;
double r730104 = r730102 * r730103;
double r730105 = -r730099;
double r730106 = r730105 + r730099;
double r730107 = r730105 + r730105;
double r730108 = r730106 * r730107;
double r730109 = r730104 + r730108;
double r730110 = r730109 / r730102;
double r730111 = r730099 * r730099;
double r730112 = r730111 - r730104;
double r730113 = sqrt(r730112);
double r730114 = r730105 + r730113;
double r730115 = r730110 / r730114;
double r730116 = r730111 + r730104;
double r730117 = r730116 / r730112;
double r730118 = r730116 / r730117;
double r730119 = sqrt(r730118);
double r730120 = r730105 - r730119;
double r730121 = r730120 / r730102;
double r730122 = r730101 ? r730115 : r730121;
return r730122;
}



Bits error versus a



Bits error versus b_2



Bits error versus c
if b_2 < -0.3563232421875Initial program 4.1
rmApplied p16-flip--3.6
Applied associate-/l/3.6
Simplified0.7
rmApplied associate-/r*0.5
if -0.3563232421875 < b_2 Initial program 0.4
rmApplied p16-flip--1.3
rmApplied difference-of-squares1.2
Applied associate-/l*0.4
Final simplification0.5
herbie shell --seed 2019107 +o rules:numerics
(FPCore (a b_2 c)
:name "quad2m (problem 3.2.1, negative)"
(/.p16 (-.p16 (neg.p16 b_2) (sqrt.p16 (-.p16 (*.p16 b_2 b_2) (*.p16 a c)))) a))