Time bar (total: 6.7s)
| 1× | search |
| True | Other | False | Iter |
|---|---|---|---|
| 0% | 99.9% | 0.1% | 0 |
| 0% | 99.9% | 0.1% | 1 |
| 0% | 99.9% | 0.1% | 2 |
| 0% | 99.9% | 0.1% | 3 |
| 12.5% | 87.4% | 0.1% | 4 |
| 25% | 74.9% | 0.1% | 5 |
| 31.2% | 68.7% | 0.1% | 6 |
| 67.1% | 32.8% | 0.1% | 7 |
| 71% | 28.9% | 0.1% | 8 |
| 82.3% | 17.6% | 0.1% | 9 |
| 84.9% | 15% | 0.1% | 10 |
| 90.8% | 9.1% | 0.1% | 11 |
| 92.2% | 7.7% | 0.1% | 12 |
| 95.3% | 4.6% | 0.1% | 13 |
| 96% | 3.9% | 0.1% | 14 |
Compiled 14 to 11 computations (21.4% saved)
| 1× | intervals |
| 10.0ms | 203× | body | 128 | valid |
| 3.0ms | 23× | body | 1024 | valid |
| 2.0ms | 21× | body | 512 | valid |
| 1.0ms | 9× | body | 256 | valid |
Compiled 29 to 23 computations (20.7% saved)
| 1× | egg-herbie |
| 1996× | fma-def_binary64 |
| 1626× | fma-neg_binary64 |
| 1098× | div-sub_binary64 |
| 733× | sub-neg_binary64 |
| 664× | associate-/l*_binary64 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 16 |
| 1 | 19 | 16 |
| 2 | 43 | 16 |
| 3 | 102 | 14 |
| 4 | 274 | 14 |
| 5 | 652 | 14 |
| 6 | 1272 | 14 |
| 7 | 1697 | 14 |
| 8 | 2416 | 14 |
| 9 | 2933 | 14 |
| 10 | 3278 | 14 |
| 11 | 3461 | 14 |
| 12 | 1980 | 14 |
| 13 | 1996 | 14 |
| 14 | 2659 | 14 |
| 15 | 2539 | 14 |
| 16 | 2497 | 14 |
| 17 | 2531 | 14 |
| 18 | 2531 | 14 |
| 19 | 4723 | 14 |
| 20 | 4903 | 14 |
| 21 | 5942 | 14 |
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 2 | 2 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 3 | 3 |
| Status | Error | Program |
| ▶ | 13.8b | (fma.f64 y (/.f64 (+.f64 x -1) (+.f64 1 y)) 1) |
| 23.2b | (-.f64 1 (/.f64 (*.f64 (-.f64 1 x) y) (+.f64 y 1))) |
Compiled 73 to 55 computations (24.7% saved)
Found 2 expressions with local error:
| New | Error | Program |
| ✓ | 0.0b | (/.f64 (+.f64 x -1) (+.f64 1 y)) |
| ✓ | 13.8b | (fma.f64 y (/.f64 (+.f64 x -1) (+.f64 1 y)) 1) |
2 calls:
| 14.0ms | (/.f64 (+.f64 x -1) (+.f64 1 y)) |
| 9.0ms | (fma.f64 y (/.f64 (+.f64 x -1) (+.f64 1 y)) 1) |
| 1× | rewrite-expression-head |
| 35× | *-un-lft-identity_binary64 |
| 20× | times-frac_binary64 |
| 18× | add-sqr-sqrt_binary64 |
| 13× | add-cube-cbrt_binary64 |
| 11× | distribute-lft-out_binary64 |
2 calls:
| 5.0ms | (/.f64 (+.f64 x -1) (+.f64 1 y)) |
| 0.0ms | (fma.f64 y (/.f64 (+.f64 x -1) (+.f64 1 y)) 1) |
| 1× | egg-herbie |
| 780× | fma-neg_binary64 |
| 491× | associate--l+_binary64 |
| 425× | associate--r+_binary64 |
| 390× | associate-+l+_binary64 |
| 315× | fma-def_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 160 | 2086 |
| 1 | 416 | 1897 |
| 2 | 1275 | 1850 |
| 3 | 4701 | 1850 |
| 4 | 5402 | 1850 |
4 alts after pruning (4 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 99 | 3 | 102 |
| Fresh | 0 | 1 | 1 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 100 | 4 | 104 |
| Status | Error | Program |
| ▶ | 13.6b | (-.f64 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (/.f64 y (+.f64 1 y))) |
| 23.2b | (-.f64 1 (/.f64 (*.f64 (-.f64 1 x) y) (+.f64 y 1))) | |
| 30.2b | (-.f64 (+.f64 x (/.f64 x (*.f64 y y))) (+.f64 (/.f64 1 (*.f64 y y)) (/.f64 (+.f64 x -1) y))) | |
| 30.4b | (cbrt.f64 (pow.f64 (fma.f64 y (/.f64 (+.f64 x -1) (+.f64 1 y)) 1) 3)) |
Compiled 1920 to 1317 computations (31.4% saved)
Found 2 expressions with local error:
| New | Error | Program |
| ✓ | 0.0b | (/.f64 y (+.f64 1 y)) |
| ✓ | 1.9b | (-.f64 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (/.f64 y (+.f64 1 y))) |
2 calls:
| 10.0ms | (-.f64 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (/.f64 y (+.f64 1 y))) |
| 2.0ms | (/.f64 y (+.f64 1 y)) |
| 1× | rewrite-expression-head |
| 96× | *-un-lft-identity_binary64 |
| 67× | add-sqr-sqrt_binary64 |
| 62× | add-cube-cbrt_binary64 |
| 61× | times-frac_binary64 |
| 54× | prod-diff_binary64 |
2 calls:
| 10.0ms | (-.f64 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (/.f64 y (+.f64 1 y))) |
| 3.0ms | (/.f64 y (+.f64 1 y)) |
| 1× | egg-herbie |
| 546× | fma-neg_binary64 |
| 471× | times-frac_binary64 |
| 249× | distribute-rgt-in_binary64 |
| 228× | cancel-sign-sub-inv_binary64 |
| 204× | distribute-lft-in_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 267 | 5363 |
| 1 | 693 | 3649 |
| 2 | 1982 | 2906 |
| 3 | 4437 | 2906 |
| 4 | 4802 | 2906 |
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 221 | 2 | 223 |
| Fresh | 2 | 1 | 3 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 224 | 3 | 227 |
| Status | Error | Program |
| 30.2b | (-.f64 (+.f64 x (/.f64 x (*.f64 y y))) (+.f64 (/.f64 1 (*.f64 y y)) (/.f64 (+.f64 x -1) y))) | |
| ▶ | 13.8b | (-.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (cbrt.f64 y) (cbrt.f64 y)) (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y)))) (/.f64 (cbrt.f64 y) (cbrt.f64 (+.f64 1 y)))) x 1) (/.f64 y (+.f64 1 y))) |
| 14.2b | (+.f64 (fma.f64 1 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (neg.f64 (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) (fma.f64 (neg.f64 (-.f64 1 y)) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) |
Compiled 6988 to 4629 computations (33.8% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.3b | (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y))) |
| ✓ | 0.5b | (*.f64 (cbrt.f64 y) (cbrt.f64 y)) |
| ✓ | 0.6b | (cbrt.f64 y) |
| ✓ | 1.9b | (-.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (cbrt.f64 y) (cbrt.f64 y)) (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y)))) (/.f64 (cbrt.f64 y) (cbrt.f64 (+.f64 1 y)))) x 1) (/.f64 y (+.f64 1 y))) |
4 calls:
| 36.0ms | (*.f64 (cbrt.f64 y) (cbrt.f64 y)) |
| 35.0ms | (cbrt.f64 y) |
| 16.0ms | (-.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (cbrt.f64 y) (cbrt.f64 y)) (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y)))) (/.f64 (cbrt.f64 y) (cbrt.f64 (+.f64 1 y)))) x 1) (/.f64 y (+.f64 1 y))) |
| 6.0ms | (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y))) |
| 1× | rewrite-expression-head |
| 112× | *-un-lft-identity_binary64 |
| 93× | add-sqr-sqrt_binary64 |
| 72× | add-cube-cbrt_binary64 |
| 54× | prod-diff_binary64 |
| 49× | times-frac_binary64 |
4 calls:
| 9.0ms | (-.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (cbrt.f64 y) (cbrt.f64 y)) (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y)))) (/.f64 (cbrt.f64 y) (cbrt.f64 (+.f64 1 y)))) x 1) (/.f64 y (+.f64 1 y))) |
| 8.0ms | (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y))) |
| 6.0ms | (*.f64 (cbrt.f64 y) (cbrt.f64 y)) |
| 1.0ms | (cbrt.f64 y) |
| 1× | egg-herbie |
| 450× | fma-neg_binary64 |
| 322× | unswap-sqr_binary64 |
| 318× | exp-prod_binary64 |
| 290× | distribute-rgt-neg-in_binary64 |
| 227× | associate-*r*_binary64 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 357 | 8172 |
| 1 | 838 | 5093 |
| 2 | 2886 | 4103 |
| 3 | 4161 | 4085 |
| 4 | 4860 | 4085 |
3 alts after pruning (2 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 315 | 1 | 316 |
| Fresh | 1 | 1 | 2 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 316 | 3 | 319 |
| Status | Error | Program |
| ✓ | 13.8b | (-.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (cbrt.f64 y) (cbrt.f64 y)) (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y)))) (/.f64 (cbrt.f64 y) (cbrt.f64 (+.f64 1 y)))) x 1) (/.f64 y (+.f64 1 y))) |
| ▶ | 14.2b | (+.f64 (fma.f64 1 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (neg.f64 (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) (fma.f64 (neg.f64 (-.f64 1 y)) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) |
| 30.1b | (-.f64 (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (pow.f64 y 3)) (+.f64 (/.f64 x (pow.f64 y 2)) x))) (+.f64 (/.f64 x y) (+.f64 (/.f64 x (pow.f64 y 3)) (/.f64 1 (pow.f64 y 2))))) |
Compiled 15028 to 9379 computations (37.6% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.1b | (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))) |
| ✓ | 3.6b | (fma.f64 1 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (neg.f64 (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) |
| ✓ | 17.4b | (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) |
| ✓ | 33.8b | (fma.f64 (neg.f64 (-.f64 1 y)) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))))) |
4 calls:
| 47.0ms | (fma.f64 1 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (neg.f64 (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) |
| 8.0ms | (fma.f64 (neg.f64 (-.f64 1 y)) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))))) |
| 3.0ms | (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) |
| 2.0ms | (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))) |
| 1× | rewrite-expression-head |
| 30× | add-sqr-sqrt_binary64 |
| 25× | times-frac_binary64 |
| 25× | *-un-lft-identity_binary64 |
| 22× | add-cube-cbrt_binary64 |
| 18× | associate-*r*_binary64 |
4 calls:
| 12.0ms | (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))) |
| 5.0ms | (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) |
| 0.0ms | (fma.f64 (neg.f64 (-.f64 1 y)) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))))) |
| 0.0ms | (fma.f64 1 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (neg.f64 (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) |
| 1× | egg-herbie |
| 608× | fma-def_binary64 |
| 361× | fma-neg_binary64 |
| 357× | associate-/l*_binary64 |
| 341× | distribute-rgt-in_binary64 |
| 287× | times-frac_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 224 | 3307 |
| 1 | 532 | 2909 |
| 2 | 1905 | 2525 |
| 3 | 4680 | 2525 |
| 4 | 4870 | 2525 |
3 alts after pruning (1 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 474 | 0 | 474 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 1 | 1 |
| Total | 474 | 3 | 477 |
| Status | Error | Program |
| ✓ | 13.8b | (-.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (cbrt.f64 y) (cbrt.f64 y)) (*.f64 (cbrt.f64 (+.f64 1 y)) (cbrt.f64 (+.f64 1 y)))) (/.f64 (cbrt.f64 y) (cbrt.f64 (+.f64 1 y)))) x 1) (/.f64 y (+.f64 1 y))) |
| ✓ | 14.2b | (+.f64 (fma.f64 1 (fma.f64 (/.f64 y (+.f64 1 y)) x 1) (neg.f64 (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) (fma.f64 (neg.f64 (-.f64 1 y)) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y))) (*.f64 (-.f64 1 y) (/.f64 y (-.f64 (*.f64 1 1) (*.f64 y y)))))) |
| 30.1b | (-.f64 (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (pow.f64 y 3)) (+.f64 (/.f64 x (pow.f64 y 2)) x))) (+.f64 (/.f64 x y) (+.f64 (/.f64 x (pow.f64 y 3)) (/.f64 1 (pow.f64 y 2))))) |
Compiled 27761 to 18108 computations (34.8% saved)
Total 0.1b remaining (77%)
Threshold costs 0.1b (77%)
Compiled 45483 to 31791 computations (30.1% saved)
Compiled 11 to 8 computations (27.3% saved)
| 1× | egg-herbie |
| 52× | cancel-sign-sub-inv_binary64 |
| 51× | distribute-rgt-neg-in_binary64 |
| 33× | neg-sub0_binary64 |
| 33× | neg-mul-1_binary64 |
| 32× | distribute-lft-neg-in_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 45 | 191 |
| 1 | 76 | 191 |
| 2 | 103 | 185 |
| 3 | 128 | 185 |
| 4 | 151 | 185 |
| 5 | 183 | 185 |
| 6 | 214 | 185 |
| 7 | 250 | 185 |
| 8 | 280 | 185 |
| 9 | 305 | 185 |
| 10 | 322 | 185 |
| 11 | 332 | 185 |
| 12 | 339 | 185 |
| 13 | 341 | 185 |
| 14 | 336 | 185 |
Compiled 128 to 85 computations (33.6% saved)
| 1× | intervals |
| 248.0ms | 6340× | body | 128 | valid |
| 91.0ms | 608× | body | 1024 | valid |
| 77.0ms | 630× | body | 512 | valid |
| 29.0ms | 416× | body | 256 | valid |
| 1.0ms | 6× | body | 2048 | valid |
Compiled 267 to 183 computations (31.5% saved)
Loading profile data...