The quadratic formula (r1)

Percentage Accurate: 51.9% → 85.6%
Time: 10.5s
Alternatives: 9
Speedup: 2.5×

Specification

?
\[\begin{array}{l} \\ \frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))
double code(double a, double b, double c) {
	return (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    code = (-b + sqrt(((b * b) - ((4.0d0 * a) * c)))) / (2.0d0 * a)
end function
public static double code(double a, double b, double c) {
	return (-b + Math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
def code(a, b, c):
	return (-b + math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a)
function code(a, b, c)
	return Float64(Float64(Float64(-b) + sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a))
end
function tmp = code(a, b, c)
	tmp = (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
end
code[a_, b_, c_] := N[(N[((-b) + N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}
\end{array}

Sampling outcomes in binary64 precision:

Local Percentage Accuracy vs ?

The average percentage accuracy by input value. Horizontal axis shows value of an input variable; the variable is choosen in the title. Vertical axis is accuracy; higher is better. Red represent the original program, while blue represents Herbie's suggestion. These can be toggled with buttons below the plot. The line is an average while dots represent individual samples.

Accuracy vs Speed?

Herbie found 9 alternatives:

AlternativeAccuracySpeedup
The accuracy (vertical axis) and speed (horizontal axis) of each alternatives. Up and to the right is better. The red square shows the initial program, and each blue circle shows an alternative.The line shows the best available speed-accuracy tradeoffs.

Initial Program: 51.9% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))
double code(double a, double b, double c) {
	return (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    code = (-b + sqrt(((b * b) - ((4.0d0 * a) * c)))) / (2.0d0 * a)
end function
public static double code(double a, double b, double c) {
	return (-b + Math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
}
def code(a, b, c):
	return (-b + math.sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a)
function code(a, b, c)
	return Float64(Float64(Float64(-b) + sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a))
end
function tmp = code(a, b, c)
	tmp = (-b + sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
end
code[a_, b_, c_] := N[(N[((-b) + N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}
\end{array}

Alternative 1: 85.6% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -7 \cdot 10^{+125}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\left(-c\right) \cdot \mathsf{fma}\left(\frac{c}{{b}^{3}}, a, \frac{1}{b}\right)\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b -7e+125)
   (/ (- b) a)
   (if (<= b 6.6e-47)
     (/ (- (sqrt (fma b b (* (* -4.0 c) a))) b) (* 2.0 a))
     (* (- c) (fma (/ c (pow b 3.0)) a (/ 1.0 b))))))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -7e+125) {
		tmp = -b / a;
	} else if (b <= 6.6e-47) {
		tmp = (sqrt(fma(b, b, ((-4.0 * c) * a))) - b) / (2.0 * a);
	} else {
		tmp = -c * fma((c / pow(b, 3.0)), a, (1.0 / b));
	}
	return tmp;
}
function code(a, b, c)
	tmp = 0.0
	if (b <= -7e+125)
		tmp = Float64(Float64(-b) / a);
	elseif (b <= 6.6e-47)
		tmp = Float64(Float64(sqrt(fma(b, b, Float64(Float64(-4.0 * c) * a))) - b) / Float64(2.0 * a));
	else
		tmp = Float64(Float64(-c) * fma(Float64(c / (b ^ 3.0)), a, Float64(1.0 / b)));
	end
	return tmp
end
code[a_, b_, c_] := If[LessEqual[b, -7e+125], N[((-b) / a), $MachinePrecision], If[LessEqual[b, 6.6e-47], N[(N[(N[Sqrt[N[(b * b + N[(N[(-4.0 * c), $MachinePrecision] * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[((-c) * N[(N[(c / N[Power[b, 3.0], $MachinePrecision]), $MachinePrecision] * a + N[(1.0 / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -7 \cdot 10^{+125}:\\
\;\;\;\;\frac{-b}{a}\\

\mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\
\;\;\;\;\frac{\sqrt{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)} - b}{2 \cdot a}\\

\mathbf{else}:\\
\;\;\;\;\left(-c\right) \cdot \mathsf{fma}\left(\frac{c}{{b}^{3}}, a, \frac{1}{b}\right)\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if b < -7.00000000000000023e125

    1. Initial program 51.5%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \frac{b}{a}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot b}{a}} \]
      2. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(b\right)}}{a} \]
      3. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}} \]
      4. lower-neg.f6494.0

        \[\leadsto \frac{\color{blue}{-b}}{a} \]
    5. Applied rewrites94.0%

      \[\leadsto \color{blue}{\frac{-b}{a}} \]

    if -7.00000000000000023e125 < b < 6.60000000000000007e-47

    1. Initial program 80.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6480.7

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval80.7

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites80.7%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Step-by-step derivation
      1. lift-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(-4 \cdot c\right) \cdot a + b \cdot b}} - b}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(-4 \cdot c\right) \cdot a}} - b}{2 \cdot a} \]
      3. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b} + \left(-4 \cdot c\right) \cdot a} - b}{2 \cdot a} \]
      4. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)}} - b}{2 \cdot a} \]
      5. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      6. lower-*.f6480.8

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      7. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      8. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
      9. lower-*.f6480.8

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
    6. Applied rewrites80.8%

      \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)}} - b}{2 \cdot a} \]

    if 6.60000000000000007e-47 < b

    1. Initial program 10.8%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{c \cdot \left(-1 \cdot \frac{a \cdot c}{{b}^{3}} - \frac{1}{b}\right)} \]
    4. Step-by-step derivation
      1. sub-negN/A

        \[\leadsto c \cdot \color{blue}{\left(-1 \cdot \frac{a \cdot c}{{b}^{3}} + \left(\mathsf{neg}\left(\frac{1}{b}\right)\right)\right)} \]
      2. mul-1-negN/A

        \[\leadsto c \cdot \left(\color{blue}{\left(\mathsf{neg}\left(\frac{a \cdot c}{{b}^{3}}\right)\right)} + \left(\mathsf{neg}\left(\frac{1}{b}\right)\right)\right) \]
      3. distribute-neg-outN/A

        \[\leadsto c \cdot \color{blue}{\left(\mathsf{neg}\left(\left(\frac{a \cdot c}{{b}^{3}} + \frac{1}{b}\right)\right)\right)} \]
      4. distribute-rgt-neg-outN/A

        \[\leadsto \color{blue}{\mathsf{neg}\left(c \cdot \left(\frac{a \cdot c}{{b}^{3}} + \frac{1}{b}\right)\right)} \]
      5. lower-neg.f64N/A

        \[\leadsto \color{blue}{-c \cdot \left(\frac{a \cdot c}{{b}^{3}} + \frac{1}{b}\right)} \]
      6. lower-*.f64N/A

        \[\leadsto -\color{blue}{c \cdot \left(\frac{a \cdot c}{{b}^{3}} + \frac{1}{b}\right)} \]
      7. associate-/l*N/A

        \[\leadsto -c \cdot \left(\color{blue}{a \cdot \frac{c}{{b}^{3}}} + \frac{1}{b}\right) \]
      8. *-commutativeN/A

        \[\leadsto -c \cdot \left(\color{blue}{\frac{c}{{b}^{3}} \cdot a} + \frac{1}{b}\right) \]
      9. lower-fma.f64N/A

        \[\leadsto -c \cdot \color{blue}{\mathsf{fma}\left(\frac{c}{{b}^{3}}, a, \frac{1}{b}\right)} \]
      10. lower-/.f64N/A

        \[\leadsto -c \cdot \mathsf{fma}\left(\color{blue}{\frac{c}{{b}^{3}}}, a, \frac{1}{b}\right) \]
      11. lower-pow.f64N/A

        \[\leadsto -c \cdot \mathsf{fma}\left(\frac{c}{\color{blue}{{b}^{3}}}, a, \frac{1}{b}\right) \]
      12. lower-/.f6490.9

        \[\leadsto -c \cdot \mathsf{fma}\left(\frac{c}{{b}^{3}}, a, \color{blue}{\frac{1}{b}}\right) \]
    5. Applied rewrites90.9%

      \[\leadsto \color{blue}{-c \cdot \mathsf{fma}\left(\frac{c}{{b}^{3}}, a, \frac{1}{b}\right)} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification87.1%

    \[\leadsto \begin{array}{l} \mathbf{if}\;b \leq -7 \cdot 10^{+125}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\left(-c\right) \cdot \mathsf{fma}\left(\frac{c}{{b}^{3}}, a, \frac{1}{b}\right)\\ \end{array} \]
  5. Add Preprocessing

Alternative 2: 85.8% accurate, 0.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -7 \cdot 10^{+125}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b -7e+125)
   (/ (- b) a)
   (if (<= b 6.6e-47)
     (/ (- (sqrt (fma b b (* (* -4.0 c) a))) b) (* 2.0 a))
     (/ (- c) b))))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -7e+125) {
		tmp = -b / a;
	} else if (b <= 6.6e-47) {
		tmp = (sqrt(fma(b, b, ((-4.0 * c) * a))) - b) / (2.0 * a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
function code(a, b, c)
	tmp = 0.0
	if (b <= -7e+125)
		tmp = Float64(Float64(-b) / a);
	elseif (b <= 6.6e-47)
		tmp = Float64(Float64(sqrt(fma(b, b, Float64(Float64(-4.0 * c) * a))) - b) / Float64(2.0 * a));
	else
		tmp = Float64(Float64(-c) / b);
	end
	return tmp
end
code[a_, b_, c_] := If[LessEqual[b, -7e+125], N[((-b) / a), $MachinePrecision], If[LessEqual[b, 6.6e-47], N[(N[(N[Sqrt[N[(b * b + N[(N[(-4.0 * c), $MachinePrecision] * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[((-c) / b), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -7 \cdot 10^{+125}:\\
\;\;\;\;\frac{-b}{a}\\

\mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\
\;\;\;\;\frac{\sqrt{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)} - b}{2 \cdot a}\\

\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if b < -7.00000000000000023e125

    1. Initial program 51.5%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \frac{b}{a}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot b}{a}} \]
      2. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(b\right)}}{a} \]
      3. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}} \]
      4. lower-neg.f6494.0

        \[\leadsto \frac{\color{blue}{-b}}{a} \]
    5. Applied rewrites94.0%

      \[\leadsto \color{blue}{\frac{-b}{a}} \]

    if -7.00000000000000023e125 < b < 6.60000000000000007e-47

    1. Initial program 80.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6480.7

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval80.7

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites80.7%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Step-by-step derivation
      1. lift-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(-4 \cdot c\right) \cdot a + b \cdot b}} - b}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(-4 \cdot c\right) \cdot a}} - b}{2 \cdot a} \]
      3. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b} + \left(-4 \cdot c\right) \cdot a} - b}{2 \cdot a} \]
      4. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)}} - b}{2 \cdot a} \]
      5. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      6. lower-*.f6480.8

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      7. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      8. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
      9. lower-*.f6480.8

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
    6. Applied rewrites80.8%

      \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)}} - b}{2 \cdot a} \]

    if 6.60000000000000007e-47 < b

    1. Initial program 10.8%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{-1 \cdot \frac{c}{b}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      2. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      3. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(c\right)}}{b} \]
      4. lower-neg.f6490.9

        \[\leadsto \frac{\color{blue}{-c}}{b} \]
    5. Applied rewrites90.9%

      \[\leadsto \color{blue}{\frac{-c}{b}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification87.1%

    \[\leadsto \begin{array}{l} \mathbf{if}\;b \leq -7 \cdot 10^{+125}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \]
  5. Add Preprocessing

Alternative 3: 85.7% accurate, 0.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -4.5 \cdot 10^{+116}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\left(\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b\right) \cdot \frac{0.5}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b -4.5e+116)
   (/ (- b) a)
   (if (<= b 6.6e-47)
     (* (- (sqrt (fma (* -4.0 c) a (* b b))) b) (/ 0.5 a))
     (/ (- c) b))))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -4.5e+116) {
		tmp = -b / a;
	} else if (b <= 6.6e-47) {
		tmp = (sqrt(fma((-4.0 * c), a, (b * b))) - b) * (0.5 / a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
function code(a, b, c)
	tmp = 0.0
	if (b <= -4.5e+116)
		tmp = Float64(Float64(-b) / a);
	elseif (b <= 6.6e-47)
		tmp = Float64(Float64(sqrt(fma(Float64(-4.0 * c), a, Float64(b * b))) - b) * Float64(0.5 / a));
	else
		tmp = Float64(Float64(-c) / b);
	end
	return tmp
end
code[a_, b_, c_] := If[LessEqual[b, -4.5e+116], N[((-b) / a), $MachinePrecision], If[LessEqual[b, 6.6e-47], N[(N[(N[Sqrt[N[(N[(-4.0 * c), $MachinePrecision] * a + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] * N[(0.5 / a), $MachinePrecision]), $MachinePrecision], N[((-c) / b), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -4.5 \cdot 10^{+116}:\\
\;\;\;\;\frac{-b}{a}\\

\mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\
\;\;\;\;\left(\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b\right) \cdot \frac{0.5}{a}\\

\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if b < -4.50000000000000016e116

    1. Initial program 53.5%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \frac{b}{a}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot b}{a}} \]
      2. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(b\right)}}{a} \]
      3. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}} \]
      4. lower-neg.f6494.2

        \[\leadsto \frac{\color{blue}{-b}}{a} \]
    5. Applied rewrites94.2%

      \[\leadsto \color{blue}{\frac{-b}{a}} \]

    if -4.50000000000000016e116 < b < 6.60000000000000007e-47

    1. Initial program 80.4%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}} \]
      2. clear-numN/A

        \[\leadsto \color{blue}{\frac{1}{\frac{2 \cdot a}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}} \]
      3. associate-/r/N/A

        \[\leadsto \color{blue}{\frac{1}{2 \cdot a} \cdot \left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right)} \]
      4. lower-*.f64N/A

        \[\leadsto \color{blue}{\frac{1}{2 \cdot a} \cdot \left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right)} \]
      5. lift-*.f64N/A

        \[\leadsto \frac{1}{\color{blue}{2 \cdot a}} \cdot \left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right) \]
      6. associate-/r*N/A

        \[\leadsto \color{blue}{\frac{\frac{1}{2}}{a}} \cdot \left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right) \]
      7. metadata-evalN/A

        \[\leadsto \frac{\color{blue}{\frac{1}{2}}}{a} \cdot \left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right) \]
      8. lower-/.f6480.2

        \[\leadsto \color{blue}{\frac{0.5}{a}} \cdot \left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right) \]
      9. lift-+.f64N/A

        \[\leadsto \frac{\frac{1}{2}}{a} \cdot \color{blue}{\left(\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right)} \]
      10. +-commutativeN/A

        \[\leadsto \frac{\frac{1}{2}}{a} \cdot \color{blue}{\left(\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)\right)} \]
      11. lift-neg.f64N/A

        \[\leadsto \frac{\frac{1}{2}}{a} \cdot \left(\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}\right) \]
      12. unsub-negN/A

        \[\leadsto \frac{\frac{1}{2}}{a} \cdot \color{blue}{\left(\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b\right)} \]
      13. lower--.f6480.2

        \[\leadsto \frac{0.5}{a} \cdot \color{blue}{\left(\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b\right)} \]
    4. Applied rewrites80.2%

      \[\leadsto \color{blue}{\frac{0.5}{a} \cdot \left(\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b\right)} \]

    if 6.60000000000000007e-47 < b

    1. Initial program 10.8%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{-1 \cdot \frac{c}{b}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      2. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      3. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(c\right)}}{b} \]
      4. lower-neg.f6490.9

        \[\leadsto \frac{\color{blue}{-c}}{b} \]
    5. Applied rewrites90.9%

      \[\leadsto \color{blue}{\frac{-c}{b}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification87.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;b \leq -4.5 \cdot 10^{+116}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\left(\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b\right) \cdot \frac{0.5}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \]
  5. Add Preprocessing

Alternative 4: 80.9% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -1.15 \cdot 10^{-46}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \frac{-b}{a}\right)\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\left(c \cdot a\right) \cdot -4} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b -1.15e-46)
   (fma (/ (/ c b) b) b (/ (- b) a))
   (if (<= b 6.6e-47)
     (/ (- (sqrt (* (* c a) -4.0)) b) (* 2.0 a))
     (/ (- c) b))))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -1.15e-46) {
		tmp = fma(((c / b) / b), b, (-b / a));
	} else if (b <= 6.6e-47) {
		tmp = (sqrt(((c * a) * -4.0)) - b) / (2.0 * a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
function code(a, b, c)
	tmp = 0.0
	if (b <= -1.15e-46)
		tmp = fma(Float64(Float64(c / b) / b), b, Float64(Float64(-b) / a));
	elseif (b <= 6.6e-47)
		tmp = Float64(Float64(sqrt(Float64(Float64(c * a) * -4.0)) - b) / Float64(2.0 * a));
	else
		tmp = Float64(Float64(-c) / b);
	end
	return tmp
end
code[a_, b_, c_] := If[LessEqual[b, -1.15e-46], N[(N[(N[(c / b), $MachinePrecision] / b), $MachinePrecision] * b + N[((-b) / a), $MachinePrecision]), $MachinePrecision], If[LessEqual[b, 6.6e-47], N[(N[(N[Sqrt[N[(N[(c * a), $MachinePrecision] * -4.0), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[((-c) / b), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -1.15 \cdot 10^{-46}:\\
\;\;\;\;\mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \frac{-b}{a}\right)\\

\mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\
\;\;\;\;\frac{\sqrt{\left(c \cdot a\right) \cdot -4} - b}{2 \cdot a}\\

\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if b < -1.15e-46

    1. Initial program 70.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \left(b \cdot \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right)\right)} \]
    4. Step-by-step derivation
      1. mul-1-negN/A

        \[\leadsto \color{blue}{\mathsf{neg}\left(b \cdot \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right)\right)} \]
      2. distribute-rgt-inN/A

        \[\leadsto \mathsf{neg}\left(\color{blue}{\left(\left(-1 \cdot \frac{c}{{b}^{2}}\right) \cdot b + \frac{1}{a} \cdot b\right)}\right) \]
      3. distribute-neg-inN/A

        \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(-1 \cdot \frac{c}{{b}^{2}}\right) \cdot b\right)\right) + \left(\mathsf{neg}\left(\frac{1}{a} \cdot b\right)\right)} \]
      4. mul-1-negN/A

        \[\leadsto \left(\mathsf{neg}\left(\color{blue}{\left(\mathsf{neg}\left(\frac{c}{{b}^{2}}\right)\right)} \cdot b\right)\right) + \left(\mathsf{neg}\left(\frac{1}{a} \cdot b\right)\right) \]
      5. distribute-lft-neg-outN/A

        \[\leadsto \left(\mathsf{neg}\left(\color{blue}{\left(\mathsf{neg}\left(\frac{c}{{b}^{2}} \cdot b\right)\right)}\right)\right) + \left(\mathsf{neg}\left(\frac{1}{a} \cdot b\right)\right) \]
      6. remove-double-negN/A

        \[\leadsto \color{blue}{\frac{c}{{b}^{2}} \cdot b} + \left(\mathsf{neg}\left(\frac{1}{a} \cdot b\right)\right) \]
      7. associate-*l/N/A

        \[\leadsto \frac{c}{{b}^{2}} \cdot b + \left(\mathsf{neg}\left(\color{blue}{\frac{1 \cdot b}{a}}\right)\right) \]
      8. *-lft-identityN/A

        \[\leadsto \frac{c}{{b}^{2}} \cdot b + \left(\mathsf{neg}\left(\frac{\color{blue}{b}}{a}\right)\right) \]
      9. lower-fma.f64N/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{c}{{b}^{2}}, b, \mathsf{neg}\left(\frac{b}{a}\right)\right)} \]
      10. unpow2N/A

        \[\leadsto \mathsf{fma}\left(\frac{c}{\color{blue}{b \cdot b}}, b, \mathsf{neg}\left(\frac{b}{a}\right)\right) \]
      11. associate-/r*N/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{\frac{c}{b}}{b}}, b, \mathsf{neg}\left(\frac{b}{a}\right)\right) \]
      12. lower-/.f64N/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{\frac{c}{b}}{b}}, b, \mathsf{neg}\left(\frac{b}{a}\right)\right) \]
      13. lower-/.f64N/A

        \[\leadsto \mathsf{fma}\left(\frac{\color{blue}{\frac{c}{b}}}{b}, b, \mathsf{neg}\left(\frac{b}{a}\right)\right) \]
      14. distribute-frac-negN/A

        \[\leadsto \mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}}\right) \]
      15. lower-/.f64N/A

        \[\leadsto \mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}}\right) \]
      16. lower-neg.f6486.1

        \[\leadsto \mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \frac{\color{blue}{-b}}{a}\right) \]
    5. Applied rewrites86.1%

      \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \frac{-b}{a}\right)} \]

    if -1.15e-46 < b < 6.60000000000000007e-47

    1. Initial program 73.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6473.7

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval73.7

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites73.7%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Taylor expanded in c around inf

      \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
    6. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
      2. lower-*.f6466.4

        \[\leadsto \frac{\sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}} - b}{2 \cdot a} \]
    7. Applied rewrites66.4%

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

    if 6.60000000000000007e-47 < b

    1. Initial program 10.8%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{-1 \cdot \frac{c}{b}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      2. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      3. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(c\right)}}{b} \]
      4. lower-neg.f6490.9

        \[\leadsto \frac{\color{blue}{-c}}{b} \]
    5. Applied rewrites90.9%

      \[\leadsto \color{blue}{\frac{-c}{b}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification82.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;b \leq -1.15 \cdot 10^{-46}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\frac{c}{b}}{b}, b, \frac{-b}{a}\right)\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\left(c \cdot a\right) \cdot -4} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \]
  5. Add Preprocessing

Alternative 5: 80.9% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -6.5 \cdot 10^{-50}:\\ \;\;\;\;\left(\frac{c}{b \cdot b} - \frac{1}{a}\right) \cdot b\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\left(c \cdot a\right) \cdot -4} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b -6.5e-50)
   (* (- (/ c (* b b)) (/ 1.0 a)) b)
   (if (<= b 6.6e-47)
     (/ (- (sqrt (* (* c a) -4.0)) b) (* 2.0 a))
     (/ (- c) b))))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -6.5e-50) {
		tmp = ((c / (b * b)) - (1.0 / a)) * b;
	} else if (b <= 6.6e-47) {
		tmp = (sqrt(((c * a) * -4.0)) - b) / (2.0 * a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    real(8) :: tmp
    if (b <= (-6.5d-50)) then
        tmp = ((c / (b * b)) - (1.0d0 / a)) * b
    else if (b <= 6.6d-47) then
        tmp = (sqrt(((c * a) * (-4.0d0))) - b) / (2.0d0 * a)
    else
        tmp = -c / b
    end if
    code = tmp
end function
public static double code(double a, double b, double c) {
	double tmp;
	if (b <= -6.5e-50) {
		tmp = ((c / (b * b)) - (1.0 / a)) * b;
	} else if (b <= 6.6e-47) {
		tmp = (Math.sqrt(((c * a) * -4.0)) - b) / (2.0 * a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
def code(a, b, c):
	tmp = 0
	if b <= -6.5e-50:
		tmp = ((c / (b * b)) - (1.0 / a)) * b
	elif b <= 6.6e-47:
		tmp = (math.sqrt(((c * a) * -4.0)) - b) / (2.0 * a)
	else:
		tmp = -c / b
	return tmp
function code(a, b, c)
	tmp = 0.0
	if (b <= -6.5e-50)
		tmp = Float64(Float64(Float64(c / Float64(b * b)) - Float64(1.0 / a)) * b);
	elseif (b <= 6.6e-47)
		tmp = Float64(Float64(sqrt(Float64(Float64(c * a) * -4.0)) - b) / Float64(2.0 * a));
	else
		tmp = Float64(Float64(-c) / b);
	end
	return tmp
end
function tmp_2 = code(a, b, c)
	tmp = 0.0;
	if (b <= -6.5e-50)
		tmp = ((c / (b * b)) - (1.0 / a)) * b;
	elseif (b <= 6.6e-47)
		tmp = (sqrt(((c * a) * -4.0)) - b) / (2.0 * a);
	else
		tmp = -c / b;
	end
	tmp_2 = tmp;
end
code[a_, b_, c_] := If[LessEqual[b, -6.5e-50], N[(N[(N[(c / N[(b * b), $MachinePrecision]), $MachinePrecision] - N[(1.0 / a), $MachinePrecision]), $MachinePrecision] * b), $MachinePrecision], If[LessEqual[b, 6.6e-47], N[(N[(N[Sqrt[N[(N[(c * a), $MachinePrecision] * -4.0), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[((-c) / b), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -6.5 \cdot 10^{-50}:\\
\;\;\;\;\left(\frac{c}{b \cdot b} - \frac{1}{a}\right) \cdot b\\

\mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\
\;\;\;\;\frac{\sqrt{\left(c \cdot a\right) \cdot -4} - b}{2 \cdot a}\\

\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if b < -6.49999999999999987e-50

    1. Initial program 70.0%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6470.0

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval70.0

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites70.0%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \left(b \cdot \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right)\right)} \]
    6. Step-by-step derivation
      1. mul-1-negN/A

        \[\leadsto \color{blue}{\mathsf{neg}\left(b \cdot \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right)\right)} \]
      2. *-commutativeN/A

        \[\leadsto \mathsf{neg}\left(\color{blue}{\left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot b}\right) \]
      3. distribute-rgt-neg-inN/A

        \[\leadsto \color{blue}{\left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot \left(\mathsf{neg}\left(b\right)\right)} \]
      4. mul-1-negN/A

        \[\leadsto \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot \color{blue}{\left(-1 \cdot b\right)} \]
      5. lower-*.f64N/A

        \[\leadsto \color{blue}{\left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot \left(-1 \cdot b\right)} \]
      6. +-commutativeN/A

        \[\leadsto \color{blue}{\left(\frac{1}{a} + -1 \cdot \frac{c}{{b}^{2}}\right)} \cdot \left(-1 \cdot b\right) \]
      7. mul-1-negN/A

        \[\leadsto \left(\frac{1}{a} + \color{blue}{\left(\mathsf{neg}\left(\frac{c}{{b}^{2}}\right)\right)}\right) \cdot \left(-1 \cdot b\right) \]
      8. unsub-negN/A

        \[\leadsto \color{blue}{\left(\frac{1}{a} - \frac{c}{{b}^{2}}\right)} \cdot \left(-1 \cdot b\right) \]
      9. lower--.f64N/A

        \[\leadsto \color{blue}{\left(\frac{1}{a} - \frac{c}{{b}^{2}}\right)} \cdot \left(-1 \cdot b\right) \]
      10. lower-/.f64N/A

        \[\leadsto \left(\color{blue}{\frac{1}{a}} - \frac{c}{{b}^{2}}\right) \cdot \left(-1 \cdot b\right) \]
      11. lower-/.f64N/A

        \[\leadsto \left(\frac{1}{a} - \color{blue}{\frac{c}{{b}^{2}}}\right) \cdot \left(-1 \cdot b\right) \]
      12. unpow2N/A

        \[\leadsto \left(\frac{1}{a} - \frac{c}{\color{blue}{b \cdot b}}\right) \cdot \left(-1 \cdot b\right) \]
      13. lower-*.f64N/A

        \[\leadsto \left(\frac{1}{a} - \frac{c}{\color{blue}{b \cdot b}}\right) \cdot \left(-1 \cdot b\right) \]
      14. mul-1-negN/A

        \[\leadsto \left(\frac{1}{a} - \frac{c}{b \cdot b}\right) \cdot \color{blue}{\left(\mathsf{neg}\left(b\right)\right)} \]
      15. lower-neg.f6484.9

        \[\leadsto \left(\frac{1}{a} - \frac{c}{b \cdot b}\right) \cdot \color{blue}{\left(-b\right)} \]
    7. Applied rewrites84.9%

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

    if -6.49999999999999987e-50 < b < 6.60000000000000007e-47

    1. Initial program 74.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6474.7

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval74.7

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites74.7%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Taylor expanded in c around inf

      \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
    6. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
      2. lower-*.f6467.3

        \[\leadsto \frac{\sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}} - b}{2 \cdot a} \]
    7. Applied rewrites67.3%

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

    if 6.60000000000000007e-47 < b

    1. Initial program 10.8%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{-1 \cdot \frac{c}{b}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      2. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      3. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(c\right)}}{b} \]
      4. lower-neg.f6490.9

        \[\leadsto \frac{\color{blue}{-c}}{b} \]
    5. Applied rewrites90.9%

      \[\leadsto \color{blue}{\frac{-c}{b}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification82.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;b \leq -6.5 \cdot 10^{-50}:\\ \;\;\;\;\left(\frac{c}{b \cdot b} - \frac{1}{a}\right) \cdot b\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\frac{\sqrt{\left(c \cdot a\right) \cdot -4} - b}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \]
  5. Add Preprocessing

Alternative 6: 80.8% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -6.5 \cdot 10^{-50}:\\ \;\;\;\;\left(\frac{c}{b \cdot b} - \frac{1}{a}\right) \cdot b\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\left(\sqrt{\left(-4 \cdot a\right) \cdot c} - b\right) \cdot \frac{0.5}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b -6.5e-50)
   (* (- (/ c (* b b)) (/ 1.0 a)) b)
   (if (<= b 6.6e-47)
     (* (- (sqrt (* (* -4.0 a) c)) b) (/ 0.5 a))
     (/ (- c) b))))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -6.5e-50) {
		tmp = ((c / (b * b)) - (1.0 / a)) * b;
	} else if (b <= 6.6e-47) {
		tmp = (sqrt(((-4.0 * a) * c)) - b) * (0.5 / a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    real(8) :: tmp
    if (b <= (-6.5d-50)) then
        tmp = ((c / (b * b)) - (1.0d0 / a)) * b
    else if (b <= 6.6d-47) then
        tmp = (sqrt((((-4.0d0) * a) * c)) - b) * (0.5d0 / a)
    else
        tmp = -c / b
    end if
    code = tmp
end function
public static double code(double a, double b, double c) {
	double tmp;
	if (b <= -6.5e-50) {
		tmp = ((c / (b * b)) - (1.0 / a)) * b;
	} else if (b <= 6.6e-47) {
		tmp = (Math.sqrt(((-4.0 * a) * c)) - b) * (0.5 / a);
	} else {
		tmp = -c / b;
	}
	return tmp;
}
def code(a, b, c):
	tmp = 0
	if b <= -6.5e-50:
		tmp = ((c / (b * b)) - (1.0 / a)) * b
	elif b <= 6.6e-47:
		tmp = (math.sqrt(((-4.0 * a) * c)) - b) * (0.5 / a)
	else:
		tmp = -c / b
	return tmp
function code(a, b, c)
	tmp = 0.0
	if (b <= -6.5e-50)
		tmp = Float64(Float64(Float64(c / Float64(b * b)) - Float64(1.0 / a)) * b);
	elseif (b <= 6.6e-47)
		tmp = Float64(Float64(sqrt(Float64(Float64(-4.0 * a) * c)) - b) * Float64(0.5 / a));
	else
		tmp = Float64(Float64(-c) / b);
	end
	return tmp
end
function tmp_2 = code(a, b, c)
	tmp = 0.0;
	if (b <= -6.5e-50)
		tmp = ((c / (b * b)) - (1.0 / a)) * b;
	elseif (b <= 6.6e-47)
		tmp = (sqrt(((-4.0 * a) * c)) - b) * (0.5 / a);
	else
		tmp = -c / b;
	end
	tmp_2 = tmp;
end
code[a_, b_, c_] := If[LessEqual[b, -6.5e-50], N[(N[(N[(c / N[(b * b), $MachinePrecision]), $MachinePrecision] - N[(1.0 / a), $MachinePrecision]), $MachinePrecision] * b), $MachinePrecision], If[LessEqual[b, 6.6e-47], N[(N[(N[Sqrt[N[(N[(-4.0 * a), $MachinePrecision] * c), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision] * N[(0.5 / a), $MachinePrecision]), $MachinePrecision], N[((-c) / b), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -6.5 \cdot 10^{-50}:\\
\;\;\;\;\left(\frac{c}{b \cdot b} - \frac{1}{a}\right) \cdot b\\

\mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\
\;\;\;\;\left(\sqrt{\left(-4 \cdot a\right) \cdot c} - b\right) \cdot \frac{0.5}{a}\\

\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if b < -6.49999999999999987e-50

    1. Initial program 70.0%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6470.0

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval70.0

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites70.0%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \left(b \cdot \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right)\right)} \]
    6. Step-by-step derivation
      1. mul-1-negN/A

        \[\leadsto \color{blue}{\mathsf{neg}\left(b \cdot \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right)\right)} \]
      2. *-commutativeN/A

        \[\leadsto \mathsf{neg}\left(\color{blue}{\left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot b}\right) \]
      3. distribute-rgt-neg-inN/A

        \[\leadsto \color{blue}{\left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot \left(\mathsf{neg}\left(b\right)\right)} \]
      4. mul-1-negN/A

        \[\leadsto \left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot \color{blue}{\left(-1 \cdot b\right)} \]
      5. lower-*.f64N/A

        \[\leadsto \color{blue}{\left(-1 \cdot \frac{c}{{b}^{2}} + \frac{1}{a}\right) \cdot \left(-1 \cdot b\right)} \]
      6. +-commutativeN/A

        \[\leadsto \color{blue}{\left(\frac{1}{a} + -1 \cdot \frac{c}{{b}^{2}}\right)} \cdot \left(-1 \cdot b\right) \]
      7. mul-1-negN/A

        \[\leadsto \left(\frac{1}{a} + \color{blue}{\left(\mathsf{neg}\left(\frac{c}{{b}^{2}}\right)\right)}\right) \cdot \left(-1 \cdot b\right) \]
      8. unsub-negN/A

        \[\leadsto \color{blue}{\left(\frac{1}{a} - \frac{c}{{b}^{2}}\right)} \cdot \left(-1 \cdot b\right) \]
      9. lower--.f64N/A

        \[\leadsto \color{blue}{\left(\frac{1}{a} - \frac{c}{{b}^{2}}\right)} \cdot \left(-1 \cdot b\right) \]
      10. lower-/.f64N/A

        \[\leadsto \left(\color{blue}{\frac{1}{a}} - \frac{c}{{b}^{2}}\right) \cdot \left(-1 \cdot b\right) \]
      11. lower-/.f64N/A

        \[\leadsto \left(\frac{1}{a} - \color{blue}{\frac{c}{{b}^{2}}}\right) \cdot \left(-1 \cdot b\right) \]
      12. unpow2N/A

        \[\leadsto \left(\frac{1}{a} - \frac{c}{\color{blue}{b \cdot b}}\right) \cdot \left(-1 \cdot b\right) \]
      13. lower-*.f64N/A

        \[\leadsto \left(\frac{1}{a} - \frac{c}{\color{blue}{b \cdot b}}\right) \cdot \left(-1 \cdot b\right) \]
      14. mul-1-negN/A

        \[\leadsto \left(\frac{1}{a} - \frac{c}{b \cdot b}\right) \cdot \color{blue}{\left(\mathsf{neg}\left(b\right)\right)} \]
      15. lower-neg.f6484.9

        \[\leadsto \left(\frac{1}{a} - \frac{c}{b \cdot b}\right) \cdot \color{blue}{\left(-b\right)} \]
    7. Applied rewrites84.9%

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

    if -6.49999999999999987e-50 < b < 6.60000000000000007e-47

    1. Initial program 74.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6474.7

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval74.7

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites74.7%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Taylor expanded in c around inf

      \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
    6. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
      2. lower-*.f6467.3

        \[\leadsto \frac{\sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}} - b}{2 \cdot a} \]
    7. Applied rewrites67.3%

      \[\leadsto \frac{\sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}} - b}{2 \cdot a} \]
    8. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{\sqrt{-4 \cdot \left(a \cdot c\right)} - b}{2 \cdot a}} \]
      2. clear-numN/A

        \[\leadsto \color{blue}{\frac{1}{\frac{2 \cdot a}{\sqrt{-4 \cdot \left(a \cdot c\right)} - b}}} \]
      3. associate-/r/N/A

        \[\leadsto \color{blue}{\frac{1}{2 \cdot a} \cdot \left(\sqrt{-4 \cdot \left(a \cdot c\right)} - b\right)} \]
      4. lower-*.f64N/A

        \[\leadsto \color{blue}{\frac{1}{2 \cdot a} \cdot \left(\sqrt{-4 \cdot \left(a \cdot c\right)} - b\right)} \]
      5. lift-*.f64N/A

        \[\leadsto \frac{1}{\color{blue}{2 \cdot a}} \cdot \left(\sqrt{-4 \cdot \left(a \cdot c\right)} - b\right) \]
      6. associate-/r*N/A

        \[\leadsto \color{blue}{\frac{\frac{1}{2}}{a}} \cdot \left(\sqrt{-4 \cdot \left(a \cdot c\right)} - b\right) \]
      7. metadata-evalN/A

        \[\leadsto \frac{\color{blue}{\frac{1}{2}}}{a} \cdot \left(\sqrt{-4 \cdot \left(a \cdot c\right)} - b\right) \]
      8. lift-/.f6467.3

        \[\leadsto \color{blue}{\frac{0.5}{a}} \cdot \left(\sqrt{-4 \cdot \left(a \cdot c\right)} - b\right) \]
    9. Applied rewrites67.3%

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

    if 6.60000000000000007e-47 < b

    1. Initial program 10.8%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{-1 \cdot \frac{c}{b}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      2. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      3. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(c\right)}}{b} \]
      4. lower-neg.f6490.9

        \[\leadsto \frac{\color{blue}{-c}}{b} \]
    5. Applied rewrites90.9%

      \[\leadsto \color{blue}{\frac{-c}{b}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification82.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;b \leq -6.5 \cdot 10^{-50}:\\ \;\;\;\;\left(\frac{c}{b \cdot b} - \frac{1}{a}\right) \cdot b\\ \mathbf{elif}\;b \leq 6.6 \cdot 10^{-47}:\\ \;\;\;\;\left(\sqrt{\left(-4 \cdot a\right) \cdot c} - b\right) \cdot \frac{0.5}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \]
  5. Add Preprocessing

Alternative 7: 67.4% accurate, 2.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq 8.5 \cdot 10^{-253}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-c}{b}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (if (<= b 8.5e-253) (/ (- b) a) (/ (- c) b)))
double code(double a, double b, double c) {
	double tmp;
	if (b <= 8.5e-253) {
		tmp = -b / a;
	} else {
		tmp = -c / b;
	}
	return tmp;
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    real(8) :: tmp
    if (b <= 8.5d-253) then
        tmp = -b / a
    else
        tmp = -c / b
    end if
    code = tmp
end function
public static double code(double a, double b, double c) {
	double tmp;
	if (b <= 8.5e-253) {
		tmp = -b / a;
	} else {
		tmp = -c / b;
	}
	return tmp;
}
def code(a, b, c):
	tmp = 0
	if b <= 8.5e-253:
		tmp = -b / a
	else:
		tmp = -c / b
	return tmp
function code(a, b, c)
	tmp = 0.0
	if (b <= 8.5e-253)
		tmp = Float64(Float64(-b) / a);
	else
		tmp = Float64(Float64(-c) / b);
	end
	return tmp
end
function tmp_2 = code(a, b, c)
	tmp = 0.0;
	if (b <= 8.5e-253)
		tmp = -b / a;
	else
		tmp = -c / b;
	end
	tmp_2 = tmp;
end
code[a_, b_, c_] := If[LessEqual[b, 8.5e-253], N[((-b) / a), $MachinePrecision], N[((-c) / b), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq 8.5 \cdot 10^{-253}:\\
\;\;\;\;\frac{-b}{a}\\

\mathbf{else}:\\
\;\;\;\;\frac{-c}{b}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if b < 8.4999999999999999e-253

    1. Initial program 73.9%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \frac{b}{a}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot b}{a}} \]
      2. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(b\right)}}{a} \]
      3. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}} \]
      4. lower-neg.f6463.6

        \[\leadsto \frac{\color{blue}{-b}}{a} \]
    5. Applied rewrites63.6%

      \[\leadsto \color{blue}{\frac{-b}{a}} \]

    if 8.4999999999999999e-253 < b

    1. Initial program 21.6%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in c around 0

      \[\leadsto \color{blue}{-1 \cdot \frac{c}{b}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      2. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot c}{b}} \]
      3. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(c\right)}}{b} \]
      4. lower-neg.f6477.3

        \[\leadsto \frac{\color{blue}{-c}}{b} \]
    5. Applied rewrites77.3%

      \[\leadsto \color{blue}{\frac{-c}{b}} \]
  3. Recombined 2 regimes into one program.
  4. Add Preprocessing

Alternative 8: 43.4% accurate, 2.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -4 \cdot 10^{-310}:\\ \;\;\;\;\frac{-b}{a}\\ \mathbf{else}:\\ \;\;\;\;0\\ \end{array} \end{array} \]
(FPCore (a b c) :precision binary64 (if (<= b -4e-310) (/ (- b) a) 0.0))
double code(double a, double b, double c) {
	double tmp;
	if (b <= -4e-310) {
		tmp = -b / a;
	} else {
		tmp = 0.0;
	}
	return tmp;
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    real(8) :: tmp
    if (b <= (-4d-310)) then
        tmp = -b / a
    else
        tmp = 0.0d0
    end if
    code = tmp
end function
public static double code(double a, double b, double c) {
	double tmp;
	if (b <= -4e-310) {
		tmp = -b / a;
	} else {
		tmp = 0.0;
	}
	return tmp;
}
def code(a, b, c):
	tmp = 0
	if b <= -4e-310:
		tmp = -b / a
	else:
		tmp = 0.0
	return tmp
function code(a, b, c)
	tmp = 0.0
	if (b <= -4e-310)
		tmp = Float64(Float64(-b) / a);
	else
		tmp = 0.0;
	end
	return tmp
end
function tmp_2 = code(a, b, c)
	tmp = 0.0;
	if (b <= -4e-310)
		tmp = -b / a;
	else
		tmp = 0.0;
	end
	tmp_2 = tmp;
end
code[a_, b_, c_] := If[LessEqual[b, -4e-310], N[((-b) / a), $MachinePrecision], 0.0]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;b \leq -4 \cdot 10^{-310}:\\
\;\;\;\;\frac{-b}{a}\\

\mathbf{else}:\\
\;\;\;\;0\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if b < -3.999999999999988e-310

    1. Initial program 73.7%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Taylor expanded in b around -inf

      \[\leadsto \color{blue}{-1 \cdot \frac{b}{a}} \]
    4. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \color{blue}{\frac{-1 \cdot b}{a}} \]
      2. mul-1-negN/A

        \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(b\right)}}{a} \]
      3. lower-/.f64N/A

        \[\leadsto \color{blue}{\frac{\mathsf{neg}\left(b\right)}{a}} \]
      4. lower-neg.f6465.9

        \[\leadsto \frac{\color{blue}{-b}}{a} \]
    5. Applied rewrites65.9%

      \[\leadsto \color{blue}{\frac{-b}{a}} \]

    if -3.999999999999988e-310 < b

    1. Initial program 23.9%

      \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
      3. lift-neg.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
      4. unsub-negN/A

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      5. lower--.f6423.9

        \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
      6. lift--.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
      7. sub-negN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
      8. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      10. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      11. associate-*l*N/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
      12. distribute-lft-neg-inN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
      13. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
      14. associate-*r*N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
      15. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
      16. lower-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
      17. metadata-eval23.9

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
    4. Applied rewrites23.9%

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
    5. Step-by-step derivation
      1. lift-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(-4 \cdot c\right) \cdot a + b \cdot b}} - b}{2 \cdot a} \]
      2. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(-4 \cdot c\right) \cdot a}} - b}{2 \cdot a} \]
      3. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b} + \left(-4 \cdot c\right) \cdot a} - b}{2 \cdot a} \]
      4. lower-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)}} - b}{2 \cdot a} \]
      5. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      6. lower-*.f6423.9

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      7. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
      8. *-commutativeN/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
      9. lower-*.f6423.9

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
    6. Applied rewrites23.9%

      \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)}} - b}{2 \cdot a} \]
    7. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)} - b}{2 \cdot a}} \]
      2. lift--.f64N/A

        \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)} - b}}{2 \cdot a} \]
      3. div-subN/A

        \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)}}{2 \cdot a} - \frac{b}{2 \cdot a}} \]
      4. lift-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + a \cdot \left(c \cdot -4\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      5. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b} + a \cdot \left(c \cdot -4\right)}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      6. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b + \color{blue}{a \cdot \left(c \cdot -4\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      7. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b + a \cdot \color{blue}{\left(c \cdot -4\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      8. *-commutativeN/A

        \[\leadsto \frac{\sqrt{b \cdot b + a \cdot \color{blue}{\left(-4 \cdot c\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      9. lift-*.f64N/A

        \[\leadsto \frac{\sqrt{b \cdot b + a \cdot \color{blue}{\left(-4 \cdot c\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      10. *-commutativeN/A

        \[\leadsto \frac{\sqrt{b \cdot b + \color{blue}{\left(-4 \cdot c\right) \cdot a}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      11. +-commutativeN/A

        \[\leadsto \frac{\sqrt{\color{blue}{\left(-4 \cdot c\right) \cdot a + b \cdot b}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      12. lift-fma.f64N/A

        \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
      13. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{2 \cdot a}} - \frac{b}{2 \cdot a} \]
      14. lift-/.f64N/A

        \[\leadsto \frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{2 \cdot a} - \color{blue}{\frac{b}{2 \cdot a}} \]
      15. sub-negN/A

        \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{2 \cdot a} + \left(\mathsf{neg}\left(\frac{b}{2 \cdot a}\right)\right)} \]
    8. Applied rewrites22.7%

      \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{a}, 0.5, \frac{b}{-2 \cdot a}\right)} \]
    9. Taylor expanded in c around 0

      \[\leadsto \color{blue}{\frac{-1}{2} \cdot \frac{b}{a} + \frac{1}{2} \cdot \frac{b}{a}} \]
    10. Step-by-step derivation
      1. distribute-rgt-outN/A

        \[\leadsto \color{blue}{\frac{b}{a} \cdot \left(\frac{-1}{2} + \frac{1}{2}\right)} \]
      2. metadata-evalN/A

        \[\leadsto \frac{b}{a} \cdot \color{blue}{0} \]
      3. mul0-rgt23.8

        \[\leadsto \color{blue}{0} \]
    11. Applied rewrites23.8%

      \[\leadsto \color{blue}{0} \]
  3. Recombined 2 regimes into one program.
  4. Add Preprocessing

Alternative 9: 10.9% accurate, 50.0× speedup?

\[\begin{array}{l} \\ 0 \end{array} \]
(FPCore (a b c) :precision binary64 0.0)
double code(double a, double b, double c) {
	return 0.0;
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    code = 0.0d0
end function
public static double code(double a, double b, double c) {
	return 0.0;
}
def code(a, b, c):
	return 0.0
function code(a, b, c)
	return 0.0
end
function tmp = code(a, b, c)
	tmp = 0.0;
end
code[a_, b_, c_] := 0.0
\begin{array}{l}

\\
0
\end{array}
Derivation
  1. Initial program 48.6%

    \[\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. lift-+.f64N/A

      \[\leadsto \frac{\color{blue}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a} \]
    2. +-commutativeN/A

      \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}{2 \cdot a} \]
    3. lift-neg.f64N/A

      \[\leadsto \frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \color{blue}{\left(\mathsf{neg}\left(b\right)\right)}}{2 \cdot a} \]
    4. unsub-negN/A

      \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
    5. lower--.f6448.6

      \[\leadsto \frac{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}{2 \cdot a} \]
    6. lift--.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}} - b}{2 \cdot a} \]
    7. sub-negN/A

      \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}} - b}{2 \cdot a} \]
    8. +-commutativeN/A

      \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}} - b}{2 \cdot a} \]
    9. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
    10. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right)} \cdot c\right)\right) + b \cdot b} - b}{2 \cdot a} \]
    11. associate-*l*N/A

      \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(\color{blue}{4 \cdot \left(a \cdot c\right)}\right)\right) + b \cdot b} - b}{2 \cdot a} \]
    12. distribute-lft-neg-inN/A

      \[\leadsto \frac{\sqrt{\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot \left(a \cdot c\right)} + b \cdot b} - b}{2 \cdot a} \]
    13. *-commutativeN/A

      \[\leadsto \frac{\sqrt{\left(\mathsf{neg}\left(4\right)\right) \cdot \color{blue}{\left(c \cdot a\right)} + b \cdot b} - b}{2 \cdot a} \]
    14. associate-*r*N/A

      \[\leadsto \frac{\sqrt{\color{blue}{\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c\right) \cdot a} + b \cdot b} - b}{2 \cdot a} \]
    15. lower-fma.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot c, a, b \cdot b\right)}} - b}{2 \cdot a} \]
    16. lower-*.f64N/A

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot c}, a, b \cdot b\right)} - b}{2 \cdot a} \]
    17. metadata-eval48.6

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot c, a, b \cdot b\right)} - b}{2 \cdot a} \]
  4. Applied rewrites48.6%

    \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}}{2 \cdot a} \]
  5. Step-by-step derivation
    1. lift-fma.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{\left(-4 \cdot c\right) \cdot a + b \cdot b}} - b}{2 \cdot a} \]
    2. +-commutativeN/A

      \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + \left(-4 \cdot c\right) \cdot a}} - b}{2 \cdot a} \]
    3. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b} + \left(-4 \cdot c\right) \cdot a} - b}{2 \cdot a} \]
    4. lower-fma.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, \left(-4 \cdot c\right) \cdot a\right)}} - b}{2 \cdot a} \]
    5. *-commutativeN/A

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
    6. lower-*.f6448.6

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, \color{blue}{a \cdot \left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
    7. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(-4 \cdot c\right)}\right)} - b}{2 \cdot a} \]
    8. *-commutativeN/A

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
    9. lower-*.f6448.6

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \color{blue}{\left(c \cdot -4\right)}\right)} - b}{2 \cdot a} \]
  6. Applied rewrites48.6%

    \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)}} - b}{2 \cdot a} \]
  7. Step-by-step derivation
    1. lift-/.f64N/A

      \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)} - b}{2 \cdot a}} \]
    2. lift--.f64N/A

      \[\leadsto \frac{\color{blue}{\sqrt{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)} - b}}{2 \cdot a} \]
    3. div-subN/A

      \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(b, b, a \cdot \left(c \cdot -4\right)\right)}}{2 \cdot a} - \frac{b}{2 \cdot a}} \]
    4. lift-fma.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b + a \cdot \left(c \cdot -4\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    5. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{b \cdot b} + a \cdot \left(c \cdot -4\right)}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    6. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{b \cdot b + \color{blue}{a \cdot \left(c \cdot -4\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    7. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{b \cdot b + a \cdot \color{blue}{\left(c \cdot -4\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    8. *-commutativeN/A

      \[\leadsto \frac{\sqrt{b \cdot b + a \cdot \color{blue}{\left(-4 \cdot c\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    9. lift-*.f64N/A

      \[\leadsto \frac{\sqrt{b \cdot b + a \cdot \color{blue}{\left(-4 \cdot c\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    10. *-commutativeN/A

      \[\leadsto \frac{\sqrt{b \cdot b + \color{blue}{\left(-4 \cdot c\right) \cdot a}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    11. +-commutativeN/A

      \[\leadsto \frac{\sqrt{\color{blue}{\left(-4 \cdot c\right) \cdot a + b \cdot b}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    12. lift-fma.f64N/A

      \[\leadsto \frac{\sqrt{\color{blue}{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}}{2 \cdot a} - \frac{b}{2 \cdot a} \]
    13. lift-/.f64N/A

      \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{2 \cdot a}} - \frac{b}{2 \cdot a} \]
    14. lift-/.f64N/A

      \[\leadsto \frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{2 \cdot a} - \color{blue}{\frac{b}{2 \cdot a}} \]
    15. sub-negN/A

      \[\leadsto \color{blue}{\frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{2 \cdot a} + \left(\mathsf{neg}\left(\frac{b}{2 \cdot a}\right)\right)} \]
  8. Applied rewrites48.0%

    \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)}}{a}, 0.5, \frac{b}{-2 \cdot a}\right)} \]
  9. Taylor expanded in c around 0

    \[\leadsto \color{blue}{\frac{-1}{2} \cdot \frac{b}{a} + \frac{1}{2} \cdot \frac{b}{a}} \]
  10. Step-by-step derivation
    1. distribute-rgt-outN/A

      \[\leadsto \color{blue}{\frac{b}{a} \cdot \left(\frac{-1}{2} + \frac{1}{2}\right)} \]
    2. metadata-evalN/A

      \[\leadsto \frac{b}{a} \cdot \color{blue}{0} \]
    3. mul0-rgt13.4

      \[\leadsto \color{blue}{0} \]
  11. Applied rewrites13.4%

    \[\leadsto \color{blue}{0} \]
  12. Add Preprocessing

Developer Target 1: 70.1% accurate, 0.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\\ \mathbf{if}\;b < 0:\\ \;\;\;\;\frac{\left(-b\right) + t\_0}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c}{a \cdot \frac{\left(-b\right) - t\_0}{2 \cdot a}}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (let* ((t_0 (sqrt (- (* b b) (* (* 4.0 a) c)))))
   (if (< b 0.0)
     (/ (+ (- b) t_0) (* 2.0 a))
     (/ c (* a (/ (- (- b) t_0) (* 2.0 a)))))))
double code(double a, double b, double c) {
	double t_0 = sqrt(((b * b) - ((4.0 * a) * c)));
	double tmp;
	if (b < 0.0) {
		tmp = (-b + t_0) / (2.0 * a);
	} else {
		tmp = c / (a * ((-b - t_0) / (2.0 * a)));
	}
	return tmp;
}
real(8) function code(a, b, c)
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    real(8), intent (in) :: c
    real(8) :: t_0
    real(8) :: tmp
    t_0 = sqrt(((b * b) - ((4.0d0 * a) * c)))
    if (b < 0.0d0) then
        tmp = (-b + t_0) / (2.0d0 * a)
    else
        tmp = c / (a * ((-b - t_0) / (2.0d0 * a)))
    end if
    code = tmp
end function
public static double code(double a, double b, double c) {
	double t_0 = Math.sqrt(((b * b) - ((4.0 * a) * c)));
	double tmp;
	if (b < 0.0) {
		tmp = (-b + t_0) / (2.0 * a);
	} else {
		tmp = c / (a * ((-b - t_0) / (2.0 * a)));
	}
	return tmp;
}
def code(a, b, c):
	t_0 = math.sqrt(((b * b) - ((4.0 * a) * c)))
	tmp = 0
	if b < 0.0:
		tmp = (-b + t_0) / (2.0 * a)
	else:
		tmp = c / (a * ((-b - t_0) / (2.0 * a)))
	return tmp
function code(a, b, c)
	t_0 = sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))
	tmp = 0.0
	if (b < 0.0)
		tmp = Float64(Float64(Float64(-b) + t_0) / Float64(2.0 * a));
	else
		tmp = Float64(c / Float64(a * Float64(Float64(Float64(-b) - t_0) / Float64(2.0 * a))));
	end
	return tmp
end
function tmp_2 = code(a, b, c)
	t_0 = sqrt(((b * b) - ((4.0 * a) * c)));
	tmp = 0.0;
	if (b < 0.0)
		tmp = (-b + t_0) / (2.0 * a);
	else
		tmp = c / (a * ((-b - t_0) / (2.0 * a)));
	end
	tmp_2 = tmp;
end
code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(N[(b * b), $MachinePrecision] - N[(N[(4.0 * a), $MachinePrecision] * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[Less[b, 0.0], N[(N[((-b) + t$95$0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(c / N[(a * N[(N[((-b) - t$95$0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\\
\mathbf{if}\;b < 0:\\
\;\;\;\;\frac{\left(-b\right) + t\_0}{2 \cdot a}\\

\mathbf{else}:\\
\;\;\;\;\frac{c}{a \cdot \frac{\left(-b\right) - t\_0}{2 \cdot a}}\\


\end{array}
\end{array}

Reproduce

?
herbie shell --seed 2024268 
(FPCore (a b c)
  :name "The quadratic formula (r1)"
  :precision binary64

  :alt
  (! :herbie-platform default (let ((d (- (* b b) (* (* 4 a) c)))) (let ((r1 (/ (+ (- b) (sqrt d)) (* 2 a)))) (let ((r2 (/ (- (- b) (sqrt d)) (* 2 a)))) (if (< b 0) r1 (/ c (* a r2)))))))

  (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))