



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 2019008
(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: 21.3s)Debug log
1 calls. Slowest were:
| 10.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 61.5b
Found 3 expressions with local error:
| 5.5b | (log (- 1 x)) |
| 5.4b | (log (+ 1 x)) |
| 0.0b | (/ (log (- 1 x)) (log (+ 1 x))) |
3 calls. Slowest were:
| 9.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 2.0ms | (log (- 1 x)) |
| 1.0ms | (log (+ 1 x)) |
3 calls. Slowest were:
| 83.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
| 48.0ms | (log (+ 1 x)) |
| 37.0ms | (log (- 1 x)) |
63 calls. Slowest were:
| 374.0ms | (- (+ (/ 1 x) (log -1)) (+ (log (/ -1 x)) (* 1/2 (/ 1 (pow x 2))))) |
| 267.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 217.0ms | (- (+ (log (/ -1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
2 alts after pruning (2 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:
| 4.0ms | (- (- -1 x) (* x (* x 1/2))) |
1 calls. Slowest were:
| 10.0ms | (- (- -1 x) (* x (* x 1/2))) |
4 calls. Slowest were:
| 137.0ms | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
| 99.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
| 88.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.0b
Found 3 expressions with local error:
| 0.0b | (log (/ (exp (- -1 x)) (exp (* x (* x 1/2))))) |
| 0.0b | (exp (- -1 x)) |
| 0.0b | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
3 calls. Slowest were:
| 6.0ms | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
| 3.0ms | (log (/ (exp (- -1 x)) (exp (* x (* x 1/2))))) |
| 1.0ms | (exp (- -1 x)) |
3 calls. Slowest were:
| 70.0ms | (log (/ (exp (- -1 x)) (exp (* x (* x 1/2))))) |
| 45.0ms | (/ (exp (- -1 x)) (exp (* x (* x 1/2)))) |
| 15.0ms | (exp (- -1 x)) |
78 calls. Slowest were:
| 396.0ms | (log (/ (exp (- (+ x 1))) (exp (* 1/2 (pow x 2))))) |
| 370.0ms | (/ (* (* (exp (- -1 x)) (exp (- -1 x))) (exp (- -1 x))) (* (* (exp (* x (* x 1/2))) (exp (* x (* x 1/2)))) (exp (* x (* x 1/2))))) |
| 349.0ms | (- (+ (* 1/3 (* (pow x 3) (exp -1))) (exp -1)) (* x (exp -1))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.0b
Found 3 expressions with local error:
| 0.0b | (log (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x)))) |
| 0.0b | (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x))) |
| 0.0b | (* (exp (* x (* x 1/2))) (exp x)) |
3 calls. Slowest were:
| 12.0ms | (* (exp (* x (* x 1/2))) (exp x)) |
| 11.0ms | (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x))) |
| 5.0ms | (log (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x)))) |
3 calls. Slowest were:
| 156.0ms | (log (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x)))) |
| 129.0ms | (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x))) |
| 21.0ms | (* (exp (* x (* x 1/2))) (exp x)) |
42 calls. Slowest were:
| 346.0ms | (- (+ (* 1/3 (* (pow x 3) (exp -1))) (exp -1)) (* x (exp -1))) |
| 117.0ms | (/ (exp -1) (* (exp (* x (* x 1/2))) (exp x))) |
| 112.0ms | (- -1 (log (* (exp (* x (* x 1/2))) (exp x)))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.0b
0% (0.3b remaining)
Error of 0.4b against oracle of 0.1b and baseline of 0.4b