Average Error: 1.7 → 0.4
Time: 14.6s
Precision: 64
\[\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.015533447265625:\\ \;\;\;\;\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{\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}}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left(-b_2\right) - \sqrt{b_2 \cdot b_2 - a \cdot c}}{a}\\ \end{array}\]
\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.015533447265625:\\
\;\;\;\;\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{\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}}}}\\

\mathbf{else}:\\
\;\;\;\;\frac{\left(-b_2\right) - \sqrt{b_2 \cdot b_2 - a \cdot c}}{a}\\

\end{array}
double f(double a, double b_2, double c) {
        double r556465 = b_2;
        double r556466 = -r556465;
        double r556467 = r556465 * r556465;
        double r556468 = a;
        double r556469 = c;
        double r556470 = r556468 * r556469;
        double r556471 = r556467 - r556470;
        double r556472 = sqrt(r556471);
        double r556473 = r556466 - r556472;
        double r556474 = r556473 / r556468;
        return r556474;
}

double f(double a, double b_2, double c) {
        double r556475 = b_2;
        double r556476 = -0.015533447265625;
        bool r556477 = r556475 <= r556476;
        double r556478 = a;
        double r556479 = c;
        double r556480 = r556478 * r556479;
        double r556481 = -r556475;
        double r556482 = r556481 + r556475;
        double r556483 = r556481 + r556481;
        double r556484 = r556482 * r556483;
        double r556485 = r556480 + r556484;
        double r556486 = r556485 / r556478;
        double r556487 = r556475 * r556475;
        double r556488 = r556487 + r556480;
        double r556489 = r556487 - r556480;
        double r556490 = r556488 / r556489;
        double r556491 = r556488 / r556490;
        double r556492 = sqrt(r556491);
        double r556493 = r556481 + r556492;
        double r556494 = r556486 / r556493;
        double r556495 = sqrt(r556489);
        double r556496 = r556481 - r556495;
        double r556497 = r556496 / r556478;
        double r556498 = r556477 ? r556494 : r556497;
        return r556498;
}

Error

Bits error versus a

Bits error versus b_2

Bits error versus c

Derivation

  1. Split input into 2 regimes
  2. if b_2 < -0.015533447265625

    1. Initial program 3.2

      \[\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}\]
    2. Using strategy rm
    3. Applied p16-flip--2.8

      \[\leadsto \frac{\color{blue}{\left(\frac{\left(\left(\left(-b_2\right) \cdot \left(-b_2\right)\right) - \left(\left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right) \cdot \left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)\right)\right)}{\left(\frac{\left(-b_2\right)}{\left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)}\right)}\right)}}{a}\]
    4. Applied associate-/l/2.9

      \[\leadsto \color{blue}{\frac{\left(\left(\left(-b_2\right) \cdot \left(-b_2\right)\right) - \left(\left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right) \cdot \left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)\right)\right)}{\left(a \cdot \left(\frac{\left(-b_2\right)}{\left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)}\right)\right)}}\]
    5. Simplified0.7

      \[\leadsto \frac{\color{blue}{\left(\frac{\left(a \cdot c\right)}{\left(\left(\frac{\left(-b_2\right)}{b_2}\right) \cdot \left(\frac{\left(-b_2\right)}{\left(-b_2\right)}\right)\right)}\right)}}{\left(a \cdot \left(\frac{\left(-b_2\right)}{\left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)}\right)\right)}\]
    6. Using strategy rm
    7. Applied associate-/r*0.5

      \[\leadsto \color{blue}{\frac{\left(\frac{\left(\frac{\left(a \cdot c\right)}{\left(\left(\frac{\left(-b_2\right)}{b_2}\right) \cdot \left(\frac{\left(-b_2\right)}{\left(-b_2\right)}\right)\right)}\right)}{a}\right)}{\left(\frac{\left(-b_2\right)}{\left(\sqrt{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)}\right)}}\]
    8. Using strategy rm
    9. Applied p16-flip--1.4

      \[\leadsto \frac{\left(\frac{\left(\frac{\left(a \cdot c\right)}{\left(\left(\frac{\left(-b_2\right)}{b_2}\right) \cdot \left(\frac{\left(-b_2\right)}{\left(-b_2\right)}\right)\right)}\right)}{a}\right)}{\left(\frac{\left(-b_2\right)}{\left(\sqrt{\color{blue}{\left(\frac{\left(\left(\left(b_2 \cdot b_2\right) \cdot \left(b_2 \cdot b_2\right)\right) - \left(\left(a \cdot c\right) \cdot \left(a \cdot c\right)\right)\right)}{\left(\frac{\left(b_2 \cdot b_2\right)}{\left(a \cdot c\right)}\right)}\right)}}\right)}\right)}\]
    10. Using strategy rm
    11. Applied difference-of-squares1.4

      \[\leadsto \frac{\left(\frac{\left(\frac{\left(a \cdot c\right)}{\left(\left(\frac{\left(-b_2\right)}{b_2}\right) \cdot \left(\frac{\left(-b_2\right)}{\left(-b_2\right)}\right)\right)}\right)}{a}\right)}{\left(\frac{\left(-b_2\right)}{\left(\sqrt{\left(\frac{\color{blue}{\left(\left(\frac{\left(b_2 \cdot b_2\right)}{\left(a \cdot c\right)}\right) \cdot \left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)\right)}}{\left(\frac{\left(b_2 \cdot b_2\right)}{\left(a \cdot c\right)}\right)}\right)}\right)}\right)}\]
    12. Applied associate-/l*0.5

      \[\leadsto \frac{\left(\frac{\left(\frac{\left(a \cdot c\right)}{\left(\left(\frac{\left(-b_2\right)}{b_2}\right) \cdot \left(\frac{\left(-b_2\right)}{\left(-b_2\right)}\right)\right)}\right)}{a}\right)}{\left(\frac{\left(-b_2\right)}{\left(\sqrt{\color{blue}{\left(\frac{\left(\frac{\left(b_2 \cdot b_2\right)}{\left(a \cdot c\right)}\right)}{\left(\frac{\left(\frac{\left(b_2 \cdot b_2\right)}{\left(a \cdot c\right)}\right)}{\left(\left(b_2 \cdot b_2\right) - \left(a \cdot c\right)\right)}\right)}\right)}}\right)}\right)}\]

    if -0.015533447265625 < b_2

    1. Initial program 0.4

      \[\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}\]
  3. Recombined 2 regimes into one program.
  4. Final simplification0.4

    \[\leadsto \begin{array}{l} \mathbf{if}\;b_2 \le -0.015533447265625:\\ \;\;\;\;\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{\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}}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left(-b_2\right) - \sqrt{b_2 \cdot b_2 - a \cdot c}}{a}\\ \end{array}\]

Reproduce

herbie shell --seed 2019121 
(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))