



Bits error versus a




Bits error versus x
Results
| Original | 29.7 |
|---|---|
| Target | 0.2 |
| Herbie | 0.0 |
Initial program 29.7
Simplified0.0
Final simplification0.0
herbie shell --seed 2019022 +o rules:numerics
(FPCore (a x)
:name "expax (section 3.5)"
:herbie-target
(if (< (fabs (* a x)) 1/10) (* (* a x) (+ 1 (+ (/ (* a x) 2) (/ (pow (* a x) 2) 6)))) (- (exp (* a x)) 1))
(- (exp (* a x)) 1))
Time bar (total: 2.6s)Debug log
| 39.0ms | 84× | body | 1280 | valid |
| 15.0ms | 175× | body | 80 | valid |
| 13.0ms | 43× | body | 640 | valid |
| 5.0ms | 24× | body | 320 | valid |
| 2.0ms | 17× | body | 160 | valid |
| 6.0ms | (- (exp (* a x)) 1) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 0.0b | (expm1 (* a x)) |
| 2× | log1p-expm1-u |
| 1× | add-log-exp |
| 1× | expm1-udef |
| 1× | add-cube-cbrt |
| 1× | add-exp-log |
| 1× | add-cbrt-cube |
| 1× | *-un-lft-identity |
| 1× | expm1-log1p |
| 1× | pow1 |
| 1× | expm1-log1p-u |
| 1× | add-sqr-sqrt |
| 1.0ms | (expm1 (* a x)) |
| 40.0ms | (expm1 (* a x)) |
| 168.0ms | (+ (* 1/2 (* (pow a 2) (pow x 2))) (+ (* a x) (* 1/6 (* (pow a 3) (pow x 3))))) |
| 3.0ms | (- (exp (* a x)) 1) |
| 3.0ms | (- (exp (* a x)) 1) |
| 2.0ms | (* a x) |
1 alts after pruning (0 fresh and 1 done)
Merged error: 0.0b
| 987.0ms | 2682× | body | 1280 | valid |
| 411.0ms | 1330× | body | 640 | valid |
| 276.0ms | 5460× | body | 80 | valid |
| 191.0ms | 760× | body | 320 | valid |
| 96.0ms | 431× | body | 160 | valid |