jeff quadratic root 1

Percentage Accurate: 71.3% → 91.1%
Time: 4.7s
Alternatives: 15
Speedup: 1.0×

Specification

?
\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\\ \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - t\_0}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_0}\\ \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)) (/ (* 2.0 c) (+ (- b) t_0)))))
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 = (2.0 * c) / (-b + t_0);
	}
	return tmp;
}
module fmin_fmax_functions
    implicit none
    private
    public fmax
    public fmin

    interface fmax
        module procedure fmax88
        module procedure fmax44
        module procedure fmax84
        module procedure fmax48
    end interface
    interface fmin
        module procedure fmin88
        module procedure fmin44
        module procedure fmin84
        module procedure fmin48
    end interface
contains
    real(8) function fmax88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(4) function fmax44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(8) function fmax84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmax48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
    end function
    real(8) function fmin88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(4) function fmin44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(8) function fmin84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmin48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
    end function
end module

real(8) function code(a, b, c)
use fmin_fmax_functions
    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 = (2.0d0 * c) / (-b + t_0)
    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 = (2.0 * c) / (-b + t_0);
	}
	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 = (2.0 * c) / (-b + t_0)
	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(Float64(2.0 * c) / Float64(Float64(-b) + t_0));
	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 = (2.0 * c) / (-b + t_0);
	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[GreaterEqual[b, 0.0], N[(N[((-b) - t$95$0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) + t$95$0), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

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

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


\end{array}
\end{array}

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 15 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: 71.3% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\\ \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - t\_0}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_0}\\ \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)) (/ (* 2.0 c) (+ (- b) t_0)))))
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 = (2.0 * c) / (-b + t_0);
	}
	return tmp;
}
module fmin_fmax_functions
    implicit none
    private
    public fmax
    public fmin

    interface fmax
        module procedure fmax88
        module procedure fmax44
        module procedure fmax84
        module procedure fmax48
    end interface
    interface fmin
        module procedure fmin88
        module procedure fmin44
        module procedure fmin84
        module procedure fmin48
    end interface
contains
    real(8) function fmax88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(4) function fmax44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(8) function fmax84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmax48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
    end function
    real(8) function fmin88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(4) function fmin44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(8) function fmin84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmin48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
    end function
end module

real(8) function code(a, b, c)
use fmin_fmax_functions
    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 = (2.0d0 * c) / (-b + t_0)
    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 = (2.0 * c) / (-b + t_0);
	}
	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 = (2.0 * c) / (-b + t_0)
	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(Float64(2.0 * c) / Float64(Float64(-b) + t_0));
	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 = (2.0 * c) / (-b + t_0);
	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[GreaterEqual[b, 0.0], N[(N[((-b) - t$95$0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) + t$95$0), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

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

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


\end{array}
\end{array}

Alternative 1: 91.1% accurate, 0.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}\\ t_1 := \frac{\frac{c}{b}}{b}\\ \mathbf{if}\;b \leq -2.6 \cdot 10^{+123}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\ \end{array}\\ \mathbf{elif}\;b \leq 2.35 \cdot 10^{-67}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - t\_0}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_0}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, t\_1, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot t\_1}, \left|b\right|, -b\right)}\\ \end{array} \end{array} \]
(FPCore (a b c)
 :precision binary64
 (let* ((t_0 (sqrt (fma (* -4.0 a) c (* b b)))) (t_1 (/ (/ c b) b)))
   (if (<= b -2.6e+123)
     (if (>= b 0.0)
       (/ (- (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a))
       (/ (* 2.0 c) (fma 1.0 (fabs b) (- b))))
     (if (<= b 2.35e-67)
       (if (>= b 0.0) (/ (- (- b) t_0) (* 2.0 a)) (/ (* 2.0 c) (+ (- b) t_0)))
       (if (>= b 0.0)
         (/ (- (- b) (* (sqrt (fma (* -4.0 a) t_1 1.0)) (fabs b))) (* 2.0 a))
         (/
          (* 2.0 c)
          (fma (sqrt (- 1.0 (* (* a 4.0) t_1))) (fabs b) (- b))))))))
double code(double a, double b, double c) {
	double t_0 = sqrt(fma((-4.0 * a), c, (b * b)));
	double t_1 = (c / b) / b;
	double tmp_1;
	if (b <= -2.6e+123) {
		double tmp_2;
		if (b >= 0.0) {
			tmp_2 = (-b - sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
		} else {
			tmp_2 = (2.0 * c) / fma(1.0, fabs(b), -b);
		}
		tmp_1 = tmp_2;
	} else if (b <= 2.35e-67) {
		double tmp_3;
		if (b >= 0.0) {
			tmp_3 = (-b - t_0) / (2.0 * a);
		} else {
			tmp_3 = (2.0 * c) / (-b + t_0);
		}
		tmp_1 = tmp_3;
	} else if (b >= 0.0) {
		tmp_1 = (-b - (sqrt(fma((-4.0 * a), t_1, 1.0)) * fabs(b))) / (2.0 * a);
	} else {
		tmp_1 = (2.0 * c) / fma(sqrt((1.0 - ((a * 4.0) * t_1))), fabs(b), -b);
	}
	return tmp_1;
}
function code(a, b, c)
	t_0 = sqrt(fma(Float64(-4.0 * a), c, Float64(b * b)))
	t_1 = Float64(Float64(c / b) / b)
	tmp_1 = 0.0
	if (b <= -2.6e+123)
		tmp_2 = 0.0
		if (b >= 0.0)
			tmp_2 = Float64(Float64(Float64(-b) - sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a));
		else
			tmp_2 = Float64(Float64(2.0 * c) / fma(1.0, abs(b), Float64(-b)));
		end
		tmp_1 = tmp_2;
	elseif (b <= 2.35e-67)
		tmp_3 = 0.0
		if (b >= 0.0)
			tmp_3 = Float64(Float64(Float64(-b) - t_0) / Float64(2.0 * a));
		else
			tmp_3 = Float64(Float64(2.0 * c) / Float64(Float64(-b) + t_0));
		end
		tmp_1 = tmp_3;
	elseif (b >= 0.0)
		tmp_1 = Float64(Float64(Float64(-b) - Float64(sqrt(fma(Float64(-4.0 * a), t_1, 1.0)) * abs(b))) / Float64(2.0 * a));
	else
		tmp_1 = Float64(Float64(2.0 * c) / fma(sqrt(Float64(1.0 - Float64(Float64(a * 4.0) * t_1))), abs(b), Float64(-b)));
	end
	return tmp_1
end
code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(N[(-4.0 * a), $MachinePrecision] * c + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[(c / b), $MachinePrecision] / b), $MachinePrecision]}, If[LessEqual[b, -2.6e+123], If[GreaterEqual[b, 0.0], 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], N[(N[(2.0 * c), $MachinePrecision] / N[(1.0 * N[Abs[b], $MachinePrecision] + (-b)), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 2.35e-67], If[GreaterEqual[b, 0.0], N[(N[((-b) - t$95$0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) + t$95$0), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], N[(N[((-b) - N[(N[Sqrt[N[(N[(-4.0 * a), $MachinePrecision] * t$95$1 + 1.0), $MachinePrecision]], $MachinePrecision] * N[Abs[b], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[(N[Sqrt[N[(1.0 - N[(N[(a * 4.0), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[Abs[b], $MachinePrecision] + (-b)), $MachinePrecision]), $MachinePrecision]]]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}\\
t_1 := \frac{\frac{c}{b}}{b}\\
\mathbf{if}\;b \leq -2.6 \cdot 10^{+123}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \geq 0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\

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


\end{array}\\

\mathbf{elif}\;b \leq 2.35 \cdot 10^{-67}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \geq 0:\\
\;\;\;\;\frac{\left(-b\right) - t\_0}{2 \cdot a}\\

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


\end{array}\\

\mathbf{elif}\;b \geq 0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, t\_1, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\

\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot t\_1}, \left|b\right|, -b\right)}\\


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

    1. Initial program 71.3%

      \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
    2. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\ \end{array} \]
      2. +-commutativeN/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}\\ \end{array} \]
      3. lift-sqrt.f64N/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\ \end{array} \]
      4. lift--.f64N/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2} \cdot c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\ \end{array} \]
      5. sub-to-multN/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2} \cdot c}{\sqrt{\left(1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)} + \left(-b\right)}\\ \end{array} \]
      6. sqrt-prodN/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \sqrt{b \cdot b} + \left(-b\right)}\\ \end{array} \]
      7. lift-*.f64N/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \sqrt{b \cdot b} + \left(-b\right)}\\ \end{array} \]
      8. rem-sqrt-square-revN/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot \color{blue}{c}}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \left|b\right| + \left(-b\right)}\\ \end{array} \]
      9. lower-fma.f64N/A

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}}, \left|b\right|, -b\right)}}\\ \end{array} \]
    3. Applied rewrites73.3%

      \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}}\\ \end{array} \]
    4. Taylor expanded in a around 0

      \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\ \end{array} \]
    5. Step-by-step derivation
      1. Applied rewrites69.4%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\ \end{array} \]

      if -2.59999999999999985e123 < b < 2.35000000000000002e-67

      1. Initial program 71.3%

        \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
      2. Step-by-step derivation
        1. lift--.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. sub-flipN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        3. +-commutativeN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        4. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        5. distribute-lft-neg-outN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(\mathsf{neg}\left(4 \cdot a\right)\right) \cdot c} + b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        6. lower-fma.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        7. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(\color{blue}{4 \cdot a}\right), c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        8. distribute-lft-neg-inN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot a}, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        9. lower-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot a}, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        10. metadata-eval71.3

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
      3. Applied rewrites71.3%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
      4. Step-by-step derivation
        1. lift--.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. sub-flipN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}}\\ \end{array} \]
        3. +-commutativeN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}\\ \end{array} \]
        4. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}\\ \end{array} \]
        5. distribute-lft-neg-outN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\left(\mathsf{neg}\left(4 \cdot a\right)\right) \cdot c + b \cdot b}}\\ \end{array} \]
        6. lower-fma.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}\\ \end{array} \]
        7. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}\\ \end{array} \]
        8. distribute-lft-neg-inN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
        9. lower-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
        10. metadata-eval71.4

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
      5. Applied rewrites71.4%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}\\ \end{array} \]

      if 2.35000000000000002e-67 < b

      1. Initial program 71.3%

        \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
      2. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\ \end{array} \]
        2. +-commutativeN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}\\ \end{array} \]
        3. lift-sqrt.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\ \end{array} \]
        4. lift--.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2} \cdot c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\ \end{array} \]
        5. sub-to-multN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2} \cdot c}{\sqrt{\left(1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)} + \left(-b\right)}\\ \end{array} \]
        6. sqrt-prodN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \sqrt{b \cdot b} + \left(-b\right)}\\ \end{array} \]
        7. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \sqrt{b \cdot b} + \left(-b\right)}\\ \end{array} \]
        8. rem-sqrt-square-revN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot \color{blue}{c}}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \left|b\right| + \left(-b\right)}\\ \end{array} \]
        9. lower-fma.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}}, \left|b\right|, -b\right)}}\\ \end{array} \]
      3. Applied rewrites73.3%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}}\\ \end{array} \]
      4. Step-by-step derivation
        1. lift-sqrt.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        2. lift--.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        3. sub-to-multN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        4. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \frac{\color{blue}{\left(4 \cdot a\right) \cdot c}}{b \cdot b}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        5. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \frac{\color{blue}{\left(4 \cdot a\right)} \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        6. *-commutativeN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \frac{\color{blue}{\left(a \cdot 4\right)} \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        7. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \frac{\color{blue}{\left(a \cdot 4\right)} \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        8. associate-*r/N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \color{blue}{\left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        9. lift-/.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \left(a \cdot 4\right) \cdot \color{blue}{\frac{c}{b \cdot b}}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        10. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(1 - \color{blue}{\left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}\right) \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        11. lift--.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}\right)} \cdot \left(b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        12. sqrt-prodN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \color{blue}{\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}} \cdot \sqrt{b \cdot b}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        13. lift-sqrt.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \color{blue}{\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}} \cdot \sqrt{b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        14. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}} \cdot \sqrt{\color{blue}{b \cdot b}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        15. rem-sqrt-square-revN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}} \cdot \color{blue}{\left|b\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        16. lift-fabs.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}} \cdot \color{blue}{\left|b\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        17. lower-*.f6476.2

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \color{blue}{\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}} \cdot \left|b\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
      5. Applied rewrites76.2%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \color{blue}{\sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{c}{b \cdot b}, 1\right)} \cdot \left|b\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
      6. Step-by-step derivation
        1. lift-/.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \color{blue}{\frac{c}{b \cdot b}}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        2. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{c}{\color{blue}{b \cdot b}}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        3. associate-/r*N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \color{blue}{\frac{\frac{c}{b}}{b}}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        4. lower-/.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \color{blue}{\frac{\frac{c}{b}}{b}}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        5. lower-/.f6477.9

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\color{blue}{\frac{c}{b}}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
      7. Applied rewrites77.9%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \color{blue}{\frac{\frac{c}{b}}{b}}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
      8. Step-by-step derivation
        1. lift-/.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\frac{c}{b}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        2. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\frac{c}{b}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        3. associate-/r*N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\frac{c}{b}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{\frac{c}{b}}{b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        4. lower-/.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\frac{c}{b}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{\frac{c}{b}}{b}}, \left|b\right|, -b\right)}\\ \end{array} \]
        5. lower-/.f6479.9

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\frac{c}{b}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{\frac{c}{b}}{b}}, \left|b\right|, -b\right)}\\ \end{array} \]
      9. Applied rewrites79.9%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, \frac{\frac{c}{b}}{b}, 1\right)} \cdot \left|b\right|}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{\frac{c}{b}}{b}}, \left|b\right|, -b\right)}\\ \end{array} \]
    6. Recombined 3 regimes into one program.
    7. Add Preprocessing

    Alternative 2: 90.3% accurate, 0.8× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}\\ \mathbf{if}\;b \leq -2.6 \cdot 10^{+123}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\ \end{array}\\ \mathbf{elif}\;b \leq 3 \cdot 10^{+106}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - t\_0}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_0}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
    (FPCore (a b c)
     :precision binary64
     (let* ((t_0 (sqrt (fma (* -4.0 a) c (* b b)))))
       (if (<= b -2.6e+123)
         (if (>= b 0.0)
           (/ (- (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a))
           (/ (* 2.0 c) (fma 1.0 (fabs b) (- b))))
         (if (<= b 3e+106)
           (if (>= b 0.0) (/ (- (- b) t_0) (* 2.0 a)) (/ (* 2.0 c) (+ (- b) t_0)))
           (if (>= b 0.0) (* -1.0 (/ b a)) (/ 2.0 (sqrt (* -4.0 (/ a c)))))))))
    double code(double a, double b, double c) {
    	double t_0 = sqrt(fma((-4.0 * a), c, (b * b)));
    	double tmp_1;
    	if (b <= -2.6e+123) {
    		double tmp_2;
    		if (b >= 0.0) {
    			tmp_2 = (-b - sqrt(((b * b) - ((4.0 * a) * c)))) / (2.0 * a);
    		} else {
    			tmp_2 = (2.0 * c) / fma(1.0, fabs(b), -b);
    		}
    		tmp_1 = tmp_2;
    	} else if (b <= 3e+106) {
    		double tmp_3;
    		if (b >= 0.0) {
    			tmp_3 = (-b - t_0) / (2.0 * a);
    		} else {
    			tmp_3 = (2.0 * c) / (-b + t_0);
    		}
    		tmp_1 = tmp_3;
    	} else if (b >= 0.0) {
    		tmp_1 = -1.0 * (b / a);
    	} else {
    		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
    	}
    	return tmp_1;
    }
    
    function code(a, b, c)
    	t_0 = sqrt(fma(Float64(-4.0 * a), c, Float64(b * b)))
    	tmp_1 = 0.0
    	if (b <= -2.6e+123)
    		tmp_2 = 0.0
    		if (b >= 0.0)
    			tmp_2 = Float64(Float64(Float64(-b) - sqrt(Float64(Float64(b * b) - Float64(Float64(4.0 * a) * c)))) / Float64(2.0 * a));
    		else
    			tmp_2 = Float64(Float64(2.0 * c) / fma(1.0, abs(b), Float64(-b)));
    		end
    		tmp_1 = tmp_2;
    	elseif (b <= 3e+106)
    		tmp_3 = 0.0
    		if (b >= 0.0)
    			tmp_3 = Float64(Float64(Float64(-b) - t_0) / Float64(2.0 * a));
    		else
    			tmp_3 = Float64(Float64(2.0 * c) / Float64(Float64(-b) + t_0));
    		end
    		tmp_1 = tmp_3;
    	elseif (b >= 0.0)
    		tmp_1 = Float64(-1.0 * Float64(b / a));
    	else
    		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
    	end
    	return tmp_1
    end
    
    code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(N[(-4.0 * a), $MachinePrecision] * c + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[b, -2.6e+123], If[GreaterEqual[b, 0.0], 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], N[(N[(2.0 * c), $MachinePrecision] / N[(1.0 * N[Abs[b], $MachinePrecision] + (-b)), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 3e+106], If[GreaterEqual[b, 0.0], N[(N[((-b) - t$95$0), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) + t$95$0), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    t_0 := \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}\\
    \mathbf{if}\;b \leq -2.6 \cdot 10^{+123}:\\
    \;\;\;\;\begin{array}{l}
    \mathbf{if}\;b \geq 0:\\
    \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\
    
    
    \end{array}\\
    
    \mathbf{elif}\;b \leq 3 \cdot 10^{+106}:\\
    \;\;\;\;\begin{array}{l}
    \mathbf{if}\;b \geq 0:\\
    \;\;\;\;\frac{\left(-b\right) - t\_0}{2 \cdot a}\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_0}\\
    
    
    \end{array}\\
    
    \mathbf{elif}\;b \geq 0:\\
    \;\;\;\;-1 \cdot \frac{b}{a}\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 3 regimes
    2. if b < -2.59999999999999985e123

      1. Initial program 71.3%

        \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
      2. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\ \end{array} \]
        2. +-commutativeN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}\\ \end{array} \]
        3. lift-sqrt.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\ \end{array} \]
        4. lift--.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2} \cdot c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\ \end{array} \]
        5. sub-to-multN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2} \cdot c}{\sqrt{\left(1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}\right) \cdot \left(b \cdot b\right)} + \left(-b\right)}\\ \end{array} \]
        6. sqrt-prodN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \sqrt{b \cdot b} + \left(-b\right)}\\ \end{array} \]
        7. lift-*.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \sqrt{b \cdot b} + \left(-b\right)}\\ \end{array} \]
        8. rem-sqrt-square-revN/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot \color{blue}{c}}{\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}} \cdot \left|b\right| + \left(-b\right)}\\ \end{array} \]
        9. lower-fma.f64N/A

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \frac{\left(4 \cdot a\right) \cdot c}{b \cdot b}}, \left|b\right|, -b\right)}}\\ \end{array} \]
      3. Applied rewrites73.3%

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{\mathsf{fma}\left(\sqrt{1 - \left(a \cdot 4\right) \cdot \frac{c}{b \cdot b}}, \left|b\right|, -b\right)}}\\ \end{array} \]
      4. Taylor expanded in a around 0

        \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\ \end{array} \]
      5. Step-by-step derivation
        1. Applied rewrites69.4%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{2 \cdot c}}{\mathsf{fma}\left(1, \left|b\right|, -b\right)}\\ \end{array} \]

        if -2.59999999999999985e123 < b < 3.0000000000000001e106

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Step-by-step derivation
          1. lift--.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. sub-flipN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. +-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. distribute-lft-neg-outN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(\mathsf{neg}\left(4 \cdot a\right)\right) \cdot c} + b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          6. lower-fma.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          7. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(\color{blue}{4 \cdot a}\right), c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          8. distribute-lft-neg-inN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot a}, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          9. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot a}, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          10. metadata-eval71.3

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        3. Applied rewrites71.3%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        4. Step-by-step derivation
          1. lift--.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. sub-flipN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}}\\ \end{array} \]
          3. +-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}\\ \end{array} \]
          4. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}\\ \end{array} \]
          5. distribute-lft-neg-outN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\left(\mathsf{neg}\left(4 \cdot a\right)\right) \cdot c + b \cdot b}}\\ \end{array} \]
          6. lower-fma.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}\\ \end{array} \]
          7. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}\\ \end{array} \]
          8. distribute-lft-neg-inN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
          9. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
          10. metadata-eval71.4

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
        5. Applied rewrites71.4%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}\\ \end{array} \]

        if 3.0000000000000001e106 < b

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        3. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          2. lower-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
          3. lower-*.f6436.5

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
        4. Applied rewrites36.5%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        5. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        6. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          2. lower-/.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        7. Applied rewrites35.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        8. Taylor expanded in c around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
        9. Step-by-step derivation
          1. lower-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
          2. lower-sqrt.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
          3. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
          4. lower-/.f6442.3

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
        10. Applied rewrites42.3%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
      6. Recombined 3 regimes into one program.
      7. Add Preprocessing

      Alternative 3: 90.3% accurate, 0.8× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := -1 \cdot \frac{b}{a}\\ t_1 := \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}\\ \mathbf{if}\;b \leq -2.8 \cdot 10^{+123}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq 3 \cdot 10^{+106}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - t\_1}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_1}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
      (FPCore (a b c)
       :precision binary64
       (let* ((t_0 (* -1.0 (/ b a))) (t_1 (sqrt (fma (* -4.0 a) c (* b b)))))
         (if (<= b -2.8e+123)
           (if (>= b 0.0) t_0 (* (+ c c) (/ -0.5 b)))
           (if (<= b 3e+106)
             (if (>= b 0.0) (/ (- (- b) t_1) (* 2.0 a)) (/ (* 2.0 c) (+ (- b) t_1)))
             (if (>= b 0.0) t_0 (/ 2.0 (sqrt (* -4.0 (/ a c)))))))))
      double code(double a, double b, double c) {
      	double t_0 = -1.0 * (b / a);
      	double t_1 = sqrt(fma((-4.0 * a), c, (b * b)));
      	double tmp_1;
      	if (b <= -2.8e+123) {
      		double tmp_2;
      		if (b >= 0.0) {
      			tmp_2 = t_0;
      		} else {
      			tmp_2 = (c + c) * (-0.5 / b);
      		}
      		tmp_1 = tmp_2;
      	} else if (b <= 3e+106) {
      		double tmp_3;
      		if (b >= 0.0) {
      			tmp_3 = (-b - t_1) / (2.0 * a);
      		} else {
      			tmp_3 = (2.0 * c) / (-b + t_1);
      		}
      		tmp_1 = tmp_3;
      	} else if (b >= 0.0) {
      		tmp_1 = t_0;
      	} else {
      		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
      	}
      	return tmp_1;
      }
      
      function code(a, b, c)
      	t_0 = Float64(-1.0 * Float64(b / a))
      	t_1 = sqrt(fma(Float64(-4.0 * a), c, Float64(b * b)))
      	tmp_1 = 0.0
      	if (b <= -2.8e+123)
      		tmp_2 = 0.0
      		if (b >= 0.0)
      			tmp_2 = t_0;
      		else
      			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
      		end
      		tmp_1 = tmp_2;
      	elseif (b <= 3e+106)
      		tmp_3 = 0.0
      		if (b >= 0.0)
      			tmp_3 = Float64(Float64(Float64(-b) - t_1) / Float64(2.0 * a));
      		else
      			tmp_3 = Float64(Float64(2.0 * c) / Float64(Float64(-b) + t_1));
      		end
      		tmp_1 = tmp_3;
      	elseif (b >= 0.0)
      		tmp_1 = t_0;
      	else
      		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
      	end
      	return tmp_1
      end
      
      code[a_, b_, c_] := Block[{t$95$0 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Sqrt[N[(N[(-4.0 * a), $MachinePrecision] * c + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[b, -2.8e+123], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 3e+106], If[GreaterEqual[b, 0.0], N[(N[((-b) - t$95$1), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) + t$95$1), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$0, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := -1 \cdot \frac{b}{a}\\
      t_1 := \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}\\
      \mathbf{if}\;b \leq -2.8 \cdot 10^{+123}:\\
      \;\;\;\;\begin{array}{l}
      \mathbf{if}\;b \geq 0:\\
      \;\;\;\;t\_0\\
      
      \mathbf{else}:\\
      \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
      
      
      \end{array}\\
      
      \mathbf{elif}\;b \leq 3 \cdot 10^{+106}:\\
      \;\;\;\;\begin{array}{l}
      \mathbf{if}\;b \geq 0:\\
      \;\;\;\;\frac{\left(-b\right) - t\_1}{2 \cdot a}\\
      
      \mathbf{else}:\\
      \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_1}\\
      
      
      \end{array}\\
      
      \mathbf{elif}\;b \geq 0:\\
      \;\;\;\;t\_0\\
      
      \mathbf{else}:\\
      \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 3 regimes
      2. if b < -2.80000000000000011e123

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        3. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          2. lower-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
          3. lower-*.f6436.5

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
        4. Applied rewrites36.5%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        5. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        6. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          2. lower-/.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        7. Applied rewrites35.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        8. Step-by-step derivation
          1. lift-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          2. mult-flipN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          3. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          4. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          5. count-2-revN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. lift-+.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. lower-/.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          8. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          9. *-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
          10. lower-*.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
          11. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
          12. *-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          13. lower-*.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
        9. Applied rewrites35.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
        10. Taylor expanded in b around -inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
        11. Step-by-step derivation
          1. lower-/.f6467.9

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
        12. Applied rewrites67.9%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

        if -2.80000000000000011e123 < b < 3.0000000000000001e106

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Step-by-step derivation
          1. lift--.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. sub-flipN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. +-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(\mathsf{neg}\left(\color{blue}{\left(4 \cdot a\right) \cdot c}\right)\right) + b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. distribute-lft-neg-outN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left(\mathsf{neg}\left(4 \cdot a\right)\right) \cdot c} + b \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          6. lower-fma.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          7. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(\color{blue}{4 \cdot a}\right), c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          8. distribute-lft-neg-inN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot a}, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          9. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(4\right)\right) \cdot a}, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          10. metadata-eval71.3

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(\color{blue}{-4} \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        3. Applied rewrites71.3%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        4. Step-by-step derivation
          1. lift--.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. sub-flipN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{b \cdot b + \left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right)}}\\ \end{array} \]
          3. +-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}\\ \end{array} \]
          4. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\left(\mathsf{neg}\left(\left(4 \cdot a\right) \cdot c\right)\right) + b \cdot b}}\\ \end{array} \]
          5. distribute-lft-neg-outN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\left(\mathsf{neg}\left(4 \cdot a\right)\right) \cdot c + b \cdot b}}\\ \end{array} \]
          6. lower-fma.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}\\ \end{array} \]
          7. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\mathsf{fma}\left(\mathsf{neg}\left(4 \cdot a\right), c, b \cdot b\right)}}\\ \end{array} \]
          8. distribute-lft-neg-inN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
          9. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\mathsf{fma}\left(\left(\mathsf{neg}\left(4\right)\right) \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
          10. metadata-eval71.4

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}\\ \end{array} \]
        5. Applied rewrites71.4%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\mathsf{fma}\left(-4 \cdot a, c, b \cdot b\right)}}\\ \end{array} \]

        if 3.0000000000000001e106 < b

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        3. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          2. lower-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
          3. lower-*.f6436.5

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
        4. Applied rewrites36.5%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        5. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        6. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          2. lower-/.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        7. Applied rewrites35.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        8. Taylor expanded in c around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
        9. Step-by-step derivation
          1. lower-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
          2. lower-sqrt.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
          3. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
          4. lower-/.f6442.3

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
        10. Applied rewrites42.3%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
      3. Recombined 3 regimes into one program.
      4. Add Preprocessing

      Alternative 4: 90.3% accurate, 0.8× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\mathsf{fma}\left(-4, c \cdot a, b \cdot b\right)}\\ t_1 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -2.8 \cdot 10^{+123}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq 3 \cdot 10^{+106}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{t\_0 + b}{-2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{t\_0 - b}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
      (FPCore (a b c)
       :precision binary64
       (let* ((t_0 (sqrt (fma -4.0 (* c a) (* b b)))) (t_1 (* -1.0 (/ b a))))
         (if (<= b -2.8e+123)
           (if (>= b 0.0) t_1 (* (+ c c) (/ -0.5 b)))
           (if (<= b 3e+106)
             (if (>= b 0.0) (/ (+ t_0 b) (* -2.0 a)) (/ (+ c c) (- t_0 b)))
             (if (>= b 0.0) t_1 (/ 2.0 (sqrt (* -4.0 (/ a c)))))))))
      double code(double a, double b, double c) {
      	double t_0 = sqrt(fma(-4.0, (c * a), (b * b)));
      	double t_1 = -1.0 * (b / a);
      	double tmp_1;
      	if (b <= -2.8e+123) {
      		double tmp_2;
      		if (b >= 0.0) {
      			tmp_2 = t_1;
      		} else {
      			tmp_2 = (c + c) * (-0.5 / b);
      		}
      		tmp_1 = tmp_2;
      	} else if (b <= 3e+106) {
      		double tmp_3;
      		if (b >= 0.0) {
      			tmp_3 = (t_0 + b) / (-2.0 * a);
      		} else {
      			tmp_3 = (c + c) / (t_0 - b);
      		}
      		tmp_1 = tmp_3;
      	} else if (b >= 0.0) {
      		tmp_1 = t_1;
      	} else {
      		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
      	}
      	return tmp_1;
      }
      
      function code(a, b, c)
      	t_0 = sqrt(fma(-4.0, Float64(c * a), Float64(b * b)))
      	t_1 = Float64(-1.0 * Float64(b / a))
      	tmp_1 = 0.0
      	if (b <= -2.8e+123)
      		tmp_2 = 0.0
      		if (b >= 0.0)
      			tmp_2 = t_1;
      		else
      			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
      		end
      		tmp_1 = tmp_2;
      	elseif (b <= 3e+106)
      		tmp_3 = 0.0
      		if (b >= 0.0)
      			tmp_3 = Float64(Float64(t_0 + b) / Float64(-2.0 * a));
      		else
      			tmp_3 = Float64(Float64(c + c) / Float64(t_0 - b));
      		end
      		tmp_1 = tmp_3;
      	elseif (b >= 0.0)
      		tmp_1 = t_1;
      	else
      		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
      	end
      	return tmp_1
      end
      
      code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(-4.0 * N[(c * a), $MachinePrecision] + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -2.8e+123], If[GreaterEqual[b, 0.0], t$95$1, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 3e+106], If[GreaterEqual[b, 0.0], N[(N[(t$95$0 + b), $MachinePrecision] / N[(-2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] / N[(t$95$0 - b), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$1, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sqrt{\mathsf{fma}\left(-4, c \cdot a, b \cdot b\right)}\\
      t_1 := -1 \cdot \frac{b}{a}\\
      \mathbf{if}\;b \leq -2.8 \cdot 10^{+123}:\\
      \;\;\;\;\begin{array}{l}
      \mathbf{if}\;b \geq 0:\\
      \;\;\;\;t\_1\\
      
      \mathbf{else}:\\
      \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
      
      
      \end{array}\\
      
      \mathbf{elif}\;b \leq 3 \cdot 10^{+106}:\\
      \;\;\;\;\begin{array}{l}
      \mathbf{if}\;b \geq 0:\\
      \;\;\;\;\frac{t\_0 + b}{-2 \cdot a}\\
      
      \mathbf{else}:\\
      \;\;\;\;\frac{c + c}{t\_0 - b}\\
      
      
      \end{array}\\
      
      \mathbf{elif}\;b \geq 0:\\
      \;\;\;\;t\_1\\
      
      \mathbf{else}:\\
      \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 3 regimes
      2. if b < -2.80000000000000011e123

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        3. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          2. lower-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
          3. lower-*.f6436.5

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
        4. Applied rewrites36.5%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
        5. Taylor expanded in b around inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        6. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          2. lower-/.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        7. Applied rewrites35.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
        8. Step-by-step derivation
          1. lift-/.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          2. mult-flipN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          3. lower-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          4. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          5. count-2-revN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. lift-+.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. lower-/.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          8. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          9. *-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
          10. lower-*.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
          11. lift-*.f64N/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
          12. *-commutativeN/A

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          13. lower-*.f6435.0

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
        9. Applied rewrites35.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
        10. Taylor expanded in b around -inf

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
        11. Step-by-step derivation
          1. lower-/.f6467.9

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
        12. Applied rewrites67.9%

          \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

        if -2.80000000000000011e123 < b < 3.0000000000000001e106

        1. Initial program 71.3%

          \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
        2. Step-by-step derivation
          1. Applied rewrites71.3%

            \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\sqrt{\mathsf{fma}\left(-4, c \cdot a, b \cdot b\right)} + b}{-2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(-4, c \cdot a, b \cdot b\right)} - b}\\ } \end{array}} \]

          if 3.0000000000000001e106 < b

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Taylor expanded in c around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          9. Step-by-step derivation
            1. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            2. lower-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            4. lower-/.f6442.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
          10. Applied rewrites42.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
        3. Recombined 3 regimes into one program.
        4. Add Preprocessing

        Alternative 5: 85.8% accurate, 0.8× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} t_0 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -2.8 \cdot 10^{+123}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq -2 \cdot 10^{-310}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(c \cdot a, -4, b \cdot b\right)} - b}\\ \end{array}\\ \mathbf{elif}\;b \leq 2.3 \cdot 10^{-69}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\frac{c}{a} \cdot -4} \cdot a}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
        (FPCore (a b c)
         :precision binary64
         (let* ((t_0 (* -1.0 (/ b a))))
           (if (<= b -2.8e+123)
             (if (>= b 0.0) t_0 (* (+ c c) (/ -0.5 b)))
             (if (<= b -2e-310)
               (if (>= b 0.0)
                 (/ (* -2.0 b) (+ a a))
                 (/ (+ c c) (- (sqrt (fma (* c a) -4.0 (* b b))) b)))
               (if (<= b 2.3e-69)
                 (if (>= b 0.0)
                   (/ (- (- b) (sqrt (* (* c -4.0) a))) (+ a a))
                   (/ (+ c c) (* (sqrt (* (/ c a) -4.0)) a)))
                 (if (>= b 0.0) t_0 (/ 2.0 (sqrt (* -4.0 (/ a c))))))))))
        double code(double a, double b, double c) {
        	double t_0 = -1.0 * (b / a);
        	double tmp_1;
        	if (b <= -2.8e+123) {
        		double tmp_2;
        		if (b >= 0.0) {
        			tmp_2 = t_0;
        		} else {
        			tmp_2 = (c + c) * (-0.5 / b);
        		}
        		tmp_1 = tmp_2;
        	} else if (b <= -2e-310) {
        		double tmp_3;
        		if (b >= 0.0) {
        			tmp_3 = (-2.0 * b) / (a + a);
        		} else {
        			tmp_3 = (c + c) / (sqrt(fma((c * a), -4.0, (b * b))) - b);
        		}
        		tmp_1 = tmp_3;
        	} else if (b <= 2.3e-69) {
        		double tmp_4;
        		if (b >= 0.0) {
        			tmp_4 = (-b - sqrt(((c * -4.0) * a))) / (a + a);
        		} else {
        			tmp_4 = (c + c) / (sqrt(((c / a) * -4.0)) * a);
        		}
        		tmp_1 = tmp_4;
        	} else if (b >= 0.0) {
        		tmp_1 = t_0;
        	} else {
        		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
        	}
        	return tmp_1;
        }
        
        function code(a, b, c)
        	t_0 = Float64(-1.0 * Float64(b / a))
        	tmp_1 = 0.0
        	if (b <= -2.8e+123)
        		tmp_2 = 0.0
        		if (b >= 0.0)
        			tmp_2 = t_0;
        		else
        			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
        		end
        		tmp_1 = tmp_2;
        	elseif (b <= -2e-310)
        		tmp_3 = 0.0
        		if (b >= 0.0)
        			tmp_3 = Float64(Float64(-2.0 * b) / Float64(a + a));
        		else
        			tmp_3 = Float64(Float64(c + c) / Float64(sqrt(fma(Float64(c * a), -4.0, Float64(b * b))) - b));
        		end
        		tmp_1 = tmp_3;
        	elseif (b <= 2.3e-69)
        		tmp_4 = 0.0
        		if (b >= 0.0)
        			tmp_4 = Float64(Float64(Float64(-b) - sqrt(Float64(Float64(c * -4.0) * a))) / Float64(a + a));
        		else
        			tmp_4 = Float64(Float64(c + c) / Float64(sqrt(Float64(Float64(c / a) * -4.0)) * a));
        		end
        		tmp_1 = tmp_4;
        	elseif (b >= 0.0)
        		tmp_1 = t_0;
        	else
        		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
        	end
        	return tmp_1
        end
        
        code[a_, b_, c_] := Block[{t$95$0 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -2.8e+123], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, -2e-310], If[GreaterEqual[b, 0.0], N[(N[(-2.0 * b), $MachinePrecision] / N[(a + a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] / N[(N[Sqrt[N[(N[(c * a), $MachinePrecision] * -4.0 + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 2.3e-69], If[GreaterEqual[b, 0.0], N[(N[((-b) - N[Sqrt[N[(N[(c * -4.0), $MachinePrecision] * a), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(a + a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] / N[(N[Sqrt[N[(N[(c / a), $MachinePrecision] * -4.0), $MachinePrecision]], $MachinePrecision] * a), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$0, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        t_0 := -1 \cdot \frac{b}{a}\\
        \mathbf{if}\;b \leq -2.8 \cdot 10^{+123}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;t\_0\\
        
        \mathbf{else}:\\
        \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \leq -2 \cdot 10^{-310}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;\frac{-2 \cdot b}{a + a}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(c \cdot a, -4, b \cdot b\right)} - b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \leq 2.3 \cdot 10^{-69}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{a + a}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{c + c}{\sqrt{\frac{c}{a} \cdot -4} \cdot a}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \geq 0:\\
        \;\;\;\;t\_0\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 4 regimes
        2. if b < -2.80000000000000011e123

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Step-by-step derivation
            1. lift-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. mult-flipN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            8. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            9. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            10. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            11. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
            12. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            13. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          9. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
          10. Taylor expanded in b around -inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lower-/.f6467.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
          12. Applied rewrites67.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

          if -2.80000000000000011e123 < b < -1.999999999999994e-310

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\color{blue}{-2 \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot \color{blue}{b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. Applied rewrites69.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\color{blue}{-2 \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. Step-by-step derivation
            1. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{\color{blue}{2 \cdot a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{\color{blue}{a + a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            3. lower-+.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{\color{blue}{a + a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            6. lower-+.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            7. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\ \end{array} \]
            8. +-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}\\ \end{array} \]
            9. lift-neg.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(\mathsf{neg}\left(b\right)\right)}}\\ \end{array} \]
            10. sub-flip-reverseN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}\\ \end{array} \]
            11. lower--.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}\\ \end{array} \]
          6. Applied rewrites69.9%

            \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}\\ } \end{array}} \]
          7. Step-by-step derivation
            1. lift-fma.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{c} + c}{\sqrt{\left(-4 \cdot c\right) \cdot a + b \cdot b} - b}\\ \end{array} \]
            2. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\left(-4 \cdot c\right) \cdot a + b \cdot b} - b}\\ \end{array} \]
            3. associate-*l*N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{-4 \cdot \left(c \cdot a\right) + b \cdot b} - b}\\ \end{array} \]
            4. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{-4 \cdot \left(a \cdot c\right) + b \cdot b} - b}\\ \end{array} \]
            5. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{-4 \cdot \left(a \cdot c\right) + b \cdot b} - b}\\ \end{array} \]
            6. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\left(a \cdot c\right) \cdot -4 + b \cdot b} - b}\\ \end{array} \]
            7. lower-fma.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{c} + c}{\sqrt{\mathsf{fma}\left(a \cdot c, -4, b \cdot b\right)} - b}\\ \end{array} \]
            8. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(a \cdot c, -4, b \cdot b\right)} - b}\\ \end{array} \]
            9. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(c \cdot a, -4, b \cdot b\right)} - b}\\ \end{array} \]
            10. lower-*.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(c \cdot a, -4, b \cdot b\right)} - b}\\ \end{array} \]
          8. Applied rewrites69.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{\color{blue}{c} + c}{\sqrt{\mathsf{fma}\left(c \cdot a, -4, b \cdot b\right)} - b}\\ \end{array} \]

          if -1.999999999999994e-310 < b < 2.3000000000000001e-69

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. lower-*.f6456.1

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot \color{blue}{c}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. Applied rewrites56.1%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            2. lower-*.f6440.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          7. Applied rewrites40.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          8. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
          9. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \color{blue}{\frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{\color{blue}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            4. lower-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \color{blue}{\sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            5. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{\color{blue}{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            6. lower-/.f6426.7

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \color{blue}{\frac{c}{a}}}}\\ \end{array} \]
          10. Applied rewrites26.7%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            2. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot \color{blue}{c}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            3. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(c \cdot \color{blue}{a}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            4. associate-*l*N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot \color{blue}{a}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            5. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            6. lower-*.f6426.7

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot \color{blue}{a}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            7. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            8. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            9. lower-*.f6426.7

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            10. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{\mathsf{Rewrite=>}\left(lift-*.f64, \left(2 \cdot a\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            11. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{\mathsf{Rewrite=>}\left(count-2-rev, \left(a + a\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            12. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{\mathsf{Rewrite<=}\left(lift-+.f64, \left(a + a\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
          12. Applied rewrites26.7%

            \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\frac{c}{a} \cdot -4} \cdot a}\\ } \end{array}} \]

          if 2.3000000000000001e-69 < b

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Taylor expanded in c around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          9. Step-by-step derivation
            1. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            2. lower-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            4. lower-/.f6442.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
          10. Applied rewrites42.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
        3. Recombined 4 regimes into one program.
        4. Add Preprocessing

        Alternative 6: 85.4% accurate, 0.8× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} t_0 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -5.5 \cdot 10^{+58}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq -2 \cdot 10^{-310}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}\\ \end{array}\\ \mathbf{elif}\;b \leq 2.3 \cdot 10^{-69}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\frac{c}{a} \cdot -4} \cdot a}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
        (FPCore (a b c)
         :precision binary64
         (let* ((t_0 (* -1.0 (/ b a))))
           (if (<= b -5.5e+58)
             (if (>= b 0.0) t_0 (* (+ c c) (/ -0.5 b)))
             (if (<= b -2e-310)
               (if (>= b 0.0)
                 (/ (* -2.0 b) (+ a a))
                 (/ (+ c c) (- (sqrt (fma (* -4.0 c) a (* b b))) b)))
               (if (<= b 2.3e-69)
                 (if (>= b 0.0)
                   (/ (- (- b) (sqrt (* (* c -4.0) a))) (+ a a))
                   (/ (+ c c) (* (sqrt (* (/ c a) -4.0)) a)))
                 (if (>= b 0.0) t_0 (/ 2.0 (sqrt (* -4.0 (/ a c))))))))))
        double code(double a, double b, double c) {
        	double t_0 = -1.0 * (b / a);
        	double tmp_1;
        	if (b <= -5.5e+58) {
        		double tmp_2;
        		if (b >= 0.0) {
        			tmp_2 = t_0;
        		} else {
        			tmp_2 = (c + c) * (-0.5 / b);
        		}
        		tmp_1 = tmp_2;
        	} else if (b <= -2e-310) {
        		double tmp_3;
        		if (b >= 0.0) {
        			tmp_3 = (-2.0 * b) / (a + a);
        		} else {
        			tmp_3 = (c + c) / (sqrt(fma((-4.0 * c), a, (b * b))) - b);
        		}
        		tmp_1 = tmp_3;
        	} else if (b <= 2.3e-69) {
        		double tmp_4;
        		if (b >= 0.0) {
        			tmp_4 = (-b - sqrt(((c * -4.0) * a))) / (a + a);
        		} else {
        			tmp_4 = (c + c) / (sqrt(((c / a) * -4.0)) * a);
        		}
        		tmp_1 = tmp_4;
        	} else if (b >= 0.0) {
        		tmp_1 = t_0;
        	} else {
        		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
        	}
        	return tmp_1;
        }
        
        function code(a, b, c)
        	t_0 = Float64(-1.0 * Float64(b / a))
        	tmp_1 = 0.0
        	if (b <= -5.5e+58)
        		tmp_2 = 0.0
        		if (b >= 0.0)
        			tmp_2 = t_0;
        		else
        			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
        		end
        		tmp_1 = tmp_2;
        	elseif (b <= -2e-310)
        		tmp_3 = 0.0
        		if (b >= 0.0)
        			tmp_3 = Float64(Float64(-2.0 * b) / Float64(a + a));
        		else
        			tmp_3 = Float64(Float64(c + c) / Float64(sqrt(fma(Float64(-4.0 * c), a, Float64(b * b))) - b));
        		end
        		tmp_1 = tmp_3;
        	elseif (b <= 2.3e-69)
        		tmp_4 = 0.0
        		if (b >= 0.0)
        			tmp_4 = Float64(Float64(Float64(-b) - sqrt(Float64(Float64(c * -4.0) * a))) / Float64(a + a));
        		else
        			tmp_4 = Float64(Float64(c + c) / Float64(sqrt(Float64(Float64(c / a) * -4.0)) * a));
        		end
        		tmp_1 = tmp_4;
        	elseif (b >= 0.0)
        		tmp_1 = t_0;
        	else
        		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
        	end
        	return tmp_1
        end
        
        code[a_, b_, c_] := Block[{t$95$0 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -5.5e+58], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, -2e-310], If[GreaterEqual[b, 0.0], N[(N[(-2.0 * b), $MachinePrecision] / N[(a + a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] / N[(N[Sqrt[N[(N[(-4.0 * c), $MachinePrecision] * a + N[(b * b), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 2.3e-69], If[GreaterEqual[b, 0.0], N[(N[((-b) - N[Sqrt[N[(N[(c * -4.0), $MachinePrecision] * a), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(a + a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] / N[(N[Sqrt[N[(N[(c / a), $MachinePrecision] * -4.0), $MachinePrecision]], $MachinePrecision] * a), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$0, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        t_0 := -1 \cdot \frac{b}{a}\\
        \mathbf{if}\;b \leq -5.5 \cdot 10^{+58}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;t\_0\\
        
        \mathbf{else}:\\
        \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \leq -2 \cdot 10^{-310}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;\frac{-2 \cdot b}{a + a}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \leq 2.3 \cdot 10^{-69}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{a + a}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{c + c}{\sqrt{\frac{c}{a} \cdot -4} \cdot a}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \geq 0:\\
        \;\;\;\;t\_0\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 4 regimes
        2. if b < -5.4999999999999999e58

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Step-by-step derivation
            1. lift-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. mult-flipN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            8. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            9. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            10. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            11. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
            12. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            13. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          9. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
          10. Taylor expanded in b around -inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lower-/.f6467.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
          12. Applied rewrites67.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

          if -5.4999999999999999e58 < b < -1.999999999999994e-310

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\color{blue}{-2 \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot \color{blue}{b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. Applied rewrites69.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\color{blue}{-2 \cdot b}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. Step-by-step derivation
            1. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{\color{blue}{2 \cdot a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{\color{blue}{a + a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            3. lower-+.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{\color{blue}{a + a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            6. lower-+.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            7. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}}\\ \end{array} \]
            8. +-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}}\\ \end{array} \]
            9. lift-neg.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\color{blue}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(\mathsf{neg}\left(b\right)\right)}}\\ \end{array} \]
            10. sub-flip-reverseN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}\\ \end{array} \]
            11. lower--.f6469.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{c + c}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}}\\ \end{array} \]
          6. Applied rewrites69.9%

            \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-2 \cdot b}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\mathsf{fma}\left(-4 \cdot c, a, b \cdot b\right)} - b}\\ } \end{array}} \]

          if -1.999999999999994e-310 < b < 2.3000000000000001e-69

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. lower-*.f6456.1

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot \color{blue}{c}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. Applied rewrites56.1%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            2. lower-*.f6440.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          7. Applied rewrites40.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          8. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
          9. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \color{blue}{\frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{\color{blue}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            4. lower-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \color{blue}{\sqrt{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            5. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{\color{blue}{-4 \cdot \frac{c}{a}}}}\\ \end{array} \]
            6. lower-/.f6426.7

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \color{blue}{\frac{c}{a}}}}\\ \end{array} \]
          10. Applied rewrites26.7%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            2. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot \color{blue}{c}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            3. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(c \cdot \color{blue}{a}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            4. associate-*l*N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot \color{blue}{a}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            5. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            6. lower-*.f6426.7

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot \color{blue}{a}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            7. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(-4 \cdot c\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            8. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            9. lower-*.f6426.7

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            10. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{\mathsf{Rewrite=>}\left(lift-*.f64, \left(2 \cdot a\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            11. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{\mathsf{Rewrite=>}\left(count-2-rev, \left(a + a\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
            12. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{\mathsf{Rewrite<=}\left(lift-+.f64, \left(a + a\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;2 \cdot \frac{c}{a \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \end{array} \]
          12. Applied rewrites26.7%

            \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left(c \cdot -4\right) \cdot a}}{a + a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\frac{c}{a} \cdot -4} \cdot a}\\ } \end{array}} \]

          if 2.3000000000000001e-69 < b

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Taylor expanded in c around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          9. Step-by-step derivation
            1. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            2. lower-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            4. lower-/.f6442.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
          10. Applied rewrites42.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
        3. Recombined 4 regimes into one program.
        4. Add Preprocessing

        Alternative 7: 80.7% accurate, 0.9× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} t_0 := -1 \cdot \frac{b}{a}\\ t_1 := \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}\\ \mathbf{if}\;b \leq -0.00017:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq 2.35 \cdot 10^{-69}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - t\_1}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_1}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
        (FPCore (a b c)
         :precision binary64
         (let* ((t_0 (* -1.0 (/ b a))) (t_1 (sqrt (fabs (* (* -4.0 a) c)))))
           (if (<= b -0.00017)
             (if (>= b 0.0) t_0 (* (+ c c) (/ -0.5 b)))
             (if (<= b 2.35e-69)
               (if (>= b 0.0) (/ (- (- b) t_1) (* 2.0 a)) (/ (* 2.0 c) (+ (- b) t_1)))
               (if (>= b 0.0) t_0 (/ 2.0 (sqrt (* -4.0 (/ a c)))))))))
        double code(double a, double b, double c) {
        	double t_0 = -1.0 * (b / a);
        	double t_1 = sqrt(fabs(((-4.0 * a) * c)));
        	double tmp_1;
        	if (b <= -0.00017) {
        		double tmp_2;
        		if (b >= 0.0) {
        			tmp_2 = t_0;
        		} else {
        			tmp_2 = (c + c) * (-0.5 / b);
        		}
        		tmp_1 = tmp_2;
        	} else if (b <= 2.35e-69) {
        		double tmp_3;
        		if (b >= 0.0) {
        			tmp_3 = (-b - t_1) / (2.0 * a);
        		} else {
        			tmp_3 = (2.0 * c) / (-b + t_1);
        		}
        		tmp_1 = tmp_3;
        	} else if (b >= 0.0) {
        		tmp_1 = t_0;
        	} else {
        		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
        	}
        	return tmp_1;
        }
        
        module fmin_fmax_functions
            implicit none
            private
            public fmax
            public fmin
        
            interface fmax
                module procedure fmax88
                module procedure fmax44
                module procedure fmax84
                module procedure fmax48
            end interface
            interface fmin
                module procedure fmin88
                module procedure fmin44
                module procedure fmin84
                module procedure fmin48
            end interface
        contains
            real(8) function fmax88(x, y) result (res)
                real(8), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(x, max(x, y), y /= y), x /= x)
            end function
            real(4) function fmax44(x, y) result (res)
                real(4), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(y, merge(x, max(x, y), y /= y), x /= x)
            end function
            real(8) function fmax84(x, y) result(res)
                real(8), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
            end function
            real(8) function fmax48(x, y) result(res)
                real(4), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
            end function
            real(8) function fmin88(x, y) result (res)
                real(8), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(x, min(x, y), y /= y), x /= x)
            end function
            real(4) function fmin44(x, y) result (res)
                real(4), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(y, merge(x, min(x, y), y /= y), x /= x)
            end function
            real(8) function fmin84(x, y) result(res)
                real(8), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
            end function
            real(8) function fmin48(x, y) result(res)
                real(4), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
            end function
        end module
        
        real(8) function code(a, b, c)
        use fmin_fmax_functions
            real(8), intent (in) :: a
            real(8), intent (in) :: b
            real(8), intent (in) :: c
            real(8) :: t_0
            real(8) :: t_1
            real(8) :: tmp
            real(8) :: tmp_1
            real(8) :: tmp_2
            real(8) :: tmp_3
            t_0 = (-1.0d0) * (b / a)
            t_1 = sqrt(abs((((-4.0d0) * a) * c)))
            if (b <= (-0.00017d0)) then
                if (b >= 0.0d0) then
                    tmp_2 = t_0
                else
                    tmp_2 = (c + c) * ((-0.5d0) / b)
                end if
                tmp_1 = tmp_2
            else if (b <= 2.35d-69) then
                if (b >= 0.0d0) then
                    tmp_3 = (-b - t_1) / (2.0d0 * a)
                else
                    tmp_3 = (2.0d0 * c) / (-b + t_1)
                end if
                tmp_1 = tmp_3
            else if (b >= 0.0d0) then
                tmp_1 = t_0
            else
                tmp_1 = 2.0d0 / sqrt(((-4.0d0) * (a / c)))
            end if
            code = tmp_1
        end function
        
        public static double code(double a, double b, double c) {
        	double t_0 = -1.0 * (b / a);
        	double t_1 = Math.sqrt(Math.abs(((-4.0 * a) * c)));
        	double tmp_1;
        	if (b <= -0.00017) {
        		double tmp_2;
        		if (b >= 0.0) {
        			tmp_2 = t_0;
        		} else {
        			tmp_2 = (c + c) * (-0.5 / b);
        		}
        		tmp_1 = tmp_2;
        	} else if (b <= 2.35e-69) {
        		double tmp_3;
        		if (b >= 0.0) {
        			tmp_3 = (-b - t_1) / (2.0 * a);
        		} else {
        			tmp_3 = (2.0 * c) / (-b + t_1);
        		}
        		tmp_1 = tmp_3;
        	} else if (b >= 0.0) {
        		tmp_1 = t_0;
        	} else {
        		tmp_1 = 2.0 / Math.sqrt((-4.0 * (a / c)));
        	}
        	return tmp_1;
        }
        
        def code(a, b, c):
        	t_0 = -1.0 * (b / a)
        	t_1 = math.sqrt(math.fabs(((-4.0 * a) * c)))
        	tmp_1 = 0
        	if b <= -0.00017:
        		tmp_2 = 0
        		if b >= 0.0:
        			tmp_2 = t_0
        		else:
        			tmp_2 = (c + c) * (-0.5 / b)
        		tmp_1 = tmp_2
        	elif b <= 2.35e-69:
        		tmp_3 = 0
        		if b >= 0.0:
        			tmp_3 = (-b - t_1) / (2.0 * a)
        		else:
        			tmp_3 = (2.0 * c) / (-b + t_1)
        		tmp_1 = tmp_3
        	elif b >= 0.0:
        		tmp_1 = t_0
        	else:
        		tmp_1 = 2.0 / math.sqrt((-4.0 * (a / c)))
        	return tmp_1
        
        function code(a, b, c)
        	t_0 = Float64(-1.0 * Float64(b / a))
        	t_1 = sqrt(abs(Float64(Float64(-4.0 * a) * c)))
        	tmp_1 = 0.0
        	if (b <= -0.00017)
        		tmp_2 = 0.0
        		if (b >= 0.0)
        			tmp_2 = t_0;
        		else
        			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
        		end
        		tmp_1 = tmp_2;
        	elseif (b <= 2.35e-69)
        		tmp_3 = 0.0
        		if (b >= 0.0)
        			tmp_3 = Float64(Float64(Float64(-b) - t_1) / Float64(2.0 * a));
        		else
        			tmp_3 = Float64(Float64(2.0 * c) / Float64(Float64(-b) + t_1));
        		end
        		tmp_1 = tmp_3;
        	elseif (b >= 0.0)
        		tmp_1 = t_0;
        	else
        		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
        	end
        	return tmp_1
        end
        
        function tmp_5 = code(a, b, c)
        	t_0 = -1.0 * (b / a);
        	t_1 = sqrt(abs(((-4.0 * a) * c)));
        	tmp_2 = 0.0;
        	if (b <= -0.00017)
        		tmp_3 = 0.0;
        		if (b >= 0.0)
        			tmp_3 = t_0;
        		else
        			tmp_3 = (c + c) * (-0.5 / b);
        		end
        		tmp_2 = tmp_3;
        	elseif (b <= 2.35e-69)
        		tmp_4 = 0.0;
        		if (b >= 0.0)
        			tmp_4 = (-b - t_1) / (2.0 * a);
        		else
        			tmp_4 = (2.0 * c) / (-b + t_1);
        		end
        		tmp_2 = tmp_4;
        	elseif (b >= 0.0)
        		tmp_2 = t_0;
        	else
        		tmp_2 = 2.0 / sqrt((-4.0 * (a / c)));
        	end
        	tmp_5 = tmp_2;
        end
        
        code[a_, b_, c_] := Block[{t$95$0 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Sqrt[N[Abs[N[(N[(-4.0 * a), $MachinePrecision] * c), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]}, If[LessEqual[b, -0.00017], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 2.35e-69], If[GreaterEqual[b, 0.0], N[(N[((-b) - t$95$1), $MachinePrecision] / N[(2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * c), $MachinePrecision] / N[((-b) + t$95$1), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$0, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        t_0 := -1 \cdot \frac{b}{a}\\
        t_1 := \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}\\
        \mathbf{if}\;b \leq -0.00017:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;t\_0\\
        
        \mathbf{else}:\\
        \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \leq 2.35 \cdot 10^{-69}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;\frac{\left(-b\right) - t\_1}{2 \cdot a}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + t\_1}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \geq 0:\\
        \;\;\;\;t\_0\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 3 regimes
        2. if b < -1.7e-4

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Step-by-step derivation
            1. lift-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. mult-flipN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            8. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            9. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            10. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            11. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
            12. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            13. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          9. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
          10. Taylor expanded in b around -inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lower-/.f6467.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
          12. Applied rewrites67.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

          if -1.7e-4 < b < 2.34999999999999984e-69

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. lower-*.f6456.1

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot \color{blue}{c}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. Applied rewrites56.1%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            2. lower-*.f6440.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          7. Applied rewrites40.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          8. Step-by-step derivation
            1. rem-square-sqrtN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            2. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\sqrt{-4 \cdot \left(a \cdot c\right)}} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            3. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \color{blue}{\sqrt{-4 \cdot \left(a \cdot c\right)}}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            4. sqr-abs-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left|\sqrt{-4 \cdot \left(a \cdot c\right)}\right| \cdot \left|\sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            5. mul-fabsN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left|\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            6. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\color{blue}{\sqrt{-4 \cdot \left(a \cdot c\right)}} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            7. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \color{blue}{\sqrt{-4 \cdot \left(a \cdot c\right)}}\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            8. rem-square-sqrtN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\color{blue}{-4 \cdot \left(a \cdot c\right)}\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            9. lower-fabs.f6445.1

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left|-4 \cdot \left(a \cdot c\right)\right|}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          9. Applied rewrites45.1%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{\left|\left(-4 \cdot a\right) \cdot c\right|}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          10. Step-by-step derivation
            1. rem-square-sqrtN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}}}\\ \end{array} \]
            2. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}}}\\ \end{array} \]
            3. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}}}\\ \end{array} \]
            4. sqr-abs-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left|\sqrt{-4 \cdot \left(a \cdot c\right)}\right| \cdot \left|\sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}\\ \end{array} \]
            5. mul-fabsN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left|\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}\\ \end{array} \]
            6. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\left|\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}\\ \end{array} \]
            7. lift-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{\left|\sqrt{-4 \cdot \left(a \cdot c\right)} \cdot \sqrt{-4 \cdot \left(a \cdot c\right)}\right|}}\\ \end{array} \]
            8. rem-square-sqrtN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-\color{blue}{b}\right) + \sqrt{\left|-4 \cdot \left(a \cdot c\right)\right|}}\\ \end{array} \]
            9. lower-fabs.f6449.8

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left|-4 \cdot \left(a \cdot c\right)\right|}}\\ \end{array} \]
          11. Applied rewrites49.7%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{\left|\left(-4 \cdot a\right) \cdot c\right|}}\\ \end{array} \]

          if 2.34999999999999984e-69 < b

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Taylor expanded in c around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          9. Step-by-step derivation
            1. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            2. lower-sqrt.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
            4. lower-/.f6442.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
          10. Applied rewrites42.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
        3. Recombined 3 regimes into one program.
        4. Add Preprocessing

        Alternative 8: 80.4% accurate, 1.0× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\left(-4 \cdot a\right) \cdot c}\\ t_1 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -0.00017:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq 2.3 \cdot 10^{-69}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{t\_0 + b}{-2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{t\_0 - b}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
        (FPCore (a b c)
         :precision binary64
         (let* ((t_0 (sqrt (* (* -4.0 a) c))) (t_1 (* -1.0 (/ b a))))
           (if (<= b -0.00017)
             (if (>= b 0.0) t_1 (* (+ c c) (/ -0.5 b)))
             (if (<= b 2.3e-69)
               (if (>= b 0.0) (/ (+ t_0 b) (* -2.0 a)) (/ (+ c c) (- t_0 b)))
               (if (>= b 0.0) t_1 (/ 2.0 (sqrt (* -4.0 (/ a c)))))))))
        double code(double a, double b, double c) {
        	double t_0 = sqrt(((-4.0 * a) * c));
        	double t_1 = -1.0 * (b / a);
        	double tmp_1;
        	if (b <= -0.00017) {
        		double tmp_2;
        		if (b >= 0.0) {
        			tmp_2 = t_1;
        		} else {
        			tmp_2 = (c + c) * (-0.5 / b);
        		}
        		tmp_1 = tmp_2;
        	} else if (b <= 2.3e-69) {
        		double tmp_3;
        		if (b >= 0.0) {
        			tmp_3 = (t_0 + b) / (-2.0 * a);
        		} else {
        			tmp_3 = (c + c) / (t_0 - b);
        		}
        		tmp_1 = tmp_3;
        	} else if (b >= 0.0) {
        		tmp_1 = t_1;
        	} else {
        		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
        	}
        	return tmp_1;
        }
        
        module fmin_fmax_functions
            implicit none
            private
            public fmax
            public fmin
        
            interface fmax
                module procedure fmax88
                module procedure fmax44
                module procedure fmax84
                module procedure fmax48
            end interface
            interface fmin
                module procedure fmin88
                module procedure fmin44
                module procedure fmin84
                module procedure fmin48
            end interface
        contains
            real(8) function fmax88(x, y) result (res)
                real(8), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(x, max(x, y), y /= y), x /= x)
            end function
            real(4) function fmax44(x, y) result (res)
                real(4), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(y, merge(x, max(x, y), y /= y), x /= x)
            end function
            real(8) function fmax84(x, y) result(res)
                real(8), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
            end function
            real(8) function fmax48(x, y) result(res)
                real(4), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
            end function
            real(8) function fmin88(x, y) result (res)
                real(8), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(x, min(x, y), y /= y), x /= x)
            end function
            real(4) function fmin44(x, y) result (res)
                real(4), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(y, merge(x, min(x, y), y /= y), x /= x)
            end function
            real(8) function fmin84(x, y) result(res)
                real(8), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
            end function
            real(8) function fmin48(x, y) result(res)
                real(4), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
            end function
        end module
        
        real(8) function code(a, b, c)
        use fmin_fmax_functions
            real(8), intent (in) :: a
            real(8), intent (in) :: b
            real(8), intent (in) :: c
            real(8) :: t_0
            real(8) :: t_1
            real(8) :: tmp
            real(8) :: tmp_1
            real(8) :: tmp_2
            real(8) :: tmp_3
            t_0 = sqrt((((-4.0d0) * a) * c))
            t_1 = (-1.0d0) * (b / a)
            if (b <= (-0.00017d0)) then
                if (b >= 0.0d0) then
                    tmp_2 = t_1
                else
                    tmp_2 = (c + c) * ((-0.5d0) / b)
                end if
                tmp_1 = tmp_2
            else if (b <= 2.3d-69) then
                if (b >= 0.0d0) then
                    tmp_3 = (t_0 + b) / ((-2.0d0) * a)
                else
                    tmp_3 = (c + c) / (t_0 - b)
                end if
                tmp_1 = tmp_3
            else if (b >= 0.0d0) then
                tmp_1 = t_1
            else
                tmp_1 = 2.0d0 / sqrt(((-4.0d0) * (a / c)))
            end if
            code = tmp_1
        end function
        
        public static double code(double a, double b, double c) {
        	double t_0 = Math.sqrt(((-4.0 * a) * c));
        	double t_1 = -1.0 * (b / a);
        	double tmp_1;
        	if (b <= -0.00017) {
        		double tmp_2;
        		if (b >= 0.0) {
        			tmp_2 = t_1;
        		} else {
        			tmp_2 = (c + c) * (-0.5 / b);
        		}
        		tmp_1 = tmp_2;
        	} else if (b <= 2.3e-69) {
        		double tmp_3;
        		if (b >= 0.0) {
        			tmp_3 = (t_0 + b) / (-2.0 * a);
        		} else {
        			tmp_3 = (c + c) / (t_0 - b);
        		}
        		tmp_1 = tmp_3;
        	} else if (b >= 0.0) {
        		tmp_1 = t_1;
        	} else {
        		tmp_1 = 2.0 / Math.sqrt((-4.0 * (a / c)));
        	}
        	return tmp_1;
        }
        
        def code(a, b, c):
        	t_0 = math.sqrt(((-4.0 * a) * c))
        	t_1 = -1.0 * (b / a)
        	tmp_1 = 0
        	if b <= -0.00017:
        		tmp_2 = 0
        		if b >= 0.0:
        			tmp_2 = t_1
        		else:
        			tmp_2 = (c + c) * (-0.5 / b)
        		tmp_1 = tmp_2
        	elif b <= 2.3e-69:
        		tmp_3 = 0
        		if b >= 0.0:
        			tmp_3 = (t_0 + b) / (-2.0 * a)
        		else:
        			tmp_3 = (c + c) / (t_0 - b)
        		tmp_1 = tmp_3
        	elif b >= 0.0:
        		tmp_1 = t_1
        	else:
        		tmp_1 = 2.0 / math.sqrt((-4.0 * (a / c)))
        	return tmp_1
        
        function code(a, b, c)
        	t_0 = sqrt(Float64(Float64(-4.0 * a) * c))
        	t_1 = Float64(-1.0 * Float64(b / a))
        	tmp_1 = 0.0
        	if (b <= -0.00017)
        		tmp_2 = 0.0
        		if (b >= 0.0)
        			tmp_2 = t_1;
        		else
        			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
        		end
        		tmp_1 = tmp_2;
        	elseif (b <= 2.3e-69)
        		tmp_3 = 0.0
        		if (b >= 0.0)
        			tmp_3 = Float64(Float64(t_0 + b) / Float64(-2.0 * a));
        		else
        			tmp_3 = Float64(Float64(c + c) / Float64(t_0 - b));
        		end
        		tmp_1 = tmp_3;
        	elseif (b >= 0.0)
        		tmp_1 = t_1;
        	else
        		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
        	end
        	return tmp_1
        end
        
        function tmp_5 = code(a, b, c)
        	t_0 = sqrt(((-4.0 * a) * c));
        	t_1 = -1.0 * (b / a);
        	tmp_2 = 0.0;
        	if (b <= -0.00017)
        		tmp_3 = 0.0;
        		if (b >= 0.0)
        			tmp_3 = t_1;
        		else
        			tmp_3 = (c + c) * (-0.5 / b);
        		end
        		tmp_2 = tmp_3;
        	elseif (b <= 2.3e-69)
        		tmp_4 = 0.0;
        		if (b >= 0.0)
        			tmp_4 = (t_0 + b) / (-2.0 * a);
        		else
        			tmp_4 = (c + c) / (t_0 - b);
        		end
        		tmp_2 = tmp_4;
        	elseif (b >= 0.0)
        		tmp_2 = t_1;
        	else
        		tmp_2 = 2.0 / sqrt((-4.0 * (a / c)));
        	end
        	tmp_5 = tmp_2;
        end
        
        code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(N[(-4.0 * a), $MachinePrecision] * c), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -0.00017], If[GreaterEqual[b, 0.0], t$95$1, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 2.3e-69], If[GreaterEqual[b, 0.0], N[(N[(t$95$0 + b), $MachinePrecision] / N[(-2.0 * a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] / N[(t$95$0 - b), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$1, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        t_0 := \sqrt{\left(-4 \cdot a\right) \cdot c}\\
        t_1 := -1 \cdot \frac{b}{a}\\
        \mathbf{if}\;b \leq -0.00017:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;t\_1\\
        
        \mathbf{else}:\\
        \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \leq 2.3 \cdot 10^{-69}:\\
        \;\;\;\;\begin{array}{l}
        \mathbf{if}\;b \geq 0:\\
        \;\;\;\;\frac{t\_0 + b}{-2 \cdot a}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{c + c}{t\_0 - b}\\
        
        
        \end{array}\\
        
        \mathbf{elif}\;b \geq 0:\\
        \;\;\;\;t\_1\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 3 regimes
        2. if b < -1.7e-4

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Step-by-step derivation
            1. lift-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. mult-flipN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            8. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            9. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            10. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            11. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
            12. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            13. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          9. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
          10. Taylor expanded in b around -inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lower-/.f6467.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
          12. Applied rewrites67.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

          if -1.7e-4 < b < 2.3000000000000001e-69

          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \color{blue}{\left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. lower-*.f6456.1

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot \color{blue}{c}\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          4. Applied rewrites56.1%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{\color{blue}{-4 \cdot \left(a \cdot c\right)}}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          5. Taylor expanded in a around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
            2. lower-*.f6440.3

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          7. Applied rewrites40.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{-4 \cdot \left(a \cdot c\right)}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{\left(-b\right)} + \sqrt{-4 \cdot \left(a \cdot c\right)}}\\ \end{array} \]
          8. Step-by-step derivation
            1. Applied rewrites40.3%

              \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\sqrt{\left(-4 \cdot a\right) \cdot c} + b}{-2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{c + c}{\sqrt{\left(-4 \cdot a\right) \cdot c} - b}\\ } \end{array}} \]

            if 2.3000000000000001e-69 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6442.3

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites42.3%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          9. Recombined 3 regimes into one program.
          10. Add Preprocessing

          Alternative 9: 80.1% accurate, 0.9× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{-4 \cdot \frac{a}{c}}\\ t_1 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -3 \cdot 10^{-39}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq -4 \cdot 10^{-306}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array}\\ \mathbf{elif}\;b \leq 7.6 \cdot 10^{-70}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-0.5 \cdot \frac{\sqrt{-4 \cdot \left(a \cdot c\right)}}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{t\_0}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{t\_0}\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (let* ((t_0 (sqrt (* -4.0 (/ a c)))) (t_1 (* -1.0 (/ b a))))
             (if (<= b -3e-39)
               (if (>= b 0.0) t_1 (* (+ c c) (/ -0.5 b)))
               (if (<= b -4e-306)
                 (if (>= b 0.0) t_1 (/ -2.0 (* a (sqrt (/ -4.0 (* a c))))))
                 (if (<= b 7.6e-70)
                   (if (>= b 0.0) (* -0.5 (/ (sqrt (- (* 4.0 (* a c)))) a)) (/ -2.0 t_0))
                   (if (>= b 0.0) t_1 (/ 2.0 t_0)))))))
          double code(double a, double b, double c) {
          	double t_0 = sqrt((-4.0 * (a / c)));
          	double t_1 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -3e-39) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_1;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b <= -4e-306) {
          		double tmp_3;
          		if (b >= 0.0) {
          			tmp_3 = t_1;
          		} else {
          			tmp_3 = -2.0 / (a * sqrt((-4.0 / (a * c))));
          		}
          		tmp_1 = tmp_3;
          	} else if (b <= 7.6e-70) {
          		double tmp_4;
          		if (b >= 0.0) {
          			tmp_4 = -0.5 * (sqrt(-(4.0 * (a * c))) / a);
          		} else {
          			tmp_4 = -2.0 / t_0;
          		}
          		tmp_1 = tmp_4;
          	} else if (b >= 0.0) {
          		tmp_1 = t_1;
          	} else {
          		tmp_1 = 2.0 / t_0;
          	}
          	return tmp_1;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: t_0
              real(8) :: t_1
              real(8) :: tmp
              real(8) :: tmp_1
              real(8) :: tmp_2
              real(8) :: tmp_3
              real(8) :: tmp_4
              t_0 = sqrt(((-4.0d0) * (a / c)))
              t_1 = (-1.0d0) * (b / a)
              if (b <= (-3d-39)) then
                  if (b >= 0.0d0) then
                      tmp_2 = t_1
                  else
                      tmp_2 = (c + c) * ((-0.5d0) / b)
                  end if
                  tmp_1 = tmp_2
              else if (b <= (-4d-306)) then
                  if (b >= 0.0d0) then
                      tmp_3 = t_1
                  else
                      tmp_3 = (-2.0d0) / (a * sqrt(((-4.0d0) / (a * c))))
                  end if
                  tmp_1 = tmp_3
              else if (b <= 7.6d-70) then
                  if (b >= 0.0d0) then
                      tmp_4 = (-0.5d0) * (sqrt(-(4.0d0 * (a * c))) / a)
                  else
                      tmp_4 = (-2.0d0) / t_0
                  end if
                  tmp_1 = tmp_4
              else if (b >= 0.0d0) then
                  tmp_1 = t_1
              else
                  tmp_1 = 2.0d0 / t_0
              end if
              code = tmp_1
          end function
          
          public static double code(double a, double b, double c) {
          	double t_0 = Math.sqrt((-4.0 * (a / c)));
          	double t_1 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -3e-39) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_1;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b <= -4e-306) {
          		double tmp_3;
          		if (b >= 0.0) {
          			tmp_3 = t_1;
          		} else {
          			tmp_3 = -2.0 / (a * Math.sqrt((-4.0 / (a * c))));
          		}
          		tmp_1 = tmp_3;
          	} else if (b <= 7.6e-70) {
          		double tmp_4;
          		if (b >= 0.0) {
          			tmp_4 = -0.5 * (Math.sqrt(-(4.0 * (a * c))) / a);
          		} else {
          			tmp_4 = -2.0 / t_0;
          		}
          		tmp_1 = tmp_4;
          	} else if (b >= 0.0) {
          		tmp_1 = t_1;
          	} else {
          		tmp_1 = 2.0 / t_0;
          	}
          	return tmp_1;
          }
          
          def code(a, b, c):
          	t_0 = math.sqrt((-4.0 * (a / c)))
          	t_1 = -1.0 * (b / a)
          	tmp_1 = 0
          	if b <= -3e-39:
          		tmp_2 = 0
          		if b >= 0.0:
          			tmp_2 = t_1
          		else:
          			tmp_2 = (c + c) * (-0.5 / b)
          		tmp_1 = tmp_2
          	elif b <= -4e-306:
          		tmp_3 = 0
          		if b >= 0.0:
          			tmp_3 = t_1
          		else:
          			tmp_3 = -2.0 / (a * math.sqrt((-4.0 / (a * c))))
          		tmp_1 = tmp_3
          	elif b <= 7.6e-70:
          		tmp_4 = 0
          		if b >= 0.0:
          			tmp_4 = -0.5 * (math.sqrt(-(4.0 * (a * c))) / a)
          		else:
          			tmp_4 = -2.0 / t_0
          		tmp_1 = tmp_4
          	elif b >= 0.0:
          		tmp_1 = t_1
          	else:
          		tmp_1 = 2.0 / t_0
          	return tmp_1
          
          function code(a, b, c)
          	t_0 = sqrt(Float64(-4.0 * Float64(a / c)))
          	t_1 = Float64(-1.0 * Float64(b / a))
          	tmp_1 = 0.0
          	if (b <= -3e-39)
          		tmp_2 = 0.0
          		if (b >= 0.0)
          			tmp_2 = t_1;
          		else
          			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
          		end
          		tmp_1 = tmp_2;
          	elseif (b <= -4e-306)
          		tmp_3 = 0.0
          		if (b >= 0.0)
          			tmp_3 = t_1;
          		else
          			tmp_3 = Float64(-2.0 / Float64(a * sqrt(Float64(-4.0 / Float64(a * c)))));
          		end
          		tmp_1 = tmp_3;
          	elseif (b <= 7.6e-70)
          		tmp_4 = 0.0
          		if (b >= 0.0)
          			tmp_4 = Float64(-0.5 * Float64(sqrt(Float64(-Float64(4.0 * Float64(a * c)))) / a));
          		else
          			tmp_4 = Float64(-2.0 / t_0);
          		end
          		tmp_1 = tmp_4;
          	elseif (b >= 0.0)
          		tmp_1 = t_1;
          	else
          		tmp_1 = Float64(2.0 / t_0);
          	end
          	return tmp_1
          end
          
          function tmp_6 = code(a, b, c)
          	t_0 = sqrt((-4.0 * (a / c)));
          	t_1 = -1.0 * (b / a);
          	tmp_2 = 0.0;
          	if (b <= -3e-39)
          		tmp_3 = 0.0;
          		if (b >= 0.0)
          			tmp_3 = t_1;
          		else
          			tmp_3 = (c + c) * (-0.5 / b);
          		end
          		tmp_2 = tmp_3;
          	elseif (b <= -4e-306)
          		tmp_4 = 0.0;
          		if (b >= 0.0)
          			tmp_4 = t_1;
          		else
          			tmp_4 = -2.0 / (a * sqrt((-4.0 / (a * c))));
          		end
          		tmp_2 = tmp_4;
          	elseif (b <= 7.6e-70)
          		tmp_5 = 0.0;
          		if (b >= 0.0)
          			tmp_5 = -0.5 * (sqrt(-(4.0 * (a * c))) / a);
          		else
          			tmp_5 = -2.0 / t_0;
          		end
          		tmp_2 = tmp_5;
          	elseif (b >= 0.0)
          		tmp_2 = t_1;
          	else
          		tmp_2 = 2.0 / t_0;
          	end
          	tmp_6 = tmp_2;
          end
          
          code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -3e-39], If[GreaterEqual[b, 0.0], t$95$1, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, -4e-306], If[GreaterEqual[b, 0.0], t$95$1, N[(-2.0 / N[(a * N[Sqrt[N[(-4.0 / N[(a * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 7.6e-70], If[GreaterEqual[b, 0.0], N[(-0.5 * N[(N[Sqrt[(-N[(4.0 * N[(a * c), $MachinePrecision]), $MachinePrecision])], $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision], N[(-2.0 / t$95$0), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$1, N[(2.0 / t$95$0), $MachinePrecision]]]]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          t_0 := \sqrt{-4 \cdot \frac{a}{c}}\\
          t_1 := -1 \cdot \frac{b}{a}\\
          \mathbf{if}\;b \leq -3 \cdot 10^{-39}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \leq -4 \cdot 10^{-306}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \leq 7.6 \cdot 10^{-70}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;-0.5 \cdot \frac{\sqrt{-4 \cdot \left(a \cdot c\right)}}{a}\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{t\_0}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{2}{t\_0}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 4 regimes
          2. if b < -3.00000000000000028e-39

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              4. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              5. count-2-revN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              6. lift-+.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              7. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              8. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              9. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              10. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              11. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
              12. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
              13. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            9. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
            10. Taylor expanded in b around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lower-/.f6467.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
            12. Applied rewrites67.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

            if -3.00000000000000028e-39 < b < -4.00000000000000011e-306

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            11. Taylor expanded in a around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}}\\ \end{array} \]
            12. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \color{blue}{\sqrt{\frac{-4}{a \cdot c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array} \]
              3. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array} \]
              4. lower-*.f6448.1

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array} \]
            13. Applied rewrites48.1%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}}\\ \end{array} \]

            if -4.00000000000000011e-306 < b < 7.5999999999999995e-70

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            11. Taylor expanded in b around 0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{\frac{-1}{2} \cdot \frac{\sqrt{\mathsf{neg}\left(4 \cdot \left(a \cdot c\right)\right)}}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            12. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \color{blue}{\frac{\sqrt{\mathsf{neg}\left(4 \cdot \left(a \cdot c\right)\right)}}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \frac{\sqrt{\mathsf{neg}\left(4 \cdot \left(a \cdot c\right)\right)}}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              3. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \frac{\sqrt{\mathsf{neg}\left(4 \cdot \left(a \cdot c\right)\right)}}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              4. lower-neg.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \frac{\sqrt{-4 \cdot \left(a \cdot c\right)}}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              5. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \frac{\sqrt{-4 \cdot \left(a \cdot c\right)}}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              6. lower-*.f6420.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-0.5 \cdot \frac{\sqrt{-4 \cdot \left(a \cdot c\right)}}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            13. Applied rewrites20.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-0.5 \cdot \frac{\sqrt{-4 \cdot \left(a \cdot c\right)}}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]

            if 7.5999999999999995e-70 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6442.3

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites42.3%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          3. Recombined 4 regimes into one program.
          4. Add Preprocessing

          Alternative 10: 76.0% accurate, 1.0× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{-4 \cdot \frac{a}{c}}\\ t_1 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -3 \cdot 10^{-39}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq -4 \cdot 10^{-306}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array}\\ \mathbf{elif}\;b \leq 3.4 \cdot 10^{-178}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{t\_0}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{t\_0}\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (let* ((t_0 (sqrt (* -4.0 (/ a c)))) (t_1 (* -1.0 (/ b a))))
             (if (<= b -3e-39)
               (if (>= b 0.0) t_1 (* (+ c c) (/ -0.5 b)))
               (if (<= b -4e-306)
                 (if (>= b 0.0) t_1 (/ -2.0 (* a (sqrt (/ -4.0 (* a c))))))
                 (if (<= b 3.4e-178)
                   (if (>= b 0.0) (* -0.5 (sqrt (* -4.0 (/ c a)))) (/ -2.0 t_0))
                   (if (>= b 0.0) t_1 (/ 2.0 t_0)))))))
          double code(double a, double b, double c) {
          	double t_0 = sqrt((-4.0 * (a / c)));
          	double t_1 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -3e-39) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_1;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b <= -4e-306) {
          		double tmp_3;
          		if (b >= 0.0) {
          			tmp_3 = t_1;
          		} else {
          			tmp_3 = -2.0 / (a * sqrt((-4.0 / (a * c))));
          		}
          		tmp_1 = tmp_3;
          	} else if (b <= 3.4e-178) {
          		double tmp_4;
          		if (b >= 0.0) {
          			tmp_4 = -0.5 * sqrt((-4.0 * (c / a)));
          		} else {
          			tmp_4 = -2.0 / t_0;
          		}
          		tmp_1 = tmp_4;
          	} else if (b >= 0.0) {
          		tmp_1 = t_1;
          	} else {
          		tmp_1 = 2.0 / t_0;
          	}
          	return tmp_1;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: t_0
              real(8) :: t_1
              real(8) :: tmp
              real(8) :: tmp_1
              real(8) :: tmp_2
              real(8) :: tmp_3
              real(8) :: tmp_4
              t_0 = sqrt(((-4.0d0) * (a / c)))
              t_1 = (-1.0d0) * (b / a)
              if (b <= (-3d-39)) then
                  if (b >= 0.0d0) then
                      tmp_2 = t_1
                  else
                      tmp_2 = (c + c) * ((-0.5d0) / b)
                  end if
                  tmp_1 = tmp_2
              else if (b <= (-4d-306)) then
                  if (b >= 0.0d0) then
                      tmp_3 = t_1
                  else
                      tmp_3 = (-2.0d0) / (a * sqrt(((-4.0d0) / (a * c))))
                  end if
                  tmp_1 = tmp_3
              else if (b <= 3.4d-178) then
                  if (b >= 0.0d0) then
                      tmp_4 = (-0.5d0) * sqrt(((-4.0d0) * (c / a)))
                  else
                      tmp_4 = (-2.0d0) / t_0
                  end if
                  tmp_1 = tmp_4
              else if (b >= 0.0d0) then
                  tmp_1 = t_1
              else
                  tmp_1 = 2.0d0 / t_0
              end if
              code = tmp_1
          end function
          
          public static double code(double a, double b, double c) {
          	double t_0 = Math.sqrt((-4.0 * (a / c)));
          	double t_1 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -3e-39) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_1;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b <= -4e-306) {
          		double tmp_3;
          		if (b >= 0.0) {
          			tmp_3 = t_1;
          		} else {
          			tmp_3 = -2.0 / (a * Math.sqrt((-4.0 / (a * c))));
          		}
          		tmp_1 = tmp_3;
          	} else if (b <= 3.4e-178) {
          		double tmp_4;
          		if (b >= 0.0) {
          			tmp_4 = -0.5 * Math.sqrt((-4.0 * (c / a)));
          		} else {
          			tmp_4 = -2.0 / t_0;
          		}
          		tmp_1 = tmp_4;
          	} else if (b >= 0.0) {
          		tmp_1 = t_1;
          	} else {
          		tmp_1 = 2.0 / t_0;
          	}
          	return tmp_1;
          }
          
          def code(a, b, c):
          	t_0 = math.sqrt((-4.0 * (a / c)))
          	t_1 = -1.0 * (b / a)
          	tmp_1 = 0
          	if b <= -3e-39:
          		tmp_2 = 0
          		if b >= 0.0:
          			tmp_2 = t_1
          		else:
          			tmp_2 = (c + c) * (-0.5 / b)
          		tmp_1 = tmp_2
          	elif b <= -4e-306:
          		tmp_3 = 0
          		if b >= 0.0:
          			tmp_3 = t_1
          		else:
          			tmp_3 = -2.0 / (a * math.sqrt((-4.0 / (a * c))))
          		tmp_1 = tmp_3
          	elif b <= 3.4e-178:
          		tmp_4 = 0
          		if b >= 0.0:
          			tmp_4 = -0.5 * math.sqrt((-4.0 * (c / a)))
          		else:
          			tmp_4 = -2.0 / t_0
          		tmp_1 = tmp_4
          	elif b >= 0.0:
          		tmp_1 = t_1
          	else:
          		tmp_1 = 2.0 / t_0
          	return tmp_1
          
          function code(a, b, c)
          	t_0 = sqrt(Float64(-4.0 * Float64(a / c)))
          	t_1 = Float64(-1.0 * Float64(b / a))
          	tmp_1 = 0.0
          	if (b <= -3e-39)
          		tmp_2 = 0.0
          		if (b >= 0.0)
          			tmp_2 = t_1;
          		else
          			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
          		end
          		tmp_1 = tmp_2;
          	elseif (b <= -4e-306)
          		tmp_3 = 0.0
          		if (b >= 0.0)
          			tmp_3 = t_1;
          		else
          			tmp_3 = Float64(-2.0 / Float64(a * sqrt(Float64(-4.0 / Float64(a * c)))));
          		end
          		tmp_1 = tmp_3;
          	elseif (b <= 3.4e-178)
          		tmp_4 = 0.0
          		if (b >= 0.0)
          			tmp_4 = Float64(-0.5 * sqrt(Float64(-4.0 * Float64(c / a))));
          		else
          			tmp_4 = Float64(-2.0 / t_0);
          		end
          		tmp_1 = tmp_4;
          	elseif (b >= 0.0)
          		tmp_1 = t_1;
          	else
          		tmp_1 = Float64(2.0 / t_0);
          	end
          	return tmp_1
          end
          
          function tmp_6 = code(a, b, c)
          	t_0 = sqrt((-4.0 * (a / c)));
          	t_1 = -1.0 * (b / a);
          	tmp_2 = 0.0;
          	if (b <= -3e-39)
          		tmp_3 = 0.0;
          		if (b >= 0.0)
          			tmp_3 = t_1;
          		else
          			tmp_3 = (c + c) * (-0.5 / b);
          		end
          		tmp_2 = tmp_3;
          	elseif (b <= -4e-306)
          		tmp_4 = 0.0;
          		if (b >= 0.0)
          			tmp_4 = t_1;
          		else
          			tmp_4 = -2.0 / (a * sqrt((-4.0 / (a * c))));
          		end
          		tmp_2 = tmp_4;
          	elseif (b <= 3.4e-178)
          		tmp_5 = 0.0;
          		if (b >= 0.0)
          			tmp_5 = -0.5 * sqrt((-4.0 * (c / a)));
          		else
          			tmp_5 = -2.0 / t_0;
          		end
          		tmp_2 = tmp_5;
          	elseif (b >= 0.0)
          		tmp_2 = t_1;
          	else
          		tmp_2 = 2.0 / t_0;
          	end
          	tmp_6 = tmp_2;
          end
          
          code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -3e-39], If[GreaterEqual[b, 0.0], t$95$1, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, -4e-306], If[GreaterEqual[b, 0.0], t$95$1, N[(-2.0 / N[(a * N[Sqrt[N[(-4.0 / N[(a * c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, 3.4e-178], If[GreaterEqual[b, 0.0], N[(-0.5 * N[Sqrt[N[(-4.0 * N[(c / a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(-2.0 / t$95$0), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$1, N[(2.0 / t$95$0), $MachinePrecision]]]]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          t_0 := \sqrt{-4 \cdot \frac{a}{c}}\\
          t_1 := -1 \cdot \frac{b}{a}\\
          \mathbf{if}\;b \leq -3 \cdot 10^{-39}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \leq -4 \cdot 10^{-306}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \leq 3.4 \cdot 10^{-178}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{t\_0}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{2}{t\_0}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 4 regimes
          2. if b < -3.00000000000000028e-39

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              4. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              5. count-2-revN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              6. lift-+.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              7. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              8. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              9. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              10. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              11. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
              12. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
              13. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            9. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
            10. Taylor expanded in b around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lower-/.f6467.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
            12. Applied rewrites67.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

            if -3.00000000000000028e-39 < b < -4.00000000000000011e-306

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            11. Taylor expanded in a around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}}\\ \end{array} \]
            12. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \color{blue}{\sqrt{\frac{-4}{a \cdot c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array} \]
              3. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array} \]
              4. lower-*.f6448.1

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}\\ \end{array} \]
            13. Applied rewrites48.1%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{a \cdot \sqrt{\frac{-4}{a \cdot c}}}}\\ \end{array} \]

            if -4.00000000000000011e-306 < b < 3.39999999999999973e-178

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            11. Taylor expanded in a around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{\frac{-1}{2} \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            12. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \color{blue}{\sqrt{-4 \cdot \frac{c}{a}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              4. lower-/.f6415.7

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            13. Applied rewrites15.7%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]

            if 3.39999999999999973e-178 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6442.3

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites42.3%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          3. Recombined 4 regimes into one program.
          4. Add Preprocessing

          Alternative 11: 71.3% accurate, 1.0× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{-4 \cdot \frac{a}{c}}\\ t_1 := -1 \cdot \frac{b}{a}\\ t_2 := \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{t\_0}\\ \end{array}\\ \mathbf{if}\;b \leq -3.7 \cdot 10^{-61}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_1\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \leq -1.7 \cdot 10^{-305}:\\ \;\;\;\;t\_2\\ \mathbf{elif}\;b \leq 3.4 \cdot 10^{-178}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{t\_0}\\ \end{array}\\ \mathbf{else}:\\ \;\;\;\;t\_2\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (let* ((t_0 (sqrt (* -4.0 (/ a c))))
                  (t_1 (* -1.0 (/ b a)))
                  (t_2 (if (>= b 0.0) t_1 (/ 2.0 t_0))))
             (if (<= b -3.7e-61)
               (if (>= b 0.0) t_1 (* (+ c c) (/ -0.5 b)))
               (if (<= b -1.7e-305)
                 t_2
                 (if (<= b 3.4e-178)
                   (if (>= b 0.0) (* -0.5 (sqrt (* -4.0 (/ c a)))) (/ -2.0 t_0))
                   t_2)))))
          double code(double a, double b, double c) {
          	double t_0 = sqrt((-4.0 * (a / c)));
          	double t_1 = -1.0 * (b / a);
          	double tmp;
          	if (b >= 0.0) {
          		tmp = t_1;
          	} else {
          		tmp = 2.0 / t_0;
          	}
          	double t_2 = tmp;
          	double tmp_2;
          	if (b <= -3.7e-61) {
          		double tmp_3;
          		if (b >= 0.0) {
          			tmp_3 = t_1;
          		} else {
          			tmp_3 = (c + c) * (-0.5 / b);
          		}
          		tmp_2 = tmp_3;
          	} else if (b <= -1.7e-305) {
          		tmp_2 = t_2;
          	} else if (b <= 3.4e-178) {
          		double tmp_4;
          		if (b >= 0.0) {
          			tmp_4 = -0.5 * sqrt((-4.0 * (c / a)));
          		} else {
          			tmp_4 = -2.0 / t_0;
          		}
          		tmp_2 = tmp_4;
          	} else {
          		tmp_2 = t_2;
          	}
          	return tmp_2;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: t_0
              real(8) :: t_1
              real(8) :: t_2
              real(8) :: tmp
              real(8) :: tmp_1
              real(8) :: tmp_2
              real(8) :: tmp_3
              real(8) :: tmp_4
              t_0 = sqrt(((-4.0d0) * (a / c)))
              t_1 = (-1.0d0) * (b / a)
              if (b >= 0.0d0) then
                  tmp = t_1
              else
                  tmp = 2.0d0 / t_0
              end if
              t_2 = tmp
              if (b <= (-3.7d-61)) then
                  if (b >= 0.0d0) then
                      tmp_3 = t_1
                  else
                      tmp_3 = (c + c) * ((-0.5d0) / b)
                  end if
                  tmp_2 = tmp_3
              else if (b <= (-1.7d-305)) then
                  tmp_2 = t_2
              else if (b <= 3.4d-178) then
                  if (b >= 0.0d0) then
                      tmp_4 = (-0.5d0) * sqrt(((-4.0d0) * (c / a)))
                  else
                      tmp_4 = (-2.0d0) / t_0
                  end if
                  tmp_2 = tmp_4
              else
                  tmp_2 = t_2
              end if
              code = tmp_2
          end function
          
          public static double code(double a, double b, double c) {
          	double t_0 = Math.sqrt((-4.0 * (a / c)));
          	double t_1 = -1.0 * (b / a);
          	double tmp;
          	if (b >= 0.0) {
          		tmp = t_1;
          	} else {
          		tmp = 2.0 / t_0;
          	}
          	double t_2 = tmp;
          	double tmp_2;
          	if (b <= -3.7e-61) {
          		double tmp_3;
          		if (b >= 0.0) {
          			tmp_3 = t_1;
          		} else {
          			tmp_3 = (c + c) * (-0.5 / b);
          		}
          		tmp_2 = tmp_3;
          	} else if (b <= -1.7e-305) {
          		tmp_2 = t_2;
          	} else if (b <= 3.4e-178) {
          		double tmp_4;
          		if (b >= 0.0) {
          			tmp_4 = -0.5 * Math.sqrt((-4.0 * (c / a)));
          		} else {
          			tmp_4 = -2.0 / t_0;
          		}
          		tmp_2 = tmp_4;
          	} else {
          		tmp_2 = t_2;
          	}
          	return tmp_2;
          }
          
          def code(a, b, c):
          	t_0 = math.sqrt((-4.0 * (a / c)))
          	t_1 = -1.0 * (b / a)
          	tmp = 0
          	if b >= 0.0:
          		tmp = t_1
          	else:
          		tmp = 2.0 / t_0
          	t_2 = tmp
          	tmp_2 = 0
          	if b <= -3.7e-61:
          		tmp_3 = 0
          		if b >= 0.0:
          			tmp_3 = t_1
          		else:
          			tmp_3 = (c + c) * (-0.5 / b)
          		tmp_2 = tmp_3
          	elif b <= -1.7e-305:
          		tmp_2 = t_2
          	elif b <= 3.4e-178:
          		tmp_4 = 0
          		if b >= 0.0:
          			tmp_4 = -0.5 * math.sqrt((-4.0 * (c / a)))
          		else:
          			tmp_4 = -2.0 / t_0
          		tmp_2 = tmp_4
          	else:
          		tmp_2 = t_2
          	return tmp_2
          
          function code(a, b, c)
          	t_0 = sqrt(Float64(-4.0 * Float64(a / c)))
          	t_1 = Float64(-1.0 * Float64(b / a))
          	tmp = 0.0
          	if (b >= 0.0)
          		tmp = t_1;
          	else
          		tmp = Float64(2.0 / t_0);
          	end
          	t_2 = tmp
          	tmp_2 = 0.0
          	if (b <= -3.7e-61)
          		tmp_3 = 0.0
          		if (b >= 0.0)
          			tmp_3 = t_1;
          		else
          			tmp_3 = Float64(Float64(c + c) * Float64(-0.5 / b));
          		end
          		tmp_2 = tmp_3;
          	elseif (b <= -1.7e-305)
          		tmp_2 = t_2;
          	elseif (b <= 3.4e-178)
          		tmp_4 = 0.0
          		if (b >= 0.0)
          			tmp_4 = Float64(-0.5 * sqrt(Float64(-4.0 * Float64(c / a))));
          		else
          			tmp_4 = Float64(-2.0 / t_0);
          		end
          		tmp_2 = tmp_4;
          	else
          		tmp_2 = t_2;
          	end
          	return tmp_2
          end
          
          function tmp_6 = code(a, b, c)
          	t_0 = sqrt((-4.0 * (a / c)));
          	t_1 = -1.0 * (b / a);
          	tmp = 0.0;
          	if (b >= 0.0)
          		tmp = t_1;
          	else
          		tmp = 2.0 / t_0;
          	end
          	t_2 = tmp;
          	tmp_3 = 0.0;
          	if (b <= -3.7e-61)
          		tmp_4 = 0.0;
          		if (b >= 0.0)
          			tmp_4 = t_1;
          		else
          			tmp_4 = (c + c) * (-0.5 / b);
          		end
          		tmp_3 = tmp_4;
          	elseif (b <= -1.7e-305)
          		tmp_3 = t_2;
          	elseif (b <= 3.4e-178)
          		tmp_5 = 0.0;
          		if (b >= 0.0)
          			tmp_5 = -0.5 * sqrt((-4.0 * (c / a)));
          		else
          			tmp_5 = -2.0 / t_0;
          		end
          		tmp_3 = tmp_5;
          	else
          		tmp_3 = t_2;
          	end
          	tmp_6 = tmp_3;
          end
          
          code[a_, b_, c_] := Block[{t$95$0 = N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = If[GreaterEqual[b, 0.0], t$95$1, N[(2.0 / t$95$0), $MachinePrecision]]}, If[LessEqual[b, -3.7e-61], If[GreaterEqual[b, 0.0], t$95$1, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[LessEqual[b, -1.7e-305], t$95$2, If[LessEqual[b, 3.4e-178], If[GreaterEqual[b, 0.0], N[(-0.5 * N[Sqrt[N[(-4.0 * N[(c / a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(-2.0 / t$95$0), $MachinePrecision]], t$95$2]]]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          t_0 := \sqrt{-4 \cdot \frac{a}{c}}\\
          t_1 := -1 \cdot \frac{b}{a}\\
          t_2 := \begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{2}{t\_0}\\
          
          
          \end{array}\\
          \mathbf{if}\;b \leq -3.7 \cdot 10^{-61}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_1\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \leq -1.7 \cdot 10^{-305}:\\
          \;\;\;\;t\_2\\
          
          \mathbf{elif}\;b \leq 3.4 \cdot 10^{-178}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{t\_0}\\
          
          
          \end{array}\\
          
          \mathbf{else}:\\
          \;\;\;\;t\_2\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 3 regimes
          2. if b < -3.7e-61

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              4. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              5. count-2-revN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              6. lift-+.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              7. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              8. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              9. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              10. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              11. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
              12. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
              13. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            9. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
            10. Taylor expanded in b around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lower-/.f6467.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
            12. Applied rewrites67.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

            if -3.7e-61 < b < -1.7e-305 or 3.39999999999999973e-178 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6442.3

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites42.3%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]

            if -1.7e-305 < b < 3.39999999999999973e-178

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            11. Taylor expanded in a around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{\frac{-1}{2} \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            12. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \color{blue}{\sqrt{-4 \cdot \frac{c}{a}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{-1}{2} \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              4. lower-/.f6415.7

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            13. Applied rewrites15.7%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-0.5 \cdot \sqrt{-4 \cdot \frac{c}{a}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          3. Recombined 3 regimes into one program.
          4. Add Preprocessing

          Alternative 12: 69.8% accurate, 1.4× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} t_0 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -3.7 \cdot 10^{-61}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (let* ((t_0 (* -1.0 (/ b a))))
             (if (<= b -3.7e-61)
               (if (>= b 0.0) t_0 (* (+ c c) (/ -0.5 b)))
               (if (>= b 0.0) t_0 (/ 2.0 (sqrt (* -4.0 (/ a c))))))))
          double code(double a, double b, double c) {
          	double t_0 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -3.7e-61) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_0;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b >= 0.0) {
          		tmp_1 = t_0;
          	} else {
          		tmp_1 = 2.0 / sqrt((-4.0 * (a / c)));
          	}
          	return tmp_1;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: t_0
              real(8) :: tmp
              real(8) :: tmp_1
              real(8) :: tmp_2
              t_0 = (-1.0d0) * (b / a)
              if (b <= (-3.7d-61)) then
                  if (b >= 0.0d0) then
                      tmp_2 = t_0
                  else
                      tmp_2 = (c + c) * ((-0.5d0) / b)
                  end if
                  tmp_1 = tmp_2
              else if (b >= 0.0d0) then
                  tmp_1 = t_0
              else
                  tmp_1 = 2.0d0 / sqrt(((-4.0d0) * (a / c)))
              end if
              code = tmp_1
          end function
          
          public static double code(double a, double b, double c) {
          	double t_0 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -3.7e-61) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_0;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b >= 0.0) {
          		tmp_1 = t_0;
          	} else {
          		tmp_1 = 2.0 / Math.sqrt((-4.0 * (a / c)));
          	}
          	return tmp_1;
          }
          
          def code(a, b, c):
          	t_0 = -1.0 * (b / a)
          	tmp_1 = 0
          	if b <= -3.7e-61:
          		tmp_2 = 0
          		if b >= 0.0:
          			tmp_2 = t_0
          		else:
          			tmp_2 = (c + c) * (-0.5 / b)
          		tmp_1 = tmp_2
          	elif b >= 0.0:
          		tmp_1 = t_0
          	else:
          		tmp_1 = 2.0 / math.sqrt((-4.0 * (a / c)))
          	return tmp_1
          
          function code(a, b, c)
          	t_0 = Float64(-1.0 * Float64(b / a))
          	tmp_1 = 0.0
          	if (b <= -3.7e-61)
          		tmp_2 = 0.0
          		if (b >= 0.0)
          			tmp_2 = t_0;
          		else
          			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
          		end
          		tmp_1 = tmp_2;
          	elseif (b >= 0.0)
          		tmp_1 = t_0;
          	else
          		tmp_1 = Float64(2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
          	end
          	return tmp_1
          end
          
          function tmp_4 = code(a, b, c)
          	t_0 = -1.0 * (b / a);
          	tmp_2 = 0.0;
          	if (b <= -3.7e-61)
          		tmp_3 = 0.0;
          		if (b >= 0.0)
          			tmp_3 = t_0;
          		else
          			tmp_3 = (c + c) * (-0.5 / b);
          		end
          		tmp_2 = tmp_3;
          	elseif (b >= 0.0)
          		tmp_2 = t_0;
          	else
          		tmp_2 = 2.0 / sqrt((-4.0 * (a / c)));
          	end
          	tmp_4 = tmp_2;
          end
          
          code[a_, b_, c_] := Block[{t$95$0 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -3.7e-61], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$0, N[(2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          t_0 := -1 \cdot \frac{b}{a}\\
          \mathbf{if}\;b \leq -3.7 \cdot 10^{-61}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_0\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \geq 0:\\
          \;\;\;\;t\_0\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if b < -3.7e-61

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              4. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              5. count-2-revN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              6. lift-+.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              7. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              8. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              9. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              10. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              11. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
              12. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
              13. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            9. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
            10. Taylor expanded in b around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lower-/.f6467.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
            12. Applied rewrites67.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

            if -3.7e-61 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6442.3

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites42.3%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          3. Recombined 2 regimes into one program.
          4. Add Preprocessing

          Alternative 13: 69.7% accurate, 1.4× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} t_0 := -1 \cdot \frac{b}{a}\\ \mathbf{if}\;b \leq -1.3 \cdot 10^{-113}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;t\_0\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (let* ((t_0 (* -1.0 (/ b a))))
             (if (<= b -1.3e-113)
               (if (>= b 0.0) t_0 (* (+ c c) (/ -0.5 b)))
               (if (>= b 0.0) t_0 (/ -2.0 (sqrt (* -4.0 (/ a c))))))))
          double code(double a, double b, double c) {
          	double t_0 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -1.3e-113) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_0;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b >= 0.0) {
          		tmp_1 = t_0;
          	} else {
          		tmp_1 = -2.0 / sqrt((-4.0 * (a / c)));
          	}
          	return tmp_1;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: t_0
              real(8) :: tmp
              real(8) :: tmp_1
              real(8) :: tmp_2
              t_0 = (-1.0d0) * (b / a)
              if (b <= (-1.3d-113)) then
                  if (b >= 0.0d0) then
                      tmp_2 = t_0
                  else
                      tmp_2 = (c + c) * ((-0.5d0) / b)
                  end if
                  tmp_1 = tmp_2
              else if (b >= 0.0d0) then
                  tmp_1 = t_0
              else
                  tmp_1 = (-2.0d0) / sqrt(((-4.0d0) * (a / c)))
              end if
              code = tmp_1
          end function
          
          public static double code(double a, double b, double c) {
          	double t_0 = -1.0 * (b / a);
          	double tmp_1;
          	if (b <= -1.3e-113) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = t_0;
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b >= 0.0) {
          		tmp_1 = t_0;
          	} else {
          		tmp_1 = -2.0 / Math.sqrt((-4.0 * (a / c)));
          	}
          	return tmp_1;
          }
          
          def code(a, b, c):
          	t_0 = -1.0 * (b / a)
          	tmp_1 = 0
          	if b <= -1.3e-113:
          		tmp_2 = 0
          		if b >= 0.0:
          			tmp_2 = t_0
          		else:
          			tmp_2 = (c + c) * (-0.5 / b)
          		tmp_1 = tmp_2
          	elif b >= 0.0:
          		tmp_1 = t_0
          	else:
          		tmp_1 = -2.0 / math.sqrt((-4.0 * (a / c)))
          	return tmp_1
          
          function code(a, b, c)
          	t_0 = Float64(-1.0 * Float64(b / a))
          	tmp_1 = 0.0
          	if (b <= -1.3e-113)
          		tmp_2 = 0.0
          		if (b >= 0.0)
          			tmp_2 = t_0;
          		else
          			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
          		end
          		tmp_1 = tmp_2;
          	elseif (b >= 0.0)
          		tmp_1 = t_0;
          	else
          		tmp_1 = Float64(-2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
          	end
          	return tmp_1
          end
          
          function tmp_4 = code(a, b, c)
          	t_0 = -1.0 * (b / a);
          	tmp_2 = 0.0;
          	if (b <= -1.3e-113)
          		tmp_3 = 0.0;
          		if (b >= 0.0)
          			tmp_3 = t_0;
          		else
          			tmp_3 = (c + c) * (-0.5 / b);
          		end
          		tmp_2 = tmp_3;
          	elseif (b >= 0.0)
          		tmp_2 = t_0;
          	else
          		tmp_2 = -2.0 / sqrt((-4.0 * (a / c)));
          	end
          	tmp_4 = tmp_2;
          end
          
          code[a_, b_, c_] := Block[{t$95$0 = N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[b, -1.3e-113], If[GreaterEqual[b, 0.0], t$95$0, N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], t$95$0, N[(-2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          t_0 := -1 \cdot \frac{b}{a}\\
          \mathbf{if}\;b \leq -1.3 \cdot 10^{-113}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;t\_0\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \geq 0:\\
          \;\;\;\;t\_0\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if b < -1.3e-113

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              4. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              5. count-2-revN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              6. lift-+.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              7. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              8. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              9. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              10. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              11. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
              12. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
              13. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            9. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
            10. Taylor expanded in b around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lower-/.f6467.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
            12. Applied rewrites67.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

            if -1.3e-113 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          3. Recombined 2 regimes into one program.
          4. Add Preprocessing

          Alternative 14: 69.3% accurate, 1.4× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \leq -1.3 \cdot 10^{-113}:\\ \;\;\;\;\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array}\\ \mathbf{elif}\;b \geq 0:\\ \;\;\;\;-1 \cdot \left(b \cdot \frac{1}{a}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (if (<= b -1.3e-113)
             (if (>= b 0.0) (* -1.0 (/ b a)) (* (+ c c) (/ -0.5 b)))
             (if (>= b 0.0) (* -1.0 (* b (/ 1.0 a))) (/ -2.0 (sqrt (* -4.0 (/ a c)))))))
          double code(double a, double b, double c) {
          	double tmp_1;
          	if (b <= -1.3e-113) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = -1.0 * (b / a);
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b >= 0.0) {
          		tmp_1 = -1.0 * (b * (1.0 / a));
          	} else {
          		tmp_1 = -2.0 / sqrt((-4.0 * (a / c)));
          	}
          	return tmp_1;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: tmp
              real(8) :: tmp_1
              real(8) :: tmp_2
              if (b <= (-1.3d-113)) then
                  if (b >= 0.0d0) then
                      tmp_2 = (-1.0d0) * (b / a)
                  else
                      tmp_2 = (c + c) * ((-0.5d0) / b)
                  end if
                  tmp_1 = tmp_2
              else if (b >= 0.0d0) then
                  tmp_1 = (-1.0d0) * (b * (1.0d0 / a))
              else
                  tmp_1 = (-2.0d0) / sqrt(((-4.0d0) * (a / c)))
              end if
              code = tmp_1
          end function
          
          public static double code(double a, double b, double c) {
          	double tmp_1;
          	if (b <= -1.3e-113) {
          		double tmp_2;
          		if (b >= 0.0) {
          			tmp_2 = -1.0 * (b / a);
          		} else {
          			tmp_2 = (c + c) * (-0.5 / b);
          		}
          		tmp_1 = tmp_2;
          	} else if (b >= 0.0) {
          		tmp_1 = -1.0 * (b * (1.0 / a));
          	} else {
          		tmp_1 = -2.0 / Math.sqrt((-4.0 * (a / c)));
          	}
          	return tmp_1;
          }
          
          def code(a, b, c):
          	tmp_1 = 0
          	if b <= -1.3e-113:
          		tmp_2 = 0
          		if b >= 0.0:
          			tmp_2 = -1.0 * (b / a)
          		else:
          			tmp_2 = (c + c) * (-0.5 / b)
          		tmp_1 = tmp_2
          	elif b >= 0.0:
          		tmp_1 = -1.0 * (b * (1.0 / a))
          	else:
          		tmp_1 = -2.0 / math.sqrt((-4.0 * (a / c)))
          	return tmp_1
          
          function code(a, b, c)
          	tmp_1 = 0.0
          	if (b <= -1.3e-113)
          		tmp_2 = 0.0
          		if (b >= 0.0)
          			tmp_2 = Float64(-1.0 * Float64(b / a));
          		else
          			tmp_2 = Float64(Float64(c + c) * Float64(-0.5 / b));
          		end
          		tmp_1 = tmp_2;
          	elseif (b >= 0.0)
          		tmp_1 = Float64(-1.0 * Float64(b * Float64(1.0 / a)));
          	else
          		tmp_1 = Float64(-2.0 / sqrt(Float64(-4.0 * Float64(a / c))));
          	end
          	return tmp_1
          end
          
          function tmp_4 = code(a, b, c)
          	tmp_2 = 0.0;
          	if (b <= -1.3e-113)
          		tmp_3 = 0.0;
          		if (b >= 0.0)
          			tmp_3 = -1.0 * (b / a);
          		else
          			tmp_3 = (c + c) * (-0.5 / b);
          		end
          		tmp_2 = tmp_3;
          	elseif (b >= 0.0)
          		tmp_2 = -1.0 * (b * (1.0 / a));
          	else
          		tmp_2 = -2.0 / sqrt((-4.0 * (a / c)));
          	end
          	tmp_4 = tmp_2;
          end
          
          code[a_, b_, c_] := If[LessEqual[b, -1.3e-113], If[GreaterEqual[b, 0.0], N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]], If[GreaterEqual[b, 0.0], N[(-1.0 * N[(b * N[(1.0 / a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(-2.0 / N[Sqrt[N[(-4.0 * N[(a / c), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          \mathbf{if}\;b \leq -1.3 \cdot 10^{-113}:\\
          \;\;\;\;\begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;-1 \cdot \frac{b}{a}\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}\\
          
          \mathbf{elif}\;b \geq 0:\\
          \;\;\;\;-1 \cdot \left(b \cdot \frac{1}{a}\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if b < -1.3e-113

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              4. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              5. count-2-revN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              6. lift-+.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              7. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              8. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              9. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              10. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
              11. lift-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
              12. *-commutativeN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
              13. lower-*.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            9. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
            10. Taylor expanded in b around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lower-/.f6467.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
            12. Applied rewrites67.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]

            if -1.3e-113 < b

            1. Initial program 71.3%

              \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
            2. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
              2. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
              3. lower-*.f6436.5

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
            4. Applied rewrites36.5%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            5. Taylor expanded in b around inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
              2. lower-/.f6435.0

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. Applied rewrites35.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            8. Taylor expanded in c around -inf

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            9. Step-by-step derivation
              1. lower-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              2. lower-sqrt.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\color{blue}{\sqrt{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{\color{blue}{-4 \cdot \frac{a}{c}}}}\\ \end{array} \]
              4. lower-/.f6441.9

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \color{blue}{\frac{a}{c}}}}\\ \end{array} \]
            10. Applied rewrites41.9%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            11. Step-by-step derivation
              1. lift-/.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              2. mult-flipN/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \left(b \cdot \color{blue}{\frac{1}{a}}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              3. lower-*.f64N/A

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \left(b \cdot \color{blue}{\frac{1}{a}}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
              4. lower-/.f6441.8

                \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \left(b \cdot \frac{1}{\color{blue}{a}}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
            12. Applied rewrites41.8%

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \left(b \cdot \color{blue}{\frac{1}{a}}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{-2}{\sqrt{-4 \cdot \frac{a}{c}}}\\ \end{array} \]
          3. Recombined 2 regimes into one program.
          4. Add Preprocessing

          Alternative 15: 67.9% accurate, 2.0× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\ \end{array} \end{array} \]
          (FPCore (a b c)
           :precision binary64
           (if (>= b 0.0) (* -1.0 (/ b a)) (* (+ c c) (/ -0.5 b))))
          double code(double a, double b, double c) {
          	double tmp;
          	if (b >= 0.0) {
          		tmp = -1.0 * (b / a);
          	} else {
          		tmp = (c + c) * (-0.5 / b);
          	}
          	return tmp;
          }
          
          module fmin_fmax_functions
              implicit none
              private
              public fmax
              public fmin
          
              interface fmax
                  module procedure fmax88
                  module procedure fmax44
                  module procedure fmax84
                  module procedure fmax48
              end interface
              interface fmin
                  module procedure fmin88
                  module procedure fmin44
                  module procedure fmin84
                  module procedure fmin48
              end interface
          contains
              real(8) function fmax88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(4) function fmax44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
              end function
              real(8) function fmax84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmax48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
              end function
              real(8) function fmin88(x, y) result (res)
                  real(8), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(4) function fmin44(x, y) result (res)
                  real(4), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
              end function
              real(8) function fmin84(x, y) result(res)
                  real(8), intent (in) :: x
                  real(4), intent (in) :: y
                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
              end function
              real(8) function fmin48(x, y) result(res)
                  real(4), intent (in) :: x
                  real(8), intent (in) :: y
                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
              end function
          end module
          
          real(8) function code(a, b, c)
          use fmin_fmax_functions
              real(8), intent (in) :: a
              real(8), intent (in) :: b
              real(8), intent (in) :: c
              real(8) :: tmp
              if (b >= 0.0d0) then
                  tmp = (-1.0d0) * (b / a)
              else
                  tmp = (c + c) * ((-0.5d0) / b)
              end if
              code = tmp
          end function
          
          public static double code(double a, double b, double c) {
          	double tmp;
          	if (b >= 0.0) {
          		tmp = -1.0 * (b / a);
          	} else {
          		tmp = (c + c) * (-0.5 / b);
          	}
          	return tmp;
          }
          
          def code(a, b, c):
          	tmp = 0
          	if b >= 0.0:
          		tmp = -1.0 * (b / a)
          	else:
          		tmp = (c + c) * (-0.5 / b)
          	return tmp
          
          function code(a, b, c)
          	tmp = 0.0
          	if (b >= 0.0)
          		tmp = Float64(-1.0 * Float64(b / a));
          	else
          		tmp = Float64(Float64(c + c) * Float64(-0.5 / b));
          	end
          	return tmp
          end
          
          function tmp_2 = code(a, b, c)
          	tmp = 0.0;
          	if (b >= 0.0)
          		tmp = -1.0 * (b / a);
          	else
          		tmp = (c + c) * (-0.5 / b);
          	end
          	tmp_2 = tmp;
          end
          
          code[a_, b_, c_] := If[GreaterEqual[b, 0.0], N[(-1.0 * N[(b / a), $MachinePrecision]), $MachinePrecision], N[(N[(c + c), $MachinePrecision] * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          \mathbf{if}\;b \geq 0:\\
          \;\;\;\;-1 \cdot \frac{b}{a}\\
          
          \mathbf{else}:\\
          \;\;\;\;\left(c + c\right) \cdot \frac{-0.5}{b}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Initial program 71.3%

            \[\begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\ \end{array} \]
          2. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            2. lower-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \color{blue}{\frac{a \cdot c}{b}}}\\ \end{array} \]
            3. lower-*.f6436.5

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{\color{blue}{a \cdot c}}{b}}\\ \end{array} \]
          4. Applied rewrites36.5%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
          5. Taylor expanded in b around inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \color{blue}{\frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{\color{blue}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          7. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;\color{blue}{-1 \cdot \frac{b}{a}}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
          8. Step-by-step derivation
            1. lift-/.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\frac{2 \cdot c}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            2. mult-flipN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            3. lower-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            4. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(2 \cdot c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            5. count-2-revN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            6. lift-+.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}\\ \end{array} \]
            7. lower-/.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{1}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            8. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{-2 \cdot \frac{a \cdot c}{b}}}\\ \end{array} \]
            9. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            10. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\color{blue}{\frac{a \cdot c}{b} \cdot -2}}\\ \end{array} \]
            11. lift-*.f64N/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{a \cdot c}}{b} \cdot -2}\\ \end{array} \]
            12. *-commutativeN/A

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
            13. lower-*.f6435.0

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{\color{blue}{c \cdot a}}{b} \cdot -2}\\ \end{array} \]
          9. Applied rewrites35.0%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \frac{1}{\frac{c \cdot a}{b} \cdot -2}\\ \end{array} \]
          10. Taylor expanded in b around -inf

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{\frac{-1}{2}}{b}}\\ \end{array} \]
          11. Step-by-step derivation
            1. lower-/.f6467.9

              \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\left(c + c\right) \cdot \color{blue}{\frac{-0.5}{b}}\\ \end{array} \]
          12. Applied rewrites67.9%

            \[\leadsto \begin{array}{l} \mathbf{if}\;b \geq 0:\\ \;\;\;\;-1 \cdot \frac{b}{a}\\ \mathbf{else}:\\ \;\;\;\;\color{blue}{\left(c + c\right) \cdot \frac{-0.5}{b}}\\ \end{array} \]
          13. Add Preprocessing

          Reproduce

          ?
          herbie shell --seed 2025150 
          (FPCore (a b c)
            :name "jeff quadratic root 1"
            :precision binary64
            (if (>= b 0.0) (/ (- (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)) (/ (* 2.0 c) (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))))))