


Bits error versus x
Initial program 58.3
Initial simplification50.3
rmApplied sub-neg50.3
Applied log1p-def0.0
Final simplification0.0
herbie shell --seed 2018365 +o rules:numerics
(FPCore (x)
:name "Hyperbolic arc-(co)tangent"
(* (/ 1 2) (log (/ (+ 1 x) (- 1 x)))))
Time bar (total: 9.2s)Debug log
2 alts after pruning (2 fresh and 0 done)
Merged error: 50.0b
Found 2 expressions with local error:
| 7.8b | (log (- 1 x)) |
| 0.0b | (fma (log (- 1 x)) -1/2 (/ (log1p x) 2)) |
2 calls. Slowest were:
| 1.0ms | (log (- 1 x)) |
| 0.0ms | (fma (log (- 1 x)) -1/2 (/ (log1p x) 2)) |
2 calls. Slowest were:
| 138.0ms | (fma (log (- 1 x)) -1/2 (/ (log1p x) 2)) |
| 34.0ms | (log (- 1 x)) |
14 calls. Slowest were:
| 349.0ms | (- (log -1) (+ (log (/ 1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
| 303.0ms | (- (+ x (+ (* 1/3 (pow x 3)) (* 1/2 (pow x 2))))) |
| 293.0ms | (- (+ (log (/ -1 x)) (+ (* 1/2 (/ 1 (pow x 2))) (/ 1 x)))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 0.0b | (fma (log1p (- x)) -1/2 (/ (log1p x) 2)) |
1 calls. Slowest were:
| 0.0ms | (fma (log1p (- x)) -1/2 (/ (log1p x) 2)) |
1 calls. Slowest were:
| 129.0ms | (fma (log1p (- x)) -1/2 (/ (log1p x) 2)) |
3 calls. Slowest were:
| 404.0ms | (+ x (+ (* 1/3 (pow x 3)) (* 1/5 (pow x 5)))) |
| 96.0ms | (- (+ (* 1/3 (/ 1 (pow x 3))) (/ 1 x)) (* 1/2 (log -1))) |
| 72.0ms | (+ (/ 1 x) (+ (* 1/3 (/ 1 (pow x 3))) (* 1/2 (log -1)))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0b
Found 3 expressions with local error:
| 0.1b | (* 1/3 (pow x 3)) |
| 0.1b | (* 1/5 (pow x 5)) |
| 0.0b | (+ (* 1/3 (pow x 3)) (* 1/5 (pow x 5))) |
3 calls. Slowest were:
| 11.0ms | (+ (* 1/3 (pow x 3)) (* 1/5 (pow x 5))) |
| 3.0ms | (* 1/3 (pow x 3)) |
| 2.0ms | (* 1/5 (pow x 5)) |
3 calls. Slowest were:
| 84.0ms | (+ (* 1/3 (pow x 3)) (* 1/5 (pow x 5))) |
| 34.0ms | (* 1/5 (pow x 5)) |
| 27.0ms | (* 1/3 (pow x 3)) |
17 calls. Slowest were:
| 33.0ms | (* (exp (* 1/3 (pow x 3))) (exp (* 1/5 (pow x 5)))) |
| 20.0ms | (+ (* 1/3 (pow x 3)) (* 1/5 (pow x 5))) |
| 20.0ms | (+ (* 1/3 (pow x 3)) (* 1/5 (pow x 5))) |
4 alts after pruning (1 fresh and 3 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.6b | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
| 0.6b | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
| 0.6b | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
| 0.5b | (* (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2)))) |
4 calls. Slowest were:
| 5.0ms | (* (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2)))) |
| 1.0ms | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
| 1.0ms | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
4 calls. Slowest were:
| 290.0ms | (* (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2)))) |
| 225.0ms | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
| 223.0ms | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
| 208.0ms | (cbrt (fma (log1p (- x)) -1/2 (/ (log1p x) 2))) |
41 calls. Slowest were:
| 311.0ms | (- (+ (* 2/3 (* (/ 1 x) (pow (/ 1/2 (pow (log -1) 2)) 1/3))) (pow (* 1/2 (log -1)) 1/3)) (* 4/9 (* (/ 1 (pow x 2)) (pow (/ 1/2 (pow (log -1) 5)) 1/3)))) |
| 307.0ms | (- (pow (* 1/4 (pow (log -1) 2)) 1/3) (+ (* 4/9 (* (pow (/ 1/4 (pow (log -1) 4)) 1/3) (/ 1 (pow x 2)))) (* 4/3 (* (pow (/ 1/4 (log -1)) 1/3) (/ 1 x))))) |
| 281.0ms | (- (+ (* 4/3 (* (pow (/ 1/4 (log -1)) 1/3) (/ 1 x))) (pow (* 1/4 (pow (log -1) 2)) 1/3)) (* 4/9 (* (pow (/ 1/4 (pow (log -1) 4)) 1/3) (/ 1 (pow x 2))))) |
4 alts after pruning (0 fresh and 4 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.0b against oracle of 0.0b and baseline of 0.0b