Time bar (total: 6.9s)
| 1× | search |
| True | Other | False | Iter |
|---|---|---|---|
| 0% | 0% | 100% | 0 |
| 0% | 0% | 100% | 1 |
Compiled 38 to 21 computations (44.7% saved)
| Status | Error | Program |
| ▶ | 0.7b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) |
| 2.1s | 8256× | body | 128 | valid |
Compiled 145 to 72 computations (50.3% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.3b | (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) |
| ✓ | 0.4b | (*.f32 x (PI.f32)) |
| ✓ | 0.4b | (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))) |
| ✓ | 0.4b | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
4 calls:
| 29.0ms | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| 10.0ms | (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))) |
| 8.0ms | (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) |
| 2.0ms | (*.f32 x (PI.f32)) |
| 2× | batch-egg-rewrite |
| 720× | prod-diff_binary32 |
| 487× | fma-udef_binary32 |
| 203× | expm1-udef_binary32 |
| 203× | log1p-udef_binary32 |
| 201× | fma-neg_binary32 |
4 calls:
| 126.0ms | (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) |
| 126.0ms | (*.f32 x (PI.f32)) |
| 126.0ms | (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))) |
| 126.0ms | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 49 |
| 1 | 213 | 49 |
| 2 | 3040 | 49 |
| 3 | 4727 | 49 |
| 4 | 4687 | 49 |
| 5 | 5075 | 49 |
| 0 | 0 | 0 |
| 1 | 0 | 0 |
15 alts after pruning (15 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 255 | 15 | 270 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 256 | 15 | 271 |
| Status | Error | Program |
| 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (*.f32 x (PI.f32)))) | |
| 1.1b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 2)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (cbrt.f32 (*.f32 x (PI.f32)))))) | |
| 5.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (-.f32 (exp.f32 (log1p.f32 (*.f32 x (PI.f32)))) 1) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (cbrt.f32 (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) (pow.f32 (cbrt.f32 (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) 2))) | |
| 0.8b | (*.f32 (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)))) 1) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.0b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (pow.f32 (sqrt.f32 (*.f32 x (PI.f32))) 2))) | |
| 0.8b | (*.f32 (log.f32 (+.f32 1 (expm1.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)) 2)) (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (sqrt.f32 (sin.f32 (*.f32 x (PI.f32)))) (*.f32 (sqrt.f32 (sin.f32 (*.f32 x (PI.f32)))) (/.f32 1 (*.f32 x (PI.f32)))))) | |
| 5.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (-.f32 (exp.f32 (log1p.f32 (*.f32 x (PI.f32)))) 1)) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 3) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))))) 1)) | |
| ▶ | 0.7b | (*.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) 2) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 3.8b | (*.f32 (-.f32 (+.f32 1 (*.f32 1/120 (*.f32 (pow.f32 (PI.f32) 4) (*.f32 (pow.f32 tau 4) (pow.f32 x 4))))) (+.f32 (*.f32 1/5040 (*.f32 (pow.f32 (PI.f32) 6) (*.f32 (pow.f32 tau 6) (pow.f32 x 6)))) (*.f32 1/6 (*.f32 (pow.f32 (PI.f32) 2) (*.f32 (pow.f32 tau 2) (pow.f32 x 2)))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) |
Compiled 7708 to 1669 computations (78.3% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.4b | (*.f32 (PI.f32) (*.f32 tau x)) |
| ✓ | 0.4b | (*.f32 x (PI.f32)) |
| ✓ | 0.4b | (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))) |
| ✓ | 0.4b | (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) |
4 calls:
| 29.0ms | (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) |
| 9.0ms | (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))) |
| 6.0ms | (*.f32 (PI.f32) (*.f32 tau x)) |
| 5.0ms | (*.f32 x (PI.f32)) |
| 2× | batch-egg-rewrite |
| 763× | prod-diff_binary32 |
| 221× | log1p-udef_binary32 |
| 121× | add-sqr-sqrt_binary32 |
| 113× | egg-rr |
| 111× | add-log-exp_binary32 |
4 calls:
| 75.0ms | (*.f32 (PI.f32) (*.f32 tau x)) |
| 75.0ms | (*.f32 x (PI.f32)) |
| 75.0ms | (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))) |
| 75.0ms | (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 47 |
| 1 | 233 | 47 |
| 2 | 3286 | 47 |
| 3 | 5016 | 47 |
| 0 | 0 | 0 |
| 1 | 0 | 0 |
16 alts after pruning (16 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 184 | 3 | 187 |
| Fresh | 1 | 13 | 14 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 186 | 16 | 202 |
| Status | Error | Program |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) x))) 2) (sqrt.f32 (*.f32 (PI.f32) x))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) x))) (sqrt.f32 (*.f32 (PI.f32) x))))) | |
| ▶ | 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (*.f32 x (PI.f32)))) |
| 1.1b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 2)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (cbrt.f32 (*.f32 x (PI.f32)))))) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) (pow.f32 (cbrt.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) x)) (*.f32 (PI.f32) x))) 3)) | |
| 0.8b | (*.f32 (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)))) 1) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.0b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (pow.f32 (sqrt.f32 (*.f32 x (PI.f32))) 2))) | |
| 3.8b | (*.f32 (-.f32 (+.f32 1 (*.f32 1/120 (*.f32 (pow.f32 (PI.f32) 4) (*.f32 (pow.f32 tau 4) (pow.f32 x 4))))) (+.f32 (*.f32 1/5040 (*.f32 (pow.f32 (PI.f32) 6) (*.f32 (pow.f32 tau 6) (pow.f32 x 6)))) (*.f32 1/6 (*.f32 (pow.f32 (PI.f32) 2) (*.f32 (pow.f32 tau 2) (pow.f32 x 2)))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x)))) 2) (PI.f32)) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x)))) (*.f32 tau x))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.8b | (*.f32 (log.f32 (+.f32 1 (expm1.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)) 2)) (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (sqrt.f32 (sin.f32 (*.f32 x (PI.f32)))) (*.f32 (sqrt.f32 (sin.f32 (*.f32 x (PI.f32)))) (/.f32 1 (*.f32 x (PI.f32)))))) | |
| 5.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (-.f32 (exp.f32 (log1p.f32 (*.f32 x (PI.f32)))) 1) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 5.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (-.f32 (exp.f32 (log1p.f32 (*.f32 x (PI.f32)))) 1)) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 3) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))))) 1)) | |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) 2) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) |
Compiled 5793 to 1445 computations (75.1% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.4b | (*.f32 x (PI.f32)) |
| ✓ | 0.4b | (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (*.f32 x (PI.f32))) |
| ✓ | 0.4b | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| ✓ | 1.0b | (pow.f32 (PI.f32) 3) |
4 calls:
| 31.0ms | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| 20.0ms | (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (*.f32 x (PI.f32))) |
| 2.0ms | (*.f32 x (PI.f32)) |
| 0.0ms | (pow.f32 (PI.f32) 3) |
| 2× | batch-egg-rewrite |
| 828× | prod-diff_binary32 |
| 146× | add-sqr-sqrt_binary32 |
| 137× | add-cbrt-cube_binary32 |
| 137× | log1p-expm1-u_binary32 |
| 137× | expm1-log1p-u_binary32 |
4 calls:
| 78.0ms | (*.f32 x (PI.f32)) |
| 78.0ms | (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (*.f32 x (PI.f32))) |
| 78.0ms | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| 78.0ms | (pow.f32 (PI.f32) 3) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 15 | 44 |
| 1 | 301 | 44 |
| 2 | 3872 | 44 |
| 3 | 5265 | 44 |
| 0 | 0 | 0 |
| 1 | 0 | 0 |
17 alts after pruning (17 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 214 | 4 | 218 |
| Fresh | 2 | 13 | 15 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 217 | 17 | 234 |
| Status | Error | Program |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) x))) 2) (sqrt.f32 (*.f32 (PI.f32) x))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) x))) (sqrt.f32 (*.f32 (PI.f32) x))))) | |
| 1.1b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 2)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (cbrt.f32 (*.f32 x (PI.f32)))))) | |
| 0.8b | (*.f32 (log.f32 (+.f32 1 (expm1.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| ▶ | 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32)))) |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) (pow.f32 (cbrt.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) x)) (*.f32 (PI.f32) x))) 3)) | |
| 0.8b | (*.f32 (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)))) 1) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.0b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (pow.f32 (sqrt.f32 (*.f32 x (PI.f32))) 2))) | |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (*.f32 (pow.f32 (pow.f32 (cbrt.f32 (PI.f32)) 2) 3) (PI.f32))))) (*.f32 x (PI.f32)))) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (/.f32 (sqrt.f32 (sin.f32 (*.f32 (PI.f32) x))) 1) (/.f32 (sqrt.f32 (sin.f32 (*.f32 (PI.f32) x))) (*.f32 (PI.f32) x)))) | |
| 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))))) 1)) | |
| 3.8b | (*.f32 (-.f32 (+.f32 1 (*.f32 1/120 (*.f32 (pow.f32 (PI.f32) 4) (*.f32 (pow.f32 tau 4) (pow.f32 x 4))))) (+.f32 (*.f32 1/5040 (*.f32 (pow.f32 (PI.f32) 6) (*.f32 (pow.f32 tau 6) (pow.f32 x 6)))) (*.f32 1/6 (*.f32 (pow.f32 (PI.f32) 2) (*.f32 (pow.f32 tau 2) (pow.f32 x 2)))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x)))) 2) (PI.f32)) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x)))) (*.f32 tau x))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.1b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (pow.f32 (cbrt.f32 (*.f32 (PI.f32) x)) 3))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)) 2)) (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 5.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (-.f32 (exp.f32 (log1p.f32 (*.f32 x (PI.f32)))) 1) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 3) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) 2) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) |
Compiled 7391 to 2889 computations (60.9% saved)
Found 4 expressions with local error:
| New | Error | Program |
| ✓ | 0.4b | (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32))) |
| ✓ | 0.4b | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| ✓ | 1.0b | (log.f32 (PI.f32)) |
| ✓ | 1.6b | (exp.f32 (*.f32 3 (log.f32 (PI.f32)))) |
4 calls:
| 34.0ms | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| 18.0ms | (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32))) |
| 0.0ms | (exp.f32 (*.f32 3 (log.f32 (PI.f32)))) |
| 0.0ms | (log.f32 (PI.f32)) |
| 2× | batch-egg-rewrite |
| 828× | prod-diff_binary32 |
| 169× | add-sqr-sqrt_binary32 |
| 160× | add-cbrt-cube_binary32 |
| 160× | add-log-exp_binary32 |
| 160× | log1p-expm1-u_binary32 |
4 calls:
| 84.0ms | (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32))) |
| 84.0ms | (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) |
| 83.0ms | (log.f32 (PI.f32)) |
| 83.0ms | (exp.f32 (*.f32 3 (log.f32 (PI.f32)))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 56 |
| 1 | 349 | 43 |
| 2 | 4214 | 43 |
| 3 | 5597 | 43 |
| 0 | 0 | 0 |
| 1 | 0 | 0 |
17 alts after pruning (17 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 158 | 5 | 163 |
| Fresh | 4 | 12 | 16 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 163 | 17 | 180 |
| Status | Error | Program |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (PI.f32) (*.f32 tau x))) (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) x))) 2) (sqrt.f32 (*.f32 (PI.f32) x))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) x))) (sqrt.f32 (*.f32 (PI.f32) x))))) | |
| 0.9b | (*.f32 (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 (PI.f32) x) tau)) (*.f32 (PI.f32) x)) (/.f32 1 tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32)))) | |
| 0.9b | (*.f32 (log.f32 (exp.f32 (/.f32 (sin.f32 (*.f32 (*.f32 (PI.f32) x) tau)) (*.f32 (*.f32 (PI.f32) x) tau)))) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32)))) | |
| 1.1b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (PI.f32) 3)))) (pow.f32 (cbrt.f32 (*.f32 (PI.f32) x)) 3))) | |
| 0.8b | (*.f32 (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)))) 1) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (exp.f32 (*.f32 3 (-.f32 (exp.f32 (log1p.f32 (log.f32 (PI.f32)))) 1)))))) (*.f32 x (PI.f32)))) | |
| 1.0b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (pow.f32 (sqrt.f32 (*.f32 x (PI.f32))) 2))) | |
| 3.8b | (*.f32 (-.f32 (+.f32 1 (*.f32 1/120 (*.f32 (pow.f32 (PI.f32) 4) (*.f32 (pow.f32 tau 4) (pow.f32 x 4))))) (+.f32 (*.f32 1/5040 (*.f32 (pow.f32 (PI.f32) 6) (*.f32 (pow.f32 tau 6) (pow.f32 x 6)))) (*.f32 1/6 (*.f32 (pow.f32 (PI.f32) 2) (*.f32 (pow.f32 tau 2) (pow.f32 x 2)))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x)))) 2) (PI.f32)) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (PI.f32) (*.f32 tau x)))) (*.f32 tau x))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (pow.f32 (pow.f32 (PI.f32) 3) 3) 1/3)))) (*.f32 x (PI.f32)))) | |
| 0.8b | (*.f32 (log.f32 (+.f32 1 (expm1.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau))))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 1 (pow.f32 (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)) 2)) (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (cbrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 5.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (-.f32 (exp.f32 (log1p.f32 (*.f32 x (PI.f32)))) 1) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (/.f32 (sin.f32 (*.f32 (pow.f32 (cbrt.f32 (*.f32 x (PI.f32))) 3) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) | |
| 0.8b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (-.f32 (exp.f32 (log1p.f32 (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32))))) 1)) | |
| 0.9b | (*.f32 (/.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau)) (*.f32 (*.f32 x (PI.f32)) tau)) (/.f32 (sin.f32 (cbrt.f32 (*.f32 (pow.f32 x 3) (pow.f32 (exp.f32 1) (*.f32 3 (log.f32 (PI.f32))))))) (*.f32 x (PI.f32)))) | |
| 1.2b | (*.f32 (*.f32 (/.f32 (pow.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) 2) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (/.f32 (cbrt.f32 (sin.f32 (*.f32 (*.f32 x (PI.f32)) tau))) (sqrt.f32 (*.f32 (*.f32 x (PI.f32)) tau)))) (/.f32 (sin.f32 (*.f32 x (PI.f32))) (*.f32 x (PI.f32)))) |
Compiled 5554 to 2116 computations (61.9% saved)
Total 0.5b remaining (76.9%)
Threshold costs 0.5b (76.9%)
Compiled 47864 to 26236 computations (45.2% saved)
| 1× | egg-herbie |
| 4× | *-commutative_binary32 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 14 | 40 |
| 1 | 18 | 40 |
| 2 | 18 | 40 |
Compiled 606 to 341 computations (43.7% saved)
Loading profile data...