



Bits error versus x
Results
| Original | 61.0 |
|---|---|
| Target | 0.3 |
| Herbie | 0.0 |
Initial program 61.0
Simplified60.1
rmApplied sub-neg60.1
Applied log1p-def0.0
Final simplification0.0
herbie shell --seed 2019008 +o rules:numerics
(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.3s)Debug log
1 calls. Slowest were:
| 5.0ms | (/ (log (- 1 x)) (log (+ 1 x))) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 59.9b
Found 2 expressions with local error:
| 5.5b | (log (- 1 x)) |
| 0.0b | (/ (log (- 1 x)) (log1p x)) |
2 calls. Slowest were:
| 13.0ms | (log (- 1 x)) |
| 6.0ms | (/ (log (- 1 x)) (log1p x)) |
2 calls. Slowest were:
| 85.0ms | (/ (log (- 1 x)) (log1p x)) |
| 27.0ms | (log (- 1 x)) |
47 calls. Slowest were:
| 336.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 305.0ms | (- (+ x (+ (* 1/3 (pow x 3)) (* 1/2 (pow x 2))))) |
| 252.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 | (/ (log1p (- x)) (log1p x)) |
1 calls. Slowest were:
| 5.0ms | (/ (log1p (- x)) (log1p x)) |
1 calls. Slowest were:
| 63.0ms | (/ (log1p (- x)) (log1p x)) |
28 calls. Slowest were:
| 247.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))))))))))) |
| 185.0ms | (- (+ x (+ (* 1/2 (pow x 2)) 1))) |
| 183.0ms | (- (+ (* 2 (/ 1 (* (pow (log (/ 1 x)) 2) (pow x 2)))) (+ (* 2 (/ 1 (* (log (/ 1 x)) x))) (+ (* 1/2 (/ (log -1) (* (pow (log (/ 1 x)) 2) (pow x 2)))) 1))) (+ (/ (log -1) (* (pow (log (/ 1 x)) 3) (pow x 2))) (+ (/ (log -1) (log (/ 1 x))) (/ (log -1) (* (pow (log (/ 1 x)) 2) x))))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.0b
Found 2 expressions with local error:
| 0.0b | (/ 1 (/ (log1p x) (log1p (- x)))) |
| 0.0b | (/ (log1p x) (log1p (- x))) |
2 calls. Slowest were:
| 3.0ms | (/ (log1p x) (log1p (- x))) |
| 2.0ms | (/ 1 (/ (log1p x) (log1p (- x)))) |
2 calls. Slowest were:
| 80.0ms | (/ (log1p x) (log1p (- x))) |
| 72.0ms | (/ 1 (/ (log1p x) (log1p (- x)))) |
46 calls. Slowest were:
| 202.0ms | (- (+ (* 1/2 (/ (log -1) (* (pow x 2) (pow (log (/ -1 x)) 2)))) (+ (* 2 (/ 1 (* (pow x 2) (pow (log (/ -1 x)) 2)))) (+ (/ (log -1) (* x (pow (log (/ -1 x)) 2))) 1))) (+ (/ (log -1) (* (pow x 2) (pow (log (/ -1 x)) 3))) (+ (/ (log -1) (log (/ -1 x))) (* 2 (/ 1 (* x (log (/ -1 x)))))))) |
| 193.0ms | (- (+ (* 2 (/ 1 (* (pow (log (/ 1 x)) 2) (pow x 2)))) (+ (* 2 (/ 1 (* (log (/ 1 x)) x))) (+ (* 1/2 (/ (log -1) (* (pow (log (/ 1 x)) 2) (pow x 2)))) 1))) (+ (/ (log -1) (* (pow (log (/ 1 x)) 3) (pow x 2))) (+ (/ (log -1) (log (/ 1 x))) (/ (log -1) (* (pow (log (/ 1 x)) 2) x))))) |
| 193.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))))))))))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0b
Found 3 expressions with local error:
| 0.0b | (/ 1 (log1p (- x))) |
| 0.0b | (/ 1 (log1p x)) |
| 0.0b | (/ (/ 1 (log1p x)) (/ 1 (log1p (- x)))) |
3 calls. Slowest were:
| 4.0ms | (/ (/ 1 (log1p x)) (/ 1 (log1p (- x)))) |
| 1.0ms | (/ 1 (log1p (- x))) |
| 1.0ms | (/ 1 (log1p x)) |
3 calls. Slowest were:
| 91.0ms | (/ (/ 1 (log1p x)) (/ 1 (log1p (- x)))) |
| 43.0ms | (/ 1 (log1p (- x))) |
| 32.0ms | (/ 1 (log1p x)) |
61 calls. Slowest were:
| 1.3s | (/ (* (* (/ 1 (log1p x)) (/ 1 (log1p x))) (/ 1 (log1p x))) (* (* (/ 1 (log1p (- x))) (/ 1 (log1p (- x)))) (/ 1 (log1p (- x))))) |
| 549.0ms | (- (+ (/ 1 (* (pow x 2) (pow (- (log -1) (log (/ -1 x))) 3))) (+ (/ 1 (- (log -1) (log (/ -1 x)))) (* 1/2 (/ 1 (* (pow x 2) (pow (- (log -1) (log (/ -1 x))) 2)))))) (/ 1 (* x (pow (- (log -1) (log (/ -1 x))) 2)))) |
| 283.0ms | (+ (/ 1 (- (log -1) (log (/ 1 x)))) (+ (/ 1 (* x (pow (- (log -1) (log (/ 1 x))) 2))) (+ (* 1/2 (/ 1 (* (pow x 2) (pow (- (log -1) (log (/ 1 x))) 2)))) (/ 1 (* (pow x 2) (pow (- (log -1) (log (/ 1 x))) 3)))))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.0b against oracle of 0.0b and baseline of 0.0b