\left(\frac{\sqrt{2}}{4} \cdot \sqrt{1 - 3 \cdot \left(v \cdot v\right)}\right) \cdot \left(1 - v \cdot v\right)\left(\left(\frac{\sqrt{2}}{4} \cdot \sqrt{\sqrt{1 - 3 \cdot \left(v \cdot v\right)}}\right) \cdot \sqrt{\sqrt{1 - 3 \cdot \left(v \cdot v\right)}}\right) \cdot \left(1 - v \cdot v\right)double f(double v) {
double r193750 = 2.0;
double r193751 = sqrt(r193750);
double r193752 = 4.0;
double r193753 = r193751 / r193752;
double r193754 = 1.0;
double r193755 = 3.0;
double r193756 = v;
double r193757 = r193756 * r193756;
double r193758 = r193755 * r193757;
double r193759 = r193754 - r193758;
double r193760 = sqrt(r193759);
double r193761 = r193753 * r193760;
double r193762 = r193754 - r193757;
double r193763 = r193761 * r193762;
return r193763;
}
double f(double v) {
double r193764 = 2.0;
double r193765 = sqrt(r193764);
double r193766 = 4.0;
double r193767 = r193765 / r193766;
double r193768 = 1.0;
double r193769 = 3.0;
double r193770 = v;
double r193771 = r193770 * r193770;
double r193772 = r193769 * r193771;
double r193773 = r193768 - r193772;
double r193774 = sqrt(r193773);
double r193775 = sqrt(r193774);
double r193776 = r193767 * r193775;
double r193777 = r193776 * r193775;
double r193778 = r193768 - r193771;
double r193779 = r193777 * r193778;
return r193779;
}



Bits error versus v
Results
Initial program 0.0
rmApplied add-sqr-sqrt0.0
Applied sqrt-prod0.0
Applied associate-*r*0.0
Final simplification0.0
herbie shell --seed 2019304 +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))))