
Time bar (total: 1.4s)
| 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 6 computations (40% saved)
ival-add: 0.0ms (0% of total)ival-mult: 0.0ms (0% of total)const: 0.0ms (0% of total)| 641.0ms | 7251× | 0 | valid |
| 128.0ms | 1005× | 0 | infinite |
ival-add: 146.0ms (62.7% of total)ival-mult: 75.0ms (32.2% of total)const: 8.0ms (3.4% of total)backward-pass: 4.0ms (1.7% of total)| 1× | egg-herbie |
| 569× | fma-neg |
| 422× | fma-define |
| 84× | cancel-sign-sub-inv |
| 77× | unsub-neg |
| 69× | distribute-rgt-in |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 24 | 221 |
| 1 | 70 | 209 |
| 2 | 201 | 177 |
| 3 | 660 | 171 |
| 4 | 1501 | 168 |
| 5 | 2144 | 168 |
| 6 | 2257 | 168 |
| 7 | 2261 | 168 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 x y) x) y) |
(+.f64 (+.f64 (*.f64 x y) x) y) |
(+.f64 (+.f64 (*.f64 (neg.f64 x) y) (neg.f64 x)) y) |
(+.f64 (+.f64 (*.f64 x (neg.f64 y)) x) (neg.f64 y)) |
(neg.f64 (+.f64 (+.f64 (*.f64 (neg.f64 x) y) (neg.f64 x)) y)) |
(neg.f64 (+.f64 (+.f64 (*.f64 x (neg.f64 y)) x) (neg.f64 y))) |
(+.f64 (+.f64 (*.f64 y x) y) x) |
| Outputs |
|---|
(+.f64 (+.f64 (*.f64 x y) x) y) |
(+.f64 y (fma.f64 x y x)) |
(+.f64 x (fma.f64 x y y)) |
(fma.f64 (+.f64 y #s(literal 1 binary64)) x y) |
(fma.f64 x (+.f64 y #s(literal 1 binary64)) y) |
(+.f64 (+.f64 (*.f64 x y) x) y) |
(+.f64 y (fma.f64 x y x)) |
(+.f64 x (fma.f64 x y y)) |
(fma.f64 (+.f64 y #s(literal 1 binary64)) x y) |
(fma.f64 x (+.f64 y #s(literal 1 binary64)) y) |
(+.f64 (+.f64 (*.f64 (neg.f64 x) y) (neg.f64 x)) y) |
(+.f64 y (-.f64 (*.f64 x (neg.f64 y)) x)) |
(+.f64 y (neg.f64 (fma.f64 x y x))) |
(fma.f64 x (-.f64 #s(literal -1 binary64) y) y) |
(+.f64 (+.f64 (*.f64 x (neg.f64 y)) x) (neg.f64 y)) |
(-.f64 (fma.f64 x (neg.f64 y) x) y) |
(-.f64 (-.f64 x (*.f64 x y)) y) |
(-.f64 x (fma.f64 x y y)) |
(fma.f64 y (-.f64 #s(literal -1 binary64) x) x) |
(neg.f64 (+.f64 (+.f64 (*.f64 (neg.f64 x) y) (neg.f64 x)) y)) |
(neg.f64 (+.f64 y (-.f64 (*.f64 x (neg.f64 y)) x))) |
(-.f64 (neg.f64 y) (neg.f64 (fma.f64 x y x))) |
(-.f64 (fma.f64 x y x) y) |
(fma.f64 x y (-.f64 x y)) |
(fma.f64 y (+.f64 x #s(literal -1 binary64)) x) |
(neg.f64 (+.f64 (+.f64 (*.f64 x (neg.f64 y)) x) (neg.f64 y))) |
(neg.f64 (-.f64 (fma.f64 x (neg.f64 y) x) y)) |
(-.f64 y (-.f64 x (*.f64 x y))) |
(-.f64 (fma.f64 x y y) x) |
(fma.f64 (+.f64 y #s(literal -1 binary64)) x y) |
(fma.f64 x (+.f64 y #s(literal -1 binary64)) y) |
(+.f64 (+.f64 (*.f64 y x) y) x) |
(+.f64 y (fma.f64 x y x)) |
(+.f64 x (fma.f64 x y y)) |
(fma.f64 (+.f64 y #s(literal 1 binary64)) x y) |
(fma.f64 x (+.f64 y #s(literal 1 binary64)) y) |
(sort x y)
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 0 | 0 | - | 0 | - | (*.f64 x y) |
| 0 | 0 | - | 0 | - | x |
| 0 | 0 | - | 0 | - | (+.f64 (+.f64 (*.f64 x y) x) y) |
| 0 | 0 | - | 0 | - | (+.f64 (*.f64 x y) x) |
| 0 | 0 | - | 0 | - | y |
| 118.0ms | 444× | 256 | valid |
| 8.0ms | 68× | 256 | infinite |
Compiled 49 to 17 computations (65.3% saved)
ival-add: 7.0ms (61.1% of total)ival-mult: 4.0ms (34.9% of total)const: 0.0ms (0% of total)Compiled 26 to 12 computations (53.8% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (+.f64 (+.f64 (*.f64 x y) x) y) |
Compiled 9 to 5 computations (44.4% saved)
| 20.0ms | 222× | 256 | valid |
| 3.0ms | 34× | 256 | infinite |
Compiled 20 to 6 computations (70% saved)
ival-add: 3.0ms (50.5% of total)ival-mult: 3.0ms (50.5% of total)const: 0.0ms (0% of total)Compiled 2 to 2 computations (0% saved)
1 alts after pruning (0 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 0 | 1 | 1 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (+.f64 (+.f64 (*.f64 x y) x) y) |
Compiled 18 to 10 computations (44.4% saved)
| 1× | egg-herbie |
| 2× | +-commutative |
| 1× | *-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 31 |
| 1 | 13 | 31 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 x y) x) y) |
| Outputs |
|---|
(+.f64 (+.f64 (*.f64 x y) x) y) |
(+.f64 y (+.f64 x (*.f64 x y))) |
| 1× | done |
Compiled 9 to 5 computations (44.4% saved)
(sort x y)
Compiled 72 to 40 computations (44.4% saved)
Loading profile data...