
Time bar (total: 3.7s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 2 |
| 25% | 25% | 74.9% | 0.1% | 0% | 0% | 0% | 3 |
| 37.5% | 37.5% | 62.4% | 0.1% | 0% | 0% | 0% | 4 |
| 56.3% | 56.2% | 43.7% | 0.1% | 0% | 0% | 0% | 5 |
| 65.6% | 65.6% | 34.3% | 0.1% | 0% | 0% | 0% | 6 |
| 76.6% | 76.5% | 23.4% | 0.1% | 0% | 0% | 0% | 7 |
| 82% | 82% | 18% | 0.1% | 0% | 0% | 0% | 8 |
| 87.9% | 87.8% | 12.1% | 0.1% | 0% | 0% | 0% | 9 |
| 90.8% | 90.7% | 9.2% | 0.1% | 0% | 0% | 0% | 10 |
| 93.8% | 93.8% | 6.1% | 0.1% | 0% | 0% | 0% | 11 |
| 95.4% | 95.3% | 4.6% | 0.1% | 0% | 0% | 0% | 12 |
Compiled 14 to 10 computations (28.6% saved)
ival-add, time spent: 5.0ms, 41.0% of total-timeival-div, time spent: 4.0ms, 33.0% of total-timeival-mult, time spent: 3.0ms, 24.0% of total-timeconst, time spent: 1.0ms, 8.0% of total-time| 1.6s | 7224× | 0 | valid |
| 397.0ms | 1031× | 0 | infinite |
| 0.0ms | 1× | 0 | infinite |
ival-add, time spent: 581.0ms, 51.0% of total-timeival-div, time spent: 393.0ms, 35.0% of total-timeival-mult, time spent: 131.0ms, 12.0% of total-timeconst, time spent: 26.0ms, 2.0% of total-time| 1× | egg-herbie |
| 1758× | div-sub |
| 1344× | fma-neg |
| 1196× | fma-def |
| 588× | times-frac |
| 526× | unsub-neg |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 0 | 0 | - | 0 | - | x |
| 0 | 0 | - | 0 | - | (*.f64 x (+.f64 (/.f64 x y) 1)) |
| 0 | 0 | - | 0 | - | (+.f64 x 1) |
| 0 | 0 | - | 0 | - | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 0 | 0 | - | 0 | - | y |
| 0 | 0 | - | 0 | - | (+.f64 (/.f64 x y) 1) |
| 0 | 0 | - | 0 | - | 1 |
| 0 | 0 | - | 0 | - | (/.f64 x y) |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 32 | 341 |
| 1 | 94 | 312 |
| 2 | 231 | 298 |
| 3 | 735 | 298 |
| 4 | 2580 | 282 |
| 5 | 5117 | 282 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 (*.f64 (neg.f64 x) (+.f64 (/.f64 (neg.f64 x) y) 1)) (+.f64 (neg.f64 x) 1)) |
(/.f64 (*.f64 x (+.f64 (/.f64 x (neg.f64 y)) 1)) (+.f64 x 1)) |
(neg.f64 (/.f64 (*.f64 (neg.f64 x) (+.f64 (/.f64 (neg.f64 x) y) 1)) (+.f64 (neg.f64 x) 1))) |
(neg.f64 (/.f64 (*.f64 x (+.f64 (/.f64 x (neg.f64 y)) 1)) (+.f64 x 1))) |
(/.f64 (*.f64 y (+.f64 (/.f64 y x) 1)) (+.f64 y 1)) |
| Outputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
(/.f64 (+.f64 (/.f64 x y) 1) (-.f64 (/.f64 1 x) -1)) |
(/.f64 (+.f64 (/.f64 x y) 1) (+.f64 (/.f64 1 x) 1)) |
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
(/.f64 (+.f64 (/.f64 x y) 1) (-.f64 (/.f64 1 x) -1)) |
(/.f64 (+.f64 (/.f64 x y) 1) (+.f64 (/.f64 1 x) 1)) |
(/.f64 (*.f64 (neg.f64 x) (+.f64 (/.f64 (neg.f64 x) y) 1)) (+.f64 (neg.f64 x) 1)) |
(/.f64 (*.f64 (neg.f64 x) (+.f64 1 (/.f64 (neg.f64 x) y))) (+.f64 1 (neg.f64 x))) |
(*.f64 (/.f64 (neg.f64 x) (-.f64 1 x)) (-.f64 1 (/.f64 x y))) |
(/.f64 x (/.f64 (-.f64 1 x) (+.f64 (/.f64 x y) -1))) |
(*.f64 (/.f64 x (-.f64 1 x)) (+.f64 (/.f64 x y) -1)) |
(/.f64 (+.f64 (/.f64 x y) -1) (-.f64 -1 (/.f64 -1 x))) |
(/.f64 (+.f64 (/.f64 x y) -1) (+.f64 -1 (/.f64 1 x))) |
(/.f64 (*.f64 x (+.f64 (/.f64 x (neg.f64 y)) 1)) (+.f64 x 1)) |
(/.f64 (*.f64 x (+.f64 1 (/.f64 x (neg.f64 y)))) (+.f64 x 1)) |
(/.f64 (fma.f64 x (/.f64 x (neg.f64 y)) x) (+.f64 x 1)) |
(*.f64 (-.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (-.f64 1 (/.f64 x y)) (-.f64 (/.f64 1 x) -1)) |
(/.f64 (+.f64 (/.f64 x y) -1) (+.f64 (/.f64 -1 x) -1)) |
(neg.f64 (/.f64 (*.f64 (neg.f64 x) (+.f64 (/.f64 (neg.f64 x) y) 1)) (+.f64 (neg.f64 x) 1))) |
(/.f64 (neg.f64 (*.f64 (neg.f64 x) (+.f64 1 (/.f64 (neg.f64 x) y)))) (+.f64 1 (neg.f64 x))) |
(/.f64 (*.f64 x (-.f64 1 (/.f64 x y))) (-.f64 1 x)) |
(*.f64 (/.f64 x (-.f64 1 x)) (-.f64 1 (/.f64 x y))) |
(*.f64 (-.f64 1 (/.f64 x y)) (/.f64 x (-.f64 1 x))) |
(/.f64 (-.f64 1 (/.f64 x y)) (-.f64 -1 (/.f64 -1 x))) |
(/.f64 (+.f64 (/.f64 x y) -1) (+.f64 1 (/.f64 -1 x))) |
(neg.f64 (/.f64 (*.f64 x (+.f64 (/.f64 x (neg.f64 y)) 1)) (+.f64 x 1))) |
(/.f64 (neg.f64 (*.f64 x (+.f64 1 (/.f64 x (neg.f64 y))))) (+.f64 x 1)) |
(/.f64 (neg.f64 (fma.f64 x (/.f64 x (neg.f64 y)) x)) (+.f64 x 1)) |
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) -1)) |
(*.f64 (+.f64 (/.f64 x y) -1) (/.f64 x (+.f64 x 1))) |
(/.f64 (-.f64 1 (/.f64 x y)) (-.f64 (/.f64 -1 x) 1)) |
(/.f64 (-.f64 1 (/.f64 x y)) (+.f64 (/.f64 -1 x) -1)) |
(/.f64 (*.f64 y (+.f64 (/.f64 y x) 1)) (+.f64 y 1)) |
(/.f64 (*.f64 y (+.f64 1 (/.f64 y x))) (+.f64 y 1)) |
(/.f64 (fma.f64 y (/.f64 y x) y) (+.f64 y 1)) |
Compiled 83 to 45 computations (45.8% saved)
ival-add, time spent: 220.0ms, 66.0% of total-timeival-div, time spent: 50.0ms, 15.0% of total-timeival-mult, time spent: 49.0ms, 15.0% of total-timeconst, time spent: 16.0ms, 5.0% of total-timeCompiled 45 to 27 computations (40% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.8% | (/.f64 (+.f64 (/.f64 x y) 1) (-.f64 (/.f64 1 x) -1)) |
| ▶ | 88.0% | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| ▶ | 99.9% | (/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
Compiled 39 to 28 computations (28.2% saved)
Compiled 100 to 51 computations (49% saved)
ival-add, time spent: 327.0ms, 61.0% of total-timeival-div, time spent: 112.0ms, 21.0% of total-timeival-sub, time spent: 47.0ms, 9.0% of total-timeconst, time spent: 26.0ms, 5.0% of total-timeival-mult, time spent: 24.0ms, 4.0% of total-timeCompiled 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 | 3 | 3 |
| Done | 0 | 0 | 0 |
| Total | 0 | 3 | 3 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 99.8% | (/.f64 (+.f64 (/.f64 x y) 1) (-.f64 (/.f64 1 x) -1)) |
| ✓ | 88.0% | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| ✓ | 99.9% | (/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
Compiled 74 to 50 computations (32.4% saved)
Total -7.8b remaining (-14184.7%)
Threshold costs -7.8b (-14184.7%)
| Inputs |
|---|
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 (+.f64 (/.f64 x y) 1) (-.f64 (/.f64 1 x) -1)) |
| Outputs |
|---|
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
3 calls:
| 5.0ms | x |
| 3.0ms | y |
| 3.0ms | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.9% | 1 | x |
| 99.9% | 1 | y |
| 99.9% | 1 | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
Compiled 19 to 13 computations (31.6% saved)
| 1× | egg-herbie |
| 4× | +-commutative |
| 3× | 1-exp |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 43 |
| 1 | 21 | 43 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
| Outputs |
|---|
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 1 (/.f64 x y)))) |
Compiled 13 to 9 computations (30.8% saved)
| 1758× | div-sub |
| 1344× | fma-neg |
| 1196× | fma-def |
| 588× | times-frac |
| 526× | unsub-neg |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 32 | 341 |
| 1 | 94 | 312 |
| 2 | 231 | 298 |
| 3 | 735 | 298 |
| 4 | 2580 | 282 |
| 5 | 5117 | 282 |
| 1× | node limit |
Compiled 24 to 15 computations (37.5% saved)
Compiled 82 to 58 computations (29.3% saved)
Loading profile data...