


Bits error versus x
Results
Initial program 58.1
rmApplied tanh-undef0.0
Final simplification0.0
herbie shell --seed 2019007 +o rules:numerics
(FPCore (x)
:name "Hyperbolic tangent"
(/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))))
Time bar (total: 20.2s)Debug log
1 calls. Slowest were:
| 21.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 58.5b
Found 3 expressions with local error:
| 7.5b | (- (exp x) (exp (- x))) |
| 1.2b | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 0.0b | (+ (exp x) (exp (- x))) |
3 calls. Slowest were:
| 47.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 10.0ms | (- (exp x) (exp (- x))) |
| 5.0ms | (+ (exp x) (exp (- x))) |
3 calls. Slowest were:
| 97.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 42.0ms | (- (exp x) (exp (- x))) |
| 32.0ms | (+ (exp x) (exp (- x))) |
91 calls. Slowest were:
| 354.0ms | (- (* (exp x) (exp x)) (* (exp (- x)) (exp (- x)))) |
| 249.0ms | (+ (* (exp x) (exp x)) (- (* (exp (- x)) (exp (- x))) (* (exp x) (exp (- x))))) |
| 140.0ms | (- (pow (exp x) 3) (pow (exp (- x)) 3)) |
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:
| 86.0ms | (tanh x) |
3 calls. Slowest were:
| 107.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 51.0ms | (/ (- (exp x) (exp (* -1 x))) (+ (exp (* -1 x)) (exp x))) |
| 28.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0b
Found 3 expressions with local error:
| 0.1b | (* 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))) |
3 calls. Slowest were:
| 6.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 3.0ms | (* 1/3 (pow x 3)) |
| 2.0ms | (* 2/15 (pow x 5)) |
3 calls. Slowest were:
| 30.0ms | (* 2/15 (pow x 5)) |
| 23.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 15.0ms | (* 1/3 (pow x 3)) |
25 calls. Slowest were:
| 140.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 131.0ms | (/ (exp (+ x (* 2/15 (pow x 5)))) (exp (* 1/3 (pow x 3)))) |
| 124.0ms | (fma 1 (+ x (* 2/15 (pow x 5))) (- (* (pow x 3) 1/3))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0b
Found 3 expressions with local error:
| 7.5b | (- (exp (* 2 x)) 1) |
| 0.7b | (/ (- (exp (* 2 x)) 1) (+ (exp (* 2 x)) 1)) |
| 0.0b | (+ (exp (* 2 x)) 1) |
3 calls. Slowest were:
| 28.0ms | (/ (- (exp (* 2 x)) 1) (+ (exp (* 2 x)) 1)) |
| 11.0ms | (- (exp (* 2 x)) 1) |
| 8.0ms | (+ (exp (* 2 x)) 1) |
3 calls. Slowest were:
| 59.0ms | (/ (- (exp (* 2 x)) 1) (+ (exp (* 2 x)) 1)) |
| 16.0ms | (- (exp (* 2 x)) 1) |
| 8.0ms | (+ (exp (* 2 x)) 1) |
52 calls. Slowest were:
| 346.0ms | (/ (* (* (- (exp (* 2 x)) 1) (- (exp (* 2 x)) 1)) (- (exp (* 2 x)) 1)) (* (* (+ (exp (* 2 x)) 1) (+ (exp (* 2 x)) 1)) (+ (exp (* 2 x)) 1))) |
| 171.0ms | (+ (* 2 x) (+ (* 4/3 (pow x 3)) (* 2 (pow x 2)))) |
| 141.0ms | (- (* (exp (* 2 x)) (exp (* 2 x))) (* 1 1)) |
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