


Bits error versus x
Results
Initial program 58.0
rmApplied tanh-undef0.0
Final simplification0.0
herbie shell --seed 2019005 +o rules:numerics
(FPCore (x)
:name "Hyperbolic tangent"
(/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))))
Time bar (total: 20.9s)Debug log
1 calls. Slowest were:
| 28.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:
| 23.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 5.0ms | (- (exp x) (exp (- x))) |
| 4.0ms | (+ (exp x) (exp (- x))) |
3 calls. Slowest were:
| 87.0ms | (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))) |
| 57.0ms | (- (exp x) (exp (- x))) |
| 26.0ms | (+ (exp x) (exp (- x))) |
91 calls. Slowest were:
| 345.0ms | (- (* (exp x) (exp x)) (* (exp (- x)) (exp (- x)))) |
| 262.0ms | (+ (* (exp x) (exp x)) (- (* (exp (- x)) (exp (- x))) (* (exp x) (exp (- x))))) |
| 190.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:
| 100.0ms | (tanh x) |
3 calls. Slowest were:
| 128.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 46.0ms | (/ (- (exp x) (exp (* -1 x))) (+ (exp (* -1 x)) (exp x))) |
| 36.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.1b | (* (pow x 5) 1/60) |
| 0.0b | (/ (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) (+ (exp x) (exp (- x)))) |
| 0.0b | (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) |
| 0.0b | (fma 1/3 (* x x) 2) |
4 calls. Slowest were:
| 12.0ms | (/ (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) (+ (exp x) (exp (- x)))) |
| 3.0ms | (* (pow x 5) 1/60) |
| 0.0ms | (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) |
4 calls. Slowest were:
| 56.0ms | (/ (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) (+ (exp x) (exp (- x)))) |
| 37.0ms | (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) |
| 34.0ms | (fma 1/3 (* x x) 2) |
| 28.0ms | (* (pow x 5) 1/60) |
48 calls. Slowest were:
| 229.0ms | (+ (* (exp x) (exp x)) (- (* (exp (- x)) (exp (- x))) (* (exp x) (exp (- x))))) |
| 141.0ms | (+ (* 1/3 (/ (pow x 3) (+ (exp x) (exp (- x))))) (+ (* 2 (/ x (+ (exp x) (exp (- x))))) (* 1/60 (/ (pow x 5) (+ (exp x) (exp (- x))))))) |
| 135.0ms | (+ (* 1/3 (/ (pow x 3) (+ (exp (* -1 x)) (exp x)))) (+ (* 2 (/ x (+ (exp (* -1 x)) (exp x)))) (* 1/60 (/ (pow x 5) (+ (exp (* -1 x)) (exp x)))))) |
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:
| 5.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 1.0ms | (* 1/3 (pow x 3)) |
| 1.0ms | (+ x (* 2/15 (pow x 5))) |
4 calls. Slowest were:
| 73.0ms | (+ x (* 2/15 (pow x 5))) |
| 34.0ms | (* 2/15 (pow x 5)) |
| 32.0ms | (- (+ x (* 2/15 (pow x 5))) (* 1/3 (pow x 3))) |
| 20.0ms | (* 1/3 (pow x 3)) |
28 calls. Slowest were:
| 171.0ms | (fma 1 (+ x (* 2/15 (pow x 5))) (- (* (pow x 3) 1/3))) |
| 165.0ms | (/ (exp (+ x (* 2/15 (pow x 5)))) (exp (* 1/3 (pow x 3)))) |
| 120.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