Time bar (total: 5.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 |
| 0% | 99.9% | 0.1% | 4 |
| 0% | 99.9% | 0.1% | 5 |
| 0% | 99.9% | 0.1% | 6 |
| 37.4% | 62.4% | 0.1% | 7 |
| 43.7% | 56.2% | 0.1% | 8 |
| 43.7% | 56.2% | 0.1% | 9 |
| 65.5% | 34.3% | 0.1% | 10 |
| 70.2% | 29.6% | 0.1% | 11 |
| 70.2% | 29.6% | 0.1% | 12 |
| 81.9% | 17.9% | 0.1% | 13 |
| 84.6% | 15.2% | 0.1% | 14 |
Compiled 13 to 9 computations (30.8% saved)
| 1.5s | 2041× | body | 1024 | valid |
| 798.0ms | 4659× | body | 128 | valid |
| 453.0ms | 1035× | body | 512 | valid |
| 145.0ms | 510× | body | 256 | valid |
| 15.0ms | 11× | body | 2048 | valid |
Compiled 26 to 18 computations (30.8% saved)
| 2× | egg-herbie |
| 16× | fma-def_binary64 |
| 8× | *-commutative_binary64 |
| 4× | +-commutative_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 22 | 48 |
| 1 | 38 | 48 |
| 2 | 50 | 48 |
| 0 | 3 | 3 |
| 1× | saturated |
| 1× | saturated |
Compiled 12 to 8 computations (33.3% saved)
| 1× | egg-herbie |
| 4× | fma-def_binary64 |
| 2× | *-commutative_binary64 |
| 1× | +-commutative_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 12 |
| 1 | 13 | 12 |
| 2 | 16 | 12 |
| 1× | saturated |
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 1 | 1 | 2 |
| Fresh | 1 | 0 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 2 | 1 | 3 |
| Status | Error | Program |
| ▶ | 0.1b | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) |
Compiled 42 to 23 computations (45.2% saved)
Found 2 expressions with local error:
| New | Error | Program |
| ✓ | 0.0b | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) |
| ✓ | 0.2b | (*.f64 z (cos.f64 y)) |
15 calls:
| 2.0ms | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) | z | 0 |
| 2.0ms | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) | z | -inf |
| 2.0ms | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) | x | -inf |
| 2.0ms | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) | z | inf |
| 2.0ms | (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))) | x | inf |
| 1× | batch-egg-rewrite |
| 689× | log1p-expm1-u_binary64 |
| 689× | expm1-log1p-u_binary64 |
| 201× | prod-diff_binary64 |
| 147× | log1p-udef_binary64 |
| 81× | add-sqr-sqrt_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 18 |
| 1 | 156 | 18 |
| 2 | 1869 | 18 |
| 1× | node limit |
| 1× | egg-herbie |
| 744× | cancel-sign-sub-inv_binary64 |
| 697× | fma-def_binary64 |
| 362× | fma-neg_binary64 |
| 276× | sub-neg_binary64 |
| 234× | *-commutative_binary64 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 39 | 588 |
| 1 | 107 | 587 |
| 2 | 326 | 576 |
| 3 | 1247 | 568 |
| 4 | 4695 | 568 |
| 1× | node limit |
7 alts after pruning (7 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 48 | 7 | 55 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 49 | 7 | 56 |
| Status | Error | Program |
| ▶ | 0.1b | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) |
| 1.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) | |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (*.f64 (pow.f64 z 3) (pow.f64 (cos.f64 y) 3)))) | |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (pow.f64 (*.f64 z (cos.f64 y)) 3))) | |
| 22.5b | (expm1.f64 (log1p.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) | |
| 28.3b | (pow.f64 (sqrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | |
| 1.3b | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 3) |
Compiled 920 to 384 computations (58.3% saved)
Found 2 expressions with local error:
| New | Error | Program |
| ✓ | 0.1b | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) |
| ✓ | 0.1b | (*.f64 (sin.f64 y) x) |
15 calls:
| 3.0ms | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) | z | -inf |
| 2.0ms | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) | x | -inf |
| 2.0ms | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) | x | 0 |
| 2.0ms | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) | z | inf |
| 2.0ms | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) | x | inf |
| 1× | batch-egg-rewrite |
| 689× | log1p-expm1-u_binary64 |
| 689× | expm1-log1p-u_binary64 |
| 201× | prod-diff_binary64 |
| 147× | log1p-udef_binary64 |
| 81× | add-sqr-sqrt_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 18 |
| 1 | 156 | 18 |
| 2 | 1869 | 18 |
| 1× | node limit |
| 1× | egg-herbie |
| 811× | fma-def_binary64 |
| 505× | associate-*l*_binary64 |
| 422× | associate-*r*_binary64 |
| 410× | fma-neg_binary64 |
| 224× | sub-neg_binary64 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 39 | 480 |
| 1 | 118 | 472 |
| 2 | 358 | 460 |
| 3 | 1240 | 451 |
| 4 | 4701 | 451 |
| 1× | node limit |
7 alts after pruning (6 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 57 | 0 | 57 |
| Fresh | 0 | 6 | 6 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 57 | 7 | 64 |
| Status | Error | Program |
| ✓ | 0.1b | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) |
| ▶ | 1.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (*.f64 (pow.f64 z 3) (pow.f64 (cos.f64 y) 3)))) | |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (pow.f64 (*.f64 z (cos.f64 y)) 3))) | |
| 22.5b | (expm1.f64 (log1p.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) | |
| 28.3b | (pow.f64 (sqrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | |
| 1.3b | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 3) |
Compiled 913 to 379 computations (58.5% saved)
Found 4 expressions with local error:
| New | Error | Program |
| 0.2b | (*.f64 z (cos.f64 y)) | |
| ✓ | 0.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) |
| ✓ | 0.5b | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) |
| ✓ | 0.5b | (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) |
27 calls:
| 40.0ms | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | y | inf |
| 40.0ms | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | y | -inf |
| 36.0ms | (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) | y | -inf |
| 36.0ms | (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) | y | inf |
| 8.0ms | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | y | 0 |
| 1× | batch-egg-rewrite |
| 879× | log1p-expm1-u_binary64 |
| 879× | expm1-log1p-u_binary64 |
| 201× | prod-diff_binary64 |
| 107× | add-sqr-sqrt_binary64 |
| 99× | add-cube-cbrt_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 43 |
| 1 | 238 | 43 |
| 2 | 2498 | 43 |
| 1× | node limit |
| 1× | egg-herbie |
| 622× | cancel-sign-sub-inv_binary64 |
| 475× | times-frac_binary64 |
| 329× | unswap-sqr_binary64 |
| 267× | associate-*r*_binary64 |
| 226× | distribute-rgt-neg-in_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 180 | 2427 |
| 1 | 628 | 2381 |
| 2 | 2441 | 2379 |
| 1× | node limit |
10 alts after pruning (8 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 213 | 5 | 218 |
| Fresh | 2 | 3 | 5 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 1 | 1 |
| Total | 215 | 10 | 225 |
| Status | Error | Program |
| ✓ | 0.1b | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) |
| ✓ | 1.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (*.f64 (pow.f64 z 3) (pow.f64 (cos.f64 y) 3)))) | |
| 1.7b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 2)) (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))))) | |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (pow.f64 (*.f64 z (cos.f64 y)) 3))) | |
| 14.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 2) (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 4)))) | |
| 30.3b | (*.f64 (exp.f64 (log.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) | |
| ▶ | 1.6b | (*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) |
| 28.3b | (pow.f64 (sqrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | |
| 51.6b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (cbrt.f64 (*.f64 x (*.f64 x (pow.f64 (sin.f64 y) 2))))) |
Compiled 7752 to 3282 computations (57.7% saved)
Found 4 expressions with local error:
| New | Error | Program |
| 0.5b | (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | |
| 0.5b | (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) | |
| ✓ | 0.6b | (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) |
| ✓ | 0.8b | (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3) |
18 calls:
| 139.0ms | (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3) | y | -inf |
| 134.0ms | (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3) | y | inf |
| 117.0ms | (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) | y | inf |
| 113.0ms | (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) | y | -inf |
| 13.0ms | (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3) | z | inf |
| 1× | batch-egg-rewrite |
| 485× | log-prod_binary64 |
| 201× | prod-diff_binary64 |
| 189× | expm1-udef_binary64 |
| 189× | log1p-udef_binary64 |
| 186× | pow1/3_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 30 |
| 1 | 234 | 30 |
| 2 | 2537 | 30 |
| 1× | node limit |
| 1× | egg-herbie |
| 528× | times-frac_binary64 |
| 433× | associate-*l*_binary64 |
| 355× | associate-/l*_binary64 |
| 323× | associate-/r*_binary64 |
| 229× | fma-def_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 362 | 4987 |
| 1 | 1343 | 4838 |
| 1× | node limit |
12 alts after pruning (9 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 303 | 2 | 305 |
| Fresh | 0 | 7 | 7 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 303 | 12 | 315 |
| Status | Error | Program |
| ✓ | 0.1b | (fma.f64 (cos.f64 y) z (*.f64 (sin.f64 y) x)) |
| ✓ | 1.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) |
| 1.9b | (*.f64 (pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3)) 3) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) | |
| 58.0b | (*.f64 (pow.f64 (exp.f64 (*.f64 1/9 (-.f64 (log.f64 (sin.f64 y)) (log.f64 (/.f64 1 x))))) 3) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) | |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (*.f64 (pow.f64 z 3) (pow.f64 (cos.f64 y) 3)))) | |
| 1.7b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 2)) (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))))) | |
| 32.9b | (fma.f64 x (sin.f64 y) (cbrt.f64 (pow.f64 (*.f64 z (cos.f64 y)) 3))) | |
| 14.3b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 2) (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 4)))) | |
| 30.3b | (*.f64 (exp.f64 (log.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))))) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) | |
| ✓ | 1.6b | (*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y))))) 3) (pow.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2)) |
| 28.3b | (pow.f64 (sqrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) 2) | |
| 51.6b | (*.f64 (cbrt.f64 (fma.f64 x (sin.f64 y) (*.f64 z (cos.f64 y)))) (cbrt.f64 (*.f64 x (*.f64 x (pow.f64 (sin.f64 y) 2))))) |
Compiled 15054 to 7207 computations (52.1% saved)
Total 0.1b remaining (46.1%)
Threshold costs 0.1b (46.1%)
Compiled 3908 to 2290 computations (41.4% saved)
| 1× | egg-herbie |
| 1× | *-commutative_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 12 |
| 1 | 9 | 12 |
| 1× | saturated |
| 1× | fuel |
Compiled 318 to 173 computations (45.6% saved)
Loading profile data...