2isqrt (example 3.6)

Percentage Accurate: 37.6% → 99.5%
Time: 8.1s
Alternatives: 11
Speedup: 1.5×

Specification

?
\[x > 1 \land x < 10^{+308}\]
\[\begin{array}{l} \\ \frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \end{array} \]
(FPCore (x) :precision binary64 (- (/ 1.0 (sqrt x)) (/ 1.0 (sqrt (+ x 1.0)))))
double code(double x) {
	return (1.0 / sqrt(x)) - (1.0 / sqrt((x + 1.0)));
}
real(8) function code(x)
    real(8), intent (in) :: x
    code = (1.0d0 / sqrt(x)) - (1.0d0 / sqrt((x + 1.0d0)))
end function
public static double code(double x) {
	return (1.0 / Math.sqrt(x)) - (1.0 / Math.sqrt((x + 1.0)));
}
def code(x):
	return (1.0 / math.sqrt(x)) - (1.0 / math.sqrt((x + 1.0)))
function code(x)
	return Float64(Float64(1.0 / sqrt(x)) - Float64(1.0 / sqrt(Float64(x + 1.0))))
end
function tmp = code(x)
	tmp = (1.0 / sqrt(x)) - (1.0 / sqrt((x + 1.0)));
end
code[x_] := N[(N[(1.0 / N[Sqrt[x], $MachinePrecision]), $MachinePrecision] - N[(1.0 / N[Sqrt[N[(x + 1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}
\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: 37.6% accurate, 1.0× speedup?

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

\\
\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}
\end{array}

Alternative 1: 99.5% accurate, 0.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{1 + x}\\ \frac{-\frac{\sqrt{x}}{-x}}{t\_0 \cdot \mathsf{fma}\left(\frac{-1}{\sqrt{x}}, -x, t\_0\right)} \end{array} \end{array} \]
(FPCore (x)
 :precision binary64
 (let* ((t_0 (sqrt (+ 1.0 x))))
   (/ (- (/ (sqrt x) (- x))) (* t_0 (fma (/ -1.0 (sqrt x)) (- x) t_0)))))
double code(double x) {
	double t_0 = sqrt((1.0 + x));
	return -(sqrt(x) / -x) / (t_0 * fma((-1.0 / sqrt(x)), -x, t_0));
}
function code(x)
	t_0 = sqrt(Float64(1.0 + x))
	return Float64(Float64(-Float64(sqrt(x) / Float64(-x))) / Float64(t_0 * fma(Float64(-1.0 / sqrt(x)), Float64(-x), t_0)))
end
code[x_] := Block[{t$95$0 = N[Sqrt[N[(1.0 + x), $MachinePrecision]], $MachinePrecision]}, N[((-N[(N[Sqrt[x], $MachinePrecision] / (-x)), $MachinePrecision]) / N[(t$95$0 * N[(N[(-1.0 / N[Sqrt[x], $MachinePrecision]), $MachinePrecision] * (-x) + t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sqrt{1 + x}\\
\frac{-\frac{\sqrt{x}}{-x}}{t\_0 \cdot \mathsf{fma}\left(\frac{-1}{\sqrt{x}}, -x, t\_0\right)}
\end{array}
\end{array}
Derivation
  1. Initial program 46.1%

    \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. lift--.f64N/A

      \[\leadsto \color{blue}{\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}} \]
    2. lift-/.f64N/A

      \[\leadsto \color{blue}{\frac{1}{\sqrt{x}}} - \frac{1}{\sqrt{x + 1}} \]
    3. lift-/.f64N/A

      \[\leadsto \frac{1}{\sqrt{x}} - \color{blue}{\frac{1}{\sqrt{x + 1}}} \]
    4. frac-subN/A

      \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
    5. div-invN/A

      \[\leadsto \color{blue}{\left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
    6. metadata-evalN/A

      \[\leadsto \left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot \color{blue}{\frac{1}{1}}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
    7. div-invN/A

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

      \[\leadsto \left(\color{blue}{\sqrt{x + 1}} - \frac{\sqrt{x}}{1}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
    9. flip--N/A

      \[\leadsto \color{blue}{\frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}}} \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
    10. metadata-evalN/A

      \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \frac{\color{blue}{1 \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}} \]
    11. frac-timesN/A

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

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

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

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

      \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \color{blue}{\frac{\frac{1}{\sqrt{x}} \cdot -1}{\mathsf{neg}\left(\sqrt{x + 1}\right)}} \]
  4. Applied rewrites48.6%

    \[\leadsto \color{blue}{\frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)}} \]
  5. Taylor expanded in x around 0

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

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

      \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
    3. lower-sqrt.f64N/A

      \[\leadsto \frac{-\color{blue}{\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
    4. lower-/.f6499.4

      \[\leadsto \frac{-\sqrt{\color{blue}{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
  7. Applied rewrites99.4%

    \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
  8. Step-by-step derivation
    1. Applied rewrites99.5%

      \[\leadsto \frac{-\frac{\sqrt{x}}{x}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
    2. Step-by-step derivation
      1. lift-+.f64N/A

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

        \[\leadsto \frac{-\frac{\sqrt{x}}{x}}{\left(\color{blue}{\sqrt{x} \cdot 1} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
    3. Applied rewrites99.5%

      \[\leadsto \frac{-\frac{\sqrt{x}}{x}}{\color{blue}{\mathsf{fma}\left(\frac{-1}{\sqrt{x}}, -x, \sqrt{1 + x}\right)} \cdot \left(-\sqrt{x + 1}\right)} \]
    4. Final simplification99.5%

      \[\leadsto \frac{-\frac{\sqrt{x}}{-x}}{\sqrt{1 + x} \cdot \mathsf{fma}\left(\frac{-1}{\sqrt{x}}, -x, \sqrt{1 + x}\right)} \]
    5. Add Preprocessing

    Alternative 2: 99.5% accurate, 0.6× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{1 + x}\\ \frac{\frac{\sqrt{x}}{-x}}{\left(\left(-\sqrt{x}\right) - t\_0\right) \cdot t\_0} \end{array} \end{array} \]
    (FPCore (x)
     :precision binary64
     (let* ((t_0 (sqrt (+ 1.0 x))))
       (/ (/ (sqrt x) (- x)) (* (- (- (sqrt x)) t_0) t_0))))
    double code(double x) {
    	double t_0 = sqrt((1.0 + x));
    	return (sqrt(x) / -x) / ((-sqrt(x) - t_0) * t_0);
    }
    
    real(8) function code(x)
        real(8), intent (in) :: x
        real(8) :: t_0
        t_0 = sqrt((1.0d0 + x))
        code = (sqrt(x) / -x) / ((-sqrt(x) - t_0) * t_0)
    end function
    
    public static double code(double x) {
    	double t_0 = Math.sqrt((1.0 + x));
    	return (Math.sqrt(x) / -x) / ((-Math.sqrt(x) - t_0) * t_0);
    }
    
    def code(x):
    	t_0 = math.sqrt((1.0 + x))
    	return (math.sqrt(x) / -x) / ((-math.sqrt(x) - t_0) * t_0)
    
    function code(x)
    	t_0 = sqrt(Float64(1.0 + x))
    	return Float64(Float64(sqrt(x) / Float64(-x)) / Float64(Float64(Float64(-sqrt(x)) - t_0) * t_0))
    end
    
    function tmp = code(x)
    	t_0 = sqrt((1.0 + x));
    	tmp = (sqrt(x) / -x) / ((-sqrt(x) - t_0) * t_0);
    end
    
    code[x_] := Block[{t$95$0 = N[Sqrt[N[(1.0 + x), $MachinePrecision]], $MachinePrecision]}, N[(N[(N[Sqrt[x], $MachinePrecision] / (-x)), $MachinePrecision] / N[(N[((-N[Sqrt[x], $MachinePrecision]) - t$95$0), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    t_0 := \sqrt{1 + x}\\
    \frac{\frac{\sqrt{x}}{-x}}{\left(\left(-\sqrt{x}\right) - t\_0\right) \cdot t\_0}
    \end{array}
    \end{array}
    
    Derivation
    1. Initial program 46.1%

      \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift--.f64N/A

        \[\leadsto \color{blue}{\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}} \]
      2. lift-/.f64N/A

        \[\leadsto \color{blue}{\frac{1}{\sqrt{x}}} - \frac{1}{\sqrt{x + 1}} \]
      3. lift-/.f64N/A

        \[\leadsto \frac{1}{\sqrt{x}} - \color{blue}{\frac{1}{\sqrt{x + 1}}} \]
      4. frac-subN/A

        \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
      5. div-invN/A

        \[\leadsto \color{blue}{\left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
      6. metadata-evalN/A

        \[\leadsto \left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot \color{blue}{\frac{1}{1}}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
      7. div-invN/A

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

        \[\leadsto \left(\color{blue}{\sqrt{x + 1}} - \frac{\sqrt{x}}{1}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
      9. flip--N/A

        \[\leadsto \color{blue}{\frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}}} \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
      10. metadata-evalN/A

        \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \frac{\color{blue}{1 \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}} \]
      11. frac-timesN/A

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

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

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

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

        \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \color{blue}{\frac{\frac{1}{\sqrt{x}} \cdot -1}{\mathsf{neg}\left(\sqrt{x + 1}\right)}} \]
    4. Applied rewrites48.6%

      \[\leadsto \color{blue}{\frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)}} \]
    5. Taylor expanded in x around 0

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

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

        \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      3. lower-sqrt.f64N/A

        \[\leadsto \frac{-\color{blue}{\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      4. lower-/.f6499.4

        \[\leadsto \frac{-\sqrt{\color{blue}{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
    7. Applied rewrites99.4%

      \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
    8. Step-by-step derivation
      1. Applied rewrites99.5%

        \[\leadsto \frac{-\frac{\sqrt{x}}{x}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      2. Final simplification99.5%

        \[\leadsto \frac{\frac{\sqrt{x}}{-x}}{\left(\left(-\sqrt{x}\right) - \sqrt{1 + x}\right) \cdot \sqrt{1 + x}} \]
      3. Add Preprocessing

      Alternative 3: 99.4% accurate, 0.6× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{1 + x}\\ \frac{-\sqrt{\frac{1}{x}}}{\left(\left(-\sqrt{x}\right) - t\_0\right) \cdot t\_0} \end{array} \end{array} \]
      (FPCore (x)
       :precision binary64
       (let* ((t_0 (sqrt (+ 1.0 x))))
         (/ (- (sqrt (/ 1.0 x))) (* (- (- (sqrt x)) t_0) t_0))))
      double code(double x) {
      	double t_0 = sqrt((1.0 + x));
      	return -sqrt((1.0 / x)) / ((-sqrt(x) - t_0) * t_0);
      }
      
      real(8) function code(x)
          real(8), intent (in) :: x
          real(8) :: t_0
          t_0 = sqrt((1.0d0 + x))
          code = -sqrt((1.0d0 / x)) / ((-sqrt(x) - t_0) * t_0)
      end function
      
      public static double code(double x) {
      	double t_0 = Math.sqrt((1.0 + x));
      	return -Math.sqrt((1.0 / x)) / ((-Math.sqrt(x) - t_0) * t_0);
      }
      
      def code(x):
      	t_0 = math.sqrt((1.0 + x))
      	return -math.sqrt((1.0 / x)) / ((-math.sqrt(x) - t_0) * t_0)
      
      function code(x)
      	t_0 = sqrt(Float64(1.0 + x))
      	return Float64(Float64(-sqrt(Float64(1.0 / x))) / Float64(Float64(Float64(-sqrt(x)) - t_0) * t_0))
      end
      
      function tmp = code(x)
      	t_0 = sqrt((1.0 + x));
      	tmp = -sqrt((1.0 / x)) / ((-sqrt(x) - t_0) * t_0);
      end
      
      code[x_] := Block[{t$95$0 = N[Sqrt[N[(1.0 + x), $MachinePrecision]], $MachinePrecision]}, N[((-N[Sqrt[N[(1.0 / x), $MachinePrecision]], $MachinePrecision]) / N[(N[((-N[Sqrt[x], $MachinePrecision]) - t$95$0), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sqrt{1 + x}\\
      \frac{-\sqrt{\frac{1}{x}}}{\left(\left(-\sqrt{x}\right) - t\_0\right) \cdot t\_0}
      \end{array}
      \end{array}
      
      Derivation
      1. Initial program 46.1%

        \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift--.f64N/A

          \[\leadsto \color{blue}{\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}} \]
        2. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{1}{\sqrt{x}}} - \frac{1}{\sqrt{x + 1}} \]
        3. lift-/.f64N/A

          \[\leadsto \frac{1}{\sqrt{x}} - \color{blue}{\frac{1}{\sqrt{x + 1}}} \]
        4. frac-subN/A

          \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
        5. div-invN/A

          \[\leadsto \color{blue}{\left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
        6. metadata-evalN/A

          \[\leadsto \left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot \color{blue}{\frac{1}{1}}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        7. div-invN/A

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

          \[\leadsto \left(\color{blue}{\sqrt{x + 1}} - \frac{\sqrt{x}}{1}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        9. flip--N/A

          \[\leadsto \color{blue}{\frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}}} \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        10. metadata-evalN/A

          \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \frac{\color{blue}{1 \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        11. frac-timesN/A

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

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

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

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

          \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \color{blue}{\frac{\frac{1}{\sqrt{x}} \cdot -1}{\mathsf{neg}\left(\sqrt{x + 1}\right)}} \]
      4. Applied rewrites48.6%

        \[\leadsto \color{blue}{\frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)}} \]
      5. Taylor expanded in x around 0

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

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

          \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
        3. lower-sqrt.f64N/A

          \[\leadsto \frac{-\color{blue}{\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
        4. lower-/.f6499.4

          \[\leadsto \frac{-\sqrt{\color{blue}{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      7. Applied rewrites99.4%

        \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      8. Final simplification99.4%

        \[\leadsto \frac{-\sqrt{\frac{1}{x}}}{\left(\left(-\sqrt{x}\right) - \sqrt{1 + x}\right) \cdot \sqrt{1 + x}} \]
      9. Add Preprocessing

      Alternative 4: 99.2% accurate, 0.6× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{1 + x}\\ \frac{\frac{-1}{\sqrt{x}}}{\left(\left(-\sqrt{x}\right) - t\_0\right) \cdot t\_0} \end{array} \end{array} \]
      (FPCore (x)
       :precision binary64
       (let* ((t_0 (sqrt (+ 1.0 x))))
         (/ (/ -1.0 (sqrt x)) (* (- (- (sqrt x)) t_0) t_0))))
      double code(double x) {
      	double t_0 = sqrt((1.0 + x));
      	return (-1.0 / sqrt(x)) / ((-sqrt(x) - t_0) * t_0);
      }
      
      real(8) function code(x)
          real(8), intent (in) :: x
          real(8) :: t_0
          t_0 = sqrt((1.0d0 + x))
          code = ((-1.0d0) / sqrt(x)) / ((-sqrt(x) - t_0) * t_0)
      end function
      
      public static double code(double x) {
      	double t_0 = Math.sqrt((1.0 + x));
      	return (-1.0 / Math.sqrt(x)) / ((-Math.sqrt(x) - t_0) * t_0);
      }
      
      def code(x):
      	t_0 = math.sqrt((1.0 + x))
      	return (-1.0 / math.sqrt(x)) / ((-math.sqrt(x) - t_0) * t_0)
      
      function code(x)
      	t_0 = sqrt(Float64(1.0 + x))
      	return Float64(Float64(-1.0 / sqrt(x)) / Float64(Float64(Float64(-sqrt(x)) - t_0) * t_0))
      end
      
      function tmp = code(x)
      	t_0 = sqrt((1.0 + x));
      	tmp = (-1.0 / sqrt(x)) / ((-sqrt(x) - t_0) * t_0);
      end
      
      code[x_] := Block[{t$95$0 = N[Sqrt[N[(1.0 + x), $MachinePrecision]], $MachinePrecision]}, N[(N[(-1.0 / N[Sqrt[x], $MachinePrecision]), $MachinePrecision] / N[(N[((-N[Sqrt[x], $MachinePrecision]) - t$95$0), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sqrt{1 + x}\\
      \frac{\frac{-1}{\sqrt{x}}}{\left(\left(-\sqrt{x}\right) - t\_0\right) \cdot t\_0}
      \end{array}
      \end{array}
      
      Derivation
      1. Initial program 46.1%

        \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift--.f64N/A

          \[\leadsto \color{blue}{\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}} \]
        2. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{1}{\sqrt{x}}} - \frac{1}{\sqrt{x + 1}} \]
        3. lift-/.f64N/A

          \[\leadsto \frac{1}{\sqrt{x}} - \color{blue}{\frac{1}{\sqrt{x + 1}}} \]
        4. frac-subN/A

          \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
        5. div-invN/A

          \[\leadsto \color{blue}{\left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
        6. metadata-evalN/A

          \[\leadsto \left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot \color{blue}{\frac{1}{1}}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        7. div-invN/A

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

          \[\leadsto \left(\color{blue}{\sqrt{x + 1}} - \frac{\sqrt{x}}{1}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        9. flip--N/A

          \[\leadsto \color{blue}{\frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}}} \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        10. metadata-evalN/A

          \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \frac{\color{blue}{1 \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        11. frac-timesN/A

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

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

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

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

          \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \color{blue}{\frac{\frac{1}{\sqrt{x}} \cdot -1}{\mathsf{neg}\left(\sqrt{x + 1}\right)}} \]
      4. Applied rewrites48.6%

        \[\leadsto \color{blue}{\frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)}} \]
      5. Taylor expanded in x around 0

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

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

          \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
        3. lower-sqrt.f64N/A

          \[\leadsto \frac{-\color{blue}{\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
        4. lower-/.f6499.4

          \[\leadsto \frac{-\sqrt{\color{blue}{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      7. Applied rewrites99.4%

        \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)} \]
      8. Step-by-step derivation
        1. lift-/.f64N/A

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

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

          \[\leadsto \color{blue}{\frac{\mathsf{neg}\left(\left(-\sqrt{\frac{1}{x}}\right)\right)}{\mathsf{neg}\left(\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)\right)}} \]
      9. Applied rewrites99.2%

        \[\leadsto \color{blue}{\frac{-\frac{-1}{\sqrt{x}}}{\left(\sqrt{1 + x} + \sqrt{x}\right) \cdot \sqrt{1 + x}}} \]
      10. Final simplification99.2%

        \[\leadsto \frac{\frac{-1}{\sqrt{x}}}{\left(\left(-\sqrt{x}\right) - \sqrt{1 + x}\right) \cdot \sqrt{1 + x}} \]
      11. Add Preprocessing

      Alternative 5: 98.8% accurate, 1.2× speedup?

      \[\begin{array}{l} \\ \frac{-\sqrt{\frac{1}{x}}}{\mathsf{fma}\left(x, -2, -1.5\right)} \end{array} \]
      (FPCore (x) :precision binary64 (/ (- (sqrt (/ 1.0 x))) (fma x -2.0 -1.5)))
      double code(double x) {
      	return -sqrt((1.0 / x)) / fma(x, -2.0, -1.5);
      }
      
      function code(x)
      	return Float64(Float64(-sqrt(Float64(1.0 / x))) / fma(x, -2.0, -1.5))
      end
      
      code[x_] := N[((-N[Sqrt[N[(1.0 / x), $MachinePrecision]], $MachinePrecision]) / N[(x * -2.0 + -1.5), $MachinePrecision]), $MachinePrecision]
      
      \begin{array}{l}
      
      \\
      \frac{-\sqrt{\frac{1}{x}}}{\mathsf{fma}\left(x, -2, -1.5\right)}
      \end{array}
      
      Derivation
      1. Initial program 46.1%

        \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift--.f64N/A

          \[\leadsto \color{blue}{\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}} \]
        2. lift-/.f64N/A

          \[\leadsto \color{blue}{\frac{1}{\sqrt{x}}} - \frac{1}{\sqrt{x + 1}} \]
        3. lift-/.f64N/A

          \[\leadsto \frac{1}{\sqrt{x}} - \color{blue}{\frac{1}{\sqrt{x + 1}}} \]
        4. frac-subN/A

          \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
        5. div-invN/A

          \[\leadsto \color{blue}{\left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
        6. metadata-evalN/A

          \[\leadsto \left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot \color{blue}{\frac{1}{1}}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        7. div-invN/A

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

          \[\leadsto \left(\color{blue}{\sqrt{x + 1}} - \frac{\sqrt{x}}{1}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        9. flip--N/A

          \[\leadsto \color{blue}{\frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}}} \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        10. metadata-evalN/A

          \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \frac{\color{blue}{1 \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}} \]
        11. frac-timesN/A

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

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

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

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

          \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \color{blue}{\frac{\frac{1}{\sqrt{x}} \cdot -1}{\mathsf{neg}\left(\sqrt{x + 1}\right)}} \]
      4. Applied rewrites48.6%

        \[\leadsto \color{blue}{\frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)}} \]
      5. Taylor expanded in x around inf

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

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

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

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

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

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\color{blue}{\left(2 \cdot \left(\mathsf{neg}\left(\frac{1}{x}\right)\right)\right)} \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        6. distribute-neg-fracN/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(2 \cdot \color{blue}{\frac{\mathsf{neg}\left(1\right)}{x}}\right) \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        7. metadata-evalN/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(2 \cdot \frac{\color{blue}{-1}}{x}\right) \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        8. rem-square-sqrtN/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(2 \cdot \frac{\color{blue}{\sqrt{-1} \cdot \sqrt{-1}}}{x}\right) \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        9. unpow2N/A

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

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\color{blue}{\mathsf{fma}\left(2 \cdot \frac{{\left(\sqrt{-1}\right)}^{2}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)}} \]
        11. associate-*r/N/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\color{blue}{\frac{2 \cdot {\left(\sqrt{-1}\right)}^{2}}{x}}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        12. unpow2N/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{2 \cdot \color{blue}{\left(\sqrt{-1} \cdot \sqrt{-1}\right)}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        13. rem-square-sqrtN/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{2 \cdot \color{blue}{-1}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        14. metadata-evalN/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{\color{blue}{-2}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        15. lower-/.f64N/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\color{blue}{\frac{-2}{x}}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        16. unpow2N/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{-2}{x}, \color{blue}{x \cdot x}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        17. lower-*.f64N/A

          \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{-2}{x}, \color{blue}{x \cdot x}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
      7. Applied rewrites47.6%

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

        \[\leadsto \frac{\color{blue}{-1 \cdot \sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
      9. Step-by-step derivation
        1. mul-1-negN/A

          \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(\sqrt{\frac{1}{x}}\right)}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
        2. lower-neg.f64N/A

          \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
        3. lower-sqrt.f64N/A

          \[\leadsto \frac{-\color{blue}{\sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
        4. lower-/.f6486.6

          \[\leadsto \frac{-\sqrt{\color{blue}{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, -1.5\right)} \]
      10. Applied rewrites86.6%

        \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, -1.5\right)} \]
      11. Step-by-step derivation
        1. Applied rewrites98.6%

          \[\leadsto \frac{-\sqrt{\frac{1}{x}}}{\mathsf{fma}\left(x, \color{blue}{-2}, -1.5\right)} \]
        2. Add Preprocessing

        Alternative 6: 98.7% accurate, 1.3× speedup?

        \[\begin{array}{l} \\ \frac{\frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(-2, x, -1.5\right)} \end{array} \]
        (FPCore (x) :precision binary64 (/ (/ -1.0 (sqrt x)) (fma -2.0 x -1.5)))
        double code(double x) {
        	return (-1.0 / sqrt(x)) / fma(-2.0, x, -1.5);
        }
        
        function code(x)
        	return Float64(Float64(-1.0 / sqrt(x)) / fma(-2.0, x, -1.5))
        end
        
        code[x_] := N[(N[(-1.0 / N[Sqrt[x], $MachinePrecision]), $MachinePrecision] / N[(-2.0 * x + -1.5), $MachinePrecision]), $MachinePrecision]
        
        \begin{array}{l}
        
        \\
        \frac{\frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(-2, x, -1.5\right)}
        \end{array}
        
        Derivation
        1. Initial program 46.1%

          \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. lift--.f64N/A

            \[\leadsto \color{blue}{\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}} \]
          2. lift-/.f64N/A

            \[\leadsto \color{blue}{\frac{1}{\sqrt{x}}} - \frac{1}{\sqrt{x + 1}} \]
          3. lift-/.f64N/A

            \[\leadsto \frac{1}{\sqrt{x}} - \color{blue}{\frac{1}{\sqrt{x + 1}}} \]
          4. frac-subN/A

            \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
          5. div-invN/A

            \[\leadsto \color{blue}{\left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}}} \]
          6. metadata-evalN/A

            \[\leadsto \left(1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot \color{blue}{\frac{1}{1}}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
          7. div-invN/A

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

            \[\leadsto \left(\color{blue}{\sqrt{x + 1}} - \frac{\sqrt{x}}{1}\right) \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
          9. flip--N/A

            \[\leadsto \color{blue}{\frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}}} \cdot \frac{1}{\sqrt{x} \cdot \sqrt{x + 1}} \]
          10. metadata-evalN/A

            \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \frac{\color{blue}{1 \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}} \]
          11. frac-timesN/A

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

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

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

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

            \[\leadsto \frac{\sqrt{x + 1} \cdot \sqrt{x + 1} - \frac{\sqrt{x}}{1} \cdot \frac{\sqrt{x}}{1}}{\sqrt{x + 1} + \frac{\sqrt{x}}{1}} \cdot \color{blue}{\frac{\frac{1}{\sqrt{x}} \cdot -1}{\mathsf{neg}\left(\sqrt{x + 1}\right)}} \]
        4. Applied rewrites48.6%

          \[\leadsto \color{blue}{\frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(-\sqrt{x + 1}\right)}} \]
        5. Taylor expanded in x around inf

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

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

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

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

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

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\color{blue}{\left(2 \cdot \left(\mathsf{neg}\left(\frac{1}{x}\right)\right)\right)} \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          6. distribute-neg-fracN/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(2 \cdot \color{blue}{\frac{\mathsf{neg}\left(1\right)}{x}}\right) \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          7. metadata-evalN/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(2 \cdot \frac{\color{blue}{-1}}{x}\right) \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          8. rem-square-sqrtN/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\left(2 \cdot \frac{\color{blue}{\sqrt{-1} \cdot \sqrt{-1}}}{x}\right) \cdot {x}^{2} + \left(\mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          9. unpow2N/A

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

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\color{blue}{\mathsf{fma}\left(2 \cdot \frac{{\left(\sqrt{-1}\right)}^{2}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)}} \]
          11. associate-*r/N/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\color{blue}{\frac{2 \cdot {\left(\sqrt{-1}\right)}^{2}}{x}}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          12. unpow2N/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{2 \cdot \color{blue}{\left(\sqrt{-1} \cdot \sqrt{-1}\right)}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          13. rem-square-sqrtN/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{2 \cdot \color{blue}{-1}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          14. metadata-evalN/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{\color{blue}{-2}}{x}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          15. lower-/.f64N/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\color{blue}{\frac{-2}{x}}, {x}^{2}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          16. unpow2N/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{-2}{x}, \color{blue}{x \cdot x}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
          17. lower-*.f64N/A

            \[\leadsto \frac{\left(\left(x + 1\right) - x\right) \cdot \frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(\frac{-2}{x}, \color{blue}{x \cdot x}, \mathsf{neg}\left(\left(\frac{3}{2} \cdot \frac{1}{{x}^{2}}\right) \cdot {x}^{2}\right)\right)} \]
        7. Applied rewrites47.6%

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

          \[\leadsto \frac{\color{blue}{-1 \cdot \sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
        9. Step-by-step derivation
          1. mul-1-negN/A

            \[\leadsto \frac{\color{blue}{\mathsf{neg}\left(\sqrt{\frac{1}{x}}\right)}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
          2. lower-neg.f64N/A

            \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
          3. lower-sqrt.f64N/A

            \[\leadsto \frac{-\color{blue}{\sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, \frac{-3}{2}\right)} \]
          4. lower-/.f6486.6

            \[\leadsto \frac{-\sqrt{\color{blue}{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, -1.5\right)} \]
        10. Applied rewrites86.6%

          \[\leadsto \frac{\color{blue}{-\sqrt{\frac{1}{x}}}}{\mathsf{fma}\left(\frac{-2}{x}, x \cdot x, -1.5\right)} \]
        11. Step-by-step derivation
          1. Applied rewrites98.5%

            \[\leadsto \color{blue}{\frac{\frac{-1}{\sqrt{x}}}{\mathsf{fma}\left(-2, x, -1.5\right)}} \]
          2. Add Preprocessing

          Alternative 7: 97.5% accurate, 1.5× speedup?

          \[\begin{array}{l} \\ \frac{\frac{0.5}{\sqrt{x}}}{x} \end{array} \]
          (FPCore (x) :precision binary64 (/ (/ 0.5 (sqrt x)) x))
          double code(double x) {
          	return (0.5 / sqrt(x)) / x;
          }
          
          real(8) function code(x)
              real(8), intent (in) :: x
              code = (0.5d0 / sqrt(x)) / x
          end function
          
          public static double code(double x) {
          	return (0.5 / Math.sqrt(x)) / x;
          }
          
          def code(x):
          	return (0.5 / math.sqrt(x)) / x
          
          function code(x)
          	return Float64(Float64(0.5 / sqrt(x)) / x)
          end
          
          function tmp = code(x)
          	tmp = (0.5 / sqrt(x)) / x;
          end
          
          code[x_] := N[(N[(0.5 / N[Sqrt[x], $MachinePrecision]), $MachinePrecision] / x), $MachinePrecision]
          
          \begin{array}{l}
          
          \\
          \frac{\frac{0.5}{\sqrt{x}}}{x}
          \end{array}
          
          Derivation
          1. Initial program 46.1%

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

            \[\leadsto \color{blue}{\frac{1}{2} \cdot \sqrt{\frac{1}{{x}^{3}}}} \]
          4. Step-by-step derivation
            1. *-commutativeN/A

              \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}} \cdot \frac{1}{2}} \]
            2. lower-*.f64N/A

              \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}} \cdot \frac{1}{2}} \]
            3. lower-sqrt.f64N/A

              \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}}} \cdot \frac{1}{2} \]
            4. lower-/.f64N/A

              \[\leadsto \sqrt{\color{blue}{\frac{1}{{x}^{3}}}} \cdot \frac{1}{2} \]
            5. lower-pow.f6474.8

              \[\leadsto \sqrt{\frac{1}{\color{blue}{{x}^{3}}}} \cdot 0.5 \]
          5. Applied rewrites74.8%

            \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}} \cdot 0.5} \]
          6. Step-by-step derivation
            1. Applied rewrites96.9%

              \[\leadsto \frac{\frac{-1}{\sqrt{x}}}{-x} \cdot 0.5 \]
            2. Step-by-step derivation
              1. Applied rewrites96.9%

                \[\leadsto \frac{\frac{-0.5}{\sqrt{x}}}{\color{blue}{-x}} \]
              2. Step-by-step derivation
                1. Applied rewrites96.9%

                  \[\leadsto \frac{\frac{0.5}{\sqrt{x}}}{\color{blue}{x}} \]
                2. Add Preprocessing

                Alternative 8: 97.5% accurate, 1.5× speedup?

                \[\begin{array}{l} \\ \frac{\frac{0.5}{x}}{\sqrt{x}} \end{array} \]
                (FPCore (x) :precision binary64 (/ (/ 0.5 x) (sqrt x)))
                double code(double x) {
                	return (0.5 / x) / sqrt(x);
                }
                
                real(8) function code(x)
                    real(8), intent (in) :: x
                    code = (0.5d0 / x) / sqrt(x)
                end function
                
                public static double code(double x) {
                	return (0.5 / x) / Math.sqrt(x);
                }
                
                def code(x):
                	return (0.5 / x) / math.sqrt(x)
                
                function code(x)
                	return Float64(Float64(0.5 / x) / sqrt(x))
                end
                
                function tmp = code(x)
                	tmp = (0.5 / x) / sqrt(x);
                end
                
                code[x_] := N[(N[(0.5 / x), $MachinePrecision] / N[Sqrt[x], $MachinePrecision]), $MachinePrecision]
                
                \begin{array}{l}
                
                \\
                \frac{\frac{0.5}{x}}{\sqrt{x}}
                \end{array}
                
                Derivation
                1. Initial program 46.1%

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

                  \[\leadsto \color{blue}{\frac{1}{2} \cdot \sqrt{\frac{1}{{x}^{3}}}} \]
                4. Step-by-step derivation
                  1. *-commutativeN/A

                    \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}} \cdot \frac{1}{2}} \]
                  2. lower-*.f64N/A

                    \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}} \cdot \frac{1}{2}} \]
                  3. lower-sqrt.f64N/A

                    \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}}} \cdot \frac{1}{2} \]
                  4. lower-/.f64N/A

                    \[\leadsto \sqrt{\color{blue}{\frac{1}{{x}^{3}}}} \cdot \frac{1}{2} \]
                  5. lower-pow.f6474.8

                    \[\leadsto \sqrt{\frac{1}{\color{blue}{{x}^{3}}}} \cdot 0.5 \]
                5. Applied rewrites74.8%

                  \[\leadsto \color{blue}{\sqrt{\frac{1}{{x}^{3}}} \cdot 0.5} \]
                6. Step-by-step derivation
                  1. Applied rewrites96.9%

                    \[\leadsto \frac{\frac{-1}{\sqrt{x}}}{-x} \cdot 0.5 \]
                  2. Step-by-step derivation
                    1. Applied rewrites96.9%

                      \[\leadsto \frac{\frac{-0.5}{\sqrt{x}}}{\color{blue}{-x}} \]
                    2. Step-by-step derivation
                      1. Applied rewrites96.9%

                        \[\leadsto \frac{\frac{0.5}{x}}{\color{blue}{\sqrt{x}}} \]
                      2. Add Preprocessing

                      Alternative 9: 81.2% accurate, 1.5× speedup?

                      \[\begin{array}{l} \\ \frac{0.5 \cdot \sqrt{x}}{x \cdot x} \end{array} \]
                      (FPCore (x) :precision binary64 (/ (* 0.5 (sqrt x)) (* x x)))
                      double code(double x) {
                      	return (0.5 * sqrt(x)) / (x * x);
                      }
                      
                      real(8) function code(x)
                          real(8), intent (in) :: x
                          code = (0.5d0 * sqrt(x)) / (x * x)
                      end function
                      
                      public static double code(double x) {
                      	return (0.5 * Math.sqrt(x)) / (x * x);
                      }
                      
                      def code(x):
                      	return (0.5 * math.sqrt(x)) / (x * x)
                      
                      function code(x)
                      	return Float64(Float64(0.5 * sqrt(x)) / Float64(x * x))
                      end
                      
                      function tmp = code(x)
                      	tmp = (0.5 * sqrt(x)) / (x * x);
                      end
                      
                      code[x_] := N[(N[(0.5 * N[Sqrt[x], $MachinePrecision]), $MachinePrecision] / N[(x * x), $MachinePrecision]), $MachinePrecision]
                      
                      \begin{array}{l}
                      
                      \\
                      \frac{0.5 \cdot \sqrt{x}}{x \cdot x}
                      \end{array}
                      
                      Derivation
                      1. Initial program 46.1%

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

                        \[\leadsto \color{blue}{\frac{\frac{1}{2} \cdot \left(\sqrt{\frac{1}{{x}^{3}}} \cdot \left(1 + \frac{1}{4} \cdot x\right)\right) - \left(\frac{-1}{2} \cdot \sqrt{x} + \frac{1}{2} \cdot \sqrt{\frac{1}{x}}\right)}{{x}^{2}}} \]
                      4. Applied rewrites86.5%

                        \[\leadsto \color{blue}{\frac{-0.5 \cdot \left(\sqrt{\frac{1}{x}} - \mathsf{fma}\left(\mathsf{fma}\left(0.25, x, 1\right), \sqrt{\frac{1}{{x}^{3}}}, \sqrt{x}\right)\right)}{x \cdot x}} \]
                      5. Taylor expanded in x around inf

                        \[\leadsto \frac{\frac{1}{2} \cdot \sqrt{x}}{\color{blue}{x} \cdot x} \]
                      6. Step-by-step derivation
                        1. Applied rewrites85.0%

                          \[\leadsto \frac{0.5 \cdot \sqrt{x}}{\color{blue}{x} \cdot x} \]
                        2. Add Preprocessing

                        Alternative 10: 35.9% accurate, 1.8× speedup?

                        \[\begin{array}{l} \\ \sqrt{\frac{x}{x \cdot x}} \end{array} \]
                        (FPCore (x) :precision binary64 (sqrt (/ x (* x x))))
                        double code(double x) {
                        	return sqrt((x / (x * x)));
                        }
                        
                        real(8) function code(x)
                            real(8), intent (in) :: x
                            code = sqrt((x / (x * x)))
                        end function
                        
                        public static double code(double x) {
                        	return Math.sqrt((x / (x * x)));
                        }
                        
                        def code(x):
                        	return math.sqrt((x / (x * x)))
                        
                        function code(x)
                        	return sqrt(Float64(x / Float64(x * x)))
                        end
                        
                        function tmp = code(x)
                        	tmp = sqrt((x / (x * x)));
                        end
                        
                        code[x_] := N[Sqrt[N[(x / N[(x * x), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
                        
                        \begin{array}{l}
                        
                        \\
                        \sqrt{\frac{x}{x \cdot x}}
                        \end{array}
                        
                        Derivation
                        1. Initial program 46.1%

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

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

                            \[\leadsto \color{blue}{\sqrt{\frac{1}{x}}} \]
                          2. lower-/.f645.8

                            \[\leadsto \sqrt{\color{blue}{\frac{1}{x}}} \]
                        5. Applied rewrites5.8%

                          \[\leadsto \color{blue}{\sqrt{\frac{1}{x}}} \]
                        6. Step-by-step derivation
                          1. Applied rewrites43.8%

                            \[\leadsto \sqrt{\frac{x}{x \cdot x}} \]
                          2. Add Preprocessing

                          Alternative 11: 5.6% accurate, 2.2× speedup?

                          \[\begin{array}{l} \\ \sqrt{\frac{1}{x}} \end{array} \]
                          (FPCore (x) :precision binary64 (sqrt (/ 1.0 x)))
                          double code(double x) {
                          	return sqrt((1.0 / x));
                          }
                          
                          real(8) function code(x)
                              real(8), intent (in) :: x
                              code = sqrt((1.0d0 / x))
                          end function
                          
                          public static double code(double x) {
                          	return Math.sqrt((1.0 / x));
                          }
                          
                          def code(x):
                          	return math.sqrt((1.0 / x))
                          
                          function code(x)
                          	return sqrt(Float64(1.0 / x))
                          end
                          
                          function tmp = code(x)
                          	tmp = sqrt((1.0 / x));
                          end
                          
                          code[x_] := N[Sqrt[N[(1.0 / x), $MachinePrecision]], $MachinePrecision]
                          
                          \begin{array}{l}
                          
                          \\
                          \sqrt{\frac{1}{x}}
                          \end{array}
                          
                          Derivation
                          1. Initial program 46.1%

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

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

                              \[\leadsto \color{blue}{\sqrt{\frac{1}{x}}} \]
                            2. lower-/.f645.8

                              \[\leadsto \sqrt{\color{blue}{\frac{1}{x}}} \]
                          5. Applied rewrites5.8%

                            \[\leadsto \color{blue}{\sqrt{\frac{1}{x}}} \]
                          6. Add Preprocessing

                          Developer Target 1: 37.7% accurate, 0.2× speedup?

                          \[\begin{array}{l} \\ {x}^{-0.5} - {\left(x + 1\right)}^{-0.5} \end{array} \]
                          (FPCore (x) :precision binary64 (- (pow x -0.5) (pow (+ x 1.0) -0.5)))
                          double code(double x) {
                          	return pow(x, -0.5) - pow((x + 1.0), -0.5);
                          }
                          
                          real(8) function code(x)
                              real(8), intent (in) :: x
                              code = (x ** (-0.5d0)) - ((x + 1.0d0) ** (-0.5d0))
                          end function
                          
                          public static double code(double x) {
                          	return Math.pow(x, -0.5) - Math.pow((x + 1.0), -0.5);
                          }
                          
                          def code(x):
                          	return math.pow(x, -0.5) - math.pow((x + 1.0), -0.5)
                          
                          function code(x)
                          	return Float64((x ^ -0.5) - (Float64(x + 1.0) ^ -0.5))
                          end
                          
                          function tmp = code(x)
                          	tmp = (x ^ -0.5) - ((x + 1.0) ^ -0.5);
                          end
                          
                          code[x_] := N[(N[Power[x, -0.5], $MachinePrecision] - N[Power[N[(x + 1.0), $MachinePrecision], -0.5], $MachinePrecision]), $MachinePrecision]
                          
                          \begin{array}{l}
                          
                          \\
                          {x}^{-0.5} - {\left(x + 1\right)}^{-0.5}
                          \end{array}
                          

                          Reproduce

                          ?
                          herbie shell --seed 2024270 
                          (FPCore (x)
                            :name "2isqrt (example 3.6)"
                            :precision binary64
                            :pre (and (> x 1.0) (< x 1e+308))
                          
                            :alt
                            (! :herbie-platform default (- (pow x -1/2) (pow (+ x 1) -1/2)))
                          
                            (- (/ 1.0 (sqrt x)) (/ 1.0 (sqrt (+ x 1.0)))))