| Alternative 1 | |
|---|---|
| Accuracy | 98.6% |
| Cost | 19844 |

(FPCore (x n) :precision binary64 (- (pow (+ x 1.0) (/ 1.0 n)) (pow x (/ 1.0 n))))
(FPCore (x n) :precision binary64 (let* ((t_0 (pow x (/ 1.0 n)))) (if (<= x 6.4e-6) (- (exp (/ (log1p x) n)) t_0) (/ t_0 (* x n)))))
double code(double x, double n) {
return pow((x + 1.0), (1.0 / n)) - pow(x, (1.0 / n));
}
double code(double x, double n) {
double t_0 = pow(x, (1.0 / n));
double tmp;
if (x <= 6.4e-6) {
tmp = exp((log1p(x) / n)) - t_0;
} else {
tmp = t_0 / (x * n);
}
return tmp;
}
public static double code(double x, double n) {
return Math.pow((x + 1.0), (1.0 / n)) - Math.pow(x, (1.0 / n));
}
public static double code(double x, double n) {
double t_0 = Math.pow(x, (1.0 / n));
double tmp;
if (x <= 6.4e-6) {
tmp = Math.exp((Math.log1p(x) / n)) - t_0;
} else {
tmp = t_0 / (x * n);
}
return tmp;
}
def code(x, n): return math.pow((x + 1.0), (1.0 / n)) - math.pow(x, (1.0 / n))
def code(x, n): t_0 = math.pow(x, (1.0 / n)) tmp = 0 if x <= 6.4e-6: tmp = math.exp((math.log1p(x) / n)) - t_0 else: tmp = t_0 / (x * n) return tmp
function code(x, n) return Float64((Float64(x + 1.0) ^ Float64(1.0 / n)) - (x ^ Float64(1.0 / n))) end
function code(x, n) t_0 = x ^ Float64(1.0 / n) tmp = 0.0 if (x <= 6.4e-6) tmp = Float64(exp(Float64(log1p(x) / n)) - t_0); else tmp = Float64(t_0 / Float64(x * n)); end return tmp end
code[x_, n_] := N[(N[Power[N[(x + 1.0), $MachinePrecision], N[(1.0 / n), $MachinePrecision]], $MachinePrecision] - N[Power[x, N[(1.0 / n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
code[x_, n_] := Block[{t$95$0 = N[Power[x, N[(1.0 / n), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[x, 6.4e-6], N[(N[Exp[N[(N[Log[1 + x], $MachinePrecision] / n), $MachinePrecision]], $MachinePrecision] - t$95$0), $MachinePrecision], N[(t$95$0 / N[(x * n), $MachinePrecision]), $MachinePrecision]]]
{\left(x + 1\right)}^{\left(\frac{1}{n}\right)} - {x}^{\left(\frac{1}{n}\right)}
\begin{array}{l}
t_0 := {x}^{\left(\frac{1}{n}\right)}\\
\mathbf{if}\;x \leq 6.4 \cdot 10^{-6}:\\
\;\;\;\;e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - t_0\\
\mathbf{else}:\\
\;\;\;\;\frac{t_0}{x \cdot n}\\
\end{array}
Herbie found 9 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Results
if x < 6.3999999999999997e-6Initial program 77.0%
Taylor expanded in n around 0 76.9%
Simplified99.1%
[Start]76.9% | \[ e^{\frac{\log \left(1 + x\right)}{n}} - e^{\frac{\log x}{n}}
\] |
|---|---|
log1p-def [=>]99.1% | \[ e^{\frac{\color{blue}{\mathsf{log1p}\left(x\right)}}{n}} - e^{\frac{\log x}{n}}
\] |
*-rgt-identity [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - e^{\frac{\color{blue}{\log x \cdot 1}}{n}}
\] |
associate-*r/ [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - e^{\color{blue}{\log x \cdot \frac{1}{n}}}
\] |
unpow-1 [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - e^{\log x \cdot \color{blue}{{n}^{-1}}}
\] |
exp-to-pow [=>]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - \color{blue}{{x}^{\left({n}^{-1}\right)}}
\] |
/-rgt-identity [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\color{blue}{\left(\frac{{n}^{-1}}{1}\right)}}
\] |
metadata-eval [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\left(\frac{{n}^{-1}}{\color{blue}{\frac{2}{2}}}\right)}
\] |
associate-/l* [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\color{blue}{\left(\frac{{n}^{-1} \cdot 2}{2}\right)}}
\] |
*-commutative [<=]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\left(\frac{\color{blue}{2 \cdot {n}^{-1}}}{2}\right)}
\] |
*-commutative [=>]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\left(\frac{\color{blue}{{n}^{-1} \cdot 2}}{2}\right)}
\] |
associate-/l* [=>]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\color{blue}{\left(\frac{{n}^{-1}}{\frac{2}{2}}\right)}}
\] |
metadata-eval [=>]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\left(\frac{{n}^{-1}}{\color{blue}{1}}\right)}
\] |
/-rgt-identity [=>]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\color{blue}{\left({n}^{-1}\right)}}
\] |
unpow-1 [=>]99.1% | \[ e^{\frac{\mathsf{log1p}\left(x\right)}{n}} - {x}^{\color{blue}{\left(\frac{1}{n}\right)}}
\] |
if 6.3999999999999997e-6 < x Initial program 8.9%
Taylor expanded in x around inf 100.0%
Simplified100.0%
[Start]100.0% | \[ \frac{e^{-1 \cdot \frac{\log \left(\frac{1}{x}\right)}{n}}}{n \cdot x}
\] |
|---|---|
log-rec [=>]100.0% | \[ \frac{e^{-1 \cdot \frac{\color{blue}{-\log x}}{n}}}{n \cdot x}
\] |
mul-1-neg [<=]100.0% | \[ \frac{e^{-1 \cdot \frac{\color{blue}{-1 \cdot \log x}}{n}}}{n \cdot x}
\] |
mul-1-neg [=>]100.0% | \[ \frac{e^{-1 \cdot \frac{\color{blue}{-\log x}}{n}}}{n \cdot x}
\] |
distribute-frac-neg [=>]100.0% | \[ \frac{e^{-1 \cdot \color{blue}{\left(-\frac{\log x}{n}\right)}}}{n \cdot x}
\] |
neg-mul-1 [<=]100.0% | \[ \frac{e^{\color{blue}{-\left(-\frac{\log x}{n}\right)}}}{n \cdot x}
\] |
remove-double-neg [=>]100.0% | \[ \frac{e^{\color{blue}{\frac{\log x}{n}}}}{n \cdot x}
\] |
*-rgt-identity [<=]100.0% | \[ \frac{e^{\frac{\color{blue}{\log x \cdot 1}}{n}}}{n \cdot x}
\] |
associate-*r/ [<=]100.0% | \[ \frac{e^{\color{blue}{\log x \cdot \frac{1}{n}}}}{n \cdot x}
\] |
unpow-1 [<=]100.0% | \[ \frac{e^{\log x \cdot \color{blue}{{n}^{-1}}}}{n \cdot x}
\] |
exp-to-pow [=>]100.0% | \[ \frac{\color{blue}{{x}^{\left({n}^{-1}\right)}}}{n \cdot x}
\] |
unpow-1 [=>]100.0% | \[ \frac{{x}^{\color{blue}{\left(\frac{1}{n}\right)}}}{n \cdot x}
\] |
*-commutative [=>]100.0% | \[ \frac{{x}^{\left(\frac{1}{n}\right)}}{\color{blue}{x \cdot n}}
\] |
Final simplification99.5%
| Alternative 1 | |
|---|---|
| Accuracy | 98.6% |
| Cost | 19844 |
| Alternative 2 | |
|---|---|
| Accuracy | 88.7% |
| Cost | 13648 |
| Alternative 3 | |
|---|---|
| Accuracy | 87.2% |
| Cost | 13520 |
| Alternative 4 | |
|---|---|
| Accuracy | 82.1% |
| Cost | 8200 |
| Alternative 5 | |
|---|---|
| Accuracy | 83.9% |
| Cost | 7172 |
| Alternative 6 | |
|---|---|
| Accuracy | 83.4% |
| Cost | 7044 |
| Alternative 7 | |
|---|---|
| Accuracy | 65.7% |
| Cost | 6916 |
| Alternative 8 | |
|---|---|
| Accuracy | 42.0% |
| Cost | 452 |
| Alternative 9 | |
|---|---|
| Accuracy | 19.5% |
| Cost | 192 |
herbie shell --seed 2023277
(FPCore (x n)
:name "2nthrt (problem 3.4.6)"
:precision binary64
(- (pow (+ x 1.0) (/ 1.0 n)) (pow x (/ 1.0 n))))