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)) <= -0.05102895011493297)) {
VAR = ((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))))))))));
} else {
double VAR_1;
if ((((double) (1.0 / n)) <= 1.431004864818934e-20)) {
VAR_1 = ((double) (((double) (1.0 / ((double) (n * x)))) + ((double) (((double) (((double) (1.0 / ((double) (n * n)))) * ((double) (((double) (((double) log(1.0)) / x)) + ((double) (((double) log(x)) / x)))))) - ((double) (0.5 / ((double) (x * ((double) (n * x))))))))));
} else {
VAR_1 = ((double) (((double) pow(((double) pow(((double) (((double) cbrt(((double) exp(((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))))))))))) * ((double) cbrt(((double) exp(((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))))))))))))), ((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))))))))), ((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))))))))) * ((double) pow(((double) pow(((double) cbrt(((double) exp(((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))))))))))), ((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((double) pow(x, ((double) (1.0 / n)))))))))))), ((double) cbrt(((double) log(((double) (((double) pow(((double) (1.0 + x)), ((double) (1.0 / n)))) - ((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) < -0.051028950114932969Initial program 0.4
rmApplied add-sqr-sqrt0.4
if -0.051028950114932969 < (/ 1.0 n) < 1.4310048648189339e-20Initial program 45.1
Taylor expanded around inf 32.8
Simplified32.7
if 1.4310048648189339e-20 < (/ 1.0 n) Initial program 11.8
rmApplied add-exp-log11.8
rmApplied add-cube-cbrt11.8
Applied exp-prod11.8
Simplified11.8
rmApplied add-cube-cbrt11.8
Applied unpow-prod-down11.8
Applied unpow-prod-down11.8
Final simplification24.3
herbie shell --seed 2020190
(FPCore (x n)
:name "2nthrt (problem 3.4.6)"
:precision binary64
(- (pow (+ x 1.0) (/ 1.0 n)) (pow x (/ 1.0 n))))