Migdal et al, Equation (51)

Percentage Accurate: 99.4% → 99.5%
Time: 6.5s
Alternatives: 12
Speedup: 0.8×

Specification

?
\[\begin{array}{l} \\ \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \end{array} \]
(FPCore (k n)
 :precision binary64
 (* (/ 1.0 (sqrt k)) (pow (* (* 2.0 PI) n) (/ (- 1.0 k) 2.0))))
double code(double k, double n) {
	return (1.0 / sqrt(k)) * pow(((2.0 * ((double) M_PI)) * n), ((1.0 - k) / 2.0));
}
public static double code(double k, double n) {
	return (1.0 / Math.sqrt(k)) * Math.pow(((2.0 * Math.PI) * n), ((1.0 - k) / 2.0));
}
def code(k, n):
	return (1.0 / math.sqrt(k)) * math.pow(((2.0 * math.pi) * n), ((1.0 - k) / 2.0))
function code(k, n)
	return Float64(Float64(1.0 / sqrt(k)) * (Float64(Float64(2.0 * pi) * n) ^ Float64(Float64(1.0 - k) / 2.0)))
end
function tmp = code(k, n)
	tmp = (1.0 / sqrt(k)) * (((2.0 * pi) * n) ^ ((1.0 - k) / 2.0));
end
code[k_, n_] := N[(N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision] * N[Power[N[(N[(2.0 * Pi), $MachinePrecision] * n), $MachinePrecision], N[(N[(1.0 - k), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}
\end{array}

Local Percentage Accuracy vs ?

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

Accuracy vs Speed?

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

\[\begin{array}{l} \\ \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \end{array} \]
(FPCore (k n)
 :precision binary64
 (* (/ 1.0 (sqrt k)) (pow (* (* 2.0 PI) n) (/ (- 1.0 k) 2.0))))
double code(double k, double n) {
	return (1.0 / sqrt(k)) * pow(((2.0 * ((double) M_PI)) * n), ((1.0 - k) / 2.0));
}
public static double code(double k, double n) {
	return (1.0 / Math.sqrt(k)) * Math.pow(((2.0 * Math.PI) * n), ((1.0 - k) / 2.0));
}
def code(k, n):
	return (1.0 / math.sqrt(k)) * math.pow(((2.0 * math.pi) * n), ((1.0 - k) / 2.0))
function code(k, n)
	return Float64(Float64(1.0 / sqrt(k)) * (Float64(Float64(2.0 * pi) * n) ^ Float64(Float64(1.0 - k) / 2.0)))
end
function tmp = code(k, n)
	tmp = (1.0 / sqrt(k)) * (((2.0 * pi) * n) ^ ((1.0 - k) / 2.0));
end
code[k_, n_] := N[(N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision] * N[Power[N[(N[(2.0 * Pi), $MachinePrecision] * n), $MachinePrecision], N[(N[(1.0 - k), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}
\end{array}

Alternative 1: 99.5% accurate, 0.6× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := n \cdot \left(\pi + \pi\right)\\ \frac{1}{\sqrt{k}} \cdot \left({t\_0}^{\left(k \cdot -0.5\right)} \cdot {t\_0}^{0.5}\right) \end{array} \end{array} \]
(FPCore (k n)
 :precision binary64
 (let* ((t_0 (* n (+ PI PI))))
   (* (/ 1.0 (sqrt k)) (* (pow t_0 (* k -0.5)) (pow t_0 0.5)))))
double code(double k, double n) {
	double t_0 = n * (((double) M_PI) + ((double) M_PI));
	return (1.0 / sqrt(k)) * (pow(t_0, (k * -0.5)) * pow(t_0, 0.5));
}
public static double code(double k, double n) {
	double t_0 = n * (Math.PI + Math.PI);
	return (1.0 / Math.sqrt(k)) * (Math.pow(t_0, (k * -0.5)) * Math.pow(t_0, 0.5));
}
def code(k, n):
	t_0 = n * (math.pi + math.pi)
	return (1.0 / math.sqrt(k)) * (math.pow(t_0, (k * -0.5)) * math.pow(t_0, 0.5))
function code(k, n)
	t_0 = Float64(n * Float64(pi + pi))
	return Float64(Float64(1.0 / sqrt(k)) * Float64((t_0 ^ Float64(k * -0.5)) * (t_0 ^ 0.5)))
end
function tmp = code(k, n)
	t_0 = n * (pi + pi);
	tmp = (1.0 / sqrt(k)) * ((t_0 ^ (k * -0.5)) * (t_0 ^ 0.5));
end
code[k_, n_] := Block[{t$95$0 = N[(n * N[(Pi + Pi), $MachinePrecision]), $MachinePrecision]}, N[(N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision] * N[(N[Power[t$95$0, N[(k * -0.5), $MachinePrecision]], $MachinePrecision] * N[Power[t$95$0, 0.5], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := n \cdot \left(\pi + \pi\right)\\
\frac{1}{\sqrt{k}} \cdot \left({t\_0}^{\left(k \cdot -0.5\right)} \cdot {t\_0}^{0.5}\right)
\end{array}
\end{array}
Derivation
  1. Initial program 99.4%

    \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
  2. Step-by-step derivation
    1. lift-pow.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}} \]
    2. lift-/.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\color{blue}{\left(\frac{1 - k}{2}\right)}} \]
    3. lift--.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{1 - k}}{2}\right)} \]
    4. sub-flipN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{1 + \left(\mathsf{neg}\left(k\right)\right)}}{2}\right)} \]
    5. +-commutativeN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{\left(\mathsf{neg}\left(k\right)\right) + 1}}{2}\right)} \]
    6. div-addN/A

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

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2} + \color{blue}{\frac{1}{2}}\right)} \]
    8. pow-addN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2}\right)} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\frac{1}{2}}\right)} \]
    9. lower-unsound-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2}\right)} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\frac{1}{2}}\right)} \]
  3. Applied rewrites99.4%

    \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot -0.5\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{0.5}\right)} \]
  4. Add Preprocessing

Alternative 2: 99.4% accurate, 0.8× speedup?

\[\begin{array}{l} \\ \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot -0.5\right)} \cdot \left(\sqrt{\pi \cdot n} \cdot \sqrt{2}\right)\right) \end{array} \]
(FPCore (k n)
 :precision binary64
 (*
  (/ 1.0 (sqrt k))
  (* (pow (* n (+ PI PI)) (* k -0.5)) (* (sqrt (* PI n)) (sqrt 2.0)))))
double code(double k, double n) {
	return (1.0 / sqrt(k)) * (pow((n * (((double) M_PI) + ((double) M_PI))), (k * -0.5)) * (sqrt((((double) M_PI) * n)) * sqrt(2.0)));
}
public static double code(double k, double n) {
	return (1.0 / Math.sqrt(k)) * (Math.pow((n * (Math.PI + Math.PI)), (k * -0.5)) * (Math.sqrt((Math.PI * n)) * Math.sqrt(2.0)));
}
def code(k, n):
	return (1.0 / math.sqrt(k)) * (math.pow((n * (math.pi + math.pi)), (k * -0.5)) * (math.sqrt((math.pi * n)) * math.sqrt(2.0)))
function code(k, n)
	return Float64(Float64(1.0 / sqrt(k)) * Float64((Float64(n * Float64(pi + pi)) ^ Float64(k * -0.5)) * Float64(sqrt(Float64(pi * n)) * sqrt(2.0))))
end
function tmp = code(k, n)
	tmp = (1.0 / sqrt(k)) * (((n * (pi + pi)) ^ (k * -0.5)) * (sqrt((pi * n)) * sqrt(2.0)));
end
code[k_, n_] := N[(N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision] * N[(N[Power[N[(n * N[(Pi + Pi), $MachinePrecision]), $MachinePrecision], N[(k * -0.5), $MachinePrecision]], $MachinePrecision] * N[(N[Sqrt[N[(Pi * n), $MachinePrecision]], $MachinePrecision] * N[Sqrt[2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot -0.5\right)} \cdot \left(\sqrt{\pi \cdot n} \cdot \sqrt{2}\right)\right)
\end{array}
Derivation
  1. Initial program 99.4%

    \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
  2. Step-by-step derivation
    1. lift-pow.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}} \]
    2. lift-/.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\color{blue}{\left(\frac{1 - k}{2}\right)}} \]
    3. lift--.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{1 - k}}{2}\right)} \]
    4. sub-flipN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{1 + \left(\mathsf{neg}\left(k\right)\right)}}{2}\right)} \]
    5. +-commutativeN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{\left(\mathsf{neg}\left(k\right)\right) + 1}}{2}\right)} \]
    6. div-addN/A

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

      \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2} + \color{blue}{\frac{1}{2}}\right)} \]
    8. pow-addN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2}\right)} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\frac{1}{2}}\right)} \]
    9. lower-unsound-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2}\right)} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\frac{1}{2}}\right)} \]
  3. Applied rewrites99.4%

    \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot -0.5\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{0.5}\right)} \]
  4. Step-by-step derivation
    1. lift-pow.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \color{blue}{{\left(n \cdot \left(\pi + \pi\right)\right)}^{\frac{1}{2}}}\right) \]
    2. sqr-powN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \color{blue}{\left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)}\right) \]
    3. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\color{blue}{\left(n \cdot \left(\pi + \pi\right)\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    4. lift-+.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(n \cdot \color{blue}{\left(\pi + \pi\right)}\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    5. distribute-lft-inN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\color{blue}{\left(n \cdot \pi + n \cdot \pi\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    6. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(\color{blue}{n \cdot \pi} + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    7. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(n \cdot \pi + \color{blue}{n \cdot \pi}\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    8. count-2-revN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\color{blue}{\left(2 \cdot \left(n \cdot \pi\right)\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    9. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\color{blue}{\left(2 \cdot \left(n \cdot \pi\right)\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    10. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\color{blue}{\left(n \cdot \left(\pi + \pi\right)\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    11. lift-+.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \color{blue}{\left(\pi + \pi\right)}\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    12. distribute-lft-inN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\color{blue}{\left(n \cdot \pi + n \cdot \pi\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    13. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{n \cdot \pi} + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    14. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(n \cdot \pi + \color{blue}{n \cdot \pi}\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    15. count-2-revN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\color{blue}{\left(2 \cdot \left(n \cdot \pi\right)\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    16. lift-*.f64N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\color{blue}{\left(2 \cdot \left(n \cdot \pi\right)\right)}}^{\left(\frac{\frac{1}{2}}{2}\right)}\right)\right) \]
    17. sqr-powN/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}\right) \]
    18. unpow1/2N/A

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot \frac{-1}{2}\right)} \cdot \color{blue}{\sqrt{2 \cdot \left(n \cdot \pi\right)}}\right) \]
  5. Applied rewrites99.4%

    \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot -0.5\right)} \cdot \color{blue}{\left(\sqrt{\pi \cdot n} \cdot \sqrt{2}\right)}\right) \]
  6. Add Preprocessing

Alternative 3: 99.4% accurate, 1.0× speedup?

\[\begin{array}{l} \\ {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, -0.5, 0.5\right)\right)} \cdot \frac{1}{\sqrt{k}} \end{array} \]
(FPCore (k n)
 :precision binary64
 (* (pow (* n (+ PI PI)) (fma k -0.5 0.5)) (/ 1.0 (sqrt k))))
double code(double k, double n) {
	return pow((n * (((double) M_PI) + ((double) M_PI))), fma(k, -0.5, 0.5)) * (1.0 / sqrt(k));
}
function code(k, n)
	return Float64((Float64(n * Float64(pi + pi)) ^ fma(k, -0.5, 0.5)) * Float64(1.0 / sqrt(k)))
end
code[k_, n_] := N[(N[Power[N[(n * N[(Pi + Pi), $MachinePrecision]), $MachinePrecision], N[(k * -0.5 + 0.5), $MachinePrecision]], $MachinePrecision] * N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
{\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, -0.5, 0.5\right)\right)} \cdot \frac{1}{\sqrt{k}}
\end{array}
Derivation
  1. Initial program 99.4%

    \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
  2. Step-by-step derivation
    1. lift-*.f64N/A

      \[\leadsto \color{blue}{\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}} \]
    2. *-commutativeN/A

      \[\leadsto \color{blue}{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}}} \]
    3. lower-*.f6499.4

      \[\leadsto \color{blue}{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}}} \]
    4. lift-*.f64N/A

      \[\leadsto {\color{blue}{\left(\left(2 \cdot \pi\right) \cdot n\right)}}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    5. *-commutativeN/A

      \[\leadsto {\color{blue}{\left(n \cdot \left(2 \cdot \pi\right)\right)}}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    6. lower-*.f6499.4

      \[\leadsto {\color{blue}{\left(n \cdot \left(2 \cdot \pi\right)\right)}}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    7. lift-*.f64N/A

      \[\leadsto {\left(n \cdot \color{blue}{\left(2 \cdot \pi\right)}\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    8. count-2-revN/A

      \[\leadsto {\left(n \cdot \color{blue}{\left(\pi + \pi\right)}\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    9. lower-+.f6499.4

      \[\leadsto {\left(n \cdot \color{blue}{\left(\pi + \pi\right)}\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    10. lift-/.f64N/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\color{blue}{\left(\frac{1 - k}{2}\right)}} \cdot \frac{1}{\sqrt{k}} \]
    11. lift--.f64N/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\color{blue}{1 - k}}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    12. sub-flipN/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\color{blue}{1 + \left(\mathsf{neg}\left(k\right)\right)}}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    13. +-commutativeN/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\color{blue}{\left(\mathsf{neg}\left(k\right)\right) + 1}}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    14. div-addN/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\color{blue}{\left(\frac{\mathsf{neg}\left(k\right)}{2} + \frac{1}{2}\right)}} \cdot \frac{1}{\sqrt{k}} \]
    15. distribute-neg-fracN/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\color{blue}{\left(\mathsf{neg}\left(\frac{k}{2}\right)\right)} + \frac{1}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    16. mult-flipN/A

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\left(\mathsf{neg}\left(\color{blue}{k \cdot \frac{1}{2}}\right)\right) + \frac{1}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    17. metadata-evalN/A

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

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\color{blue}{k \cdot \left(\mathsf{neg}\left(\frac{1}{2}\right)\right)} + \frac{1}{2}\right)} \cdot \frac{1}{\sqrt{k}} \]
    19. metadata-evalN/A

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

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\color{blue}{\left(\mathsf{fma}\left(k, \mathsf{neg}\left(\frac{1}{2}\right), \frac{1}{2}\right)\right)}} \cdot \frac{1}{\sqrt{k}} \]
    21. metadata-eval99.4

      \[\leadsto {\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, \color{blue}{-0.5}, 0.5\right)\right)} \cdot \frac{1}{\sqrt{k}} \]
  3. Applied rewrites99.4%

    \[\leadsto \color{blue}{{\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, -0.5, 0.5\right)\right)} \cdot \frac{1}{\sqrt{k}}} \]
  4. Add Preprocessing

Alternative 4: 99.4% accurate, 1.1× speedup?

\[\begin{array}{l} \\ \frac{{\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, -0.5, 0.5\right)\right)}}{\sqrt{k}} \end{array} \]
(FPCore (k n)
 :precision binary64
 (/ (pow (* n (+ PI PI)) (fma k -0.5 0.5)) (sqrt k)))
double code(double k, double n) {
	return pow((n * (((double) M_PI) + ((double) M_PI))), fma(k, -0.5, 0.5)) / sqrt(k);
}
function code(k, n)
	return Float64((Float64(n * Float64(pi + pi)) ^ fma(k, -0.5, 0.5)) / sqrt(k))
end
code[k_, n_] := N[(N[Power[N[(n * N[(Pi + Pi), $MachinePrecision]), $MachinePrecision], N[(k * -0.5 + 0.5), $MachinePrecision]], $MachinePrecision] / N[Sqrt[k], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{{\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, -0.5, 0.5\right)\right)}}{\sqrt{k}}
\end{array}
Derivation
  1. Initial program 99.4%

    \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
  2. Step-by-step derivation
    1. lift-*.f64N/A

      \[\leadsto \color{blue}{\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}} \]
    2. *-commutativeN/A

      \[\leadsto \color{blue}{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \frac{1}{\sqrt{k}}} \]
    3. lift-/.f64N/A

      \[\leadsto {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \cdot \color{blue}{\frac{1}{\sqrt{k}}} \]
    4. mult-flip-revN/A

      \[\leadsto \color{blue}{\frac{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}}{\sqrt{k}}} \]
    5. lower-/.f6499.5

      \[\leadsto \color{blue}{\frac{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}}{\sqrt{k}}} \]
  3. Applied rewrites99.5%

    \[\leadsto \color{blue}{\frac{{\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\mathsf{fma}\left(k, -0.5, 0.5\right)\right)}}{\sqrt{k}}} \]
  4. Add Preprocessing

Alternative 5: 98.1% accurate, 1.1× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(\pi + \pi\right) \cdot n\\ \mathbf{if}\;k \leq 1:\\ \;\;\;\;\frac{1}{\sqrt{k}} \cdot \sqrt{t\_0}\\ \mathbf{else}:\\ \;\;\;\;\frac{{t\_0}^{\left(-0.5 \cdot k\right)}}{\sqrt{k}}\\ \end{array} \end{array} \]
(FPCore (k n)
 :precision binary64
 (let* ((t_0 (* (+ PI PI) n)))
   (if (<= k 1.0)
     (* (/ 1.0 (sqrt k)) (sqrt t_0))
     (/ (pow t_0 (* -0.5 k)) (sqrt k)))))
double code(double k, double n) {
	double t_0 = (((double) M_PI) + ((double) M_PI)) * n;
	double tmp;
	if (k <= 1.0) {
		tmp = (1.0 / sqrt(k)) * sqrt(t_0);
	} else {
		tmp = pow(t_0, (-0.5 * k)) / sqrt(k);
	}
	return tmp;
}
public static double code(double k, double n) {
	double t_0 = (Math.PI + Math.PI) * n;
	double tmp;
	if (k <= 1.0) {
		tmp = (1.0 / Math.sqrt(k)) * Math.sqrt(t_0);
	} else {
		tmp = Math.pow(t_0, (-0.5 * k)) / Math.sqrt(k);
	}
	return tmp;
}
def code(k, n):
	t_0 = (math.pi + math.pi) * n
	tmp = 0
	if k <= 1.0:
		tmp = (1.0 / math.sqrt(k)) * math.sqrt(t_0)
	else:
		tmp = math.pow(t_0, (-0.5 * k)) / math.sqrt(k)
	return tmp
function code(k, n)
	t_0 = Float64(Float64(pi + pi) * n)
	tmp = 0.0
	if (k <= 1.0)
		tmp = Float64(Float64(1.0 / sqrt(k)) * sqrt(t_0));
	else
		tmp = Float64((t_0 ^ Float64(-0.5 * k)) / sqrt(k));
	end
	return tmp
end
function tmp_2 = code(k, n)
	t_0 = (pi + pi) * n;
	tmp = 0.0;
	if (k <= 1.0)
		tmp = (1.0 / sqrt(k)) * sqrt(t_0);
	else
		tmp = (t_0 ^ (-0.5 * k)) / sqrt(k);
	end
	tmp_2 = tmp;
end
code[k_, n_] := Block[{t$95$0 = N[(N[(Pi + Pi), $MachinePrecision] * n), $MachinePrecision]}, If[LessEqual[k, 1.0], N[(N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision] * N[Sqrt[t$95$0], $MachinePrecision]), $MachinePrecision], N[(N[Power[t$95$0, N[(-0.5 * k), $MachinePrecision]], $MachinePrecision] / N[Sqrt[k], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left(\pi + \pi\right) \cdot n\\
\mathbf{if}\;k \leq 1:\\
\;\;\;\;\frac{1}{\sqrt{k}} \cdot \sqrt{t\_0}\\

\mathbf{else}:\\
\;\;\;\;\frac{{t\_0}^{\left(-0.5 \cdot k\right)}}{\sqrt{k}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if k < 1

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. mult-flipN/A

        \[\leadsto {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}} \cdot \color{blue}{\frac{1}{\sqrt{k}}} \]
      3. lift-/.f64N/A

        \[\leadsto {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}} \cdot \frac{1}{\color{blue}{\sqrt{k}}} \]
      4. *-commutativeN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}} \]
      5. lower-*.f6450.6

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}} \]
      6. lift-pow.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\color{blue}{\frac{1}{2}}} \]
      7. sqr-powN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}}\right) \]
      8. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      9. count-2-revN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \pi + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      10. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \pi + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      11. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \pi + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      12. distribute-lft-inN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      13. lift-+.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      14. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
    6. Applied rewrites50.6%

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\sqrt{\left(\pi + \pi\right) \cdot n}} \]

    if 1 < k

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Step-by-step derivation
      1. lift-pow.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)}} \]
      2. lift-/.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\color{blue}{\left(\frac{1 - k}{2}\right)}} \]
      3. lift--.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{1 - k}}{2}\right)} \]
      4. sub-flipN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{1 + \left(\mathsf{neg}\left(k\right)\right)}}{2}\right)} \]
      5. +-commutativeN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\color{blue}{\left(\mathsf{neg}\left(k\right)\right) + 1}}{2}\right)} \]
      6. div-addN/A

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

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2} + \color{blue}{\frac{1}{2}}\right)} \]
      8. pow-addN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2}\right)} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\frac{1}{2}}\right)} \]
      9. lower-unsound-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{\mathsf{neg}\left(k\right)}{2}\right)} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\frac{1}{2}}\right)} \]
    3. Applied rewrites99.4%

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(k \cdot -0.5\right)} \cdot {\left(n \cdot \left(\pi + \pi\right)\right)}^{0.5}\right)} \]
    4. Applied rewrites99.5%

      \[\leadsto \color{blue}{\frac{{\left(\left(\pi + \pi\right) \cdot n\right)}^{\left(\mathsf{fma}\left(-0.5, k, 0.5\right)\right)}}{\sqrt{k}}} \]
    5. Taylor expanded in k around inf

      \[\leadsto \frac{{\left(\left(\pi + \pi\right) \cdot n\right)}^{\color{blue}{\left(\frac{-1}{2} \cdot k\right)}}}{\sqrt{k}} \]
    6. Step-by-step derivation
      1. lower-*.f6452.4

        \[\leadsto \frac{{\left(\left(\pi + \pi\right) \cdot n\right)}^{\left(-0.5 \cdot \color{blue}{k}\right)}}{\sqrt{k}} \]
    7. Applied rewrites52.4%

      \[\leadsto \frac{{\left(\left(\pi + \pi\right) \cdot n\right)}^{\color{blue}{\left(-0.5 \cdot k\right)}}}{\sqrt{k}} \]
  3. Recombined 2 regimes into one program.
  4. Add Preprocessing

Alternative 6: 62.9% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq 12000:\\ \;\;\;\;\sqrt{\frac{\pi + \pi}{k} \cdot n}\\ \mathbf{elif}\;n \leq 1.5 \cdot 10^{+31}:\\ \;\;\;\;\sqrt{2} \cdot \sqrt{\log \left(e^{\frac{n}{k} \cdot \pi}\right)}\\ \mathbf{else}:\\ \;\;\;\;n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}}\\ \end{array} \end{array} \]
(FPCore (k n)
 :precision binary64
 (if (<= n 12000.0)
   (sqrt (* (/ (+ PI PI) k) n))
   (if (<= n 1.5e+31)
     (* (sqrt 2.0) (sqrt (log (exp (* (/ n k) PI)))))
     (* n (sqrt (* 2.0 (/ PI (* k n))))))))
double code(double k, double n) {
	double tmp;
	if (n <= 12000.0) {
		tmp = sqrt((((((double) M_PI) + ((double) M_PI)) / k) * n));
	} else if (n <= 1.5e+31) {
		tmp = sqrt(2.0) * sqrt(log(exp(((n / k) * ((double) M_PI)))));
	} else {
		tmp = n * sqrt((2.0 * (((double) M_PI) / (k * n))));
	}
	return tmp;
}
public static double code(double k, double n) {
	double tmp;
	if (n <= 12000.0) {
		tmp = Math.sqrt((((Math.PI + Math.PI) / k) * n));
	} else if (n <= 1.5e+31) {
		tmp = Math.sqrt(2.0) * Math.sqrt(Math.log(Math.exp(((n / k) * Math.PI))));
	} else {
		tmp = n * Math.sqrt((2.0 * (Math.PI / (k * n))));
	}
	return tmp;
}
def code(k, n):
	tmp = 0
	if n <= 12000.0:
		tmp = math.sqrt((((math.pi + math.pi) / k) * n))
	elif n <= 1.5e+31:
		tmp = math.sqrt(2.0) * math.sqrt(math.log(math.exp(((n / k) * math.pi))))
	else:
		tmp = n * math.sqrt((2.0 * (math.pi / (k * n))))
	return tmp
function code(k, n)
	tmp = 0.0
	if (n <= 12000.0)
		tmp = sqrt(Float64(Float64(Float64(pi + pi) / k) * n));
	elseif (n <= 1.5e+31)
		tmp = Float64(sqrt(2.0) * sqrt(log(exp(Float64(Float64(n / k) * pi)))));
	else
		tmp = Float64(n * sqrt(Float64(2.0 * Float64(pi / Float64(k * n)))));
	end
	return tmp
end
function tmp_2 = code(k, n)
	tmp = 0.0;
	if (n <= 12000.0)
		tmp = sqrt((((pi + pi) / k) * n));
	elseif (n <= 1.5e+31)
		tmp = sqrt(2.0) * sqrt(log(exp(((n / k) * pi))));
	else
		tmp = n * sqrt((2.0 * (pi / (k * n))));
	end
	tmp_2 = tmp;
end
code[k_, n_] := If[LessEqual[n, 12000.0], N[Sqrt[N[(N[(N[(Pi + Pi), $MachinePrecision] / k), $MachinePrecision] * n), $MachinePrecision]], $MachinePrecision], If[LessEqual[n, 1.5e+31], N[(N[Sqrt[2.0], $MachinePrecision] * N[Sqrt[N[Log[N[Exp[N[(N[(n / k), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(n * N[Sqrt[N[(2.0 * N[(Pi / N[(k * n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq 12000:\\
\;\;\;\;\sqrt{\frac{\pi + \pi}{k} \cdot n}\\

\mathbf{elif}\;n \leq 1.5 \cdot 10^{+31}:\\
\;\;\;\;\sqrt{2} \cdot \sqrt{\log \left(e^{\frac{n}{k} \cdot \pi}\right)}\\

\mathbf{else}:\\
\;\;\;\;n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if n < 12000

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

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

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      2. mult-flipN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      3. lift-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      4. *-commutativeN/A

        \[\leadsto \sqrt{\left(n \cdot \left(\pi + \pi\right)\right) \cdot \frac{1}{k}} \]
      5. associate-*l*N/A

        \[\leadsto \sqrt{n \cdot \left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right)} \]
      6. *-commutativeN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right) \cdot n} \]
      7. lower-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right) \cdot n} \]
      8. mult-flip-revN/A

        \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
      9. lower-/.f6438.2

        \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
    8. Applied rewrites38.2%

      \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]

    if 12000 < n < 1.49999999999999995e31

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

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

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      2. lift-/.f64N/A

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      3. lift-*.f64N/A

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      4. lift-+.f64N/A

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      5. count-2-revN/A

        \[\leadsto \sqrt{\frac{\left(2 \cdot \pi\right) \cdot n}{k}} \]
      6. associate-*l*N/A

        \[\leadsto \sqrt{\frac{2 \cdot \left(\pi \cdot n\right)}{k}} \]
      7. lift-*.f64N/A

        \[\leadsto \sqrt{\frac{2 \cdot \left(\pi \cdot n\right)}{k}} \]
      8. associate-/l*N/A

        \[\leadsto \sqrt{2 \cdot \frac{\pi \cdot n}{k}} \]
      9. sqrt-prodN/A

        \[\leadsto \sqrt{2} \cdot \color{blue}{\sqrt{\frac{\pi \cdot n}{k}}} \]
      10. lower-unsound-sqrt.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\color{blue}{\frac{\pi \cdot n}{k}}} \]
      11. lower-unsound-*.f64N/A

        \[\leadsto \sqrt{2} \cdot \color{blue}{\sqrt{\frac{\pi \cdot n}{k}}} \]
      12. lower-unsound-sqrt.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{\pi \cdot n}{k}} \]
      13. lift-*.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{\pi \cdot n}{k}} \]
      14. associate-/l*N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\pi \cdot \frac{n}{k}} \]
      15. *-commutativeN/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{n}{k} \cdot \pi} \]
      16. lower-*.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{n}{k} \cdot \pi} \]
      17. lower-/.f6438.2

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{n}{k} \cdot \pi} \]
    8. Applied rewrites38.2%

      \[\leadsto \sqrt{2} \cdot \color{blue}{\sqrt{\frac{n}{k} \cdot \pi}} \]
    9. Step-by-step derivation
      1. lift-*.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{n}{k} \cdot \pi} \]
      2. lift-PI.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{n}{k} \cdot \mathsf{PI}\left(\right)} \]
      3. add-log-expN/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\frac{n}{k} \cdot \log \left(e^{\mathsf{PI}\left(\right)}\right)} \]
      4. log-pow-revN/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left({\left(e^{\mathsf{PI}\left(\right)}\right)}^{\left(\frac{n}{k}\right)}\right)} \]
      5. lower-log.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left({\left(e^{\mathsf{PI}\left(\right)}\right)}^{\left(\frac{n}{k}\right)}\right)} \]
      6. lift-PI.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left({\left(e^{\pi}\right)}^{\left(\frac{n}{k}\right)}\right)} \]
      7. pow-expN/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left(e^{\pi \cdot \frac{n}{k}}\right)} \]
      8. *-commutativeN/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left(e^{\frac{n}{k} \cdot \pi}\right)} \]
      9. lift-*.f64N/A

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left(e^{\frac{n}{k} \cdot \pi}\right)} \]
      10. lower-exp.f6415.5

        \[\leadsto \sqrt{2} \cdot \sqrt{\log \left(e^{\frac{n}{k} \cdot \pi}\right)} \]
    10. Applied rewrites15.5%

      \[\leadsto \sqrt{2} \cdot \sqrt{\log \left(e^{\frac{n}{k} \cdot \pi}\right)} \]

    if 1.49999999999999995e31 < n

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

      \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
    7. Taylor expanded in n around inf

      \[\leadsto n \cdot \color{blue}{\sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}}} \]
    8. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      2. lower-sqrt.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      3. lower-*.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      4. lower-/.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      5. lower-PI.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}} \]
      6. lower-*.f6450.3

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}} \]
    9. Applied rewrites50.3%

      \[\leadsto n \cdot \color{blue}{\sqrt{2 \cdot \frac{\pi}{k \cdot n}}} \]
  3. Recombined 3 regimes into one program.
  4. Add Preprocessing

Alternative 7: 62.8% accurate, 1.8× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq 2.8 \cdot 10^{-47}:\\ \;\;\;\;\frac{1}{\sqrt{k}} \cdot \sqrt{\left(\pi + \pi\right) \cdot n}\\ \mathbf{else}:\\ \;\;\;\;n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}}\\ \end{array} \end{array} \]
(FPCore (k n)
 :precision binary64
 (if (<= n 2.8e-47)
   (* (/ 1.0 (sqrt k)) (sqrt (* (+ PI PI) n)))
   (* n (sqrt (* 2.0 (/ PI (* k n)))))))
double code(double k, double n) {
	double tmp;
	if (n <= 2.8e-47) {
		tmp = (1.0 / sqrt(k)) * sqrt(((((double) M_PI) + ((double) M_PI)) * n));
	} else {
		tmp = n * sqrt((2.0 * (((double) M_PI) / (k * n))));
	}
	return tmp;
}
public static double code(double k, double n) {
	double tmp;
	if (n <= 2.8e-47) {
		tmp = (1.0 / Math.sqrt(k)) * Math.sqrt(((Math.PI + Math.PI) * n));
	} else {
		tmp = n * Math.sqrt((2.0 * (Math.PI / (k * n))));
	}
	return tmp;
}
def code(k, n):
	tmp = 0
	if n <= 2.8e-47:
		tmp = (1.0 / math.sqrt(k)) * math.sqrt(((math.pi + math.pi) * n))
	else:
		tmp = n * math.sqrt((2.0 * (math.pi / (k * n))))
	return tmp
function code(k, n)
	tmp = 0.0
	if (n <= 2.8e-47)
		tmp = Float64(Float64(1.0 / sqrt(k)) * sqrt(Float64(Float64(pi + pi) * n)));
	else
		tmp = Float64(n * sqrt(Float64(2.0 * Float64(pi / Float64(k * n)))));
	end
	return tmp
end
function tmp_2 = code(k, n)
	tmp = 0.0;
	if (n <= 2.8e-47)
		tmp = (1.0 / sqrt(k)) * sqrt(((pi + pi) * n));
	else
		tmp = n * sqrt((2.0 * (pi / (k * n))));
	end
	tmp_2 = tmp;
end
code[k_, n_] := If[LessEqual[n, 2.8e-47], N[(N[(1.0 / N[Sqrt[k], $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[(N[(Pi + Pi), $MachinePrecision] * n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(n * N[Sqrt[N[(2.0 * N[(Pi / N[(k * n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq 2.8 \cdot 10^{-47}:\\
\;\;\;\;\frac{1}{\sqrt{k}} \cdot \sqrt{\left(\pi + \pi\right) \cdot n}\\

\mathbf{else}:\\
\;\;\;\;n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if n < 2.79999999999999993e-47

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. mult-flipN/A

        \[\leadsto {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}} \cdot \color{blue}{\frac{1}{\sqrt{k}}} \]
      3. lift-/.f64N/A

        \[\leadsto {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}} \cdot \frac{1}{\color{blue}{\sqrt{k}}} \]
      4. *-commutativeN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}} \]
      5. lower-*.f6450.6

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}} \]
      6. lift-pow.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\color{blue}{\frac{1}{2}}} \]
      7. sqr-powN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot \color{blue}{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}}\right) \]
      8. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      9. count-2-revN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \pi + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      10. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \pi + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      11. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \pi + n \cdot \pi\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      12. distribute-lft-inN/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      13. lift-+.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
      14. lift-*.f64N/A

        \[\leadsto \frac{1}{\sqrt{k}} \cdot \left({\left(n \cdot \left(\pi + \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)} \cdot {\left(\color{blue}{2} \cdot \left(n \cdot \pi\right)\right)}^{\left(\frac{\frac{1}{2}}{2}\right)}\right) \]
    6. Applied rewrites50.6%

      \[\leadsto \frac{1}{\sqrt{k}} \cdot \color{blue}{\sqrt{\left(\pi + \pi\right) \cdot n}} \]

    if 2.79999999999999993e-47 < n

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

      \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
    7. Taylor expanded in n around inf

      \[\leadsto n \cdot \color{blue}{\sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}}} \]
    8. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      2. lower-sqrt.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      3. lower-*.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      4. lower-/.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      5. lower-PI.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}} \]
      6. lower-*.f6450.3

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}} \]
    9. Applied rewrites50.3%

      \[\leadsto n \cdot \color{blue}{\sqrt{2 \cdot \frac{\pi}{k \cdot n}}} \]
  3. Recombined 2 regimes into one program.
  4. Add Preprocessing

Alternative 8: 62.6% accurate, 2.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq 9.5 \cdot 10^{+27}:\\ \;\;\;\;\sqrt{\frac{\pi + \pi}{k} \cdot n}\\ \mathbf{else}:\\ \;\;\;\;n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}}\\ \end{array} \end{array} \]
(FPCore (k n)
 :precision binary64
 (if (<= n 9.5e+27)
   (sqrt (* (/ (+ PI PI) k) n))
   (* n (sqrt (* 2.0 (/ PI (* k n)))))))
double code(double k, double n) {
	double tmp;
	if (n <= 9.5e+27) {
		tmp = sqrt((((((double) M_PI) + ((double) M_PI)) / k) * n));
	} else {
		tmp = n * sqrt((2.0 * (((double) M_PI) / (k * n))));
	}
	return tmp;
}
public static double code(double k, double n) {
	double tmp;
	if (n <= 9.5e+27) {
		tmp = Math.sqrt((((Math.PI + Math.PI) / k) * n));
	} else {
		tmp = n * Math.sqrt((2.0 * (Math.PI / (k * n))));
	}
	return tmp;
}
def code(k, n):
	tmp = 0
	if n <= 9.5e+27:
		tmp = math.sqrt((((math.pi + math.pi) / k) * n))
	else:
		tmp = n * math.sqrt((2.0 * (math.pi / (k * n))))
	return tmp
function code(k, n)
	tmp = 0.0
	if (n <= 9.5e+27)
		tmp = sqrt(Float64(Float64(Float64(pi + pi) / k) * n));
	else
		tmp = Float64(n * sqrt(Float64(2.0 * Float64(pi / Float64(k * n)))));
	end
	return tmp
end
function tmp_2 = code(k, n)
	tmp = 0.0;
	if (n <= 9.5e+27)
		tmp = sqrt((((pi + pi) / k) * n));
	else
		tmp = n * sqrt((2.0 * (pi / (k * n))));
	end
	tmp_2 = tmp;
end
code[k_, n_] := If[LessEqual[n, 9.5e+27], N[Sqrt[N[(N[(N[(Pi + Pi), $MachinePrecision] / k), $MachinePrecision] * n), $MachinePrecision]], $MachinePrecision], N[(n * N[Sqrt[N[(2.0 * N[(Pi / N[(k * n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq 9.5 \cdot 10^{+27}:\\
\;\;\;\;\sqrt{\frac{\pi + \pi}{k} \cdot n}\\

\mathbf{else}:\\
\;\;\;\;n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if n < 9.4999999999999997e27

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

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

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      2. mult-flipN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      3. lift-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      4. *-commutativeN/A

        \[\leadsto \sqrt{\left(n \cdot \left(\pi + \pi\right)\right) \cdot \frac{1}{k}} \]
      5. associate-*l*N/A

        \[\leadsto \sqrt{n \cdot \left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right)} \]
      6. *-commutativeN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right) \cdot n} \]
      7. lower-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right) \cdot n} \]
      8. mult-flip-revN/A

        \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
      9. lower-/.f6438.2

        \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
    8. Applied rewrites38.2%

      \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]

    if 9.4999999999999997e27 < n

    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

      \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
    7. Taylor expanded in n around inf

      \[\leadsto n \cdot \color{blue}{\sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}}} \]
    8. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      2. lower-sqrt.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      3. lower-*.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      4. lower-/.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\mathsf{PI}\left(\right)}{k \cdot n}} \]
      5. lower-PI.f64N/A

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}} \]
      6. lower-*.f6450.3

        \[\leadsto n \cdot \sqrt{2 \cdot \frac{\pi}{k \cdot n}} \]
    9. Applied rewrites50.3%

      \[\leadsto n \cdot \color{blue}{\sqrt{2 \cdot \frac{\pi}{k \cdot n}}} \]
  3. Recombined 2 regimes into one program.
  4. Add Preprocessing

Alternative 9: 50.7% accurate, 2.7× speedup?

\[\begin{array}{l} \\ \frac{\sqrt{\left(\pi + \pi\right) \cdot n}}{\sqrt{k}} \end{array} \]
(FPCore (k n) :precision binary64 (/ (sqrt (* (+ PI PI) n)) (sqrt k)))
double code(double k, double n) {
	return sqrt(((((double) M_PI) + ((double) M_PI)) * n)) / sqrt(k);
}
public static double code(double k, double n) {
	return Math.sqrt(((Math.PI + Math.PI) * n)) / Math.sqrt(k);
}
def code(k, n):
	return math.sqrt(((math.pi + math.pi) * n)) / math.sqrt(k)
function code(k, n)
	return Float64(sqrt(Float64(Float64(pi + pi) * n)) / sqrt(k))
end
function tmp = code(k, n)
	tmp = sqrt(((pi + pi) * n)) / sqrt(k);
end
code[k_, n_] := N[(N[Sqrt[N[(N[(Pi + Pi), $MachinePrecision] * n), $MachinePrecision]], $MachinePrecision] / N[Sqrt[k], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\frac{\sqrt{\left(\pi + \pi\right) \cdot n}}{\sqrt{k}}
\end{array}
Derivation
  1. Initial program 99.4%

    \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
  2. Taylor expanded in k around 0

    \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
  3. Step-by-step derivation
    1. lower-/.f64N/A

      \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    2. lower-pow.f64N/A

      \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
    3. lower-*.f64N/A

      \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
    4. lower-*.f64N/A

      \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
    5. lower-PI.f64N/A

      \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
    6. lower-sqrt.f6450.7

      \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
  4. Applied rewrites50.7%

    \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
  5. Step-by-step derivation
    1. Applied rewrites50.7%

      \[\leadsto \frac{\sqrt{\left(\pi + \pi\right) \cdot n}}{\color{blue}{\sqrt{k}}} \]
    2. Add Preprocessing

    Alternative 10: 50.6% accurate, 2.7× speedup?

    \[\begin{array}{l} \\ \sqrt{n} \cdot \sqrt{\frac{\pi + \pi}{k}} \end{array} \]
    (FPCore (k n) :precision binary64 (* (sqrt n) (sqrt (/ (+ PI PI) k))))
    double code(double k, double n) {
    	return sqrt(n) * sqrt(((((double) M_PI) + ((double) M_PI)) / k));
    }
    
    public static double code(double k, double n) {
    	return Math.sqrt(n) * Math.sqrt(((Math.PI + Math.PI) / k));
    }
    
    def code(k, n):
    	return math.sqrt(n) * math.sqrt(((math.pi + math.pi) / k))
    
    function code(k, n)
    	return Float64(sqrt(n) * sqrt(Float64(Float64(pi + pi) / k)))
    end
    
    function tmp = code(k, n)
    	tmp = sqrt(n) * sqrt(((pi + pi) / k));
    end
    
    code[k_, n_] := N[(N[Sqrt[n], $MachinePrecision] * N[Sqrt[N[(N[(Pi + Pi), $MachinePrecision] / k), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
    
    \begin{array}{l}
    
    \\
    \sqrt{n} \cdot \sqrt{\frac{\pi + \pi}{k}}
    \end{array}
    
    Derivation
    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

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

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      2. lift-/.f64N/A

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      3. mult-flipN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      4. lift-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      5. *-commutativeN/A

        \[\leadsto \sqrt{\left(n \cdot \left(\pi + \pi\right)\right) \cdot \frac{1}{k}} \]
      6. associate-*l*N/A

        \[\leadsto \sqrt{n \cdot \left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right)} \]
      7. sqrt-prodN/A

        \[\leadsto \sqrt{n} \cdot \color{blue}{\sqrt{\left(\pi + \pi\right) \cdot \frac{1}{k}}} \]
      8. lower-unsound-*.f64N/A

        \[\leadsto \sqrt{n} \cdot \color{blue}{\sqrt{\left(\pi + \pi\right) \cdot \frac{1}{k}}} \]
      9. lower-unsound-sqrt.f64N/A

        \[\leadsto \sqrt{n} \cdot \sqrt{\color{blue}{\left(\pi + \pi\right) \cdot \frac{1}{k}}} \]
      10. lower-unsound-sqrt.f64N/A

        \[\leadsto \sqrt{n} \cdot \sqrt{\left(\pi + \pi\right) \cdot \frac{1}{k}} \]
      11. mult-flip-revN/A

        \[\leadsto \sqrt{n} \cdot \sqrt{\frac{\pi + \pi}{k}} \]
      12. lower-/.f6450.6

        \[\leadsto \sqrt{n} \cdot \sqrt{\frac{\pi + \pi}{k}} \]
    8. Applied rewrites50.6%

      \[\leadsto \sqrt{n} \cdot \color{blue}{\sqrt{\frac{\pi + \pi}{k}}} \]
    9. Add Preprocessing

    Alternative 11: 38.3% accurate, 3.1× speedup?

    \[\begin{array}{l} \\ \sqrt{\frac{\pi + \pi}{k} \cdot n} \end{array} \]
    (FPCore (k n) :precision binary64 (sqrt (* (/ (+ PI PI) k) n)))
    double code(double k, double n) {
    	return sqrt((((((double) M_PI) + ((double) M_PI)) / k) * n));
    }
    
    public static double code(double k, double n) {
    	return Math.sqrt((((Math.PI + Math.PI) / k) * n));
    }
    
    def code(k, n):
    	return math.sqrt((((math.pi + math.pi) / k) * n))
    
    function code(k, n)
    	return sqrt(Float64(Float64(Float64(pi + pi) / k) * n))
    end
    
    function tmp = code(k, n)
    	tmp = sqrt((((pi + pi) / k) * n));
    end
    
    code[k_, n_] := N[Sqrt[N[(N[(N[(Pi + Pi), $MachinePrecision] / k), $MachinePrecision] * n), $MachinePrecision]], $MachinePrecision]
    
    \begin{array}{l}
    
    \\
    \sqrt{\frac{\pi + \pi}{k} \cdot n}
    \end{array}
    
    Derivation
    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

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

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      2. mult-flipN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      3. lift-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot n\right) \cdot \frac{1}{k}} \]
      4. *-commutativeN/A

        \[\leadsto \sqrt{\left(n \cdot \left(\pi + \pi\right)\right) \cdot \frac{1}{k}} \]
      5. associate-*l*N/A

        \[\leadsto \sqrt{n \cdot \left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right)} \]
      6. *-commutativeN/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right) \cdot n} \]
      7. lower-*.f64N/A

        \[\leadsto \sqrt{\left(\left(\pi + \pi\right) \cdot \frac{1}{k}\right) \cdot n} \]
      8. mult-flip-revN/A

        \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
      9. lower-/.f6438.2

        \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
    8. Applied rewrites38.2%

      \[\leadsto \sqrt{\frac{\pi + \pi}{k} \cdot n} \]
    9. Add Preprocessing

    Alternative 12: 38.2% accurate, 3.1× speedup?

    \[\begin{array}{l} \\ \sqrt{\frac{n}{k} \cdot \left(\pi + \pi\right)} \end{array} \]
    (FPCore (k n) :precision binary64 (sqrt (* (/ n k) (+ PI PI))))
    double code(double k, double n) {
    	return sqrt(((n / k) * (((double) M_PI) + ((double) M_PI))));
    }
    
    public static double code(double k, double n) {
    	return Math.sqrt(((n / k) * (Math.PI + Math.PI)));
    }
    
    def code(k, n):
    	return math.sqrt(((n / k) * (math.pi + math.pi)))
    
    function code(k, n)
    	return sqrt(Float64(Float64(n / k) * Float64(pi + pi)))
    end
    
    function tmp = code(k, n)
    	tmp = sqrt(((n / k) * (pi + pi)));
    end
    
    code[k_, n_] := N[Sqrt[N[(N[(n / k), $MachinePrecision] * N[(Pi + Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
    
    \begin{array}{l}
    
    \\
    \sqrt{\frac{n}{k} \cdot \left(\pi + \pi\right)}
    \end{array}
    
    Derivation
    1. Initial program 99.4%

      \[\frac{1}{\sqrt{k}} \cdot {\left(\left(2 \cdot \pi\right) \cdot n\right)}^{\left(\frac{1 - k}{2}\right)} \]
    2. Taylor expanded in k around 0

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}}} \]
    3. Step-by-step derivation
      1. lower-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
      2. lower-pow.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{\color{blue}{k}}} \]
      3. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      4. lower-*.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \mathsf{PI}\left(\right)\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      5. lower-PI.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\sqrt{k}} \]
      6. lower-sqrt.f6450.7

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}} \]
    4. Applied rewrites50.7%

      \[\leadsto \color{blue}{\frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{0.5}}{\sqrt{k}}} \]
    5. Step-by-step derivation
      1. lift-/.f64N/A

        \[\leadsto \frac{{\left(2 \cdot \left(n \cdot \pi\right)\right)}^{\frac{1}{2}}}{\color{blue}{\sqrt{k}}} \]
    6. Applied rewrites38.3%

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

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      2. lift-*.f64N/A

        \[\leadsto \sqrt{\frac{\left(\pi + \pi\right) \cdot n}{k}} \]
      3. associate-/l*N/A

        \[\leadsto \sqrt{\left(\pi + \pi\right) \cdot \frac{n}{k}} \]
      4. *-commutativeN/A

        \[\leadsto \sqrt{\frac{n}{k} \cdot \left(\pi + \pi\right)} \]
      5. lower-*.f64N/A

        \[\leadsto \sqrt{\frac{n}{k} \cdot \left(\pi + \pi\right)} \]
      6. lower-/.f6438.3

        \[\leadsto \sqrt{\frac{n}{k} \cdot \left(\pi + \pi\right)} \]
    8. Applied rewrites38.3%

      \[\leadsto \sqrt{\frac{n}{k} \cdot \left(\pi + \pi\right)} \]
    9. Add Preprocessing

    Reproduce

    ?
    herbie shell --seed 2025162 
    (FPCore (k n)
      :name "Migdal et al, Equation (51)"
      :precision binary64
      (* (/ 1.0 (sqrt k)) (pow (* (* 2.0 PI) n) (/ (- 1.0 k) 2.0))))