{\left(x + 1\right)}^{\left(\frac{1}{n}\right)} - {x}^{\left(\frac{1}{n}\right)}\begin{array}{l}
\mathbf{if}\;n \le -3406.416978222420766542199999094009399414 \lor \neg \left(n \le 1031392298459.7406005859375\right):\\
\;\;\;\;\frac{1}{x} \cdot \left(\frac{1}{n} - \frac{-\log x}{{n}^{2}}\right) - \frac{0.5}{{x}^{2} \cdot n}\\
\mathbf{else}:\\
\;\;\;\;\left({\left(x + 1\right)}^{\left(\frac{\frac{1}{n}}{2}\right)} + {x}^{\left(\frac{\frac{1}{n}}{2}\right)}\right) \cdot \sqrt[3]{{\left(\sqrt[3]{{\left(\sqrt[3]{{\left({\left(x + 1\right)}^{\left(\frac{\frac{1}{n}}{2}\right)} - {x}^{\left(\frac{\frac{1}{n}}{2}\right)}\right)}^{3}}\right)}^{3}}\right)}^{3}}\\
\end{array}double f(double x, double n) {
double r61050 = x;
double r61051 = 1.0;
double r61052 = r61050 + r61051;
double r61053 = n;
double r61054 = r61051 / r61053;
double r61055 = pow(r61052, r61054);
double r61056 = pow(r61050, r61054);
double r61057 = r61055 - r61056;
return r61057;
}
double f(double x, double n) {
double r61058 = n;
double r61059 = -3406.4169782224208;
bool r61060 = r61058 <= r61059;
double r61061 = 1031392298459.7406;
bool r61062 = r61058 <= r61061;
double r61063 = !r61062;
bool r61064 = r61060 || r61063;
double r61065 = 1.0;
double r61066 = x;
double r61067 = r61065 / r61066;
double r61068 = 1.0;
double r61069 = r61068 / r61058;
double r61070 = log(r61066);
double r61071 = -r61070;
double r61072 = 2.0;
double r61073 = pow(r61058, r61072);
double r61074 = r61071 / r61073;
double r61075 = r61069 - r61074;
double r61076 = r61067 * r61075;
double r61077 = 0.5;
double r61078 = pow(r61066, r61072);
double r61079 = r61078 * r61058;
double r61080 = r61077 / r61079;
double r61081 = r61076 - r61080;
double r61082 = r61066 + r61065;
double r61083 = r61065 / r61058;
double r61084 = r61083 / r61072;
double r61085 = pow(r61082, r61084);
double r61086 = pow(r61066, r61084);
double r61087 = r61085 + r61086;
double r61088 = r61085 - r61086;
double r61089 = 3.0;
double r61090 = pow(r61088, r61089);
double r61091 = cbrt(r61090);
double r61092 = pow(r61091, r61089);
double r61093 = cbrt(r61092);
double r61094 = pow(r61093, r61089);
double r61095 = cbrt(r61094);
double r61096 = r61087 * r61095;
double r61097 = r61064 ? r61081 : r61096;
return r61097;
}



Bits error versus x



Bits error versus n
Results
if n < -3406.4169782224208 or 1031392298459.7406 < n Initial program 44.9
Taylor expanded around inf 33.1
Simplified32.5
if -3406.4169782224208 < n < 1031392298459.7406Initial program 8.3
rmApplied sqr-pow8.3
Applied sqr-pow8.3
Applied difference-of-squares8.3
rmApplied add-cbrt-cube8.3
Simplified8.3
rmApplied add-cbrt-cube8.3
Simplified8.3
rmApplied add-cbrt-cube8.3
Simplified8.3
Final simplification22.2
herbie shell --seed 2019323
(FPCore (x n)
:name "2nthrt (problem 3.4.6)"
:precision binary64
(- (pow (+ x 1) (/ 1 n)) (pow x (/ 1 n))))