2cbrt (problem 3.3.4)

Percentage Accurate: 7.0% → 98.2%
Time: 12.5s
Alternatives: 5
Speedup: 2.0×

Specification

?
\[x > 1 \land x < 10^{+308}\]
\[\begin{array}{l} \\ \sqrt[3]{x + 1} - \sqrt[3]{x} \end{array} \]
(FPCore (x) :precision binary64 (- (cbrt (+ x 1.0)) (cbrt x)))
double code(double x) {
	return cbrt((x + 1.0)) - cbrt(x);
}
public static double code(double x) {
	return Math.cbrt((x + 1.0)) - Math.cbrt(x);
}
function code(x)
	return Float64(cbrt(Float64(x + 1.0)) - cbrt(x))
end
code[x_] := N[(N[Power[N[(x + 1.0), $MachinePrecision], 1/3], $MachinePrecision] - N[Power[x, 1/3], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\sqrt[3]{x + 1} - \sqrt[3]{x}
\end{array}

Sampling outcomes in binary64 precision:

Local Percentage Accuracy vs ?

The average percentage accuracy by input value. Horizontal axis shows value of an input variable; the variable is choosen in the title. Vertical axis is accuracy; higher is better. Red represent the original program, while blue represents Herbie's suggestion. These can be toggled with buttons below the plot. The line is an average while dots represent individual samples.

Accuracy vs Speed?

Herbie found 5 alternatives:

AlternativeAccuracySpeedup
The accuracy (vertical axis) and speed (horizontal axis) of each alternatives. Up and to the right is better. The red square shows the initial program, and each blue circle shows an alternative.The line shows the best available speed-accuracy tradeoffs.

Initial Program: 7.0% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \sqrt[3]{x + 1} - \sqrt[3]{x} \end{array} \]
(FPCore (x) :precision binary64 (- (cbrt (+ x 1.0)) (cbrt x)))
double code(double x) {
	return cbrt((x + 1.0)) - cbrt(x);
}
public static double code(double x) {
	return Math.cbrt((x + 1.0)) - Math.cbrt(x);
}
function code(x)
	return Float64(cbrt(Float64(x + 1.0)) - cbrt(x))
end
code[x_] := N[(N[Power[N[(x + 1.0), $MachinePrecision], 1/3], $MachinePrecision] - N[Power[x, 1/3], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\sqrt[3]{x + 1} - \sqrt[3]{x}
\end{array}

Alternative 1: 98.2% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot {x}^{-0.6666666666666666}}{x} \end{array} \]
(FPCore (x)
 :precision binary64
 (/
  (+
   (cbrt (* x 0.037037037037037035))
   (* -0.1111111111111111 (pow x -0.6666666666666666)))
  x))
double code(double x) {
	return (cbrt((x * 0.037037037037037035)) + (-0.1111111111111111 * pow(x, -0.6666666666666666))) / x;
}
public static double code(double x) {
	return (Math.cbrt((x * 0.037037037037037035)) + (-0.1111111111111111 * Math.pow(x, -0.6666666666666666))) / x;
}
function code(x)
	return Float64(Float64(cbrt(Float64(x * 0.037037037037037035)) + Float64(-0.1111111111111111 * (x ^ -0.6666666666666666))) / x)
end
code[x_] := N[(N[(N[Power[N[(x * 0.037037037037037035), $MachinePrecision], 1/3], $MachinePrecision] + N[(-0.1111111111111111 * N[Power[x, -0.6666666666666666], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / x), $MachinePrecision]
\begin{array}{l}

\\
\frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot {x}^{-0.6666666666666666}}{x}
\end{array}
Derivation
  1. Initial program 6.4%

    \[\sqrt[3]{x + 1} - \sqrt[3]{x} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. add-sqr-sqrt6.0%

      \[\leadsto \color{blue}{\sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}}} - \sqrt[3]{x} \]
    2. add-sqr-sqrt6.3%

      \[\leadsto \sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}} - \color{blue}{\sqrt{\sqrt[3]{x}} \cdot \sqrt{\sqrt[3]{x}}} \]
    3. difference-of-squares6.3%

      \[\leadsto \color{blue}{\left(\sqrt{\sqrt[3]{x + 1}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right)} \]
    4. pow1/36.3%

      \[\leadsto \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    5. sqrt-pow16.3%

      \[\leadsto \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    6. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    7. pow1/36.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    8. sqrt-pow16.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    9. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{\color{blue}{0.16666666666666666}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    10. pow1/33.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} - \sqrt{\sqrt[3]{x}}\right) \]
    11. sqrt-pow13.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} - \sqrt{\sqrt[3]{x}}\right) \]
    12. metadata-eval3.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} - \sqrt{\sqrt[3]{x}}\right) \]
    13. pow1/36.2%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \]
    14. sqrt-pow16.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \]
    15. metadata-eval6.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{\color{blue}{0.16666666666666666}}\right) \]
  4. Applied egg-rr6.4%

    \[\leadsto \color{blue}{\left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{0.16666666666666666}\right)} \]
  5. Taylor expanded in x around inf 98.5%

    \[\leadsto \color{blue}{\frac{-0.1388888888888889 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + \left(0.027777777777777776 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + 0.3333333333333333 \cdot \sqrt[3]{x}\right)}{x}} \]
  6. Step-by-step derivation
    1. *-un-lft-identity98.5%

      \[\leadsto \color{blue}{1 \cdot \frac{-0.1388888888888889 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + \left(0.027777777777777776 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + 0.3333333333333333 \cdot \sqrt[3]{x}\right)}{x}} \]
  7. Applied egg-rr98.7%

    \[\leadsto \color{blue}{1 \cdot \frac{\sqrt[3]{x \cdot 0.037037037037037035} + \sqrt[3]{{x}^{-2}} \cdot -0.1111111111111111}{x}} \]
  8. Step-by-step derivation
    1. associate-*r/98.7%

      \[\leadsto \color{blue}{\frac{1 \cdot \left(\sqrt[3]{x \cdot 0.037037037037037035} + \sqrt[3]{{x}^{-2}} \cdot -0.1111111111111111\right)}{x}} \]
    2. *-lft-identity98.7%

      \[\leadsto \frac{\color{blue}{\sqrt[3]{x \cdot 0.037037037037037035} + \sqrt[3]{{x}^{-2}} \cdot -0.1111111111111111}}{x} \]
    3. *-commutative98.7%

      \[\leadsto \frac{\sqrt[3]{x \cdot 0.037037037037037035} + \color{blue}{-0.1111111111111111 \cdot \sqrt[3]{{x}^{-2}}}}{x} \]
  9. Simplified98.7%

    \[\leadsto \color{blue}{\frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot \sqrt[3]{{x}^{-2}}}{x}} \]
  10. Step-by-step derivation
    1. pow1/398.7%

      \[\leadsto \frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot \color{blue}{{\left({x}^{-2}\right)}^{0.3333333333333333}}}{x} \]
    2. pow-pow98.7%

      \[\leadsto \frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot \color{blue}{{x}^{\left(-2 \cdot 0.3333333333333333\right)}}}{x} \]
    3. metadata-eval98.7%

      \[\leadsto \frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot {x}^{\color{blue}{-0.6666666666666666}}}{x} \]
  11. Applied egg-rr98.7%

    \[\leadsto \frac{\sqrt[3]{x \cdot 0.037037037037037035} + -0.1111111111111111 \cdot \color{blue}{{x}^{-0.6666666666666666}}}{x} \]
  12. Add Preprocessing

Alternative 2: 97.1% accurate, 2.0× speedup?

\[\begin{array}{l} \\ \frac{\sqrt[3]{x} \cdot 0.3333333333333333}{x} \end{array} \]
(FPCore (x) :precision binary64 (/ (* (cbrt x) 0.3333333333333333) x))
double code(double x) {
	return (cbrt(x) * 0.3333333333333333) / x;
}
public static double code(double x) {
	return (Math.cbrt(x) * 0.3333333333333333) / x;
}
function code(x)
	return Float64(Float64(cbrt(x) * 0.3333333333333333) / x)
end
code[x_] := N[(N[(N[Power[x, 1/3], $MachinePrecision] * 0.3333333333333333), $MachinePrecision] / x), $MachinePrecision]
\begin{array}{l}

\\
\frac{\sqrt[3]{x} \cdot 0.3333333333333333}{x}
\end{array}
Derivation
  1. Initial program 6.4%

    \[\sqrt[3]{x + 1} - \sqrt[3]{x} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. add-sqr-sqrt6.0%

      \[\leadsto \color{blue}{\sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}}} - \sqrt[3]{x} \]
    2. add-sqr-sqrt6.3%

      \[\leadsto \sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}} - \color{blue}{\sqrt{\sqrt[3]{x}} \cdot \sqrt{\sqrt[3]{x}}} \]
    3. difference-of-squares6.3%

      \[\leadsto \color{blue}{\left(\sqrt{\sqrt[3]{x + 1}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right)} \]
    4. pow1/36.3%

      \[\leadsto \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    5. sqrt-pow16.3%

      \[\leadsto \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    6. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    7. pow1/36.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    8. sqrt-pow16.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    9. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{\color{blue}{0.16666666666666666}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    10. pow1/33.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} - \sqrt{\sqrt[3]{x}}\right) \]
    11. sqrt-pow13.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} - \sqrt{\sqrt[3]{x}}\right) \]
    12. metadata-eval3.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} - \sqrt{\sqrt[3]{x}}\right) \]
    13. pow1/36.2%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \]
    14. sqrt-pow16.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \]
    15. metadata-eval6.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{\color{blue}{0.16666666666666666}}\right) \]
  4. Applied egg-rr6.4%

    \[\leadsto \color{blue}{\left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{0.16666666666666666}\right)} \]
  5. Taylor expanded in x around inf 98.5%

    \[\leadsto \color{blue}{\frac{-0.1388888888888889 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + \left(0.027777777777777776 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + 0.3333333333333333 \cdot \sqrt[3]{x}\right)}{x}} \]
  6. Taylor expanded in x around inf 97.7%

    \[\leadsto \frac{\color{blue}{0.3333333333333333 \cdot \sqrt[3]{x}}}{x} \]
  7. Step-by-step derivation
    1. *-commutative97.7%

      \[\leadsto \frac{\color{blue}{\sqrt[3]{x} \cdot 0.3333333333333333}}{x} \]
  8. Simplified97.7%

    \[\leadsto \frac{\color{blue}{\sqrt[3]{x} \cdot 0.3333333333333333}}{x} \]
  9. Add Preprocessing

Alternative 3: 97.1% accurate, 2.0× speedup?

\[\begin{array}{l} \\ \sqrt[3]{x} \cdot \frac{0.3333333333333333}{x} \end{array} \]
(FPCore (x) :precision binary64 (* (cbrt x) (/ 0.3333333333333333 x)))
double code(double x) {
	return cbrt(x) * (0.3333333333333333 / x);
}
public static double code(double x) {
	return Math.cbrt(x) * (0.3333333333333333 / x);
}
function code(x)
	return Float64(cbrt(x) * Float64(0.3333333333333333 / x))
end
code[x_] := N[(N[Power[x, 1/3], $MachinePrecision] * N[(0.3333333333333333 / x), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\sqrt[3]{x} \cdot \frac{0.3333333333333333}{x}
\end{array}
Derivation
  1. Initial program 6.4%

    \[\sqrt[3]{x + 1} - \sqrt[3]{x} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. add-sqr-sqrt6.0%

      \[\leadsto \color{blue}{\sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}}} - \sqrt[3]{x} \]
    2. add-sqr-sqrt6.3%

      \[\leadsto \sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}} - \color{blue}{\sqrt{\sqrt[3]{x}} \cdot \sqrt{\sqrt[3]{x}}} \]
    3. difference-of-squares6.3%

      \[\leadsto \color{blue}{\left(\sqrt{\sqrt[3]{x + 1}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right)} \]
    4. pow1/36.3%

      \[\leadsto \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    5. sqrt-pow16.3%

      \[\leadsto \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    6. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    7. pow1/36.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    8. sqrt-pow16.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    9. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{\color{blue}{0.16666666666666666}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    10. pow1/33.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} - \sqrt{\sqrt[3]{x}}\right) \]
    11. sqrt-pow13.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} - \sqrt{\sqrt[3]{x}}\right) \]
    12. metadata-eval3.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} - \sqrt{\sqrt[3]{x}}\right) \]
    13. pow1/36.2%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \]
    14. sqrt-pow16.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \]
    15. metadata-eval6.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{\color{blue}{0.16666666666666666}}\right) \]
  4. Applied egg-rr6.4%

    \[\leadsto \color{blue}{\left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{0.16666666666666666}\right)} \]
  5. Taylor expanded in x around inf 98.5%

    \[\leadsto \color{blue}{\frac{-0.1388888888888889 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + \left(0.027777777777777776 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + 0.3333333333333333 \cdot \sqrt[3]{x}\right)}{x}} \]
  6. Taylor expanded in x around inf 97.7%

    \[\leadsto \frac{\color{blue}{0.3333333333333333 \cdot \sqrt[3]{x}}}{x} \]
  7. Step-by-step derivation
    1. *-commutative97.7%

      \[\leadsto \frac{\color{blue}{\sqrt[3]{x} \cdot 0.3333333333333333}}{x} \]
  8. Simplified97.7%

    \[\leadsto \frac{\color{blue}{\sqrt[3]{x} \cdot 0.3333333333333333}}{x} \]
  9. Step-by-step derivation
    1. associate-/l*97.7%

      \[\leadsto \color{blue}{\sqrt[3]{x} \cdot \frac{0.3333333333333333}{x}} \]
    2. *-commutative97.7%

      \[\leadsto \color{blue}{\frac{0.3333333333333333}{x} \cdot \sqrt[3]{x}} \]
  10. Applied egg-rr97.7%

    \[\leadsto \color{blue}{\frac{0.3333333333333333}{x} \cdot \sqrt[3]{x}} \]
  11. Final simplification97.7%

    \[\leadsto \sqrt[3]{x} \cdot \frac{0.3333333333333333}{x} \]
  12. Add Preprocessing

Alternative 4: 97.1% accurate, 2.0× speedup?

\[\begin{array}{l} \\ 0.3333333333333333 \cdot \frac{\sqrt[3]{x}}{x} \end{array} \]
(FPCore (x) :precision binary64 (* 0.3333333333333333 (/ (cbrt x) x)))
double code(double x) {
	return 0.3333333333333333 * (cbrt(x) / x);
}
public static double code(double x) {
	return 0.3333333333333333 * (Math.cbrt(x) / x);
}
function code(x)
	return Float64(0.3333333333333333 * Float64(cbrt(x) / x))
end
code[x_] := N[(0.3333333333333333 * N[(N[Power[x, 1/3], $MachinePrecision] / x), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
0.3333333333333333 \cdot \frac{\sqrt[3]{x}}{x}
\end{array}
Derivation
  1. Initial program 6.4%

    \[\sqrt[3]{x + 1} - \sqrt[3]{x} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. add-sqr-sqrt6.0%

      \[\leadsto \color{blue}{\sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}}} - \sqrt[3]{x} \]
    2. add-sqr-sqrt6.3%

      \[\leadsto \sqrt{\sqrt[3]{x + 1}} \cdot \sqrt{\sqrt[3]{x + 1}} - \color{blue}{\sqrt{\sqrt[3]{x}} \cdot \sqrt{\sqrt[3]{x}}} \]
    3. difference-of-squares6.3%

      \[\leadsto \color{blue}{\left(\sqrt{\sqrt[3]{x + 1}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right)} \]
    4. pow1/36.3%

      \[\leadsto \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    5. sqrt-pow16.3%

      \[\leadsto \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    6. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} + \sqrt{\sqrt[3]{x}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    7. pow1/36.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    8. sqrt-pow16.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    9. metadata-eval6.3%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{\color{blue}{0.16666666666666666}}\right) \cdot \left(\sqrt{\sqrt[3]{x + 1}} - \sqrt{\sqrt[3]{x}}\right) \]
    10. pow1/33.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\sqrt{\color{blue}{{\left(x + 1\right)}^{0.3333333333333333}}} - \sqrt{\sqrt[3]{x}}\right) \]
    11. sqrt-pow13.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left(\color{blue}{{\left(x + 1\right)}^{\left(\frac{0.3333333333333333}{2}\right)}} - \sqrt{\sqrt[3]{x}}\right) \]
    12. metadata-eval3.9%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{\color{blue}{0.16666666666666666}} - \sqrt{\sqrt[3]{x}}\right) \]
    13. pow1/36.2%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \sqrt{\color{blue}{{x}^{0.3333333333333333}}}\right) \]
    14. sqrt-pow16.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - \color{blue}{{x}^{\left(\frac{0.3333333333333333}{2}\right)}}\right) \]
    15. metadata-eval6.4%

      \[\leadsto \left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{\color{blue}{0.16666666666666666}}\right) \]
  4. Applied egg-rr6.4%

    \[\leadsto \color{blue}{\left({\left(x + 1\right)}^{0.16666666666666666} + {x}^{0.16666666666666666}\right) \cdot \left({\left(x + 1\right)}^{0.16666666666666666} - {x}^{0.16666666666666666}\right)} \]
  5. Taylor expanded in x around inf 98.5%

    \[\leadsto \color{blue}{\frac{-0.1388888888888889 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + \left(0.027777777777777776 \cdot \sqrt[3]{\frac{1}{{x}^{2}}} + 0.3333333333333333 \cdot \sqrt[3]{x}\right)}{x}} \]
  6. Taylor expanded in x around inf 97.7%

    \[\leadsto \frac{\color{blue}{0.3333333333333333 \cdot \sqrt[3]{x}}}{x} \]
  7. Step-by-step derivation
    1. *-commutative97.7%

      \[\leadsto \frac{\color{blue}{\sqrt[3]{x} \cdot 0.3333333333333333}}{x} \]
  8. Simplified97.7%

    \[\leadsto \frac{\color{blue}{\sqrt[3]{x} \cdot 0.3333333333333333}}{x} \]
  9. Step-by-step derivation
    1. associate-/l*97.7%

      \[\leadsto \color{blue}{\sqrt[3]{x} \cdot \frac{0.3333333333333333}{x}} \]
  10. Applied egg-rr97.7%

    \[\leadsto \color{blue}{\sqrt[3]{x} \cdot \frac{0.3333333333333333}{x}} \]
  11. Step-by-step derivation
    1. *-commutative97.7%

      \[\leadsto \color{blue}{\frac{0.3333333333333333}{x} \cdot \sqrt[3]{x}} \]
    2. associate-*l/97.7%

      \[\leadsto \color{blue}{\frac{0.3333333333333333 \cdot \sqrt[3]{x}}{x}} \]
    3. associate-*r/97.6%

      \[\leadsto \color{blue}{0.3333333333333333 \cdot \frac{\sqrt[3]{x}}{x}} \]
  12. Simplified97.6%

    \[\leadsto \color{blue}{0.3333333333333333 \cdot \frac{\sqrt[3]{x}}{x}} \]
  13. Add Preprocessing

Alternative 5: 5.4% accurate, 2.0× speedup?

\[\begin{array}{l} \\ \sqrt[3]{x} + 1 \end{array} \]
(FPCore (x) :precision binary64 (+ (cbrt x) 1.0))
double code(double x) {
	return cbrt(x) + 1.0;
}
public static double code(double x) {
	return Math.cbrt(x) + 1.0;
}
function code(x)
	return Float64(cbrt(x) + 1.0)
end
code[x_] := N[(N[Power[x, 1/3], $MachinePrecision] + 1.0), $MachinePrecision]
\begin{array}{l}

\\
\sqrt[3]{x} + 1
\end{array}
Derivation
  1. Initial program 6.4%

    \[\sqrt[3]{x + 1} - \sqrt[3]{x} \]
  2. Add Preprocessing
  3. Taylor expanded in x around 0 1.8%

    \[\leadsto \color{blue}{1 - \sqrt[3]{x}} \]
  4. Step-by-step derivation
    1. sub-neg1.8%

      \[\leadsto \color{blue}{1 + \left(-\sqrt[3]{x}\right)} \]
    2. rem-square-sqrt0.0%

      \[\leadsto 1 + \color{blue}{\sqrt{-\sqrt[3]{x}} \cdot \sqrt{-\sqrt[3]{x}}} \]
    3. fabs-sqr0.0%

      \[\leadsto 1 + \color{blue}{\left|\sqrt{-\sqrt[3]{x}} \cdot \sqrt{-\sqrt[3]{x}}\right|} \]
    4. rem-square-sqrt5.3%

      \[\leadsto 1 + \left|\color{blue}{-\sqrt[3]{x}}\right| \]
    5. fabs-neg5.3%

      \[\leadsto 1 + \color{blue}{\left|\sqrt[3]{x}\right|} \]
    6. unpow1/35.3%

      \[\leadsto 1 + \left|\color{blue}{{x}^{0.3333333333333333}}\right| \]
    7. metadata-eval5.3%

      \[\leadsto 1 + \left|{x}^{\color{blue}{\left(2 \cdot 0.16666666666666666\right)}}\right| \]
    8. pow-sqr5.3%

      \[\leadsto 1 + \left|\color{blue}{{x}^{0.16666666666666666} \cdot {x}^{0.16666666666666666}}\right| \]
    9. fabs-sqr5.3%

      \[\leadsto 1 + \color{blue}{{x}^{0.16666666666666666} \cdot {x}^{0.16666666666666666}} \]
    10. pow-sqr5.3%

      \[\leadsto 1 + \color{blue}{{x}^{\left(2 \cdot 0.16666666666666666\right)}} \]
    11. metadata-eval5.3%

      \[\leadsto 1 + {x}^{\color{blue}{0.3333333333333333}} \]
    12. unpow1/35.3%

      \[\leadsto 1 + \color{blue}{\sqrt[3]{x}} \]
  5. Simplified5.3%

    \[\leadsto \color{blue}{1 + \sqrt[3]{x}} \]
  6. Final simplification5.3%

    \[\leadsto \sqrt[3]{x} + 1 \]
  7. Add Preprocessing

Developer Target 1: 98.5% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt[3]{x + 1}\\ \frac{1}{\left(t\_0 \cdot t\_0 + \sqrt[3]{x} \cdot t\_0\right) + \sqrt[3]{x} \cdot \sqrt[3]{x}} \end{array} \end{array} \]
(FPCore (x)
 :precision binary64
 (let* ((t_0 (cbrt (+ x 1.0))))
   (/ 1.0 (+ (+ (* t_0 t_0) (* (cbrt x) t_0)) (* (cbrt x) (cbrt x))))))
double code(double x) {
	double t_0 = cbrt((x + 1.0));
	return 1.0 / (((t_0 * t_0) + (cbrt(x) * t_0)) + (cbrt(x) * cbrt(x)));
}
public static double code(double x) {
	double t_0 = Math.cbrt((x + 1.0));
	return 1.0 / (((t_0 * t_0) + (Math.cbrt(x) * t_0)) + (Math.cbrt(x) * Math.cbrt(x)));
}
function code(x)
	t_0 = cbrt(Float64(x + 1.0))
	return Float64(1.0 / Float64(Float64(Float64(t_0 * t_0) + Float64(cbrt(x) * t_0)) + Float64(cbrt(x) * cbrt(x))))
end
code[x_] := Block[{t$95$0 = N[Power[N[(x + 1.0), $MachinePrecision], 1/3], $MachinePrecision]}, N[(1.0 / N[(N[(N[(t$95$0 * t$95$0), $MachinePrecision] + N[(N[Power[x, 1/3], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision] + N[(N[Power[x, 1/3], $MachinePrecision] * N[Power[x, 1/3], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sqrt[3]{x + 1}\\
\frac{1}{\left(t\_0 \cdot t\_0 + \sqrt[3]{x} \cdot t\_0\right) + \sqrt[3]{x} \cdot \sqrt[3]{x}}
\end{array}
\end{array}

Reproduce

?
herbie shell --seed 2024113 
(FPCore (x)
  :name "2cbrt (problem 3.3.4)"
  :precision binary64
  :pre (and (> x 1.0) (< x 1e+308))

  :alt
  (! :herbie-platform default (/ 1 (+ (* (cbrt (+ x 1)) (cbrt (+ x 1))) (* (cbrt x) (cbrt (+ x 1))) (* (cbrt x) (cbrt x)))))

  (- (cbrt (+ x 1.0)) (cbrt x)))