


Bits error versus x
Results
Initial program 0.2
Taylor expanded around 0 0.2
Final simplification0.2
herbie shell --seed 2019008 +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)))))))
Time bar (total: 54.2s)Debug log
1 calls. Slowest were:
| 695.0ms | (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)))))) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.1b
Found 4 expressions with local error:
| 1.0b | (sqrt PI) |
| 0.2b | (* (/ 2 3) (* (* (fabs x) (fabs x)) (fabs x))) |
| 0.1b | (* (/ 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))))) |
| 0.1b | (* (/ 1 5) (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (fabs x))) |
4 calls. Slowest were:
| 1.4s | (* (/ 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))))) |
| 200.0ms | (* (/ 1 5) (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (fabs x))) |
| 37.0ms | (* (/ 2 3) (* (* (fabs x) (fabs x)) (fabs x))) |
4 calls. Slowest were:
| 249.0ms | (* (/ 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))))) |
| 49.0ms | (* (/ 1 5) (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (fabs x))) |
| 29.0ms | (* (/ 2 3) (* (* (fabs x) (fabs x)) (fabs x))) |
| 0.0ms | (sqrt PI) |
72 calls. Slowest were:
| 1.0s | (* (* (* (/ 1 (sqrt PI)) (/ 1 (sqrt PI))) (/ 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)))) (+ (+ (+ (* 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))))) (+ (+ (+ (* 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)))))) |
| 947.0ms | (* (* (* (/ 1 5) (/ 1 5)) (/ 1 5)) (* (* (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x))) (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x))) (* (* (fabs x) (fabs x)) (fabs x)))) |
| 857.0ms | (* (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)))) (+ (+ (* 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))) (* (/ 1 21) (* (* (* (* (* (* (fabs x) (fabs x)) (fabs x)) (fabs x)) (fabs x)) (fabs x)) (fabs x)))) (* (+ (+ (* 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))))))) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.2b | (* 2/3 (pow (fabs x) 3)) |
| 0.1b | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7)))))) |
| 0.1b | (* 1/5 (pow (fabs x) 5)) |
| 0.1b | (* 1/21 (pow (fabs x) 7)) |
4 calls. Slowest were:
| 46.0ms | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7)))))) |
| 5.0ms | (* 2/3 (pow (fabs x) 3)) |
| 4.0ms | (* 1/5 (pow (fabs x) 5)) |
4 calls. Slowest were:
| 243.0ms | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7)))))) |
| 44.0ms | (* 1/5 (pow (fabs x) 5)) |
| 42.0ms | (* 1/21 (pow (fabs x) 7)) |
| 34.0ms | (* 2/3 (pow (fabs x) 3)) |
56 calls. Slowest were:
| 523.0ms | (* (* (* (sqrt (/ 1 PI)) (sqrt (/ 1 PI))) (sqrt (/ 1 PI))) (* (* (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7))))) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7)))))) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7))))))) |
| 471.0ms | (* (sqrt PI) (- (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7)))))) |
| 347.0ms | (* (sqrt (/ 1 PI)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7))))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0b
Found 4 expressions with local error:
| 7.8b | (sqrt (* 1/21 (pow (fabs x) 7))) |
| 7.8b | (sqrt (* 1/21 (pow (fabs x) 7))) |
| 0.2b | (* 2/3 (pow (fabs x) 3)) |
| 0.1b | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7)))))))) |
4 calls. Slowest were:
| 72.0ms | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7)))))))) |
| 2.0ms | (* 2/3 (pow (fabs x) 3)) |
| 1.0ms | (sqrt (* 1/21 (pow (fabs x) 7))) |
4 calls. Slowest were:
| 326.0ms | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7)))))))) |
| 90.0ms | (sqrt (* 1/21 (pow (fabs x) 7))) |
| 88.0ms | (sqrt (* 1/21 (pow (fabs x) 7))) |
| 21.0ms | (* 2/3 (pow (fabs x) 3)) |
46 calls. Slowest were:
| 548.0ms | (* (* (* (sqrt (/ 1 PI)) (sqrt (/ 1 PI))) (sqrt (/ 1 PI))) (* (* (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7))))))) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7)))))))) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7))))))))) |
| 333.0ms | (- (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7))))))) |
| 292.0ms | (* (sqrt 1) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* (sqrt (* 1/21 (pow (fabs x) 7))) (sqrt (* 1/21 (pow (fabs x) 7)))))))) |
4 alts after pruning (1 fresh and 3 done)
Merged error: 0b
Found 4 expressions with local error:
| 1.0b | (sqrt PI) |
| 0.3b | (* (fabs x) 1/21) |
| 0.3b | (* 1/5 (fabs x)) |
| 0.3b | (/ (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x))))) (sqrt PI)) |
4 calls. Slowest were:
| 6.0ms | (/ (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x))))) (sqrt PI)) |
| 5.0ms | (* (fabs x) 1/21) |
| 2.0ms | (* 1/5 (fabs x)) |
4 calls. Slowest were:
| 212.0ms | (/ (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x))))) (sqrt PI)) |
| 9.0ms | (* (fabs x) 1/21) |
| 8.0ms | (* 1/5 (fabs x)) |
| 0.0ms | (sqrt PI) |
40 calls. Slowest were:
| 564.0ms | (* (sqrt (/ 1 PI)) (+ (* 1/5 (pow (fabs x) 5)) (+ (* 2 (fabs x)) (+ (* 2/3 (pow (fabs x) 3)) (* 1/21 (pow (fabs x) 7)))))) |
| 507.0ms | (/ (* (* (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x))))) (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x)))))) (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x)))))) (* (* (sqrt PI) (sqrt PI)) (sqrt PI))) |
| 382.0ms | (/ (* (cbrt (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x)))))) (cbrt (fma (fabs x) (fma 2/3 (* (fabs x) (fabs x)) 2) (fma (* (* (fabs x) 1/21) (pow (fabs x) 4)) (* (fabs x) (fabs x)) (* (pow (fabs x) 4) (* 1/5 (fabs x))))))) 1) |
4 alts after pruning (0 fresh and 4 done)
Merged error: 0b
0% (0.1b remaining)
Error of 0.2b against oracle of 0.0b and baseline of 0.2b