\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}{1} \cdot \left(\frac{1}{\sqrt{\pi}} \cdot \mathsf{fma}\left(\frac{\sqrt{1}}{\sqrt{21}} \cdot \left(\frac{\sqrt{1}}{\sqrt{21}} \cdot {\left(\left|x\right|\right)}^{6}\right), \left|x\right|, \mathsf{fma}\left(\left(\frac{1}{5} \cdot {\left(\left|x\right|\right)}^{3}\right) \cdot \left|x\right|, \left|x\right|, \mathsf{fma}\left(\left|x\right|, 2, {\left(\left|x\right|\right)}^{3} \cdot \frac{2}{3}\right)\right)\right)\right)\right|double f(double x) {
double r214769 = 1.0;
double r214770 = atan2(1.0, 0.0);
double r214771 = sqrt(r214770);
double r214772 = r214769 / r214771;
double r214773 = 2.0;
double r214774 = x;
double r214775 = fabs(r214774);
double r214776 = r214773 * r214775;
double r214777 = 3.0;
double r214778 = r214773 / r214777;
double r214779 = r214775 * r214775;
double r214780 = r214779 * r214775;
double r214781 = r214778 * r214780;
double r214782 = r214776 + r214781;
double r214783 = 5.0;
double r214784 = r214769 / r214783;
double r214785 = r214780 * r214775;
double r214786 = r214785 * r214775;
double r214787 = r214784 * r214786;
double r214788 = r214782 + r214787;
double r214789 = 21.0;
double r214790 = r214769 / r214789;
double r214791 = r214786 * r214775;
double r214792 = r214791 * r214775;
double r214793 = r214790 * r214792;
double r214794 = r214788 + r214793;
double r214795 = r214772 * r214794;
double r214796 = fabs(r214795);
return r214796;
}
double f(double x) {
double r214797 = 1.0;
double r214798 = r214797 / r214797;
double r214799 = 1.0;
double r214800 = atan2(1.0, 0.0);
double r214801 = sqrt(r214800);
double r214802 = r214799 / r214801;
double r214803 = sqrt(r214799);
double r214804 = 21.0;
double r214805 = sqrt(r214804);
double r214806 = r214803 / r214805;
double r214807 = x;
double r214808 = fabs(r214807);
double r214809 = 6.0;
double r214810 = pow(r214808, r214809);
double r214811 = r214806 * r214810;
double r214812 = r214806 * r214811;
double r214813 = 5.0;
double r214814 = r214799 / r214813;
double r214815 = 3.0;
double r214816 = pow(r214808, r214815);
double r214817 = r214814 * r214816;
double r214818 = r214817 * r214808;
double r214819 = 2.0;
double r214820 = 3.0;
double r214821 = r214819 / r214820;
double r214822 = r214816 * r214821;
double r214823 = fma(r214808, r214819, r214822);
double r214824 = fma(r214818, r214808, r214823);
double r214825 = fma(r214812, r214808, r214824);
double r214826 = r214802 * r214825;
double r214827 = r214798 * r214826;
double r214828 = fabs(r214827);
return r214828;
}



Bits error versus x
Initial program 0.2
rmApplied add-sqr-sqrt0.2
Applied add-sqr-sqrt0.2
Applied times-frac0.2
Applied associate-*l*0.2
Simplified0.2
rmApplied *-un-lft-identity0.2
Applied *-un-lft-identity0.2
Applied times-frac0.2
Applied associate-*l*0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x)
:name "Jmat.Real.erfi, branch x less than or equal to 0.5"
:precision binary64
(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)))))))