\sqrt[3]{x + 1} - \sqrt[3]{x}\frac{1}{\sqrt[3]{x + 1} \cdot \left(\sqrt[3]{x + 1} + \sqrt[3]{-1} \cdot \sqrt[3]{-x}\right) + \left(\sqrt[3]{-x} \cdot \sqrt[3]{-x}\right) \cdot {\left(\sqrt[3]{-1}\right)}^{2}}double f(double x) {
double r80866 = x;
double r80867 = 1.0;
double r80868 = r80866 + r80867;
double r80869 = cbrt(r80868);
double r80870 = cbrt(r80866);
double r80871 = r80869 - r80870;
return r80871;
}
double f(double x) {
double r80872 = 1.0;
double r80873 = x;
double r80874 = r80873 + r80872;
double r80875 = cbrt(r80874);
double r80876 = -1.0;
double r80877 = cbrt(r80876);
double r80878 = -r80873;
double r80879 = cbrt(r80878);
double r80880 = r80877 * r80879;
double r80881 = r80875 + r80880;
double r80882 = r80875 * r80881;
double r80883 = r80879 * r80879;
double r80884 = 2.0;
double r80885 = pow(r80877, r80884);
double r80886 = r80883 * r80885;
double r80887 = r80882 + r80886;
double r80888 = r80872 / r80887;
return r80888;
}



Bits error versus x
Results
Initial program 29.3
Taylor expanded around -inf 47.0
Simplified29.3
rmApplied flip3--29.2
Simplified0.5
Simplified32.9
rmApplied sqr-pow32.9
Simplified32.6
Simplified0.5
Final simplification0.5
herbie shell --seed 2019350
(FPCore (x)
:name "2cbrt (problem 3.3.4)"
:precision binary64
(- (cbrt (+ x 1)) (cbrt x)))