\left(\frac{1}{\sqrt{\pi}} \cdot e^{\left|x\right| \cdot \left|x\right|}\right) \cdot \left(\left(\left(\frac{1}{\left|x\right|} + \frac{1}{2} \cdot \left(\left(\frac{1}{\left|x\right|} \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right)\right) + \frac{3}{4} \cdot \left(\left(\left(\left(\frac{1}{\left|x\right|} \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right)\right) + \frac{15}{8} \cdot \left(\left(\left(\left(\left(\left(\frac{1}{\left|x\right|} \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right) \cdot \frac{1}{\left|x\right|}\right)\right)\sqrt{\frac{1}{\pi}} \cdot \left(\left(\frac{{\left(e^{x}\right)}^{x}}{\left|x\right|} + 0.5 \cdot \frac{{\left(e^{x}\right)}^{x}}{{\left(\left|x\right|\right)}^{3}}\right) + \left(0.75 \cdot \frac{{\left(e^{x}\right)}^{x}}{{\left(\left|x\right|\right)}^{5}} + 1.875 \cdot \frac{e^{x \cdot x}}{{\left(\left|x\right|\right)}^{7}}\right)\right)(FPCore (x)
:precision binary64
(*
(* (/ 1.0 (sqrt PI)) (exp (* (fabs x) (fabs x))))
(+
(+
(+
(/ 1.0 (fabs x))
(*
(/ 1.0 2.0)
(* (* (/ 1.0 (fabs x)) (/ 1.0 (fabs x))) (/ 1.0 (fabs x)))))
(*
(/ 3.0 4.0)
(*
(*
(* (* (/ 1.0 (fabs x)) (/ 1.0 (fabs x))) (/ 1.0 (fabs x)))
(/ 1.0 (fabs x)))
(/ 1.0 (fabs x)))))
(*
(/ 15.0 8.0)
(*
(*
(*
(*
(* (* (/ 1.0 (fabs x)) (/ 1.0 (fabs x))) (/ 1.0 (fabs x)))
(/ 1.0 (fabs x)))
(/ 1.0 (fabs x)))
(/ 1.0 (fabs x)))
(/ 1.0 (fabs x)))))))(FPCore (x)
:precision binary64
(*
(sqrt (/ 1.0 PI))
(+
(+
(/ (pow (exp x) x) (fabs x))
(* 0.5 (/ (pow (exp x) x) (pow (fabs x) 3.0))))
(+
(* 0.75 (/ (pow (exp x) x) (pow (fabs x) 5.0)))
(* 1.875 (/ (exp (* x x)) (pow (fabs x) 7.0)))))))double code(double x) {
return ((1.0 / sqrt((double) M_PI)) * exp(fabs(x) * fabs(x))) * ((((1.0 / fabs(x)) + ((1.0 / 2.0) * (((1.0 / fabs(x)) * (1.0 / fabs(x))) * (1.0 / fabs(x))))) + ((3.0 / 4.0) * (((((1.0 / fabs(x)) * (1.0 / fabs(x))) * (1.0 / fabs(x))) * (1.0 / fabs(x))) * (1.0 / fabs(x))))) + ((15.0 / 8.0) * (((((((1.0 / fabs(x)) * (1.0 / fabs(x))) * (1.0 / fabs(x))) * (1.0 / fabs(x))) * (1.0 / fabs(x))) * (1.0 / fabs(x))) * (1.0 / fabs(x)))));
}
double code(double x) {
return sqrt(1.0 / ((double) M_PI)) * (((pow(exp(x), x) / fabs(x)) + (0.5 * (pow(exp(x), x) / pow(fabs(x), 3.0)))) + ((0.75 * (pow(exp(x), x) / pow(fabs(x), 5.0))) + (1.875 * (exp(x * x) / pow(fabs(x), 7.0)))));
}









Bits error versus x
Results
| Alternative 1 | |
|---|---|
| Error | 1.3 |
| Cost | 55296 |
| Alternative 2 | |
|---|---|
| Error | 1.3 |
| Cost | 48704 |
| Alternative 3 | |
|---|---|
| Error | 1.3 |
| Cost | 33600 |
| Alternative 4 | |
|---|---|
| Error | 1.3 |
| Cost | 33600 |
| Alternative 5 | |
|---|---|
| Error | 2.7 |
| Cost | 27264 |
| Alternative 6 | |
|---|---|
| Error | 56.6 |
| Cost | 64 |

Initial program 2.8
Simplified2.6
Taylor expanded around inf 2.6
Simplified1.2
rmApplied pow-to-exp_binary64_35571.2
Simplified1.2
Simplified1.2
Final simplification1.2
herbie shell --seed 2021044
(FPCore (x)
:name "Jmat.Real.erfi, branch x greater than or equal to 5"
:precision binary64
:pre (>= x 0.5)
(* (* (/ 1.0 (sqrt PI)) (exp (* (fabs x) (fabs x)))) (+ (+ (+ (/ 1.0 (fabs x)) (* (/ 1.0 2.0) (* (* (/ 1.0 (fabs x)) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))))) (* (/ 3.0 4.0) (* (* (* (* (/ 1.0 (fabs x)) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))))) (* (/ 15.0 8.0) (* (* (* (* (* (* (/ 1.0 (fabs x)) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))) (/ 1.0 (fabs x))) (/ 1.0 (fabs x)))))))