
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 |
| 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 |
| 33.3% | 25% | 50% | 0.1% | 0% | 25% | 0% | 4 |
| 44.4% | 25% | 31.2% | 0.1% | 0% | 43.7% | 0% | 5 |
| 53.3% | 25% | 21.9% | 0.1% | 0% | 53.1% | 0% | 6 |
| 64% | 25% | 14% | 0.1% | 0% | 60.9% | 0% | 7 |
| 71.1% | 25% | 10.1% | 0.1% | 0% | 64.8% | 0% | 8 |
| 79% | 25% | 6.6% | 0.1% | 0% | 68.3% | 0% | 9 |
| 83.7% | 25% | 4.9% | 0.1% | 0% | 70% | 0% | 10 |
| 88.6% | 25% | 3.2% | 0.1% | 0% | 71.7% | 0% | 11 |
| 91.3% | 25% | 2.4% | 0.1% | 0% | 72.5% | 0% | 12 |
Compiled 9 to 7 computations (22.2% saved)
| 991.0ms | 7210× | body | 256 | valid |
| 162.0ms | 1046× | body | 256 | infinite |
| 70.0ms | 801× | body | 256 | invalid |
| 2× | egg-herbie |
| 4× | exp-sum |
| 4× | rem-exp-log |
| 2× | swap-a-b |
| 2× | +-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 38 |
| 1 | 15 | 14 |
| 2 | 17 | 14 |
| 0 | 2 | 2 |
| 1 | 2 | 2 |
| 1× | unsound |
| 1× | saturated |
| Inputs |
|---|
0 |
1 |
| Outputs |
|---|
0 |
1 |
0 |
| Inputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(exp.f64 (+.f64 (log.f64 b) (log.f64 a))) |
| Outputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 a b) |
(exp.f64 (+.f64 (log.f64 b) (log.f64 a))) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 a b) |
(sort a b)
Compiled 10 to 8 computations (20% saved)
| 1× | egg-herbie |
| 4× | exp-sum |
| 4× | rem-exp-log |
| 2× | +-commutative |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 19 |
| 1 | 13 | 7 |
| 2 | 16 | 7 |
| 1× | saturated |
| Inputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 a b) |
Compiled 11 to 7 computations (36.4% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 1 | 1 | 2 |
| Fresh | 1 | 0 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 2 | 1 | 3 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 a b) |
| ▶ | 100.0% | (*.f64 a b) |
Compiled 10 to 6 computations (40% saved)
Compiled 8 to 4 computations (50% saved)
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 a b) |
Compiled 16 to 10 computations (37.5% saved)
Total -4.9b remaining (-∞%)
Threshold costs -4.9b (-∞%)
| Inputs |
|---|
(*.f64 a b) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(*.f64 a b) |
6 calls:
| 3.0ms | (log.f64 a) |
| 3.0ms | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 3.0ms | (+.f64 (log.f64 a) (log.f64 b)) |
| 3.0ms | (log.f64 b) |
| 3.0ms | b |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | a |
| 100.0% | 1 | b |
| 100.0% | 1 | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 100.0% | 1 | (+.f64 (log.f64 a) (log.f64 b)) |
| 100.0% | 1 | (log.f64 a) |
| 100.0% | 1 | (log.f64 b) |
Compiled 40 to 28 computations (30% saved)
| 1× | egg-herbie |
| 2× | *-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 5 | 7 |
| 1 | 6 | 7 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(*.f64 a b) |
| Outputs |
|---|
(*.f64 a b) |
Compiled 5 to 3 computations (40% saved)
| 4× | exp-sum |
| 4× | rem-exp-log |
| 2× | +-commutative |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 19 |
| 1 | 13 | 7 |
| 2 | 16 | 7 |
| 1× | saturated |
Compiled 23 to 11 computations (52.2% saved)
(sort a b)
Compiled 46 to 30 computations (34.8% saved)
Loading profile data...