



Bits error versus x
Results
| Original | 58.6 |
|---|---|
| Target | 0.5 |
| Herbie | 0.5 |
Initial program 58.6
Initial simplification58.6
Taylor expanded around 0 0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2018362
(FPCore (x)
:name "expm1 (example 3.7)"
:pre (< -0.00017 x)
:herbie-target
(* x (+ (+ 1 (/ x 2)) (/ (* x x) 6)))
(- (exp x) 1))
Time bar (total: 13.7s)Debug log
1 alts after pruning (1 fresh and 0 done)
Merged error: 58.7b
Found 1 expressions with local error:
| 7.3b | (- (exp x) 1) |
1 calls. Slowest were:
| 3.0ms | (- (exp x) 1) |
1 calls. Slowest were:
| 21.0ms | (- (exp x) 1) |
4 calls. Slowest were:
| 130.0ms | (+ x (+ (* 1/6 (pow x 3)) (* 1/2 (pow x 2)))) |
| 3.0ms | (- (exp x) 1) |
| 3.0ms | (- (exp x) 1) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.1b
Found 2 expressions with local error:
| 0.4b | (* x 1/6) |
| 0.0b | (* (+ (* x 1/6) 1/2) (* x x)) |
2 calls. Slowest were:
| 5.0ms | (* (+ (* x 1/6) 1/2) (* x x)) |
| 0.0ms | (* x 1/6) |
2 calls. Slowest were:
| 27.0ms | (* (+ (* x 1/6) 1/2) (* x x)) |
| 7.0ms | (* x 1/6) |
13 calls. Slowest were:
| 468.0ms | (* (- (* (* x 1/6) (* x 1/6)) (* 1/2 1/2)) (* x x)) |
| 412.0ms | (* (+ (pow (* x 1/6) 3) (pow 1/2 3)) (* x x)) |
| 126.0ms | (* (* (* (+ (* x 1/6) 1/2) (+ (* x 1/6) 1/2)) (+ (* x 1/6) 1/2)) (* (* (* x x) (* x x)) (* x x))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0.1b
Found 4 expressions with local error:
| 7.2b | (- (pow (exp x) 3) (pow 1 3)) |
| 0.0b | (* (exp x) (exp x)) |
| 0.0b | (pow (exp x) 3) |
| 0.0b | (+ (* 1 1) (* (exp x) 1)) |
4 calls. Slowest were:
| 13.0ms | (- (pow (exp x) 3) (pow 1 3)) |
| 7.0ms | (* (exp x) (exp x)) |
| 5.0ms | (+ (* 1 1) (* (exp x) 1)) |
4 calls. Slowest were:
| 32.0ms | (- (pow (exp x) 3) (pow 1 3)) |
| 15.0ms | (pow (exp x) 3) |
| 11.0ms | (+ (* 1 1) (* (exp x) 1)) |
| 10.0ms | (* (exp x) (exp x)) |
45 calls. Slowest were:
| 331.0ms | (+ (* 3 x) (+ (* 9/2 (pow x 3)) (* 9/2 (pow x 2)))) |
| 69.0ms | (+ (* 2 x) (+ (* 2 (pow x 2)) 1)) |
| 65.0ms | (* (* (* (exp x) (exp x)) (exp x)) (* (* (exp x) (exp x)) (exp x))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 7.1b | (- (pow (pow (exp x) 3) 3) (pow (pow 1 3) 3)) |
| 0.0b | (* (exp x) (exp x)) |
| 0.0b | (pow (pow (exp x) 3) 3) |
| 0.0b | (* (pow (exp x) 3) (pow (exp x) 3)) |
4 calls. Slowest were:
| 27.0ms | (- (pow (pow (exp x) 3) 3) (pow (pow 1 3) 3)) |
| 5.0ms | (* (exp x) (exp x)) |
| 5.0ms | (* (pow (exp x) 3) (pow (exp x) 3)) |
4 calls. Slowest were:
| 41.0ms | (- (pow (pow (exp x) 3) 3) (pow (pow 1 3) 3)) |
| 35.0ms | (pow (pow (exp x) 3) 3) |
| 18.0ms | (* (pow (exp x) 3) (pow (exp x) 3)) |
| 15.0ms | (* (exp x) (exp x)) |
150 calls. Slowest were:
| 901.0ms | (pow (pow (* (cbrt (exp x)) (cbrt (exp x))) 3) 3) |
| 565.0ms | (* (* (* (pow (exp x) 3) (pow (exp x) 3)) (pow (exp x) 3)) (* (* (pow (exp x) 3) (pow (exp x) 3)) (pow (exp x) 3))) |
| 460.0ms | (pow (pow (* (cbrt (exp x)) (cbrt (exp x))) 3) 3) |
4 alts after pruning (1 fresh and 3 done)
Merged error: 0.0b
0% (0.4b remaining)
Error of 0.5b against oracle of 0.0b and baseline of 0.5b