{\left(x + 1\right)}^{\left(\frac{1}{n}\right)} - {x}^{\left(\frac{1}{n}\right)}\begin{array}{l}
\mathbf{if}\;\frac{1}{n} \le -1.0314329489541403 \cdot 10^{-6}:\\
\;\;\;\;\sqrt[3]{{\left({\left(1 + x\right)}^{\left(\frac{1}{n}\right)} - {x}^{\left(\frac{1}{n}\right)}\right)}^{3}}\\
\mathbf{elif}\;\frac{1}{n} \le 5.9317209469061504 \cdot 10^{-23}:\\
\;\;\;\;\frac{\frac{1}{n}}{x}\\
\mathbf{else}:\\
\;\;\;\;\sqrt[3]{{\left(\frac{{\left(1 + x\right)}^{\left(\frac{1}{n} \cdot 2\right)} - {x}^{\left(\frac{1}{n} \cdot 2\right)}}{{\left(1 + x\right)}^{\left(\frac{1}{n}\right)} + {x}^{\left(\frac{1}{n}\right)}}\right)}^{3}}\\
\end{array}double code(double x, double n) {
return ((double) (((double) pow(((double) (x + 1.0)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n))))));
}
double code(double x, double n) {
double VAR;
if ((((double) (1.0 / n)) <= -1.0314329489541403e-06)) {
VAR = ((double) cbrt(((double) pow(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))), 3.0))));
} else {
double VAR_1;
if ((((double) (1.0 / n)) <= 5.93172094690615e-23)) {
VAR_1 = ((double) (((double) (1.0 / n)) / x));
} else {
VAR_1 = ((double) cbrt(((double) pow(((double) (((double) (((double) pow(((double) (1.0 + x)), ((double) (((double) (1.0 / n)) * 2.0)))) - ((double) pow(x, ((double) (((double) (1.0 / n)) * 2.0)))))) / ((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) + ((double) pow(x, ((double) (1.0 / n)))))))), 3.0))));
}
VAR = VAR_1;
}
return VAR;
}



Bits error versus x



Bits error versus n
Results
if (/ 1.0 n) < -1.0314329489541403e-6Initial program 1.2
rmApplied add-cbrt-cube1.3
Simplified1.3
if -1.0314329489541403e-6 < (/ 1.0 n) < 5.9317209469061504e-23Initial program 45.2
Taylor expanded around -inf 64.0
Simplified31.7
rmApplied *-un-lft-identity31.7
Applied times-frac31.2
rmApplied associate-*l/31.2
Simplified31.2
if 5.9317209469061504e-23 < (/ 1.0 n) Initial program 11.4
rmApplied add-cbrt-cube11.4
Simplified11.4
rmApplied flip--11.5
Simplified11.4
Final simplification23.1
herbie shell --seed 2020179
(FPCore (x n)
:name "2nthrt (problem 3.4.6)"
:precision binary64
(- (pow (+ x 1.0) (/ 1.0 n)) (pow x (/ 1.0 n))))