


Bits error versus x
Initial program 57.8
Taylor expanded around 0 0.6
Simplified0.6
Final simplification0.6
herbie shell --seed 2019016 +o rules:numerics
(FPCore (x)
:name "Hyperbolic sine"
(/ (- (exp x) (exp (- x))) 2))
Time bar (total: 8.3s)Debug log
| 525× | (pre true 80) |
| 280× | (body real 80) |
| 105× | (body real 1280) |
| 82× | (body real 640) |
| 42× | (body real 320) |
| 16× | (body real 160) |
| 21.0ms | (/ (- (exp x) (exp (- x))) 2) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 57.7b
Found 1 expressions with local error:
| 6.1b | (- (exp x) (exp (- x))) |
| 10× | *-un-lft-identity |
| 10× | add-sqr-sqrt |
| 9× | prod-diff |
| 8× | add-cube-cbrt |
| 3× | add-log-exp |
| 3× | fma-neg |
| 1× | difference-of-squares |
| 1× | distribute-lft-out-- |
| 1× | flip-- |
| 1× | log1p-expm1-u |
| 1× | add-exp-log |
| 1× | diff-log |
| 1× | add-cbrt-cube |
| 1× | flip3-- |
| 1× | sub-neg |
| 1× | pow1 |
| 1× | expm1-log1p-u |
| 5.0ms | (- (exp x) (exp (- x))) |
| 52.0ms | (- (exp x) (exp (- x))) |
| 63.0ms | (fma 1 (exp x) (- (* (exp (- x)) 1))) |
| 58.0ms | (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) |
| 52.0ms | (fma 1 (exp x) (- (* (cbrt (exp (- x))) (* (cbrt (exp (- x))) (cbrt (exp (- x))))))) |
| 39.0ms | (fma 1 (exp x) (- (* (sqrt (exp (- x))) (sqrt (exp (- x)))))) |
| 39.0ms | (fma (- (cbrt (exp (- x)))) (* (cbrt (exp (- x))) (cbrt (exp (- x)))) (* (cbrt (exp (- x))) (* (cbrt (exp (- x))) (cbrt (exp (- x)))))) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.0b
Found 3 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)) |
| 0.0b | (fma 1/3 (* x x) 2) |
| 4× | add-cube-cbrt |
| 4× | *-un-lft-identity |
| 4× | add-sqr-sqrt |
| 3× | add-log-exp |
| 3× | log1p-expm1-u |
| 3× | add-exp-log |
| 3× | associate-*l* |
| 3× | add-cbrt-cube |
| 3× | pow1 |
| 3× | expm1-log1p-u |
| 2× | fma-udef |
| 1× | *-commutative |
| 2.0ms | (* (pow x 5) 1/60) |
| 0.0ms | (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) |
| 0.0ms | (fma 1/3 (* x x) 2) |
| 33.0ms | (fma 1/3 (* x x) 2) |
| 30.0ms | (* (pow x 5) 1/60) |
| 30.0ms | (fma (fma 1/3 (* x x) 2) x (* (pow x 5) 1/60)) |
| 86.0ms | (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) |
| 84.0ms | (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) |
| 84.0ms | (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) |
| 12.0ms | (+ (* 1/3 (pow x 2)) 2) |
| 12.0ms | (+ (* 1/3 (pow x 2)) 2) |
2 alts after pruning (1 fresh and 1 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 6.1b | (- (exp x) (exp (- x))) |
| 10× | *-un-lft-identity |
| 10× | add-sqr-sqrt |
| 9× | prod-diff |
| 8× | add-cube-cbrt |
| 3× | add-log-exp |
| 3× | fma-neg |
| 1× | difference-of-squares |
| 1× | distribute-lft-out-- |
| 1× | flip-- |
| 1× | log1p-expm1-u |
| 1× | add-exp-log |
| 1× | diff-log |
| 1× | add-cbrt-cube |
| 1× | flip3-- |
| 1× | sub-neg |
| 1× | pow1 |
| 1× | expm1-log1p-u |
| 7.0ms | (- (exp x) (exp (- x))) |
| 47.0ms | (- (exp x) (exp (- x))) |
| 70.0ms | (fma 1 (exp x) (- (* (exp (- x)) 1))) |
| 55.0ms | (+ (* 2 x) (+ (* 1/3 (pow x 3)) (* 1/60 (pow x 5)))) |
| 43.0ms | (fma (* (cbrt (exp x)) (cbrt (exp x))) (cbrt (exp x)) (- (* (exp (- x)) 1))) |
| 39.0ms | (fma (- (cbrt (exp (- x)))) (* (cbrt (exp (- x))) (cbrt (exp (- x)))) (* (cbrt (exp (- x))) (* (cbrt (exp (- x))) (cbrt (exp (- x)))))) |
| 38.0ms | (fma 1 (exp x) (- (* (sqrt (exp (- x))) (sqrt (exp (- x)))))) |
2 alts after pruning (0 fresh and 2 done)
Merged error: 0.0b
0% (0.6b remaining)
Error of 0.6b against oracle of 0.0b and baseline of 0.6b
| 15887× | (pre true 80) |
| 8172× | (body real 80) |
| 3343× | (body real 1280) |
| 2501× | (body real 640) |
| 1247× | (body real 320) |
| 624× | (body real 160) |