



Bits error versus x
Results
| Original | 61.0 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
Initial program 61.0
Taylor expanded around 0 0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019002
(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: 19.9s)Debug log
1 calls. Slowest were:
| 7.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 61.0b
Found 3 expressions with local error:
| 6.4b | (log (+ 1 x)) |
| 6.4b | (log (- 1 x)) |
| 0.0b | (/ (log (- 1 x)) (log (+ 1 x))) |
3 calls. Slowest were:
| 28.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 1.0ms | (log (+ 1 x)) |
| 1.0ms | (log (- 1 x)) |
3 calls. Slowest were:
| 96.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 38.0ms | (log (+ 1 x)) |
| 35.0ms | (log (- 1 x)) |
63 calls. Slowest were:
| 219.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 188.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 167.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))))))))))) |
4 alts after pruning (4 fresh and 0 done)
Merged error: 0b
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:
| 202.0ms | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
| 104.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
| 101.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 6.4b | (log (+ 1 x)) |
| 6.4b | (log (+ 1 x)) |
| 3.4b | (log (- 1 (* x x))) |
| 0.0b | (/ (- (log (- 1 (* x x))) (log (+ 1 x))) (log (+ 1 x))) |
4 calls. Slowest were:
| 26.0ms | (/ (- (log (- 1 (* x x))) (log (+ 1 x))) (log (+ 1 x))) |
| 1.0ms | (log (+ 1 x)) |
| 1.0ms | (log (+ 1 x)) |
4 calls. Slowest were:
| 90.0ms | (/ (- (log (- 1 (* x x))) (log (+ 1 x))) (log (+ 1 x))) |
| 83.0ms | (log (- 1 (* x x))) |
| 38.0ms | (log (+ 1 x)) |
| 26.0ms | (log (+ 1 x)) |
106 calls. Slowest were:
| 374.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 286.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 208.0ms | (- (log -1) (+ (* 2 (log (/ 1 x))) (+ (* 1/2 (/ 1 (pow x 4))) (/ 1 (pow x 2))))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0b
Found 4 expressions with local error:
| 6.4b | (log (+ 1 x)) |
| 6.4b | (log (- 1 x)) |
| 0.0b | (/ 1 (/ (log (+ 1 x)) (log (- 1 x)))) |
| 0.0b | (/ (log (+ 1 x)) (log (- 1 x))) |
4 calls. Slowest were:
| 5.0ms | (/ (log (+ 1 x)) (log (- 1 x))) |
| 2.0ms | (/ 1 (/ (log (+ 1 x)) (log (- 1 x)))) |
| 1.0ms | (log (+ 1 x)) |
4 calls. Slowest were:
| 85.0ms | (/ 1 (/ (log (+ 1 x)) (log (- 1 x)))) |
| 71.0ms | (/ (log (+ 1 x)) (log (- 1 x))) |
| 36.0ms | (log (+ 1 x)) |
| 29.0ms | (log (- 1 x)) |
88 calls. Slowest were:
| 280.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 274.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 263.0ms | (- (+ (log (/ -1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0b
0% (0.3b remaining)
Error of 0.4b against oracle of 0.0b and baseline of 0.4b