Compound Interest

Percentage Accurate: 28.3% → 93.7%
Time: 19.2s
Alternatives: 17
Speedup: 38.0×

Specification

?
\[\begin{array}{l} \\ 100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \end{array} \]
(FPCore (i n)
 :precision binary64
 (* 100.0 (/ (- (pow (+ 1.0 (/ i n)) n) 1.0) (/ i n))))
double code(double i, double n) {
	return 100.0 * ((pow((1.0 + (i / n)), n) - 1.0) / (i / n));
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    code = 100.0d0 * ((((1.0d0 + (i / n)) ** n) - 1.0d0) / (i / n))
end function
public static double code(double i, double n) {
	return 100.0 * ((Math.pow((1.0 + (i / n)), n) - 1.0) / (i / n));
}
def code(i, n):
	return 100.0 * ((math.pow((1.0 + (i / n)), n) - 1.0) / (i / n))
function code(i, n)
	return Float64(100.0 * Float64(Float64((Float64(1.0 + Float64(i / n)) ^ n) - 1.0) / Float64(i / n)))
end
function tmp = code(i, n)
	tmp = 100.0 * ((((1.0 + (i / n)) ^ n) - 1.0) / (i / n));
end
code[i_, n_] := N[(100.0 * N[(N[(N[Power[N[(1.0 + N[(i / n), $MachinePrecision]), $MachinePrecision], n], $MachinePrecision] - 1.0), $MachinePrecision] / N[(i / n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}
\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 17 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: 28.3% accurate, 1.0× speedup?

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

\\
100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}
\end{array}

Alternative 1: 93.7% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= (/ (+ (pow (+ 1.0 (/ i n)) n) -1.0) (/ i n)) INFINITY)
   (/ (* n 100.0) (/ i (expm1 (* n (log1p (/ i n))))))
   (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))))
double code(double i, double n) {
	double tmp;
	if (((pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= ((double) INFINITY)) {
		tmp = (n * 100.0) / (i / expm1((n * log1p((i / n)))));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
public static double code(double i, double n) {
	double tmp;
	if (((Math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= Double.POSITIVE_INFINITY) {
		tmp = (n * 100.0) / (i / Math.expm1((n * Math.log1p((i / n)))));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if ((math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= math.inf:
		tmp = (n * 100.0) / (i / math.expm1((n * math.log1p((i / n)))))
	else:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	return tmp
function code(i, n)
	tmp = 0.0
	if (Float64(Float64((Float64(1.0 + Float64(i / n)) ^ n) + -1.0) / Float64(i / n)) <= Inf)
		tmp = Float64(Float64(n * 100.0) / Float64(i / expm1(Float64(n * log1p(Float64(i / n))))));
	else
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	end
	return tmp
end
code[i_, n_] := If[LessEqual[N[(N[(N[Power[N[(1.0 + N[(i / n), $MachinePrecision]), $MachinePrecision], n], $MachinePrecision] + -1.0), $MachinePrecision] / N[(i / n), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(n * 100.0), $MachinePrecision] / N[(i / N[(Exp[N[(n * N[Log[1 + N[(i / n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\
\;\;\;\;\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}\\

\mathbf{else}:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n)) < +inf.0

    1. Initial program 30.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/30.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg30.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in30.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified30.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in30.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg30.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/30.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative30.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/30.2%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*30.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log30.2%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define30.2%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow36.4%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define96.1%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr96.1%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative96.1%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine42.6%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative42.6%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine26.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative26.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp30.2%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num30.2%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv30.2%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp26.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative26.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine42.6%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative42.6%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine96.1%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr96.1%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]

    if +inf.0 < (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n))

    1. Initial program 0.0%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/0.0%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified0.0%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/0.0%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative0.0%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/1.8%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*1.8%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log1.8%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define1.8%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative1.8%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv1.8%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification96.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 2: 93.8% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;n \cdot \left(100 \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= (/ (+ (pow (+ 1.0 (/ i n)) n) -1.0) (/ i n)) INFINITY)
   (* n (* 100.0 (/ (expm1 (* n (log1p (/ i n)))) i)))
   (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))))
double code(double i, double n) {
	double tmp;
	if (((pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= ((double) INFINITY)) {
		tmp = n * (100.0 * (expm1((n * log1p((i / n)))) / i));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
public static double code(double i, double n) {
	double tmp;
	if (((Math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= Double.POSITIVE_INFINITY) {
		tmp = n * (100.0 * (Math.expm1((n * Math.log1p((i / n)))) / i));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if ((math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= math.inf:
		tmp = n * (100.0 * (math.expm1((n * math.log1p((i / n)))) / i))
	else:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	return tmp
function code(i, n)
	tmp = 0.0
	if (Float64(Float64((Float64(1.0 + Float64(i / n)) ^ n) + -1.0) / Float64(i / n)) <= Inf)
		tmp = Float64(n * Float64(100.0 * Float64(expm1(Float64(n * log1p(Float64(i / n)))) / i)));
	else
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	end
	return tmp
end
code[i_, n_] := If[LessEqual[N[(N[(N[Power[N[(1.0 + N[(i / n), $MachinePrecision]), $MachinePrecision], n], $MachinePrecision] + -1.0), $MachinePrecision] / N[(i / n), $MachinePrecision]), $MachinePrecision], Infinity], N[(n * N[(100.0 * N[(N[(Exp[N[(n * N[Log[1 + N[(i / n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]] - 1), $MachinePrecision] / i), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\
\;\;\;\;n \cdot \left(100 \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\right)\\

\mathbf{else}:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n)) < +inf.0

    1. Initial program 30.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/30.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg30.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in30.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified30.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval30.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in30.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg30.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/30.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. associate-/r/30.2%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      7. associate-*r*30.2%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      8. add-exp-log30.2%

        \[\leadsto \left(100 \cdot \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i}\right) \cdot n \]
      9. expm1-define30.2%

        \[\leadsto \left(100 \cdot \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i}\right) \cdot n \]
      10. log-pow36.4%

        \[\leadsto \left(100 \cdot \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i}\right) \cdot n \]
      11. log1p-define96.1%

        \[\leadsto \left(100 \cdot \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i}\right) \cdot n \]
    6. Applied egg-rr96.1%

      \[\leadsto \color{blue}{\left(100 \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\right) \cdot n} \]

    if +inf.0 < (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n))

    1. Initial program 0.0%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/0.0%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified0.0%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/0.0%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative0.0%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/1.8%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*1.8%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log1.8%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define1.8%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative1.8%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv1.8%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification96.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;n \cdot \left(100 \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 3: 93.8% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;n \cdot \frac{100 \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= (/ (+ (pow (+ 1.0 (/ i n)) n) -1.0) (/ i n)) INFINITY)
   (* n (/ (* 100.0 (expm1 (* n (log1p (/ i n))))) i))
   (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))))
double code(double i, double n) {
	double tmp;
	if (((pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= ((double) INFINITY)) {
		tmp = n * ((100.0 * expm1((n * log1p((i / n))))) / i);
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
public static double code(double i, double n) {
	double tmp;
	if (((Math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= Double.POSITIVE_INFINITY) {
		tmp = n * ((100.0 * Math.expm1((n * Math.log1p((i / n))))) / i);
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if ((math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= math.inf:
		tmp = n * ((100.0 * math.expm1((n * math.log1p((i / n))))) / i)
	else:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	return tmp
function code(i, n)
	tmp = 0.0
	if (Float64(Float64((Float64(1.0 + Float64(i / n)) ^ n) + -1.0) / Float64(i / n)) <= Inf)
		tmp = Float64(n * Float64(Float64(100.0 * expm1(Float64(n * log1p(Float64(i / n))))) / i));
	else
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	end
	return tmp
end
code[i_, n_] := If[LessEqual[N[(N[(N[Power[N[(1.0 + N[(i / n), $MachinePrecision]), $MachinePrecision], n], $MachinePrecision] + -1.0), $MachinePrecision] / N[(i / n), $MachinePrecision]), $MachinePrecision], Infinity], N[(n * N[(N[(100.0 * N[(Exp[N[(n * N[Log[1 + N[(i / n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision] / i), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\
\;\;\;\;n \cdot \frac{100 \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\\

\mathbf{else}:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n)) < +inf.0

    1. Initial program 30.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/30.2%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*30.2%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative30.2%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/30.2%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg30.2%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in30.2%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval30.2%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval30.2%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval30.2%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define30.2%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval30.2%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified30.2%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. fma-undefine30.2%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + -100}}{i} \]
      2. metadata-eval30.2%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{100 \cdot -1}}{i} \]
      3. metadata-eval30.2%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{\left(-1\right)}}{i} \]
      4. distribute-lft-in30.2%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      5. sub-neg30.2%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{i} \]
      6. *-commutative30.2%

        \[\leadsto n \cdot \frac{\color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot 100}}{i} \]
      7. add-exp-log30.2%

        \[\leadsto n \cdot \frac{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot 100}{i} \]
      8. expm1-define30.2%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot 100}{i} \]
      9. log-pow36.4%

        \[\leadsto n \cdot \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot 100}{i} \]
      10. log1p-define96.1%

        \[\leadsto n \cdot \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot 100}{i} \]
    6. Applied egg-rr96.1%

      \[\leadsto n \cdot \frac{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot 100}}{i} \]

    if +inf.0 < (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n))

    1. Initial program 0.0%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/0.0%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified0.0%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/0.0%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative0.0%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/1.8%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*1.8%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log1.8%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define1.8%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative1.8%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv1.8%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification96.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;n \cdot \frac{100 \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 4: 93.8% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;n \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot 0.01}\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= (/ (+ (pow (+ 1.0 (/ i n)) n) -1.0) (/ i n)) INFINITY)
   (* n (/ (expm1 (* n (log1p (/ i n)))) (* i 0.01)))
   (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))))
double code(double i, double n) {
	double tmp;
	if (((pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= ((double) INFINITY)) {
		tmp = n * (expm1((n * log1p((i / n)))) / (i * 0.01));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
public static double code(double i, double n) {
	double tmp;
	if (((Math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= Double.POSITIVE_INFINITY) {
		tmp = n * (Math.expm1((n * Math.log1p((i / n)))) / (i * 0.01));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if ((math.pow((1.0 + (i / n)), n) + -1.0) / (i / n)) <= math.inf:
		tmp = n * (math.expm1((n * math.log1p((i / n)))) / (i * 0.01))
	else:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	return tmp
function code(i, n)
	tmp = 0.0
	if (Float64(Float64((Float64(1.0 + Float64(i / n)) ^ n) + -1.0) / Float64(i / n)) <= Inf)
		tmp = Float64(n * Float64(expm1(Float64(n * log1p(Float64(i / n)))) / Float64(i * 0.01)));
	else
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	end
	return tmp
end
code[i_, n_] := If[LessEqual[N[(N[(N[Power[N[(1.0 + N[(i / n), $MachinePrecision]), $MachinePrecision], n], $MachinePrecision] + -1.0), $MachinePrecision] / N[(i / n), $MachinePrecision]), $MachinePrecision], Infinity], N[(n * N[(N[(Exp[N[(n * N[Log[1 + N[(i / n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]] - 1), $MachinePrecision] / N[(i * 0.01), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\
\;\;\;\;n \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot 0.01}\\

\mathbf{else}:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n)) < +inf.0

    1. Initial program 30.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num29.9%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv29.9%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/29.9%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log29.9%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define29.9%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow32.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define84.8%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr84.8%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/85.4%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative85.4%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified85.4%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Step-by-step derivation
      1. *-commutative85.4%

        \[\leadsto \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right) \cdot \frac{100}{i}} \]
      2. clear-num85.3%

        \[\leadsto \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right) \cdot \color{blue}{\frac{1}{\frac{i}{100}}} \]
      3. un-div-inv85.3%

        \[\leadsto \color{blue}{\frac{n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{\frac{i}{100}}} \]
      4. div-inv85.4%

        \[\leadsto \frac{n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{\color{blue}{i \cdot \frac{1}{100}}} \]
      5. metadata-eval85.4%

        \[\leadsto \frac{n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot \color{blue}{0.01}} \]
    8. Applied egg-rr85.4%

      \[\leadsto \color{blue}{\frac{n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot 0.01}} \]
    9. Step-by-step derivation
      1. associate-/l*96.0%

        \[\leadsto \color{blue}{n \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot 0.01}} \]
    10. Simplified96.0%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot 0.01}} \]

    if +inf.0 < (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (/.f64 i n)) n) #s(literal 1 binary64)) (/.f64 i n))

    1. Initial program 0.0%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/0.0%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified0.0%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval0.0%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in0.0%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg0.0%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/0.0%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative0.0%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/1.8%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*1.8%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log1.8%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define1.8%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define1.8%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative1.8%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num1.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv1.8%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine1.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr1.8%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval99.9%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified99.9%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification96.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{{\left(1 + \frac{i}{n}\right)}^{n} + -1}{\frac{i}{n}} \leq \infty:\\ \;\;\;\;n \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i \cdot 0.01}\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 5: 85.7% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -7.2 \cdot 10^{+52} \lor \neg \left(n \leq 0.0004\right):\\ \;\;\;\;n \cdot \left(100 \cdot \frac{\mathsf{expm1}\left(i\right)}{i}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (or (<= n -7.2e+52) (not (<= n 0.0004)))
   (* n (* 100.0 (/ (expm1 i) i)))
   (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))))
double code(double i, double n) {
	double tmp;
	if ((n <= -7.2e+52) || !(n <= 0.0004)) {
		tmp = n * (100.0 * (expm1(i) / i));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
public static double code(double i, double n) {
	double tmp;
	if ((n <= -7.2e+52) || !(n <= 0.0004)) {
		tmp = n * (100.0 * (Math.expm1(i) / i));
	} else {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if (n <= -7.2e+52) or not (n <= 0.0004):
		tmp = n * (100.0 * (math.expm1(i) / i))
	else:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	return tmp
function code(i, n)
	tmp = 0.0
	if ((n <= -7.2e+52) || !(n <= 0.0004))
		tmp = Float64(n * Float64(100.0 * Float64(expm1(i) / i)));
	else
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	end
	return tmp
end
code[i_, n_] := If[Or[LessEqual[n, -7.2e+52], N[Not[LessEqual[n, 0.0004]], $MachinePrecision]], N[(n * N[(100.0 * N[(N[(Exp[i] - 1), $MachinePrecision] / i), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -7.2 \cdot 10^{+52} \lor \neg \left(n \leq 0.0004\right):\\
\;\;\;\;n \cdot \left(100 \cdot \frac{\mathsf{expm1}\left(i\right)}{i}\right)\\

\mathbf{else}:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if n < -7.2e52 or 4.00000000000000019e-4 < n

    1. Initial program 24.4%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/24.8%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*24.8%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative24.8%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/24.8%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg24.8%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in24.8%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval24.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval24.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval24.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define24.8%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval24.8%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified24.8%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in n around inf 45.9%

      \[\leadsto n \cdot \color{blue}{\frac{100 \cdot e^{i} - 100}{i}} \]
    6. Step-by-step derivation
      1. sub-neg45.9%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot e^{i} + \left(-100\right)}}{i} \]
      2. metadata-eval45.9%

        \[\leadsto n \cdot \frac{100 \cdot e^{i} + \color{blue}{-100}}{i} \]
      3. metadata-eval45.9%

        \[\leadsto n \cdot \frac{100 \cdot e^{i} + \color{blue}{100 \cdot -1}}{i} \]
      4. distribute-lft-in46.0%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot \left(e^{i} + -1\right)}}{i} \]
      5. metadata-eval46.0%

        \[\leadsto n \cdot \frac{100 \cdot \left(e^{i} + \color{blue}{\left(-1\right)}\right)}{i} \]
      6. sub-neg46.0%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left(e^{i} - 1\right)}}{i} \]
      7. associate-*r/46.0%

        \[\leadsto n \cdot \color{blue}{\left(100 \cdot \frac{e^{i} - 1}{i}\right)} \]
      8. *-commutative46.0%

        \[\leadsto n \cdot \color{blue}{\left(\frac{e^{i} - 1}{i} \cdot 100\right)} \]
      9. expm1-define97.0%

        \[\leadsto n \cdot \left(\frac{\color{blue}{\mathsf{expm1}\left(i\right)}}{i} \cdot 100\right) \]
    7. Simplified97.0%

      \[\leadsto n \cdot \color{blue}{\left(\frac{\mathsf{expm1}\left(i\right)}{i} \cdot 100\right)} \]

    if -7.2e52 < n < 4.00000000000000019e-4

    1. Initial program 26.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/26.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified26.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/26.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative26.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/26.4%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*26.4%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log26.4%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define26.4%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow41.0%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define86.3%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr86.3%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative86.3%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine24.1%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative24.1%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine23.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative23.8%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp26.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num26.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv26.4%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp23.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative23.8%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine24.1%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative24.1%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine86.4%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr86.4%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 82.0%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg82.0%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/82.0%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval82.0%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval82.0%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified82.0%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification90.1%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -7.2 \cdot 10^{+52} \lor \neg \left(n \leq 0.0004\right):\\ \;\;\;\;n \cdot \left(100 \cdot \frac{\mathsf{expm1}\left(i\right)}{i}\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 6: 74.4% accurate, 3.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -2 \cdot 10^{+229}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(n \cdot 50 + i \cdot \left(\left(i \cdot n\right) \cdot 4.166666666666667 + n \cdot 16.666666666666668\right)\right)\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -2e+229)
   (+ (* n 100.0) (* i (+ (* 16.666666666666668 (* i n)) (* n 50.0))))
   (if (<= n 0.0004)
     (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))
     (+
      (* n 100.0)
      (*
       i
       (+
        (* n 50.0)
        (* i (+ (* (* i n) 4.166666666666667) (* n 16.666666666666668)))))))))
double code(double i, double n) {
	double tmp;
	if (n <= -2e+229) {
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = (n * 100.0) + (i * ((n * 50.0) + (i * (((i * n) * 4.166666666666667) + (n * 16.666666666666668)))));
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-2d+229)) then
        tmp = (n * 100.0d0) + (i * ((16.666666666666668d0 * (i * n)) + (n * 50.0d0)))
    else if (n <= 0.0004d0) then
        tmp = (n * 100.0d0) / (1.0d0 + (i * ((0.5d0 / n) + (-0.5d0))))
    else
        tmp = (n * 100.0d0) + (i * ((n * 50.0d0) + (i * (((i * n) * 4.166666666666667d0) + (n * 16.666666666666668d0)))))
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -2e+229) {
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = (n * 100.0) + (i * ((n * 50.0) + (i * (((i * n) * 4.166666666666667) + (n * 16.666666666666668)))));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -2e+229:
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)))
	elif n <= 0.0004:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	else:
		tmp = (n * 100.0) + (i * ((n * 50.0) + (i * (((i * n) * 4.166666666666667) + (n * 16.666666666666668)))))
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -2e+229)
		tmp = Float64(Float64(n * 100.0) + Float64(i * Float64(Float64(16.666666666666668 * Float64(i * n)) + Float64(n * 50.0))));
	elseif (n <= 0.0004)
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	else
		tmp = Float64(Float64(n * 100.0) + Float64(i * Float64(Float64(n * 50.0) + Float64(i * Float64(Float64(Float64(i * n) * 4.166666666666667) + Float64(n * 16.666666666666668))))));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -2e+229)
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	elseif (n <= 0.0004)
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	else
		tmp = (n * 100.0) + (i * ((n * 50.0) + (i * (((i * n) * 4.166666666666667) + (n * 16.666666666666668)))));
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -2e+229], N[(N[(n * 100.0), $MachinePrecision] + N[(i * N[(N[(16.666666666666668 * N[(i * n), $MachinePrecision]), $MachinePrecision] + N[(n * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 0.0004], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] + N[(i * N[(N[(n * 50.0), $MachinePrecision] + N[(i * N[(N[(N[(i * n), $MachinePrecision] * 4.166666666666667), $MachinePrecision] + N[(n * 16.666666666666668), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -2 \cdot 10^{+229}:\\
\;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\

\mathbf{elif}\;n \leq 0.0004:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\

\mathbf{else}:\\
\;\;\;\;n \cdot 100 + i \cdot \left(n \cdot 50 + i \cdot \left(\left(i \cdot n\right) \cdot 4.166666666666667 + n \cdot 16.666666666666668\right)\right)\\


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

    1. Initial program 21.5%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num21.5%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv21.5%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/22.3%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log22.3%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define22.3%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow22.3%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define53.2%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr53.2%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/53.3%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative53.3%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified53.3%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 99.4%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 79.3%

      \[\leadsto \color{blue}{100 \cdot n + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + 50 \cdot n\right)} \]

    if -2e229 < n < 4.00000000000000019e-4

    1. Initial program 26.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/26.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified26.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/26.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative26.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/26.4%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*26.5%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log26.5%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define26.5%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow36.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define85.3%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative85.3%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv26.4%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine85.3%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]

    if 4.00000000000000019e-4 < n

    1. Initial program 24.1%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num24.1%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv24.1%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/24.5%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log24.5%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define24.5%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow20.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define77.8%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr77.8%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/77.8%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative77.8%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified77.8%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 95.9%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 84.7%

      \[\leadsto \color{blue}{100 \cdot n + i \cdot \left(50 \cdot n + i \cdot \left(4.166666666666667 \cdot \left(i \cdot n\right) + 16.666666666666668 \cdot n\right)\right)} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification80.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -2 \cdot 10^{+229}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(n \cdot 50 + i \cdot \left(\left(i \cdot n\right) \cdot 4.166666666666667 + n \cdot 16.666666666666668\right)\right)\\ \end{array} \]
  5. Add Preprocessing

Alternative 7: 74.4% accurate, 4.2× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -2.5 \cdot 10^{+230}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;100 \cdot \left(n \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + i \cdot 0.041666666666666664\right)\right)\right)\right)\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -2.5e+230)
   (+ (* n 100.0) (* i (+ (* 16.666666666666668 (* i n)) (* n 50.0))))
   (if (<= n 0.0004)
     (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))
     (*
      100.0
      (*
       n
       (+
        1.0
        (*
         i
         (+
          0.5
          (* i (+ 0.16666666666666666 (* i 0.041666666666666664)))))))))))
double code(double i, double n) {
	double tmp;
	if (n <= -2.5e+230) {
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = 100.0 * (n * (1.0 + (i * (0.5 + (i * (0.16666666666666666 + (i * 0.041666666666666664)))))));
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-2.5d+230)) then
        tmp = (n * 100.0d0) + (i * ((16.666666666666668d0 * (i * n)) + (n * 50.0d0)))
    else if (n <= 0.0004d0) then
        tmp = (n * 100.0d0) / (1.0d0 + (i * ((0.5d0 / n) + (-0.5d0))))
    else
        tmp = 100.0d0 * (n * (1.0d0 + (i * (0.5d0 + (i * (0.16666666666666666d0 + (i * 0.041666666666666664d0)))))))
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -2.5e+230) {
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = 100.0 * (n * (1.0 + (i * (0.5 + (i * (0.16666666666666666 + (i * 0.041666666666666664)))))));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -2.5e+230:
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)))
	elif n <= 0.0004:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	else:
		tmp = 100.0 * (n * (1.0 + (i * (0.5 + (i * (0.16666666666666666 + (i * 0.041666666666666664)))))))
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -2.5e+230)
		tmp = Float64(Float64(n * 100.0) + Float64(i * Float64(Float64(16.666666666666668 * Float64(i * n)) + Float64(n * 50.0))));
	elseif (n <= 0.0004)
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	else
		tmp = Float64(100.0 * Float64(n * Float64(1.0 + Float64(i * Float64(0.5 + Float64(i * Float64(0.16666666666666666 + Float64(i * 0.041666666666666664))))))));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -2.5e+230)
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	elseif (n <= 0.0004)
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	else
		tmp = 100.0 * (n * (1.0 + (i * (0.5 + (i * (0.16666666666666666 + (i * 0.041666666666666664)))))));
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -2.5e+230], N[(N[(n * 100.0), $MachinePrecision] + N[(i * N[(N[(16.666666666666668 * N[(i * n), $MachinePrecision]), $MachinePrecision] + N[(n * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 0.0004], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(100.0 * N[(n * N[(1.0 + N[(i * N[(0.5 + N[(i * N[(0.16666666666666666 + N[(i * 0.041666666666666664), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -2.5 \cdot 10^{+230}:\\
\;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\

\mathbf{elif}\;n \leq 0.0004:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\

\mathbf{else}:\\
\;\;\;\;100 \cdot \left(n \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + i \cdot 0.041666666666666664\right)\right)\right)\right)\\


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

    1. Initial program 21.5%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num21.5%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv21.5%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/22.3%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log22.3%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define22.3%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow22.3%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define53.2%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr53.2%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/53.3%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative53.3%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified53.3%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 99.4%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 79.3%

      \[\leadsto \color{blue}{100 \cdot n + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + 50 \cdot n\right)} \]

    if -2.5000000000000001e230 < n < 4.00000000000000019e-4

    1. Initial program 26.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/26.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified26.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/26.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative26.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/26.4%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*26.5%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log26.5%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define26.5%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow36.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define85.3%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative85.3%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv26.4%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine85.3%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]

    if 4.00000000000000019e-4 < n

    1. Initial program 24.1%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num24.1%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv24.1%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/24.5%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log24.5%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define24.5%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow20.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define77.8%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr77.8%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/77.8%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative77.8%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified77.8%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 95.9%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 84.4%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + 0.041666666666666664 \cdot i\right)\right)\right)\right)}\right) \]
    9. Step-by-step derivation
      1. *-commutative84.4%

        \[\leadsto \frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + \color{blue}{i \cdot 0.041666666666666664}\right)\right)\right)\right)\right) \]
    10. Simplified84.4%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + i \cdot 0.041666666666666664\right)\right)\right)\right)}\right) \]
    11. Taylor expanded in n around 0 84.7%

      \[\leadsto \color{blue}{100 \cdot \left(n \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + 0.041666666666666664 \cdot i\right)\right)\right)\right)} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification80.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -2.5 \cdot 10^{+230}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;100 \cdot \left(n \cdot \left(1 + i \cdot \left(0.5 + i \cdot \left(0.16666666666666666 + i \cdot 0.041666666666666664\right)\right)\right)\right)\\ \end{array} \]
  5. Add Preprocessing

Alternative 8: 73.4% accurate, 4.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -1.9 \cdot 10^{+229}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -1.9e+229)
   (+ (* n 100.0) (* i (+ (* 16.666666666666668 (* i n)) (* n 50.0))))
   (if (<= n 0.0004)
     (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))
     (* (/ 100.0 i) (* n (* i (+ 1.0 (* i 0.5))))))))
double code(double i, double n) {
	double tmp;
	if (n <= -1.9e+229) {
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-1.9d+229)) then
        tmp = (n * 100.0d0) + (i * ((16.666666666666668d0 * (i * n)) + (n * 50.0d0)))
    else if (n <= 0.0004d0) then
        tmp = (n * 100.0d0) / (1.0d0 + (i * ((0.5d0 / n) + (-0.5d0))))
    else
        tmp = (100.0d0 / i) * (n * (i * (1.0d0 + (i * 0.5d0))))
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -1.9e+229) {
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -1.9e+229:
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)))
	elif n <= 0.0004:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	else:
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))))
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -1.9e+229)
		tmp = Float64(Float64(n * 100.0) + Float64(i * Float64(Float64(16.666666666666668 * Float64(i * n)) + Float64(n * 50.0))));
	elseif (n <= 0.0004)
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	else
		tmp = Float64(Float64(100.0 / i) * Float64(n * Float64(i * Float64(1.0 + Float64(i * 0.5)))));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -1.9e+229)
		tmp = (n * 100.0) + (i * ((16.666666666666668 * (i * n)) + (n * 50.0)));
	elseif (n <= 0.0004)
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	else
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -1.9e+229], N[(N[(n * 100.0), $MachinePrecision] + N[(i * N[(N[(16.666666666666668 * N[(i * n), $MachinePrecision]), $MachinePrecision] + N[(n * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 0.0004], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(100.0 / i), $MachinePrecision] * N[(n * N[(i * N[(1.0 + N[(i * 0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -1.9 \cdot 10^{+229}:\\
\;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\

\mathbf{elif}\;n \leq 0.0004:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\


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

    1. Initial program 21.5%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num21.5%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv21.5%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/22.3%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log22.3%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define22.3%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow22.3%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define53.2%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr53.2%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/53.3%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative53.3%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified53.3%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 99.4%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 79.3%

      \[\leadsto \color{blue}{100 \cdot n + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + 50 \cdot n\right)} \]

    if -1.90000000000000009e229 < n < 4.00000000000000019e-4

    1. Initial program 26.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/26.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified26.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/26.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative26.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/26.4%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*26.5%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log26.5%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define26.5%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow36.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define85.3%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative85.3%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv26.4%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine85.3%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]

    if 4.00000000000000019e-4 < n

    1. Initial program 24.1%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num24.1%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv24.1%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/24.5%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log24.5%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define24.5%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow20.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define77.8%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr77.8%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/77.8%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative77.8%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified77.8%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 95.9%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 84.0%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + 0.5 \cdot i\right)\right)}\right) \]
    9. Step-by-step derivation
      1. *-commutative84.0%

        \[\leadsto \frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + \color{blue}{i \cdot 0.5}\right)\right)\right) \]
    10. Simplified84.0%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + i \cdot 0.5\right)\right)}\right) \]
  3. Recombined 3 regimes into one program.
  4. Final simplification79.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -1.9 \cdot 10^{+229}:\\ \;\;\;\;n \cdot 100 + i \cdot \left(16.666666666666668 \cdot \left(i \cdot n\right) + n \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\ \end{array} \]
  5. Add Preprocessing

Alternative 9: 73.2% accurate, 4.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -3.05 \cdot 10^{+231}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -3.05e+231)
   (* n (+ 100.0 (* i 50.0)))
   (if (<= n 0.0004)
     (/ (* n 100.0) (+ 1.0 (* i (+ (/ 0.5 n) -0.5))))
     (* (/ 100.0 i) (* n (* i (+ 1.0 (* i 0.5))))))))
double code(double i, double n) {
	double tmp;
	if (n <= -3.05e+231) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-3.05d+231)) then
        tmp = n * (100.0d0 + (i * 50.0d0))
    else if (n <= 0.0004d0) then
        tmp = (n * 100.0d0) / (1.0d0 + (i * ((0.5d0 / n) + (-0.5d0))))
    else
        tmp = (100.0d0 / i) * (n * (i * (1.0d0 + (i * 0.5d0))))
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -3.05e+231) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 0.0004) {
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	} else {
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -3.05e+231:
		tmp = n * (100.0 + (i * 50.0))
	elif n <= 0.0004:
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)))
	else:
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))))
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -3.05e+231)
		tmp = Float64(n * Float64(100.0 + Float64(i * 50.0)));
	elseif (n <= 0.0004)
		tmp = Float64(Float64(n * 100.0) / Float64(1.0 + Float64(i * Float64(Float64(0.5 / n) + -0.5))));
	else
		tmp = Float64(Float64(100.0 / i) * Float64(n * Float64(i * Float64(1.0 + Float64(i * 0.5)))));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -3.05e+231)
		tmp = n * (100.0 + (i * 50.0));
	elseif (n <= 0.0004)
		tmp = (n * 100.0) / (1.0 + (i * ((0.5 / n) + -0.5)));
	else
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -3.05e+231], N[(n * N[(100.0 + N[(i * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 0.0004], N[(N[(n * 100.0), $MachinePrecision] / N[(1.0 + N[(i * N[(N[(0.5 / n), $MachinePrecision] + -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(100.0 / i), $MachinePrecision] * N[(n * N[(i * N[(1.0 + N[(i * 0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -3.05 \cdot 10^{+231}:\\
\;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\

\mathbf{elif}\;n \leq 0.0004:\\
\;\;\;\;\frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\


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

    1. Initial program 21.5%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/22.3%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*22.4%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative22.4%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/22.3%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg22.3%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in22.3%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval22.3%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval22.3%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval22.3%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define22.3%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval22.3%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified22.3%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 77.2%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative77.2%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/77.2%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval77.2%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified77.2%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in n around inf 77.2%

      \[\leadsto \color{blue}{n \cdot \left(100 + 50 \cdot i\right)} \]
    9. Step-by-step derivation
      1. *-commutative77.2%

        \[\leadsto n \cdot \left(100 + \color{blue}{i \cdot 50}\right) \]
    10. Simplified77.2%

      \[\leadsto \color{blue}{n \cdot \left(100 + i \cdot 50\right)} \]

    if -3.04999999999999986e231 < n < 4.00000000000000019e-4

    1. Initial program 26.2%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/26.2%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified26.2%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1 \cdot 100}}{\frac{i}{n}} \]
      2. metadata-eval26.2%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{\left(-1\right)} \cdot 100}{\frac{i}{n}} \]
      3. distribute-rgt-in26.2%

        \[\leadsto \frac{\color{blue}{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      4. sub-neg26.2%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{\frac{i}{n}} \]
      5. associate-*r/26.2%

        \[\leadsto \color{blue}{100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}} \]
      6. *-commutative26.2%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \cdot 100} \]
      7. associate-/r/26.4%

        \[\leadsto \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \cdot 100 \]
      8. associate-*l*26.5%

        \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot \left(n \cdot 100\right)} \]
      9. add-exp-log26.5%

        \[\leadsto \frac{\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1}{i} \cdot \left(n \cdot 100\right) \]
      10. expm1-define26.5%

        \[\leadsto \frac{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)}}{i} \cdot \left(n \cdot 100\right) \]
      11. log-pow36.8%

        \[\leadsto \frac{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
      12. log1p-define85.3%

        \[\leadsto \frac{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right)}{i} \cdot \left(n \cdot 100\right) \]
    6. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i} \cdot \left(n \cdot 100\right)} \]
    7. Step-by-step derivation
      1. *-commutative85.3%

        \[\leadsto \color{blue}{\left(n \cdot 100\right) \cdot \frac{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}{i}} \]
      2. expm1-undefine28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{e^{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)} - 1}}{i} \]
      3. *-commutative28.4%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right) \cdot n}} - 1}{i} \]
      4. log1p-undefine23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\color{blue}{\log \left(1 + \frac{i}{n}\right)} \cdot n} - 1}{i} \]
      5. +-commutative23.9%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{e^{\log \color{blue}{\left(\frac{i}{n} + 1\right)} \cdot n} - 1}{i} \]
      6. pow-to-exp26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \frac{\color{blue}{{\left(\frac{i}{n} + 1\right)}^{n}} - 1}{i} \]
      7. clear-num26.5%

        \[\leadsto \left(n \cdot 100\right) \cdot \color{blue}{\frac{1}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      8. un-div-inv26.4%

        \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{{\left(\frac{i}{n} + 1\right)}^{n} - 1}}} \]
      9. pow-to-exp23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{e^{\log \left(\frac{i}{n} + 1\right) \cdot n}} - 1}} \]
      10. +-commutative23.9%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\log \color{blue}{\left(1 + \frac{i}{n}\right)} \cdot n} - 1}} \]
      11. log1p-undefine28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)} \cdot n} - 1}} \]
      12. *-commutative28.5%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{e^{\color{blue}{n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)}} - 1}} \]
      13. expm1-undefine85.3%

        \[\leadsto \frac{n \cdot 100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    8. Applied egg-rr85.3%

      \[\leadsto \color{blue}{\frac{n \cdot 100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)}}} \]
    9. Taylor expanded in i around 0 77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(0.5 \cdot \frac{1}{n} - 0.5\right)}} \]
    10. Step-by-step derivation
      1. sub-neg77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \color{blue}{\left(0.5 \cdot \frac{1}{n} + \left(-0.5\right)\right)}} \]
      2. associate-*r/77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\color{blue}{\frac{0.5 \cdot 1}{n}} + \left(-0.5\right)\right)} \]
      3. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{\color{blue}{0.5}}{n} + \left(-0.5\right)\right)} \]
      4. metadata-eval77.7%

        \[\leadsto \frac{n \cdot 100}{1 + i \cdot \left(\frac{0.5}{n} + \color{blue}{-0.5}\right)} \]
    11. Simplified77.7%

      \[\leadsto \frac{n \cdot 100}{\color{blue}{1 + i \cdot \left(\frac{0.5}{n} + -0.5\right)}} \]

    if 4.00000000000000019e-4 < n

    1. Initial program 24.1%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num24.1%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv24.1%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/24.5%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log24.5%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define24.5%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow20.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define77.8%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr77.8%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/77.8%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative77.8%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified77.8%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 95.9%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 84.0%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + 0.5 \cdot i\right)\right)}\right) \]
    9. Step-by-step derivation
      1. *-commutative84.0%

        \[\leadsto \frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + \color{blue}{i \cdot 0.5}\right)\right)\right) \]
    10. Simplified84.0%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + i \cdot 0.5\right)\right)}\right) \]
  3. Recombined 3 regimes into one program.
  4. Add Preprocessing

Alternative 10: 62.7% accurate, 4.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -6.4 \cdot 10^{-164}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 1.05 \cdot 10^{-123}:\\ \;\;\;\;\frac{0}{\frac{i}{n}}\\ \mathbf{else}:\\ \;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -6.4e-164)
   (* n (+ 100.0 (* i 50.0)))
   (if (<= n 1.05e-123)
     (/ 0.0 (/ i n))
     (* (/ 100.0 i) (* n (* i (+ 1.0 (* i 0.5))))))))
double code(double i, double n) {
	double tmp;
	if (n <= -6.4e-164) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 1.05e-123) {
		tmp = 0.0 / (i / n);
	} else {
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-6.4d-164)) then
        tmp = n * (100.0d0 + (i * 50.0d0))
    else if (n <= 1.05d-123) then
        tmp = 0.0d0 / (i / n)
    else
        tmp = (100.0d0 / i) * (n * (i * (1.0d0 + (i * 0.5d0))))
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -6.4e-164) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 1.05e-123) {
		tmp = 0.0 / (i / n);
	} else {
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -6.4e-164:
		tmp = n * (100.0 + (i * 50.0))
	elif n <= 1.05e-123:
		tmp = 0.0 / (i / n)
	else:
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))))
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -6.4e-164)
		tmp = Float64(n * Float64(100.0 + Float64(i * 50.0)));
	elseif (n <= 1.05e-123)
		tmp = Float64(0.0 / Float64(i / n));
	else
		tmp = Float64(Float64(100.0 / i) * Float64(n * Float64(i * Float64(1.0 + Float64(i * 0.5)))));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -6.4e-164)
		tmp = n * (100.0 + (i * 50.0));
	elseif (n <= 1.05e-123)
		tmp = 0.0 / (i / n);
	else
		tmp = (100.0 / i) * (n * (i * (1.0 + (i * 0.5))));
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -6.4e-164], N[(n * N[(100.0 + N[(i * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 1.05e-123], N[(0.0 / N[(i / n), $MachinePrecision]), $MachinePrecision], N[(N[(100.0 / i), $MachinePrecision] * N[(n * N[(i * N[(1.0 + N[(i * 0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -6.4 \cdot 10^{-164}:\\
\;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\

\mathbf{elif}\;n \leq 1.05 \cdot 10^{-123}:\\
\;\;\;\;\frac{0}{\frac{i}{n}}\\

\mathbf{else}:\\
\;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if n < -6.4000000000000001e-164

    1. Initial program 22.5%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/22.8%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*22.8%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative22.8%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/22.8%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg22.8%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in22.8%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval22.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval22.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval22.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define22.8%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval22.8%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified22.8%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 69.6%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative69.6%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/69.6%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval69.6%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified69.6%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in n around inf 69.7%

      \[\leadsto \color{blue}{n \cdot \left(100 + 50 \cdot i\right)} \]
    9. Step-by-step derivation
      1. *-commutative69.7%

        \[\leadsto n \cdot \left(100 + \color{blue}{i \cdot 50}\right) \]
    10. Simplified69.7%

      \[\leadsto \color{blue}{n \cdot \left(100 + i \cdot 50\right)} \]

    if -6.4000000000000001e-164 < n < 1.05e-123

    1. Initial program 40.1%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/40.1%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg40.1%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in40.1%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval40.1%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval40.1%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified40.1%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 65.1%

      \[\leadsto \frac{\color{blue}{1} \cdot 100 + -100}{\frac{i}{n}} \]

    if 1.05e-123 < n

    1. Initial program 20.3%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num20.3%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv20.3%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/20.6%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log20.6%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define20.6%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow25.1%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define81.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr81.7%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/81.6%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative81.6%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified81.6%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 87.2%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 78.2%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + 0.5 \cdot i\right)\right)}\right) \]
    9. Step-by-step derivation
      1. *-commutative78.2%

        \[\leadsto \frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + \color{blue}{i \cdot 0.5}\right)\right)\right) \]
    10. Simplified78.2%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \color{blue}{\left(i \cdot \left(1 + i \cdot 0.5\right)\right)}\right) \]
  3. Recombined 3 regimes into one program.
  4. Final simplification72.2%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -6.4 \cdot 10^{-164}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 1.05 \cdot 10^{-123}:\\ \;\;\;\;\frac{0}{\frac{i}{n}}\\ \mathbf{else}:\\ \;\;\;\;\frac{100}{i} \cdot \left(n \cdot \left(i \cdot \left(1 + i \cdot 0.5\right)\right)\right)\\ \end{array} \]
  5. Add Preprocessing

Alternative 11: 61.8% accurate, 6.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -5.6 \cdot 10^{-175}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 2.9 \cdot 10^{-135}:\\ \;\;\;\;\frac{0}{\frac{i}{n}}\\ \mathbf{else}:\\ \;\;\;\;n \cdot 100 + \left(i \cdot n\right) \cdot 50\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -5.6e-175)
   (* n (+ 100.0 (* i 50.0)))
   (if (<= n 2.9e-135) (/ 0.0 (/ i n)) (+ (* n 100.0) (* (* i n) 50.0)))))
double code(double i, double n) {
	double tmp;
	if (n <= -5.6e-175) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 2.9e-135) {
		tmp = 0.0 / (i / n);
	} else {
		tmp = (n * 100.0) + ((i * n) * 50.0);
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-5.6d-175)) then
        tmp = n * (100.0d0 + (i * 50.0d0))
    else if (n <= 2.9d-135) then
        tmp = 0.0d0 / (i / n)
    else
        tmp = (n * 100.0d0) + ((i * n) * 50.0d0)
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -5.6e-175) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 2.9e-135) {
		tmp = 0.0 / (i / n);
	} else {
		tmp = (n * 100.0) + ((i * n) * 50.0);
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -5.6e-175:
		tmp = n * (100.0 + (i * 50.0))
	elif n <= 2.9e-135:
		tmp = 0.0 / (i / n)
	else:
		tmp = (n * 100.0) + ((i * n) * 50.0)
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -5.6e-175)
		tmp = Float64(n * Float64(100.0 + Float64(i * 50.0)));
	elseif (n <= 2.9e-135)
		tmp = Float64(0.0 / Float64(i / n));
	else
		tmp = Float64(Float64(n * 100.0) + Float64(Float64(i * n) * 50.0));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -5.6e-175)
		tmp = n * (100.0 + (i * 50.0));
	elseif (n <= 2.9e-135)
		tmp = 0.0 / (i / n);
	else
		tmp = (n * 100.0) + ((i * n) * 50.0);
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -5.6e-175], N[(n * N[(100.0 + N[(i * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 2.9e-135], N[(0.0 / N[(i / n), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] + N[(N[(i * n), $MachinePrecision] * 50.0), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -5.6 \cdot 10^{-175}:\\
\;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\

\mathbf{elif}\;n \leq 2.9 \cdot 10^{-135}:\\
\;\;\;\;\frac{0}{\frac{i}{n}}\\

\mathbf{else}:\\
\;\;\;\;n \cdot 100 + \left(i \cdot n\right) \cdot 50\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if n < -5.6e-175

    1. Initial program 22.5%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/22.8%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*22.8%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative22.8%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/22.8%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg22.8%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in22.8%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval22.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval22.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval22.8%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define22.8%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval22.8%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified22.8%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 69.6%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative69.6%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/69.6%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval69.6%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified69.6%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in n around inf 69.7%

      \[\leadsto \color{blue}{n \cdot \left(100 + 50 \cdot i\right)} \]
    9. Step-by-step derivation
      1. *-commutative69.7%

        \[\leadsto n \cdot \left(100 + \color{blue}{i \cdot 50}\right) \]
    10. Simplified69.7%

      \[\leadsto \color{blue}{n \cdot \left(100 + i \cdot 50\right)} \]

    if -5.6e-175 < n < 2.9000000000000002e-135

    1. Initial program 43.9%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-*r/43.9%

        \[\leadsto \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}} \]
      2. sub-neg43.9%

        \[\leadsto \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{\frac{i}{n}} \]
      3. distribute-rgt-in43.9%

        \[\leadsto \frac{\color{blue}{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \left(-1\right) \cdot 100}}{\frac{i}{n}} \]
      4. metadata-eval43.9%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-1} \cdot 100}{\frac{i}{n}} \]
      5. metadata-eval43.9%

        \[\leadsto \frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + \color{blue}{-100}}{\frac{i}{n}} \]
    3. Simplified43.9%

      \[\leadsto \color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot 100 + -100}{\frac{i}{n}}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 69.5%

      \[\leadsto \frac{\color{blue}{1} \cdot 100 + -100}{\frac{i}{n}} \]

    if 2.9000000000000002e-135 < n

    1. Initial program 19.6%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num19.6%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv19.6%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/19.9%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log19.9%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define19.9%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow25.9%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define80.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr80.7%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/80.7%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative80.7%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified80.7%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 84.2%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 72.9%

      \[\leadsto \color{blue}{50 \cdot \left(i \cdot n\right) + 100 \cdot n} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification71.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -5.6 \cdot 10^{-175}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 2.9 \cdot 10^{-135}:\\ \;\;\;\;\frac{0}{\frac{i}{n}}\\ \mathbf{else}:\\ \;\;\;\;n \cdot 100 + \left(i \cdot n\right) \cdot 50\\ \end{array} \]
  5. Add Preprocessing

Alternative 12: 61.6% accurate, 6.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -1.1 \cdot 10^{+116}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\ \mathbf{else}:\\ \;\;\;\;n \cdot 100 + \left(i \cdot n\right) \cdot 50\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= n -1.1e+116)
   (* n (+ 100.0 (* i 50.0)))
   (if (<= n 0.0004)
     (* 100.0 (/ i (/ i n)))
     (+ (* n 100.0) (* (* i n) 50.0)))))
double code(double i, double n) {
	double tmp;
	if (n <= -1.1e+116) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 0.0004) {
		tmp = 100.0 * (i / (i / n));
	} else {
		tmp = (n * 100.0) + ((i * n) * 50.0);
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (n <= (-1.1d+116)) then
        tmp = n * (100.0d0 + (i * 50.0d0))
    else if (n <= 0.0004d0) then
        tmp = 100.0d0 * (i / (i / n))
    else
        tmp = (n * 100.0d0) + ((i * n) * 50.0d0)
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (n <= -1.1e+116) {
		tmp = n * (100.0 + (i * 50.0));
	} else if (n <= 0.0004) {
		tmp = 100.0 * (i / (i / n));
	} else {
		tmp = (n * 100.0) + ((i * n) * 50.0);
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if n <= -1.1e+116:
		tmp = n * (100.0 + (i * 50.0))
	elif n <= 0.0004:
		tmp = 100.0 * (i / (i / n))
	else:
		tmp = (n * 100.0) + ((i * n) * 50.0)
	return tmp
function code(i, n)
	tmp = 0.0
	if (n <= -1.1e+116)
		tmp = Float64(n * Float64(100.0 + Float64(i * 50.0)));
	elseif (n <= 0.0004)
		tmp = Float64(100.0 * Float64(i / Float64(i / n)));
	else
		tmp = Float64(Float64(n * 100.0) + Float64(Float64(i * n) * 50.0));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (n <= -1.1e+116)
		tmp = n * (100.0 + (i * 50.0));
	elseif (n <= 0.0004)
		tmp = 100.0 * (i / (i / n));
	else
		tmp = (n * 100.0) + ((i * n) * 50.0);
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[n, -1.1e+116], N[(n * N[(100.0 + N[(i * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[n, 0.0004], N[(100.0 * N[(i / N[(i / n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(n * 100.0), $MachinePrecision] + N[(N[(i * n), $MachinePrecision] * 50.0), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -1.1 \cdot 10^{+116}:\\
\;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\

\mathbf{elif}\;n \leq 0.0004:\\
\;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\

\mathbf{else}:\\
\;\;\;\;n \cdot 100 + \left(i \cdot n\right) \cdot 50\\


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

    1. Initial program 16.9%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/17.5%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*17.5%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative17.5%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/17.4%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg17.4%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in17.4%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval17.4%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval17.4%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval17.4%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define17.4%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval17.4%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified17.4%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 70.7%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative70.7%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/70.7%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval70.7%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified70.7%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in n around inf 70.7%

      \[\leadsto \color{blue}{n \cdot \left(100 + 50 \cdot i\right)} \]
    9. Step-by-step derivation
      1. *-commutative70.7%

        \[\leadsto n \cdot \left(100 + \color{blue}{i \cdot 50}\right) \]
    10. Simplified70.7%

      \[\leadsto \color{blue}{n \cdot \left(100 + i \cdot 50\right)} \]

    if -1.1e116 < n < 4.00000000000000019e-4

    1. Initial program 28.6%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Taylor expanded in i around 0 65.5%

      \[\leadsto 100 \cdot \frac{\color{blue}{i}}{\frac{i}{n}} \]

    if 4.00000000000000019e-4 < n

    1. Initial program 24.1%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. clear-num24.1%

        \[\leadsto 100 \cdot \color{blue}{\frac{1}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      2. un-div-inv24.1%

        \[\leadsto \color{blue}{\frac{100}{\frac{\frac{i}{n}}{{\left(1 + \frac{i}{n}\right)}^{n} - 1}}} \]
      3. associate-/l/24.5%

        \[\leadsto \frac{100}{\color{blue}{\frac{i}{\left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right) \cdot n}}} \]
      4. add-exp-log24.5%

        \[\leadsto \frac{100}{\frac{i}{\left(\color{blue}{e^{\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)}} - 1\right) \cdot n}} \]
      5. expm1-define24.5%

        \[\leadsto \frac{100}{\frac{i}{\color{blue}{\mathsf{expm1}\left(\log \left({\left(1 + \frac{i}{n}\right)}^{n}\right)\right)} \cdot n}} \]
      6. log-pow20.7%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(\color{blue}{n \cdot \log \left(1 + \frac{i}{n}\right)}\right) \cdot n}} \]
      7. log1p-define77.8%

        \[\leadsto \frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \color{blue}{\mathsf{log1p}\left(\frac{i}{n}\right)}\right) \cdot n}} \]
    4. Applied egg-rr77.8%

      \[\leadsto \color{blue}{\frac{100}{\frac{i}{\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n}}} \]
    5. Step-by-step derivation
      1. associate-/r/77.8%

        \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(\mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right) \cdot n\right)} \]
      2. *-commutative77.8%

        \[\leadsto \frac{100}{i} \cdot \color{blue}{\left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    6. Simplified77.8%

      \[\leadsto \color{blue}{\frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(n \cdot \mathsf{log1p}\left(\frac{i}{n}\right)\right)\right)} \]
    7. Taylor expanded in n around inf 95.9%

      \[\leadsto \frac{100}{i} \cdot \left(n \cdot \mathsf{expm1}\left(\color{blue}{i}\right)\right) \]
    8. Taylor expanded in i around 0 77.3%

      \[\leadsto \color{blue}{50 \cdot \left(i \cdot n\right) + 100 \cdot n} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification70.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -1.1 \cdot 10^{+116}:\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{elif}\;n \leq 0.0004:\\ \;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\ \mathbf{else}:\\ \;\;\;\;n \cdot 100 + \left(i \cdot n\right) \cdot 50\\ \end{array} \]
  5. Add Preprocessing

Alternative 13: 61.6% accurate, 6.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;n \leq -1.1 \cdot 10^{+116} \lor \neg \left(n \leq 0.0004\right):\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{else}:\\ \;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (or (<= n -1.1e+116) (not (<= n 0.0004)))
   (* n (+ 100.0 (* i 50.0)))
   (* 100.0 (/ i (/ i n)))))
double code(double i, double n) {
	double tmp;
	if ((n <= -1.1e+116) || !(n <= 0.0004)) {
		tmp = n * (100.0 + (i * 50.0));
	} else {
		tmp = 100.0 * (i / (i / n));
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if ((n <= (-1.1d+116)) .or. (.not. (n <= 0.0004d0))) then
        tmp = n * (100.0d0 + (i * 50.0d0))
    else
        tmp = 100.0d0 * (i / (i / n))
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if ((n <= -1.1e+116) || !(n <= 0.0004)) {
		tmp = n * (100.0 + (i * 50.0));
	} else {
		tmp = 100.0 * (i / (i / n));
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if (n <= -1.1e+116) or not (n <= 0.0004):
		tmp = n * (100.0 + (i * 50.0))
	else:
		tmp = 100.0 * (i / (i / n))
	return tmp
function code(i, n)
	tmp = 0.0
	if ((n <= -1.1e+116) || !(n <= 0.0004))
		tmp = Float64(n * Float64(100.0 + Float64(i * 50.0)));
	else
		tmp = Float64(100.0 * Float64(i / Float64(i / n)));
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if ((n <= -1.1e+116) || ~((n <= 0.0004)))
		tmp = n * (100.0 + (i * 50.0));
	else
		tmp = 100.0 * (i / (i / n));
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[Or[LessEqual[n, -1.1e+116], N[Not[LessEqual[n, 0.0004]], $MachinePrecision]], N[(n * N[(100.0 + N[(i * 50.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(100.0 * N[(i / N[(i / n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;n \leq -1.1 \cdot 10^{+116} \lor \neg \left(n \leq 0.0004\right):\\
\;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\

\mathbf{else}:\\
\;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if n < -1.1e116 or 4.00000000000000019e-4 < n

    1. Initial program 21.6%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/22.0%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*22.0%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative22.0%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/22.0%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg22.0%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in22.0%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval22.0%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval22.0%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval22.0%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define22.0%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval22.0%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified22.0%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 74.9%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative74.9%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/74.9%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval74.9%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified74.9%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in n around inf 74.9%

      \[\leadsto \color{blue}{n \cdot \left(100 + 50 \cdot i\right)} \]
    9. Step-by-step derivation
      1. *-commutative74.9%

        \[\leadsto n \cdot \left(100 + \color{blue}{i \cdot 50}\right) \]
    10. Simplified74.9%

      \[\leadsto \color{blue}{n \cdot \left(100 + i \cdot 50\right)} \]

    if -1.1e116 < n < 4.00000000000000019e-4

    1. Initial program 28.6%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Taylor expanded in i around 0 65.5%

      \[\leadsto 100 \cdot \frac{\color{blue}{i}}{\frac{i}{n}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification70.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;n \leq -1.1 \cdot 10^{+116} \lor \neg \left(n \leq 0.0004\right):\\ \;\;\;\;n \cdot \left(100 + i \cdot 50\right)\\ \mathbf{else}:\\ \;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\ \end{array} \]
  5. Add Preprocessing

Alternative 14: 58.4% accurate, 7.6× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;i \leq -5 \cdot 10^{+49}:\\ \;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\ \mathbf{elif}\;i \leq 2:\\ \;\;\;\;n \cdot 100\\ \mathbf{else}:\\ \;\;\;\;\left(i \cdot n\right) \cdot 50\\ \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (if (<= i -5e+49)
   (* 100.0 (/ i (/ i n)))
   (if (<= i 2.0) (* n 100.0) (* (* i n) 50.0))))
double code(double i, double n) {
	double tmp;
	if (i <= -5e+49) {
		tmp = 100.0 * (i / (i / n));
	} else if (i <= 2.0) {
		tmp = n * 100.0;
	} else {
		tmp = (i * n) * 50.0;
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (i <= (-5d+49)) then
        tmp = 100.0d0 * (i / (i / n))
    else if (i <= 2.0d0) then
        tmp = n * 100.0d0
    else
        tmp = (i * n) * 50.0d0
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (i <= -5e+49) {
		tmp = 100.0 * (i / (i / n));
	} else if (i <= 2.0) {
		tmp = n * 100.0;
	} else {
		tmp = (i * n) * 50.0;
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if i <= -5e+49:
		tmp = 100.0 * (i / (i / n))
	elif i <= 2.0:
		tmp = n * 100.0
	else:
		tmp = (i * n) * 50.0
	return tmp
function code(i, n)
	tmp = 0.0
	if (i <= -5e+49)
		tmp = Float64(100.0 * Float64(i / Float64(i / n)));
	elseif (i <= 2.0)
		tmp = Float64(n * 100.0);
	else
		tmp = Float64(Float64(i * n) * 50.0);
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (i <= -5e+49)
		tmp = 100.0 * (i / (i / n));
	elseif (i <= 2.0)
		tmp = n * 100.0;
	else
		tmp = (i * n) * 50.0;
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[i, -5e+49], N[(100.0 * N[(i / N[(i / n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[i, 2.0], N[(n * 100.0), $MachinePrecision], N[(N[(i * n), $MachinePrecision] * 50.0), $MachinePrecision]]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;i \leq -5 \cdot 10^{+49}:\\
\;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\

\mathbf{elif}\;i \leq 2:\\
\;\;\;\;n \cdot 100\\

\mathbf{else}:\\
\;\;\;\;\left(i \cdot n\right) \cdot 50\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if i < -5.0000000000000004e49

    1. Initial program 71.3%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Taylor expanded in i around 0 22.9%

      \[\leadsto 100 \cdot \frac{\color{blue}{i}}{\frac{i}{n}} \]

    if -5.0000000000000004e49 < i < 2

    1. Initial program 5.8%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Taylor expanded in i around 0 86.8%

      \[\leadsto \color{blue}{100 \cdot n} \]
    4. Step-by-step derivation
      1. *-commutative86.8%

        \[\leadsto \color{blue}{n \cdot 100} \]
    5. Simplified86.8%

      \[\leadsto \color{blue}{n \cdot 100} \]

    if 2 < i

    1. Initial program 41.6%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/41.9%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*42.0%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative42.0%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/42.0%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg42.0%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in41.9%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval41.9%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval41.9%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval41.9%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define42.0%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval42.0%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified42.0%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 37.8%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative37.8%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/37.8%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval37.8%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified37.8%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in i around inf 37.8%

      \[\leadsto \color{blue}{100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    9. Step-by-step derivation
      1. associate-*r/37.8%

        \[\leadsto 100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right)\right) \]
      2. metadata-eval37.8%

        \[\leadsto 100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right)\right) \]
    10. Simplified37.8%

      \[\leadsto \color{blue}{100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - \frac{0.5}{n}\right)\right)\right)} \]
    11. Taylor expanded in n around inf 38.7%

      \[\leadsto \color{blue}{50 \cdot \left(i \cdot n\right)} \]
    12. Step-by-step derivation
      1. *-commutative38.7%

        \[\leadsto 50 \cdot \color{blue}{\left(n \cdot i\right)} \]
    13. Simplified38.7%

      \[\leadsto \color{blue}{50 \cdot \left(n \cdot i\right)} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification64.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;i \leq -5 \cdot 10^{+49}:\\ \;\;\;\;100 \cdot \frac{i}{\frac{i}{n}}\\ \mathbf{elif}\;i \leq 2:\\ \;\;\;\;n \cdot 100\\ \mathbf{else}:\\ \;\;\;\;\left(i \cdot n\right) \cdot 50\\ \end{array} \]
  5. Add Preprocessing

Alternative 15: 54.7% accurate, 11.4× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;i \leq 2:\\ \;\;\;\;n \cdot 100\\ \mathbf{else}:\\ \;\;\;\;\left(i \cdot n\right) \cdot 50\\ \end{array} \end{array} \]
(FPCore (i n) :precision binary64 (if (<= i 2.0) (* n 100.0) (* (* i n) 50.0)))
double code(double i, double n) {
	double tmp;
	if (i <= 2.0) {
		tmp = n * 100.0;
	} else {
		tmp = (i * n) * 50.0;
	}
	return tmp;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: tmp
    if (i <= 2.0d0) then
        tmp = n * 100.0d0
    else
        tmp = (i * n) * 50.0d0
    end if
    code = tmp
end function
public static double code(double i, double n) {
	double tmp;
	if (i <= 2.0) {
		tmp = n * 100.0;
	} else {
		tmp = (i * n) * 50.0;
	}
	return tmp;
}
def code(i, n):
	tmp = 0
	if i <= 2.0:
		tmp = n * 100.0
	else:
		tmp = (i * n) * 50.0
	return tmp
function code(i, n)
	tmp = 0.0
	if (i <= 2.0)
		tmp = Float64(n * 100.0);
	else
		tmp = Float64(Float64(i * n) * 50.0);
	end
	return tmp
end
function tmp_2 = code(i, n)
	tmp = 0.0;
	if (i <= 2.0)
		tmp = n * 100.0;
	else
		tmp = (i * n) * 50.0;
	end
	tmp_2 = tmp;
end
code[i_, n_] := If[LessEqual[i, 2.0], N[(n * 100.0), $MachinePrecision], N[(N[(i * n), $MachinePrecision] * 50.0), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;i \leq 2:\\
\;\;\;\;n \cdot 100\\

\mathbf{else}:\\
\;\;\;\;\left(i \cdot n\right) \cdot 50\\


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

    1. Initial program 19.8%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Add Preprocessing
    3. Taylor expanded in i around 0 69.3%

      \[\leadsto \color{blue}{100 \cdot n} \]
    4. Step-by-step derivation
      1. *-commutative69.3%

        \[\leadsto \color{blue}{n \cdot 100} \]
    5. Simplified69.3%

      \[\leadsto \color{blue}{n \cdot 100} \]

    if 2 < i

    1. Initial program 41.6%

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
    2. Step-by-step derivation
      1. associate-/r/41.9%

        \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
      2. associate-*r*42.0%

        \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
      3. *-commutative42.0%

        \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
      4. associate-*r/42.0%

        \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
      5. sub-neg42.0%

        \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
      6. distribute-lft-in41.9%

        \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
      7. metadata-eval41.9%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
      8. metadata-eval41.9%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
      9. metadata-eval41.9%

        \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
      10. fma-define42.0%

        \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
      11. metadata-eval42.0%

        \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
    3. Simplified42.0%

      \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
    4. Add Preprocessing
    5. Taylor expanded in i around 0 37.8%

      \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    6. Step-by-step derivation
      1. *-commutative37.8%

        \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
      2. associate-*r/37.8%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
      3. metadata-eval37.8%

        \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
    7. Simplified37.8%

      \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
    8. Taylor expanded in i around inf 37.8%

      \[\leadsto \color{blue}{100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
    9. Step-by-step derivation
      1. associate-*r/37.8%

        \[\leadsto 100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right)\right) \]
      2. metadata-eval37.8%

        \[\leadsto 100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right)\right) \]
    10. Simplified37.8%

      \[\leadsto \color{blue}{100 \cdot \left(i \cdot \left(n \cdot \left(0.5 - \frac{0.5}{n}\right)\right)\right)} \]
    11. Taylor expanded in n around inf 38.7%

      \[\leadsto \color{blue}{50 \cdot \left(i \cdot n\right)} \]
    12. Step-by-step derivation
      1. *-commutative38.7%

        \[\leadsto 50 \cdot \color{blue}{\left(n \cdot i\right)} \]
    13. Simplified38.7%

      \[\leadsto \color{blue}{50 \cdot \left(n \cdot i\right)} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification61.6%

    \[\leadsto \begin{array}{l} \mathbf{if}\;i \leq 2:\\ \;\;\;\;n \cdot 100\\ \mathbf{else}:\\ \;\;\;\;\left(i \cdot n\right) \cdot 50\\ \end{array} \]
  5. Add Preprocessing

Alternative 16: 49.3% accurate, 38.0× speedup?

\[\begin{array}{l} \\ n \cdot 100 \end{array} \]
(FPCore (i n) :precision binary64 (* n 100.0))
double code(double i, double n) {
	return n * 100.0;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    code = n * 100.0d0
end function
public static double code(double i, double n) {
	return n * 100.0;
}
def code(i, n):
	return n * 100.0
function code(i, n)
	return Float64(n * 100.0)
end
function tmp = code(i, n)
	tmp = n * 100.0;
end
code[i_, n_] := N[(n * 100.0), $MachinePrecision]
\begin{array}{l}

\\
n \cdot 100
\end{array}
Derivation
  1. Initial program 25.2%

    \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
  2. Add Preprocessing
  3. Taylor expanded in i around 0 53.4%

    \[\leadsto \color{blue}{100 \cdot n} \]
  4. Step-by-step derivation
    1. *-commutative53.4%

      \[\leadsto \color{blue}{n \cdot 100} \]
  5. Simplified53.4%

    \[\leadsto \color{blue}{n \cdot 100} \]
  6. Add Preprocessing

Alternative 17: 2.8% accurate, 38.0× speedup?

\[\begin{array}{l} \\ i \cdot -50 \end{array} \]
(FPCore (i n) :precision binary64 (* i -50.0))
double code(double i, double n) {
	return i * -50.0;
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    code = i * (-50.0d0)
end function
public static double code(double i, double n) {
	return i * -50.0;
}
def code(i, n):
	return i * -50.0
function code(i, n)
	return Float64(i * -50.0)
end
function tmp = code(i, n)
	tmp = i * -50.0;
end
code[i_, n_] := N[(i * -50.0), $MachinePrecision]
\begin{array}{l}

\\
i \cdot -50
\end{array}
Derivation
  1. Initial program 25.2%

    \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}} \]
  2. Step-by-step derivation
    1. associate-/r/25.5%

      \[\leadsto 100 \cdot \color{blue}{\left(\frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i} \cdot n\right)} \]
    2. associate-*r*25.5%

      \[\leadsto \color{blue}{\left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right) \cdot n} \]
    3. *-commutative25.5%

      \[\leadsto \color{blue}{n \cdot \left(100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{i}\right)} \]
    4. associate-*r/25.5%

      \[\leadsto n \cdot \color{blue}{\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{i}} \]
    5. sub-neg25.5%

      \[\leadsto n \cdot \frac{100 \cdot \color{blue}{\left({\left(1 + \frac{i}{n}\right)}^{n} + \left(-1\right)\right)}}{i} \]
    6. distribute-lft-in25.5%

      \[\leadsto n \cdot \frac{\color{blue}{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \left(-1\right)}}{i} \]
    7. metadata-eval25.5%

      \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + 100 \cdot \color{blue}{-1}}{i} \]
    8. metadata-eval25.5%

      \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{-100}}{i} \]
    9. metadata-eval25.5%

      \[\leadsto n \cdot \frac{100 \cdot {\left(1 + \frac{i}{n}\right)}^{n} + \color{blue}{\left(-100\right)}}{i} \]
    10. fma-define25.5%

      \[\leadsto n \cdot \frac{\color{blue}{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}}{i} \]
    11. metadata-eval25.5%

      \[\leadsto n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, \color{blue}{-100}\right)}{i} \]
  3. Simplified25.5%

    \[\leadsto \color{blue}{n \cdot \frac{\mathsf{fma}\left(100, {\left(1 + \frac{i}{n}\right)}^{n}, -100\right)}{i}} \]
  4. Add Preprocessing
  5. Taylor expanded in i around 0 61.8%

    \[\leadsto n \cdot \color{blue}{\left(100 + 100 \cdot \left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right)\right)} \]
  6. Step-by-step derivation
    1. *-commutative61.8%

      \[\leadsto n \cdot \left(100 + \color{blue}{\left(i \cdot \left(0.5 - 0.5 \cdot \frac{1}{n}\right)\right) \cdot 100}\right) \]
    2. associate-*r/61.8%

      \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \color{blue}{\frac{0.5 \cdot 1}{n}}\right)\right) \cdot 100\right) \]
    3. metadata-eval61.8%

      \[\leadsto n \cdot \left(100 + \left(i \cdot \left(0.5 - \frac{\color{blue}{0.5}}{n}\right)\right) \cdot 100\right) \]
  7. Simplified61.8%

    \[\leadsto n \cdot \color{blue}{\left(100 + \left(i \cdot \left(0.5 - \frac{0.5}{n}\right)\right) \cdot 100\right)} \]
  8. Taylor expanded in n around 0 2.8%

    \[\leadsto \color{blue}{-50 \cdot i} \]
  9. Step-by-step derivation
    1. *-commutative2.8%

      \[\leadsto \color{blue}{i \cdot -50} \]
  10. Simplified2.8%

    \[\leadsto \color{blue}{i \cdot -50} \]
  11. Add Preprocessing

Developer Target 1: 33.3% accurate, 0.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := 1 + \frac{i}{n}\\ 100 \cdot \frac{e^{n \cdot \begin{array}{l} \mathbf{if}\;t\_0 = 1:\\ \;\;\;\;\frac{i}{n}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{i}{n} \cdot \log t\_0}{\left(\frac{i}{n} + 1\right) - 1}\\ \end{array}} - 1}{\frac{i}{n}} \end{array} \end{array} \]
(FPCore (i n)
 :precision binary64
 (let* ((t_0 (+ 1.0 (/ i n))))
   (*
    100.0
    (/
     (-
      (exp
       (*
        n
        (if (== t_0 1.0)
          (/ i n)
          (/ (* (/ i n) (log t_0)) (- (+ (/ i n) 1.0) 1.0)))))
      1.0)
     (/ i n)))))
double code(double i, double n) {
	double t_0 = 1.0 + (i / n);
	double tmp;
	if (t_0 == 1.0) {
		tmp = i / n;
	} else {
		tmp = ((i / n) * log(t_0)) / (((i / n) + 1.0) - 1.0);
	}
	return 100.0 * ((exp((n * tmp)) - 1.0) / (i / n));
}
real(8) function code(i, n)
    real(8), intent (in) :: i
    real(8), intent (in) :: n
    real(8) :: t_0
    real(8) :: tmp
    t_0 = 1.0d0 + (i / n)
    if (t_0 == 1.0d0) then
        tmp = i / n
    else
        tmp = ((i / n) * log(t_0)) / (((i / n) + 1.0d0) - 1.0d0)
    end if
    code = 100.0d0 * ((exp((n * tmp)) - 1.0d0) / (i / n))
end function
public static double code(double i, double n) {
	double t_0 = 1.0 + (i / n);
	double tmp;
	if (t_0 == 1.0) {
		tmp = i / n;
	} else {
		tmp = ((i / n) * Math.log(t_0)) / (((i / n) + 1.0) - 1.0);
	}
	return 100.0 * ((Math.exp((n * tmp)) - 1.0) / (i / n));
}
def code(i, n):
	t_0 = 1.0 + (i / n)
	tmp = 0
	if t_0 == 1.0:
		tmp = i / n
	else:
		tmp = ((i / n) * math.log(t_0)) / (((i / n) + 1.0) - 1.0)
	return 100.0 * ((math.exp((n * tmp)) - 1.0) / (i / n))
function code(i, n)
	t_0 = Float64(1.0 + Float64(i / n))
	tmp = 0.0
	if (t_0 == 1.0)
		tmp = Float64(i / n);
	else
		tmp = Float64(Float64(Float64(i / n) * log(t_0)) / Float64(Float64(Float64(i / n) + 1.0) - 1.0));
	end
	return Float64(100.0 * Float64(Float64(exp(Float64(n * tmp)) - 1.0) / Float64(i / n)))
end
function tmp_2 = code(i, n)
	t_0 = 1.0 + (i / n);
	tmp = 0.0;
	if (t_0 == 1.0)
		tmp = i / n;
	else
		tmp = ((i / n) * log(t_0)) / (((i / n) + 1.0) - 1.0);
	end
	tmp_2 = 100.0 * ((exp((n * tmp)) - 1.0) / (i / n));
end
code[i_, n_] := Block[{t$95$0 = N[(1.0 + N[(i / n), $MachinePrecision]), $MachinePrecision]}, N[(100.0 * N[(N[(N[Exp[N[(n * If[Equal[t$95$0, 1.0], N[(i / n), $MachinePrecision], N[(N[(N[(i / n), $MachinePrecision] * N[Log[t$95$0], $MachinePrecision]), $MachinePrecision] / N[(N[(N[(i / n), $MachinePrecision] + 1.0), $MachinePrecision] - 1.0), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]], $MachinePrecision] - 1.0), $MachinePrecision] / N[(i / n), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := 1 + \frac{i}{n}\\
100 \cdot \frac{e^{n \cdot \begin{array}{l}
\mathbf{if}\;t\_0 = 1:\\
\;\;\;\;\frac{i}{n}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{i}{n} \cdot \log t\_0}{\left(\frac{i}{n} + 1\right) - 1}\\


\end{array}} - 1}{\frac{i}{n}}
\end{array}
\end{array}

Reproduce

?
herbie shell --seed 2024117 
(FPCore (i n)
  :name "Compound Interest"
  :precision binary64

  :alt
  (! :herbie-platform default (let ((lnbase (if (== (+ 1 (/ i n)) 1) (/ i n) (/ (* (/ i n) (log (+ 1 (/ i n)))) (- (+ (/ i n) 1) 1))))) (* 100 (/ (- (exp (* n lnbase)) 1) (/ i n)))))

  (* 100.0 (/ (- (pow (+ 1.0 (/ i n)) n) 1.0) (/ i n))))