Time bar (total: 11.3s)
| 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 |
| 0% | 99.9% | 0.1% | 4 |
| 0% | 99.9% | 0.1% | 5 |
| 3.1% | 96.8% | 0.1% | 6 |
| 15.6% | 81.2% | 3.2% | 7 |
| 23.4% | 72.6% | 4% | 8 |
| 32.4% | 55.8% | 11.8% | 9 |
| 36.3% | 50.9% | 12.8% | 10 |
| 40.7% | 41.5% | 17.9% | 11 |
| 42.6% | 38.6% | 18.8% | 12 |
| 44.5% | 33.5% | 22% | 13 |
| 45.5% | 32% | 22.5% | 14 |
Compiled 18 to 12 computations (33.3% saved)
| 3.1s | 1834× | body | 2048 | valid |
| 2.1s | 2638× | body | 1024 | valid |
| 552.0ms | 1217× | body | 512 | valid |
| 312.0ms | 1918× | body | 128 | valid |
| 167.0ms | 605× | body | 256 | valid |
| 162.0ms | 273× | body | 512 | invalid |
| 157.0ms | 180× | body | 1024 | invalid |
| 116.0ms | 44× | body | 4096 | valid |
| 72.0ms | 502× | body | 128 | invalid |
| 51.0ms | 144× | body | 256 | invalid |
| 36.0ms | 25× | body | 2048 | invalid |
Compiled 53 to 35 computations (34% saved)
| 1× | egg-herbie |
| 701× | fma-def_binary64 |
| 563× | associate-/r/_binary64 |
| 484× | associate-/r*_binary64 |
| 474× | associate-*l/_binary64 |
| 421× | associate-/l/_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 22 |
| 1 | 29 | 22 |
| 2 | 67 | 20 |
| 3 | 164 | 20 |
| 4 | 463 | 20 |
| 5 | 1761 | 20 |
| 6 | 4847 | 20 |
| 7 | 5013 | 20 |
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 |
| 48.8b | (*.f64 100 (/.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 i n)) n) 1) (/.f64 i n))) | |
| ▶ | 48.8b | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) |
Compiled 97 to 63 computations (35.1% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.0b | (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i) |
| ✓ | 0.0b | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) |
| ✓ | 0.4b | (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) |
| ✓ | 7.7b | (pow.f64 (+.f64 1 (/.f64 i n)) n) |
4 calls:
| 185.0ms | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) |
| 140.0ms | (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i) |
| 92.0ms | (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) |
| 42.0ms | (pow.f64 (+.f64 1 (/.f64 i n)) n) |
| 1× | rewrite-expression-head |
| 27× | add-sqr-sqrt_binary64 |
| 24× | *-un-lft-identity_binary64 |
| 22× | add-cube-cbrt_binary64 |
| 19× | times-frac_binary64 |
| 13× | associate-*r*_binary64 |
4 calls:
| 8.0ms | (pow.f64 (+.f64 1 (/.f64 i n)) n) |
| 7.0ms | (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i) |
| 7.0ms | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) |
| 1.0ms | (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) |
| 1× | egg-herbie |
| 462× | times-frac_binary64 |
| 322× | *-commutative_binary64 |
| 293× | +-commutative_binary64 |
| 262× | fma-def_binary64 |
| 225× | sub-neg_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 982 | 10503 |
| 1 | 3140 | 10129 |
| 2 | 4870 | 9717 |
| 3 | 4972 | 9717 |
15 alts after pruning (15 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 247 | 14 | 261 |
| Fresh | 0 | 1 | 1 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 248 | 15 | 263 |
| Status | Error | Program |
| 32.4b | (-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25))))) | |
| 48.8b | (*.f64 100 (/.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 i n)) n) 1) (/.f64 i n))) | |
| 54.9b | (*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i))) | |
| ▶ | 29.6b | (*.f64 100 n) |
| 46.0b | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i)) | |
| 30.6b | (*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))) | |
| 47.8b | (/.f64 (*.f64 (-.f64 (*.f64 100 (exp.f64 i)) 100) n) i) | |
| 32.4b | (*.f64 n (/.f64 (-.f64 (fma.f64 50/3 (pow.f64 i 3) (fma.f64 100 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 100/3)))) (*.f64 50 (+.f64 (/.f64 (*.f64 i i) n) (/.f64 (pow.f64 i 3) n)))) i)) | |
| 48.7b | (*.f64 n (-.f64 (*.f64 100 (/.f64 (exp.f64 i) i)) (+.f64 (*.f64 50 (/.f64 (*.f64 (exp.f64 i) i) n)) (*.f64 100 (/.f64 1 i))))) | |
| 54.0b | (*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)) | |
| 53.8b | (*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i))))) | |
| 47.8b | (/.f64 (fma.f64 (exp.f64 i) 100 -100) (/.f64 i n)) | |
| 54.9b | (-.f64 (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (log.f64 i)) i) (fma.f64 100 (/.f64 (pow.f64 n 3) (*.f64 i i)) (*.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (pow.f64 n 3) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 (*.f64 n n) (log.f64 n)) i)))) | |
| 55.4b | (fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100)) | |
| 54.6b | (/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i) |
Compiled 14075 to 8827 computations (37.3% saved)
15 alts after pruning (14 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 14 | 14 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 0 | 15 | 15 |
| Status | Error | Program |
| 32.4b | (-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25))))) | |
| 48.8b | (*.f64 100 (/.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 i n)) n) 1) (/.f64 i n))) | |
| 54.9b | (*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i))) | |
| ✓ | 29.6b | (*.f64 100 n) |
| 46.0b | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i)) | |
| ▶ | 30.6b | (*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))) |
| 47.8b | (/.f64 (*.f64 (-.f64 (*.f64 100 (exp.f64 i)) 100) n) i) | |
| 32.4b | (*.f64 n (/.f64 (-.f64 (fma.f64 50/3 (pow.f64 i 3) (fma.f64 100 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 100/3)))) (*.f64 50 (+.f64 (/.f64 (*.f64 i i) n) (/.f64 (pow.f64 i 3) n)))) i)) | |
| 48.7b | (*.f64 n (-.f64 (*.f64 100 (/.f64 (exp.f64 i) i)) (+.f64 (*.f64 50 (/.f64 (*.f64 (exp.f64 i) i) n)) (*.f64 100 (/.f64 1 i))))) | |
| 54.0b | (*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)) | |
| 53.8b | (*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i))))) | |
| 47.8b | (/.f64 (fma.f64 (exp.f64 i) 100 -100) (/.f64 i n)) | |
| 54.9b | (-.f64 (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (log.f64 i)) i) (fma.f64 100 (/.f64 (pow.f64 n 3) (*.f64 i i)) (*.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (pow.f64 n 3) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 (*.f64 n n) (log.f64 n)) i)))) | |
| 55.4b | (fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100)) | |
| 54.6b | (/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i) |
Compiled 939 to 584 computations (37.8% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 2.6b | (*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))) |
| ✓ | 3.5b | (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)) |
| ✓ | 4.4b | (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))) |
| ✓ | 6.2b | (/.f64 (*.f64 i i) n) |
4 calls:
| 43.0ms | (*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))) |
| 32.0ms | (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))) |
| 14.0ms | (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)) |
| 13.0ms | (/.f64 (*.f64 i i) n) |
| 1× | rewrite-expression-head |
| 37× | *-un-lft-identity_binary64 |
| 23× | add-sqr-sqrt_binary64 |
| 21× | add-cube-cbrt_binary64 |
| 20× | associate-*r/_binary64 |
| 20× | times-frac_binary64 |
4 calls:
| 10.0ms | (*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))) |
| 8.0ms | (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)) |
| 6.0ms | (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))) |
| 4.0ms | (/.f64 (*.f64 i i) n) |
| 1× | egg-herbie |
| 568× | times-frac_binary64 |
| 407× | fma-neg_binary64 |
| 312× | cancel-sign-sub-inv_binary64 |
| 200× | distribute-rgt-in_binary64 |
| 185× | distribute-lft-in_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 272 | 8392 |
| 1 | 784 | 7689 |
| 2 | 2879 | 7475 |
| 3 | 4765 | 7475 |
| 4 | 4938 | 7475 |
15 alts after pruning (14 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 234 | 2 | 236 |
| Fresh | 1 | 12 | 13 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 1 | 1 |
| Total | 236 | 15 | 251 |
| Status | Error | Program |
| 32.4b | (-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25))))) | |
| 48.8b | (*.f64 100 (/.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 i n)) n) 1) (/.f64 i n))) | |
| 54.9b | (*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i))) | |
| ✓ | 29.6b | (*.f64 100 n) |
| 46.0b | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i)) | |
| 54.9b | (-.f64 (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (log.f64 i)) i) (fma.f64 100 (/.f64 (pow.f64 n 3) (*.f64 i i)) (*.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (pow.f64 n 3) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 (*.f64 n n) (log.f64 n)) i)))) | |
| 47.3b | (exp.f64 (log.f64 (*.f64 n (-.f64 (+.f64 100 (fma.f64 i 50 (fma.f64 (*.f64 i i) 50/3 (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 (*.f64 i i) n) (/.f64 i n))))))) | |
| 54.6b | (/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i) | |
| ▶ | 30.6b | (fma.f64 n 100 (*.f64 i (fma.f64 n 50 -50))) |
| 48.7b | (*.f64 n (-.f64 (*.f64 100 (/.f64 (exp.f64 i) i)) (+.f64 (*.f64 50 (/.f64 (*.f64 (exp.f64 i) i) n)) (*.f64 100 (/.f64 1 i))))) | |
| 54.0b | (*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)) | |
| 53.8b | (*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i))))) | |
| 47.8b | (/.f64 (fma.f64 (exp.f64 i) 100 -100) (/.f64 i n)) | |
| 47.8b | (/.f64 (*.f64 (-.f64 (*.f64 100 (exp.f64 i)) 100) n) i) | |
| 55.4b | (fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100)) |
Compiled 13556 to 5572 computations (58.9% saved)
Found 3 expressions with local error:
| New | Error | Program |
| ✓ | 0.0b | (fma.f64 n 50 -50) |
| ✓ | 0.0b | (fma.f64 n 100 (*.f64 i (fma.f64 n 50 -50))) |
| ✓ | 0.1b | (*.f64 i (fma.f64 n 50 -50)) |
3 calls:
| 7.0ms | (fma.f64 n 100 (*.f64 i (fma.f64 n 50 -50))) |
| 6.0ms | (*.f64 i (fma.f64 n 50 -50)) |
| 2.0ms | (fma.f64 n 50 -50) |
| 1× | rewrite-expression-head |
| 7× | add-sqr-sqrt_binary64 |
| 5× | *-un-lft-identity_binary64 |
| 5× | add-cube-cbrt_binary64 |
| 5× | add-cbrt-cube_binary64 |
| 5× | add-exp-log_binary64 |
3 calls:
| 4.0ms | (*.f64 i (fma.f64 n 50 -50)) |
| 0.0ms | (fma.f64 n 50 -50) |
| 0.0ms | (fma.f64 n 100 (*.f64 i (fma.f64 n 50 -50))) |
| 1× | egg-herbie |
| 739× | distribute-rgt-neg-out_binary64 |
| 517× | fma-def_binary64 |
| 373× | distribute-neg-out_binary64 |
| 270× | unsub-neg_binary64 |
| 267× | *-commutative_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 72 | 1102 |
| 1 | 132 | 956 |
| 2 | 372 | 956 |
| 3 | 1074 | 956 |
| 4 | 2169 | 956 |
| 5 | 5099 | 956 |
15 alts after pruning (13 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 89 | 0 | 89 |
| Fresh | 0 | 13 | 13 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 1 | 1 |
| Total | 89 | 15 | 104 |
| Status | Error | Program |
| 32.4b | (-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25))))) | |
| 48.8b | (*.f64 100 (/.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 i n)) n) 1) (/.f64 i n))) | |
| 54.9b | (*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i))) | |
| ✓ | 29.6b | (*.f64 100 n) |
| 46.0b | (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i)) | |
| 54.9b | (-.f64 (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (log.f64 i)) i) (fma.f64 100 (/.f64 (pow.f64 n 3) (*.f64 i i)) (*.f64 50 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (pow.f64 n 3) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 (*.f64 n n) (log.f64 n)) i)))) | |
| 47.3b | (exp.f64 (log.f64 (*.f64 n (-.f64 (+.f64 100 (fma.f64 i 50 (fma.f64 (*.f64 i i) 50/3 (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 (*.f64 i i) n) (/.f64 i n))))))) | |
| 54.6b | (/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i) | |
| ✓ | 30.6b | (fma.f64 n 100 (*.f64 i (fma.f64 n 50 -50))) |
| 48.7b | (*.f64 n (-.f64 (*.f64 100 (/.f64 (exp.f64 i) i)) (+.f64 (*.f64 50 (/.f64 (*.f64 (exp.f64 i) i) n)) (*.f64 100 (/.f64 1 i))))) | |
| 54.0b | (*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)) | |
| 53.8b | (*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i))))) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i))))) | |
| 47.8b | (/.f64 (fma.f64 (exp.f64 i) 100 -100) (/.f64 i n)) | |
| 47.8b | (/.f64 (*.f64 (-.f64 (*.f64 100 (exp.f64 i)) 100) n) i) | |
| 55.4b | (fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100)) |
Compiled 1624 to 1113 computations (31.5% saved)
Total 7.3b remaining (70.4%)
Threshold costs 0b (0%)
Compiled 9052 to 6080 computations (32.8% saved)
| Iters | Range | Point | |
|---|---|---|---|
| 3 | 5.7822390698821425e+274 | 8.005582345484438e+274 | 5.887413016264065e+274 |
| 9 | 2.9050658218234403e+231 | 2.4233517925229457e+240 | 2.3751934240026747e+240 |
| 9 | 0.00579022180323356 | 50651.624269443695 | 0.8560767434772578 |
| 9 | -9.353060707798373e-9 | -4.833690062419475e-14 | -3.349360149998456e-9 |
Compiled 3 to 2 computations (33.3% saved)
| 1× | egg-herbie |
| 30× | *-commutative_binary64 |
| 17× | +-commutative_binary64 |
| 15× | sub-neg_binary64 |
| 13× | neg-sub0_binary64 |
| 13× | neg-mul-1_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 73 | 208 |
| 1 | 101 | 208 |
| 2 | 114 | 208 |
| 3 | 126 | 208 |
| 4 | 142 | 208 |
| 5 | 163 | 208 |
| 6 | 183 | 208 |
| 7 | 195 | 208 |
| 8 | 202 | 208 |
| 9 | 204 | 208 |
| 10 | 203 | 208 |
Compiled 725 to 455 computations (37.2% saved)
Loading profile data...