
Time bar (total: 2.0s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 100% | 99.9% | 0% | 0.1% | 0% | 0% | 0% | 1 |
Compiled 10 to 7 computations (30% saved)
| 519.0ms | 6228× | body | 256 | valid |
| 160.0ms | 2028× | body | 256 | infinite |
| 1× | egg-herbie |
| 894× | fma-def |
| 142× | unsub-neg |
| 130× | associate-*r* |
| 98× | distribute-lft-in |
| 78× | associate-*l* |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 19 | 80 |
| 1 | 42 | 72 |
| 2 | 100 | 72 |
| 3 | 291 | 72 |
| 4 | 649 | 72 |
| 5 | 1053 | 72 |
| 6 | 1203 | 72 |
| 7 | 1214 | 72 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 1/2 (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) y)) |
(*.f64 1/2 (-.f64 (*.f64 x x) (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 y y) x)) |
| Outputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 1/2 (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) y)) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 1/2 (-.f64 (*.f64 x x) (neg.f64 y))) |
(*.f64 1/2 (fma.f64 x x y)) |
(*.f64 1/2 (-.f64 (*.f64 y y) x)) |
(abs x)
Compiled 11 to 8 computations (27.3% saved)
| 1× | egg-herbie |
| 630× | fma-def |
| 76× | distribute-lft-in |
| 74× | unsub-neg |
| 68× | distribute-rgt-in |
| 56× | distribute-lft-neg-in |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 19 |
| 1 | 14 | 19 |
| 2 | 25 | 19 |
| 3 | 49 | 19 |
| 4 | 84 | 19 |
| 5 | 116 | 19 |
| 6 | 207 | 19 |
| 7 | 345 | 19 |
| 8 | 558 | 19 |
| 9 | 725 | 19 |
| 10 | 824 | 19 |
| 11 | 840 | 19 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| Outputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
Compiled 9 to 6 computations (33.3% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 1 | 1 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 2 | 2 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ▶ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
Compiled 18 to 12 computations (33.3% saved)
Found 1 expressions with local accuracy:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
Compiled 21 to 8 computations (61.9% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | inf | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 0.0ms | x | @ | 0 | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 0.0ms | y | @ | -inf | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 0.0ms | y | @ | 0 | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 0.0ms | y | @ | inf | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 1× | batch-egg-rewrite |
| 1760× | pow1 |
| 1634× | add-exp-log |
| 1634× | log1p-expm1-u |
| 1634× | expm1-log1p-u |
| 1600× | add-log-exp |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 19 |
| 1 | 173 | 19 |
| 2 | 2235 | 19 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| Outputs |
|---|
(+.f64 (*.f64 1/2 (*.f64 x x)) (*.f64 1/2 (neg.f64 y))) |
(+.f64 (*.f64 (*.f64 x x) 1/2) (*.f64 (neg.f64 y) 1/2)) |
(-.f64 (+.f64 1 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 1) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 6) (pow.f64 y 3))) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 4) (*.f64 y y))) (fma.f64 x x y)) |
(/.f64 (*.f64 (-.f64 (pow.f64 x 6) (pow.f64 y 3)) 1/2) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x 4) (*.f64 y y)) 1/2) (fma.f64 x x y)) |
(pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 1) |
(pow.f64 (cbrt.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 3) |
(pow.f64 (pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 3) 1/3) |
(pow.f64 (sqrt.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 2) |
(sqrt.f64 (*.f64 1/4 (pow.f64 (-.f64 (*.f64 x x) y) 2))) |
(log.f64 (pow.f64 (exp.f64 1/2) (-.f64 (*.f64 x x) y))) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(exp.f64 (log.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
| 1× | egg-herbie |
| 1494× | fma-def |
| 1202× | log-prod |
| 744× | associate-*r* |
| 620× | associate-*l* |
| 538× | unsub-neg |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 68 | 867 |
| 1 | 169 | 793 |
| 2 | 490 | 793 |
| 3 | 2912 | 793 |
| 4 | 6138 | 793 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 -1/2 y) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(*.f64 1/2 (pow.f64 x 2)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(*.f64 1/2 (pow.f64 x 2)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(*.f64 1/2 (pow.f64 x 2)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(*.f64 -1/2 y) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(*.f64 -1/2 y) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(+.f64 (*.f64 1/2 (*.f64 x x)) (*.f64 1/2 (neg.f64 y))) |
(+.f64 (*.f64 (*.f64 x x) 1/2) (*.f64 (neg.f64 y) 1/2)) |
(-.f64 (+.f64 1 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 1) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 6) (pow.f64 y 3))) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 4) (*.f64 y y))) (fma.f64 x x y)) |
(/.f64 (*.f64 (-.f64 (pow.f64 x 6) (pow.f64 y 3)) 1/2) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x 4) (*.f64 y y)) 1/2) (fma.f64 x x y)) |
(pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 1) |
(pow.f64 (cbrt.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 3) |
(pow.f64 (pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 3) 1/3) |
(pow.f64 (sqrt.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 2) |
(sqrt.f64 (*.f64 1/4 (pow.f64 (-.f64 (*.f64 x x) y) 2))) |
(log.f64 (pow.f64 (exp.f64 1/2) (-.f64 (*.f64 x x) y))) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(exp.f64 (log.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
| Outputs |
|---|
(*.f64 -1/2 y) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 -1/2 y) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(*.f64 -1/2 y) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 -1/2 y) (*.f64 1/2 (pow.f64 x 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 1/2 (*.f64 x x)) (*.f64 1/2 (neg.f64 y))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(+.f64 (*.f64 (*.f64 x x) 1/2) (*.f64 (neg.f64 y) 1/2)) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(-.f64 (+.f64 1 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 1) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 6) (pow.f64 y 3))) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(*.f64 (/.f64 1/2 (fma.f64 y (fma.f64 x x y) (pow.f64 x 4))) (-.f64 (pow.f64 x 6) (pow.f64 y 3))) |
(*.f64 1/2 (/.f64 (-.f64 (pow.f64 x 6) (pow.f64 y 3)) (fma.f64 y (fma.f64 x x y) (pow.f64 x 4)))) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 4) (*.f64 y y))) (fma.f64 x x y)) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(/.f64 (*.f64 (-.f64 (pow.f64 x 6) (pow.f64 y 3)) 1/2) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(/.f64 (*.f64 1/2 (-.f64 (pow.f64 x 6) (pow.f64 y 3))) (+.f64 (pow.f64 x 4) (*.f64 y (fma.f64 x x y)))) |
(*.f64 (/.f64 1/2 (fma.f64 y (fma.f64 x x y) (pow.f64 x 4))) (-.f64 (pow.f64 x 6) (pow.f64 y 3))) |
(*.f64 1/2 (/.f64 (-.f64 (pow.f64 x 6) (pow.f64 y 3)) (fma.f64 y (fma.f64 x x y) (pow.f64 x 4)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x 4) (*.f64 y y)) 1/2) (fma.f64 x x y)) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 1) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(pow.f64 (cbrt.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 3) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(pow.f64 (pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 3) 1/3) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(pow.f64 (sqrt.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y))) 2) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(sqrt.f64 (*.f64 1/4 (pow.f64 (-.f64 (*.f64 x x) y) 2))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(log.f64 (pow.f64 (exp.f64 1/2) (-.f64 (*.f64 x x) y))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)) 3)) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(exp.f64 (log.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (-.f64 (*.f64 x x) y)))) |
(fma.f64 -1/2 y (*.f64 1/2 (*.f64 x x))) |
(*.f64 1/2 (fma.f64 x x (neg.f64 y))) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
Compiled 279 to 150 computations (46.2% saved)
3 alts after pruning (2 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 24 | 2 | 26 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 24 | 3 | 27 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ▶ | 48.9% | (*.f64 1/2 (*.f64 x x)) |
| ▶ | 53.4% | (*.f64 -1/2 y) |
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ▶ | 48.9% | (*.f64 1/2 (*.f64 x x)) |
| ▶ | 53.4% | (*.f64 -1/2 y) |
Compiled 42 to 30 computations (28.6% saved)
Found 1 expressions with local accuracy:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 99.7% | (*.f64 1/2 (*.f64 x x)) |
Compiled 18 to 10 computations (44.4% saved)
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | inf | (*.f64 1/2 (*.f64 x x)) |
| 0.0ms | x | @ | 0 | (*.f64 1/2 (*.f64 x x)) |
| 0.0ms | x | @ | -inf | (*.f64 1/2 (*.f64 x x)) |
| 1× | batch-egg-rewrite |
| 1058× | pow1 |
| 1024× | add-sqr-sqrt |
| 976× | add-exp-log |
| 976× | log1p-expm1-u |
| 976× | expm1-log1p-u |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 13 |
| 1 | 122 | 13 |
| 2 | 1383 | 13 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 1/2 (*.f64 x x)) |
| Outputs |
|---|
(-.f64 (+.f64 1 (*.f64 1/2 (*.f64 x x))) 1) |
(pow.f64 (*.f64 1/2 (*.f64 x x)) 1) |
(pow.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) 3) |
(pow.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3) 1/3) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
(sqrt.f64 (*.f64 1/4 (pow.f64 x 4))) |
(log.f64 (pow.f64 (exp.f64 1/2) (*.f64 x x))) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (*.f64 x x)))) |
(exp.f64 (log.f64 (*.f64 1/2 (*.f64 x x)))) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (*.f64 x x)))) |
| 1× | egg-herbie |
| 2120× | log-prod |
| 1106× | distribute-rgt-in |
| 1092× | distribute-lft-in |
| 768× | associate-*r* |
| 688× | associate-*l* |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 38 | 299 |
| 1 | 90 | 299 |
| 2 | 319 | 299 |
| 3 | 2131 | 299 |
| 4 | 7005 | 299 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (pow.f64 x 2)) |
(-.f64 (+.f64 1 (*.f64 1/2 (*.f64 x x))) 1) |
(pow.f64 (*.f64 1/2 (*.f64 x x)) 1) |
(pow.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) 3) |
(pow.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3) 1/3) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
(sqrt.f64 (*.f64 1/4 (pow.f64 x 4))) |
(log.f64 (pow.f64 (exp.f64 1/2) (*.f64 x x))) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (*.f64 x x)))) |
(exp.f64 (log.f64 (*.f64 1/2 (*.f64 x x)))) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (*.f64 x x)))) |
| Outputs |
|---|
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 1/2 (pow.f64 x 2)) |
(*.f64 1/2 (*.f64 x x)) |
(-.f64 (+.f64 1 (*.f64 1/2 (*.f64 x x))) 1) |
(*.f64 1/2 (*.f64 x x)) |
(pow.f64 (*.f64 1/2 (*.f64 x x)) 1) |
(*.f64 1/2 (*.f64 x x)) |
(pow.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) 3) |
(*.f64 1/2 (*.f64 x x)) |
(pow.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3) 1/3) |
(*.f64 1/2 (*.f64 x x)) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
(*.f64 1/2 (*.f64 x x)) |
(sqrt.f64 (*.f64 1/4 (pow.f64 x 4))) |
(*.f64 1/2 (*.f64 x x)) |
(log.f64 (pow.f64 (exp.f64 1/2) (*.f64 x x))) |
(*.f64 1/2 (*.f64 x x)) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3)) |
(*.f64 1/2 (*.f64 x x)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 1/2 (*.f64 x x)) |
(exp.f64 (log.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 1/2 (*.f64 x x)) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 1/2 (*.f64 x x)) |
Compiled 93 to 61 computations (34.4% saved)
4 alts after pruning (1 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 12 | 1 | 13 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 1 | 1 |
| Total | 12 | 4 | 16 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 48.9% | (pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ✓ | 48.9% | (*.f64 1/2 (*.f64 x x)) |
| ✓ | 53.4% | (*.f64 -1/2 y) |
| ▶ | 48.9% | (pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ✓ | 48.9% | (*.f64 1/2 (*.f64 x x)) |
| ✓ | 53.4% | (*.f64 -1/2 y) |
Compiled 58 to 44 computations (24.1% saved)
Found 2 expressions with local accuracy:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 99.6% | (pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| ✓ | 99.3% | (*.f64 x (sqrt.f64 1/2)) |
Compiled 18 to 15 computations (16.7% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | (*.f64 x (sqrt.f64 1/2)) |
| 1.0ms | x | @ | 0 | (*.f64 x (sqrt.f64 1/2)) |
| 0.0ms | x | @ | -inf | (pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| 0.0ms | x | @ | inf | (*.f64 x (sqrt.f64 1/2)) |
| 0.0ms | x | @ | 0 | (pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| 1× | batch-egg-rewrite |
| 1456× | pow1 |
| 1338× | add-exp-log |
| 1338× | log1p-expm1-u |
| 1338× | expm1-log1p-u |
| 1306× | add-log-exp |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 28 |
| 1 | 184 | 24 |
| 2 | 1958 | 24 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 x (sqrt.f64 1/2)) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| Outputs |
|---|
(-.f64 (+.f64 1 (*.f64 x (sqrt.f64 1/2))) 1) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 1) |
(pow.f64 (*.f64 1/2 (*.f64 x x)) 1/2) |
(pow.f64 (cbrt.f64 (*.f64 x (sqrt.f64 1/2))) 3) |
(pow.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 3) 1/3) |
(pow.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) 2) |
(sqrt.f64 (*.f64 1/2 (*.f64 x x))) |
(fabs.f64 (*.f64 x (sqrt.f64 1/2))) |
(log.f64 (pow.f64 (exp.f64 x) (sqrt.f64 1/2))) |
(cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 x (sqrt.f64 1/2)))) |
(exp.f64 (log.f64 (*.f64 x (sqrt.f64 1/2)))) |
(log1p.f64 (expm1.f64 (*.f64 x (sqrt.f64 1/2)))) |
(-.f64 (+.f64 1 (*.f64 1/2 (*.f64 x x))) 1) |
(*.f64 x (*.f64 (sqrt.f64 1/2) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (sqrt.f64 1/2) (*.f64 x (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (*.f64 x (sqrt.f64 1/2)) (*.f64 x (sqrt.f64 1/2))) |
(*.f64 (*.f64 1/2 (*.f64 x x)) 1) |
(*.f64 1 (*.f64 1/2 (*.f64 x x))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (*.f64 (cbrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4)) (cbrt.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 (*.f64 x x) 1/2) |
(*.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (sqrt.f64 (*.f64 x (sqrt.f64 1/2)))) (sqrt.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) x) (sqrt.f64 1/2)) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (sqrt.f64 1/2)) x) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (cbrt.f64 (*.f64 1/2 (*.f64 x x)))) (cbrt.f64 (*.f64 x (sqrt.f64 1/2)))) |
(sqrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4)) |
(log.f64 (pow.f64 (exp.f64 (*.f64 x x)) 1/2)) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (*.f64 x x)))) |
(exp.f64 (log.f64 (*.f64 1/2 (*.f64 x x)))) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (*.f64 x x)))) |
| 1× | egg-herbie |
| 1238× | fma-def |
| 1214× | distribute-rgt-in |
| 1210× | distribute-lft-in |
| 1080× | log-prod |
| 600× | associate-+r+ |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 79 | 1097 |
| 1 | 193 | 777 |
| 2 | 677 | 769 |
| 3 | 2251 | 769 |
| 4 | 7376 | 769 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(-.f64 (+.f64 1 (*.f64 x (sqrt.f64 1/2))) 1) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 1) |
(pow.f64 (*.f64 1/2 (*.f64 x x)) 1/2) |
(pow.f64 (cbrt.f64 (*.f64 x (sqrt.f64 1/2))) 3) |
(pow.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 3) 1/3) |
(pow.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) 2) |
(sqrt.f64 (*.f64 1/2 (*.f64 x x))) |
(fabs.f64 (*.f64 x (sqrt.f64 1/2))) |
(log.f64 (pow.f64 (exp.f64 x) (sqrt.f64 1/2))) |
(cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 x (sqrt.f64 1/2)))) |
(exp.f64 (log.f64 (*.f64 x (sqrt.f64 1/2)))) |
(log1p.f64 (expm1.f64 (*.f64 x (sqrt.f64 1/2)))) |
(-.f64 (+.f64 1 (*.f64 1/2 (*.f64 x x))) 1) |
(*.f64 x (*.f64 (sqrt.f64 1/2) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (sqrt.f64 1/2) (*.f64 x (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (*.f64 x (sqrt.f64 1/2)) (*.f64 x (sqrt.f64 1/2))) |
(*.f64 (*.f64 1/2 (*.f64 x x)) 1) |
(*.f64 1 (*.f64 1/2 (*.f64 x x))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (*.f64 (cbrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4)) (cbrt.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 (*.f64 x x) 1/2) |
(*.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (sqrt.f64 (*.f64 x (sqrt.f64 1/2)))) (sqrt.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) x) (sqrt.f64 1/2)) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (sqrt.f64 1/2)) x) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (cbrt.f64 (*.f64 1/2 (*.f64 x x)))) (cbrt.f64 (*.f64 x (sqrt.f64 1/2)))) |
(sqrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4)) |
(log.f64 (pow.f64 (exp.f64 (*.f64 x x)) 1/2)) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3)) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (*.f64 x x)))) |
(exp.f64 (log.f64 (*.f64 1/2 (*.f64 x x)))) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (*.f64 x x)))) |
| Outputs |
|---|
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (sqrt.f64 1/2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (pow.f64 (sqrt.f64 1/2) 2) (pow.f64 x 2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(-.f64 (+.f64 1 (*.f64 x (sqrt.f64 1/2))) 1) |
(*.f64 (sqrt.f64 1/2) x) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 1) |
(*.f64 (sqrt.f64 1/2) x) |
(pow.f64 (*.f64 1/2 (*.f64 x x)) 1/2) |
(*.f64 (sqrt.f64 1/2) x) |
(pow.f64 (cbrt.f64 (*.f64 x (sqrt.f64 1/2))) 3) |
(*.f64 (sqrt.f64 1/2) x) |
(pow.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 3) 1/3) |
(*.f64 (sqrt.f64 1/2) x) |
(pow.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) 2) |
(*.f64 (sqrt.f64 1/2) x) |
(sqrt.f64 (*.f64 1/2 (*.f64 x x))) |
(*.f64 (sqrt.f64 1/2) x) |
(fabs.f64 (*.f64 x (sqrt.f64 1/2))) |
(*.f64 (sqrt.f64 1/2) x) |
(log.f64 (pow.f64 (exp.f64 x) (sqrt.f64 1/2))) |
(*.f64 (sqrt.f64 1/2) x) |
(cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 3)) |
(*.f64 (sqrt.f64 1/2) x) |
(expm1.f64 (log1p.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (sqrt.f64 1/2) x) |
(exp.f64 (log.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (sqrt.f64 1/2) x) |
(log1p.f64 (expm1.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 (sqrt.f64 1/2) x) |
(-.f64 (+.f64 1 (*.f64 1/2 (*.f64 x x))) 1) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 x (*.f64 (sqrt.f64 1/2) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (sqrt.f64 1/2) (*.f64 x (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (*.f64 x (sqrt.f64 1/2)) (*.f64 x (sqrt.f64 1/2))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (*.f64 1/2 (*.f64 x x)) 1) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 1 (*.f64 1/2 (*.f64 x x))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 1/2) x) 4))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (*.f64 1/4 (pow.f64 x 4)))) |
(*.f64 (cbrt.f64 (*.f64 1/4 (pow.f64 x 4))) (cbrt.f64 (*.f64 (/.f64 x 2) x))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (*.f64 (cbrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4)) (cbrt.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 1/2) x) 4))) |
(*.f64 (cbrt.f64 (*.f64 1/2 (*.f64 x x))) (cbrt.f64 (*.f64 1/4 (pow.f64 x 4)))) |
(*.f64 (cbrt.f64 (*.f64 1/4 (pow.f64 x 4))) (cbrt.f64 (*.f64 (/.f64 x 2) x))) |
(*.f64 (*.f64 x x) 1/2) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 (sqrt.f64 (*.f64 x (sqrt.f64 1/2))) (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (sqrt.f64 (*.f64 x (sqrt.f64 1/2)))) (sqrt.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) x) (sqrt.f64 1/2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (sqrt.f64 1/2)) x) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 (*.f64 (*.f64 x (sqrt.f64 1/2)) (cbrt.f64 (*.f64 1/2 (*.f64 x x)))) (cbrt.f64 (*.f64 x (sqrt.f64 1/2)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(sqrt.f64 (pow.f64 (*.f64 x (sqrt.f64 1/2)) 4)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(log.f64 (pow.f64 (exp.f64 (*.f64 x x)) 1/2)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(cbrt.f64 (pow.f64 (*.f64 1/2 (*.f64 x x)) 3)) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(expm1.f64 (log1p.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(exp.f64 (log.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(log1p.f64 (expm1.f64 (*.f64 1/2 (*.f64 x x)))) |
(*.f64 x (*.f64 x (pow.f64 (sqrt.f64 1/2) 2))) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
Compiled 395 to 297 computations (24.8% saved)
3 alts after pruning (1 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 41 | 1 | 42 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 1 | 2 | 3 |
| Total | 43 | 3 | 46 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 49.2% | (*.f64 (/.f64 x 2) x) |
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ✓ | 53.4% | (*.f64 -1/2 y) |
| ▶ | 49.2% | (*.f64 (/.f64 x 2) x) |
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ✓ | 53.4% | (*.f64 -1/2 y) |
Compiled 42 to 30 computations (28.6% saved)
Compiled 13 to 9 computations (30.8% saved)
Compiled 2 to 2 computations (0% saved)
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 0 | 3 | 3 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 49.2% | (*.f64 (/.f64 x 2) x) |
| ✓ | 99.7% | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| ✓ | 53.4% | (*.f64 -1/2 y) |
Compiled 49 to 33 computations (32.7% saved)
| Inputs |
|---|
(*.f64 -1/2 y) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(pow.f64 (*.f64 x (sqrt.f64 1/2)) 2) |
| Outputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
5 calls:
| 6.0ms | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 4.0ms | y |
| 4.0ms | x |
| 4.0ms | (-.f64 (*.f64 x x) y) |
| 3.0ms | (*.f64 x x) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.7% | 1 | x |
| 99.7% | 1 | y |
| 99.7% | 1 | (*.f64 1/2 (-.f64 (*.f64 x x) y)) |
| 99.7% | 1 | (-.f64 (*.f64 x x) y) |
| 99.7% | 1 | (*.f64 x x) |
Compiled 55 to 35 computations (36.4% saved)
| Inputs |
|---|
(*.f64 -1/2 y) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 (/.f64 x 2) x) |
| Outputs |
|---|
(*.f64 -1/2 y) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 -1/2 y) |
(*.f64 (/.f64 x 2) x) |
3 calls:
| 29.0ms | y |
| 12.0ms | x |
| 9.0ms | (*.f64 x x) |
| Accuracy | Segments | Branch |
|---|---|---|
| 91.0% | 4 | x |
| 71.2% | 9 | y |
| 91.0% | 4 | (*.f64 x x) |
Compiled 26 to 17 computations (34.6% saved)
| Inputs |
|---|
(*.f64 -1/2 y) |
(*.f64 1/2 (*.f64 x x)) |
| Outputs |
|---|
(*.f64 -1/2 y) |
(*.f64 1/2 (*.f64 x x)) |
(*.f64 -1/2 y) |
(*.f64 1/2 (*.f64 x x)) |
2 calls:
| 17.0ms | x |
| 8.0ms | (*.f64 x x) |
| Accuracy | Segments | Branch |
|---|---|---|
| 90.7% | 4 | x |
| 90.7% | 4 | (*.f64 x x) |
Compiled 18 to 12 computations (33.3% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
(*.f64 -1/2 y) |
| Outputs |
|---|
(*.f64 -1/2 y) |
2 calls:
| 2.0ms | x |
| 2.0ms | y |
| Accuracy | Segments | Branch |
|---|---|---|
| 53.4% | 1 | y |
| 53.4% | 1 | x |
Compiled 11 to 8 computations (27.3% saved)
| 3× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 17193326297930520.0 | 3147758247340835300.0 |
| 0.0ms | 1.0026909637436216e-45 | 3.263820038138693e-40 |
| 0.0ms | 8.02840343007452e-104 | 1.296503049645665e-103 |
Compiled 14 to 10 computations (28.6% saved)
| 3× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 10.0ms | 17193326297930520.0 | 3147758247340835300.0 |
| 13.0ms | 1.0026909637436216e-45 | 3.263820038138693e-40 |
| 7.0ms | 8.02840343007452e-104 | 1.296503049645665e-103 |
| 26.0ms | 320× | body | 256 | valid |
Compiled 254 to 210 computations (17.3% saved)
| 1× | egg-herbie |
| 10× | *-commutative |
| 4× | sub-neg |
| 4× | not-or |
| 4× | +-commutative |
| 4× | if-if-or-not |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 35 | 190 |
| 1 | 47 | 190 |
| 2 | 55 | 190 |
| 3 | 60 | 186 |
| 4 | 62 | 186 |
| 5 | 63 | 186 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(if (<=.f64 (*.f64 x x) 8069530869021589/80695308690215893426747474125094121072803306025913234775958104891895238188026287332176417290004307232371974124148359168) (*.f64 -1/2 y) (if (<=.f64 (*.f64 x x) 6427752177035961/3213876088517980551083924184682325205044405987565585670602752) (*.f64 1/2 (*.f64 x x)) (if (<=.f64 (*.f64 x x) 20000000000000000) (*.f64 -1/2 y) (*.f64 (/.f64 x 2) x)))) |
(if (<=.f64 (*.f64 x x) 2420859260706477/20173827172553973356686868531273530268200826506478308693989526222973809547006571833044104322501076808092993531037089792) (*.f64 -1/2 y) (if (<=.f64 (*.f64 x x) 2812141577453233/1606938044258990275541962092341162602522202993782792835301376) (*.f64 1/2 (*.f64 x x)) (if (<=.f64 (*.f64 x x) 410000000000000000) (*.f64 -1/2 y) (*.f64 1/2 (*.f64 x x))))) |
(*.f64 -1/2 y) |
| Outputs |
|---|
(*.f64 1/2 (-.f64 (*.f64 x x) y)) |
(if (<=.f64 (*.f64 x x) 8069530869021589/80695308690215893426747474125094121072803306025913234775958104891895238188026287332176417290004307232371974124148359168) (*.f64 -1/2 y) (if (<=.f64 (*.f64 x x) 6427752177035961/3213876088517980551083924184682325205044405987565585670602752) (*.f64 1/2 (*.f64 x x)) (if (<=.f64 (*.f64 x x) 20000000000000000) (*.f64 -1/2 y) (*.f64 (/.f64 x 2) x)))) |
(if (<=.f64 (*.f64 x x) 8069530869021589/80695308690215893426747474125094121072803306025913234775958104891895238188026287332176417290004307232371974124148359168) (*.f64 y -1/2) (if (<=.f64 (*.f64 x x) 6427752177035961/3213876088517980551083924184682325205044405987565585670602752) (*.f64 1/2 (*.f64 x x)) (if (<=.f64 (*.f64 x x) 20000000000000000) (*.f64 y -1/2) (*.f64 x (/.f64 x 2))))) |
(if (<=.f64 (*.f64 x x) 2420859260706477/20173827172553973356686868531273530268200826506478308693989526222973809547006571833044104322501076808092993531037089792) (*.f64 -1/2 y) (if (<=.f64 (*.f64 x x) 2812141577453233/1606938044258990275541962092341162602522202993782792835301376) (*.f64 1/2 (*.f64 x x)) (if (<=.f64 (*.f64 x x) 410000000000000000) (*.f64 -1/2 y) (*.f64 1/2 (*.f64 x x))))) |
(if (<=.f64 (*.f64 x x) 2420859260706477/20173827172553973356686868531273530268200826506478308693989526222973809547006571833044104322501076808092993531037089792) (*.f64 y -1/2) (if (or (<=.f64 (*.f64 x x) 2812141577453233/1606938044258990275541962092341162602522202993782792835301376) (not (<=.f64 (*.f64 x x) 410000000000000000))) (*.f64 1/2 (*.f64 x x)) (*.f64 y -1/2))) |
(if (or (<=.f64 (*.f64 x x) 2420859260706477/20173827172553973356686868531273530268200826506478308693989526222973809547006571833044104322501076808092993531037089792) (and (not (<=.f64 (*.f64 x x) 2812141577453233/1606938044258990275541962092341162602522202993782792835301376)) (<=.f64 (*.f64 x x) 410000000000000000))) (*.f64 y -1/2) (*.f64 1/2 (*.f64 x x))) |
(*.f64 -1/2 y) |
(*.f64 y -1/2) |
Compiled 79 to 48 computations (39.2% saved)
| 1494× | fma-def |
| 1238× | fma-def |
| 1214× | distribute-rgt-in |
| 1210× | distribute-lft-in |
| 1202× | log-prod |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 68 | 867 |
| 1 | 169 | 793 |
| 2 | 490 | 793 |
| 3 | 2912 | 793 |
| 4 | 6138 | 793 |
| 0 | 6 | 13 |
| 1 | 122 | 13 |
| 2 | 1383 | 13 |
| 0 | 79 | 1097 |
| 1 | 193 | 777 |
| 2 | 677 | 769 |
| 3 | 2251 | 769 |
| 4 | 7376 | 769 |
| 1× | node limit |
| 1× | node limit |
| 1× | node limit |
Compiled 207 to 136 computations (34.3% saved)
(abs x)
Compiled 182 to 104 computations (42.9% saved)
Loading profile data...