\sqrt[3]{x + 1} - \sqrt[3]{x}\begin{array}{l}
\mathbf{if}\;x \le -4.4950236535924181 \cdot 10^{61}:\\
\;\;\;\;\mathsf{fma}\left({\left(\frac{1}{{x}^{2}}\right)}^{\frac{1}{3}}, 0.333333333333333315, 0.061728395061728392 \cdot {\left(\frac{1}{{x}^{8}}\right)}^{\frac{1}{3}} - 0.1111111111111111 \cdot {\left(\frac{1}{{x}^{5}}\right)}^{\frac{1}{3}}\right)\\
\mathbf{elif}\;x \le 0.0131361152034403465:\\
\;\;\;\;\mathsf{fma}\left(\sqrt[3]{{x}^{3} + {1}^{3}}, \frac{1}{\frac{\sqrt[3]{{\left(x \cdot x\right)}^{3} + {\left(1 \cdot 1 - x \cdot 1\right)}^{3}}}{\sqrt[3]{\left(x \cdot x\right) \cdot \left(x \cdot x\right) + \left(\left(1 \cdot 1 - x \cdot 1\right) \cdot \left(1 \cdot 1 - x \cdot 1\right) - \left(x \cdot x\right) \cdot \left(1 \cdot 1 - x \cdot 1\right)\right)}}}, -\sqrt[3]{x}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{0 + 1}{\mathsf{fma}\left(\sqrt[3]{x + 1}, \sqrt[3]{x + 1} + \sqrt[3]{x}, {x}^{\frac{2}{3}}\right)}\\
\end{array}double code(double x) {
return (cbrt((x + 1.0)) - cbrt(x));
}
double code(double x) {
double VAR;
if ((x <= -4.495023653592418e+61)) {
VAR = fma(pow((1.0 / pow(x, 2.0)), 0.3333333333333333), 0.3333333333333333, ((0.06172839506172839 * pow((1.0 / pow(x, 8.0)), 0.3333333333333333)) - (0.1111111111111111 * pow((1.0 / pow(x, 5.0)), 0.3333333333333333))));
} else {
double VAR_1;
if ((x <= 0.013136115203440346)) {
VAR_1 = fma(cbrt((pow(x, 3.0) + pow(1.0, 3.0))), (1.0 / (cbrt((pow((x * x), 3.0) + pow(((1.0 * 1.0) - (x * 1.0)), 3.0))) / cbrt((((x * x) * (x * x)) + ((((1.0 * 1.0) - (x * 1.0)) * ((1.0 * 1.0) - (x * 1.0))) - ((x * x) * ((1.0 * 1.0) - (x * 1.0)))))))), -cbrt(x));
} else {
VAR_1 = ((0.0 + 1.0) / fma(cbrt((x + 1.0)), (cbrt((x + 1.0)) + cbrt(x)), pow(x, 0.6666666666666666)));
}
VAR = VAR_1;
}
return VAR;
}



Bits error versus x
Results
if x < -4.495023653592418e+61Initial program 61.2
Taylor expanded around inf 40.3
Simplified40.3
if -4.495023653592418e+61 < x < 0.013136115203440346Initial program 4.6
rmApplied flip3-+4.6
Applied cbrt-div4.5
rmApplied div-inv4.5
Applied fma-neg4.5
rmApplied flip3-+4.5
Applied cbrt-div4.5
if 0.013136115203440346 < x Initial program 59.0
rmApplied flip3--58.9
Simplified1.0
Simplified4.4
Final simplification11.8
herbie shell --seed 2020071 +o rules:numerics
(FPCore (x)
:name "2cbrt (problem 3.3.4)"
:precision binary64
(- (cbrt (+ x 1)) (cbrt x)))