\left|\frac{1}{\sqrt{\pi}} \cdot \left(\left(\left(2 \cdot \left|x\right| + \frac{2}{3} \cdot \left(\left(\left|x\right| \cdot \left|x\right|\right) \cdot \left|x\right|\right)\right) + \frac{1}{5} \cdot \left(\left(\left(\left(\left|x\right| \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right)\right) + \frac{1}{21} \cdot \left(\left(\left(\left(\left(\left(\left|x\right| \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right)\right)\right|\left|\frac{1}{\sqrt{\pi}} \cdot \left(\left(\frac{1}{5} \cdot \left(\left|x\right| \cdot \left(\left(\left(\left|x\right| \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right)\right) + \left(\left|x\right| \cdot 2 + \left(\left(\left|x\right| \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \frac{2}{3}\right)\right) + \left(\left|x\right| \cdot \left(\left|x\right| \cdot \left(\left|x\right| \cdot \left(\left(\left(\left|x\right| \cdot \left|x\right|\right) \cdot \left|x\right|\right) \cdot \left|x\right|\right)\right)\right)\right) \cdot \frac{1}{21}\right)\right|double f(double x) {
double r2253713 = 1.0;
double r2253714 = atan2(1.0, 0.0);
double r2253715 = sqrt(r2253714);
double r2253716 = r2253713 / r2253715;
double r2253717 = 2.0;
double r2253718 = x;
double r2253719 = fabs(r2253718);
double r2253720 = r2253717 * r2253719;
double r2253721 = 3.0;
double r2253722 = r2253717 / r2253721;
double r2253723 = r2253719 * r2253719;
double r2253724 = r2253723 * r2253719;
double r2253725 = r2253722 * r2253724;
double r2253726 = r2253720 + r2253725;
double r2253727 = 5.0;
double r2253728 = r2253713 / r2253727;
double r2253729 = r2253724 * r2253719;
double r2253730 = r2253729 * r2253719;
double r2253731 = r2253728 * r2253730;
double r2253732 = r2253726 + r2253731;
double r2253733 = 21.0;
double r2253734 = r2253713 / r2253733;
double r2253735 = r2253730 * r2253719;
double r2253736 = r2253735 * r2253719;
double r2253737 = r2253734 * r2253736;
double r2253738 = r2253732 + r2253737;
double r2253739 = r2253716 * r2253738;
double r2253740 = fabs(r2253739);
return r2253740;
}
double f(double x) {
double r2253741 = 1.0;
double r2253742 = atan2(1.0, 0.0);
double r2253743 = sqrt(r2253742);
double r2253744 = r2253741 / r2253743;
double r2253745 = 0.2;
double r2253746 = x;
double r2253747 = fabs(r2253746);
double r2253748 = r2253747 * r2253747;
double r2253749 = r2253748 * r2253747;
double r2253750 = r2253749 * r2253747;
double r2253751 = r2253747 * r2253750;
double r2253752 = r2253745 * r2253751;
double r2253753 = 2.0;
double r2253754 = r2253747 * r2253753;
double r2253755 = 0.6666666666666666;
double r2253756 = r2253749 * r2253755;
double r2253757 = r2253754 + r2253756;
double r2253758 = r2253752 + r2253757;
double r2253759 = r2253747 * r2253751;
double r2253760 = r2253747 * r2253759;
double r2253761 = 0.047619047619047616;
double r2253762 = r2253760 * r2253761;
double r2253763 = r2253758 + r2253762;
double r2253764 = r2253744 * r2253763;
double r2253765 = fabs(r2253764);
return r2253765;
}



Bits error versus x
Results
Initial program 0.2
Final simplification0.2
herbie shell --seed 2019132 +o rules:numerics
(FPCore (x)
:name "Jmat.Real.erfi, branch x less than or equal to 0.5"
(fabs (* (/ 1 (sqrt PI)) (+ (+ (+ (* 2 (fabs x)) (* (/ 2 3) (* (* (fabs x) (fabs x)) (fabs x)))) (* (/ 1 5) (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (fabs x)))) (* (/ 1 21) (* (* (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (fabs x)) (fabs x)) (fabs x)))))))