\left(\frac{\sqrt{2}}{4} \cdot \sqrt{1 - 3 \cdot \left(v \cdot v\right)}\right) \cdot \left(1 - v \cdot v\right)\sqrt[3]{{\left(\sqrt{1 - 3 \cdot \left(v \cdot v\right)}\right)}^{3} \cdot \left(\frac{2}{\frac{{4}^{3}}{\sqrt{2}}} \cdot {\left(1 - v \cdot v\right)}^{3}\right)}double f(double v) {
double r156818 = 2.0;
double r156819 = sqrt(r156818);
double r156820 = 4.0;
double r156821 = r156819 / r156820;
double r156822 = 1.0;
double r156823 = 3.0;
double r156824 = v;
double r156825 = r156824 * r156824;
double r156826 = r156823 * r156825;
double r156827 = r156822 - r156826;
double r156828 = sqrt(r156827);
double r156829 = r156821 * r156828;
double r156830 = r156822 - r156825;
double r156831 = r156829 * r156830;
return r156831;
}
double f(double v) {
double r156832 = 1.0;
double r156833 = 3.0;
double r156834 = v;
double r156835 = r156834 * r156834;
double r156836 = r156833 * r156835;
double r156837 = r156832 - r156836;
double r156838 = sqrt(r156837);
double r156839 = 3.0;
double r156840 = pow(r156838, r156839);
double r156841 = 2.0;
double r156842 = 4.0;
double r156843 = pow(r156842, r156839);
double r156844 = sqrt(r156841);
double r156845 = r156843 / r156844;
double r156846 = r156841 / r156845;
double r156847 = r156832 - r156835;
double r156848 = pow(r156847, r156839);
double r156849 = r156846 * r156848;
double r156850 = r156840 * r156849;
double r156851 = cbrt(r156850);
return r156851;
}



Bits error versus v
Results
Initial program 0.0
rmApplied add-cbrt-cube0.0
Applied add-cbrt-cube0.0
Applied add-cbrt-cube0.0
Applied add-cbrt-cube1.0
Applied cbrt-undiv0.0
Applied cbrt-unprod0.0
Applied cbrt-unprod0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019305 +o rules:numerics
(FPCore (v)
:name "Falkner and Boettcher, Appendix B, 2"
:precision binary64
(* (* (/ (sqrt 2) 4) (sqrt (- 1 (* 3 (* v v))))) (- 1 (* v v))))