


Bits error versus v
Initial program 0.5
Simplified0.5
rmApplied expm1-log1p-u0.5
rmApplied add-cbrt-cube0.5
Final simplification0.5
herbie shell --seed 2019022 +o rules:numerics
(FPCore (v)
:name "Falkner and Boettcher, Appendix B, 1"
(acos (/ (- 1 (* 5 (* v v))) (- (* v v) 1))))
Time bar (total: 26.8s)Debug log
| 78.0ms | 95× | body | 2560 | valid |
| 59.0ms | 89× | body | 1280 | valid |
| 22.0ms | 246× | body | 80 | nan |
| 16.0ms | 35× | body | 640 | valid |
| 7.0ms | 21× | body | 320 | valid |
| 2.0ms | 11× | body | 160 | valid |
| 1.0ms | 5× | body | 80 | valid |
| 573.0ms | (acos (/ (- 1 (* 5 (* v v))) (- (* v v) 1))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.3b
Found 2 expressions with local error:
| 0.3b | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 0.0b | (/ (fma (* -5 v) v 1) (fma v v -1)) |
| 10× | add-cube-cbrt |
| 10× | *-un-lft-identity |
| 10× | add-sqr-sqrt |
| 9× | times-frac |
| 4× | add-exp-log |
| 4× | add-cbrt-cube |
| 3× | associate-/l* |
| 3× | associate-/r* |
| 2× | add-log-exp |
| 2× | log1p-expm1-u |
| 2× | pow1 |
| 2× | expm1-log1p-u |
| 1× | div-inv |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 1× | acos-asin |
| 4.0ms | (/ (fma (* -5 v) v 1) (fma v v -1)) |
| 1.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 40.0ms | (/ (fma (* -5 v) v 1) (fma v v -1)) |
| 3.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 555.0ms | (- (+ (* 4 (/ 1 (pow v 4))) (+ 5 (* 4 (/ 1 (pow v 2)))))) |
| 544.0ms | (- (+ (* 4 (/ 1 (pow v 4))) (+ 5 (* 4 (/ 1 (pow v 2)))))) |
| 322.0ms | (/ (* (* (fma (* -5 v) v 1) (fma (* -5 v) v 1)) (fma (* -5 v) v 1)) (* (* (fma v v -1) (fma v v -1)) (fma v v -1))) |
| 94.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 88.0ms | (/ (sqrt (fma (* -5 v) v 1)) (sqrt (fma v v -1))) |
4 alts after pruning (4 fresh and 0 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 0.3b | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 0.0b | (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 0.0b | (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))) |
| 0.0b | (/ (fma (* -5 v) v 1) (fma v v -1)) |
| 12× | add-cube-cbrt |
| 12× | *-un-lft-identity |
| 12× | add-sqr-sqrt |
| 9× | times-frac |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 5× | expm1-log1p-u |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | pow1 |
| 3× | associate-/l* |
| 3× | associate-/r* |
| 1× | expm1-udef |
| 1× | div-inv |
| 1× | log1p-expm1 |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | expm1-log1p |
| 1× | log1p-udef |
| 1× | cbrt-undiv |
| 1× | acos-asin |
| 6.0ms | (/ (fma (* -5 v) v 1) (fma v v -1)) |
| 1.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 1.0ms | (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))) |
| 0.0ms | (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 169.0ms | (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 110.0ms | (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))) |
| 30.0ms | (/ (fma (* -5 v) v 1) (fma v v -1)) |
| 3.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 551.0ms | (- (+ (* 4 (/ 1 (pow v 4))) (+ 5 (* 4 (/ 1 (pow v 2)))))) |
| 539.0ms | (- (+ (* 4 (/ 1 (pow v 4))) (+ 5 (* 4 (/ 1 (pow v 2)))))) |
| 342.0ms | (/ (* (* (fma (* -5 v) v 1) (fma (* -5 v) v 1)) (fma (* -5 v) v 1)) (* (* (fma v v -1) (fma v v -1)) (fma v v -1))) |
| 97.0ms | (- (log (fma (* -5 v) v 1)) (log (fma v v -1))) |
| 95.0ms | (/ (* (cbrt (fma (* -5 v) v 1)) (cbrt (fma (* -5 v) v 1))) (sqrt (fma v v -1))) |
4 alts after pruning (4 fresh and 0 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 0.3b | (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 0.0b | (expm1 (log1p (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 0.0b | (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 0.0b | (log1p (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 18× | add-cube-cbrt |
| 18× | times-frac |
| 18× | *-un-lft-identity |
| 18× | add-sqr-sqrt |
| 16× | add-exp-log |
| 16× | add-cbrt-cube |
| 13× | associate-*l* |
| 13× | associate-*r* |
| 9× | pow1 |
| 5× | expm1-log1p-u |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | cbrt-unprod |
| 4× | prod-exp |
| 4× | div-exp |
| 4× | cbrt-undiv |
| 2× | div-inv |
| 1× | expm1-udef |
| 1× | pow-prod-up |
| 1× | *-commutative |
| 1× | associate-*r/ |
| 1× | log1p-expm1 |
| 1× | associate-*l/ |
| 1× | pow-prod-down |
| 1× | pow-plus |
| 1× | expm1-log1p |
| 1× | log1p-udef |
| 1× | frac-times |
| 1× | acos-asin |
| 1× | pow2 |
| 10.0ms | (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 1.0ms | (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 0.0ms | (log1p (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 0.0ms | (expm1 (log1p (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 207.0ms | (expm1 (log1p (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 98.0ms | (log1p (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 41.0ms | (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 3.0ms | (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 451.0ms | (* (fma (* -5 v) v 1) (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 422.0ms | (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 276.0ms | (acos (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1))))) |
| 272.0ms | (+ (- (log (fma (* -5 v) v 1)) (log (fma v v -1))) (log (/ (fma (* -5 v) v 1) (fma v v -1)))) |
| 268.0ms | (cbrt (* (* (/ (fma (* -5 v) v 1) (fma v v -1)) (/ (fma (* -5 v) v 1) (fma v v -1))) (/ (fma (* -5 v) v 1) (fma v v -1)))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 1.0b | (* (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 1.0b | (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 1.0b | (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 0.3b | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 12× | sqrt-prod |
| 12× | add-sqr-sqrt |
| 10× | add-cube-cbrt |
| 10× | *-un-lft-identity |
| 9× | pow1 |
| 6× | add-exp-log |
| 6× | associate-*l* |
| 6× | associate-*r* |
| 6× | pow1/2 |
| 6× | add-cbrt-cube |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | expm1-log1p-u |
| 2× | pow-prod-up |
| 2× | pow-prod-down |
| 2× | rem-sqrt-square |
| 1× | cbrt-unprod |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | sqrt-unprod |
| 1× | pow-plus |
| 1× | rem-square-sqrt |
| 1× | acos-asin |
| 1× | pow2 |
| 5.0ms | (* (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 1.0ms | (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 1.0ms | (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 1.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 193.0ms | (* (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 192.0ms | (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 190.0ms | (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) |
| 4.0ms | (acos (/ (fma (* -5 v) v 1) (fma v v -1))) |
| 99.0ms | (sqrt (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 81.0ms | (* (* (* (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) (* (* (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1)))))))) |
| 80.0ms | (sqrt (sqrt (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))))) |
| 80.0ms | (sqrt (acos (/ (fma (* -5 v) v 1) (fma v v -1)))) |
| 72.0ms | (expm1 (log1p (acos (/ (fma (* -5 v) v 1) (fma v v -1))))) |
6 alts after pruning (4 fresh and 2 done)
Merged error: 0.3b
0% (0.0b remaining)
Error of 0.5b against oracle of 0.5b and baseline of 0.5b
| 3.6s | 2979× | body | 2560 | valid |
| 1.8s | 2497× | body | 1280 | valid |
| 892.0ms | 7999× | body | 80 | nan |
| 696.0ms | 1281× | body | 640 | valid |
| 269.0ms | 636× | body | 320 | valid |
| 94.0ms | 399× | body | 160 | valid |
| 58.0ms | 208× | body | 80 | valid |