Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, C

Percentage Accurate: 100.0% → 100.0%
Time: 8.0s
Alternatives: 11
Speedup: 1.0×

Specification

?
\[\begin{array}{l} \\ \frac{x - y}{1 - y} \end{array} \]
(FPCore (x y) :precision binary64 (/ (- x y) (- 1.0 y)))
double code(double x, double y) {
	return (x - y) / (1.0 - y);
}
real(8) function code(x, y)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    code = (x - y) / (1.0d0 - y)
end function
public static double code(double x, double y) {
	return (x - y) / (1.0 - y);
}
def code(x, y):
	return (x - y) / (1.0 - y)
function code(x, y)
	return Float64(Float64(x - y) / Float64(1.0 - y))
end
function tmp = code(x, y)
	tmp = (x - y) / (1.0 - y);
end
code[x_, y_] := N[(N[(x - y), $MachinePrecision] / N[(1.0 - y), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{x - y}{1 - y}
\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 11 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: 100.0% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{x - y}{1 - y} \end{array} \]
(FPCore (x y) :precision binary64 (/ (- x y) (- 1.0 y)))
double code(double x, double y) {
	return (x - y) / (1.0 - y);
}
real(8) function code(x, y)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    code = (x - y) / (1.0d0 - y)
end function
public static double code(double x, double y) {
	return (x - y) / (1.0 - y);
}
def code(x, y):
	return (x - y) / (1.0 - y)
function code(x, y)
	return Float64(Float64(x - y) / Float64(1.0 - y))
end
function tmp = code(x, y)
	tmp = (x - y) / (1.0 - y);
end
code[x_, y_] := N[(N[(x - y), $MachinePrecision] / N[(1.0 - y), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{x - y}{1 - y}
\end{array}

Alternative 1: 100.0% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{x - y}{1 - y} \end{array} \]
(FPCore (x y) :precision binary64 (/ (- x y) (- 1.0 y)))
double code(double x, double y) {
	return (x - y) / (1.0 - y);
}
real(8) function code(x, y)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    code = (x - y) / (1.0d0 - y)
end function
public static double code(double x, double y) {
	return (x - y) / (1.0 - y);
}
def code(x, y):
	return (x - y) / (1.0 - y)
function code(x, y)
	return Float64(Float64(x - y) / Float64(1.0 - y))
end
function tmp = code(x, y)
	tmp = (x - y) / (1.0 - y);
end
code[x_, y_] := N[(N[(x - y), $MachinePrecision] / N[(1.0 - y), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{x - y}{1 - y}
\end{array}
Derivation
  1. Initial program 100.0%

    \[\frac{x - y}{1 - y} \]
  2. Add Preprocessing
  3. Add Preprocessing

Alternative 2: 85.4% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{x - y}{1 - y}\\ \mathbf{if}\;t\_0 \leq 2 \cdot 10^{-11}:\\ \;\;\;\;\mathsf{fma}\left(1 - y, x, -y\right)\\ \mathbf{elif}\;t\_0 \leq 2:\\ \;\;\;\;1\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(x, \mathsf{fma}\left(y, y, y\right), x\right)\\ \end{array} \end{array} \]
(FPCore (x y)
 :precision binary64
 (let* ((t_0 (/ (- x y) (- 1.0 y))))
   (if (<= t_0 2e-11)
     (fma (- 1.0 y) x (- y))
     (if (<= t_0 2.0) 1.0 (fma x (fma y y y) x)))))
double code(double x, double y) {
	double t_0 = (x - y) / (1.0 - y);
	double tmp;
	if (t_0 <= 2e-11) {
		tmp = fma((1.0 - y), x, -y);
	} else if (t_0 <= 2.0) {
		tmp = 1.0;
	} else {
		tmp = fma(x, fma(y, y, y), x);
	}
	return tmp;
}
function code(x, y)
	t_0 = Float64(Float64(x - y) / Float64(1.0 - y))
	tmp = 0.0
	if (t_0 <= 2e-11)
		tmp = fma(Float64(1.0 - y), x, Float64(-y));
	elseif (t_0 <= 2.0)
		tmp = 1.0;
	else
		tmp = fma(x, fma(y, y, y), x);
	end
	return tmp
end
code[x_, y_] := Block[{t$95$0 = N[(N[(x - y), $MachinePrecision] / N[(1.0 - y), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$0, 2e-11], N[(N[(1.0 - y), $MachinePrecision] * x + (-y)), $MachinePrecision], If[LessEqual[t$95$0, 2.0], 1.0, N[(x * N[(y * y + y), $MachinePrecision] + x), $MachinePrecision]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{x - y}{1 - y}\\
\mathbf{if}\;t\_0 \leq 2 \cdot 10^{-11}:\\
\;\;\;\;\mathsf{fma}\left(1 - y, x, -y\right)\\

\mathbf{elif}\;t\_0 \leq 2:\\
\;\;\;\;1\\

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


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y)) < 1.99999999999999988e-11

    1. Initial program 100.0%

      \[\frac{x - y}{1 - y} \]
    2. Add Preprocessing
    3. Taylor expanded in y around 0

      \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
    4. Step-by-step derivation
      1. mul-1-negN/A

        \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
      2. unsub-negN/A

        \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
      3. mul-1-negN/A

        \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
      5. distribute-lft-inN/A

        \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
      6. *-rgt-identityN/A

        \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
      7. associate--r+N/A

        \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
      8. *-commutativeN/A

        \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
      9. cancel-sign-subN/A

        \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
      10. +-commutativeN/A

        \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
      11. remove-double-negN/A

        \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
      12. sub-negN/A

        \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
      13. lower--.f64N/A

        \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
      14. sub-negN/A

        \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
      15. remove-double-negN/A

        \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
      16. *-rgt-identityN/A

        \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
      17. distribute-lft-outN/A

        \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
      18. distribute-rgt-outN/A

        \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
      19. *-lft-identityN/A

        \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
      20. lower-fma.f6480.9

        \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
    5. Simplified80.9%

      \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) - y} \]
    6. Step-by-step derivation
      1. lift-fma.f64N/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
      2. sub-negN/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) + \left(\mathsf{neg}\left(y\right)\right)} \]
      3. lift-fma.f64N/A

        \[\leadsto \color{blue}{\left(y \cdot x + x\right)} + \left(\mathsf{neg}\left(y\right)\right) \]
      4. distribute-lft1-inN/A

        \[\leadsto \color{blue}{\left(y + 1\right) \cdot x} + \left(\mathsf{neg}\left(y\right)\right) \]
      5. +-commutativeN/A

        \[\leadsto \color{blue}{\left(1 + y\right)} \cdot x + \left(\mathsf{neg}\left(y\right)\right) \]
      6. lift-neg.f64N/A

        \[\leadsto \left(1 + y\right) \cdot x + \color{blue}{\left(\mathsf{neg}\left(y\right)\right)} \]
      7. lower-fma.f64N/A

        \[\leadsto \color{blue}{\mathsf{fma}\left(1 + y, x, \mathsf{neg}\left(y\right)\right)} \]
      8. +-commutativeN/A

        \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, \mathsf{neg}\left(y\right)\right) \]
      9. lower-+.f6480.9

        \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, -y\right) \]
    7. Applied egg-rr80.9%

      \[\leadsto \color{blue}{\mathsf{fma}\left(y + 1, x, -y\right)} \]
    8. Applied egg-rr81.5%

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

    if 1.99999999999999988e-11 < (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y)) < 2

    1. Initial program 100.0%

      \[\frac{x - y}{1 - y} \]
    2. Add Preprocessing
    3. Taylor expanded in y around inf

      \[\leadsto \color{blue}{1} \]
    4. Step-by-step derivation
      1. Simplified96.9%

        \[\leadsto \color{blue}{1} \]

      if 2 < (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y))

      1. Initial program 99.9%

        \[\frac{x - y}{1 - y} \]
      2. Add Preprocessing
      3. Taylor expanded in x around inf

        \[\leadsto \color{blue}{\frac{x}{1 - y}} \]
      4. Step-by-step derivation
        1. lower-/.f64N/A

          \[\leadsto \color{blue}{\frac{x}{1 - y}} \]
        2. lower--.f6499.0

          \[\leadsto \frac{x}{\color{blue}{1 - y}} \]
      5. Simplified99.0%

        \[\leadsto \color{blue}{\frac{x}{1 - y}} \]
      6. Taylor expanded in y around 0

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

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

          \[\leadsto y \cdot \left(\color{blue}{y \cdot x} - -1 \cdot x\right) + x \]
        3. distribute-rgt-out--N/A

          \[\leadsto y \cdot \color{blue}{\left(x \cdot \left(y - -1\right)\right)} + x \]
        4. sub-negN/A

          \[\leadsto y \cdot \left(x \cdot \color{blue}{\left(y + \left(\mathsf{neg}\left(-1\right)\right)\right)}\right) + x \]
        5. metadata-evalN/A

          \[\leadsto y \cdot \left(x \cdot \left(y + \color{blue}{1}\right)\right) + x \]
        6. +-commutativeN/A

          \[\leadsto y \cdot \left(x \cdot \color{blue}{\left(1 + y\right)}\right) + x \]
        7. *-commutativeN/A

          \[\leadsto y \cdot \color{blue}{\left(\left(1 + y\right) \cdot x\right)} + x \]
        8. associate-*r*N/A

          \[\leadsto \color{blue}{\left(y \cdot \left(1 + y\right)\right) \cdot x} + x \]
        9. *-lft-identityN/A

          \[\leadsto \left(y \cdot \left(1 + y\right)\right) \cdot x + \color{blue}{1 \cdot x} \]
        10. distribute-rgt-outN/A

          \[\leadsto \color{blue}{x \cdot \left(y \cdot \left(1 + y\right) + 1\right)} \]
        11. distribute-lft-outN/A

          \[\leadsto \color{blue}{x \cdot \left(y \cdot \left(1 + y\right)\right) + x \cdot 1} \]
        12. *-rgt-identityN/A

          \[\leadsto x \cdot \left(y \cdot \left(1 + y\right)\right) + \color{blue}{x} \]
        13. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(x, y \cdot \left(1 + y\right), x\right)} \]
        14. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(x, y \cdot \color{blue}{\left(y + 1\right)}, x\right) \]
        15. distribute-lft-inN/A

          \[\leadsto \mathsf{fma}\left(x, \color{blue}{y \cdot y + y \cdot 1}, x\right) \]
        16. *-rgt-identityN/A

          \[\leadsto \mathsf{fma}\left(x, y \cdot y + \color{blue}{y}, x\right) \]
        17. lower-fma.f6463.2

          \[\leadsto \mathsf{fma}\left(x, \color{blue}{\mathsf{fma}\left(y, y, y\right)}, x\right) \]
      8. Simplified63.2%

        \[\leadsto \color{blue}{\mathsf{fma}\left(x, \mathsf{fma}\left(y, y, y\right), x\right)} \]
    5. Recombined 3 regimes into one program.
    6. Add Preprocessing

    Alternative 3: 85.1% accurate, 0.3× speedup?

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

      1. Initial program 100.0%

        \[\frac{x - y}{1 - y} \]
      2. Add Preprocessing
      3. Taylor expanded in y around 0

        \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
      4. Step-by-step derivation
        1. mul-1-negN/A

          \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
        2. unsub-negN/A

          \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
        3. mul-1-negN/A

          \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
        4. +-commutativeN/A

          \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
        5. distribute-lft-inN/A

          \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
        6. *-rgt-identityN/A

          \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
        7. associate--r+N/A

          \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
        8. *-commutativeN/A

          \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
        9. cancel-sign-subN/A

          \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
        10. +-commutativeN/A

          \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
        11. remove-double-negN/A

          \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
        12. sub-negN/A

          \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
        13. lower--.f64N/A

          \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
        14. sub-negN/A

          \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
        15. remove-double-negN/A

          \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
        16. *-rgt-identityN/A

          \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
        17. distribute-lft-outN/A

          \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
        18. distribute-rgt-outN/A

          \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
        19. *-lft-identityN/A

          \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
        20. lower-fma.f6480.9

          \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
      5. Simplified80.9%

        \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) - y} \]
      6. Step-by-step derivation
        1. lift-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
        2. sub-negN/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) + \left(\mathsf{neg}\left(y\right)\right)} \]
        3. lift-fma.f64N/A

          \[\leadsto \color{blue}{\left(y \cdot x + x\right)} + \left(\mathsf{neg}\left(y\right)\right) \]
        4. distribute-lft1-inN/A

          \[\leadsto \color{blue}{\left(y + 1\right) \cdot x} + \left(\mathsf{neg}\left(y\right)\right) \]
        5. +-commutativeN/A

          \[\leadsto \color{blue}{\left(1 + y\right)} \cdot x + \left(\mathsf{neg}\left(y\right)\right) \]
        6. lift-neg.f64N/A

          \[\leadsto \left(1 + y\right) \cdot x + \color{blue}{\left(\mathsf{neg}\left(y\right)\right)} \]
        7. lower-fma.f64N/A

          \[\leadsto \color{blue}{\mathsf{fma}\left(1 + y, x, \mathsf{neg}\left(y\right)\right)} \]
        8. +-commutativeN/A

          \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, \mathsf{neg}\left(y\right)\right) \]
        9. lower-+.f6480.9

          \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, -y\right) \]
      7. Applied egg-rr80.9%

        \[\leadsto \color{blue}{\mathsf{fma}\left(y + 1, x, -y\right)} \]
      8. Taylor expanded in y around 0

        \[\leadsto \mathsf{fma}\left(\color{blue}{1}, x, \mathsf{neg}\left(y\right)\right) \]
      9. Step-by-step derivation
        1. Simplified81.0%

          \[\leadsto \mathsf{fma}\left(\color{blue}{1}, x, -y\right) \]
        2. Step-by-step derivation
          1. unsub-negN/A

            \[\leadsto \color{blue}{1 \cdot x - y} \]
          2. *-lft-identityN/A

            \[\leadsto \color{blue}{x} - y \]
          3. lower--.f6481.0

            \[\leadsto \color{blue}{x - y} \]
        3. Applied egg-rr81.0%

          \[\leadsto \color{blue}{x - y} \]

        if 1.99999999999999988e-11 < (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y)) < 2

        1. Initial program 100.0%

          \[\frac{x - y}{1 - y} \]
        2. Add Preprocessing
        3. Taylor expanded in y around inf

          \[\leadsto \color{blue}{1} \]
        4. Step-by-step derivation
          1. Simplified96.9%

            \[\leadsto \color{blue}{1} \]

          if 2 < (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y))

          1. Initial program 99.9%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around 0

            \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
          4. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
            2. unsub-negN/A

              \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
            3. mul-1-negN/A

              \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
            4. +-commutativeN/A

              \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
            5. distribute-lft-inN/A

              \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
            6. *-rgt-identityN/A

              \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
            7. associate--r+N/A

              \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
            8. *-commutativeN/A

              \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
            9. cancel-sign-subN/A

              \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
            10. +-commutativeN/A

              \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
            11. remove-double-negN/A

              \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
            12. sub-negN/A

              \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
            13. lower--.f64N/A

              \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
            14. sub-negN/A

              \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
            15. remove-double-negN/A

              \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
            16. *-rgt-identityN/A

              \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
            17. distribute-lft-outN/A

              \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
            18. distribute-rgt-outN/A

              \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
            19. *-lft-identityN/A

              \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
            20. lower-fma.f6461.0

              \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
          5. Simplified61.0%

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

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

              \[\leadsto x \cdot \color{blue}{\left(y + 1\right)} \]
            2. distribute-lft-inN/A

              \[\leadsto \color{blue}{x \cdot y + x \cdot 1} \]
            3. *-rgt-identityN/A

              \[\leadsto x \cdot y + \color{blue}{x} \]
            4. lower-fma.f6461.0

              \[\leadsto \color{blue}{\mathsf{fma}\left(x, y, x\right)} \]
          8. Simplified61.0%

            \[\leadsto \color{blue}{\mathsf{fma}\left(x, y, x\right)} \]
        5. Recombined 3 regimes into one program.
        6. Add Preprocessing

        Alternative 4: 98.7% accurate, 0.6× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;y \leq -0.86:\\ \;\;\;\;1 - \frac{x}{y}\\ \mathbf{elif}\;y \leq 1:\\ \;\;\;\;\mathsf{fma}\left(x + -1, \mathsf{fma}\left(y, y, y\right), x\right)\\ \mathbf{else}:\\ \;\;\;\;1 + \frac{1 - x}{y}\\ \end{array} \end{array} \]
        (FPCore (x y)
         :precision binary64
         (if (<= y -0.86)
           (- 1.0 (/ x y))
           (if (<= y 1.0) (fma (+ x -1.0) (fma y y y) x) (+ 1.0 (/ (- 1.0 x) y)))))
        double code(double x, double y) {
        	double tmp;
        	if (y <= -0.86) {
        		tmp = 1.0 - (x / y);
        	} else if (y <= 1.0) {
        		tmp = fma((x + -1.0), fma(y, y, y), x);
        	} else {
        		tmp = 1.0 + ((1.0 - x) / y);
        	}
        	return tmp;
        }
        
        function code(x, y)
        	tmp = 0.0
        	if (y <= -0.86)
        		tmp = Float64(1.0 - Float64(x / y));
        	elseif (y <= 1.0)
        		tmp = fma(Float64(x + -1.0), fma(y, y, y), x);
        	else
        		tmp = Float64(1.0 + Float64(Float64(1.0 - x) / y));
        	end
        	return tmp
        end
        
        code[x_, y_] := If[LessEqual[y, -0.86], N[(1.0 - N[(x / y), $MachinePrecision]), $MachinePrecision], If[LessEqual[y, 1.0], N[(N[(x + -1.0), $MachinePrecision] * N[(y * y + y), $MachinePrecision] + x), $MachinePrecision], N[(1.0 + N[(N[(1.0 - x), $MachinePrecision] / y), $MachinePrecision]), $MachinePrecision]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        \mathbf{if}\;y \leq -0.86:\\
        \;\;\;\;1 - \frac{x}{y}\\
        
        \mathbf{elif}\;y \leq 1:\\
        \;\;\;\;\mathsf{fma}\left(x + -1, \mathsf{fma}\left(y, y, y\right), x\right)\\
        
        \mathbf{else}:\\
        \;\;\;\;1 + \frac{1 - x}{y}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 3 regimes
        2. if y < -0.859999999999999987

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around inf

            \[\leadsto \frac{x - y}{\color{blue}{-1 \cdot y}} \]
          4. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto \frac{x - y}{\color{blue}{\mathsf{neg}\left(y\right)}} \]
            2. lower-neg.f6497.4

              \[\leadsto \frac{x - y}{\color{blue}{-y}} \]
          5. Simplified97.4%

            \[\leadsto \frac{x - y}{\color{blue}{-y}} \]
          6. Taylor expanded in x around 0

            \[\leadsto \color{blue}{1 + -1 \cdot \frac{x}{y}} \]
          7. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto 1 + \color{blue}{\left(\mathsf{neg}\left(\frac{x}{y}\right)\right)} \]
            2. unsub-negN/A

              \[\leadsto \color{blue}{1 - \frac{x}{y}} \]
            3. lower--.f64N/A

              \[\leadsto \color{blue}{1 - \frac{x}{y}} \]
            4. lower-/.f6497.4

              \[\leadsto 1 - \color{blue}{\frac{x}{y}} \]
          8. Simplified97.4%

            \[\leadsto \color{blue}{1 - \frac{x}{y}} \]

          if -0.859999999999999987 < y < 1

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around 0

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

              \[\leadsto \color{blue}{y \cdot \left(-1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right) - \left(1 + -1 \cdot x\right)\right) + x} \]
            2. sub-negN/A

              \[\leadsto y \cdot \color{blue}{\left(-1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right) + \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right)} + x \]
            3. distribute-lft-inN/A

              \[\leadsto \color{blue}{\left(y \cdot \left(-1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)\right) + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right)} + x \]
            4. mul-1-negN/A

              \[\leadsto \left(y \cdot \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            5. distribute-rgt-neg-inN/A

              \[\leadsto \left(y \cdot \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right)} + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            6. associate-*r*N/A

              \[\leadsto \left(\color{blue}{\left(y \cdot y\right) \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)} + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            7. unpow2N/A

              \[\leadsto \left(\color{blue}{{y}^{2}} \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right) + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            8. distribute-rgt-outN/A

              \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right) \cdot \left({y}^{2} + y\right)} + x \]
            9. lower-fma.f64N/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right), {y}^{2} + y, x\right)} \]
            10. mul-1-negN/A

              \[\leadsto \mathsf{fma}\left(\mathsf{neg}\left(\left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right)\right), {y}^{2} + y, x\right) \]
            11. distribute-neg-inN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(1\right)\right) + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}, {y}^{2} + y, x\right) \]
            12. metadata-evalN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{-1} + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right), {y}^{2} + y, x\right) \]
            13. remove-double-negN/A

              \[\leadsto \mathsf{fma}\left(-1 + \color{blue}{x}, {y}^{2} + y, x\right) \]
            14. lower-+.f64N/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{-1 + x}, {y}^{2} + y, x\right) \]
            15. unpow2N/A

              \[\leadsto \mathsf{fma}\left(-1 + x, \color{blue}{y \cdot y} + y, x\right) \]
            16. lower-fma.f6499.7

              \[\leadsto \mathsf{fma}\left(-1 + x, \color{blue}{\mathsf{fma}\left(y, y, y\right)}, x\right) \]
          5. Simplified99.7%

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

          if 1 < y

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around inf

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

              \[\leadsto 1 + \color{blue}{\left(\frac{1}{y} + -1 \cdot \frac{x}{y}\right)} \]
            2. mul-1-negN/A

              \[\leadsto 1 + \left(\frac{1}{y} + \color{blue}{\left(\mathsf{neg}\left(\frac{x}{y}\right)\right)}\right) \]
            3. sub-negN/A

              \[\leadsto 1 + \color{blue}{\left(\frac{1}{y} - \frac{x}{y}\right)} \]
            4. div-subN/A

              \[\leadsto 1 + \color{blue}{\frac{1 - x}{y}} \]
            5. lower-+.f64N/A

              \[\leadsto \color{blue}{1 + \frac{1 - x}{y}} \]
            6. sub-negN/A

              \[\leadsto 1 + \frac{\color{blue}{1 + \left(\mathsf{neg}\left(x\right)\right)}}{y} \]
            7. mul-1-negN/A

              \[\leadsto 1 + \frac{1 + \color{blue}{-1 \cdot x}}{y} \]
            8. lower-/.f64N/A

              \[\leadsto 1 + \color{blue}{\frac{1 + -1 \cdot x}{y}} \]
            9. mul-1-negN/A

              \[\leadsto 1 + \frac{1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}}{y} \]
            10. sub-negN/A

              \[\leadsto 1 + \frac{\color{blue}{1 - x}}{y} \]
            11. lower--.f6499.5

              \[\leadsto 1 + \frac{\color{blue}{1 - x}}{y} \]
          5. Simplified99.5%

            \[\leadsto \color{blue}{1 + \frac{1 - x}{y}} \]
        3. Recombined 3 regimes into one program.
        4. Final simplification99.1%

          \[\leadsto \begin{array}{l} \mathbf{if}\;y \leq -0.86:\\ \;\;\;\;1 - \frac{x}{y}\\ \mathbf{elif}\;y \leq 1:\\ \;\;\;\;\mathsf{fma}\left(x + -1, \mathsf{fma}\left(y, y, y\right), x\right)\\ \mathbf{else}:\\ \;\;\;\;1 + \frac{1 - x}{y}\\ \end{array} \]
        5. Add Preprocessing

        Alternative 5: 98.5% accurate, 0.6× speedup?

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

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around inf

            \[\leadsto \frac{x - y}{\color{blue}{-1 \cdot y}} \]
          4. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto \frac{x - y}{\color{blue}{\mathsf{neg}\left(y\right)}} \]
            2. lower-neg.f6498.1

              \[\leadsto \frac{x - y}{\color{blue}{-y}} \]
          5. Simplified98.1%

            \[\leadsto \frac{x - y}{\color{blue}{-y}} \]
          6. Taylor expanded in x around 0

            \[\leadsto \color{blue}{1 + -1 \cdot \frac{x}{y}} \]
          7. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto 1 + \color{blue}{\left(\mathsf{neg}\left(\frac{x}{y}\right)\right)} \]
            2. unsub-negN/A

              \[\leadsto \color{blue}{1 - \frac{x}{y}} \]
            3. lower--.f64N/A

              \[\leadsto \color{blue}{1 - \frac{x}{y}} \]
            4. lower-/.f6498.1

              \[\leadsto 1 - \color{blue}{\frac{x}{y}} \]
          8. Simplified98.1%

            \[\leadsto \color{blue}{1 - \frac{x}{y}} \]

          if -0.859999999999999987 < y < 1

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around 0

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

              \[\leadsto \color{blue}{y \cdot \left(-1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right) - \left(1 + -1 \cdot x\right)\right) + x} \]
            2. sub-negN/A

              \[\leadsto y \cdot \color{blue}{\left(-1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right) + \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right)} + x \]
            3. distribute-lft-inN/A

              \[\leadsto \color{blue}{\left(y \cdot \left(-1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)\right) + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right)} + x \]
            4. mul-1-negN/A

              \[\leadsto \left(y \cdot \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            5. distribute-rgt-neg-inN/A

              \[\leadsto \left(y \cdot \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right)} + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            6. associate-*r*N/A

              \[\leadsto \left(\color{blue}{\left(y \cdot y\right) \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)} + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            7. unpow2N/A

              \[\leadsto \left(\color{blue}{{y}^{2}} \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right) + y \cdot \left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right)\right) + x \]
            8. distribute-rgt-outN/A

              \[\leadsto \color{blue}{\left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right)\right) \cdot \left({y}^{2} + y\right)} + x \]
            9. lower-fma.f64N/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(\mathsf{neg}\left(\left(1 + -1 \cdot x\right)\right), {y}^{2} + y, x\right)} \]
            10. mul-1-negN/A

              \[\leadsto \mathsf{fma}\left(\mathsf{neg}\left(\left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right)\right), {y}^{2} + y, x\right) \]
            11. distribute-neg-inN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{\left(\mathsf{neg}\left(1\right)\right) + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}, {y}^{2} + y, x\right) \]
            12. metadata-evalN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{-1} + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right), {y}^{2} + y, x\right) \]
            13. remove-double-negN/A

              \[\leadsto \mathsf{fma}\left(-1 + \color{blue}{x}, {y}^{2} + y, x\right) \]
            14. lower-+.f64N/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{-1 + x}, {y}^{2} + y, x\right) \]
            15. unpow2N/A

              \[\leadsto \mathsf{fma}\left(-1 + x, \color{blue}{y \cdot y} + y, x\right) \]
            16. lower-fma.f6499.7

              \[\leadsto \mathsf{fma}\left(-1 + x, \color{blue}{\mathsf{fma}\left(y, y, y\right)}, x\right) \]
          5. Simplified99.7%

            \[\leadsto \color{blue}{\mathsf{fma}\left(-1 + x, \mathsf{fma}\left(y, y, y\right), x\right)} \]
        3. Recombined 2 regimes into one program.
        4. Final simplification98.9%

          \[\leadsto \begin{array}{l} \mathbf{if}\;y \leq -0.86:\\ \;\;\;\;1 - \frac{x}{y}\\ \mathbf{elif}\;y \leq 1:\\ \;\;\;\;\mathsf{fma}\left(x + -1, \mathsf{fma}\left(y, y, y\right), x\right)\\ \mathbf{else}:\\ \;\;\;\;1 - \frac{x}{y}\\ \end{array} \]
        5. Add Preprocessing

        Alternative 6: 98.2% accurate, 0.7× speedup?

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

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around inf

            \[\leadsto \frac{x - y}{\color{blue}{-1 \cdot y}} \]
          4. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto \frac{x - y}{\color{blue}{\mathsf{neg}\left(y\right)}} \]
            2. lower-neg.f6498.1

              \[\leadsto \frac{x - y}{\color{blue}{-y}} \]
          5. Simplified98.1%

            \[\leadsto \frac{x - y}{\color{blue}{-y}} \]
          6. Taylor expanded in x around 0

            \[\leadsto \color{blue}{1 + -1 \cdot \frac{x}{y}} \]
          7. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto 1 + \color{blue}{\left(\mathsf{neg}\left(\frac{x}{y}\right)\right)} \]
            2. unsub-negN/A

              \[\leadsto \color{blue}{1 - \frac{x}{y}} \]
            3. lower--.f64N/A

              \[\leadsto \color{blue}{1 - \frac{x}{y}} \]
            4. lower-/.f6498.1

              \[\leadsto 1 - \color{blue}{\frac{x}{y}} \]
          8. Simplified98.1%

            \[\leadsto \color{blue}{1 - \frac{x}{y}} \]

          if -0.819999999999999951 < y < 1

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around 0

            \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
          4. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
            2. unsub-negN/A

              \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
            3. mul-1-negN/A

              \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
            4. +-commutativeN/A

              \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
            5. distribute-lft-inN/A

              \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
            6. *-rgt-identityN/A

              \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
            7. associate--r+N/A

              \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
            8. *-commutativeN/A

              \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
            9. cancel-sign-subN/A

              \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
            10. +-commutativeN/A

              \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
            11. remove-double-negN/A

              \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
            12. sub-negN/A

              \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
            13. lower--.f64N/A

              \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
            14. sub-negN/A

              \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
            15. remove-double-negN/A

              \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
            16. *-rgt-identityN/A

              \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
            17. distribute-lft-outN/A

              \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
            18. distribute-rgt-outN/A

              \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
            19. *-lft-identityN/A

              \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
            20. lower-fma.f6498.5

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

            \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) - y} \]
          6. Step-by-step derivation
            1. lift-fma.f64N/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
            2. sub-negN/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) + \left(\mathsf{neg}\left(y\right)\right)} \]
            3. lift-fma.f64N/A

              \[\leadsto \color{blue}{\left(y \cdot x + x\right)} + \left(\mathsf{neg}\left(y\right)\right) \]
            4. distribute-lft1-inN/A

              \[\leadsto \color{blue}{\left(y + 1\right) \cdot x} + \left(\mathsf{neg}\left(y\right)\right) \]
            5. +-commutativeN/A

              \[\leadsto \color{blue}{\left(1 + y\right)} \cdot x + \left(\mathsf{neg}\left(y\right)\right) \]
            6. lift-neg.f64N/A

              \[\leadsto \left(1 + y\right) \cdot x + \color{blue}{\left(\mathsf{neg}\left(y\right)\right)} \]
            7. lower-fma.f64N/A

              \[\leadsto \color{blue}{\mathsf{fma}\left(1 + y, x, \mathsf{neg}\left(y\right)\right)} \]
            8. +-commutativeN/A

              \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, \mathsf{neg}\left(y\right)\right) \]
            9. lower-+.f6498.5

              \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, -y\right) \]
          7. Applied egg-rr98.5%

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

        Alternative 7: 49.4% accurate, 0.7× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{x - y}{1 - y} \leq 1.5 \cdot 10^{-11}:\\ \;\;\;\;-y\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \end{array} \]
        (FPCore (x y)
         :precision binary64
         (if (<= (/ (- x y) (- 1.0 y)) 1.5e-11) (- y) 1.0))
        double code(double x, double y) {
        	double tmp;
        	if (((x - y) / (1.0 - y)) <= 1.5e-11) {
        		tmp = -y;
        	} else {
        		tmp = 1.0;
        	}
        	return tmp;
        }
        
        real(8) function code(x, y)
            real(8), intent (in) :: x
            real(8), intent (in) :: y
            real(8) :: tmp
            if (((x - y) / (1.0d0 - y)) <= 1.5d-11) then
                tmp = -y
            else
                tmp = 1.0d0
            end if
            code = tmp
        end function
        
        public static double code(double x, double y) {
        	double tmp;
        	if (((x - y) / (1.0 - y)) <= 1.5e-11) {
        		tmp = -y;
        	} else {
        		tmp = 1.0;
        	}
        	return tmp;
        }
        
        def code(x, y):
        	tmp = 0
        	if ((x - y) / (1.0 - y)) <= 1.5e-11:
        		tmp = -y
        	else:
        		tmp = 1.0
        	return tmp
        
        function code(x, y)
        	tmp = 0.0
        	if (Float64(Float64(x - y) / Float64(1.0 - y)) <= 1.5e-11)
        		tmp = Float64(-y);
        	else
        		tmp = 1.0;
        	end
        	return tmp
        end
        
        function tmp_2 = code(x, y)
        	tmp = 0.0;
        	if (((x - y) / (1.0 - y)) <= 1.5e-11)
        		tmp = -y;
        	else
        		tmp = 1.0;
        	end
        	tmp_2 = tmp;
        end
        
        code[x_, y_] := If[LessEqual[N[(N[(x - y), $MachinePrecision] / N[(1.0 - y), $MachinePrecision]), $MachinePrecision], 1.5e-11], (-y), 1.0]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        \mathbf{if}\;\frac{x - y}{1 - y} \leq 1.5 \cdot 10^{-11}:\\
        \;\;\;\;-y\\
        
        \mathbf{else}:\\
        \;\;\;\;1\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 2 regimes
        2. if (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y)) < 1.5e-11

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around 0

            \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
          4. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
            2. unsub-negN/A

              \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
            3. mul-1-negN/A

              \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
            4. +-commutativeN/A

              \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
            5. distribute-lft-inN/A

              \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
            6. *-rgt-identityN/A

              \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
            7. associate--r+N/A

              \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
            8. *-commutativeN/A

              \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
            9. cancel-sign-subN/A

              \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
            10. +-commutativeN/A

              \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
            11. remove-double-negN/A

              \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
            12. sub-negN/A

              \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
            13. lower--.f64N/A

              \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
            14. sub-negN/A

              \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
            15. remove-double-negN/A

              \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
            16. *-rgt-identityN/A

              \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
            17. distribute-lft-outN/A

              \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
            18. distribute-rgt-outN/A

              \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
            19. *-lft-identityN/A

              \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
            20. lower-fma.f6480.7

              \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
          5. Simplified80.7%

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

            \[\leadsto \color{blue}{-1 \cdot y} \]
          7. Step-by-step derivation
            1. mul-1-negN/A

              \[\leadsto \color{blue}{\mathsf{neg}\left(y\right)} \]
            2. lower-neg.f6424.8

              \[\leadsto \color{blue}{-y} \]
          8. Simplified24.8%

            \[\leadsto \color{blue}{-y} \]

          if 1.5e-11 < (/.f64 (-.f64 x y) (-.f64 #s(literal 1 binary64) y))

          1. Initial program 100.0%

            \[\frac{x - y}{1 - y} \]
          2. Add Preprocessing
          3. Taylor expanded in y around inf

            \[\leadsto \color{blue}{1} \]
          4. Step-by-step derivation
            1. Simplified65.0%

              \[\leadsto \color{blue}{1} \]
          5. Recombined 2 regimes into one program.
          6. Add Preprocessing

          Alternative 8: 86.1% accurate, 0.7× speedup?

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

            1. Initial program 100.0%

              \[\frac{x - y}{1 - y} \]
            2. Add Preprocessing
            3. Taylor expanded in y around inf

              \[\leadsto \color{blue}{1} \]
            4. Step-by-step derivation
              1. Simplified70.1%

                \[\leadsto \color{blue}{1} \]

              if -1 < y < 1

              1. Initial program 100.0%

                \[\frac{x - y}{1 - y} \]
              2. Add Preprocessing
              3. Taylor expanded in y around 0

                \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
              4. Step-by-step derivation
                1. mul-1-negN/A

                  \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
                2. unsub-negN/A

                  \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
                3. mul-1-negN/A

                  \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
                4. +-commutativeN/A

                  \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
                5. distribute-lft-inN/A

                  \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
                6. *-rgt-identityN/A

                  \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
                7. associate--r+N/A

                  \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
                8. *-commutativeN/A

                  \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
                9. cancel-sign-subN/A

                  \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
                10. +-commutativeN/A

                  \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
                11. remove-double-negN/A

                  \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
                12. sub-negN/A

                  \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
                13. lower--.f64N/A

                  \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
                14. sub-negN/A

                  \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
                15. remove-double-negN/A

                  \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
                16. *-rgt-identityN/A

                  \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
                17. distribute-lft-outN/A

                  \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
                18. distribute-rgt-outN/A

                  \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
                19. *-lft-identityN/A

                  \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
                20. lower-fma.f6498.5

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

                \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) - y} \]
              6. Step-by-step derivation
                1. lift-fma.f64N/A

                  \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
                2. sub-negN/A

                  \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) + \left(\mathsf{neg}\left(y\right)\right)} \]
                3. lift-fma.f64N/A

                  \[\leadsto \color{blue}{\left(y \cdot x + x\right)} + \left(\mathsf{neg}\left(y\right)\right) \]
                4. distribute-lft1-inN/A

                  \[\leadsto \color{blue}{\left(y + 1\right) \cdot x} + \left(\mathsf{neg}\left(y\right)\right) \]
                5. +-commutativeN/A

                  \[\leadsto \color{blue}{\left(1 + y\right)} \cdot x + \left(\mathsf{neg}\left(y\right)\right) \]
                6. lift-neg.f64N/A

                  \[\leadsto \left(1 + y\right) \cdot x + \color{blue}{\left(\mathsf{neg}\left(y\right)\right)} \]
                7. lower-fma.f64N/A

                  \[\leadsto \color{blue}{\mathsf{fma}\left(1 + y, x, \mathsf{neg}\left(y\right)\right)} \]
                8. +-commutativeN/A

                  \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, \mathsf{neg}\left(y\right)\right) \]
                9. lower-+.f6498.5

                  \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, -y\right) \]
              7. Applied egg-rr98.5%

                \[\leadsto \color{blue}{\mathsf{fma}\left(y + 1, x, -y\right)} \]
            5. Recombined 2 regimes into one program.
            6. Add Preprocessing

            Alternative 9: 86.1% accurate, 0.8× speedup?

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

              1. Initial program 100.0%

                \[\frac{x - y}{1 - y} \]
              2. Add Preprocessing
              3. Taylor expanded in y around inf

                \[\leadsto \color{blue}{1} \]
              4. Step-by-step derivation
                1. Simplified70.1%

                  \[\leadsto \color{blue}{1} \]

                if -1 < y < 1

                1. Initial program 100.0%

                  \[\frac{x - y}{1 - y} \]
                2. Add Preprocessing
                3. Taylor expanded in y around 0

                  \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
                4. Step-by-step derivation
                  1. mul-1-negN/A

                    \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
                  2. unsub-negN/A

                    \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
                  3. mul-1-negN/A

                    \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
                  4. +-commutativeN/A

                    \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
                  5. distribute-lft-inN/A

                    \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
                  6. *-rgt-identityN/A

                    \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
                  7. associate--r+N/A

                    \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
                  8. *-commutativeN/A

                    \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
                  9. cancel-sign-subN/A

                    \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
                  10. +-commutativeN/A

                    \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
                  11. remove-double-negN/A

                    \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
                  12. sub-negN/A

                    \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
                  13. lower--.f64N/A

                    \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
                  14. sub-negN/A

                    \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
                  15. remove-double-negN/A

                    \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
                  16. *-rgt-identityN/A

                    \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
                  17. distribute-lft-outN/A

                    \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
                  18. distribute-rgt-outN/A

                    \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
                  19. *-lft-identityN/A

                    \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
                  20. lower-fma.f6498.5

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

                  \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) - y} \]
              5. Recombined 2 regimes into one program.
              6. Add Preprocessing

              Alternative 10: 85.5% accurate, 1.1× speedup?

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

                1. Initial program 100.0%

                  \[\frac{x - y}{1 - y} \]
                2. Add Preprocessing
                3. Taylor expanded in y around inf

                  \[\leadsto \color{blue}{1} \]
                4. Step-by-step derivation
                  1. Simplified71.6%

                    \[\leadsto \color{blue}{1} \]

                  if -7.5e16 < y < 1

                  1. Initial program 100.0%

                    \[\frac{x - y}{1 - y} \]
                  2. Add Preprocessing
                  3. Taylor expanded in y around 0

                    \[\leadsto \color{blue}{x + -1 \cdot \left(y \cdot \left(1 + -1 \cdot x\right)\right)} \]
                  4. Step-by-step derivation
                    1. mul-1-negN/A

                      \[\leadsto x + \color{blue}{\left(\mathsf{neg}\left(y \cdot \left(1 + -1 \cdot x\right)\right)\right)} \]
                    2. unsub-negN/A

                      \[\leadsto \color{blue}{x - y \cdot \left(1 + -1 \cdot x\right)} \]
                    3. mul-1-negN/A

                      \[\leadsto x - y \cdot \left(1 + \color{blue}{\left(\mathsf{neg}\left(x\right)\right)}\right) \]
                    4. +-commutativeN/A

                      \[\leadsto x - y \cdot \color{blue}{\left(\left(\mathsf{neg}\left(x\right)\right) + 1\right)} \]
                    5. distribute-lft-inN/A

                      \[\leadsto x - \color{blue}{\left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + y \cdot 1\right)} \]
                    6. *-rgt-identityN/A

                      \[\leadsto x - \left(y \cdot \left(\mathsf{neg}\left(x\right)\right) + \color{blue}{y}\right) \]
                    7. associate--r+N/A

                      \[\leadsto \color{blue}{\left(x - y \cdot \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
                    8. *-commutativeN/A

                      \[\leadsto \left(x - \color{blue}{\left(\mathsf{neg}\left(x\right)\right) \cdot y}\right) - y \]
                    9. cancel-sign-subN/A

                      \[\leadsto \color{blue}{\left(x + x \cdot y\right)} - y \]
                    10. +-commutativeN/A

                      \[\leadsto \color{blue}{\left(x \cdot y + x\right)} - y \]
                    11. remove-double-negN/A

                      \[\leadsto \left(x \cdot y + \color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)}\right) - y \]
                    12. sub-negN/A

                      \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right)} - y \]
                    13. lower--.f64N/A

                      \[\leadsto \color{blue}{\left(x \cdot y - \left(\mathsf{neg}\left(x\right)\right)\right) - y} \]
                    14. sub-negN/A

                      \[\leadsto \color{blue}{\left(x \cdot y + \left(\mathsf{neg}\left(\left(\mathsf{neg}\left(x\right)\right)\right)\right)\right)} - y \]
                    15. remove-double-negN/A

                      \[\leadsto \left(x \cdot y + \color{blue}{x}\right) - y \]
                    16. *-rgt-identityN/A

                      \[\leadsto \left(x \cdot y + \color{blue}{x \cdot 1}\right) - y \]
                    17. distribute-lft-outN/A

                      \[\leadsto \color{blue}{x \cdot \left(y + 1\right)} - y \]
                    18. distribute-rgt-outN/A

                      \[\leadsto \color{blue}{\left(y \cdot x + 1 \cdot x\right)} - y \]
                    19. *-lft-identityN/A

                      \[\leadsto \left(y \cdot x + \color{blue}{x}\right) - y \]
                    20. lower-fma.f6496.2

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

                    \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) - y} \]
                  6. Step-by-step derivation
                    1. lift-fma.f64N/A

                      \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right)} - y \]
                    2. sub-negN/A

                      \[\leadsto \color{blue}{\mathsf{fma}\left(y, x, x\right) + \left(\mathsf{neg}\left(y\right)\right)} \]
                    3. lift-fma.f64N/A

                      \[\leadsto \color{blue}{\left(y \cdot x + x\right)} + \left(\mathsf{neg}\left(y\right)\right) \]
                    4. distribute-lft1-inN/A

                      \[\leadsto \color{blue}{\left(y + 1\right) \cdot x} + \left(\mathsf{neg}\left(y\right)\right) \]
                    5. +-commutativeN/A

                      \[\leadsto \color{blue}{\left(1 + y\right)} \cdot x + \left(\mathsf{neg}\left(y\right)\right) \]
                    6. lift-neg.f64N/A

                      \[\leadsto \left(1 + y\right) \cdot x + \color{blue}{\left(\mathsf{neg}\left(y\right)\right)} \]
                    7. lower-fma.f64N/A

                      \[\leadsto \color{blue}{\mathsf{fma}\left(1 + y, x, \mathsf{neg}\left(y\right)\right)} \]
                    8. +-commutativeN/A

                      \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, \mathsf{neg}\left(y\right)\right) \]
                    9. lower-+.f6496.2

                      \[\leadsto \mathsf{fma}\left(\color{blue}{y + 1}, x, -y\right) \]
                  7. Applied egg-rr96.2%

                    \[\leadsto \color{blue}{\mathsf{fma}\left(y + 1, x, -y\right)} \]
                  8. Taylor expanded in y around 0

                    \[\leadsto \mathsf{fma}\left(\color{blue}{1}, x, \mathsf{neg}\left(y\right)\right) \]
                  9. Step-by-step derivation
                    1. Simplified95.3%

                      \[\leadsto \mathsf{fma}\left(\color{blue}{1}, x, -y\right) \]
                    2. Step-by-step derivation
                      1. unsub-negN/A

                        \[\leadsto \color{blue}{1 \cdot x - y} \]
                      2. *-lft-identityN/A

                        \[\leadsto \color{blue}{x} - y \]
                      3. lower--.f6495.3

                        \[\leadsto \color{blue}{x - y} \]
                    3. Applied egg-rr95.3%

                      \[\leadsto \color{blue}{x - y} \]
                  10. Recombined 2 regimes into one program.
                  11. Add Preprocessing

                  Alternative 11: 38.3% accurate, 18.0× speedup?

                  \[\begin{array}{l} \\ 1 \end{array} \]
                  (FPCore (x y) :precision binary64 1.0)
                  double code(double x, double y) {
                  	return 1.0;
                  }
                  
                  real(8) function code(x, y)
                      real(8), intent (in) :: x
                      real(8), intent (in) :: y
                      code = 1.0d0
                  end function
                  
                  public static double code(double x, double y) {
                  	return 1.0;
                  }
                  
                  def code(x, y):
                  	return 1.0
                  
                  function code(x, y)
                  	return 1.0
                  end
                  
                  function tmp = code(x, y)
                  	tmp = 1.0;
                  end
                  
                  code[x_, y_] := 1.0
                  
                  \begin{array}{l}
                  
                  \\
                  1
                  \end{array}
                  
                  Derivation
                  1. Initial program 100.0%

                    \[\frac{x - y}{1 - y} \]
                  2. Add Preprocessing
                  3. Taylor expanded in y around inf

                    \[\leadsto \color{blue}{1} \]
                  4. Step-by-step derivation
                    1. Simplified39.0%

                      \[\leadsto \color{blue}{1} \]
                    2. Add Preprocessing

                    Reproduce

                    ?
                    herbie shell --seed 2024208 
                    (FPCore (x y)
                      :name "Diagrams.Trail:splitAtParam  from diagrams-lib-1.3.0.3, C"
                      :precision binary64
                      (/ (- x y) (- 1.0 y)))