
Time bar (total: 1.6s)
| 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 13 to 9 computations (30.8% saved)
ival-div, time spent: 0.0ms, 0.0% of total-timeival-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| 621.0ms | 7194× | 256 | valid |
| 85.0ms | 1061× | 256 | infinite |
| 0.0ms | 1× | 256 | valid |
ival-add, time spent: 95.0ms, 39.0% of total-timeival-div, time spent: 73.0ms, 30.0% of total-timeival-mult, time spent: 65.0ms, 26.0% of total-timeconst, time spent: 13.0ms, 5.0% of total-time| 1× | egg-herbie |
| 1010× | fma-neg |
| 531× | fma-define |
| 206× | distribute-rgt-in |
| 150× | sub-neg |
| 138× | unsub-neg |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 0 | 0 | - | 0 | - | x |
| 0 | 0 | - | 0 | - | (*.f64 y x) |
| 0 | 0 | - | 0 | - | (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
| 0 | 0 | - | 0 | - | (/.f64 x #s(literal 2 binary64)) |
| 0 | 0 | - | 0 | - | z |
| 0 | 0 | - | 0 | - | (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | y |
Useful iterations: 10 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 40 | 435 |
| 1 | 99 | 371 |
| 2 | 275 | 371 |
| 3 | 801 | 323 |
| 4 | 1690 | 297 |
| 5 | 2822 | 292 |
| 6 | 3298 | 292 |
| 7 | 3484 | 292 |
| 8 | 3535 | 292 |
| 9 | 3543 | 292 |
| 10 | 3543 | 276 |
| 11 | 4081 | 276 |
| 12 | 4081 | 276 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
(+.f64 (+.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)) (*.f64 y (neg.f64 x))) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 (neg.f64 y) x)) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) (neg.f64 z)) |
(neg.f64 (+.f64 (+.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)) (*.f64 y (neg.f64 x))) z)) |
(neg.f64 (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 (neg.f64 y) x)) z)) |
(neg.f64 (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) (neg.f64 z))) |
(+.f64 (+.f64 (/.f64 y #s(literal 2 binary64)) (*.f64 x y)) z) |
(+.f64 (+.f64 (/.f64 z #s(literal 2 binary64)) (*.f64 y z)) x) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 z x)) y) |
| Outputs |
|---|
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 x y) z)) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (fma.f64 x y z)) |
(+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
(fma.f64 x (+.f64 y #s(literal 1/2 binary64)) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 x y) z)) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (fma.f64 x y z)) |
(+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
(fma.f64 x (+.f64 y #s(literal 1/2 binary64)) z) |
(+.f64 (+.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)) (*.f64 y (neg.f64 x))) z) |
(+.f64 z (+.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)) (*.f64 x (neg.f64 y)))) |
(-.f64 z (fma.f64 x y (/.f64 x #s(literal 2 binary64)))) |
(+.f64 z (*.f64 x (-.f64 #s(literal -1/2 binary64) y))) |
(fma.f64 x (-.f64 #s(literal -1/2 binary64) y) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 (neg.f64 y) x)) z) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 x (neg.f64 y)) z)) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (fma.f64 y (neg.f64 x) z)) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (-.f64 z (*.f64 x y))) |
(-.f64 z (*.f64 x (+.f64 y #s(literal -1/2 binary64)))) |
(+.f64 z (*.f64 x (-.f64 #s(literal 1/2 binary64) y))) |
(fma.f64 x (-.f64 #s(literal 1/2 binary64) y) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) (neg.f64 z)) |
(-.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 x y)) z) |
(-.f64 (fma.f64 x y (/.f64 x #s(literal 2 binary64))) z) |
(-.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
(-.f64 (*.f64 x (+.f64 y #s(literal 1/2 binary64))) z) |
(neg.f64 (+.f64 (+.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)) (*.f64 y (neg.f64 x))) z)) |
(-.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 x y)) z) |
(-.f64 (fma.f64 x y (/.f64 x #s(literal 2 binary64))) z) |
(-.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
(-.f64 (*.f64 x (+.f64 y #s(literal 1/2 binary64))) z) |
(neg.f64 (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 (neg.f64 y) x)) z)) |
(neg.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (+.f64 (*.f64 x (neg.f64 y)) z))) |
(-.f64 (/.f64 x #s(literal -2 binary64)) (fma.f64 y (neg.f64 x) z)) |
(+.f64 (*.f64 x y) (-.f64 (*.f64 x #s(literal -1/2 binary64)) z)) |
(-.f64 (*.f64 x (+.f64 y #s(literal -1/2 binary64))) z) |
(neg.f64 (fma.f64 x (-.f64 #s(literal 1/2 binary64) y) z)) |
(neg.f64 (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) (neg.f64 z))) |
(+.f64 z (+.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)) (*.f64 x (neg.f64 y)))) |
(-.f64 z (fma.f64 x y (/.f64 x #s(literal 2 binary64)))) |
(+.f64 z (*.f64 x (-.f64 #s(literal -1/2 binary64) y))) |
(fma.f64 x (-.f64 #s(literal -1/2 binary64) y) z) |
(+.f64 (+.f64 (/.f64 y #s(literal 2 binary64)) (*.f64 x y)) z) |
(+.f64 z (+.f64 (*.f64 x y) (/.f64 y #s(literal 2 binary64)))) |
(+.f64 z (fma.f64 x y (/.f64 y #s(literal 2 binary64)))) |
(+.f64 z (fma.f64 x y (*.f64 y #s(literal 1/2 binary64)))) |
(+.f64 z (*.f64 y (+.f64 x #s(literal 1/2 binary64)))) |
(fma.f64 y (+.f64 x #s(literal 1/2 binary64)) z) |
(+.f64 (+.f64 (/.f64 z #s(literal 2 binary64)) (*.f64 y z)) x) |
(+.f64 x (+.f64 (/.f64 z #s(literal 2 binary64)) (*.f64 y z))) |
(+.f64 x (fma.f64 y z (/.f64 z #s(literal 2 binary64)))) |
(+.f64 x (fma.f64 y z (*.f64 z #s(literal 1/2 binary64)))) |
(+.f64 x (*.f64 z (+.f64 y #s(literal 1/2 binary64)))) |
(fma.f64 z (+.f64 y #s(literal 1/2 binary64)) x) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 z x)) y) |
(+.f64 y (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 x z))) |
(+.f64 y (fma.f64 x z (/.f64 x #s(literal 2 binary64)))) |
(+.f64 (/.f64 x #s(literal 2 binary64)) (fma.f64 x z y)) |
(+.f64 (*.f64 x #s(literal 1/2 binary64)) (fma.f64 x z y)) |
(+.f64 y (*.f64 x (+.f64 #s(literal 1/2 binary64) z))) |
(+.f64 y (*.f64 x (+.f64 z #s(literal 1/2 binary64)))) |
(fma.f64 x (+.f64 z #s(literal 1/2 binary64)) y) |
| 55.0ms | 448× | 256 | valid |
| 9.0ms | 63× | 256 | infinite |
| 0.0ms | 1× | 256 | infinite |
Compiled 72 to 38 computations (47.2% saved)
ival-div, time spent: 10.0ms, 42.0% of total-timeival-add, time spent: 8.0ms, 34.0% of total-timeival-mult, time spent: 4.0ms, 17.0% of total-timeconst, time spent: 2.0ms, 8.0% of total-timeCompiled 33 to 19 computations (42.4% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
Compiled 10 to 7 computations (30% saved)
| 26.0ms | 224× | 256 | valid |
| 3.0ms | 31× | 256 | infinite |
| 0.0ms | 1× | 256 | infinite |
Compiled 23 to 14 computations (39.1% saved)
ival-sub, time spent: 4.0ms, 38.0% of total-timeival-mult, time spent: 4.0ms, 38.0% of total-timeival-add, time spent: 1.0ms, 9.0% of total-timeconst, time spent: 1.0ms, 9.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 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
Compiled 29 to 19 computations (34.5% saved)
Total -0.0b remaining (-∞%)
Threshold costs -0b (-∞%)
| Inputs |
|---|
(+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
(+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
| Outputs |
|---|
(+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
5 calls:
| 1.0ms | (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
| 1.0ms | (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) |
| 1.0ms | z |
| 1.0ms | y |
| 1.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | x |
| 100.0% | 1 | y |
| 100.0% | 1 | z |
| 100.0% | 1 | (+.f64 (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) z) |
| 100.0% | 1 | (+.f64 (/.f64 x #s(literal 2 binary64)) (*.f64 y x)) |
Compiled 34 to 24 computations (29.4% saved)
| 1× | egg-herbie |
| 3× | +-commutative |
| 2× | sub-neg |
| 2× | *-commutative |
| 1× | neg-sub0 |
| 1× | neg-mul-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 28 |
| 1 | 18 | 28 |
| 2 | 23 | 28 |
| 3 | 25 | 28 |
| 4 | 26 | 28 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
| Outputs |
|---|
(+.f64 (*.f64 x (-.f64 y #s(literal -1/2 binary64))) z) |
Compiled 10 to 7 computations (30% saved)
| 1010× | fma-neg |
| 531× | fma-define |
| 206× | distribute-rgt-in |
| 150× | sub-neg |
| 138× | unsub-neg |
Useful iterations: 10 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 40 | 435 |
| 1 | 99 | 371 |
| 2 | 275 | 371 |
| 3 | 801 | 323 |
| 4 | 1690 | 297 |
| 5 | 2822 | 292 |
| 6 | 3298 | 292 |
| 7 | 3484 | 292 |
| 8 | 3535 | 292 |
| 9 | 3543 | 292 |
| 10 | 3543 | 276 |
| 11 | 4081 | 276 |
| 12 | 4081 | 276 |
| 1× | saturated |
Compiled 113 to 62 computations (45.1% saved)
Compiled 44 to 30 computations (31.8% saved)
Loading profile data...