{\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.7479825902971762 \cdot 10^{-6}:\\
\;\;\;\;{\left(1 + x\right)}^{\left(\frac{1}{n}\right)} - \left(\sqrt{{\left({x}^{\left(\frac{1}{n}\right)}\right)}^{\frac{2}{3}} \cdot \sqrt[3]{{x}^{\left(\frac{1}{n}\right)}}} \cdot \left|\sqrt[3]{{\left({x}^{\left(\frac{1}{n}\right)}\right)}^{\frac{2}{3}} \cdot \sqrt[3]{{x}^{\left(\frac{1}{n}\right)}}}\right|\right) \cdot \sqrt{\sqrt[3]{{x}^{\left(\frac{1}{n}\right)}}}\\
\mathbf{elif}\;\frac{1}{n} \le 1.0160411307279881 \cdot 10^{-15}:\\
\;\;\;\;\frac{1}{n \cdot x}\\
\mathbf{else}:\\
\;\;\;\;{\left(1 + x\right)}^{\left(\frac{1}{n}\right)} - \sqrt{{x}^{\left(\frac{1}{n}\right)}} \cdot \sqrt{{x}^{\left(\frac{1}{n}\right)}}\\
\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.7479825902971762e-06)) {
VAR = ((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) (((double) (((double) sqrt(((double) (((double) pow(((double) pow(x, ((double) (1.0 / n)))), 0.6666666666666666)) * ((double) cbrt(((double) pow(x, ((double) (1.0 / n)))))))))) * ((double) fabs(((double) cbrt(((double) (((double) pow(((double) pow(x, ((double) (1.0 / n)))), 0.6666666666666666)) * ((double) cbrt(((double) pow(x, ((double) (1.0 / n)))))))))))))) * ((double) sqrt(((double) cbrt(((double) pow(x, ((double) (1.0 / n))))))))))));
} else {
double VAR_1;
if ((((double) (1.0 / n)) <= 1.016041130727988e-15)) {
VAR_1 = ((double) (1.0 / ((double) (n * x))));
} else {
VAR_1 = ((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) (((double) sqrt(((double) pow(x, ((double) (1.0 / n)))))) * ((double) sqrt(((double) pow(x, ((double) (1.0 / n))))))))));
}
VAR = VAR_1;
}
return VAR;
}



Bits error versus x



Bits error versus n
Results
if (/ 1.0 n) < -1.7479825902971762e-6Initial program 0.8
rmApplied add-sqr-sqrt0.9
rmApplied add-cube-cbrt1.0
Applied sqrt-prod1.0
Applied associate-*r*1.0
Simplified1.0
rmApplied add-cube-cbrt1.0
Simplified1.0
rmApplied add-cube-cbrt1.0
Simplified1.0
if -1.7479825902971762e-6 < (/ 1.0 n) < 1.0160411307279881e-15Initial program 44.3
rmApplied add-sqr-sqrt44.3
Taylor expanded around -inf 64.0
Simplified30.6
if 1.0160411307279881e-15 < (/ 1.0 n) Initial program 8.4
rmApplied add-sqr-sqrt8.6
Final simplification22.4
herbie shell --seed 2020184
(FPCore (x n)
:name "2nthrt (problem 3.4.6)"
:precision binary64
(- (pow (+ x 1.0) (/ 1.0 n)) (pow x (/ 1.0 n))))