
Time bar (total: 1.9s)
| 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)
| 1.5s | 7171× | body | 256 | valid |
| 220.0ms | 1085× | body | 256 | infinite |
| 4.0ms | 3× | body | 8192 | exit |
| 2× | egg-herbie |
| 44× | fma-def |
| 38× | +-commutative |
| 24× | associate-+r+ |
| 24× | associate-+l+ |
| 6× | *-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 21 | 100 |
| 1 | 42 | 84 |
| 2 | 84 | 84 |
| 3 | 100 | 84 |
| 0 | 3 | 3 |
| 1× | saturated |
| 1× | saturated |
| Inputs |
|---|
0 |
1 |
2 |
| Outputs |
|---|
0 |
1 |
2 |
| Inputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
(+.f64 (+.f64 (/.f64 y 2) (*.f64 x y)) z) |
(+.f64 (+.f64 (/.f64 z 2) (*.f64 y z)) x) |
(+.f64 (+.f64 (/.f64 x 2) (*.f64 z x)) y) |
| Outputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
(+.f64 (/.f64 x 2) (+.f64 (*.f64 x y) z)) |
(+.f64 (/.f64 x 2) (fma.f64 x y z)) |
(+.f64 (+.f64 (/.f64 y 2) (*.f64 x y)) z) |
(+.f64 z (+.f64 (*.f64 x y) (/.f64 y 2))) |
(+.f64 z (fma.f64 x y (/.f64 y 2))) |
(+.f64 (+.f64 (/.f64 z 2) (*.f64 y z)) x) |
(+.f64 x (+.f64 (/.f64 z 2) (*.f64 y z))) |
(+.f64 x (fma.f64 y z (/.f64 z 2))) |
(+.f64 (+.f64 (/.f64 x 2) (*.f64 z x)) y) |
(+.f64 (/.f64 x 2) (+.f64 (*.f64 x z) y)) |
(+.f64 (/.f64 x 2) (fma.f64 x z y)) |
Compiled 15 to 11 computations (26.7% saved)
| 1× | egg-herbie |
| 12× | fma-def |
| 10× | +-commutative |
| 6× | associate-+r+ |
| 6× | associate-+l+ |
| 2× | *-commutative |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 25 |
| 1 | 15 | 21 |
| 2 | 27 | 21 |
| 3 | 31 | 21 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
| Outputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
(+.f64 (/.f64 x 2) (+.f64 (*.f64 x y) z)) |
(+.f64 (/.f64 x 2) (fma.f64 x y z)) |
Compiled 29 to 17 computations (41.4% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 2 | 1 | 3 |
| Fresh | 1 | 0 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 3 | 1 | 4 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (+.f64 (/.f64 x 2) (+.f64 (*.f64 x y) z)) |
| ▶ | 100.0% | (+.f64 (/.f64 x 2) (+.f64 (*.f64 x y) z)) |
Compiled 24 to 16 computations (33.3% saved)
Compiled 28 to 12 computations (57.1% saved)
Compiled 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 2) (+.f64 (*.f64 x y) z)) |
Compiled 33 to 21 computations (36.4% saved)
Total 0b remaining (0%)
Threshold costs 0b (0%)
| Inputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
(+.f64 (/.f64 x 2) (+.f64 (*.f64 x y) z)) |
| Outputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
5 calls:
| 2.0ms | (+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
| 2.0ms | (+.f64 (/.f64 x 2) (*.f64 y x)) |
| 2.0ms | y |
| 2.0ms | x |
| 2.0ms | z |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | x |
| 100.0% | 1 | y |
| 100.0% | 1 | z |
| 100.0% | 1 | (+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
| 100.0% | 1 | (+.f64 (/.f64 x 2) (*.f64 y x)) |
Compiled 55 to 37 computations (32.7% saved)
| 1× | egg-herbie |
| 4× | +-commutative |
| 2× | *-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 25 |
| 1 | 13 | 25 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
| Outputs |
|---|
(+.f64 (+.f64 (/.f64 x 2) (*.f64 y x)) z) |
(+.f64 (+.f64 (/.f64 x 2) (*.f64 x y)) z) |
Compiled 12 to 8 computations (33.3% saved)
Compiled 48 to 32 computations (33.3% saved)
Loading profile data...