



Bits error versus x
Results
| Original | 60.7 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 60.7
Taylor expanded around 0 0.5
Simplified0.5
rmApplied add-cbrt-cube0.5
Final simplification0.5
herbie shell --seed 2019007
(FPCore (x)
:name "qlog (example 3.10)"
:pre (and (< -1 x) (< x 1))
:herbie-target
(- (+ (+ (+ 1 x) (/ (* x x) 2)) (* 5/12 (pow x 3))))
(/ (log (- 1 x)) (log (+ 1 x))))
Time bar (total: 43.8s)Debug log
1 calls. Slowest were:
| 9.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 60.7b
Found 3 expressions with local error:
| 7.9b | (log (- 1 x)) |
| 7.9b | (log (+ 1 x)) |
| 0.0b | (/ (log (- 1 x)) (log (+ 1 x))) |
3 calls. Slowest were:
| 5.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 1.0ms | (log (- 1 x)) |
| 1.0ms | (log (+ 1 x)) |
3 calls. Slowest were:
| 70.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 36.0ms | (log (- 1 x)) |
| 22.0ms | (log (+ 1 x)) |
63 calls. Slowest were:
| 296.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 273.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 197.0ms | (- (+ (/ (log (/ -1 x)) (* x (pow (- (log -1) (log (/ -1 x))) 2))) (/ 1 (* (pow x 2) (pow (- (log -1) (log (/ -1 x))) 2)))) (+ (/ (log (/ -1 x)) (- (log -1) (log (/ -1 x)))) (+ (/ (log (/ -1 x)) (* (pow x 2) (pow (- (log -1) (log (/ -1 x))) 3))) (+ (/ 1 (* x (- (log -1) (log (/ -1 x))))) (+ (* 1/2 (/ (log (/ -1 x)) (* (pow x 2) (pow (- (log -1) (log (/ -1 x))) 2)))) (* 1/2 (/ 1 (* (pow x 2) (- (log -1) (log (/ -1 x))))))))))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.1b
Found 1 expressions with local error:
| 0.0b | (- (- -1 x) (* x (* x 1/2))) |
1 calls. Slowest were:
| 4.0ms | (- (- -1 x) (* x (* x 1/2))) |
1 calls. Slowest were:
| 10.0ms | (- (- -1 x) (* x (* x 1/2))) |
4 calls. Slowest were:
| 119.0ms | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
| 87.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
| 78.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
6 alts after pruning (4 fresh and 2 done)
Merged error: 0.1b
Found 4 expressions with local error:
| 0.0b | (cbrt (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2))))) |
| 0.0b | (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) |
| 0.0b | (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2)))) |
| 0.0b | (- (- -1 x) (* x (* x 1/2))) |
4 calls. Slowest were:
| 66.0ms | (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2)))) |
| 44.0ms | (cbrt (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2))))) |
| 17.0ms | (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) |
4 calls. Slowest were:
| 36.0ms | (cbrt (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2))))) |
| 23.0ms | (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2)))) |
| 19.0ms | (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) |
| 15.0ms | (- (- -1 x) (* x (* x 1/2))) |
142 calls. Slowest were:
| 1.3s | (* (- (* x (* x 1/2))) (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2))))) |
| 1.2s | (* (- (* x (* x 1/2))) (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2))))) |
| 974.0ms | (* (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2)))) (* (* (- (- -1 x) (* x (* x 1/2))) (- (- -1 x) (* x (* x 1/2)))) (- (- -1 x) (* x (* x 1/2))))) |
6 alts after pruning (3 fresh and 3 done)
Merged error: 0.1b
Found 4 expressions with local error:
| 7.9b | (log (+ 1 x)) |
| 7.9b | (log (+ 1 x)) |
| 7.9b | (log (+ 1 x)) |
| 2.4b | (log (- 1 (* x x))) |
4 calls. Slowest were:
| 1.0ms | (log (- 1 (* x x))) |
| 1.0ms | (log (+ 1 x)) |
| 1.0ms | (log (+ 1 x)) |
4 calls. Slowest were:
| 108.0ms | (log (- 1 (* x x))) |
| 32.0ms | (log (+ 1 x)) |
| 26.0ms | (log (+ 1 x)) |
| 24.0ms | (log (+ 1 x)) |
36 calls. Slowest were:
| 328.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 309.0ms | (- (log -1) (+ (* 2 (log (/ 1 x))) (+ (* 1/2 (/ 1 (pow x 4))) (/ 1 (pow x 2))))) |
| 301.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
7 alts after pruning (4 fresh and 3 done)
Merged error: 0.0b
0% (0.5b remaining)
Error of 0.5b against oracle of 0.0b and baseline of 0.5b