



Bits error versus x
Results
| Original | 40.2 |
|---|---|
| Target | 39.8 |
| Herbie | 0.8 |
if (/ (exp x) (- (exp x) 1)) < 131.21553089214348Initial program 1.2
rmApplied add-cube-cbrt1.2
if 131.21553089214348 < (/ (exp x) (- (exp x) 1)) Initial program 61.3
Taylor expanded around 0 0.6
Final simplification0.8
herbie shell --seed 2019018
(FPCore (x)
:name "expq2 (section 3.11)"
:herbie-target
(/ 1 (- 1 (exp (- x))))
(/ (exp x) (- (exp x) 1)))
Time bar (total: 16.6s)Debug log
| 20.0ms | 70× | body | 1280 | valid |
| 18.0ms | 84× | body | 10240 | exit |
| 9.0ms | 47× | body | 640 | valid |
| 4.0ms | 30× | body | 320 | valid |
| 3.0ms | 93× | body | 80 | valid |
| 1.0ms | 16× | body | 160 | valid |
| 4.0ms | (/ (exp x) (- (exp x) 1)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 39.6b
Found 2 expressions with local error:
| 4.3b | (- (exp x) 1) |
| 0.3b | (/ (exp x) (- (exp x) 1)) |
| 16× | add-sqr-sqrt |
| 12× | times-frac |
| 11× | add-cube-cbrt |
| 11× | *-un-lft-identity |
| 5× | difference-of-sqr-1 |
| 4× | add-cbrt-cube |
| 4× | associate-/r* |
| 3× | associate-/l* |
| 3× | add-exp-log |
| 2× | add-log-exp |
| 2× | flip-- |
| 2× | associate-/r/ |
| 2× | flip3-- |
| 2× | pow1 |
| 1× | div-inv |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | sub-neg |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 10.0ms | (/ (exp x) (- (exp x) 1)) |
| 5.0ms | (- (exp x) 1) |
| 21.0ms | (/ (exp x) (- (exp x) 1)) |
| 16.0ms | (- (exp x) 1) |
| 552.0ms | (/ (* (* (exp x) (exp x)) (exp x)) (* (* (- (exp x) 1) (- (exp x) 1)) (- (exp x) 1))) |
| 106.0ms | (+ x (+ (* 1/6 (pow x 3)) (* 1/2 (pow x 2)))) |
| 55.0ms | (+ (* (exp x) (exp x)) (+ (* 1 1) (* (exp x) 1))) |
| 33.0ms | (/ (* (cbrt (exp x)) (cbrt (exp x))) (* (cbrt (- (exp x) 1)) (cbrt (- (exp x) 1)))) |
| 14.0ms | (/ (* (cbrt (exp x)) (cbrt (exp x))) (+ (sqrt (exp x)) 1)) |
5 alts after pruning (5 fresh and 0 done)
Merged error: 0.3b
Found 2 expressions with local error:
| 0.3b | (* 1/12 x) |
| 0.0b | (+ (* 1/12 x) (+ (/ 1 x) 1/2)) |
| 4× | add-log-exp |
| 2× | add-cube-cbrt |
| 2× | add-exp-log |
| 2× | add-cbrt-cube |
| 2× | *-un-lft-identity |
| 2× | pow1 |
| 2× | add-sqr-sqrt |
| 1× | flip-+ |
| 1× | *-commutative |
| 1× | flip3-+ |
| 1× | sum-log |
| 1× | associate-+r+ |
| 1× | +-commutative |
| 13.0ms | (+ (* 1/12 x) (+ (/ 1 x) 1/2)) |
| 0.0ms | (* 1/12 x) |
| 12.0ms | (+ (* 1/12 x) (+ (/ 1 x) 1/2)) |
| 12.0ms | (* 1/12 x) |
| 41.0ms | (* (exp (* 1/12 x)) (exp (+ (/ 1 x) 1/2))) |
| 16.0ms | (+ (* 1/12 x) (+ (/ 1 x) 1/2)) |
| 8.0ms | (+ (* 1/12 x) (+ (/ 1 x) 1/2)) |
| 8.0ms | (+ (* 1/12 x) (+ (/ 1 x) 1/2)) |
| 1.0ms | (* 1/12 x) |
6 alts after pruning (5 fresh and 1 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 0.6b | (* (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2)))) |
| 0.5b | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 0.5b | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 0.5b | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 18× | cbrt-div |
| 15× | cbrt-prod |
| 11× | add-cube-cbrt |
| 11× | *-un-lft-identity |
| 11× | add-sqr-sqrt |
| 9× | flip-+ |
| 9× | flip3-+ |
| 9× | pow1 |
| 7× | pow1/3 |
| 6× | add-exp-log |
| 6× | associate-*l* |
| 6× | associate-*r* |
| 4× | add-log-exp |
| 4× | add-cbrt-cube |
| 4× | frac-times |
| 2× | pow-prod-up |
| 2× | associate-*r/ |
| 2× | associate-*l/ |
| 2× | pow-prod-down |
| 1× | cbrt-unprod |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | pow-plus |
| 1× | pow2 |
| 48.0ms | (* (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2)))) |
| 10.0ms | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 9.0ms | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 9.0ms | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 85.0ms | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 77.0ms | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 76.0ms | (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) |
| 53.0ms | (* (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2))) (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2)))) |
| 501.0ms | (* (cbrt (- (* 1/12 x) (+ (/ 1 x) 1/2))) (cbrt (+ (* (* 1/12 x) (* 1/12 x)) (- (* (+ (/ 1 x) 1/2) (+ (/ 1 x) 1/2)) (* (* 1/12 x) (+ (/ 1 x) 1/2)))))) |
| 464.0ms | (* (cbrt (+ (* (* 1/12 x) (* 1/12 x)) (- (* (+ (/ 1 x) 1/2) (+ (/ 1 x) 1/2)) (* (* 1/12 x) (+ (/ 1 x) 1/2))))) (cbrt (+ (* (* 1/12 x) (* 1/12 x)) (- (* (+ (/ 1 x) 1/2) (+ (/ 1 x) 1/2)) (* (* 1/12 x) (+ (/ 1 x) 1/2)))))) |
| 461.0ms | (* (cbrt (+ (pow (* 1/12 x) 3) (pow (+ (/ 1 x) 1/2) 3))) (cbrt (+ (* 1/12 x) (+ (/ 1 x) 1/2)))) |
| 456.0ms | (* (cbrt (+ (* (* 1/12 x) (* 1/12 x)) (- (* (+ (/ 1 x) 1/2) (+ (/ 1 x) 1/2)) (* (* 1/12 x) (+ (/ 1 x) 1/2))))) (cbrt (- (* 1/12 x) (+ (/ 1 x) 1/2)))) |
| 450.0ms | (cbrt (+ (pow (* 1/12 x) 3) (pow (+ (/ 1 x) 1/2) 3))) |
6 alts after pruning (5 fresh and 1 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 4.3b | (- (exp x) 1) |
| 4.3b | (- (exp x) 1) |
| 4.3b | (- (exp x) 1) |
| 0.3b | (/ (exp x) (- (exp x) 1)) |
| 20× | add-sqr-sqrt |
| 13× | add-cube-cbrt |
| 13× | *-un-lft-identity |
| 12× | times-frac |
| 7× | difference-of-sqr-1 |
| 6× | add-cbrt-cube |
| 5× | add-exp-log |
| 4× | add-log-exp |
| 4× | flip-- |
| 4× | flip3-- |
| 4× | associate-/r* |
| 4× | pow1 |
| 3× | associate-/l* |
| 3× | sub-neg |
| 2× | associate-/r/ |
| 1× | div-inv |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 13.0ms | (/ (exp x) (- (exp x) 1)) |
| 6.0ms | (- (exp x) 1) |
| 5.0ms | (- (exp x) 1) |
| 5.0ms | (- (exp x) 1) |
| 21.0ms | (/ (exp x) (- (exp x) 1)) |
| 18.0ms | (- (exp x) 1) |
| 17.0ms | (- (exp x) 1) |
| 17.0ms | (- (exp x) 1) |
| 304.0ms | (/ (* (* (exp x) (exp x)) (exp x)) (* (* (- (exp x) 1) (- (exp x) 1)) (- (exp x) 1))) |
| 111.0ms | (+ x (+ (* 1/6 (pow x 3)) (* 1/2 (pow x 2)))) |
| 109.0ms | (+ x (+ (* 1/6 (pow x 3)) (* 1/2 (pow x 2)))) |
| 86.0ms | (+ x (+ (* 1/6 (pow x 3)) (* 1/2 (pow x 2)))) |
| 36.0ms | (+ (* (exp x) (exp x)) (+ (* 1 1) (* (exp x) 1))) |
6 alts after pruning (4 fresh and 2 done)
Merged error: 0.3b
98% (0.4b remaining)
Error of 0.8b against oracle of 0.4b and baseline of 21.3b
| 1.3s | 2457× | body | 10240 | exit |
| 951.0ms | 2290× | body | 1280 | valid |
| 513.0ms | 1652× | body | 640 | valid |
| 182.0ms | 2838× | body | 80 | valid |
| 173.0ms | 807× | body | 320 | valid |
| 67.0ms | 416× | body | 160 | valid |