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

Percentage Accurate: 58.5% → 98.0%
Time: 14.4s
Alternatives: 21
Speedup: 4.4×

Specification

?
\[\begin{array}{l} \\ \frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \end{array} \]
(FPCore (x y z)
 :precision binary64
 (/
  (*
   (- x 2.0)
   (+
    (*
     (+ (* (+ (* (+ (* x 4.16438922228) 78.6994924154) x) 137.519416416) x) y)
     x)
    z))
  (+
   (* (+ (* (+ (* (+ x 43.3400022514) x) 263.505074721) x) 313.399215894) x)
   47.066876606)))
double code(double x, double y, double z) {
	return ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606);
}
real(8) function code(x, y, z)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    real(8), intent (in) :: z
    code = ((x - 2.0d0) * ((((((((x * 4.16438922228d0) + 78.6994924154d0) * x) + 137.519416416d0) * x) + y) * x) + z)) / (((((((x + 43.3400022514d0) * x) + 263.505074721d0) * x) + 313.399215894d0) * x) + 47.066876606d0)
end function
public static double code(double x, double y, double z) {
	return ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606);
}
def code(x, y, z):
	return ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606)
function code(x, y, z)
	return Float64(Float64(Float64(x - 2.0) * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606))
end
function tmp = code(x, y, z)
	tmp = ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606);
end
code[x_, y_, z_] := N[(N[(N[(x - 2.0), $MachinePrecision] * N[(N[(N[(N[(N[(N[(N[(N[(x * 4.16438922228), $MachinePrecision] + 78.6994924154), $MachinePrecision] * x), $MachinePrecision] + 137.519416416), $MachinePrecision] * x), $MachinePrecision] + y), $MachinePrecision] * x), $MachinePrecision] + z), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(x + 43.3400022514), $MachinePrecision] * x), $MachinePrecision] + 263.505074721), $MachinePrecision] * x), $MachinePrecision] + 313.399215894), $MachinePrecision] * x), $MachinePrecision] + 47.066876606), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606}
\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 21 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: 58.5% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \end{array} \]
(FPCore (x y z)
 :precision binary64
 (/
  (*
   (- x 2.0)
   (+
    (*
     (+ (* (+ (* (+ (* x 4.16438922228) 78.6994924154) x) 137.519416416) x) y)
     x)
    z))
  (+
   (* (+ (* (+ (* (+ x 43.3400022514) x) 263.505074721) x) 313.399215894) x)
   47.066876606)))
double code(double x, double y, double z) {
	return ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606);
}
real(8) function code(x, y, z)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    real(8), intent (in) :: z
    code = ((x - 2.0d0) * ((((((((x * 4.16438922228d0) + 78.6994924154d0) * x) + 137.519416416d0) * x) + y) * x) + z)) / (((((((x + 43.3400022514d0) * x) + 263.505074721d0) * x) + 313.399215894d0) * x) + 47.066876606d0)
end function
public static double code(double x, double y, double z) {
	return ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606);
}
def code(x, y, z):
	return ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606)
function code(x, y, z)
	return Float64(Float64(Float64(x - 2.0) * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / Float64(Float64(Float64(Float64(Float64(Float64(Float64(x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606))
end
function tmp = code(x, y, z)
	tmp = ((x - 2.0) * ((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z)) / (((((((x + 43.3400022514) * x) + 263.505074721) * x) + 313.399215894) * x) + 47.066876606);
end
code[x_, y_, z_] := N[(N[(N[(x - 2.0), $MachinePrecision] * N[(N[(N[(N[(N[(N[(N[(N[(x * 4.16438922228), $MachinePrecision] + 78.6994924154), $MachinePrecision] * x), $MachinePrecision] + 137.519416416), $MachinePrecision] * x), $MachinePrecision] + y), $MachinePrecision] * x), $MachinePrecision] + z), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(N[(N[(N[(x + 43.3400022514), $MachinePrecision] * x), $MachinePrecision] + 263.505074721), $MachinePrecision] * x), $MachinePrecision] + 313.399215894), $MachinePrecision] * x), $MachinePrecision] + 47.066876606), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606}
\end{array}

Alternative 1: 98.0% accurate, 0.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \mathbf{if}\;x \leq -6.5 \cdot 10^{+55}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 6.8 \cdot 10^{+22}:\\ \;\;\;\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
(FPCore (x y z)
 :precision binary64
 (let* ((t_0
         (*
          (- x)
          (fma
           (/
            (fma
             (/
              (fma (/ (- y 130977.50649958357) x) -1.0 -3655.1204654076414)
              x)
             -1.0
             -110.1139242984811)
            x)
           -1.0
           -4.16438922228))))
   (if (<= x -6.5e+55)
     t_0
     (if (<= x 6.8e+22)
       (/
        (*
         (+
          z
          (*
           (+
            y
            (*
             (+ 137.519416416 (* (+ 78.6994924154 (* 4.16438922228 x)) x))
             x))
           x))
         (- x 2.0))
        (+
         47.066876606
         (*
          (+ 313.399215894 (* (+ 263.505074721 (* (+ 43.3400022514 x) x)) x))
          x)))
       t_0))))
double code(double x, double y, double z) {
	double t_0 = -x * fma((fma((fma(((y - 130977.50649958357) / x), -1.0, -3655.1204654076414) / x), -1.0, -110.1139242984811) / x), -1.0, -4.16438922228);
	double tmp;
	if (x <= -6.5e+55) {
		tmp = t_0;
	} else if (x <= 6.8e+22) {
		tmp = ((z + ((y + ((137.519416416 + ((78.6994924154 + (4.16438922228 * x)) * x)) * x)) * x)) * (x - 2.0)) / (47.066876606 + ((313.399215894 + ((263.505074721 + ((43.3400022514 + x) * x)) * x)) * x));
	} else {
		tmp = t_0;
	}
	return tmp;
}
function code(x, y, z)
	t_0 = Float64(Float64(-x) * fma(Float64(fma(Float64(fma(Float64(Float64(y - 130977.50649958357) / x), -1.0, -3655.1204654076414) / x), -1.0, -110.1139242984811) / x), -1.0, -4.16438922228))
	tmp = 0.0
	if (x <= -6.5e+55)
		tmp = t_0;
	elseif (x <= 6.8e+22)
		tmp = Float64(Float64(Float64(z + Float64(Float64(y + Float64(Float64(137.519416416 + Float64(Float64(78.6994924154 + Float64(4.16438922228 * x)) * x)) * x)) * x)) * Float64(x - 2.0)) / Float64(47.066876606 + Float64(Float64(313.399215894 + Float64(Float64(263.505074721 + Float64(Float64(43.3400022514 + x) * x)) * x)) * x)));
	else
		tmp = t_0;
	end
	return tmp
end
code[x_, y_, z_] := Block[{t$95$0 = N[((-x) * N[(N[(N[(N[(N[(N[(N[(y - 130977.50649958357), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -3655.1204654076414), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -110.1139242984811), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -4.16438922228), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -6.5e+55], t$95$0, If[LessEqual[x, 6.8e+22], N[(N[(N[(z + N[(N[(y + N[(N[(137.519416416 + N[(N[(78.6994924154 + N[(4.16438922228 * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(47.066876606 + N[(N[(313.399215894 + N[(N[(263.505074721 + N[(N[(43.3400022514 + x), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\
\mathbf{if}\;x \leq -6.5 \cdot 10^{+55}:\\
\;\;\;\;t\_0\\

\mathbf{elif}\;x \leq 6.8 \cdot 10^{+22}:\\
\;\;\;\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\

\mathbf{else}:\\
\;\;\;\;t\_0\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if x < -6.50000000000000027e55 or 6.8e22 < x

    1. Initial program 5.0%

      \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
    2. Add Preprocessing
    3. Taylor expanded in z around 0

      \[\leadsto \color{blue}{\frac{x \cdot \left(\left(y + x \cdot \left(\frac{4297481763}{31250000} + x \cdot \left(\frac{393497462077}{5000000000} + \frac{104109730557}{25000000000} \cdot x\right)\right)\right) \cdot \left(x - 2\right)\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
    4. Applied rewrites12.1%

      \[\leadsto \color{blue}{\left(\left(x - 2\right) \cdot \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right)\right) \cdot \frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}} \]
    5. Taylor expanded in x around -inf

      \[\leadsto -1 \cdot \color{blue}{\left(x \cdot \left(-1 \cdot \frac{-1 \cdot \frac{-1 \cdot \frac{y - \frac{409304707811198655637810418659684985388407301}{3125000000000000000000000000000000000000}}{x} - \frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x} - \frac{104109730557}{25000000000}\right)\right)} \]
    6. Step-by-step derivation
      1. Applied rewrites99.1%

        \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right) \cdot \color{blue}{\left(-x\right)} \]

      if -6.50000000000000027e55 < x < 6.8e22

      1. Initial program 99.1%

        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
      2. Add Preprocessing
    7. Recombined 2 regimes into one program.
    8. Final simplification99.1%

      \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -6.5 \cdot 10^{+55}:\\ \;\;\;\;\left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \mathbf{elif}\;x \leq 6.8 \cdot 10^{+22}:\\ \;\;\;\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;\left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \end{array} \]
    9. Add Preprocessing

    Alternative 2: 98.3% accurate, 0.5× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x} \leq \infty:\\ \;\;\;\;\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot \mathsf{fma}\left(x, x, -4\right)}{x - -2}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \end{array} \]
    (FPCore (x y z)
     :precision binary64
     (if (<=
          (/
           (*
            (+
             z
             (*
              (+
               y
               (* (+ 137.519416416 (* (+ 78.6994924154 (* 4.16438922228 x)) x)) x))
              x))
            (- x 2.0))
           (+
            47.066876606
            (*
             (+ 313.399215894 (* (+ 263.505074721 (* (+ 43.3400022514 x) x)) x))
             x)))
          INFINITY)
       (/
        (*
         (/
          (fma
           (fma (fma (fma 4.16438922228 x 78.6994924154) x 137.519416416) x y)
           x
           z)
          (fma
           (fma (fma (+ 43.3400022514 x) x 263.505074721) x 313.399215894)
           x
           47.066876606))
         (fma x x -4.0))
        (- x -2.0))
       (/ 1.0 (/ 0.24013125253755718 x))))
    double code(double x, double y, double z) {
    	double tmp;
    	if ((((z + ((y + ((137.519416416 + ((78.6994924154 + (4.16438922228 * x)) * x)) * x)) * x)) * (x - 2.0)) / (47.066876606 + ((313.399215894 + ((263.505074721 + ((43.3400022514 + x) * x)) * x)) * x))) <= ((double) INFINITY)) {
    		tmp = ((fma(fma(fma(fma(4.16438922228, x, 78.6994924154), x, 137.519416416), x, y), x, z) / fma(fma(fma((43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) * fma(x, x, -4.0)) / (x - -2.0);
    	} else {
    		tmp = 1.0 / (0.24013125253755718 / x);
    	}
    	return tmp;
    }
    
    function code(x, y, z)
    	tmp = 0.0
    	if (Float64(Float64(Float64(z + Float64(Float64(y + Float64(Float64(137.519416416 + Float64(Float64(78.6994924154 + Float64(4.16438922228 * x)) * x)) * x)) * x)) * Float64(x - 2.0)) / Float64(47.066876606 + Float64(Float64(313.399215894 + Float64(Float64(263.505074721 + Float64(Float64(43.3400022514 + x) * x)) * x)) * x))) <= Inf)
    		tmp = Float64(Float64(Float64(fma(fma(fma(fma(4.16438922228, x, 78.6994924154), x, 137.519416416), x, y), x, z) / fma(fma(fma(Float64(43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) * fma(x, x, -4.0)) / Float64(x - -2.0));
    	else
    		tmp = Float64(1.0 / Float64(0.24013125253755718 / x));
    	end
    	return tmp
    end
    
    code[x_, y_, z_] := If[LessEqual[N[(N[(N[(z + N[(N[(y + N[(N[(137.519416416 + N[(N[(78.6994924154 + N[(4.16438922228 * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(47.066876606 + N[(N[(313.399215894 + N[(N[(263.505074721 + N[(N[(43.3400022514 + x), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(N[(N[(N[(N[(N[(4.16438922228 * x + 78.6994924154), $MachinePrecision] * x + 137.519416416), $MachinePrecision] * x + y), $MachinePrecision] * x + z), $MachinePrecision] / N[(N[(N[(N[(43.3400022514 + x), $MachinePrecision] * x + 263.505074721), $MachinePrecision] * x + 313.399215894), $MachinePrecision] * x + 47.066876606), $MachinePrecision]), $MachinePrecision] * N[(x * x + -4.0), $MachinePrecision]), $MachinePrecision] / N[(x - -2.0), $MachinePrecision]), $MachinePrecision], N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    \mathbf{if}\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x} \leq \infty:\\
    \;\;\;\;\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot \mathsf{fma}\left(x, x, -4\right)}{x - -2}\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if (/.f64 (*.f64 (-.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 x #s(literal 104109730557/25000000000 binary64)) #s(literal 393497462077/5000000000 binary64)) x) #s(literal 4297481763/31250000 binary64)) x) y) x) z)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 x #s(literal 216700011257/5000000000 binary64)) x) #s(literal 263505074721/1000000000 binary64)) x) #s(literal 156699607947/500000000 binary64)) x) #s(literal 23533438303/500000000 binary64))) < +inf.0

      1. Initial program 92.7%

        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
      2. Add Preprocessing
      3. Applied rewrites97.9%

        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]

      if +inf.0 < (/.f64 (*.f64 (-.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 x #s(literal 104109730557/25000000000 binary64)) #s(literal 393497462077/5000000000 binary64)) x) #s(literal 4297481763/31250000 binary64)) x) y) x) z)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 x #s(literal 216700011257/5000000000 binary64)) x) #s(literal 263505074721/1000000000 binary64)) x) #s(literal 156699607947/500000000 binary64)) x) #s(literal 23533438303/500000000 binary64)))

      1. Initial program 0.0%

        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
      2. Add Preprocessing
      3. Applied rewrites0.0%

        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
      4. Applied rewrites0.0%

        \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
      5. Taylor expanded in x around inf

        \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
      6. Step-by-step derivation
        1. lower-/.f6499.5

          \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
      7. Applied rewrites99.5%

        \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
    3. Recombined 2 regimes into one program.
    4. Final simplification98.4%

      \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x} \leq \infty:\\ \;\;\;\;\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot \mathsf{fma}\left(x, x, -4\right)}{x - -2}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
    5. Add Preprocessing

    Alternative 3: 98.3% accurate, 0.5× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x} \leq \infty:\\ \;\;\;\;\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2} \cdot \mathsf{fma}\left(x, x, -4\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \end{array} \]
    (FPCore (x y z)
     :precision binary64
     (if (<=
          (/
           (*
            (+
             z
             (*
              (+
               y
               (* (+ 137.519416416 (* (+ 78.6994924154 (* 4.16438922228 x)) x)) x))
              x))
            (- x 2.0))
           (+
            47.066876606
            (*
             (+ 313.399215894 (* (+ 263.505074721 (* (+ 43.3400022514 x) x)) x))
             x)))
          INFINITY)
       (*
        (/
         (/
          (fma
           (fma (fma (fma 4.16438922228 x 78.6994924154) x 137.519416416) x y)
           x
           z)
          (fma
           (fma (fma (+ 43.3400022514 x) x 263.505074721) x 313.399215894)
           x
           47.066876606))
         (- x -2.0))
        (fma x x -4.0))
       (/ 1.0 (/ 0.24013125253755718 x))))
    double code(double x, double y, double z) {
    	double tmp;
    	if ((((z + ((y + ((137.519416416 + ((78.6994924154 + (4.16438922228 * x)) * x)) * x)) * x)) * (x - 2.0)) / (47.066876606 + ((313.399215894 + ((263.505074721 + ((43.3400022514 + x) * x)) * x)) * x))) <= ((double) INFINITY)) {
    		tmp = ((fma(fma(fma(fma(4.16438922228, x, 78.6994924154), x, 137.519416416), x, y), x, z) / fma(fma(fma((43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) / (x - -2.0)) * fma(x, x, -4.0);
    	} else {
    		tmp = 1.0 / (0.24013125253755718 / x);
    	}
    	return tmp;
    }
    
    function code(x, y, z)
    	tmp = 0.0
    	if (Float64(Float64(Float64(z + Float64(Float64(y + Float64(Float64(137.519416416 + Float64(Float64(78.6994924154 + Float64(4.16438922228 * x)) * x)) * x)) * x)) * Float64(x - 2.0)) / Float64(47.066876606 + Float64(Float64(313.399215894 + Float64(Float64(263.505074721 + Float64(Float64(43.3400022514 + x) * x)) * x)) * x))) <= Inf)
    		tmp = Float64(Float64(Float64(fma(fma(fma(fma(4.16438922228, x, 78.6994924154), x, 137.519416416), x, y), x, z) / fma(fma(fma(Float64(43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) / Float64(x - -2.0)) * fma(x, x, -4.0));
    	else
    		tmp = Float64(1.0 / Float64(0.24013125253755718 / x));
    	end
    	return tmp
    end
    
    code[x_, y_, z_] := If[LessEqual[N[(N[(N[(z + N[(N[(y + N[(N[(137.519416416 + N[(N[(78.6994924154 + N[(4.16438922228 * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(47.066876606 + N[(N[(313.399215894 + N[(N[(263.505074721 + N[(N[(43.3400022514 + x), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(N[(N[(N[(N[(N[(4.16438922228 * x + 78.6994924154), $MachinePrecision] * x + 137.519416416), $MachinePrecision] * x + y), $MachinePrecision] * x + z), $MachinePrecision] / N[(N[(N[(N[(43.3400022514 + x), $MachinePrecision] * x + 263.505074721), $MachinePrecision] * x + 313.399215894), $MachinePrecision] * x + 47.066876606), $MachinePrecision]), $MachinePrecision] / N[(x - -2.0), $MachinePrecision]), $MachinePrecision] * N[(x * x + -4.0), $MachinePrecision]), $MachinePrecision], N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    \mathbf{if}\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x} \leq \infty:\\
    \;\;\;\;\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2} \cdot \mathsf{fma}\left(x, x, -4\right)\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if (/.f64 (*.f64 (-.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 x #s(literal 104109730557/25000000000 binary64)) #s(literal 393497462077/5000000000 binary64)) x) #s(literal 4297481763/31250000 binary64)) x) y) x) z)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 x #s(literal 216700011257/5000000000 binary64)) x) #s(literal 263505074721/1000000000 binary64)) x) #s(literal 156699607947/500000000 binary64)) x) #s(literal 23533438303/500000000 binary64))) < +inf.0

      1. Initial program 92.7%

        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
      2. Add Preprocessing
      3. Applied rewrites97.9%

        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
      4. Step-by-step derivation
        1. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2}} \]
        2. lift-*.f64N/A

          \[\leadsto \frac{\color{blue}{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}}{x - -2} \]
        3. associate-/l*N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2}} \]
        4. lift-fma.f64N/A

          \[\leadsto \color{blue}{\left(x \cdot x + -4\right)} \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        5. metadata-evalN/A

          \[\leadsto \left(x \cdot x + \color{blue}{\left(\mathsf{neg}\left(4\right)\right)}\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        6. metadata-evalN/A

          \[\leadsto \left(x \cdot x + \left(\mathsf{neg}\left(\color{blue}{-2 \cdot -2}\right)\right)\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        7. sub-negN/A

          \[\leadsto \color{blue}{\left(x \cdot x - -2 \cdot -2\right)} \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        8. lower-*.f64N/A

          \[\leadsto \color{blue}{\left(x \cdot x - -2 \cdot -2\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2}} \]
        9. sub-negN/A

          \[\leadsto \color{blue}{\left(x \cdot x + \left(\mathsf{neg}\left(-2 \cdot -2\right)\right)\right)} \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        10. metadata-evalN/A

          \[\leadsto \left(x \cdot x + \left(\mathsf{neg}\left(\color{blue}{4}\right)\right)\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        11. metadata-evalN/A

          \[\leadsto \left(x \cdot x + \color{blue}{-4}\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        12. lift-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(x, x, -4\right)} \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{104109730557}{25000000000}, x, \frac{393497462077}{5000000000}\right), x, \frac{4297481763}{31250000}\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)}}{x - -2} \]
        13. lower-/.f6497.9

          \[\leadsto \mathsf{fma}\left(x, x, -4\right) \cdot \color{blue}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
      5. Applied rewrites97.9%

        \[\leadsto \color{blue}{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]

      if +inf.0 < (/.f64 (*.f64 (-.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 x #s(literal 104109730557/25000000000 binary64)) #s(literal 393497462077/5000000000 binary64)) x) #s(literal 4297481763/31250000 binary64)) x) y) x) z)) (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (+.f64 x #s(literal 216700011257/5000000000 binary64)) x) #s(literal 263505074721/1000000000 binary64)) x) #s(literal 156699607947/500000000 binary64)) x) #s(literal 23533438303/500000000 binary64)))

      1. Initial program 0.0%

        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
      2. Add Preprocessing
      3. Applied rewrites0.0%

        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
      4. Applied rewrites0.0%

        \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
      5. Taylor expanded in x around inf

        \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
      6. Step-by-step derivation
        1. lower-/.f6499.5

          \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
      7. Applied rewrites99.5%

        \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
    3. Recombined 2 regimes into one program.
    4. Final simplification98.4%

      \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{\left(z + \left(y + \left(137.519416416 + \left(78.6994924154 + 4.16438922228 \cdot x\right) \cdot x\right) \cdot x\right) \cdot x\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x} \leq \infty:\\ \;\;\;\;\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2} \cdot \mathsf{fma}\left(x, x, -4\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
    5. Add Preprocessing

    Alternative 4: 98.0% accurate, 1.0× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \mathbf{if}\;x \leq -6.5 \cdot 10^{+55}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 6.8 \cdot 10^{+22}:\\ \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
    (FPCore (x y z)
     :precision binary64
     (let* ((t_0
             (*
              (- x)
              (fma
               (/
                (fma
                 (/
                  (fma (/ (- y 130977.50649958357) x) -1.0 -3655.1204654076414)
                  x)
                 -1.0
                 -110.1139242984811)
                x)
               -1.0
               -4.16438922228))))
       (if (<= x -6.5e+55)
         t_0
         (if (<= x 6.8e+22)
           (/
            (*
             (fma
              (fma (fma (fma 4.16438922228 x 78.6994924154) x 137.519416416) x y)
              x
              z)
             (- x 2.0))
            (fma
             (fma (fma (+ 43.3400022514 x) x 263.505074721) x 313.399215894)
             x
             47.066876606))
           t_0))))
    double code(double x, double y, double z) {
    	double t_0 = -x * fma((fma((fma(((y - 130977.50649958357) / x), -1.0, -3655.1204654076414) / x), -1.0, -110.1139242984811) / x), -1.0, -4.16438922228);
    	double tmp;
    	if (x <= -6.5e+55) {
    		tmp = t_0;
    	} else if (x <= 6.8e+22) {
    		tmp = (fma(fma(fma(fma(4.16438922228, x, 78.6994924154), x, 137.519416416), x, y), x, z) * (x - 2.0)) / fma(fma(fma((43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606);
    	} else {
    		tmp = t_0;
    	}
    	return tmp;
    }
    
    function code(x, y, z)
    	t_0 = Float64(Float64(-x) * fma(Float64(fma(Float64(fma(Float64(Float64(y - 130977.50649958357) / x), -1.0, -3655.1204654076414) / x), -1.0, -110.1139242984811) / x), -1.0, -4.16438922228))
    	tmp = 0.0
    	if (x <= -6.5e+55)
    		tmp = t_0;
    	elseif (x <= 6.8e+22)
    		tmp = Float64(Float64(fma(fma(fma(fma(4.16438922228, x, 78.6994924154), x, 137.519416416), x, y), x, z) * Float64(x - 2.0)) / fma(fma(fma(Float64(43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606));
    	else
    		tmp = t_0;
    	end
    	return tmp
    end
    
    code[x_, y_, z_] := Block[{t$95$0 = N[((-x) * N[(N[(N[(N[(N[(N[(N[(y - 130977.50649958357), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -3655.1204654076414), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -110.1139242984811), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -4.16438922228), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -6.5e+55], t$95$0, If[LessEqual[x, 6.8e+22], N[(N[(N[(N[(N[(N[(4.16438922228 * x + 78.6994924154), $MachinePrecision] * x + 137.519416416), $MachinePrecision] * x + y), $MachinePrecision] * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(N[(N[(N[(43.3400022514 + x), $MachinePrecision] * x + 263.505074721), $MachinePrecision] * x + 313.399215894), $MachinePrecision] * x + 47.066876606), $MachinePrecision]), $MachinePrecision], t$95$0]]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    t_0 := \left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\
    \mathbf{if}\;x \leq -6.5 \cdot 10^{+55}:\\
    \;\;\;\;t\_0\\
    
    \mathbf{elif}\;x \leq 6.8 \cdot 10^{+22}:\\
    \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}\\
    
    \mathbf{else}:\\
    \;\;\;\;t\_0\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if x < -6.50000000000000027e55 or 6.8e22 < x

      1. Initial program 5.0%

        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
      2. Add Preprocessing
      3. Taylor expanded in z around 0

        \[\leadsto \color{blue}{\frac{x \cdot \left(\left(y + x \cdot \left(\frac{4297481763}{31250000} + x \cdot \left(\frac{393497462077}{5000000000} + \frac{104109730557}{25000000000} \cdot x\right)\right)\right) \cdot \left(x - 2\right)\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
      4. Applied rewrites12.1%

        \[\leadsto \color{blue}{\left(\left(x - 2\right) \cdot \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right)\right) \cdot \frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}} \]
      5. Taylor expanded in x around -inf

        \[\leadsto -1 \cdot \color{blue}{\left(x \cdot \left(-1 \cdot \frac{-1 \cdot \frac{-1 \cdot \frac{y - \frac{409304707811198655637810418659684985388407301}{3125000000000000000000000000000000000000}}{x} - \frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x} - \frac{104109730557}{25000000000}\right)\right)} \]
      6. Step-by-step derivation
        1. Applied rewrites99.1%

          \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right) \cdot \color{blue}{\left(-x\right)} \]

        if -6.50000000000000027e55 < x < 6.8e22

        1. Initial program 99.1%

          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. Applied rewrites99.1%

            \[\leadsto \color{blue}{\frac{\left(x - 2\right) \cdot \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}} \]
        4. Recombined 2 regimes into one program.
        5. Final simplification99.1%

          \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -6.5 \cdot 10^{+55}:\\ \;\;\;\;\left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \mathbf{elif}\;x \leq 6.8 \cdot 10^{+22}:\\ \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}\\ \mathbf{else}:\\ \;\;\;\;\left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \end{array} \]
        6. Add Preprocessing

        Alternative 5: 96.4% accurate, 1.1× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 7.8 \cdot 10^{+21}:\\ \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
        (FPCore (x y z)
         :precision binary64
         (let* ((t_0
                 (*
                  (- x)
                  (fma
                   (/
                    (fma
                     (/
                      (fma (/ (- y 130977.50649958357) x) -1.0 -3655.1204654076414)
                      x)
                     -1.0
                     -110.1139242984811)
                    x)
                   -1.0
                   -4.16438922228))))
           (if (<= x -3.4e+21)
             t_0
             (if (<= x 7.8e+21)
               (/
                (* (fma (fma 137.519416416 x y) x z) (- x 2.0))
                (+
                 47.066876606
                 (*
                  (+ 313.399215894 (* (+ 263.505074721 (* (+ 43.3400022514 x) x)) x))
                  x)))
               t_0))))
        double code(double x, double y, double z) {
        	double t_0 = -x * fma((fma((fma(((y - 130977.50649958357) / x), -1.0, -3655.1204654076414) / x), -1.0, -110.1139242984811) / x), -1.0, -4.16438922228);
        	double tmp;
        	if (x <= -3.4e+21) {
        		tmp = t_0;
        	} else if (x <= 7.8e+21) {
        		tmp = (fma(fma(137.519416416, x, y), x, z) * (x - 2.0)) / (47.066876606 + ((313.399215894 + ((263.505074721 + ((43.3400022514 + x) * x)) * x)) * x));
        	} else {
        		tmp = t_0;
        	}
        	return tmp;
        }
        
        function code(x, y, z)
        	t_0 = Float64(Float64(-x) * fma(Float64(fma(Float64(fma(Float64(Float64(y - 130977.50649958357) / x), -1.0, -3655.1204654076414) / x), -1.0, -110.1139242984811) / x), -1.0, -4.16438922228))
        	tmp = 0.0
        	if (x <= -3.4e+21)
        		tmp = t_0;
        	elseif (x <= 7.8e+21)
        		tmp = Float64(Float64(fma(fma(137.519416416, x, y), x, z) * Float64(x - 2.0)) / Float64(47.066876606 + Float64(Float64(313.399215894 + Float64(Float64(263.505074721 + Float64(Float64(43.3400022514 + x) * x)) * x)) * x)));
        	else
        		tmp = t_0;
        	end
        	return tmp
        end
        
        code[x_, y_, z_] := Block[{t$95$0 = N[((-x) * N[(N[(N[(N[(N[(N[(N[(y - 130977.50649958357), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -3655.1204654076414), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -110.1139242984811), $MachinePrecision] / x), $MachinePrecision] * -1.0 + -4.16438922228), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -3.4e+21], t$95$0, If[LessEqual[x, 7.8e+21], N[(N[(N[(N[(137.519416416 * x + y), $MachinePrecision] * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(47.066876606 + N[(N[(313.399215894 + N[(N[(263.505074721 + N[(N[(43.3400022514 + x), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        t_0 := \left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\
        \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
        \;\;\;\;t\_0\\
        
        \mathbf{elif}\;x \leq 7.8 \cdot 10^{+21}:\\
        \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\
        
        \mathbf{else}:\\
        \;\;\;\;t\_0\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 2 regimes
        2. if x < -3.4e21 or 7.8e21 < x

          1. Initial program 9.3%

            \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
          2. Add Preprocessing
          3. Taylor expanded in z around 0

            \[\leadsto \color{blue}{\frac{x \cdot \left(\left(y + x \cdot \left(\frac{4297481763}{31250000} + x \cdot \left(\frac{393497462077}{5000000000} + \frac{104109730557}{25000000000} \cdot x\right)\right)\right) \cdot \left(x - 2\right)\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
          4. Applied rewrites15.1%

            \[\leadsto \color{blue}{\left(\left(x - 2\right) \cdot \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right)\right) \cdot \frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}} \]
          5. Taylor expanded in x around -inf

            \[\leadsto -1 \cdot \color{blue}{\left(x \cdot \left(-1 \cdot \frac{-1 \cdot \frac{-1 \cdot \frac{y - \frac{409304707811198655637810418659684985388407301}{3125000000000000000000000000000000000000}}{x} - \frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x} - \frac{104109730557}{25000000000}\right)\right)} \]
          6. Step-by-step derivation
            1. Applied rewrites98.2%

              \[\leadsto \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right) \cdot \color{blue}{\left(-x\right)} \]

            if -3.4e21 < x < 7.8e21

            1. Initial program 99.1%

              \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
            2. Add Preprocessing
            3. Taylor expanded in x around 0

              \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(z + x \cdot \left(y + \frac{4297481763}{31250000} \cdot x\right)\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
            4. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(x \cdot \left(y + \frac{4297481763}{31250000} \cdot x\right) + z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
              2. *-commutativeN/A

                \[\leadsto \frac{\left(x - 2\right) \cdot \left(\color{blue}{\left(y + \frac{4297481763}{31250000} \cdot x\right) \cdot x} + z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
              3. lower-fma.f64N/A

                \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y + \frac{4297481763}{31250000} \cdot x, x, z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
              4. +-commutativeN/A

                \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(\color{blue}{\frac{4297481763}{31250000} \cdot x + y}, x, z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
              5. lower-fma.f6498.4

                \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(137.519416416, x, y\right)}, x, z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
            5. Applied rewrites98.4%

              \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
          7. Recombined 2 regimes into one program.
          8. Final simplification98.4%

            \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;\left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \mathbf{elif}\;x \leq 7.8 \cdot 10^{+21}:\\ \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;\left(-x\right) \cdot \mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{\mathsf{fma}\left(\frac{y - 130977.50649958357}{x}, -1, -3655.1204654076414\right)}{x}, -1, -110.1139242984811\right)}{x}, -1, -4.16438922228\right)\\ \end{array} \]
          9. Add Preprocessing

          Alternative 6: 92.2% accurate, 1.1× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 7.2 \cdot 10^{-26}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{elif}\;x \leq 5 \cdot 10^{+23}:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
          (FPCore (x y z)
           :precision binary64
           (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
             (if (<= x -3.4e+21)
               t_0
               (if (<= x 7.2e-26)
                 (fma
                  (fma
                   (fma 0.3041881842569256 y -5.843575199059173)
                   x
                   (fma -0.0424927283095952 y (* 0.3041881842569256 z)))
                  x
                  (* -0.0424927283095952 z))
                 (if (<= x 5e+23)
                   (/
                    (* (fma y x z) (- x 2.0))
                    (+
                     47.066876606
                     (*
                      (+ 313.399215894 (* (+ 263.505074721 (* (+ 43.3400022514 x) x)) x))
                      x)))
                   t_0)))))
          double code(double x, double y, double z) {
          	double t_0 = 1.0 / (0.24013125253755718 / x);
          	double tmp;
          	if (x <= -3.4e+21) {
          		tmp = t_0;
          	} else if (x <= 7.2e-26) {
          		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, (0.3041881842569256 * z))), x, (-0.0424927283095952 * z));
          	} else if (x <= 5e+23) {
          		tmp = (fma(y, x, z) * (x - 2.0)) / (47.066876606 + ((313.399215894 + ((263.505074721 + ((43.3400022514 + x) * x)) * x)) * x));
          	} else {
          		tmp = t_0;
          	}
          	return tmp;
          }
          
          function code(x, y, z)
          	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
          	tmp = 0.0
          	if (x <= -3.4e+21)
          		tmp = t_0;
          	elseif (x <= 7.2e-26)
          		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, Float64(0.3041881842569256 * z))), x, Float64(-0.0424927283095952 * z));
          	elseif (x <= 5e+23)
          		tmp = Float64(Float64(fma(y, x, z) * Float64(x - 2.0)) / Float64(47.066876606 + Float64(Float64(313.399215894 + Float64(Float64(263.505074721 + Float64(Float64(43.3400022514 + x) * x)) * x)) * x)));
          	else
          		tmp = t_0;
          	end
          	return tmp
          end
          
          code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -3.4e+21], t$95$0, If[LessEqual[x, 7.2e-26], N[(N[(N[(0.3041881842569256 * y + -5.843575199059173), $MachinePrecision] * x + N[(-0.0424927283095952 * y + N[(0.3041881842569256 * z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], If[LessEqual[x, 5e+23], N[(N[(N[(y * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(47.066876606 + N[(N[(313.399215894 + N[(N[(263.505074721 + N[(N[(43.3400022514 + x), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
          \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
          \;\;\;\;t\_0\\
          
          \mathbf{elif}\;x \leq 7.2 \cdot 10^{-26}:\\
          \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\
          
          \mathbf{elif}\;x \leq 5 \cdot 10^{+23}:\\
          \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\
          
          \mathbf{else}:\\
          \;\;\;\;t\_0\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 3 regimes
          2. if x < -3.4e21 or 4.9999999999999999e23 < x

            1. Initial program 8.4%

              \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
            2. Add Preprocessing
            3. Applied rewrites15.3%

              \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
            4. Applied rewrites15.2%

              \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
            5. Taylor expanded in x around inf

              \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
            6. Step-by-step derivation
              1. lower-/.f6493.3

                \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
            7. Applied rewrites93.3%

              \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

            if -3.4e21 < x < 7.2000000000000003e-26

            1. Initial program 99.1%

              \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
            2. Add Preprocessing
            3. Applied rewrites99.7%

              \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
            4. Taylor expanded in x around 0

              \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)} \]
            5. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \color{blue}{x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
              2. *-commutativeN/A

                \[\leadsto \color{blue}{\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
              3. lower-fma.f64N/A

                \[\leadsto \color{blue}{\mathsf{fma}\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
            6. Applied rewrites98.7%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.0106231820773988, z, -5.843575199059173\right) - \mathsf{fma}\left(7.158593866711955, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), -0.37936750221396215 \cdot z\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)} \]
            7. Taylor expanded in z around 0

              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(-1 \cdot \left(\frac{137519416416}{23533438303} + \frac{-168466327098500000000}{553822718361107519809} \cdot y\right), x, \mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \frac{168466327098500000000}{553822718361107519809} \cdot z\right)\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
            8. Step-by-step derivation
              1. Applied rewrites98.7%

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right) \]

              if 7.2000000000000003e-26 < x < 4.9999999999999999e23

              1. Initial program 99.2%

                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              2. Add Preprocessing
              3. Taylor expanded in x around 0

                \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(z + x \cdot y\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
              4. Step-by-step derivation
                1. +-commutativeN/A

                  \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(x \cdot y + z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                2. *-commutativeN/A

                  \[\leadsto \frac{\left(x - 2\right) \cdot \left(\color{blue}{y \cdot x} + z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                3. lower-fma.f6492.2

                  \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              5. Applied rewrites92.2%

                \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
            9. Recombined 3 regimes into one program.
            10. Final simplification96.0%

              \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 7.2 \cdot 10^{-26}:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{elif}\;x \leq 5 \cdot 10^{+23}:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
            11. Add Preprocessing

            Alternative 7: 94.0% accurate, 1.1× speedup?

            \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -7.2 \cdot 10^{+22}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 5 \cdot 10^{+23}:\\ \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
            (FPCore (x y z)
             :precision binary64
             (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
               (if (<= x -7.2e+22)
                 t_0
                 (if (<= x 5e+23)
                   (/
                    (* (fma (fma 137.519416416 x y) x z) (- x 2.0))
                    (+
                     47.066876606
                     (*
                      (+ 313.399215894 (* (+ 263.505074721 (* (+ 43.3400022514 x) x)) x))
                      x)))
                   t_0))))
            double code(double x, double y, double z) {
            	double t_0 = 1.0 / (0.24013125253755718 / x);
            	double tmp;
            	if (x <= -7.2e+22) {
            		tmp = t_0;
            	} else if (x <= 5e+23) {
            		tmp = (fma(fma(137.519416416, x, y), x, z) * (x - 2.0)) / (47.066876606 + ((313.399215894 + ((263.505074721 + ((43.3400022514 + x) * x)) * x)) * x));
            	} else {
            		tmp = t_0;
            	}
            	return tmp;
            }
            
            function code(x, y, z)
            	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
            	tmp = 0.0
            	if (x <= -7.2e+22)
            		tmp = t_0;
            	elseif (x <= 5e+23)
            		tmp = Float64(Float64(fma(fma(137.519416416, x, y), x, z) * Float64(x - 2.0)) / Float64(47.066876606 + Float64(Float64(313.399215894 + Float64(Float64(263.505074721 + Float64(Float64(43.3400022514 + x) * x)) * x)) * x)));
            	else
            		tmp = t_0;
            	end
            	return tmp
            end
            
            code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -7.2e+22], t$95$0, If[LessEqual[x, 5e+23], N[(N[(N[(N[(137.519416416 * x + y), $MachinePrecision] * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(47.066876606 + N[(N[(313.399215894 + N[(N[(263.505074721 + N[(N[(43.3400022514 + x), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]
            
            \begin{array}{l}
            
            \\
            \begin{array}{l}
            t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
            \mathbf{if}\;x \leq -7.2 \cdot 10^{+22}:\\
            \;\;\;\;t\_0\\
            
            \mathbf{elif}\;x \leq 5 \cdot 10^{+23}:\\
            \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\
            
            \mathbf{else}:\\
            \;\;\;\;t\_0\\
            
            
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 2 regimes
            2. if x < -7.2e22 or 4.9999999999999999e23 < x

              1. Initial program 8.4%

                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              2. Add Preprocessing
              3. Applied rewrites15.3%

                \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
              4. Applied rewrites15.2%

                \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
              5. Taylor expanded in x around inf

                \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
              6. Step-by-step derivation
                1. lower-/.f6493.3

                  \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
              7. Applied rewrites93.3%

                \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

              if -7.2e22 < x < 4.9999999999999999e23

              1. Initial program 99.1%

                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              2. Add Preprocessing
              3. Taylor expanded in x around 0

                \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(z + x \cdot \left(y + \frac{4297481763}{31250000} \cdot x\right)\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
              4. Step-by-step derivation
                1. +-commutativeN/A

                  \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(x \cdot \left(y + \frac{4297481763}{31250000} \cdot x\right) + z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                2. *-commutativeN/A

                  \[\leadsto \frac{\left(x - 2\right) \cdot \left(\color{blue}{\left(y + \frac{4297481763}{31250000} \cdot x\right) \cdot x} + z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                3. lower-fma.f64N/A

                  \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y + \frac{4297481763}{31250000} \cdot x, x, z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                4. +-commutativeN/A

                  \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(\color{blue}{\frac{4297481763}{31250000} \cdot x + y}, x, z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                5. lower-fma.f6498.5

                  \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(137.519416416, x, y\right)}, x, z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              5. Applied rewrites98.5%

                \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
            3. Recombined 2 regimes into one program.
            4. Final simplification96.2%

              \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -7.2 \cdot 10^{+22}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 5 \cdot 10^{+23}:\\ \;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(137.519416416, x, y\right), x, z\right) \cdot \left(x - 2\right)}{47.066876606 + \left(313.399215894 + \left(263.505074721 + \left(43.3400022514 + x\right) \cdot x\right) \cdot x\right) \cdot x}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
            5. Add Preprocessing

            Alternative 8: 90.8% accurate, 1.2× speedup?

            \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 3.55:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{elif}\;x \leq 1.95 \cdot 10^{+68}:\\ \;\;\;\;\left(\frac{x - 2}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot x\right) \cdot y\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
            (FPCore (x y z)
             :precision binary64
             (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
               (if (<= x -3.4e+21)
                 t_0
                 (if (<= x 3.55)
                   (fma
                    (fma
                     (fma 0.3041881842569256 y -5.843575199059173)
                     x
                     (fma -0.0424927283095952 y (* 0.3041881842569256 z)))
                    x
                    (* -0.0424927283095952 z))
                   (if (<= x 1.95e+68)
                     (*
                      (*
                       (/
                        (- x 2.0)
                        (fma
                         (fma (fma (+ 43.3400022514 x) x 263.505074721) x 313.399215894)
                         x
                         47.066876606))
                       x)
                      y)
                     t_0)))))
            double code(double x, double y, double z) {
            	double t_0 = 1.0 / (0.24013125253755718 / x);
            	double tmp;
            	if (x <= -3.4e+21) {
            		tmp = t_0;
            	} else if (x <= 3.55) {
            		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, (0.3041881842569256 * z))), x, (-0.0424927283095952 * z));
            	} else if (x <= 1.95e+68) {
            		tmp = (((x - 2.0) / fma(fma(fma((43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) * x) * y;
            	} else {
            		tmp = t_0;
            	}
            	return tmp;
            }
            
            function code(x, y, z)
            	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
            	tmp = 0.0
            	if (x <= -3.4e+21)
            		tmp = t_0;
            	elseif (x <= 3.55)
            		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, Float64(0.3041881842569256 * z))), x, Float64(-0.0424927283095952 * z));
            	elseif (x <= 1.95e+68)
            		tmp = Float64(Float64(Float64(Float64(x - 2.0) / fma(fma(fma(Float64(43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) * x) * y);
            	else
            		tmp = t_0;
            	end
            	return tmp
            end
            
            code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -3.4e+21], t$95$0, If[LessEqual[x, 3.55], N[(N[(N[(0.3041881842569256 * y + -5.843575199059173), $MachinePrecision] * x + N[(-0.0424927283095952 * y + N[(0.3041881842569256 * z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], If[LessEqual[x, 1.95e+68], N[(N[(N[(N[(x - 2.0), $MachinePrecision] / N[(N[(N[(N[(43.3400022514 + x), $MachinePrecision] * x + 263.505074721), $MachinePrecision] * x + 313.399215894), $MachinePrecision] * x + 47.066876606), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision] * y), $MachinePrecision], t$95$0]]]]
            
            \begin{array}{l}
            
            \\
            \begin{array}{l}
            t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
            \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
            \;\;\;\;t\_0\\
            
            \mathbf{elif}\;x \leq 3.55:\\
            \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\
            
            \mathbf{elif}\;x \leq 1.95 \cdot 10^{+68}:\\
            \;\;\;\;\left(\frac{x - 2}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot x\right) \cdot y\\
            
            \mathbf{else}:\\
            \;\;\;\;t\_0\\
            
            
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 3 regimes
            2. if x < -3.4e21 or 1.95000000000000009e68 < x

              1. Initial program 6.0%

                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              2. Add Preprocessing
              3. Applied rewrites11.5%

                \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
              4. Applied rewrites11.4%

                \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
              5. Taylor expanded in x around inf

                \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
              6. Step-by-step derivation
                1. lower-/.f6496.7

                  \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
              7. Applied rewrites96.7%

                \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

              if -3.4e21 < x < 3.5499999999999998

              1. Initial program 99.1%

                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
              2. Add Preprocessing
              3. Applied rewrites99.7%

                \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
              4. Taylor expanded in x around 0

                \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)} \]
              5. Step-by-step derivation
                1. +-commutativeN/A

                  \[\leadsto \color{blue}{x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                2. *-commutativeN/A

                  \[\leadsto \color{blue}{\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                3. lower-fma.f64N/A

                  \[\leadsto \color{blue}{\mathsf{fma}\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
              6. Applied rewrites97.3%

                \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.0106231820773988, z, -5.843575199059173\right) - \mathsf{fma}\left(7.158593866711955, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), -0.37936750221396215 \cdot z\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)} \]
              7. Taylor expanded in z around 0

                \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(-1 \cdot \left(\frac{137519416416}{23533438303} + \frac{-168466327098500000000}{553822718361107519809} \cdot y\right), x, \mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \frac{168466327098500000000}{553822718361107519809} \cdot z\right)\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
              8. Step-by-step derivation
                1. Applied rewrites97.1%

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right) \]

                if 3.5499999999999998 < x < 1.95000000000000009e68

                1. Initial program 72.0%

                  \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                2. Add Preprocessing
                3. Taylor expanded in y around inf

                  \[\leadsto \color{blue}{\frac{x \cdot \left(y \cdot \left(x - 2\right)\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
                4. Step-by-step derivation
                  1. *-commutativeN/A

                    \[\leadsto \frac{x \cdot \color{blue}{\left(\left(x - 2\right) \cdot y\right)}}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)} \]
                  2. associate-*r*N/A

                    \[\leadsto \frac{\color{blue}{\left(x \cdot \left(x - 2\right)\right) \cdot y}}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)} \]
                  3. associate-*l/N/A

                    \[\leadsto \color{blue}{\frac{x \cdot \left(x - 2\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)} \cdot y} \]
                  4. lower-*.f64N/A

                    \[\leadsto \color{blue}{\frac{x \cdot \left(x - 2\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)} \cdot y} \]
                5. Applied rewrites71.9%

                  \[\leadsto \color{blue}{\left(\frac{x - 2}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot x\right) \cdot y} \]
              9. Recombined 3 regimes into one program.
              10. Add Preprocessing

              Alternative 9: 91.4% accurate, 1.2× speedup?

              \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 3.55:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{elif}\;x \leq 4.1 \cdot 10^{+48}:\\ \;\;\;\;\frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot \left(y \cdot \left(x - 2\right)\right)\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
              (FPCore (x y z)
               :precision binary64
               (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
                 (if (<= x -3.4e+21)
                   t_0
                   (if (<= x 3.55)
                     (fma
                      (fma
                       (fma 0.3041881842569256 y -5.843575199059173)
                       x
                       (fma -0.0424927283095952 y (* 0.3041881842569256 z)))
                      x
                      (* -0.0424927283095952 z))
                     (if (<= x 4.1e+48)
                       (*
                        (/
                         x
                         (fma
                          (fma (fma (+ 43.3400022514 x) x 263.505074721) x 313.399215894)
                          x
                          47.066876606))
                        (* y (- x 2.0)))
                       t_0)))))
              double code(double x, double y, double z) {
              	double t_0 = 1.0 / (0.24013125253755718 / x);
              	double tmp;
              	if (x <= -3.4e+21) {
              		tmp = t_0;
              	} else if (x <= 3.55) {
              		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, (0.3041881842569256 * z))), x, (-0.0424927283095952 * z));
              	} else if (x <= 4.1e+48) {
              		tmp = (x / fma(fma(fma((43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) * (y * (x - 2.0));
              	} else {
              		tmp = t_0;
              	}
              	return tmp;
              }
              
              function code(x, y, z)
              	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
              	tmp = 0.0
              	if (x <= -3.4e+21)
              		tmp = t_0;
              	elseif (x <= 3.55)
              		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, Float64(0.3041881842569256 * z))), x, Float64(-0.0424927283095952 * z));
              	elseif (x <= 4.1e+48)
              		tmp = Float64(Float64(x / fma(fma(fma(Float64(43.3400022514 + x), x, 263.505074721), x, 313.399215894), x, 47.066876606)) * Float64(y * Float64(x - 2.0)));
              	else
              		tmp = t_0;
              	end
              	return tmp
              end
              
              code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -3.4e+21], t$95$0, If[LessEqual[x, 3.55], N[(N[(N[(0.3041881842569256 * y + -5.843575199059173), $MachinePrecision] * x + N[(-0.0424927283095952 * y + N[(0.3041881842569256 * z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], If[LessEqual[x, 4.1e+48], N[(N[(x / N[(N[(N[(N[(43.3400022514 + x), $MachinePrecision] * x + 263.505074721), $MachinePrecision] * x + 313.399215894), $MachinePrecision] * x + 47.066876606), $MachinePrecision]), $MachinePrecision] * N[(y * N[(x - 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]]
              
              \begin{array}{l}
              
              \\
              \begin{array}{l}
              t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
              \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
              \;\;\;\;t\_0\\
              
              \mathbf{elif}\;x \leq 3.55:\\
              \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\
              
              \mathbf{elif}\;x \leq 4.1 \cdot 10^{+48}:\\
              \;\;\;\;\frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot \left(y \cdot \left(x - 2\right)\right)\\
              
              \mathbf{else}:\\
              \;\;\;\;t\_0\\
              
              
              \end{array}
              \end{array}
              
              Derivation
              1. Split input into 3 regimes
              2. if x < -3.4e21 or 4.1000000000000003e48 < x

                1. Initial program 7.6%

                  \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                2. Add Preprocessing
                3. Applied rewrites13.8%

                  \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                4. Applied rewrites13.7%

                  \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
                5. Taylor expanded in x around inf

                  \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
                6. Step-by-step derivation
                  1. lower-/.f6494.1

                    \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
                7. Applied rewrites94.1%

                  \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

                if -3.4e21 < x < 3.5499999999999998

                1. Initial program 99.1%

                  \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                2. Add Preprocessing
                3. Applied rewrites99.7%

                  \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                4. Taylor expanded in x around 0

                  \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)} \]
                5. Step-by-step derivation
                  1. +-commutativeN/A

                    \[\leadsto \color{blue}{x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                  2. *-commutativeN/A

                    \[\leadsto \color{blue}{\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                  3. lower-fma.f64N/A

                    \[\leadsto \color{blue}{\mathsf{fma}\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                6. Applied rewrites97.3%

                  \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.0106231820773988, z, -5.843575199059173\right) - \mathsf{fma}\left(7.158593866711955, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), -0.37936750221396215 \cdot z\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)} \]
                7. Taylor expanded in z around 0

                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(-1 \cdot \left(\frac{137519416416}{23533438303} + \frac{-168466327098500000000}{553822718361107519809} \cdot y\right), x, \mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \frac{168466327098500000000}{553822718361107519809} \cdot z\right)\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                8. Step-by-step derivation
                  1. Applied rewrites97.1%

                    \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right) \]

                  if 3.5499999999999998 < x < 4.1000000000000003e48

                  1. Initial program 88.5%

                    \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                  2. Add Preprocessing
                  3. Taylor expanded in z around 0

                    \[\leadsto \color{blue}{\frac{x \cdot \left(\left(y + x \cdot \left(\frac{4297481763}{31250000} + x \cdot \left(\frac{393497462077}{5000000000} + \frac{104109730557}{25000000000} \cdot x\right)\right)\right) \cdot \left(x - 2\right)\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
                  4. Applied rewrites99.4%

                    \[\leadsto \color{blue}{\left(\left(x - 2\right) \cdot \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right)\right) \cdot \frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}} \]
                  5. Taylor expanded in y around inf

                    \[\leadsto \left(y \cdot \left(x - 2\right)\right) \cdot \frac{\color{blue}{x}}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right), x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)} \]
                  6. Step-by-step derivation
                    1. Applied rewrites78.2%

                      \[\leadsto \left(\left(x - 2\right) \cdot y\right) \cdot \frac{\color{blue}{x}}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \]
                  7. Recombined 3 regimes into one program.
                  8. Final simplification95.2%

                    \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 3.55:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{elif}\;x \leq 4.1 \cdot 10^{+48}:\\ \;\;\;\;\frac{x}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \cdot \left(y \cdot \left(x - 2\right)\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
                  9. Add Preprocessing

                  Alternative 10: 91.6% accurate, 1.7× speedup?

                  \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 480:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{else}:\\ \;\;\;\;\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x\\ \end{array} \end{array} \]
                  (FPCore (x y z)
                   :precision binary64
                   (if (<= x -3.4e+21)
                     (/ 1.0 (/ 0.24013125253755718 x))
                     (if (<= x 480.0)
                       (fma
                        (fma
                         (fma 0.3041881842569256 y -5.843575199059173)
                         x
                         (fma -0.0424927283095952 y (* 0.3041881842569256 z)))
                        x
                        (* -0.0424927283095952 z))
                       (*
                        (+ (/ (- (/ 3655.1204654076414 x) 110.1139242984811) x) 4.16438922228)
                        x))))
                  double code(double x, double y, double z) {
                  	double tmp;
                  	if (x <= -3.4e+21) {
                  		tmp = 1.0 / (0.24013125253755718 / x);
                  	} else if (x <= 480.0) {
                  		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, (0.3041881842569256 * z))), x, (-0.0424927283095952 * z));
                  	} else {
                  		tmp = ((((3655.1204654076414 / x) - 110.1139242984811) / x) + 4.16438922228) * x;
                  	}
                  	return tmp;
                  }
                  
                  function code(x, y, z)
                  	tmp = 0.0
                  	if (x <= -3.4e+21)
                  		tmp = Float64(1.0 / Float64(0.24013125253755718 / x));
                  	elseif (x <= 480.0)
                  		tmp = fma(fma(fma(0.3041881842569256, y, -5.843575199059173), x, fma(-0.0424927283095952, y, Float64(0.3041881842569256 * z))), x, Float64(-0.0424927283095952 * z));
                  	else
                  		tmp = Float64(Float64(Float64(Float64(Float64(3655.1204654076414 / x) - 110.1139242984811) / x) + 4.16438922228) * x);
                  	end
                  	return tmp
                  end
                  
                  code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision], If[LessEqual[x, 480.0], N[(N[(N[(0.3041881842569256 * y + -5.843575199059173), $MachinePrecision] * x + N[(-0.0424927283095952 * y + N[(0.3041881842569256 * z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[(N[(3655.1204654076414 / x), $MachinePrecision] - 110.1139242984811), $MachinePrecision] / x), $MachinePrecision] + 4.16438922228), $MachinePrecision] * x), $MachinePrecision]]]
                  
                  \begin{array}{l}
                  
                  \\
                  \begin{array}{l}
                  \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                  \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\
                  
                  \mathbf{elif}\;x \leq 480:\\
                  \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)\\
                  
                  \mathbf{else}:\\
                  \;\;\;\;\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x\\
                  
                  
                  \end{array}
                  \end{array}
                  
                  Derivation
                  1. Split input into 3 regimes
                  2. if x < -3.4e21

                    1. Initial program 11.2%

                      \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                    2. Add Preprocessing
                    3. Applied rewrites19.9%

                      \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                    4. Applied rewrites19.8%

                      \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
                    5. Taylor expanded in x around inf

                      \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
                    6. Step-by-step derivation
                      1. lower-/.f6494.2

                        \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
                    7. Applied rewrites94.2%

                      \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

                    if -3.4e21 < x < 480

                    1. Initial program 99.0%

                      \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                    2. Add Preprocessing
                    3. Applied rewrites99.7%

                      \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                    4. Taylor expanded in x around 0

                      \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)} \]
                    5. Step-by-step derivation
                      1. +-commutativeN/A

                        \[\leadsto \color{blue}{x \cdot \left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                      2. *-commutativeN/A

                        \[\leadsto \color{blue}{\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                      3. lower-fma.f64N/A

                        \[\leadsto \color{blue}{\mathsf{fma}\left(\left(\frac{-1000000000}{23533438303} \cdot y + x \cdot \left(\frac{250000000}{23533438303} \cdot \left(z - \frac{4297481763}{7812500}\right) - \left(\frac{-210102341334000000000}{553822718361107519809} \cdot z + \frac{336932654197}{47066876606} \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)\right)\right) - \frac{-168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                    6. Applied rewrites96.1%

                      \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.0106231820773988, z, -5.843575199059173\right) - \mathsf{fma}\left(7.158593866711955, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), -0.37936750221396215 \cdot z\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right)} \]
                    7. Taylor expanded in z around 0

                      \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(-1 \cdot \left(\frac{137519416416}{23533438303} + \frac{-168466327098500000000}{553822718361107519809} \cdot y\right), x, \mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \frac{168466327098500000000}{553822718361107519809} \cdot z\right)\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                    8. Step-by-step derivation
                      1. Applied rewrites95.9%

                        \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, y, -5.843575199059173\right), x, \mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right)\right), x, -0.0424927283095952 \cdot z\right) \]

                      if 480 < x

                      1. Initial program 13.4%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Taylor expanded in x around inf

                        \[\leadsto \color{blue}{x \cdot \left(\left(\frac{104109730557}{25000000000} + \frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}}\right) - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \]
                      4. Step-by-step derivation
                        1. *-commutativeN/A

                          \[\leadsto \color{blue}{\left(\left(\frac{104109730557}{25000000000} + \frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}}\right) - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) \cdot x} \]
                        2. lower-*.f64N/A

                          \[\leadsto \color{blue}{\left(\left(\frac{104109730557}{25000000000} + \frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}}\right) - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) \cdot x} \]
                        3. associate--l+N/A

                          \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} + \left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)} \cdot x \]
                        4. +-commutativeN/A

                          \[\leadsto \color{blue}{\left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                        5. lower-+.f64N/A

                          \[\leadsto \color{blue}{\left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                        6. unpow2N/A

                          \[\leadsto \left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{\color{blue}{x \cdot x}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        7. associate-/r*N/A

                          \[\leadsto \left(\left(\color{blue}{\frac{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{x}}{x}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        8. metadata-evalN/A

                          \[\leadsto \left(\left(\frac{\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot 1}}{x}}{x} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        9. associate-*r/N/A

                          \[\leadsto \left(\left(\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x}}}{x} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        10. associate-*r/N/A

                          \[\leadsto \left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x}}{x} - \color{blue}{\frac{\frac{13764240537310136880149}{125000000000000000000} \cdot 1}{x}}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        11. metadata-evalN/A

                          \[\leadsto \left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x}}{x} - \frac{\color{blue}{\frac{13764240537310136880149}{125000000000000000000}}}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        12. div-subN/A

                          \[\leadsto \left(\color{blue}{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x}} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        13. lower-/.f64N/A

                          \[\leadsto \left(\color{blue}{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x}} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        14. lower--.f64N/A

                          \[\leadsto \left(\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x} - \frac{13764240537310136880149}{125000000000000000000}}}{x} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        15. associate-*r/N/A

                          \[\leadsto \left(\frac{\color{blue}{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot 1}{x}} - \frac{13764240537310136880149}{125000000000000000000}}{x} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        16. metadata-evalN/A

                          \[\leadsto \left(\frac{\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        17. lower-/.f6485.6

                          \[\leadsto \left(\frac{\color{blue}{\frac{3655.1204654076414}{x}} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x \]
                      5. Applied rewrites85.6%

                        \[\leadsto \color{blue}{\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x} \]
                    9. Recombined 3 regimes into one program.
                    10. Add Preprocessing

                    Alternative 11: 89.5% accurate, 1.7× speedup?

                    \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -36:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 480:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}\\ \mathbf{else}:\\ \;\;\;\;\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x\\ \end{array} \end{array} \]
                    (FPCore (x y z)
                     :precision binary64
                     (if (<= x -36.0)
                       (/ 1.0 (/ 0.24013125253755718 x))
                       (if (<= x 480.0)
                         (/ (* (fma y x z) (- x 2.0)) (fma 313.399215894 x 47.066876606))
                         (*
                          (+ (/ (- (/ 3655.1204654076414 x) 110.1139242984811) x) 4.16438922228)
                          x))))
                    double code(double x, double y, double z) {
                    	double tmp;
                    	if (x <= -36.0) {
                    		tmp = 1.0 / (0.24013125253755718 / x);
                    	} else if (x <= 480.0) {
                    		tmp = (fma(y, x, z) * (x - 2.0)) / fma(313.399215894, x, 47.066876606);
                    	} else {
                    		tmp = ((((3655.1204654076414 / x) - 110.1139242984811) / x) + 4.16438922228) * x;
                    	}
                    	return tmp;
                    }
                    
                    function code(x, y, z)
                    	tmp = 0.0
                    	if (x <= -36.0)
                    		tmp = Float64(1.0 / Float64(0.24013125253755718 / x));
                    	elseif (x <= 480.0)
                    		tmp = Float64(Float64(fma(y, x, z) * Float64(x - 2.0)) / fma(313.399215894, x, 47.066876606));
                    	else
                    		tmp = Float64(Float64(Float64(Float64(Float64(3655.1204654076414 / x) - 110.1139242984811) / x) + 4.16438922228) * x);
                    	end
                    	return tmp
                    end
                    
                    code[x_, y_, z_] := If[LessEqual[x, -36.0], N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision], If[LessEqual[x, 480.0], N[(N[(N[(y * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(313.399215894 * x + 47.066876606), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[(N[(3655.1204654076414 / x), $MachinePrecision] - 110.1139242984811), $MachinePrecision] / x), $MachinePrecision] + 4.16438922228), $MachinePrecision] * x), $MachinePrecision]]]
                    
                    \begin{array}{l}
                    
                    \\
                    \begin{array}{l}
                    \mathbf{if}\;x \leq -36:\\
                    \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\
                    
                    \mathbf{elif}\;x \leq 480:\\
                    \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}\\
                    
                    \mathbf{else}:\\
                    \;\;\;\;\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x\\
                    
                    
                    \end{array}
                    \end{array}
                    
                    Derivation
                    1. Split input into 3 regimes
                    2. if x < -36

                      1. Initial program 11.1%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Applied rewrites21.3%

                        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                      4. Applied rewrites21.2%

                        \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
                      5. Taylor expanded in x around inf

                        \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
                      6. Step-by-step derivation
                        1. lower-/.f6492.5

                          \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
                      7. Applied rewrites92.5%

                        \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

                      if -36 < x < 480

                      1. Initial program 99.7%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Taylor expanded in x around 0

                        \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(z + x \cdot y\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                      4. Step-by-step derivation
                        1. +-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(x \cdot y + z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                        2. *-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \left(\color{blue}{y \cdot x} + z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                        3. lower-fma.f6496.3

                          \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      5. Applied rewrites96.3%

                        \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      6. Taylor expanded in x around 0

                        \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\frac{23533438303}{500000000} + \frac{156699607947}{500000000} \cdot x}} \]
                      7. Step-by-step derivation
                        1. +-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\frac{156699607947}{500000000} \cdot x + \frac{23533438303}{500000000}}} \]
                        2. lower-fma.f6493.7

                          \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}} \]
                      8. Applied rewrites93.7%

                        \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}} \]

                      if 480 < x

                      1. Initial program 13.4%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Taylor expanded in x around inf

                        \[\leadsto \color{blue}{x \cdot \left(\left(\frac{104109730557}{25000000000} + \frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}}\right) - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \]
                      4. Step-by-step derivation
                        1. *-commutativeN/A

                          \[\leadsto \color{blue}{\left(\left(\frac{104109730557}{25000000000} + \frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}}\right) - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) \cdot x} \]
                        2. lower-*.f64N/A

                          \[\leadsto \color{blue}{\left(\left(\frac{104109730557}{25000000000} + \frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}}\right) - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) \cdot x} \]
                        3. associate--l+N/A

                          \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} + \left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)} \cdot x \]
                        4. +-commutativeN/A

                          \[\leadsto \color{blue}{\left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                        5. lower-+.f64N/A

                          \[\leadsto \color{blue}{\left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{{x}^{2}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                        6. unpow2N/A

                          \[\leadsto \left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{\color{blue}{x \cdot x}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        7. associate-/r*N/A

                          \[\leadsto \left(\left(\color{blue}{\frac{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}{x}}{x}} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        8. metadata-evalN/A

                          \[\leadsto \left(\left(\frac{\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot 1}}{x}}{x} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        9. associate-*r/N/A

                          \[\leadsto \left(\left(\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x}}}{x} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        10. associate-*r/N/A

                          \[\leadsto \left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x}}{x} - \color{blue}{\frac{\frac{13764240537310136880149}{125000000000000000000} \cdot 1}{x}}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        11. metadata-evalN/A

                          \[\leadsto \left(\left(\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x}}{x} - \frac{\color{blue}{\frac{13764240537310136880149}{125000000000000000000}}}{x}\right) + \frac{104109730557}{25000000000}\right) \cdot x \]
                        12. div-subN/A

                          \[\leadsto \left(\color{blue}{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x}} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        13. lower-/.f64N/A

                          \[\leadsto \left(\color{blue}{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x}} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        14. lower--.f64N/A

                          \[\leadsto \left(\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot \frac{1}{x} - \frac{13764240537310136880149}{125000000000000000000}}}{x} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        15. associate-*r/N/A

                          \[\leadsto \left(\frac{\color{blue}{\frac{\frac{2284450290879775841688574159837293}{625000000000000000000000000000} \cdot 1}{x}} - \frac{13764240537310136880149}{125000000000000000000}}{x} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        16. metadata-evalN/A

                          \[\leadsto \left(\frac{\frac{\color{blue}{\frac{2284450290879775841688574159837293}{625000000000000000000000000000}}}{x} - \frac{13764240537310136880149}{125000000000000000000}}{x} + \frac{104109730557}{25000000000}\right) \cdot x \]
                        17. lower-/.f6485.6

                          \[\leadsto \left(\frac{\color{blue}{\frac{3655.1204654076414}{x}} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x \]
                      5. Applied rewrites85.6%

                        \[\leadsto \color{blue}{\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x} \]
                    3. Recombined 3 regimes into one program.
                    4. Final simplification91.5%

                      \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -36:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 480:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}\\ \mathbf{else}:\\ \;\;\;\;\left(\frac{\frac{3655.1204654076414}{x} - 110.1139242984811}{x} + 4.16438922228\right) \cdot x\\ \end{array} \]
                    5. Add Preprocessing

                    Alternative 12: 89.5% accurate, 1.8× speedup?

                    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -36:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 1700:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
                    (FPCore (x y z)
                     :precision binary64
                     (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
                       (if (<= x -36.0)
                         t_0
                         (if (<= x 1700.0)
                           (/ (* (fma y x z) (- x 2.0)) (fma 313.399215894 x 47.066876606))
                           t_0))))
                    double code(double x, double y, double z) {
                    	double t_0 = 1.0 / (0.24013125253755718 / x);
                    	double tmp;
                    	if (x <= -36.0) {
                    		tmp = t_0;
                    	} else if (x <= 1700.0) {
                    		tmp = (fma(y, x, z) * (x - 2.0)) / fma(313.399215894, x, 47.066876606);
                    	} else {
                    		tmp = t_0;
                    	}
                    	return tmp;
                    }
                    
                    function code(x, y, z)
                    	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
                    	tmp = 0.0
                    	if (x <= -36.0)
                    		tmp = t_0;
                    	elseif (x <= 1700.0)
                    		tmp = Float64(Float64(fma(y, x, z) * Float64(x - 2.0)) / fma(313.399215894, x, 47.066876606));
                    	else
                    		tmp = t_0;
                    	end
                    	return tmp
                    end
                    
                    code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -36.0], t$95$0, If[LessEqual[x, 1700.0], N[(N[(N[(y * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / N[(313.399215894 * x + 47.066876606), $MachinePrecision]), $MachinePrecision], t$95$0]]]
                    
                    \begin{array}{l}
                    
                    \\
                    \begin{array}{l}
                    t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
                    \mathbf{if}\;x \leq -36:\\
                    \;\;\;\;t\_0\\
                    
                    \mathbf{elif}\;x \leq 1700:\\
                    \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}\\
                    
                    \mathbf{else}:\\
                    \;\;\;\;t\_0\\
                    
                    
                    \end{array}
                    \end{array}
                    
                    Derivation
                    1. Split input into 2 regimes
                    2. if x < -36 or 1700 < x

                      1. Initial program 12.3%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Applied rewrites19.6%

                        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                      4. Applied rewrites19.5%

                        \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
                      5. Taylor expanded in x around inf

                        \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
                      6. Step-by-step derivation
                        1. lower-/.f6488.9

                          \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
                      7. Applied rewrites88.9%

                        \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

                      if -36 < x < 1700

                      1. Initial program 99.7%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Taylor expanded in x around 0

                        \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(z + x \cdot y\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                      4. Step-by-step derivation
                        1. +-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(x \cdot y + z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                        2. *-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \left(\color{blue}{y \cdot x} + z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                        3. lower-fma.f6496.3

                          \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      5. Applied rewrites96.3%

                        \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      6. Taylor expanded in x around 0

                        \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\frac{23533438303}{500000000} + \frac{156699607947}{500000000} \cdot x}} \]
                      7. Step-by-step derivation
                        1. +-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\frac{156699607947}{500000000} \cdot x + \frac{23533438303}{500000000}}} \]
                        2. lower-fma.f6493.7

                          \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}} \]
                      8. Applied rewrites93.7%

                        \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}} \]
                    3. Recombined 2 regimes into one program.
                    4. Final simplification91.5%

                      \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -36:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 1700:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{\mathsf{fma}\left(313.399215894, x, 47.066876606\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
                    5. Add Preprocessing

                    Alternative 13: 88.7% accurate, 2.1× speedup?

                    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 1700:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{47.066876606}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
                    (FPCore (x y z)
                     :precision binary64
                     (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
                       (if (<= x -3.4e+21)
                         t_0
                         (if (<= x 1700.0) (/ (* (fma y x z) (- x 2.0)) 47.066876606) t_0))))
                    double code(double x, double y, double z) {
                    	double t_0 = 1.0 / (0.24013125253755718 / x);
                    	double tmp;
                    	if (x <= -3.4e+21) {
                    		tmp = t_0;
                    	} else if (x <= 1700.0) {
                    		tmp = (fma(y, x, z) * (x - 2.0)) / 47.066876606;
                    	} else {
                    		tmp = t_0;
                    	}
                    	return tmp;
                    }
                    
                    function code(x, y, z)
                    	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
                    	tmp = 0.0
                    	if (x <= -3.4e+21)
                    		tmp = t_0;
                    	elseif (x <= 1700.0)
                    		tmp = Float64(Float64(fma(y, x, z) * Float64(x - 2.0)) / 47.066876606);
                    	else
                    		tmp = t_0;
                    	end
                    	return tmp
                    end
                    
                    code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -3.4e+21], t$95$0, If[LessEqual[x, 1700.0], N[(N[(N[(y * x + z), $MachinePrecision] * N[(x - 2.0), $MachinePrecision]), $MachinePrecision] / 47.066876606), $MachinePrecision], t$95$0]]]
                    
                    \begin{array}{l}
                    
                    \\
                    \begin{array}{l}
                    t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
                    \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                    \;\;\;\;t\_0\\
                    
                    \mathbf{elif}\;x \leq 1700:\\
                    \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{47.066876606}\\
                    
                    \mathbf{else}:\\
                    \;\;\;\;t\_0\\
                    
                    
                    \end{array}
                    \end{array}
                    
                    Derivation
                    1. Split input into 2 regimes
                    2. if x < -3.4e21 or 1700 < x

                      1. Initial program 12.4%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Applied rewrites18.9%

                        \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                      4. Applied rewrites18.8%

                        \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
                      5. Taylor expanded in x around inf

                        \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
                      6. Step-by-step derivation
                        1. lower-/.f6489.6

                          \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
                      7. Applied rewrites89.6%

                        \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

                      if -3.4e21 < x < 1700

                      1. Initial program 99.0%

                        \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      2. Add Preprocessing
                      3. Taylor expanded in x around 0

                        \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(z + x \cdot y\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                      4. Step-by-step derivation
                        1. +-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\left(x \cdot y + z\right)}}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                        2. *-commutativeN/A

                          \[\leadsto \frac{\left(x - 2\right) \cdot \left(\color{blue}{y \cdot x} + z\right)}{\left(\left(\left(x + \frac{216700011257}{5000000000}\right) \cdot x + \frac{263505074721}{1000000000}\right) \cdot x + \frac{156699607947}{500000000}\right) \cdot x + \frac{23533438303}{500000000}} \]
                        3. lower-fma.f6495.7

                          \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      5. Applied rewrites95.7%

                        \[\leadsto \frac{\left(x - 2\right) \cdot \color{blue}{\mathsf{fma}\left(y, x, z\right)}}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                      6. Taylor expanded in x around 0

                        \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{\frac{23533438303}{500000000}}} \]
                      7. Step-by-step derivation
                        1. Applied rewrites92.6%

                          \[\leadsto \frac{\left(x - 2\right) \cdot \mathsf{fma}\left(y, x, z\right)}{\color{blue}{47.066876606}} \]
                      8. Recombined 2 regimes into one program.
                      9. Final simplification91.2%

                        \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{elif}\;x \leq 1700:\\ \;\;\;\;\frac{\mathsf{fma}\left(y, x, z\right) \cdot \left(x - 2\right)}{47.066876606}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{0.24013125253755718}{x}}\\ \end{array} \]
                      10. Add Preprocessing

                      Alternative 14: 88.8% accurate, 2.3× speedup?

                      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\ \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x \leq 3.55:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
                      (FPCore (x y z)
                       :precision binary64
                       (let* ((t_0 (/ 1.0 (/ 0.24013125253755718 x))))
                         (if (<= x -3.4e+21)
                           t_0
                           (if (<= x 3.55)
                             (fma
                              (fma -0.0424927283095952 y (* 0.3041881842569256 z))
                              x
                              (* -0.0424927283095952 z))
                             t_0))))
                      double code(double x, double y, double z) {
                      	double t_0 = 1.0 / (0.24013125253755718 / x);
                      	double tmp;
                      	if (x <= -3.4e+21) {
                      		tmp = t_0;
                      	} else if (x <= 3.55) {
                      		tmp = fma(fma(-0.0424927283095952, y, (0.3041881842569256 * z)), x, (-0.0424927283095952 * z));
                      	} else {
                      		tmp = t_0;
                      	}
                      	return tmp;
                      }
                      
                      function code(x, y, z)
                      	t_0 = Float64(1.0 / Float64(0.24013125253755718 / x))
                      	tmp = 0.0
                      	if (x <= -3.4e+21)
                      		tmp = t_0;
                      	elseif (x <= 3.55)
                      		tmp = fma(fma(-0.0424927283095952, y, Float64(0.3041881842569256 * z)), x, Float64(-0.0424927283095952 * z));
                      	else
                      		tmp = t_0;
                      	end
                      	return tmp
                      end
                      
                      code[x_, y_, z_] := Block[{t$95$0 = N[(1.0 / N[(0.24013125253755718 / x), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[x, -3.4e+21], t$95$0, If[LessEqual[x, 3.55], N[(N[(-0.0424927283095952 * y + N[(0.3041881842569256 * z), $MachinePrecision]), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], t$95$0]]]
                      
                      \begin{array}{l}
                      
                      \\
                      \begin{array}{l}
                      t_0 := \frac{1}{\frac{0.24013125253755718}{x}}\\
                      \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                      \;\;\;\;t\_0\\
                      
                      \mathbf{elif}\;x \leq 3.55:\\
                      \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, -0.0424927283095952 \cdot z\right)\\
                      
                      \mathbf{else}:\\
                      \;\;\;\;t\_0\\
                      
                      
                      \end{array}
                      \end{array}
                      
                      Derivation
                      1. Split input into 2 regimes
                      2. if x < -3.4e21 or 3.5499999999999998 < x

                        1. Initial program 13.8%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Applied rewrites20.3%

                          \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                        4. Applied rewrites20.2%

                          \[\leadsto \color{blue}{\frac{1}{\frac{\frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}}{x - 2}}} \]
                        5. Taylor expanded in x around inf

                          \[\leadsto \frac{1}{\color{blue}{\frac{\frac{25000000000}{104109730557}}{x}}} \]
                        6. Step-by-step derivation
                          1. lower-/.f6488.2

                            \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]
                        7. Applied rewrites88.2%

                          \[\leadsto \frac{1}{\color{blue}{\frac{0.24013125253755718}{x}}} \]

                        if -3.4e21 < x < 3.5499999999999998

                        1. Initial program 99.1%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Applied rewrites99.7%

                          \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                        4. Taylor expanded in x around 0

                          \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)} \]
                        5. Step-by-step derivation
                          1. +-commutativeN/A

                            \[\leadsto \color{blue}{x \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                          2. *-commutativeN/A

                            \[\leadsto \color{blue}{\left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                          3. lower-fma.f64N/A

                            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                          4. sub-negN/A

                            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{-1000000000}{23533438303} \cdot y + \left(\mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          5. lower-fma.f64N/A

                            \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          6. distribute-lft-neg-inN/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \color{blue}{\left(\mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809}\right)\right) \cdot z}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          7. lower-*.f64N/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \color{blue}{\left(\mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809}\right)\right) \cdot z}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          8. metadata-evalN/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \color{blue}{\frac{168466327098500000000}{553822718361107519809}} \cdot z\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          9. lower-*.f6493.6

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, \color{blue}{-0.0424927283095952 \cdot z}\right) \]
                        6. Applied rewrites93.6%

                          \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, -0.0424927283095952 \cdot z\right)} \]
                      3. Recombined 2 regimes into one program.
                      4. Add Preprocessing

                      Alternative 15: 88.8% accurate, 2.3× speedup?

                      \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;4.16438922228 \cdot x\\ \mathbf{elif}\;x \leq 3.8:\\ \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, -0.0424927283095952 \cdot z\right)\\ \mathbf{else}:\\ \;\;\;\;\left(4.16438922228 - \frac{110.1139242984811}{x}\right) \cdot x\\ \end{array} \end{array} \]
                      (FPCore (x y z)
                       :precision binary64
                       (if (<= x -3.4e+21)
                         (* 4.16438922228 x)
                         (if (<= x 3.8)
                           (fma
                            (fma -0.0424927283095952 y (* 0.3041881842569256 z))
                            x
                            (* -0.0424927283095952 z))
                           (* (- 4.16438922228 (/ 110.1139242984811 x)) x))))
                      double code(double x, double y, double z) {
                      	double tmp;
                      	if (x <= -3.4e+21) {
                      		tmp = 4.16438922228 * x;
                      	} else if (x <= 3.8) {
                      		tmp = fma(fma(-0.0424927283095952, y, (0.3041881842569256 * z)), x, (-0.0424927283095952 * z));
                      	} else {
                      		tmp = (4.16438922228 - (110.1139242984811 / x)) * x;
                      	}
                      	return tmp;
                      }
                      
                      function code(x, y, z)
                      	tmp = 0.0
                      	if (x <= -3.4e+21)
                      		tmp = Float64(4.16438922228 * x);
                      	elseif (x <= 3.8)
                      		tmp = fma(fma(-0.0424927283095952, y, Float64(0.3041881842569256 * z)), x, Float64(-0.0424927283095952 * z));
                      	else
                      		tmp = Float64(Float64(4.16438922228 - Float64(110.1139242984811 / x)) * x);
                      	end
                      	return tmp
                      end
                      
                      code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(4.16438922228 * x), $MachinePrecision], If[LessEqual[x, 3.8], N[(N[(-0.0424927283095952 * y + N[(0.3041881842569256 * z), $MachinePrecision]), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], N[(N[(4.16438922228 - N[(110.1139242984811 / x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]]]
                      
                      \begin{array}{l}
                      
                      \\
                      \begin{array}{l}
                      \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                      \;\;\;\;4.16438922228 \cdot x\\
                      
                      \mathbf{elif}\;x \leq 3.8:\\
                      \;\;\;\;\mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, -0.0424927283095952 \cdot z\right)\\
                      
                      \mathbf{else}:\\
                      \;\;\;\;\left(4.16438922228 - \frac{110.1139242984811}{x}\right) \cdot x\\
                      
                      
                      \end{array}
                      \end{array}
                      
                      Derivation
                      1. Split input into 3 regimes
                      2. if x < -3.4e21

                        1. Initial program 11.2%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Taylor expanded in x around inf

                          \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                        4. Step-by-step derivation
                          1. lower-*.f6493.8

                            \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                        5. Applied rewrites93.8%

                          \[\leadsto \color{blue}{4.16438922228 \cdot x} \]

                        if -3.4e21 < x < 3.7999999999999998

                        1. Initial program 99.1%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Applied rewrites99.7%

                          \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(x, x, -4\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(4.16438922228, x, 78.6994924154\right), x, 137.519416416\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}}{x - -2}} \]
                        4. Taylor expanded in x around 0

                          \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right)} \]
                        5. Step-by-step derivation
                          1. +-commutativeN/A

                            \[\leadsto \color{blue}{x \cdot \left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                          2. *-commutativeN/A

                            \[\leadsto \color{blue}{\left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                          3. lower-fma.f64N/A

                            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y - \frac{-168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                          4. sub-negN/A

                            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{-1000000000}{23533438303} \cdot y + \left(\mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          5. lower-fma.f64N/A

                            \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809} \cdot z\right)\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          6. distribute-lft-neg-inN/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \color{blue}{\left(\mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809}\right)\right) \cdot z}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          7. lower-*.f64N/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \color{blue}{\left(\mathsf{neg}\left(\frac{-168466327098500000000}{553822718361107519809}\right)\right) \cdot z}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          8. metadata-evalN/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{-1000000000}{23533438303}, y, \color{blue}{\frac{168466327098500000000}{553822718361107519809}} \cdot z\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          9. lower-*.f6493.6

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, \color{blue}{-0.0424927283095952 \cdot z}\right) \]
                        6. Applied rewrites93.6%

                          \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(-0.0424927283095952, y, 0.3041881842569256 \cdot z\right), x, -0.0424927283095952 \cdot z\right)} \]

                        if 3.7999999999999998 < x

                        1. Initial program 16.1%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Taylor expanded in x around inf

                          \[\leadsto \color{blue}{x \cdot \left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \]
                        4. Step-by-step derivation
                          1. *-commutativeN/A

                            \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) \cdot x} \]
                          2. sub-negN/A

                            \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} + \left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)\right)} \cdot x \]
                          3. +-commutativeN/A

                            \[\leadsto \color{blue}{\left(\left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                          4. neg-sub0N/A

                            \[\leadsto \left(\color{blue}{\left(0 - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} + \frac{104109730557}{25000000000}\right) \cdot x \]
                          5. associate-+l-N/A

                            \[\leadsto \color{blue}{\left(0 - \left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)} \cdot x \]
                          6. neg-sub0N/A

                            \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)\right)} \cdot x \]
                          7. lower-*.f64N/A

                            \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)\right) \cdot x} \]
                          8. neg-sub0N/A

                            \[\leadsto \color{blue}{\left(0 - \left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)} \cdot x \]
                          9. associate-+l-N/A

                            \[\leadsto \color{blue}{\left(\left(0 - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                          10. neg-sub0N/A

                            \[\leadsto \left(\color{blue}{\left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)} + \frac{104109730557}{25000000000}\right) \cdot x \]
                          11. +-commutativeN/A

                            \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} + \left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)\right)} \cdot x \]
                          12. sub-negN/A

                            \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \cdot x \]
                          13. lower--.f64N/A

                            \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \cdot x \]
                          14. associate-*r/N/A

                            \[\leadsto \left(\frac{104109730557}{25000000000} - \color{blue}{\frac{\frac{13764240537310136880149}{125000000000000000000} \cdot 1}{x}}\right) \cdot x \]
                          15. metadata-evalN/A

                            \[\leadsto \left(\frac{104109730557}{25000000000} - \frac{\color{blue}{\frac{13764240537310136880149}{125000000000000000000}}}{x}\right) \cdot x \]
                          16. lower-/.f6482.8

                            \[\leadsto \left(4.16438922228 - \color{blue}{\frac{110.1139242984811}{x}}\right) \cdot x \]
                        5. Applied rewrites82.8%

                          \[\leadsto \color{blue}{\left(4.16438922228 - \frac{110.1139242984811}{x}\right) \cdot x} \]
                      3. Recombined 3 regimes into one program.
                      4. Add Preprocessing

                      Alternative 16: 88.5% accurate, 2.5× speedup?

                      \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;4.16438922228 \cdot x\\ \mathbf{elif}\;x \leq 2:\\ \;\;\;\;\mathsf{fma}\left(-0.0424927283095952 \cdot y, x, -0.0424927283095952 \cdot z\right)\\ \mathbf{else}:\\ \;\;\;\;\left(4.16438922228 - \frac{110.1139242984811}{x}\right) \cdot x\\ \end{array} \end{array} \]
                      (FPCore (x y z)
                       :precision binary64
                       (if (<= x -3.4e+21)
                         (* 4.16438922228 x)
                         (if (<= x 2.0)
                           (fma (* -0.0424927283095952 y) x (* -0.0424927283095952 z))
                           (* (- 4.16438922228 (/ 110.1139242984811 x)) x))))
                      double code(double x, double y, double z) {
                      	double tmp;
                      	if (x <= -3.4e+21) {
                      		tmp = 4.16438922228 * x;
                      	} else if (x <= 2.0) {
                      		tmp = fma((-0.0424927283095952 * y), x, (-0.0424927283095952 * z));
                      	} else {
                      		tmp = (4.16438922228 - (110.1139242984811 / x)) * x;
                      	}
                      	return tmp;
                      }
                      
                      function code(x, y, z)
                      	tmp = 0.0
                      	if (x <= -3.4e+21)
                      		tmp = Float64(4.16438922228 * x);
                      	elseif (x <= 2.0)
                      		tmp = fma(Float64(-0.0424927283095952 * y), x, Float64(-0.0424927283095952 * z));
                      	else
                      		tmp = Float64(Float64(4.16438922228 - Float64(110.1139242984811 / x)) * x);
                      	end
                      	return tmp
                      end
                      
                      code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(4.16438922228 * x), $MachinePrecision], If[LessEqual[x, 2.0], N[(N[(-0.0424927283095952 * y), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], N[(N[(4.16438922228 - N[(110.1139242984811 / x), $MachinePrecision]), $MachinePrecision] * x), $MachinePrecision]]]
                      
                      \begin{array}{l}
                      
                      \\
                      \begin{array}{l}
                      \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                      \;\;\;\;4.16438922228 \cdot x\\
                      
                      \mathbf{elif}\;x \leq 2:\\
                      \;\;\;\;\mathsf{fma}\left(-0.0424927283095952 \cdot y, x, -0.0424927283095952 \cdot z\right)\\
                      
                      \mathbf{else}:\\
                      \;\;\;\;\left(4.16438922228 - \frac{110.1139242984811}{x}\right) \cdot x\\
                      
                      
                      \end{array}
                      \end{array}
                      
                      Derivation
                      1. Split input into 3 regimes
                      2. if x < -3.4e21

                        1. Initial program 11.2%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Taylor expanded in x around inf

                          \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                        4. Step-by-step derivation
                          1. lower-*.f6493.8

                            \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                        5. Applied rewrites93.8%

                          \[\leadsto \color{blue}{4.16438922228 \cdot x} \]

                        if -3.4e21 < x < 2

                        1. Initial program 99.1%

                          \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                        2. Add Preprocessing
                        3. Taylor expanded in x around inf

                          \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                        4. Step-by-step derivation
                          1. lower-*.f643.6

                            \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                        5. Applied rewrites3.6%

                          \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                        6. Taylor expanded in x around 0

                          \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)} \]
                        7. Step-by-step derivation
                          1. +-commutativeN/A

                            \[\leadsto \color{blue}{x \cdot \left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                          2. *-commutativeN/A

                            \[\leadsto \color{blue}{\left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                          3. +-commutativeN/A

                            \[\leadsto \left(\frac{500000000}{23533438303} \cdot \color{blue}{\left(-2 \cdot y + z\right)} - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          4. distribute-lft-inN/A

                            \[\leadsto \left(\color{blue}{\left(\frac{500000000}{23533438303} \cdot \left(-2 \cdot y\right) + \frac{500000000}{23533438303} \cdot z\right)} - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          5. associate-*r*N/A

                            \[\leadsto \left(\left(\color{blue}{\left(\frac{500000000}{23533438303} \cdot -2\right) \cdot y} + \frac{500000000}{23533438303} \cdot z\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          6. metadata-evalN/A

                            \[\leadsto \left(\left(\color{blue}{\frac{-1000000000}{23533438303}} \cdot y + \frac{500000000}{23533438303} \cdot z\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          7. associate-+r-N/A

                            \[\leadsto \color{blue}{\left(\frac{-1000000000}{23533438303} \cdot y + \left(\frac{500000000}{23533438303} \cdot z - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)\right)} \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          8. distribute-rgt-out--N/A

                            \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + \color{blue}{z \cdot \left(\frac{500000000}{23533438303} - \frac{-156699607947000000000}{553822718361107519809}\right)}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          9. metadata-evalN/A

                            \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + z \cdot \color{blue}{\frac{168466327098500000000}{553822718361107519809}}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          10. *-commutativeN/A

                            \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + \color{blue}{\frac{168466327098500000000}{553822718361107519809} \cdot z}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                          11. lower-fma.f64N/A

                            \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y + \frac{168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                          12. +-commutativeN/A

                            \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{168466327098500000000}{553822718361107519809} \cdot z + \frac{-1000000000}{23533438303} \cdot y}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          13. lower-fma.f64N/A

                            \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{168466327098500000000}{553822718361107519809}, z, \frac{-1000000000}{23533438303} \cdot y\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          14. lower-*.f64N/A

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{168466327098500000000}{553822718361107519809}, z, \color{blue}{\frac{-1000000000}{23533438303} \cdot y}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          15. lower-*.f6494.2

                            \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, z, -0.0424927283095952 \cdot y\right), x, \color{blue}{-0.0424927283095952 \cdot z}\right) \]
                        8. Applied rewrites94.2%

                          \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, z, -0.0424927283095952 \cdot y\right), x, -0.0424927283095952 \cdot z\right)} \]
                        9. Taylor expanded in z around 0

                          \[\leadsto \mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                        10. Step-by-step derivation
                          1. Applied rewrites93.9%

                            \[\leadsto \mathsf{fma}\left(-0.0424927283095952 \cdot y, x, -0.0424927283095952 \cdot z\right) \]

                          if 2 < x

                          1. Initial program 17.4%

                            \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                          2. Add Preprocessing
                          3. Taylor expanded in x around inf

                            \[\leadsto \color{blue}{x \cdot \left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \]
                          4. Step-by-step derivation
                            1. *-commutativeN/A

                              \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) \cdot x} \]
                            2. sub-negN/A

                              \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} + \left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)\right)} \cdot x \]
                            3. +-commutativeN/A

                              \[\leadsto \color{blue}{\left(\left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                            4. neg-sub0N/A

                              \[\leadsto \left(\color{blue}{\left(0 - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} + \frac{104109730557}{25000000000}\right) \cdot x \]
                            5. associate-+l-N/A

                              \[\leadsto \color{blue}{\left(0 - \left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)} \cdot x \]
                            6. neg-sub0N/A

                              \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)\right)} \cdot x \]
                            7. lower-*.f64N/A

                              \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)\right) \cdot x} \]
                            8. neg-sub0N/A

                              \[\leadsto \color{blue}{\left(0 - \left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x} - \frac{104109730557}{25000000000}\right)\right)} \cdot x \]
                            9. associate-+l-N/A

                              \[\leadsto \color{blue}{\left(\left(0 - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right) + \frac{104109730557}{25000000000}\right)} \cdot x \]
                            10. neg-sub0N/A

                              \[\leadsto \left(\color{blue}{\left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)} + \frac{104109730557}{25000000000}\right) \cdot x \]
                            11. +-commutativeN/A

                              \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} + \left(\mathsf{neg}\left(\frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)\right)\right)} \cdot x \]
                            12. sub-negN/A

                              \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \cdot x \]
                            13. lower--.f64N/A

                              \[\leadsto \color{blue}{\left(\frac{104109730557}{25000000000} - \frac{13764240537310136880149}{125000000000000000000} \cdot \frac{1}{x}\right)} \cdot x \]
                            14. associate-*r/N/A

                              \[\leadsto \left(\frac{104109730557}{25000000000} - \color{blue}{\frac{\frac{13764240537310136880149}{125000000000000000000} \cdot 1}{x}}\right) \cdot x \]
                            15. metadata-evalN/A

                              \[\leadsto \left(\frac{104109730557}{25000000000} - \frac{\color{blue}{\frac{13764240537310136880149}{125000000000000000000}}}{x}\right) \cdot x \]
                            16. lower-/.f6481.6

                              \[\leadsto \left(4.16438922228 - \color{blue}{\frac{110.1139242984811}{x}}\right) \cdot x \]
                          5. Applied rewrites81.6%

                            \[\leadsto \color{blue}{\left(4.16438922228 - \frac{110.1139242984811}{x}\right) \cdot x} \]
                        11. Recombined 3 regimes into one program.
                        12. Add Preprocessing

                        Alternative 17: 88.5% accurate, 2.7× speedup?

                        \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;4.16438922228 \cdot x\\ \mathbf{elif}\;x \leq 2:\\ \;\;\;\;\mathsf{fma}\left(-0.0424927283095952 \cdot y, x, -0.0424927283095952 \cdot z\right)\\ \mathbf{else}:\\ \;\;\;\;4.16438922228 \cdot x\\ \end{array} \end{array} \]
                        (FPCore (x y z)
                         :precision binary64
                         (if (<= x -3.4e+21)
                           (* 4.16438922228 x)
                           (if (<= x 2.0)
                             (fma (* -0.0424927283095952 y) x (* -0.0424927283095952 z))
                             (* 4.16438922228 x))))
                        double code(double x, double y, double z) {
                        	double tmp;
                        	if (x <= -3.4e+21) {
                        		tmp = 4.16438922228 * x;
                        	} else if (x <= 2.0) {
                        		tmp = fma((-0.0424927283095952 * y), x, (-0.0424927283095952 * z));
                        	} else {
                        		tmp = 4.16438922228 * x;
                        	}
                        	return tmp;
                        }
                        
                        function code(x, y, z)
                        	tmp = 0.0
                        	if (x <= -3.4e+21)
                        		tmp = Float64(4.16438922228 * x);
                        	elseif (x <= 2.0)
                        		tmp = fma(Float64(-0.0424927283095952 * y), x, Float64(-0.0424927283095952 * z));
                        	else
                        		tmp = Float64(4.16438922228 * x);
                        	end
                        	return tmp
                        end
                        
                        code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(4.16438922228 * x), $MachinePrecision], If[LessEqual[x, 2.0], N[(N[(-0.0424927283095952 * y), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], N[(4.16438922228 * x), $MachinePrecision]]]
                        
                        \begin{array}{l}
                        
                        \\
                        \begin{array}{l}
                        \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                        \;\;\;\;4.16438922228 \cdot x\\
                        
                        \mathbf{elif}\;x \leq 2:\\
                        \;\;\;\;\mathsf{fma}\left(-0.0424927283095952 \cdot y, x, -0.0424927283095952 \cdot z\right)\\
                        
                        \mathbf{else}:\\
                        \;\;\;\;4.16438922228 \cdot x\\
                        
                        
                        \end{array}
                        \end{array}
                        
                        Derivation
                        1. Split input into 2 regimes
                        2. if x < -3.4e21 or 2 < x

                          1. Initial program 14.5%

                            \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                          2. Add Preprocessing
                          3. Taylor expanded in x around inf

                            \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                          4. Step-by-step derivation
                            1. lower-*.f6487.2

                              \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                          5. Applied rewrites87.2%

                            \[\leadsto \color{blue}{4.16438922228 \cdot x} \]

                          if -3.4e21 < x < 2

                          1. Initial program 99.1%

                            \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                          2. Add Preprocessing
                          3. Taylor expanded in x around inf

                            \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                          4. Step-by-step derivation
                            1. lower-*.f643.6

                              \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                          5. Applied rewrites3.6%

                            \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                          6. Taylor expanded in x around 0

                            \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)} \]
                          7. Step-by-step derivation
                            1. +-commutativeN/A

                              \[\leadsto \color{blue}{x \cdot \left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                            2. *-commutativeN/A

                              \[\leadsto \color{blue}{\left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                            3. +-commutativeN/A

                              \[\leadsto \left(\frac{500000000}{23533438303} \cdot \color{blue}{\left(-2 \cdot y + z\right)} - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            4. distribute-lft-inN/A

                              \[\leadsto \left(\color{blue}{\left(\frac{500000000}{23533438303} \cdot \left(-2 \cdot y\right) + \frac{500000000}{23533438303} \cdot z\right)} - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            5. associate-*r*N/A

                              \[\leadsto \left(\left(\color{blue}{\left(\frac{500000000}{23533438303} \cdot -2\right) \cdot y} + \frac{500000000}{23533438303} \cdot z\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            6. metadata-evalN/A

                              \[\leadsto \left(\left(\color{blue}{\frac{-1000000000}{23533438303}} \cdot y + \frac{500000000}{23533438303} \cdot z\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            7. associate-+r-N/A

                              \[\leadsto \color{blue}{\left(\frac{-1000000000}{23533438303} \cdot y + \left(\frac{500000000}{23533438303} \cdot z - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)\right)} \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            8. distribute-rgt-out--N/A

                              \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + \color{blue}{z \cdot \left(\frac{500000000}{23533438303} - \frac{-156699607947000000000}{553822718361107519809}\right)}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            9. metadata-evalN/A

                              \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + z \cdot \color{blue}{\frac{168466327098500000000}{553822718361107519809}}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            10. *-commutativeN/A

                              \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + \color{blue}{\frac{168466327098500000000}{553822718361107519809} \cdot z}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                            11. lower-fma.f64N/A

                              \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y + \frac{168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                            12. +-commutativeN/A

                              \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{168466327098500000000}{553822718361107519809} \cdot z + \frac{-1000000000}{23533438303} \cdot y}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                            13. lower-fma.f64N/A

                              \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{168466327098500000000}{553822718361107519809}, z, \frac{-1000000000}{23533438303} \cdot y\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                            14. lower-*.f64N/A

                              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{168466327098500000000}{553822718361107519809}, z, \color{blue}{\frac{-1000000000}{23533438303} \cdot y}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                            15. lower-*.f6494.2

                              \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, z, -0.0424927283095952 \cdot y\right), x, \color{blue}{-0.0424927283095952 \cdot z}\right) \]
                          8. Applied rewrites94.2%

                            \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, z, -0.0424927283095952 \cdot y\right), x, -0.0424927283095952 \cdot z\right)} \]
                          9. Taylor expanded in z around 0

                            \[\leadsto \mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                          10. Step-by-step derivation
                            1. Applied rewrites93.9%

                              \[\leadsto \mathsf{fma}\left(-0.0424927283095952 \cdot y, x, -0.0424927283095952 \cdot z\right) \]
                          11. Recombined 2 regimes into one program.
                          12. Add Preprocessing

                          Alternative 18: 75.5% accurate, 2.7× speedup?

                          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;4.16438922228 \cdot x\\ \mathbf{elif}\;x \leq 18:\\ \;\;\;\;\mathsf{fma}\left(0.3041881842569256 \cdot z, x, -0.0424927283095952 \cdot z\right)\\ \mathbf{else}:\\ \;\;\;\;4.16438922228 \cdot x\\ \end{array} \end{array} \]
                          (FPCore (x y z)
                           :precision binary64
                           (if (<= x -3.4e+21)
                             (* 4.16438922228 x)
                             (if (<= x 18.0)
                               (fma (* 0.3041881842569256 z) x (* -0.0424927283095952 z))
                               (* 4.16438922228 x))))
                          double code(double x, double y, double z) {
                          	double tmp;
                          	if (x <= -3.4e+21) {
                          		tmp = 4.16438922228 * x;
                          	} else if (x <= 18.0) {
                          		tmp = fma((0.3041881842569256 * z), x, (-0.0424927283095952 * z));
                          	} else {
                          		tmp = 4.16438922228 * x;
                          	}
                          	return tmp;
                          }
                          
                          function code(x, y, z)
                          	tmp = 0.0
                          	if (x <= -3.4e+21)
                          		tmp = Float64(4.16438922228 * x);
                          	elseif (x <= 18.0)
                          		tmp = fma(Float64(0.3041881842569256 * z), x, Float64(-0.0424927283095952 * z));
                          	else
                          		tmp = Float64(4.16438922228 * x);
                          	end
                          	return tmp
                          end
                          
                          code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(4.16438922228 * x), $MachinePrecision], If[LessEqual[x, 18.0], N[(N[(0.3041881842569256 * z), $MachinePrecision] * x + N[(-0.0424927283095952 * z), $MachinePrecision]), $MachinePrecision], N[(4.16438922228 * x), $MachinePrecision]]]
                          
                          \begin{array}{l}
                          
                          \\
                          \begin{array}{l}
                          \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                          \;\;\;\;4.16438922228 \cdot x\\
                          
                          \mathbf{elif}\;x \leq 18:\\
                          \;\;\;\;\mathsf{fma}\left(0.3041881842569256 \cdot z, x, -0.0424927283095952 \cdot z\right)\\
                          
                          \mathbf{else}:\\
                          \;\;\;\;4.16438922228 \cdot x\\
                          
                          
                          \end{array}
                          \end{array}
                          
                          Derivation
                          1. Split input into 2 regimes
                          2. if x < -3.4e21 or 18 < x

                            1. Initial program 13.1%

                              \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                            2. Add Preprocessing
                            3. Taylor expanded in x around inf

                              \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                            4. Step-by-step derivation
                              1. lower-*.f6488.6

                                \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                            5. Applied rewrites88.6%

                              \[\leadsto \color{blue}{4.16438922228 \cdot x} \]

                            if -3.4e21 < x < 18

                            1. Initial program 99.1%

                              \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                            2. Add Preprocessing
                            3. Taylor expanded in z around inf

                              \[\leadsto \color{blue}{\frac{z \cdot \left(x - 2\right)}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
                            4. Step-by-step derivation
                              1. *-commutativeN/A

                                \[\leadsto \frac{\color{blue}{\left(x - 2\right) \cdot z}}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)} \]
                              2. associate-/l*N/A

                                \[\leadsto \color{blue}{\left(x - 2\right) \cdot \frac{z}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
                              3. lower-*.f64N/A

                                \[\leadsto \color{blue}{\left(x - 2\right) \cdot \frac{z}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
                              4. lower--.f64N/A

                                \[\leadsto \color{blue}{\left(x - 2\right)} \cdot \frac{z}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)} \]
                              5. lower-/.f64N/A

                                \[\leadsto \left(x - 2\right) \cdot \color{blue}{\frac{z}{\frac{23533438303}{500000000} + x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right)}} \]
                              6. +-commutativeN/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\color{blue}{x \cdot \left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right) + \frac{23533438303}{500000000}}} \]
                              7. *-commutativeN/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\color{blue}{\left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right)\right) \cdot x} + \frac{23533438303}{500000000}} \]
                              8. lower-fma.f64N/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\color{blue}{\mathsf{fma}\left(\frac{156699607947}{500000000} + x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right), x, \frac{23533438303}{500000000}\right)}} \]
                              9. +-commutativeN/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\color{blue}{x \cdot \left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right) + \frac{156699607947}{500000000}}, x, \frac{23533438303}{500000000}\right)} \]
                              10. *-commutativeN/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\color{blue}{\left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right)\right) \cdot x} + \frac{156699607947}{500000000}, x, \frac{23533438303}{500000000}\right)} \]
                              11. lower-fma.f64N/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{263505074721}{1000000000} + x \cdot \left(\frac{216700011257}{5000000000} + x\right), x, \frac{156699607947}{500000000}\right)}, x, \frac{23533438303}{500000000}\right)} \]
                              12. +-commutativeN/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{x \cdot \left(\frac{216700011257}{5000000000} + x\right) + \frac{263505074721}{1000000000}}, x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)} \]
                              13. *-commutativeN/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\left(\frac{216700011257}{5000000000} + x\right) \cdot x} + \frac{263505074721}{1000000000}, x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)} \]
                              14. lower-fma.f64N/A

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{216700011257}{5000000000} + x, x, \frac{263505074721}{1000000000}\right)}, x, \frac{156699607947}{500000000}\right), x, \frac{23533438303}{500000000}\right)} \]
                              15. lower-+.f6472.2

                                \[\leadsto \left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\color{blue}{43.3400022514 + x}, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)} \]
                            5. Applied rewrites72.2%

                              \[\leadsto \color{blue}{\left(x - 2\right) \cdot \frac{z}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(43.3400022514 + x, x, 263.505074721\right), x, 313.399215894\right), x, 47.066876606\right)}} \]
                            6. Taylor expanded in x around 0

                              \[\leadsto \frac{-1000000000}{23533438303} \cdot z + \color{blue}{x \cdot \left(\frac{500000000}{23533438303} \cdot z - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)} \]
                            7. Step-by-step derivation
                              1. Applied rewrites70.0%

                                \[\leadsto \mathsf{fma}\left(0.3041881842569256 \cdot z, \color{blue}{x}, -0.0424927283095952 \cdot z\right) \]
                            8. Recombined 2 regimes into one program.
                            9. Add Preprocessing

                            Alternative 19: 75.5% accurate, 3.3× speedup?

                            \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;4.16438922228 \cdot x\\ \mathbf{elif}\;x \leq 18:\\ \;\;\;\;\mathsf{fma}\left(0.3041881842569256, x, -0.0424927283095952\right) \cdot z\\ \mathbf{else}:\\ \;\;\;\;4.16438922228 \cdot x\\ \end{array} \end{array} \]
                            (FPCore (x y z)
                             :precision binary64
                             (if (<= x -3.4e+21)
                               (* 4.16438922228 x)
                               (if (<= x 18.0)
                                 (* (fma 0.3041881842569256 x -0.0424927283095952) z)
                                 (* 4.16438922228 x))))
                            double code(double x, double y, double z) {
                            	double tmp;
                            	if (x <= -3.4e+21) {
                            		tmp = 4.16438922228 * x;
                            	} else if (x <= 18.0) {
                            		tmp = fma(0.3041881842569256, x, -0.0424927283095952) * z;
                            	} else {
                            		tmp = 4.16438922228 * x;
                            	}
                            	return tmp;
                            }
                            
                            function code(x, y, z)
                            	tmp = 0.0
                            	if (x <= -3.4e+21)
                            		tmp = Float64(4.16438922228 * x);
                            	elseif (x <= 18.0)
                            		tmp = Float64(fma(0.3041881842569256, x, -0.0424927283095952) * z);
                            	else
                            		tmp = Float64(4.16438922228 * x);
                            	end
                            	return tmp
                            end
                            
                            code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(4.16438922228 * x), $MachinePrecision], If[LessEqual[x, 18.0], N[(N[(0.3041881842569256 * x + -0.0424927283095952), $MachinePrecision] * z), $MachinePrecision], N[(4.16438922228 * x), $MachinePrecision]]]
                            
                            \begin{array}{l}
                            
                            \\
                            \begin{array}{l}
                            \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                            \;\;\;\;4.16438922228 \cdot x\\
                            
                            \mathbf{elif}\;x \leq 18:\\
                            \;\;\;\;\mathsf{fma}\left(0.3041881842569256, x, -0.0424927283095952\right) \cdot z\\
                            
                            \mathbf{else}:\\
                            \;\;\;\;4.16438922228 \cdot x\\
                            
                            
                            \end{array}
                            \end{array}
                            
                            Derivation
                            1. Split input into 2 regimes
                            2. if x < -3.4e21 or 18 < x

                              1. Initial program 13.1%

                                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                              2. Add Preprocessing
                              3. Taylor expanded in x around inf

                                \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                              4. Step-by-step derivation
                                1. lower-*.f6488.6

                                  \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                              5. Applied rewrites88.6%

                                \[\leadsto \color{blue}{4.16438922228 \cdot x} \]

                              if -3.4e21 < x < 18

                              1. Initial program 99.1%

                                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                              2. Add Preprocessing
                              3. Taylor expanded in x around inf

                                \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                              4. Step-by-step derivation
                                1. lower-*.f643.6

                                  \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                              5. Applied rewrites3.6%

                                \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                              6. Taylor expanded in x around 0

                                \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z + x \cdot \left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)} \]
                              7. Step-by-step derivation
                                1. +-commutativeN/A

                                  \[\leadsto \color{blue}{x \cdot \left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) + \frac{-1000000000}{23533438303} \cdot z} \]
                                2. *-commutativeN/A

                                  \[\leadsto \color{blue}{\left(\frac{500000000}{23533438303} \cdot \left(z + -2 \cdot y\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x} + \frac{-1000000000}{23533438303} \cdot z \]
                                3. +-commutativeN/A

                                  \[\leadsto \left(\frac{500000000}{23533438303} \cdot \color{blue}{\left(-2 \cdot y + z\right)} - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                4. distribute-lft-inN/A

                                  \[\leadsto \left(\color{blue}{\left(\frac{500000000}{23533438303} \cdot \left(-2 \cdot y\right) + \frac{500000000}{23533438303} \cdot z\right)} - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                5. associate-*r*N/A

                                  \[\leadsto \left(\left(\color{blue}{\left(\frac{500000000}{23533438303} \cdot -2\right) \cdot y} + \frac{500000000}{23533438303} \cdot z\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                6. metadata-evalN/A

                                  \[\leadsto \left(\left(\color{blue}{\frac{-1000000000}{23533438303}} \cdot y + \frac{500000000}{23533438303} \cdot z\right) - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                7. associate-+r-N/A

                                  \[\leadsto \color{blue}{\left(\frac{-1000000000}{23533438303} \cdot y + \left(\frac{500000000}{23533438303} \cdot z - \frac{-156699607947000000000}{553822718361107519809} \cdot z\right)\right)} \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                8. distribute-rgt-out--N/A

                                  \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + \color{blue}{z \cdot \left(\frac{500000000}{23533438303} - \frac{-156699607947000000000}{553822718361107519809}\right)}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                9. metadata-evalN/A

                                  \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + z \cdot \color{blue}{\frac{168466327098500000000}{553822718361107519809}}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                10. *-commutativeN/A

                                  \[\leadsto \left(\frac{-1000000000}{23533438303} \cdot y + \color{blue}{\frac{168466327098500000000}{553822718361107519809} \cdot z}\right) \cdot x + \frac{-1000000000}{23533438303} \cdot z \]
                                11. lower-fma.f64N/A

                                  \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{-1000000000}{23533438303} \cdot y + \frac{168466327098500000000}{553822718361107519809} \cdot z, x, \frac{-1000000000}{23533438303} \cdot z\right)} \]
                                12. +-commutativeN/A

                                  \[\leadsto \mathsf{fma}\left(\color{blue}{\frac{168466327098500000000}{553822718361107519809} \cdot z + \frac{-1000000000}{23533438303} \cdot y}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                                13. lower-fma.f64N/A

                                  \[\leadsto \mathsf{fma}\left(\color{blue}{\mathsf{fma}\left(\frac{168466327098500000000}{553822718361107519809}, z, \frac{-1000000000}{23533438303} \cdot y\right)}, x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                                14. lower-*.f64N/A

                                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(\frac{168466327098500000000}{553822718361107519809}, z, \color{blue}{\frac{-1000000000}{23533438303} \cdot y}\right), x, \frac{-1000000000}{23533438303} \cdot z\right) \]
                                15. lower-*.f6492.9

                                  \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, z, -0.0424927283095952 \cdot y\right), x, \color{blue}{-0.0424927283095952 \cdot z}\right) \]
                              8. Applied rewrites92.9%

                                \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{fma}\left(0.3041881842569256, z, -0.0424927283095952 \cdot y\right), x, -0.0424927283095952 \cdot z\right)} \]
                              9. Taylor expanded in z around inf

                                \[\leadsto z \cdot \color{blue}{\left(\frac{168466327098500000000}{553822718361107519809} \cdot x - \frac{1000000000}{23533438303}\right)} \]
                              10. Step-by-step derivation
                                1. Applied rewrites70.0%

                                  \[\leadsto \mathsf{fma}\left(0.3041881842569256, x, -0.0424927283095952\right) \cdot \color{blue}{z} \]
                              11. Recombined 2 regimes into one program.
                              12. Add Preprocessing

                              Alternative 20: 75.3% accurate, 4.4× speedup?

                              \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\ \;\;\;\;4.16438922228 \cdot x\\ \mathbf{elif}\;x \leq 2:\\ \;\;\;\;-0.0424927283095952 \cdot z\\ \mathbf{else}:\\ \;\;\;\;4.16438922228 \cdot x\\ \end{array} \end{array} \]
                              (FPCore (x y z)
                               :precision binary64
                               (if (<= x -3.4e+21)
                                 (* 4.16438922228 x)
                                 (if (<= x 2.0) (* -0.0424927283095952 z) (* 4.16438922228 x))))
                              double code(double x, double y, double z) {
                              	double tmp;
                              	if (x <= -3.4e+21) {
                              		tmp = 4.16438922228 * x;
                              	} else if (x <= 2.0) {
                              		tmp = -0.0424927283095952 * z;
                              	} else {
                              		tmp = 4.16438922228 * x;
                              	}
                              	return tmp;
                              }
                              
                              real(8) function code(x, y, z)
                                  real(8), intent (in) :: x
                                  real(8), intent (in) :: y
                                  real(8), intent (in) :: z
                                  real(8) :: tmp
                                  if (x <= (-3.4d+21)) then
                                      tmp = 4.16438922228d0 * x
                                  else if (x <= 2.0d0) then
                                      tmp = (-0.0424927283095952d0) * z
                                  else
                                      tmp = 4.16438922228d0 * x
                                  end if
                                  code = tmp
                              end function
                              
                              public static double code(double x, double y, double z) {
                              	double tmp;
                              	if (x <= -3.4e+21) {
                              		tmp = 4.16438922228 * x;
                              	} else if (x <= 2.0) {
                              		tmp = -0.0424927283095952 * z;
                              	} else {
                              		tmp = 4.16438922228 * x;
                              	}
                              	return tmp;
                              }
                              
                              def code(x, y, z):
                              	tmp = 0
                              	if x <= -3.4e+21:
                              		tmp = 4.16438922228 * x
                              	elif x <= 2.0:
                              		tmp = -0.0424927283095952 * z
                              	else:
                              		tmp = 4.16438922228 * x
                              	return tmp
                              
                              function code(x, y, z)
                              	tmp = 0.0
                              	if (x <= -3.4e+21)
                              		tmp = Float64(4.16438922228 * x);
                              	elseif (x <= 2.0)
                              		tmp = Float64(-0.0424927283095952 * z);
                              	else
                              		tmp = Float64(4.16438922228 * x);
                              	end
                              	return tmp
                              end
                              
                              function tmp_2 = code(x, y, z)
                              	tmp = 0.0;
                              	if (x <= -3.4e+21)
                              		tmp = 4.16438922228 * x;
                              	elseif (x <= 2.0)
                              		tmp = -0.0424927283095952 * z;
                              	else
                              		tmp = 4.16438922228 * x;
                              	end
                              	tmp_2 = tmp;
                              end
                              
                              code[x_, y_, z_] := If[LessEqual[x, -3.4e+21], N[(4.16438922228 * x), $MachinePrecision], If[LessEqual[x, 2.0], N[(-0.0424927283095952 * z), $MachinePrecision], N[(4.16438922228 * x), $MachinePrecision]]]
                              
                              \begin{array}{l}
                              
                              \\
                              \begin{array}{l}
                              \mathbf{if}\;x \leq -3.4 \cdot 10^{+21}:\\
                              \;\;\;\;4.16438922228 \cdot x\\
                              
                              \mathbf{elif}\;x \leq 2:\\
                              \;\;\;\;-0.0424927283095952 \cdot z\\
                              
                              \mathbf{else}:\\
                              \;\;\;\;4.16438922228 \cdot x\\
                              
                              
                              \end{array}
                              \end{array}
                              
                              Derivation
                              1. Split input into 2 regimes
                              2. if x < -3.4e21 or 2 < x

                                1. Initial program 14.5%

                                  \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                                2. Add Preprocessing
                                3. Taylor expanded in x around inf

                                  \[\leadsto \color{blue}{\frac{104109730557}{25000000000} \cdot x} \]
                                4. Step-by-step derivation
                                  1. lower-*.f6487.2

                                    \[\leadsto \color{blue}{4.16438922228 \cdot x} \]
                                5. Applied rewrites87.2%

                                  \[\leadsto \color{blue}{4.16438922228 \cdot x} \]

                                if -3.4e21 < x < 2

                                1. Initial program 99.1%

                                  \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                                2. Add Preprocessing
                                3. Taylor expanded in x around 0

                                  \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z} \]
                                4. Step-by-step derivation
                                  1. lower-*.f6470.6

                                    \[\leadsto \color{blue}{-0.0424927283095952 \cdot z} \]
                                5. Applied rewrites70.6%

                                  \[\leadsto \color{blue}{-0.0424927283095952 \cdot z} \]
                              3. Recombined 2 regimes into one program.
                              4. Add Preprocessing

                              Alternative 21: 34.1% accurate, 13.2× speedup?

                              \[\begin{array}{l} \\ -0.0424927283095952 \cdot z \end{array} \]
                              (FPCore (x y z) :precision binary64 (* -0.0424927283095952 z))
                              double code(double x, double y, double z) {
                              	return -0.0424927283095952 * z;
                              }
                              
                              real(8) function code(x, y, z)
                                  real(8), intent (in) :: x
                                  real(8), intent (in) :: y
                                  real(8), intent (in) :: z
                                  code = (-0.0424927283095952d0) * z
                              end function
                              
                              public static double code(double x, double y, double z) {
                              	return -0.0424927283095952 * z;
                              }
                              
                              def code(x, y, z):
                              	return -0.0424927283095952 * z
                              
                              function code(x, y, z)
                              	return Float64(-0.0424927283095952 * z)
                              end
                              
                              function tmp = code(x, y, z)
                              	tmp = -0.0424927283095952 * z;
                              end
                              
                              code[x_, y_, z_] := N[(-0.0424927283095952 * z), $MachinePrecision]
                              
                              \begin{array}{l}
                              
                              \\
                              -0.0424927283095952 \cdot z
                              \end{array}
                              
                              Derivation
                              1. Initial program 59.8%

                                \[\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514\right) \cdot x + 263.505074721\right) \cdot x + 313.399215894\right) \cdot x + 47.066876606} \]
                              2. Add Preprocessing
                              3. Taylor expanded in x around 0

                                \[\leadsto \color{blue}{\frac{-1000000000}{23533438303} \cdot z} \]
                              4. Step-by-step derivation
                                1. lower-*.f6439.3

                                  \[\leadsto \color{blue}{-0.0424927283095952 \cdot z} \]
                              5. Applied rewrites39.3%

                                \[\leadsto \color{blue}{-0.0424927283095952 \cdot z} \]
                              6. Add Preprocessing

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

                              \[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(\frac{y}{x \cdot x} + 4.16438922228 \cdot x\right) - 110.1139242984811\\ \mathbf{if}\;x < -3.326128725870005 \cdot 10^{+62}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;x < 9.429991714554673 \cdot 10^{+55}:\\ \;\;\;\;\frac{x - 2}{1} \cdot \frac{\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z}{\left(\left(263.505074721 \cdot x + \left(43.3400022514 \cdot \left(x \cdot x\right) + x \cdot \left(x \cdot x\right)\right)\right) + 313.399215894\right) \cdot x + 47.066876606}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
                              (FPCore (x y z)
                               :precision binary64
                               (let* ((t_0 (- (+ (/ y (* x x)) (* 4.16438922228 x)) 110.1139242984811)))
                                 (if (< x -3.326128725870005e+62)
                                   t_0
                                   (if (< x 9.429991714554673e+55)
                                     (*
                                      (/ (- x 2.0) 1.0)
                                      (/
                                       (+
                                        (*
                                         (+
                                          (* (+ (* (+ (* x 4.16438922228) 78.6994924154) x) 137.519416416) x)
                                          y)
                                         x)
                                        z)
                                       (+
                                        (*
                                         (+
                                          (+ (* 263.505074721 x) (+ (* 43.3400022514 (* x x)) (* x (* x x))))
                                          313.399215894)
                                         x)
                                        47.066876606)))
                                     t_0))))
                              double code(double x, double y, double z) {
                              	double t_0 = ((y / (x * x)) + (4.16438922228 * x)) - 110.1139242984811;
                              	double tmp;
                              	if (x < -3.326128725870005e+62) {
                              		tmp = t_0;
                              	} else if (x < 9.429991714554673e+55) {
                              		tmp = ((x - 2.0) / 1.0) * (((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z) / (((((263.505074721 * x) + ((43.3400022514 * (x * x)) + (x * (x * x)))) + 313.399215894) * x) + 47.066876606));
                              	} else {
                              		tmp = t_0;
                              	}
                              	return tmp;
                              }
                              
                              real(8) function code(x, y, z)
                                  real(8), intent (in) :: x
                                  real(8), intent (in) :: y
                                  real(8), intent (in) :: z
                                  real(8) :: t_0
                                  real(8) :: tmp
                                  t_0 = ((y / (x * x)) + (4.16438922228d0 * x)) - 110.1139242984811d0
                                  if (x < (-3.326128725870005d+62)) then
                                      tmp = t_0
                                  else if (x < 9.429991714554673d+55) then
                                      tmp = ((x - 2.0d0) / 1.0d0) * (((((((((x * 4.16438922228d0) + 78.6994924154d0) * x) + 137.519416416d0) * x) + y) * x) + z) / (((((263.505074721d0 * x) + ((43.3400022514d0 * (x * x)) + (x * (x * x)))) + 313.399215894d0) * x) + 47.066876606d0))
                                  else
                                      tmp = t_0
                                  end if
                                  code = tmp
                              end function
                              
                              public static double code(double x, double y, double z) {
                              	double t_0 = ((y / (x * x)) + (4.16438922228 * x)) - 110.1139242984811;
                              	double tmp;
                              	if (x < -3.326128725870005e+62) {
                              		tmp = t_0;
                              	} else if (x < 9.429991714554673e+55) {
                              		tmp = ((x - 2.0) / 1.0) * (((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z) / (((((263.505074721 * x) + ((43.3400022514 * (x * x)) + (x * (x * x)))) + 313.399215894) * x) + 47.066876606));
                              	} else {
                              		tmp = t_0;
                              	}
                              	return tmp;
                              }
                              
                              def code(x, y, z):
                              	t_0 = ((y / (x * x)) + (4.16438922228 * x)) - 110.1139242984811
                              	tmp = 0
                              	if x < -3.326128725870005e+62:
                              		tmp = t_0
                              	elif x < 9.429991714554673e+55:
                              		tmp = ((x - 2.0) / 1.0) * (((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z) / (((((263.505074721 * x) + ((43.3400022514 * (x * x)) + (x * (x * x)))) + 313.399215894) * x) + 47.066876606))
                              	else:
                              		tmp = t_0
                              	return tmp
                              
                              function code(x, y, z)
                              	t_0 = Float64(Float64(Float64(y / Float64(x * x)) + Float64(4.16438922228 * x)) - 110.1139242984811)
                              	tmp = 0.0
                              	if (x < -3.326128725870005e+62)
                              		tmp = t_0;
                              	elseif (x < 9.429991714554673e+55)
                              		tmp = Float64(Float64(Float64(x - 2.0) / 1.0) * Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(Float64(x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z) / Float64(Float64(Float64(Float64(Float64(263.505074721 * x) + Float64(Float64(43.3400022514 * Float64(x * x)) + Float64(x * Float64(x * x)))) + 313.399215894) * x) + 47.066876606)));
                              	else
                              		tmp = t_0;
                              	end
                              	return tmp
                              end
                              
                              function tmp_2 = code(x, y, z)
                              	t_0 = ((y / (x * x)) + (4.16438922228 * x)) - 110.1139242984811;
                              	tmp = 0.0;
                              	if (x < -3.326128725870005e+62)
                              		tmp = t_0;
                              	elseif (x < 9.429991714554673e+55)
                              		tmp = ((x - 2.0) / 1.0) * (((((((((x * 4.16438922228) + 78.6994924154) * x) + 137.519416416) * x) + y) * x) + z) / (((((263.505074721 * x) + ((43.3400022514 * (x * x)) + (x * (x * x)))) + 313.399215894) * x) + 47.066876606));
                              	else
                              		tmp = t_0;
                              	end
                              	tmp_2 = tmp;
                              end
                              
                              code[x_, y_, z_] := Block[{t$95$0 = N[(N[(N[(y / N[(x * x), $MachinePrecision]), $MachinePrecision] + N[(4.16438922228 * x), $MachinePrecision]), $MachinePrecision] - 110.1139242984811), $MachinePrecision]}, If[Less[x, -3.326128725870005e+62], t$95$0, If[Less[x, 9.429991714554673e+55], N[(N[(N[(x - 2.0), $MachinePrecision] / 1.0), $MachinePrecision] * N[(N[(N[(N[(N[(N[(N[(N[(N[(x * 4.16438922228), $MachinePrecision] + 78.6994924154), $MachinePrecision] * x), $MachinePrecision] + 137.519416416), $MachinePrecision] * x), $MachinePrecision] + y), $MachinePrecision] * x), $MachinePrecision] + z), $MachinePrecision] / N[(N[(N[(N[(N[(263.505074721 * x), $MachinePrecision] + N[(N[(43.3400022514 * N[(x * x), $MachinePrecision]), $MachinePrecision] + N[(x * N[(x * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + 313.399215894), $MachinePrecision] * x), $MachinePrecision] + 47.066876606), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]
                              
                              \begin{array}{l}
                              
                              \\
                              \begin{array}{l}
                              t_0 := \left(\frac{y}{x \cdot x} + 4.16438922228 \cdot x\right) - 110.1139242984811\\
                              \mathbf{if}\;x < -3.326128725870005 \cdot 10^{+62}:\\
                              \;\;\;\;t\_0\\
                              
                              \mathbf{elif}\;x < 9.429991714554673 \cdot 10^{+55}:\\
                              \;\;\;\;\frac{x - 2}{1} \cdot \frac{\left(\left(\left(x \cdot 4.16438922228 + 78.6994924154\right) \cdot x + 137.519416416\right) \cdot x + y\right) \cdot x + z}{\left(\left(263.505074721 \cdot x + \left(43.3400022514 \cdot \left(x \cdot x\right) + x \cdot \left(x \cdot x\right)\right)\right) + 313.399215894\right) \cdot x + 47.066876606}\\
                              
                              \mathbf{else}:\\
                              \;\;\;\;t\_0\\
                              
                              
                              \end{array}
                              \end{array}
                              

                              Reproduce

                              ?
                              herbie shell --seed 2024268 
                              (FPCore (x y z)
                                :name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, C"
                                :precision binary64
                              
                                :alt
                                (! :herbie-platform default (if (< x -332612872587000500000000000000000000000000000000000000000000000) (- (+ (/ y (* x x)) (* 104109730557/25000000000 x)) 1101139242984811/10000000000000) (if (< x 94299917145546730000000000000000000000000000000000000000) (* (/ (- x 2) 1) (/ (+ (* (+ (* (+ (* (+ (* x 104109730557/25000000000) 393497462077/5000000000) x) 4297481763/31250000) x) y) x) z) (+ (* (+ (+ (* 263505074721/1000000000 x) (+ (* 216700011257/5000000000 (* x x)) (* x (* x x)))) 156699607947/500000000) x) 23533438303/500000000))) (- (+ (/ y (* x x)) (* 104109730557/25000000000 x)) 1101139242984811/10000000000000))))
                              
                                (/ (* (- x 2.0) (+ (* (+ (* (+ (* (+ (* x 4.16438922228) 78.6994924154) x) 137.519416416) x) y) x) z)) (+ (* (+ (* (+ (* (+ x 43.3400022514) x) 263.505074721) x) 313.399215894) x) 47.066876606)))