\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 r55274 = b;
double r55275 = -r55274;
double r55276 = r55274 * r55274;
double r55277 = 4.0;
double r55278 = a;
double r55279 = c;
double r55280 = r55278 * r55279;
double r55281 = r55277 * r55280;
double r55282 = r55276 - r55281;
double r55283 = sqrt(r55282);
double r55284 = r55275 - r55283;
double r55285 = 2.0;
double r55286 = r55285 * r55278;
double r55287 = r55284 / r55286;
return r55287;
}
double f(double a, double b, double c) {
double r55288 = b;
double r55289 = -3.359953003549157e+103;
bool r55290 = r55288 <= r55289;
double r55291 = -1.0;
double r55292 = c;
double r55293 = r55292 / r55288;
double r55294 = r55291 * r55293;
double r55295 = 2.094358742794728e-239;
bool r55296 = r55288 <= r55295;
double r55297 = 2.0;
double r55298 = r55297 * r55292;
double r55299 = -r55288;
double r55300 = r55288 * r55288;
double r55301 = 4.0;
double r55302 = a;
double r55303 = r55302 * r55292;
double r55304 = r55301 * r55303;
double r55305 = r55300 - r55304;
double r55306 = sqrt(r55305);
double r55307 = r55299 + r55306;
double r55308 = r55298 / r55307;
double r55309 = 5.099089738165329e+67;
bool r55310 = r55288 <= r55309;
double r55311 = r55297 * r55302;
double r55312 = r55299 / r55311;
double r55313 = r55306 / r55311;
double r55314 = r55312 - r55313;
double r55315 = 1.0;
double r55316 = r55288 / r55302;
double r55317 = r55293 - r55316;
double r55318 = r55315 * r55317;
double r55319 = r55310 ? r55314 : r55318;
double r55320 = r55296 ? r55308 : r55319;
double r55321 = r55290 ? r55294 : r55320;
return r55321;
}




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 "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)))