Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, D

Percentage Accurate: 59.0% → 98.0%
Time: 14.4s
Alternatives: 18
Speedup: 11.3×

Specification

?
\[\begin{array}{l} \\ x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \end{array} \]
(FPCore (x y z t a b)
 :precision binary64
 (+
  x
  (/
   (*
    y
    (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b))
   (+
    (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z)
    0.607771387771))))
double code(double x, double y, double z, double t, double a, double b) {
	return x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771));
}
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(x, y, z, t, a, b)
use fmin_fmax_functions
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    real(8), intent (in) :: z
    real(8), intent (in) :: t
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    code = x + ((y * ((((((((z * 3.13060547623d0) + 11.1667541262d0) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407d0) * z) + 31.4690115749d0) * z) + 11.9400905721d0) * z) + 0.607771387771d0))
end function
public static double code(double x, double y, double z, double t, double a, double b) {
	return x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771));
}
def code(x, y, z, t, a, b):
	return x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))
function code(x, y, z, t, a, b)
	return Float64(x + Float64(Float64(y * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771)))
end
function tmp = code(x, y, z, t, a, b)
	tmp = x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771));
end
code[x_, y_, z_, t_, a_, b_] := N[(x + N[(N[(y * N[(N[(N[(N[(N[(N[(N[(N[(z * 3.13060547623), $MachinePrecision] + 11.1667541262), $MachinePrecision] * z), $MachinePrecision] + t), $MachinePrecision] * z), $MachinePrecision] + a), $MachinePrecision] * z), $MachinePrecision] + b), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(z + 15.234687407), $MachinePrecision] * z), $MachinePrecision] + 31.4690115749), $MachinePrecision] * z), $MachinePrecision] + 11.9400905721), $MachinePrecision] * z), $MachinePrecision] + 0.607771387771), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771}
\end{array}

Sampling outcomes in binary64 precision:

Local Percentage Accuracy vs ?

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

Accuracy vs Speed?

Herbie found 18 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: 59.0% accurate, 1.0× speedup?

\[\begin{array}{l} \\ x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \end{array} \]
(FPCore (x y z t a b)
 :precision binary64
 (+
  x
  (/
   (*
    y
    (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b))
   (+
    (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z)
    0.607771387771))))
double code(double x, double y, double z, double t, double a, double b) {
	return x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771));
}
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(x, y, z, t, a, b)
use fmin_fmax_functions
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    real(8), intent (in) :: z
    real(8), intent (in) :: t
    real(8), intent (in) :: a
    real(8), intent (in) :: b
    code = x + ((y * ((((((((z * 3.13060547623d0) + 11.1667541262d0) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407d0) * z) + 31.4690115749d0) * z) + 11.9400905721d0) * z) + 0.607771387771d0))
end function
public static double code(double x, double y, double z, double t, double a, double b) {
	return x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771));
}
def code(x, y, z, t, a, b):
	return x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))
function code(x, y, z, t, a, b)
	return Float64(x + Float64(Float64(y * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771)))
end
function tmp = code(x, y, z, t, a, b)
	tmp = x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771));
end
code[x_, y_, z_, t_, a_, b_] := N[(x + N[(N[(y * N[(N[(N[(N[(N[(N[(N[(N[(z * 3.13060547623), $MachinePrecision] + 11.1667541262), $MachinePrecision] * z), $MachinePrecision] + t), $MachinePrecision] * z), $MachinePrecision] + a), $MachinePrecision] * z), $MachinePrecision] + b), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(z + 15.234687407), $MachinePrecision] * z), $MachinePrecision] + 31.4690115749), $MachinePrecision] * z), $MachinePrecision] + 11.9400905721), $MachinePrecision] * z), $MachinePrecision] + 0.607771387771), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771}
\end{array}

Alternative 1: 98.0% accurate, 0.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq \infty:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{\left(457.9610022158428 + t\right) + \frac{a + \left(-5864.8025282699045 + t \cdot -15.234687407\right)}{z}}{z}}{z}, y, x\right)\\ \end{array} \end{array} \]
(FPCore (x y z t a b)
 :precision binary64
 (if (<=
      (+
       x
       (/
        (*
         y
         (+
          (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z)
          b))
        (+
         (*
          (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721)
          z)
         0.607771387771)))
      INFINITY)
   (fma
    (/
     (fma (fma (fma (fma 3.13060547623 z 11.1667541262) z t) z a) z b)
     (fma
      (fma (fma (+ 15.234687407 z) z 31.4690115749) z 11.9400905721)
      z
      0.607771387771))
    y
    x)
   (fma
    (-
     3.13060547623
     (/
      (-
       36.52704169880642
       (/
        (+
         (+ 457.9610022158428 t)
         (/ (+ a (+ -5864.8025282699045 (* t -15.234687407))) z))
        z))
      z))
    y
    x)))
double code(double x, double y, double z, double t, double a, double b) {
	double tmp;
	if ((x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))) <= ((double) INFINITY)) {
		tmp = fma((fma(fma(fma(fma(3.13060547623, z, 11.1667541262), z, t), z, a), z, b) / fma(fma(fma((15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)), y, x);
	} else {
		tmp = fma((3.13060547623 - ((36.52704169880642 - (((457.9610022158428 + t) + ((a + (-5864.8025282699045 + (t * -15.234687407))) / z)) / z)) / z)), y, x);
	}
	return tmp;
}
function code(x, y, z, t, a, b)
	tmp = 0.0
	if (Float64(x + Float64(Float64(y * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))) <= Inf)
		tmp = fma(Float64(fma(fma(fma(fma(3.13060547623, z, 11.1667541262), z, t), z, a), z, b) / fma(fma(fma(Float64(15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)), y, x);
	else
		tmp = fma(Float64(3.13060547623 - Float64(Float64(36.52704169880642 - Float64(Float64(Float64(457.9610022158428 + t) + Float64(Float64(a + Float64(-5864.8025282699045 + Float64(t * -15.234687407))) / z)) / z)) / z)), y, x);
	end
	return tmp
end
code[x_, y_, z_, t_, a_, b_] := If[LessEqual[N[(x + N[(N[(y * N[(N[(N[(N[(N[(N[(N[(N[(z * 3.13060547623), $MachinePrecision] + 11.1667541262), $MachinePrecision] * z), $MachinePrecision] + t), $MachinePrecision] * z), $MachinePrecision] + a), $MachinePrecision] * z), $MachinePrecision] + b), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(z + 15.234687407), $MachinePrecision] * z), $MachinePrecision] + 31.4690115749), $MachinePrecision] * z), $MachinePrecision] + 11.9400905721), $MachinePrecision] * z), $MachinePrecision] + 0.607771387771), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(N[(N[(N[(N[(3.13060547623 * z + 11.1667541262), $MachinePrecision] * z + t), $MachinePrecision] * z + a), $MachinePrecision] * z + b), $MachinePrecision] / N[(N[(N[(N[(15.234687407 + z), $MachinePrecision] * z + 31.4690115749), $MachinePrecision] * z + 11.9400905721), $MachinePrecision] * z + 0.607771387771), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(N[(3.13060547623 - N[(N[(36.52704169880642 - N[(N[(N[(457.9610022158428 + t), $MachinePrecision] + N[(N[(a + N[(-5864.8025282699045 + N[(t * -15.234687407), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq \infty:\\
\;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\

\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{\left(457.9610022158428 + t\right) + \frac{a + \left(-5864.8025282699045 + t \cdot -15.234687407\right)}{z}}{z}}{z}, y, x\right)\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (+.f64 x (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64)))) < +inf.0

    1. Initial program 94.0%

      \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
      2. +-commutativeN/A

        \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
      3. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
      4. lift-*.f64N/A

        \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
      5. associate-/l*N/A

        \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
      6. *-commutativeN/A

        \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
      7. lower-fma.f64N/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
    4. Applied rewrites97.4%

      \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]

    if +inf.0 < (+.f64 x (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64))))

    1. Initial program 0.0%

      \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-+.f64N/A

        \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
      2. +-commutativeN/A

        \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
      3. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
      4. lift-*.f64N/A

        \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
      5. associate-/l*N/A

        \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
      6. *-commutativeN/A

        \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
      7. lower-fma.f64N/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
    4. Applied rewrites0.0%

      \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
    5. Taylor expanded in z around 0

      \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b + z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right)}, y, x\right) \]
    6. Step-by-step derivation
      1. +-commutativeN/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) + \frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
      2. *-commutativeN/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) \cdot z} + \frac{1000000000000}{607771387771} \cdot b, y, x\right) \]
      3. lower-fma.f64N/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b, z, \frac{1000000000000}{607771387771} \cdot b\right)}, y, x\right) \]
      4. fp-cancel-sub-sign-invN/A

        \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot a + \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
      5. lower-fma.f64N/A

        \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b\right)}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
      6. metadata-evalN/A

        \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441}} \cdot b\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
      7. lower-*.f64N/A

        \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441} \cdot b}\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
      8. lower-*.f6416.6

        \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, \color{blue}{1.6453555072203998 \cdot b}\right), y, x\right) \]
    7. Applied rewrites16.6%

      \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, 1.6453555072203998 \cdot b\right)}, y, x\right) \]
    8. Taylor expanded in z around -inf

      \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} + -1 \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + \left(t + -1 \cdot \frac{-1 \cdot a - \left(\frac{1112090185084895700201045470302189}{1000000000000000000000000000000} + \frac{-15234687407}{1000000000} \cdot \left(\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t\right)\right)}{z}\right)}{z}}{z}}, y, x\right) \]
    9. Applied rewrites99.9%

      \[\leadsto \mathsf{fma}\left(\color{blue}{3.13060547623 - \frac{36.52704169880642 - \frac{\left(457.9610022158428 + t\right) - \frac{\left(-a\right) - \left(-5864.8025282699045 + t \cdot -15.234687407\right)}{z}}{z}}{z}}, y, x\right) \]
  3. Recombined 2 regimes into one program.
  4. Final simplification98.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq \infty:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{\left(457.9610022158428 + t\right) + \frac{a + \left(-5864.8025282699045 + t \cdot -15.234687407\right)}{z}}{z}}{z}, y, x\right)\\ \end{array} \]
  5. Add Preprocessing

Alternative 2: 70.8% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_1 := \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771}\\ \mathbf{if}\;t\_1 \leq -5 \cdot 10^{+213} \lor \neg \left(t\_1 \leq 5 \cdot 10^{+75} \lor \neg \left(t\_1 \leq \infty\right)\right):\\ \;\;\;\;\left(y \cdot b\right) \cdot 1.6453555072203998\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \end{array} \end{array} \]
(FPCore (x y z t a b)
 :precision binary64
 (let* ((t_1
         (/
          (*
           y
           (+
            (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z)
            b))
          (+
           (*
            (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721)
            z)
           0.607771387771))))
   (if (or (<= t_1 -5e+213) (not (or (<= t_1 5e+75) (not (<= t_1 INFINITY)))))
     (* (* y b) 1.6453555072203998)
     (fma 3.13060547623 y x))))
double code(double x, double y, double z, double t, double a, double b) {
	double t_1 = (y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771);
	double tmp;
	if ((t_1 <= -5e+213) || !((t_1 <= 5e+75) || !(t_1 <= ((double) INFINITY)))) {
		tmp = (y * b) * 1.6453555072203998;
	} else {
		tmp = fma(3.13060547623, y, x);
	}
	return tmp;
}
function code(x, y, z, t, a, b)
	t_1 = Float64(Float64(y * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))
	tmp = 0.0
	if ((t_1 <= -5e+213) || !((t_1 <= 5e+75) || !(t_1 <= Inf)))
		tmp = Float64(Float64(y * b) * 1.6453555072203998);
	else
		tmp = fma(3.13060547623, y, x);
	end
	return tmp
end
code[x_, y_, z_, t_, a_, b_] := Block[{t$95$1 = N[(N[(y * N[(N[(N[(N[(N[(N[(N[(N[(z * 3.13060547623), $MachinePrecision] + 11.1667541262), $MachinePrecision] * z), $MachinePrecision] + t), $MachinePrecision] * z), $MachinePrecision] + a), $MachinePrecision] * z), $MachinePrecision] + b), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(z + 15.234687407), $MachinePrecision] * z), $MachinePrecision] + 31.4690115749), $MachinePrecision] * z), $MachinePrecision] + 11.9400905721), $MachinePrecision] * z), $MachinePrecision] + 0.607771387771), $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[t$95$1, -5e+213], N[Not[Or[LessEqual[t$95$1, 5e+75], N[Not[LessEqual[t$95$1, Infinity]], $MachinePrecision]]], $MachinePrecision]], N[(N[(y * b), $MachinePrecision] * 1.6453555072203998), $MachinePrecision], N[(3.13060547623 * y + x), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
t_1 := \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771}\\
\mathbf{if}\;t\_1 \leq -5 \cdot 10^{+213} \lor \neg \left(t\_1 \leq 5 \cdot 10^{+75} \lor \neg \left(t\_1 \leq \infty\right)\right):\\
\;\;\;\;\left(y \cdot b\right) \cdot 1.6453555072203998\\

\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64))) < -4.9999999999999998e213 or 5.0000000000000002e75 < (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64))) < +inf.0

    1. Initial program 83.2%

      \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
    2. Add Preprocessing
    3. Taylor expanded in z around 0

      \[\leadsto x + \frac{y \cdot \color{blue}{\left(b + a \cdot z\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
    4. Step-by-step derivation
      1. +-commutativeN/A

        \[\leadsto x + \frac{y \cdot \color{blue}{\left(a \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
      2. lower-fma.f6469.1

        \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
    5. Applied rewrites69.1%

      \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
    6. Step-by-step derivation
      1. lift-*.f64N/A

        \[\leadsto x + \frac{\color{blue}{y \cdot \mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
      2. *-commutativeN/A

        \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
      3. lower-*.f6469.1

        \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      4. lift-+.f64N/A

        \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
      5. lift-*.f64N/A

        \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z} + \frac{607771387771}{1000000000000}} \]
      6. lower-fma.f6469.1

        \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\mathsf{fma}\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721, z, 0.607771387771\right)}} \]
    7. Applied rewrites69.1%

      \[\leadsto x + \color{blue}{\frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}} \]
    8. Taylor expanded in z around 0

      \[\leadsto \color{blue}{x + \frac{1000000000000}{607771387771} \cdot \left(b \cdot y\right)} \]
    9. Step-by-step derivation
      1. +-commutativeN/A

        \[\leadsto \color{blue}{\frac{1000000000000}{607771387771} \cdot \left(b \cdot y\right) + x} \]
      2. *-commutativeN/A

        \[\leadsto \color{blue}{\left(b \cdot y\right) \cdot \frac{1000000000000}{607771387771}} + x \]
      3. lower-fma.f64N/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(b \cdot y, \frac{1000000000000}{607771387771}, x\right)} \]
      4. *-commutativeN/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{y \cdot b}, \frac{1000000000000}{607771387771}, x\right) \]
      5. lower-*.f6457.5

        \[\leadsto \mathsf{fma}\left(\color{blue}{y \cdot b}, 1.6453555072203998, x\right) \]
    10. Applied rewrites57.5%

      \[\leadsto \color{blue}{\mathsf{fma}\left(y \cdot b, 1.6453555072203998, x\right)} \]
    11. Taylor expanded in x around 0

      \[\leadsto \frac{1000000000000}{607771387771} \cdot \color{blue}{\left(b \cdot y\right)} \]
    12. Step-by-step derivation
      1. Applied rewrites50.5%

        \[\leadsto \left(y \cdot b\right) \cdot \color{blue}{1.6453555072203998} \]

      if -4.9999999999999998e213 < (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64))) < 5.0000000000000002e75 or +inf.0 < (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64)))

      1. Initial program 53.6%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Taylor expanded in z around inf

        \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
      4. Step-by-step derivation
        1. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
        2. lower-fma.f6476.4

          \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
      5. Applied rewrites76.4%

        \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
    13. Recombined 2 regimes into one program.
    14. Final simplification70.6%

      \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq -5 \cdot 10^{+213} \lor \neg \left(\frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq 5 \cdot 10^{+75} \lor \neg \left(\frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq \infty\right)\right):\\ \;\;\;\;\left(y \cdot b\right) \cdot 1.6453555072203998\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \end{array} \]
    15. Add Preprocessing

    Alternative 3: 98.0% accurate, 0.5× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq \infty:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \end{array} \end{array} \]
    (FPCore (x y z t a b)
     :precision binary64
     (if (<=
          (+
           x
           (/
            (*
             y
             (+
              (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z)
              b))
            (+
             (*
              (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721)
              z)
             0.607771387771)))
          INFINITY)
       (fma
        (/
         (fma (fma (fma (fma 3.13060547623 z 11.1667541262) z t) z a) z b)
         (fma
          (fma (fma (+ 15.234687407 z) z 31.4690115749) z 11.9400905721)
          z
          0.607771387771))
        y
        x)
       (fma
        (-
         (+ (/ (+ 457.9610022158428 t) (* z z)) 3.13060547623)
         (/ 36.52704169880642 z))
        y
        x)))
    double code(double x, double y, double z, double t, double a, double b) {
    	double tmp;
    	if ((x + ((y * ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / (((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))) <= ((double) INFINITY)) {
    		tmp = fma((fma(fma(fma(fma(3.13060547623, z, 11.1667541262), z, t), z, a), z, b) / fma(fma(fma((15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)), y, x);
    	} else {
    		tmp = fma(((((457.9610022158428 + t) / (z * z)) + 3.13060547623) - (36.52704169880642 / z)), y, x);
    	}
    	return tmp;
    }
    
    function code(x, y, z, t, a, b)
    	tmp = 0.0
    	if (Float64(x + Float64(Float64(y * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771))) <= Inf)
    		tmp = fma(Float64(fma(fma(fma(fma(3.13060547623, z, 11.1667541262), z, t), z, a), z, b) / fma(fma(fma(Float64(15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)), y, x);
    	else
    		tmp = fma(Float64(Float64(Float64(Float64(457.9610022158428 + t) / Float64(z * z)) + 3.13060547623) - Float64(36.52704169880642 / z)), y, x);
    	end
    	return tmp
    end
    
    code[x_, y_, z_, t_, a_, b_] := If[LessEqual[N[(x + N[(N[(y * N[(N[(N[(N[(N[(N[(N[(N[(z * 3.13060547623), $MachinePrecision] + 11.1667541262), $MachinePrecision] * z), $MachinePrecision] + t), $MachinePrecision] * z), $MachinePrecision] + a), $MachinePrecision] * z), $MachinePrecision] + b), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(z + 15.234687407), $MachinePrecision] * z), $MachinePrecision] + 31.4690115749), $MachinePrecision] * z), $MachinePrecision] + 11.9400905721), $MachinePrecision] * z), $MachinePrecision] + 0.607771387771), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(N[(N[(N[(N[(3.13060547623 * z + 11.1667541262), $MachinePrecision] * z + t), $MachinePrecision] * z + a), $MachinePrecision] * z + b), $MachinePrecision] / N[(N[(N[(N[(15.234687407 + z), $MachinePrecision] * z + 31.4690115749), $MachinePrecision] * z + 11.9400905721), $MachinePrecision] * z + 0.607771387771), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(N[(N[(N[(N[(457.9610022158428 + t), $MachinePrecision] / N[(z * z), $MachinePrecision]), $MachinePrecision] + 3.13060547623), $MachinePrecision] - N[(36.52704169880642 / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    \mathbf{if}\;x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \leq \infty:\\
    \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\
    
    \mathbf{else}:\\
    \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if (+.f64 x (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64)))) < +inf.0

      1. Initial program 94.0%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites97.4%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]

      if +inf.0 < (+.f64 x (/.f64 (*.f64 y (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 z #s(literal 313060547623/100000000000 binary64)) #s(literal 55833770631/5000000000 binary64)) z) t) z) a) z) b)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 z #s(literal 15234687407/1000000000 binary64)) z) #s(literal 314690115749/10000000000 binary64)) z) #s(literal 119400905721/10000000000 binary64)) z) #s(literal 607771387771/1000000000000 binary64))))

      1. Initial program 0.0%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites0.0%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
      5. Taylor expanded in z around inf

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
      6. Step-by-step derivation
        1. lower--.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
        2. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        3. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        4. div-add-revN/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        5. lower-/.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        6. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\color{blue}{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}}{{z}^{2}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        7. unpow2N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        8. lower-*.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        9. associate-*r/N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} \cdot 1}{z}}, y, x\right) \]
        10. metadata-evalN/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000}}}{z}, y, x\right) \]
        11. lower-/.f6498.9

          \[\leadsto \mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \color{blue}{\frac{36.52704169880642}{z}}, y, x\right) \]
      7. Applied rewrites98.9%

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}}, y, x\right) \]
    3. Recombined 2 regimes into one program.
    4. Add Preprocessing

    Alternative 4: 97.4% accurate, 1.1× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -1.3 \cdot 10^{+22} \lor \neg \left(z \leq 9.5 \cdot 10^{+40}\right):\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\ \end{array} \end{array} \]
    (FPCore (x y z t a b)
     :precision binary64
     (if (or (<= z -1.3e+22) (not (<= z 9.5e+40)))
       (fma
        (-
         (+ (/ (+ 457.9610022158428 t) (* z z)) 3.13060547623)
         (/ 36.52704169880642 z))
        y
        x)
       (fma
        (/
         (fma (fma (fma 11.1667541262 z t) z a) z b)
         (fma
          (fma (fma (+ 15.234687407 z) z 31.4690115749) z 11.9400905721)
          z
          0.607771387771))
        y
        x)))
    double code(double x, double y, double z, double t, double a, double b) {
    	double tmp;
    	if ((z <= -1.3e+22) || !(z <= 9.5e+40)) {
    		tmp = fma(((((457.9610022158428 + t) / (z * z)) + 3.13060547623) - (36.52704169880642 / z)), y, x);
    	} else {
    		tmp = fma((fma(fma(fma(11.1667541262, z, t), z, a), z, b) / fma(fma(fma((15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)), y, x);
    	}
    	return tmp;
    }
    
    function code(x, y, z, t, a, b)
    	tmp = 0.0
    	if ((z <= -1.3e+22) || !(z <= 9.5e+40))
    		tmp = fma(Float64(Float64(Float64(Float64(457.9610022158428 + t) / Float64(z * z)) + 3.13060547623) - Float64(36.52704169880642 / z)), y, x);
    	else
    		tmp = fma(Float64(fma(fma(fma(11.1667541262, z, t), z, a), z, b) / fma(fma(fma(Float64(15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)), y, x);
    	end
    	return tmp
    end
    
    code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -1.3e+22], N[Not[LessEqual[z, 9.5e+40]], $MachinePrecision]], N[(N[(N[(N[(N[(457.9610022158428 + t), $MachinePrecision] / N[(z * z), $MachinePrecision]), $MachinePrecision] + 3.13060547623), $MachinePrecision] - N[(36.52704169880642 / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(N[(N[(N[(N[(11.1667541262 * z + t), $MachinePrecision] * z + a), $MachinePrecision] * z + b), $MachinePrecision] / N[(N[(N[(N[(15.234687407 + z), $MachinePrecision] * z + 31.4690115749), $MachinePrecision] * z + 11.9400905721), $MachinePrecision] * z + 0.607771387771), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    \mathbf{if}\;z \leq -1.3 \cdot 10^{+22} \lor \neg \left(z \leq 9.5 \cdot 10^{+40}\right):\\
    \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\
    
    \mathbf{else}:\\
    \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if z < -1.3e22 or 9.5000000000000003e40 < z

      1. Initial program 14.8%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites18.0%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
      5. Taylor expanded in z around inf

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
      6. Step-by-step derivation
        1. lower--.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
        2. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        3. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        4. div-add-revN/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        5. lower-/.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        6. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\color{blue}{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}}{{z}^{2}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        7. unpow2N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        8. lower-*.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        9. associate-*r/N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} \cdot 1}{z}}, y, x\right) \]
        10. metadata-evalN/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000}}}{z}, y, x\right) \]
        11. lower-/.f6496.0

          \[\leadsto \mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \color{blue}{\frac{36.52704169880642}{z}}, y, x\right) \]
      7. Applied rewrites96.0%

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}}, y, x\right) \]

      if -1.3e22 < z < 9.5000000000000003e40

      1. Initial program 98.4%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites99.7%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
      5. Taylor expanded in z around 0

        \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{t + \frac{55833770631}{5000000000} \cdot z}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
      6. Step-by-step derivation
        1. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{55833770631}{5000000000} \cdot z + t}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
        2. lower-fma.f6499.3

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(11.1667541262, z, t\right)}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right) \]
      7. Applied rewrites99.3%

        \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(11.1667541262, z, t\right)}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right) \]
    3. Recombined 2 regimes into one program.
    4. Final simplification97.8%

      \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -1.3 \cdot 10^{+22} \lor \neg \left(z \leq 9.5 \cdot 10^{+40}\right):\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)\\ \end{array} \]
    5. Add Preprocessing

    Alternative 5: 96.9% accurate, 1.2× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -2.5 \cdot 10^{+21} \lor \neg \left(z \leq 7.5 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;x + \frac{\mathsf{fma}\left(\mathsf{fma}\left(t, z, a\right), z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}\\ \end{array} \end{array} \]
    (FPCore (x y z t a b)
     :precision binary64
     (if (or (<= z -2.5e+21) (not (<= z 7.5e+39)))
       (fma
        (-
         (+ (/ (+ 457.9610022158428 t) (* z z)) 3.13060547623)
         (/ 36.52704169880642 z))
        y
        x)
       (+
        x
        (/
         (* (fma (fma t z a) z b) y)
         (fma
          (fma (fma (+ 15.234687407 z) z 31.4690115749) z 11.9400905721)
          z
          0.607771387771)))))
    double code(double x, double y, double z, double t, double a, double b) {
    	double tmp;
    	if ((z <= -2.5e+21) || !(z <= 7.5e+39)) {
    		tmp = fma(((((457.9610022158428 + t) / (z * z)) + 3.13060547623) - (36.52704169880642 / z)), y, x);
    	} else {
    		tmp = x + ((fma(fma(t, z, a), z, b) * y) / fma(fma(fma((15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771));
    	}
    	return tmp;
    }
    
    function code(x, y, z, t, a, b)
    	tmp = 0.0
    	if ((z <= -2.5e+21) || !(z <= 7.5e+39))
    		tmp = fma(Float64(Float64(Float64(Float64(457.9610022158428 + t) / Float64(z * z)) + 3.13060547623) - Float64(36.52704169880642 / z)), y, x);
    	else
    		tmp = Float64(x + Float64(Float64(fma(fma(t, z, a), z, b) * y) / fma(fma(fma(Float64(15.234687407 + z), z, 31.4690115749), z, 11.9400905721), z, 0.607771387771)));
    	end
    	return tmp
    end
    
    code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -2.5e+21], N[Not[LessEqual[z, 7.5e+39]], $MachinePrecision]], N[(N[(N[(N[(N[(457.9610022158428 + t), $MachinePrecision] / N[(z * z), $MachinePrecision]), $MachinePrecision] + 3.13060547623), $MachinePrecision] - N[(36.52704169880642 / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(x + N[(N[(N[(N[(t * z + a), $MachinePrecision] * z + b), $MachinePrecision] * y), $MachinePrecision] / N[(N[(N[(N[(15.234687407 + z), $MachinePrecision] * z + 31.4690115749), $MachinePrecision] * z + 11.9400905721), $MachinePrecision] * z + 0.607771387771), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    \mathbf{if}\;z \leq -2.5 \cdot 10^{+21} \lor \neg \left(z \leq 7.5 \cdot 10^{+39}\right):\\
    \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\
    
    \mathbf{else}:\\
    \;\;\;\;x + \frac{\mathsf{fma}\left(\mathsf{fma}\left(t, z, a\right), z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if z < -2.5e21 or 7.5000000000000005e39 < z

      1. Initial program 14.8%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites18.0%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
      5. Taylor expanded in z around inf

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
      6. Step-by-step derivation
        1. lower--.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
        2. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        3. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        4. div-add-revN/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        5. lower-/.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        6. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\color{blue}{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}}{{z}^{2}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        7. unpow2N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        8. lower-*.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        9. associate-*r/N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} \cdot 1}{z}}, y, x\right) \]
        10. metadata-evalN/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000}}}{z}, y, x\right) \]
        11. lower-/.f6496.0

          \[\leadsto \mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \color{blue}{\frac{36.52704169880642}{z}}, y, x\right) \]
      7. Applied rewrites96.0%

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}}, y, x\right) \]

      if -2.5e21 < z < 7.5000000000000005e39

      1. Initial program 98.4%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Taylor expanded in z around 0

        \[\leadsto x + \frac{y \cdot \color{blue}{\left(b + a \cdot z\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
      4. Step-by-step derivation
        1. +-commutativeN/A

          \[\leadsto x + \frac{y \cdot \color{blue}{\left(a \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
        2. lower-fma.f6490.2

          \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      5. Applied rewrites90.2%

        \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      6. Step-by-step derivation
        1. lift-*.f64N/A

          \[\leadsto x + \frac{\color{blue}{y \cdot \mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
        2. *-commutativeN/A

          \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
        3. lower-*.f6490.2

          \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
        4. lift-+.f64N/A

          \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        5. lift-*.f64N/A

          \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z} + \frac{607771387771}{1000000000000}} \]
        6. lower-fma.f6490.2

          \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\mathsf{fma}\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721, z, 0.607771387771\right)}} \]
      7. Applied rewrites90.2%

        \[\leadsto x + \color{blue}{\frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}} \]
      8. Taylor expanded in z around 0

        \[\leadsto x + \frac{\color{blue}{\left(b + z \cdot \left(a + t \cdot z\right)\right)} \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} \]
      9. Step-by-step derivation
        1. +-commutativeN/A

          \[\leadsto x + \frac{\color{blue}{\left(z \cdot \left(a + t \cdot z\right) + b\right)} \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} \]
        2. *-commutativeN/A

          \[\leadsto x + \frac{\left(\color{blue}{\left(a + t \cdot z\right) \cdot z} + b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} \]
        3. lower-fma.f64N/A

          \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a + t \cdot z, z, b\right)} \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} \]
        4. +-commutativeN/A

          \[\leadsto x + \frac{\mathsf{fma}\left(\color{blue}{t \cdot z + a}, z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} \]
        5. lower-fma.f6497.0

          \[\leadsto x + \frac{\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(t, z, a\right)}, z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)} \]
      10. Applied rewrites97.0%

        \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(t, z, a\right), z, b\right)} \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)} \]
    3. Recombined 2 regimes into one program.
    4. Final simplification96.5%

      \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -2.5 \cdot 10^{+21} \lor \neg \left(z \leq 7.5 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;x + \frac{\mathsf{fma}\left(\mathsf{fma}\left(t, z, a\right), z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}\\ \end{array} \]
    5. Add Preprocessing

    Alternative 6: 96.4% accurate, 1.4× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -13 \lor \neg \left(z \leq 0.00038\right):\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}, y, x\right)\\ \end{array} \end{array} \]
    (FPCore (x y z t a b)
     :precision binary64
     (if (or (<= z -13.0) (not (<= z 0.00038)))
       (fma
        (-
         (+ (/ (+ 457.9610022158428 t) (* z z)) 3.13060547623)
         (/ 36.52704169880642 z))
        y
        x)
       (fma
        (/
         (fma (fma (fma 11.1667541262 z t) z a) z b)
         (fma 11.9400905721 z 0.607771387771))
        y
        x)))
    double code(double x, double y, double z, double t, double a, double b) {
    	double tmp;
    	if ((z <= -13.0) || !(z <= 0.00038)) {
    		tmp = fma(((((457.9610022158428 + t) / (z * z)) + 3.13060547623) - (36.52704169880642 / z)), y, x);
    	} else {
    		tmp = fma((fma(fma(fma(11.1667541262, z, t), z, a), z, b) / fma(11.9400905721, z, 0.607771387771)), y, x);
    	}
    	return tmp;
    }
    
    function code(x, y, z, t, a, b)
    	tmp = 0.0
    	if ((z <= -13.0) || !(z <= 0.00038))
    		tmp = fma(Float64(Float64(Float64(Float64(457.9610022158428 + t) / Float64(z * z)) + 3.13060547623) - Float64(36.52704169880642 / z)), y, x);
    	else
    		tmp = fma(Float64(fma(fma(fma(11.1667541262, z, t), z, a), z, b) / fma(11.9400905721, z, 0.607771387771)), y, x);
    	end
    	return tmp
    end
    
    code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -13.0], N[Not[LessEqual[z, 0.00038]], $MachinePrecision]], N[(N[(N[(N[(N[(457.9610022158428 + t), $MachinePrecision] / N[(z * z), $MachinePrecision]), $MachinePrecision] + 3.13060547623), $MachinePrecision] - N[(36.52704169880642 / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(N[(N[(N[(N[(11.1667541262 * z + t), $MachinePrecision] * z + a), $MachinePrecision] * z + b), $MachinePrecision] / N[(11.9400905721 * z + 0.607771387771), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    \mathbf{if}\;z \leq -13 \lor \neg \left(z \leq 0.00038\right):\\
    \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\
    
    \mathbf{else}:\\
    \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}, y, x\right)\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if z < -13 or 3.8000000000000002e-4 < z

      1. Initial program 23.1%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites27.3%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
      5. Taylor expanded in z around inf

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
      6. Step-by-step derivation
        1. lower--.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{313060547623}{100000000000} + \left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right)\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}}, y, x\right) \]
        2. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        3. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000}}{{z}^{2}} + \frac{t}{{z}^{2}}\right) + \frac{313060547623}{100000000000}\right)} - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        4. div-add-revN/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        5. lower-/.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{{z}^{2}}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        6. lower-+.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\color{blue}{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}}{{z}^{2}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        7. unpow2N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        8. lower-*.f64N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{\color{blue}{z \cdot z}} + \frac{313060547623}{100000000000}\right) - \frac{3652704169880641883561}{100000000000000000000} \cdot \frac{1}{z}, y, x\right) \]
        9. associate-*r/N/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} \cdot 1}{z}}, y, x\right) \]
        10. metadata-evalN/A

          \[\leadsto \mathsf{fma}\left(\left(\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z \cdot z} + \frac{313060547623}{100000000000}\right) - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000}}}{z}, y, x\right) \]
        11. lower-/.f6491.0

          \[\leadsto \mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \color{blue}{\frac{36.52704169880642}{z}}, y, x\right) \]
      7. Applied rewrites91.0%

        \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}}, y, x\right) \]

      if -13 < z < 3.8000000000000002e-4

      1. Initial program 99.7%

        \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-+.f64N/A

          \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
        2. +-commutativeN/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
        3. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        4. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
        5. associate-/l*N/A

          \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
        6. *-commutativeN/A

          \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
      4. Applied rewrites99.7%

        \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
      5. Taylor expanded in z around 0

        \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{t + \frac{55833770631}{5000000000} \cdot z}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
      6. Step-by-step derivation
        1. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{55833770631}{5000000000} \cdot z + t}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
        2. lower-fma.f6499.3

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(11.1667541262, z, t\right)}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right) \]
      7. Applied rewrites99.3%

        \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(11.1667541262, z, t\right)}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right) \]
      8. Taylor expanded in z around 0

        \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{55833770631}{5000000000}, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\color{blue}{\frac{119400905721}{10000000000}}, z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
      9. Step-by-step derivation
        1. Applied rewrites99.3%

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\color{blue}{11.9400905721}, z, 0.607771387771\right)}, y, x\right) \]
      10. Recombined 2 regimes into one program.
      11. Final simplification95.0%

        \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -13 \lor \neg \left(z \leq 0.00038\right):\\ \;\;\;\;\mathsf{fma}\left(\left(\frac{457.9610022158428 + t}{z \cdot z} + 3.13060547623\right) - \frac{36.52704169880642}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}, y, x\right)\\ \end{array} \]
      12. Add Preprocessing

      Alternative 7: 96.4% accurate, 1.5× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -13 \lor \neg \left(z \leq 0.00038\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}, y, x\right)\\ \end{array} \end{array} \]
      (FPCore (x y z t a b)
       :precision binary64
       (if (or (<= z -13.0) (not (<= z 0.00038)))
         (fma
          (- 3.13060547623 (/ (- 36.52704169880642 (/ (+ 457.9610022158428 t) z)) z))
          y
          x)
         (fma
          (/
           (fma (fma (fma 11.1667541262 z t) z a) z b)
           (fma 11.9400905721 z 0.607771387771))
          y
          x)))
      double code(double x, double y, double z, double t, double a, double b) {
      	double tmp;
      	if ((z <= -13.0) || !(z <= 0.00038)) {
      		tmp = fma((3.13060547623 - ((36.52704169880642 - ((457.9610022158428 + t) / z)) / z)), y, x);
      	} else {
      		tmp = fma((fma(fma(fma(11.1667541262, z, t), z, a), z, b) / fma(11.9400905721, z, 0.607771387771)), y, x);
      	}
      	return tmp;
      }
      
      function code(x, y, z, t, a, b)
      	tmp = 0.0
      	if ((z <= -13.0) || !(z <= 0.00038))
      		tmp = fma(Float64(3.13060547623 - Float64(Float64(36.52704169880642 - Float64(Float64(457.9610022158428 + t) / z)) / z)), y, x);
      	else
      		tmp = fma(Float64(fma(fma(fma(11.1667541262, z, t), z, a), z, b) / fma(11.9400905721, z, 0.607771387771)), y, x);
      	end
      	return tmp
      end
      
      code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -13.0], N[Not[LessEqual[z, 0.00038]], $MachinePrecision]], N[(N[(3.13060547623 - N[(N[(36.52704169880642 - N[(N[(457.9610022158428 + t), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(N[(N[(N[(N[(11.1667541262 * z + t), $MachinePrecision] * z + a), $MachinePrecision] * z + b), $MachinePrecision] / N[(11.9400905721 * z + 0.607771387771), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      \mathbf{if}\;z \leq -13 \lor \neg \left(z \leq 0.00038\right):\\
      \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}, y, x\right)\\
      
      \mathbf{else}:\\
      \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}, y, x\right)\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if z < -13 or 3.8000000000000002e-4 < z

        1. Initial program 23.1%

          \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. lift-+.f64N/A

            \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
          2. +-commutativeN/A

            \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
          3. lift-/.f64N/A

            \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
          4. lift-*.f64N/A

            \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
          5. associate-/l*N/A

            \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
          6. *-commutativeN/A

            \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
          7. lower-fma.f64N/A

            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
        4. Applied rewrites27.3%

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
        5. Taylor expanded in z around 0

          \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b + z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right)}, y, x\right) \]
        6. Step-by-step derivation
          1. +-commutativeN/A

            \[\leadsto \mathsf{fma}\left(\color{blue}{z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) + \frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
          2. *-commutativeN/A

            \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) \cdot z} + \frac{1000000000000}{607771387771} \cdot b, y, x\right) \]
          3. lower-fma.f64N/A

            \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b, z, \frac{1000000000000}{607771387771} \cdot b\right)}, y, x\right) \]
          4. fp-cancel-sub-sign-invN/A

            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot a + \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
          5. lower-fma.f64N/A

            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b\right)}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
          6. metadata-evalN/A

            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441}} \cdot b\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
          7. lower-*.f64N/A

            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441} \cdot b}\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
          8. lower-*.f6422.0

            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, \color{blue}{1.6453555072203998 \cdot b}\right), y, x\right) \]
        7. Applied rewrites22.0%

          \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, 1.6453555072203998 \cdot b\right)}, y, x\right) \]
        8. Taylor expanded in z around -inf

          \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} + -1 \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
        9. Step-by-step derivation
          1. fp-cancel-sign-sub-invN/A

            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} - \left(\mathsf{neg}\left(-1\right)\right) \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
          2. metadata-evalN/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \color{blue}{1} \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}, y, x\right) \]
          3. *-lft-identityN/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
          4. lower--.f64N/A

            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
          5. lower-/.f64N/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
          6. fp-cancel-sign-sub-invN/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000} - \left(\mathsf{neg}\left(-1\right)\right) \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
          7. metadata-evalN/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} - \color{blue}{1} \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}, y, x\right) \]
          8. *-lft-identityN/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} - \color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
          9. lower--.f64N/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000} - \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
          10. lower-/.f64N/A

            \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} - \color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
          11. lower-+.f6491.0

            \[\leadsto \mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{\color{blue}{457.9610022158428 + t}}{z}}{z}, y, x\right) \]
        10. Applied rewrites91.0%

          \[\leadsto \mathsf{fma}\left(\color{blue}{3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}}, y, x\right) \]

        if -13 < z < 3.8000000000000002e-4

        1. Initial program 99.7%

          \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. lift-+.f64N/A

            \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
          2. +-commutativeN/A

            \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
          3. lift-/.f64N/A

            \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
          4. lift-*.f64N/A

            \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
          5. associate-/l*N/A

            \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
          6. *-commutativeN/A

            \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
          7. lower-fma.f64N/A

            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
        4. Applied rewrites99.7%

          \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
        5. Taylor expanded in z around 0

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{t + \frac{55833770631}{5000000000} \cdot z}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
        6. Step-by-step derivation
          1. +-commutativeN/A

            \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{55833770631}{5000000000} \cdot z + t}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{15234687407}{1000000000} + z, z, \frac{314690115749}{10000000000}\right), z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
          2. lower-fma.f6499.3

            \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(11.1667541262, z, t\right)}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right) \]
        7. Applied rewrites99.3%

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(11.1667541262, z, t\right)}, z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right) \]
        8. Taylor expanded in z around 0

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{55833770631}{5000000000}, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\color{blue}{\frac{119400905721}{10000000000}}, z, \frac{607771387771}{1000000000000}\right)}, y, x\right) \]
        9. Step-by-step derivation
          1. Applied rewrites99.3%

            \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\color{blue}{11.9400905721}, z, 0.607771387771\right)}, y, x\right) \]
        10. Recombined 2 regimes into one program.
        11. Final simplification95.0%

          \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -13 \lor \neg \left(z \leq 0.00038\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(11.1667541262, z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}, y, x\right)\\ \end{array} \]
        12. Add Preprocessing

        Alternative 8: 93.3% accurate, 1.6× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -2900000 \lor \neg \left(z \leq 6.2 \cdot 10^{-15}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(b, 1.6453555072203998, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right)\\ \end{array} \end{array} \]
        (FPCore (x y z t a b)
         :precision binary64
         (if (or (<= z -2900000.0) (not (<= z 6.2e-15)))
           (fma
            (- 3.13060547623 (/ (- 36.52704169880642 (/ (+ 457.9610022158428 t) z)) z))
            y
            x)
           (fma
            (fma
             b
             1.6453555072203998
             (* (fma 1.6453555072203998 a (* -32.324150453290734 b)) z))
            y
            x)))
        double code(double x, double y, double z, double t, double a, double b) {
        	double tmp;
        	if ((z <= -2900000.0) || !(z <= 6.2e-15)) {
        		tmp = fma((3.13060547623 - ((36.52704169880642 - ((457.9610022158428 + t) / z)) / z)), y, x);
        	} else {
        		tmp = fma(fma(b, 1.6453555072203998, (fma(1.6453555072203998, a, (-32.324150453290734 * b)) * z)), y, x);
        	}
        	return tmp;
        }
        
        function code(x, y, z, t, a, b)
        	tmp = 0.0
        	if ((z <= -2900000.0) || !(z <= 6.2e-15))
        		tmp = fma(Float64(3.13060547623 - Float64(Float64(36.52704169880642 - Float64(Float64(457.9610022158428 + t) / z)) / z)), y, x);
        	else
        		tmp = fma(fma(b, 1.6453555072203998, Float64(fma(1.6453555072203998, a, Float64(-32.324150453290734 * b)) * z)), y, x);
        	end
        	return tmp
        end
        
        code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -2900000.0], N[Not[LessEqual[z, 6.2e-15]], $MachinePrecision]], N[(N[(3.13060547623 - N[(N[(36.52704169880642 - N[(N[(457.9610022158428 + t), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision], N[(N[(b * 1.6453555072203998 + N[(N[(1.6453555072203998 * a + N[(-32.324150453290734 * b), $MachinePrecision]), $MachinePrecision] * z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        \mathbf{if}\;z \leq -2900000 \lor \neg \left(z \leq 6.2 \cdot 10^{-15}\right):\\
        \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}, y, x\right)\\
        
        \mathbf{else}:\\
        \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(b, 1.6453555072203998, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right)\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 2 regimes
        2. if z < -2.9e6 or 6.1999999999999998e-15 < z

          1. Initial program 23.7%

            \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
          2. Add Preprocessing
          3. Step-by-step derivation
            1. lift-+.f64N/A

              \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
            2. +-commutativeN/A

              \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
            3. lift-/.f64N/A

              \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
            4. lift-*.f64N/A

              \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
            5. associate-/l*N/A

              \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
            6. *-commutativeN/A

              \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
            7. lower-fma.f64N/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
          4. Applied rewrites27.8%

            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
          5. Taylor expanded in z around 0

            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b + z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right)}, y, x\right) \]
          6. Step-by-step derivation
            1. +-commutativeN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) + \frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
            2. *-commutativeN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) \cdot z} + \frac{1000000000000}{607771387771} \cdot b, y, x\right) \]
            3. lower-fma.f64N/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b, z, \frac{1000000000000}{607771387771} \cdot b\right)}, y, x\right) \]
            4. fp-cancel-sub-sign-invN/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot a + \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            5. lower-fma.f64N/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b\right)}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            6. metadata-evalN/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441}} \cdot b\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            7. lower-*.f64N/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441} \cdot b}\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            8. lower-*.f6421.9

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, \color{blue}{1.6453555072203998 \cdot b}\right), y, x\right) \]
          7. Applied rewrites21.9%

            \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, 1.6453555072203998 \cdot b\right)}, y, x\right) \]
          8. Taylor expanded in z around -inf

            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} + -1 \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
          9. Step-by-step derivation
            1. fp-cancel-sign-sub-invN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} - \left(\mathsf{neg}\left(-1\right)\right) \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
            2. metadata-evalN/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \color{blue}{1} \cdot \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}, y, x\right) \]
            3. *-lft-identityN/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
            4. lower--.f64N/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
            5. lower-/.f64N/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \color{blue}{\frac{\frac{3652704169880641883561}{100000000000000000000} + -1 \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}}, y, x\right) \]
            6. fp-cancel-sign-sub-invN/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000} - \left(\mathsf{neg}\left(-1\right)\right) \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
            7. metadata-evalN/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} - \color{blue}{1} \cdot \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}{z}, y, x\right) \]
            8. *-lft-identityN/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} - \color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
            9. lower--.f64N/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\color{blue}{\frac{3652704169880641883561}{100000000000000000000} - \frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
            10. lower-/.f64N/A

              \[\leadsto \mathsf{fma}\left(\frac{313060547623}{100000000000} - \frac{\frac{3652704169880641883561}{100000000000000000000} - \color{blue}{\frac{\frac{45796100221584283915100827016327}{100000000000000000000000000000} + t}{z}}}{z}, y, x\right) \]
            11. lower-+.f6491.1

              \[\leadsto \mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{\color{blue}{457.9610022158428 + t}}{z}}{z}, y, x\right) \]
          10. Applied rewrites91.1%

            \[\leadsto \mathsf{fma}\left(\color{blue}{3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}}, y, x\right) \]

          if -2.9e6 < z < 6.1999999999999998e-15

          1. Initial program 99.7%

            \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
          2. Add Preprocessing
          3. Step-by-step derivation
            1. lift-+.f64N/A

              \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
            2. +-commutativeN/A

              \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
            3. lift-/.f64N/A

              \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
            4. lift-*.f64N/A

              \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
            5. associate-/l*N/A

              \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
            6. *-commutativeN/A

              \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
            7. lower-fma.f64N/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
          4. Applied rewrites99.7%

            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
          5. Taylor expanded in z around 0

            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b + z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right)}, y, x\right) \]
          6. Step-by-step derivation
            1. +-commutativeN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) + \frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
            2. *-commutativeN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) \cdot z} + \frac{1000000000000}{607771387771} \cdot b, y, x\right) \]
            3. lower-fma.f64N/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b, z, \frac{1000000000000}{607771387771} \cdot b\right)}, y, x\right) \]
            4. fp-cancel-sub-sign-invN/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot a + \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            5. lower-fma.f64N/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b\right)}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            6. metadata-evalN/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441}} \cdot b\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            7. lower-*.f64N/A

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441} \cdot b}\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
            8. lower-*.f6494.4

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, \color{blue}{1.6453555072203998 \cdot b}\right), y, x\right) \]
          7. Applied rewrites94.4%

            \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, 1.6453555072203998 \cdot b\right)}, y, x\right) \]
          8. Step-by-step derivation
            1. Applied rewrites94.4%

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(b, \color{blue}{1.6453555072203998}, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right) \]
          9. Recombined 2 regimes into one program.
          10. Final simplification92.7%

            \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -2900000 \lor \neg \left(z \leq 6.2 \cdot 10^{-15}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623 - \frac{36.52704169880642 - \frac{457.9610022158428 + t}{z}}{z}, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(b, 1.6453555072203998, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right)\\ \end{array} \]
          11. Add Preprocessing

          Alternative 9: 90.6% accurate, 1.6× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -5.2 \cdot 10^{+20} \lor \neg \left(z \leq 2.2 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}, x\right)\\ \end{array} \end{array} \]
          (FPCore (x y z t a b)
           :precision binary64
           (if (or (<= z -5.2e+20) (not (<= z 2.2e+39)))
             (fma 3.13060547623 y x)
             (fma
              (fma a z b)
              (/ y (fma (fma 31.4690115749 z 11.9400905721) z 0.607771387771))
              x)))
          double code(double x, double y, double z, double t, double a, double b) {
          	double tmp;
          	if ((z <= -5.2e+20) || !(z <= 2.2e+39)) {
          		tmp = fma(3.13060547623, y, x);
          	} else {
          		tmp = fma(fma(a, z, b), (y / fma(fma(31.4690115749, z, 11.9400905721), z, 0.607771387771)), x);
          	}
          	return tmp;
          }
          
          function code(x, y, z, t, a, b)
          	tmp = 0.0
          	if ((z <= -5.2e+20) || !(z <= 2.2e+39))
          		tmp = fma(3.13060547623, y, x);
          	else
          		tmp = fma(fma(a, z, b), Float64(y / fma(fma(31.4690115749, z, 11.9400905721), z, 0.607771387771)), x);
          	end
          	return tmp
          end
          
          code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -5.2e+20], N[Not[LessEqual[z, 2.2e+39]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(a * z + b), $MachinePrecision] * N[(y / N[(N[(31.4690115749 * z + 11.9400905721), $MachinePrecision] * z + 0.607771387771), $MachinePrecision]), $MachinePrecision] + x), $MachinePrecision]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          \mathbf{if}\;z \leq -5.2 \cdot 10^{+20} \lor \neg \left(z \leq 2.2 \cdot 10^{+39}\right):\\
          \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}, x\right)\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if z < -5.2e20 or 2.2000000000000001e39 < z

            1. Initial program 15.5%

              \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            2. Add Preprocessing
            3. Taylor expanded in z around inf

              \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
            4. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
              2. lower-fma.f6488.6

                \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
            5. Applied rewrites88.6%

              \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

            if -5.2e20 < z < 2.2000000000000001e39

            1. Initial program 98.4%

              \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            2. Add Preprocessing
            3. Taylor expanded in z around 0

              \[\leadsto x + \frac{y \cdot \color{blue}{\left(b + a \cdot z\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
            4. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto x + \frac{y \cdot \color{blue}{\left(a \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
              2. lower-fma.f6490.7

                \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            5. Applied rewrites90.7%

              \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            6. Taylor expanded in z around 0

              \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\frac{607771387771}{1000000000000} + z \cdot \left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z\right)}} \]
            7. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{z \cdot \left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z\right) + \frac{607771387771}{1000000000000}}} \]
              2. *-commutativeN/A

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z\right) \cdot z} + \frac{607771387771}{1000000000000}} \]
              3. lower-fma.f64N/A

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\mathsf{fma}\left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z, z, \frac{607771387771}{1000000000000}\right)}} \]
              4. +-commutativeN/A

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\color{blue}{\frac{314690115749}{10000000000} \cdot z + \frac{119400905721}{10000000000}}, z, \frac{607771387771}{1000000000000}\right)} \]
              5. lower-fma.f6488.6

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right)}, z, 0.607771387771\right)} \]
            8. Applied rewrites88.6%

              \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}} \]
            9. Step-by-step derivation
              1. lift-+.f64N/A

                \[\leadsto \color{blue}{x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}} \]
              2. +-commutativeN/A

                \[\leadsto \color{blue}{\frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} + x} \]
              3. lift-/.f64N/A

                \[\leadsto \color{blue}{\frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}} + x \]
              4. lift-*.f64N/A

                \[\leadsto \frac{\color{blue}{y \cdot \mathsf{fma}\left(a, z, b\right)}}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} + x \]
              5. *-commutativeN/A

                \[\leadsto \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} + x \]
              6. associate-/l*N/A

                \[\leadsto \color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}} + x \]
            10. Applied rewrites88.6%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}, x\right)} \]
          3. Recombined 2 regimes into one program.
          4. Final simplification88.6%

            \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -5.2 \cdot 10^{+20} \lor \neg \left(z \leq 2.2 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}, x\right)\\ \end{array} \]
          5. Add Preprocessing

          Alternative 10: 90.4% accurate, 1.8× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -1.2 \cdot 10^{+15} \lor \neg \left(z \leq 2.2 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}\\ \end{array} \end{array} \]
          (FPCore (x y z t a b)
           :precision binary64
           (if (or (<= z -1.2e+15) (not (<= z 2.2e+39)))
             (fma 3.13060547623 y x)
             (+ x (/ (* y (fma a z b)) (fma 11.9400905721 z 0.607771387771)))))
          double code(double x, double y, double z, double t, double a, double b) {
          	double tmp;
          	if ((z <= -1.2e+15) || !(z <= 2.2e+39)) {
          		tmp = fma(3.13060547623, y, x);
          	} else {
          		tmp = x + ((y * fma(a, z, b)) / fma(11.9400905721, z, 0.607771387771));
          	}
          	return tmp;
          }
          
          function code(x, y, z, t, a, b)
          	tmp = 0.0
          	if ((z <= -1.2e+15) || !(z <= 2.2e+39))
          		tmp = fma(3.13060547623, y, x);
          	else
          		tmp = Float64(x + Float64(Float64(y * fma(a, z, b)) / fma(11.9400905721, z, 0.607771387771)));
          	end
          	return tmp
          end
          
          code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -1.2e+15], N[Not[LessEqual[z, 2.2e+39]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(x + N[(N[(y * N[(a * z + b), $MachinePrecision]), $MachinePrecision] / N[(11.9400905721 * z + 0.607771387771), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          \mathbf{if}\;z \leq -1.2 \cdot 10^{+15} \lor \neg \left(z \leq 2.2 \cdot 10^{+39}\right):\\
          \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if z < -1.2e15 or 2.2000000000000001e39 < z

            1. Initial program 16.9%

              \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            2. Add Preprocessing
            3. Taylor expanded in z around inf

              \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
            4. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
              2. lower-fma.f6487.2

                \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
            5. Applied rewrites87.2%

              \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

            if -1.2e15 < z < 2.2000000000000001e39

            1. Initial program 98.4%

              \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            2. Add Preprocessing
            3. Taylor expanded in z around 0

              \[\leadsto x + \frac{y \cdot \color{blue}{\left(b + a \cdot z\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
            4. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto x + \frac{y \cdot \color{blue}{\left(a \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
              2. lower-fma.f6490.6

                \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            5. Applied rewrites90.6%

              \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            6. Taylor expanded in z around 0

              \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\frac{607771387771}{1000000000000} + \frac{119400905721}{10000000000} \cdot z}} \]
            7. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\frac{119400905721}{10000000000} \cdot z + \frac{607771387771}{1000000000000}}} \]
              2. lower-fma.f6489.5

                \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}} \]
            8. Applied rewrites89.5%

              \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}} \]
          3. Recombined 2 regimes into one program.
          4. Final simplification88.4%

            \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -1.2 \cdot 10^{+15} \lor \neg \left(z \leq 2.2 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(11.9400905721, z, 0.607771387771\right)}\\ \end{array} \]
          5. Add Preprocessing

          Alternative 11: 90.2% accurate, 1.9× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 6.2 \cdot 10^{-15}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(b, 1.6453555072203998, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right)\\ \end{array} \end{array} \]
          (FPCore (x y z t a b)
           :precision binary64
           (if (or (<= z -33000000000.0) (not (<= z 6.2e-15)))
             (fma 3.13060547623 y x)
             (fma
              (fma
               b
               1.6453555072203998
               (* (fma 1.6453555072203998 a (* -32.324150453290734 b)) z))
              y
              x)))
          double code(double x, double y, double z, double t, double a, double b) {
          	double tmp;
          	if ((z <= -33000000000.0) || !(z <= 6.2e-15)) {
          		tmp = fma(3.13060547623, y, x);
          	} else {
          		tmp = fma(fma(b, 1.6453555072203998, (fma(1.6453555072203998, a, (-32.324150453290734 * b)) * z)), y, x);
          	}
          	return tmp;
          }
          
          function code(x, y, z, t, a, b)
          	tmp = 0.0
          	if ((z <= -33000000000.0) || !(z <= 6.2e-15))
          		tmp = fma(3.13060547623, y, x);
          	else
          		tmp = fma(fma(b, 1.6453555072203998, Float64(fma(1.6453555072203998, a, Float64(-32.324150453290734 * b)) * z)), y, x);
          	end
          	return tmp
          end
          
          code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -33000000000.0], N[Not[LessEqual[z, 6.2e-15]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(b * 1.6453555072203998 + N[(N[(1.6453555072203998 * a + N[(-32.324150453290734 * b), $MachinePrecision]), $MachinePrecision] * z), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 6.2 \cdot 10^{-15}\right):\\
          \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(b, 1.6453555072203998, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right)\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if z < -3.3e10 or 6.1999999999999998e-15 < z

            1. Initial program 23.7%

              \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            2. Add Preprocessing
            3. Taylor expanded in z around inf

              \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
            4. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
              2. lower-fma.f6482.8

                \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
            5. Applied rewrites82.8%

              \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

            if -3.3e10 < z < 6.1999999999999998e-15

            1. Initial program 99.7%

              \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
            2. Add Preprocessing
            3. Step-by-step derivation
              1. lift-+.f64N/A

                \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
              2. +-commutativeN/A

                \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
              3. lift-/.f64N/A

                \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
              4. lift-*.f64N/A

                \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
              5. associate-/l*N/A

                \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
              6. *-commutativeN/A

                \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
              7. lower-fma.f64N/A

                \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
            4. Applied rewrites99.7%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
            5. Taylor expanded in z around 0

              \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b + z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right)}, y, x\right) \]
            6. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \mathsf{fma}\left(\color{blue}{z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) + \frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
              2. *-commutativeN/A

                \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) \cdot z} + \frac{1000000000000}{607771387771} \cdot b, y, x\right) \]
              3. lower-fma.f64N/A

                \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b, z, \frac{1000000000000}{607771387771} \cdot b\right)}, y, x\right) \]
              4. fp-cancel-sub-sign-invN/A

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot a + \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
              5. lower-fma.f64N/A

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b\right)}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
              6. metadata-evalN/A

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441}} \cdot b\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
              7. lower-*.f64N/A

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441} \cdot b}\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
              8. lower-*.f6494.4

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, \color{blue}{1.6453555072203998 \cdot b}\right), y, x\right) \]
            7. Applied rewrites94.4%

              \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, 1.6453555072203998 \cdot b\right)}, y, x\right) \]
            8. Step-by-step derivation
              1. Applied rewrites94.4%

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(b, \color{blue}{1.6453555072203998}, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right) \]
            9. Recombined 2 regimes into one program.
            10. Final simplification88.4%

              \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 6.2 \cdot 10^{-15}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(b, 1.6453555072203998, \mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right) \cdot z\right), y, x\right)\\ \end{array} \]
            11. Add Preprocessing

            Alternative 12: 90.3% accurate, 2.3× speedup?

            \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 1.9 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998 \cdot a, z, 1.6453555072203998 \cdot b\right), y, x\right)\\ \end{array} \end{array} \]
            (FPCore (x y z t a b)
             :precision binary64
             (if (or (<= z -33000000000.0) (not (<= z 1.9e+39)))
               (fma 3.13060547623 y x)
               (fma (fma (* 1.6453555072203998 a) z (* 1.6453555072203998 b)) y x)))
            double code(double x, double y, double z, double t, double a, double b) {
            	double tmp;
            	if ((z <= -33000000000.0) || !(z <= 1.9e+39)) {
            		tmp = fma(3.13060547623, y, x);
            	} else {
            		tmp = fma(fma((1.6453555072203998 * a), z, (1.6453555072203998 * b)), y, x);
            	}
            	return tmp;
            }
            
            function code(x, y, z, t, a, b)
            	tmp = 0.0
            	if ((z <= -33000000000.0) || !(z <= 1.9e+39))
            		tmp = fma(3.13060547623, y, x);
            	else
            		tmp = fma(fma(Float64(1.6453555072203998 * a), z, Float64(1.6453555072203998 * b)), y, x);
            	end
            	return tmp
            end
            
            code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -33000000000.0], N[Not[LessEqual[z, 1.9e+39]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(N[(1.6453555072203998 * a), $MachinePrecision] * z + N[(1.6453555072203998 * b), $MachinePrecision]), $MachinePrecision] * y + x), $MachinePrecision]]
            
            \begin{array}{l}
            
            \\
            \begin{array}{l}
            \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 1.9 \cdot 10^{+39}\right):\\
            \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
            
            \mathbf{else}:\\
            \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998 \cdot a, z, 1.6453555072203998 \cdot b\right), y, x\right)\\
            
            
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 2 regimes
            2. if z < -3.3e10 or 1.8999999999999999e39 < z

              1. Initial program 17.6%

                \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
              2. Add Preprocessing
              3. Taylor expanded in z around inf

                \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
              4. Step-by-step derivation
                1. +-commutativeN/A

                  \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                2. lower-fma.f6486.5

                  \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
              5. Applied rewrites86.5%

                \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

              if -3.3e10 < z < 1.8999999999999999e39

              1. Initial program 98.4%

                \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
              2. Add Preprocessing
              3. Step-by-step derivation
                1. lift-+.f64N/A

                  \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
                2. +-commutativeN/A

                  \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
                3. lift-/.f64N/A

                  \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
                4. lift-*.f64N/A

                  \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
                5. associate-/l*N/A

                  \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
                6. *-commutativeN/A

                  \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
                7. lower-fma.f64N/A

                  \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
              4. Applied rewrites99.7%

                \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
              5. Taylor expanded in z around 0

                \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b + z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right)}, y, x\right) \]
              6. Step-by-step derivation
                1. +-commutativeN/A

                  \[\leadsto \mathsf{fma}\left(\color{blue}{z \cdot \left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) + \frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
                2. *-commutativeN/A

                  \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b\right) \cdot z} + \frac{1000000000000}{607771387771} \cdot b, y, x\right) \]
                3. lower-fma.f64N/A

                  \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a - \frac{11940090572100000000000000}{369386059793087248348441} \cdot b, z, \frac{1000000000000}{607771387771} \cdot b\right)}, y, x\right) \]
                4. fp-cancel-sub-sign-invN/A

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot a + \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
                5. lower-fma.f64N/A

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \left(\mathsf{neg}\left(\frac{11940090572100000000000000}{369386059793087248348441}\right)\right) \cdot b\right)}, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
                6. metadata-evalN/A

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441}} \cdot b\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
                7. lower-*.f64N/A

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771}, a, \color{blue}{\frac{-11940090572100000000000000}{369386059793087248348441} \cdot b}\right), z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
                8. lower-*.f6489.2

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, \color{blue}{1.6453555072203998 \cdot b}\right), y, x\right) \]
              7. Applied rewrites89.2%

                \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998, a, -32.324150453290734 \cdot b\right), z, 1.6453555072203998 \cdot b\right)}, y, x\right) \]
              8. Taylor expanded in a around inf

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{1000000000000}{607771387771} \cdot a, z, \frac{1000000000000}{607771387771} \cdot b\right), y, x\right) \]
              9. Step-by-step derivation
                1. Applied rewrites89.5%

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998 \cdot a, z, 1.6453555072203998 \cdot b\right), y, x\right) \]
              10. Recombined 2 regimes into one program.
              11. Final simplification88.1%

                \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 1.9 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(1.6453555072203998 \cdot a, z, 1.6453555072203998 \cdot b\right), y, x\right)\\ \end{array} \]
              12. Add Preprocessing

              Alternative 13: 90.3% accurate, 2.6× speedup?

              \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 1.9 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), 1.6453555072203998 \cdot y, x\right)\\ \end{array} \end{array} \]
              (FPCore (x y z t a b)
               :precision binary64
               (if (or (<= z -33000000000.0) (not (<= z 1.9e+39)))
                 (fma 3.13060547623 y x)
                 (fma (fma a z b) (* 1.6453555072203998 y) x)))
              double code(double x, double y, double z, double t, double a, double b) {
              	double tmp;
              	if ((z <= -33000000000.0) || !(z <= 1.9e+39)) {
              		tmp = fma(3.13060547623, y, x);
              	} else {
              		tmp = fma(fma(a, z, b), (1.6453555072203998 * y), x);
              	}
              	return tmp;
              }
              
              function code(x, y, z, t, a, b)
              	tmp = 0.0
              	if ((z <= -33000000000.0) || !(z <= 1.9e+39))
              		tmp = fma(3.13060547623, y, x);
              	else
              		tmp = fma(fma(a, z, b), Float64(1.6453555072203998 * y), x);
              	end
              	return tmp
              end
              
              code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -33000000000.0], N[Not[LessEqual[z, 1.9e+39]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(a * z + b), $MachinePrecision] * N[(1.6453555072203998 * y), $MachinePrecision] + x), $MachinePrecision]]
              
              \begin{array}{l}
              
              \\
              \begin{array}{l}
              \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 1.9 \cdot 10^{+39}\right):\\
              \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
              
              \mathbf{else}:\\
              \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), 1.6453555072203998 \cdot y, x\right)\\
              
              
              \end{array}
              \end{array}
              
              Derivation
              1. Split input into 2 regimes
              2. if z < -3.3e10 or 1.8999999999999999e39 < z

                1. Initial program 17.6%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around inf

                  \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                  2. lower-fma.f6486.5

                    \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                5. Applied rewrites86.5%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

                if -3.3e10 < z < 1.8999999999999999e39

                1. Initial program 98.4%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around 0

                  \[\leadsto x + \frac{y \cdot \color{blue}{\left(b + a \cdot z\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto x + \frac{y \cdot \color{blue}{\left(a \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
                  2. lower-fma.f6491.2

                    \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                5. Applied rewrites91.2%

                  \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                6. Taylor expanded in z around 0

                  \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\frac{607771387771}{1000000000000} + z \cdot \left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z\right)}} \]
                7. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{z \cdot \left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z\right) + \frac{607771387771}{1000000000000}}} \]
                  2. *-commutativeN/A

                    \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z\right) \cdot z} + \frac{607771387771}{1000000000000}} \]
                  3. lower-fma.f64N/A

                    \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\mathsf{fma}\left(\frac{119400905721}{10000000000} + \frac{314690115749}{10000000000} \cdot z, z, \frac{607771387771}{1000000000000}\right)}} \]
                  4. +-commutativeN/A

                    \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\color{blue}{\frac{314690115749}{10000000000} \cdot z + \frac{119400905721}{10000000000}}, z, \frac{607771387771}{1000000000000}\right)} \]
                  5. lower-fma.f6490.4

                    \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right)}, z, 0.607771387771\right)} \]
                8. Applied rewrites90.4%

                  \[\leadsto x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}} \]
                9. Step-by-step derivation
                  1. lift-+.f64N/A

                    \[\leadsto \color{blue}{x + \frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}} \]
                  2. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} + x} \]
                  3. lift-/.f64N/A

                    \[\leadsto \color{blue}{\frac{y \cdot \mathsf{fma}\left(a, z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}} + x \]
                  4. lift-*.f64N/A

                    \[\leadsto \frac{\color{blue}{y \cdot \mathsf{fma}\left(a, z, b\right)}}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} + x \]
                  5. *-commutativeN/A

                    \[\leadsto \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)} + x \]
                  6. associate-/l*N/A

                    \[\leadsto \color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(\frac{314690115749}{10000000000}, z, \frac{119400905721}{10000000000}\right), z, \frac{607771387771}{1000000000000}\right)}} + x \]
                10. Applied rewrites90.4%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(31.4690115749, z, 11.9400905721\right), z, 0.607771387771\right)}, x\right)} \]
                11. Taylor expanded in z around 0

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \color{blue}{\frac{1000000000000}{607771387771} \cdot y}, x\right) \]
                12. Step-by-step derivation
                  1. lower-*.f6489.5

                    \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \color{blue}{1.6453555072203998 \cdot y}, x\right) \]
                13. Applied rewrites89.5%

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), \color{blue}{1.6453555072203998 \cdot y}, x\right) \]
              3. Recombined 2 regimes into one program.
              4. Final simplification88.1%

                \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -33000000000 \lor \neg \left(z \leq 1.9 \cdot 10^{+39}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(a, z, b\right), 1.6453555072203998 \cdot y, x\right)\\ \end{array} \]
              5. Add Preprocessing

              Alternative 14: 84.0% accurate, 3.3× speedup?

              \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(1.6453555072203998 \cdot b, y, x\right)\\ \end{array} \end{array} \]
              (FPCore (x y z t a b)
               :precision binary64
               (if (or (<= z -31000000000.0) (not (<= z 1.26e+48)))
                 (fma 3.13060547623 y x)
                 (fma (* 1.6453555072203998 b) y x)))
              double code(double x, double y, double z, double t, double a, double b) {
              	double tmp;
              	if ((z <= -31000000000.0) || !(z <= 1.26e+48)) {
              		tmp = fma(3.13060547623, y, x);
              	} else {
              		tmp = fma((1.6453555072203998 * b), y, x);
              	}
              	return tmp;
              }
              
              function code(x, y, z, t, a, b)
              	tmp = 0.0
              	if ((z <= -31000000000.0) || !(z <= 1.26e+48))
              		tmp = fma(3.13060547623, y, x);
              	else
              		tmp = fma(Float64(1.6453555072203998 * b), y, x);
              	end
              	return tmp
              end
              
              code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -31000000000.0], N[Not[LessEqual[z, 1.26e+48]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(1.6453555072203998 * b), $MachinePrecision] * y + x), $MachinePrecision]]
              
              \begin{array}{l}
              
              \\
              \begin{array}{l}
              \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\
              \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
              
              \mathbf{else}:\\
              \;\;\;\;\mathsf{fma}\left(1.6453555072203998 \cdot b, y, x\right)\\
              
              
              \end{array}
              \end{array}
              
              Derivation
              1. Split input into 2 regimes
              2. if z < -3.1e10 or 1.26000000000000001e48 < z

                1. Initial program 15.5%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around inf

                  \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                  2. lower-fma.f6488.5

                    \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                5. Applied rewrites88.5%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

                if -3.1e10 < z < 1.26000000000000001e48

                1. Initial program 98.4%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Step-by-step derivation
                  1. lift-+.f64N/A

                    \[\leadsto \color{blue}{x + \frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
                  2. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x} \]
                  3. lift-/.f64N/A

                    \[\leadsto \color{blue}{\frac{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
                  4. lift-*.f64N/A

                    \[\leadsto \frac{\color{blue}{y \cdot \left(\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} + x \]
                  5. associate-/l*N/A

                    \[\leadsto \color{blue}{y \cdot \frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} + x \]
                  6. *-commutativeN/A

                    \[\leadsto \color{blue}{\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \cdot y} + x \]
                  7. lower-fma.f64N/A

                    \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\left(\left(\left(z \cdot \frac{313060547623}{100000000000} + \frac{55833770631}{5000000000}\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}, y, x\right)} \]
                4. Applied rewrites99.7%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(3.13060547623, z, 11.1667541262\right), z, t\right), z, a\right), z, b\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}, y, x\right)} \]
                5. Taylor expanded in z around 0

                  \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{1000000000000}{607771387771} \cdot b}, y, x\right) \]
                6. Step-by-step derivation
                  1. lower-*.f6478.0

                    \[\leadsto \mathsf{fma}\left(\color{blue}{1.6453555072203998 \cdot b}, y, x\right) \]
                7. Applied rewrites78.0%

                  \[\leadsto \mathsf{fma}\left(\color{blue}{1.6453555072203998 \cdot b}, y, x\right) \]
              3. Recombined 2 regimes into one program.
              4. Final simplification82.9%

                \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(1.6453555072203998 \cdot b, y, x\right)\\ \end{array} \]
              5. Add Preprocessing

              Alternative 15: 84.1% accurate, 3.3× speedup?

              \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(y \cdot 1.6453555072203998, b, x\right)\\ \end{array} \end{array} \]
              (FPCore (x y z t a b)
               :precision binary64
               (if (or (<= z -31000000000.0) (not (<= z 1.26e+48)))
                 (fma 3.13060547623 y x)
                 (fma (* y 1.6453555072203998) b x)))
              double code(double x, double y, double z, double t, double a, double b) {
              	double tmp;
              	if ((z <= -31000000000.0) || !(z <= 1.26e+48)) {
              		tmp = fma(3.13060547623, y, x);
              	} else {
              		tmp = fma((y * 1.6453555072203998), b, x);
              	}
              	return tmp;
              }
              
              function code(x, y, z, t, a, b)
              	tmp = 0.0
              	if ((z <= -31000000000.0) || !(z <= 1.26e+48))
              		tmp = fma(3.13060547623, y, x);
              	else
              		tmp = fma(Float64(y * 1.6453555072203998), b, x);
              	end
              	return tmp
              end
              
              code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -31000000000.0], N[Not[LessEqual[z, 1.26e+48]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(y * 1.6453555072203998), $MachinePrecision] * b + x), $MachinePrecision]]
              
              \begin{array}{l}
              
              \\
              \begin{array}{l}
              \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\
              \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
              
              \mathbf{else}:\\
              \;\;\;\;\mathsf{fma}\left(y \cdot 1.6453555072203998, b, x\right)\\
              
              
              \end{array}
              \end{array}
              
              Derivation
              1. Split input into 2 regimes
              2. if z < -3.1e10 or 1.26000000000000001e48 < z

                1. Initial program 15.5%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around inf

                  \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                  2. lower-fma.f6488.5

                    \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                5. Applied rewrites88.5%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

                if -3.1e10 < z < 1.26000000000000001e48

                1. Initial program 98.4%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around 0

                  \[\leadsto x + \frac{y \cdot \color{blue}{\left(b + a \cdot z\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto x + \frac{y \cdot \color{blue}{\left(a \cdot z + b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
                  2. lower-fma.f6489.4

                    \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                5. Applied rewrites89.4%

                  \[\leadsto x + \frac{y \cdot \color{blue}{\mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                6. Step-by-step derivation
                  1. lift-*.f64N/A

                    \[\leadsto x + \frac{\color{blue}{y \cdot \mathsf{fma}\left(a, z, b\right)}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
                  2. *-commutativeN/A

                    \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}} \]
                  3. lower-*.f6489.4

                    \[\leadsto x + \frac{\color{blue}{\mathsf{fma}\left(a, z, b\right) \cdot y}}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                  4. lift-+.f64N/A

                    \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z + \frac{607771387771}{1000000000000}}} \]
                  5. lift-*.f64N/A

                    \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\left(\left(\left(z + \frac{15234687407}{1000000000}\right) \cdot z + \frac{314690115749}{10000000000}\right) \cdot z + \frac{119400905721}{10000000000}\right) \cdot z} + \frac{607771387771}{1000000000000}} \]
                  6. lower-fma.f6489.4

                    \[\leadsto x + \frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\color{blue}{\mathsf{fma}\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721, z, 0.607771387771\right)}} \]
                7. Applied rewrites89.4%

                  \[\leadsto x + \color{blue}{\frac{\mathsf{fma}\left(a, z, b\right) \cdot y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(15.234687407 + z, z, 31.4690115749\right), z, 11.9400905721\right), z, 0.607771387771\right)}} \]
                8. Taylor expanded in z around 0

                  \[\leadsto \color{blue}{x + \frac{1000000000000}{607771387771} \cdot \left(b \cdot y\right)} \]
                9. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{1000000000000}{607771387771} \cdot \left(b \cdot y\right) + x} \]
                  2. *-commutativeN/A

                    \[\leadsto \color{blue}{\left(b \cdot y\right) \cdot \frac{1000000000000}{607771387771}} + x \]
                  3. lower-fma.f64N/A

                    \[\leadsto \color{blue}{\mathsf{fma}\left(b \cdot y, \frac{1000000000000}{607771387771}, x\right)} \]
                  4. *-commutativeN/A

                    \[\leadsto \mathsf{fma}\left(\color{blue}{y \cdot b}, \frac{1000000000000}{607771387771}, x\right) \]
                  5. lower-*.f6477.9

                    \[\leadsto \mathsf{fma}\left(\color{blue}{y \cdot b}, 1.6453555072203998, x\right) \]
                10. Applied rewrites77.9%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(y \cdot b, 1.6453555072203998, x\right)} \]
                11. Step-by-step derivation
                  1. Applied rewrites78.0%

                    \[\leadsto \mathsf{fma}\left(y \cdot 1.6453555072203998, \color{blue}{b}, x\right) \]
                12. Recombined 2 regimes into one program.
                13. Final simplification82.9%

                  \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(y \cdot 1.6453555072203998, b, x\right)\\ \end{array} \]
                14. Add Preprocessing

                Alternative 16: 84.1% accurate, 3.3× speedup?

                \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(b \cdot y, 1.6453555072203998, x\right)\\ \end{array} \end{array} \]
                (FPCore (x y z t a b)
                 :precision binary64
                 (if (or (<= z -31000000000.0) (not (<= z 1.26e+48)))
                   (fma 3.13060547623 y x)
                   (fma (* b y) 1.6453555072203998 x)))
                double code(double x, double y, double z, double t, double a, double b) {
                	double tmp;
                	if ((z <= -31000000000.0) || !(z <= 1.26e+48)) {
                		tmp = fma(3.13060547623, y, x);
                	} else {
                		tmp = fma((b * y), 1.6453555072203998, x);
                	}
                	return tmp;
                }
                
                function code(x, y, z, t, a, b)
                	tmp = 0.0
                	if ((z <= -31000000000.0) || !(z <= 1.26e+48))
                		tmp = fma(3.13060547623, y, x);
                	else
                		tmp = fma(Float64(b * y), 1.6453555072203998, x);
                	end
                	return tmp
                end
                
                code[x_, y_, z_, t_, a_, b_] := If[Or[LessEqual[z, -31000000000.0], N[Not[LessEqual[z, 1.26e+48]], $MachinePrecision]], N[(3.13060547623 * y + x), $MachinePrecision], N[(N[(b * y), $MachinePrecision] * 1.6453555072203998 + x), $MachinePrecision]]
                
                \begin{array}{l}
                
                \\
                \begin{array}{l}
                \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\
                \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\
                
                \mathbf{else}:\\
                \;\;\;\;\mathsf{fma}\left(b \cdot y, 1.6453555072203998, x\right)\\
                
                
                \end{array}
                \end{array}
                
                Derivation
                1. Split input into 2 regimes
                2. if z < -3.1e10 or 1.26000000000000001e48 < z

                  1. Initial program 15.5%

                    \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                  2. Add Preprocessing
                  3. Taylor expanded in z around inf

                    \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
                  4. Step-by-step derivation
                    1. +-commutativeN/A

                      \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                    2. lower-fma.f6488.5

                      \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                  5. Applied rewrites88.5%

                    \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]

                  if -3.1e10 < z < 1.26000000000000001e48

                  1. Initial program 98.4%

                    \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                  2. Add Preprocessing
                  3. Taylor expanded in z around 0

                    \[\leadsto \color{blue}{x + \frac{1000000000000}{607771387771} \cdot \left(b \cdot y\right)} \]
                  4. Step-by-step derivation
                    1. +-commutativeN/A

                      \[\leadsto \color{blue}{\frac{1000000000000}{607771387771} \cdot \left(b \cdot y\right) + x} \]
                    2. *-commutativeN/A

                      \[\leadsto \color{blue}{\left(b \cdot y\right) \cdot \frac{1000000000000}{607771387771}} + x \]
                    3. lower-fma.f64N/A

                      \[\leadsto \color{blue}{\mathsf{fma}\left(b \cdot y, \frac{1000000000000}{607771387771}, x\right)} \]
                    4. lower-*.f6477.9

                      \[\leadsto \mathsf{fma}\left(\color{blue}{b \cdot y}, 1.6453555072203998, x\right) \]
                  5. Applied rewrites77.9%

                    \[\leadsto \color{blue}{\mathsf{fma}\left(b \cdot y, 1.6453555072203998, x\right)} \]
                3. Recombined 2 regimes into one program.
                4. Final simplification82.8%

                  \[\leadsto \begin{array}{l} \mathbf{if}\;z \leq -31000000000 \lor \neg \left(z \leq 1.26 \cdot 10^{+48}\right):\\ \;\;\;\;\mathsf{fma}\left(3.13060547623, y, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(b \cdot y, 1.6453555072203998, x\right)\\ \end{array} \]
                5. Add Preprocessing

                Alternative 17: 62.3% accurate, 11.3× speedup?

                \[\begin{array}{l} \\ \mathsf{fma}\left(3.13060547623, y, x\right) \end{array} \]
                (FPCore (x y z t a b) :precision binary64 (fma 3.13060547623 y x))
                double code(double x, double y, double z, double t, double a, double b) {
                	return fma(3.13060547623, y, x);
                }
                
                function code(x, y, z, t, a, b)
                	return fma(3.13060547623, y, x)
                end
                
                code[x_, y_, z_, t_, a_, b_] := N[(3.13060547623 * y + x), $MachinePrecision]
                
                \begin{array}{l}
                
                \\
                \mathsf{fma}\left(3.13060547623, y, x\right)
                \end{array}
                
                Derivation
                1. Initial program 60.2%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around inf

                  \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                  2. lower-fma.f6463.2

                    \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                5. Applied rewrites63.2%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                6. Add Preprocessing

                Alternative 18: 22.1% accurate, 13.2× speedup?

                \[\begin{array}{l} \\ 3.13060547623 \cdot y \end{array} \]
                (FPCore (x y z t a b) :precision binary64 (* 3.13060547623 y))
                double code(double x, double y, double z, double t, double a, double b) {
                	return 3.13060547623 * y;
                }
                
                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(x, y, z, t, a, b)
                use fmin_fmax_functions
                    real(8), intent (in) :: x
                    real(8), intent (in) :: y
                    real(8), intent (in) :: z
                    real(8), intent (in) :: t
                    real(8), intent (in) :: a
                    real(8), intent (in) :: b
                    code = 3.13060547623d0 * y
                end function
                
                public static double code(double x, double y, double z, double t, double a, double b) {
                	return 3.13060547623 * y;
                }
                
                def code(x, y, z, t, a, b):
                	return 3.13060547623 * y
                
                function code(x, y, z, t, a, b)
                	return Float64(3.13060547623 * y)
                end
                
                function tmp = code(x, y, z, t, a, b)
                	tmp = 3.13060547623 * y;
                end
                
                code[x_, y_, z_, t_, a_, b_] := N[(3.13060547623 * y), $MachinePrecision]
                
                \begin{array}{l}
                
                \\
                3.13060547623 \cdot y
                \end{array}
                
                Derivation
                1. Initial program 60.2%

                  \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771} \]
                2. Add Preprocessing
                3. Taylor expanded in z around inf

                  \[\leadsto \color{blue}{x + \frac{313060547623}{100000000000} \cdot y} \]
                4. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{\frac{313060547623}{100000000000} \cdot y + x} \]
                  2. lower-fma.f6463.2

                    \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                5. Applied rewrites63.2%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(3.13060547623, y, x\right)} \]
                6. Taylor expanded in x around 0

                  \[\leadsto \frac{313060547623}{100000000000} \cdot \color{blue}{y} \]
                7. Step-by-step derivation
                  1. Applied rewrites23.2%

                    \[\leadsto 3.13060547623 \cdot \color{blue}{y} \]
                  2. Add Preprocessing

                  Developer Target 1: 98.5% accurate, 0.8× speedup?

                  \[\begin{array}{l} \\ \begin{array}{l} t_1 := x + \left(\left(3.13060547623 - \frac{36.527041698806414}{z}\right) + \frac{t}{z \cdot z}\right) \cdot \frac{y}{1}\\ \mathbf{if}\;z < -6.499344996252632 \cdot 10^{+53}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;z < 7.066965436914287 \cdot 10^{+59}:\\ \;\;\;\;x + \frac{y}{\frac{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771}{\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
                  (FPCore (x y z t a b)
                   :precision binary64
                   (let* ((t_1
                           (+
                            x
                            (*
                             (+ (- 3.13060547623 (/ 36.527041698806414 z)) (/ t (* z z)))
                             (/ y 1.0)))))
                     (if (< z -6.499344996252632e+53)
                       t_1
                       (if (< z 7.066965436914287e+59)
                         (+
                          x
                          (/
                           y
                           (/
                            (+
                             (*
                              (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721)
                              z)
                             0.607771387771)
                            (+
                             (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z)
                             b))))
                         t_1))))
                  double code(double x, double y, double z, double t, double a, double b) {
                  	double t_1 = x + (((3.13060547623 - (36.527041698806414 / z)) + (t / (z * z))) * (y / 1.0));
                  	double tmp;
                  	if (z < -6.499344996252632e+53) {
                  		tmp = t_1;
                  	} else if (z < 7.066965436914287e+59) {
                  		tmp = x + (y / ((((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771) / ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)));
                  	} else {
                  		tmp = t_1;
                  	}
                  	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(x, y, z, t, a, b)
                  use fmin_fmax_functions
                      real(8), intent (in) :: x
                      real(8), intent (in) :: y
                      real(8), intent (in) :: z
                      real(8), intent (in) :: t
                      real(8), intent (in) :: a
                      real(8), intent (in) :: b
                      real(8) :: t_1
                      real(8) :: tmp
                      t_1 = x + (((3.13060547623d0 - (36.527041698806414d0 / z)) + (t / (z * z))) * (y / 1.0d0))
                      if (z < (-6.499344996252632d+53)) then
                          tmp = t_1
                      else if (z < 7.066965436914287d+59) then
                          tmp = x + (y / ((((((((z + 15.234687407d0) * z) + 31.4690115749d0) * z) + 11.9400905721d0) * z) + 0.607771387771d0) / ((((((((z * 3.13060547623d0) + 11.1667541262d0) * z) + t) * z) + a) * z) + b)))
                      else
                          tmp = t_1
                      end if
                      code = tmp
                  end function
                  
                  public static double code(double x, double y, double z, double t, double a, double b) {
                  	double t_1 = x + (((3.13060547623 - (36.527041698806414 / z)) + (t / (z * z))) * (y / 1.0));
                  	double tmp;
                  	if (z < -6.499344996252632e+53) {
                  		tmp = t_1;
                  	} else if (z < 7.066965436914287e+59) {
                  		tmp = x + (y / ((((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771) / ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)));
                  	} else {
                  		tmp = t_1;
                  	}
                  	return tmp;
                  }
                  
                  def code(x, y, z, t, a, b):
                  	t_1 = x + (((3.13060547623 - (36.527041698806414 / z)) + (t / (z * z))) * (y / 1.0))
                  	tmp = 0
                  	if z < -6.499344996252632e+53:
                  		tmp = t_1
                  	elif z < 7.066965436914287e+59:
                  		tmp = x + (y / ((((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771) / ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)))
                  	else:
                  		tmp = t_1
                  	return tmp
                  
                  function code(x, y, z, t, a, b)
                  	t_1 = Float64(x + Float64(Float64(Float64(3.13060547623 - Float64(36.527041698806414 / z)) + Float64(t / Float64(z * z))) * Float64(y / 1.0)))
                  	tmp = 0.0
                  	if (z < -6.499344996252632e+53)
                  		tmp = t_1;
                  	elseif (z < 7.066965436914287e+59)
                  		tmp = Float64(x + Float64(y / Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b))));
                  	else
                  		tmp = t_1;
                  	end
                  	return tmp
                  end
                  
                  function tmp_2 = code(x, y, z, t, a, b)
                  	t_1 = x + (((3.13060547623 - (36.527041698806414 / z)) + (t / (z * z))) * (y / 1.0));
                  	tmp = 0.0;
                  	if (z < -6.499344996252632e+53)
                  		tmp = t_1;
                  	elseif (z < 7.066965436914287e+59)
                  		tmp = x + (y / ((((((((z + 15.234687407) * z) + 31.4690115749) * z) + 11.9400905721) * z) + 0.607771387771) / ((((((((z * 3.13060547623) + 11.1667541262) * z) + t) * z) + a) * z) + b)));
                  	else
                  		tmp = t_1;
                  	end
                  	tmp_2 = tmp;
                  end
                  
                  code[x_, y_, z_, t_, a_, b_] := Block[{t$95$1 = N[(x + N[(N[(N[(3.13060547623 - N[(36.527041698806414 / z), $MachinePrecision]), $MachinePrecision] + N[(t / N[(z * z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(y / 1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[Less[z, -6.499344996252632e+53], t$95$1, If[Less[z, 7.066965436914287e+59], N[(x + N[(y / N[(N[(N[(N[(N[(N[(N[(N[(z + 15.234687407), $MachinePrecision] * z), $MachinePrecision] + 31.4690115749), $MachinePrecision] * z), $MachinePrecision] + 11.9400905721), $MachinePrecision] * z), $MachinePrecision] + 0.607771387771), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(N[(z * 3.13060547623), $MachinePrecision] + 11.1667541262), $MachinePrecision] * z), $MachinePrecision] + t), $MachinePrecision] * z), $MachinePrecision] + a), $MachinePrecision] * z), $MachinePrecision] + b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$1]]]
                  
                  \begin{array}{l}
                  
                  \\
                  \begin{array}{l}
                  t_1 := x + \left(\left(3.13060547623 - \frac{36.527041698806414}{z}\right) + \frac{t}{z \cdot z}\right) \cdot \frac{y}{1}\\
                  \mathbf{if}\;z < -6.499344996252632 \cdot 10^{+53}:\\
                  \;\;\;\;t\_1\\
                  
                  \mathbf{elif}\;z < 7.066965436914287 \cdot 10^{+59}:\\
                  \;\;\;\;x + \frac{y}{\frac{\left(\left(\left(z + 15.234687407\right) \cdot z + 31.4690115749\right) \cdot z + 11.9400905721\right) \cdot z + 0.607771387771}{\left(\left(\left(z \cdot 3.13060547623 + 11.1667541262\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}}\\
                  
                  \mathbf{else}:\\
                  \;\;\;\;t\_1\\
                  
                  
                  \end{array}
                  \end{array}
                  

                  Reproduce

                  ?
                  herbie shell --seed 2024364 
                  (FPCore (x y z t a b)
                    :name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, D"
                    :precision binary64
                  
                    :alt
                    (! :herbie-platform default (if (< z -649934499625263200000000000000000000000000000000000000) (+ x (* (+ (- 313060547623/100000000000 (/ 18263520849403207/500000000000000 z)) (/ t (* z z))) (/ y 1))) (if (< z 706696543691428700000000000000000000000000000000000000000000) (+ x (/ y (/ (+ (* (+ (* (+ (* (+ z 15234687407/1000000000) z) 314690115749/10000000000) z) 119400905721/10000000000) z) 607771387771/1000000000000) (+ (* (+ (* (+ (* (+ (* z 313060547623/100000000000) 55833770631/5000000000) z) t) z) a) z) b)))) (+ x (* (+ (- 313060547623/100000000000 (/ 18263520849403207/500000000000000 z)) (/ t (* z z))) (/ y 1))))))
                  
                    (+ x (/ (* y (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b)) (+ (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z) 0.607771387771))))