



Bits error versus x
Results
| Original | 60.9 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
Initial program 60.9
Taylor expanded around 0 0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019005
(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.7s)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.6b
Found 3 expressions with local error:
| 6.8b | (log (+ 1 x)) |
| 6.5b | (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:
| 79.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 44.0ms | (log (+ 1 x)) |
| 25.0ms | (log (- 1 x)) |
63 calls. Slowest were:
| 274.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 250.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 190.0ms | (- (+ x (+ (* 1/3 (pow x 3)) (* 1/2 (pow x 2))))) |
5 alts after pruning (5 fresh and 0 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 0.0b | (- (- -1 x) (* x (* x 1/2))) |
1 calls. Slowest were:
| 5.0ms | (- (- -1 x) (* x (* x 1/2))) |
1 calls. Slowest were:
| 10.0ms | (- (- -1 x) (* x (* x 1/2))) |
4 calls. Slowest were:
| 124.0ms | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
| 86.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
| 69.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 6.8b | (log (+ 1 x)) |
| 6.5b | (log (- 1 x)) |
| 0.0b | (/ (log (+ 1 x)) (log (- 1 x))) |
| 0.0b | (/ 1 (/ (log (+ 1 x)) (log (- 1 x)))) |
4 calls. Slowest were:
| 13.0ms | (/ (log (+ 1 x)) (log (- 1 x))) |
| 4.0ms | (/ 1 (/ (log (+ 1 x)) (log (- 1 x)))) |
| 2.0ms | (log (+ 1 x)) |
4 calls. Slowest were:
| 102.0ms | (/ (log (+ 1 x)) (log (- 1 x))) |
| 82.0ms | (/ 1 (/ (log (+ 1 x)) (log (- 1 x)))) |
| 24.0ms | (log (+ 1 x)) |
| 23.0ms | (log (- 1 x)) |
88 calls. Slowest were:
| 336.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 237.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 201.0ms | (- (+ (log (/ -1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
5 alts after pruning (3 fresh and 2 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 6.8b | (log (+ 1 x)) |
| 6.8b | (log (+ 1 x)) |
| 6.8b | (log (+ 1 x)) |
| 6.5b | (log (- 1 x)) |
4 calls. Slowest were:
| 2.0ms | (log (+ 1 x)) |
| 2.0ms | (log (+ 1 x)) |
| 2.0ms | (log (+ 1 x)) |
4 calls. Slowest were:
| 42.0ms | (log (- 1 x)) |
| 37.0ms | (log (+ 1 x)) |
| 23.0ms | (log (+ 1 x)) |
| 23.0ms | (log (+ 1 x)) |
36 calls. Slowest were:
| 364.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 311.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 299.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
5 alts after pruning (2 fresh and 3 done)
Merged error: 0.0b
0% (0.4b remaining)
Error of 0.4b against oracle of 0.0b and baseline of 0.4b