\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|\left(\sqrt{\frac{1}{\pi}} \cdot \left(\left(\frac{6004799503160661}{9007199254740992} \cdot {\left(\left|x\right|\right)}^{3} + \left(\frac{3602879701896397}{18014398509481984} \cdot {\left(\left|x\right|\right)}^{5} + 2 \cdot \left|x\right|\right)\right) + \frac{1 \cdot {\left(\left|x\right|\right)}^{7}}{21}\right)\right) \cdot 1\right|double f(double x) {
double r127880 = 1.0;
double r127881 = atan2(1.0, 0.0);
double r127882 = sqrt(r127881);
double r127883 = r127880 / r127882;
double r127884 = 2.0;
double r127885 = x;
double r127886 = fabs(r127885);
double r127887 = r127884 * r127886;
double r127888 = 3.0;
double r127889 = r127884 / r127888;
double r127890 = r127886 * r127886;
double r127891 = r127890 * r127886;
double r127892 = r127889 * r127891;
double r127893 = r127887 + r127892;
double r127894 = 5.0;
double r127895 = r127880 / r127894;
double r127896 = r127891 * r127886;
double r127897 = r127896 * r127886;
double r127898 = r127895 * r127897;
double r127899 = r127893 + r127898;
double r127900 = 21.0;
double r127901 = r127880 / r127900;
double r127902 = r127897 * r127886;
double r127903 = r127902 * r127886;
double r127904 = r127901 * r127903;
double r127905 = r127899 + r127904;
double r127906 = r127883 * r127905;
double r127907 = fabs(r127906);
return r127907;
}
double f(double x) {
double r127908 = 1.0;
double r127909 = atan2(1.0, 0.0);
double r127910 = r127908 / r127909;
double r127911 = sqrt(r127910);
double r127912 = 6004799503160661.0;
double r127913 = 9007199254740992.0;
double r127914 = r127912 / r127913;
double r127915 = x;
double r127916 = fabs(r127915);
double r127917 = 3.0;
double r127918 = pow(r127916, r127917);
double r127919 = r127914 * r127918;
double r127920 = 3602879701896397.0;
double r127921 = 18014398509481984.0;
double r127922 = r127920 / r127921;
double r127923 = 5.0;
double r127924 = pow(r127916, r127923);
double r127925 = r127922 * r127924;
double r127926 = 2.0;
double r127927 = r127926 * r127916;
double r127928 = r127925 + r127927;
double r127929 = r127919 + r127928;
double r127930 = 1.0;
double r127931 = 7.0;
double r127932 = pow(r127916, r127931);
double r127933 = r127930 * r127932;
double r127934 = 21.0;
double r127935 = r127933 / r127934;
double r127936 = r127929 + r127935;
double r127937 = r127911 * r127936;
double r127938 = r127937 * r127930;
double r127939 = fabs(r127938);
return r127939;
}



Bits error versus x
Results
Initial program 0.2
rmApplied add-sqr-sqrt0.2
Applied *-un-lft-identity0.2
Applied times-frac0.2
Applied associate-*l*0.2
Simplified0.2
Taylor expanded around 0 0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019304
(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)))))))