
Time bar (total: 1.2s)
| 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 11 to 7 computations (36.4% saved)
ival-add, time spent: 0.0ms, 0.0% of total-timeival-mult, time spent: 0.0ms, 0.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 525.0ms | 6526× | 256 | valid |
| 139.0ms | 1729× | 256 | infinite |
| 0.0ms | 1× | 256 | infinite |
ival-mult, time spent: 126.0ms, 67.0% of total-timeival-add, time spent: 54.0ms, 29.0% of total-timeconst, time spent: 8.0ms, 4.0% of total-time| 1× | egg-herbie |
| 329× | fma-define |
| 268× | fma-neg |
| 79× | unsub-neg |
| 69× | associate-*l* |
| 60× | associate-*r* |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 6 | 0 | - | 0 | - | (+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
| 0 | 0 | - | 0 | - | (*.f64 d1 d3) |
| 0 | 0 | - | 0 | - | (*.f64 d1 d2) |
| 0 | 0 | - | 0 | - | d3 |
| 0 | 0 | - | 0 | - | d1 |
| 0 | 0 | - | 0 | - | d2 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 33 | 262 |
| 1 | 92 | 250 |
| 2 | 224 | 246 |
| 3 | 543 | 246 |
| 4 | 1018 | 246 |
| 5 | 1573 | 246 |
| 6 | 1676 | 246 |
| 7 | 1678 | 246 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
(+.f64 (*.f64 (neg.f64 d1) d2) (*.f64 (neg.f64 d1) d3)) |
(+.f64 (*.f64 d1 (neg.f64 d2)) (*.f64 d1 d3)) |
(+.f64 (*.f64 d1 d2) (*.f64 d1 (neg.f64 d3))) |
(neg.f64 (+.f64 (*.f64 (neg.f64 d1) d2) (*.f64 (neg.f64 d1) d3))) |
(neg.f64 (+.f64 (*.f64 d1 (neg.f64 d2)) (*.f64 d1 d3))) |
(neg.f64 (+.f64 (*.f64 d1 d2) (*.f64 d1 (neg.f64 d3)))) |
(+.f64 (*.f64 d2 d1) (*.f64 d2 d3)) |
(+.f64 (*.f64 d3 d2) (*.f64 d3 d1)) |
(+.f64 (*.f64 d1 d3) (*.f64 d1 d2)) |
| Outputs |
|---|
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
(*.f64 d1 (+.f64 d2 d3)) |
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
(*.f64 d1 (+.f64 d2 d3)) |
(+.f64 (*.f64 (neg.f64 d1) d2) (*.f64 (neg.f64 d1) d3)) |
(*.f64 (neg.f64 d1) (+.f64 d2 d3)) |
(*.f64 d1 (-.f64 (neg.f64 d2) d3)) |
(+.f64 (*.f64 d1 (neg.f64 d2)) (*.f64 d1 d3)) |
(*.f64 d1 (+.f64 (neg.f64 d2) d3)) |
(*.f64 d1 (fma.f64 #s(literal -1 binary64) d2 d3)) |
(*.f64 d1 (-.f64 d3 d2)) |
(+.f64 (*.f64 d1 d2) (*.f64 d1 (neg.f64 d3))) |
(*.f64 d1 (+.f64 d2 (neg.f64 d3))) |
(*.f64 d1 (-.f64 d2 d3)) |
(neg.f64 (+.f64 (*.f64 (neg.f64 d1) d2) (*.f64 (neg.f64 d1) d3))) |
(*.f64 d1 (+.f64 d2 d3)) |
(neg.f64 (+.f64 (*.f64 d1 (neg.f64 d2)) (*.f64 d1 d3))) |
(*.f64 d1 (+.f64 d2 (neg.f64 d3))) |
(*.f64 d1 (-.f64 d2 d3)) |
(neg.f64 (+.f64 (*.f64 d1 d2) (*.f64 d1 (neg.f64 d3)))) |
(*.f64 d1 (+.f64 (neg.f64 d2) d3)) |
(*.f64 d1 (fma.f64 #s(literal -1 binary64) d2 d3)) |
(*.f64 d1 (-.f64 d3 d2)) |
(+.f64 (*.f64 d2 d1) (*.f64 d2 d3)) |
(*.f64 d2 (+.f64 d1 d3)) |
(+.f64 (*.f64 d3 d2) (*.f64 d3 d1)) |
(*.f64 d3 (+.f64 d2 d1)) |
(*.f64 d3 (+.f64 d1 d2)) |
(+.f64 (*.f64 d1 d3) (*.f64 d1 d2)) |
(*.f64 d1 (+.f64 d2 d3)) |
(negabs d1)
(sort d2 d3)
| 41.0ms | 394× | 256 | valid |
| 10.0ms | 117× | 256 | infinite |
| 0.0ms | 1× | 256 | infinite |
Compiled 50 to 20 computations (60% saved)
ival-mult, time spent: 8.0ms, 69.0% of total-timeival-add, time spent: 3.0ms, 26.0% of total-timeconst, time spent: 1.0ms, 9.0% of total-timeCompiled 8 to 5 computations (37.5% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 d1 (+.f64 d2 d3)) |
Compiled 8 to 5 computations (37.5% saved)
| 17.0ms | 197× | 256 | valid |
| 5.0ms | 58× | 256 | infinite |
| 0.0ms | 1× | 256 | infinite |
Compiled 15 to 6 computations (60% saved)
ival-mult, time spent: 4.0ms, 69.0% of total-timeival-add, time spent: 2.0ms, 34.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-timeCompiled 3 to 3 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 d1 (+.f64 d2 d3)) |
Compiled 23 to 13 computations (43.5% saved)
Total -1.5b remaining (-∞%)
Threshold costs -1.5b (-∞%)
| Inputs |
|---|
(*.f64 d1 (+.f64 d2 d3)) |
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
| Outputs |
|---|
(*.f64 d1 (+.f64 d2 d3)) |
4 calls:
| 1.0ms | d3 |
| 1.0ms | d1 |
| 1.0ms | d2 |
| 1.0ms | (+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | d1 |
| 100.0% | 1 | d2 |
| 100.0% | 1 | d3 |
| 100.0% | 1 | (+.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
Compiled 22 to 15 computations (31.8% saved)
| 1× | egg-herbie |
| 1× | *-commutative |
| 1× | +-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 22 |
| 1 | 13 | 22 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(*.f64 d1 (+.f64 d2 d3)) |
| Outputs |
|---|
(*.f64 d1 (+.f64 d2 d3)) |
Compiled 8 to 5 computations (37.5% saved)
| 329× | fma-define |
| 268× | fma-neg |
| 79× | unsub-neg |
| 69× | associate-*l* |
| 60× | associate-*r* |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 33 | 262 |
| 1 | 92 | 250 |
| 2 | 224 | 246 |
| 3 | 543 | 246 |
| 4 | 1018 | 246 |
| 5 | 1573 | 246 |
| 6 | 1676 | 246 |
| 7 | 1678 | 246 |
| 1× | saturated |
Compiled 15 to 8 computations (46.7% saved)
(sort d2 d3)
(negabs d1)
Compiled 116 to 72 computations (37.9% saved)
Loading profile data...