


Bits error versus x
Results
Initial program 58.0
rmApplied tanh-undef0.0
Final simplification0.0
herbie shell --seed 2019005
(FPCore (x)
:name "Hyperbolic tangent"
(/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))))
Time bar (total: 18.6s)Debug log
1 calls. Slowest were:
| 23.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 57.6b
Found 3 expressions with local error:
| 6.5b | (- (exp x) (exp (- x))) |
| 1.5b | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 0.0b | (+ (exp x) (exp (- x))) |
3 calls. Slowest were:
| 27.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 10.0ms | (+ (exp x) (exp (- x))) |
| 7.0ms | (- (exp x) (exp (- x))) |
3 calls. Slowest were:
| 115.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 40.0ms | (- (exp x) (exp (- x))) |
| 24.0ms | (+ (exp x) (exp (- x))) |
69 calls. Slowest were:
| 490.0ms | (/ (* (* (- (exp x) (exp (- x))) (- (exp x) (exp (- x)))) (- (exp x) (exp (- x)))) (* (* (+ (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) (+ (exp x) (exp (- x))))) |
| 230.0ms | (- (* (exp x) (exp x)) (* (exp (- x)) (exp (- x)))) |
| 155.0ms | (+ (* (exp x) (exp x)) (- (* (exp (- x)) (exp (- x))) (* (exp x) (exp (- x))))) |
4 alts after pruning (4 fresh and 0 done)
Merged error: 0b
Found 1 expressions with local error:
| 0.0b | (tanh x) |
1 calls. Slowest were:
| 0.0ms | (tanh x) |
1 calls. Slowest were:
| 72.0ms | (tanh x) |
3 calls. Slowest were:
| 58.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 26.0ms | (/ (- (exp x) (exp (* -1 x))) (+ (exp (* -1 x)) (exp x))) |
| 19.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.2b | (* 1/3 (pow x 3)) |
| 0.1b | (* 1/60 (pow x 5)) |
| 0.0b | (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))) |
| 0.0b | (/ (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) (+ (exp x) (exp (- x)))) |
4 calls. Slowest were:
| 35.0ms | (/ (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) (+ (exp x) (exp (- x)))) |
| 6.0ms | (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))) |
| 2.0ms | (* 1/3 (pow x 3)) |
4 calls. Slowest were:
| 86.0ms | (/ (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) (+ (exp x) (exp (- x)))) |
| 83.0ms | (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))) |
| 21.0ms | (* 1/60 (pow x 5)) |
| 16.0ms | (* 1/3 (pow x 3)) |
56 calls. Slowest were:
| 266.0ms | (- (* (* 2 x) (* 2 x)) (* (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))))) |
| 185.0ms | (/ (* (* (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))))) (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))))) (* (* (+ (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) (+ (exp x) (exp (- x))))) |
| 146.0ms | (+ (pow (* 2 x) 3) (pow (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5))) 3)) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.2b | (* 1/3 (pow x 3)) |
| 0.1b | (* 2/15 (pow x 5)) |
| 0.0b | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 0.0b | (+ x (* 2/15 (pow x 5))) |
4 calls. Slowest were:
| 4.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 1.0ms | (* 1/3 (pow x 3)) |
| 1.0ms | (* 2/15 (pow x 5)) |
4 calls. Slowest were:
| 67.0ms | (+ x (* 2/15 (pow x 5))) |
| 27.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 27.0ms | (* 2/15 (pow x 5)) |
| 16.0ms | (* 1/3 (pow x 3)) |
20 calls. Slowest were:
| 165.0ms | (/ (exp (+ x (* 2/15 (pow x 5)))) (exp (* 1/3 (pow x 3)))) |
| 73.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 54.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
4 alts after pruning (1 fresh and 3 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.0b against oracle of 0.0b and baseline of 0.0b