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 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 2 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 3 |
| 0% | 0% | 74.9% | 0.1% | 0% | 25% | 0% | 4 |
| 11.1% | 6.2% | 50% | 0.1% | 0% | 43.7% | 0% | 5 |
| 20% | 9.4% | 37.5% | 0.1% | 0% | 53.1% | 0% | 6 |
| 33.3% | 12.5% | 25% | 0.1% | 1.6% | 60.9% | 0% | 7 |
| 44.2% | 14.8% | 18.7% | 0.1% | 1.6% | 64.8% | 0% | 8 |
| 57.3% | 16.8% | 12.5% | 0.1% | 2.3% | 68.3% | 0% | 9 |
| 66% | 18.1% | 9.4% | 0.1% | 2.3% | 70% | 0% | 10 |
| 75.5% | 19.2% | 6.2% | 0.1% | 2.7% | 71.7% | 0% | 11 |
| 81% | 20% | 4.7% | 0.1% | 2.7% | 72.5% | 0% | 12 |
Compiled 9 to 7 computations (22.2% saved)
| 1.3s | 8256× | body | 256 | valid |
| 105.0ms | 933× | body | 256 | invalid |
| 17.0ms | 153× | body | 256 | infinite |
| 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× | rem-exp-log |
| 2× | *-commutative |
| 2× | exp-sum |
| 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) |
Compiled 5 to 3 computations (40% saved)
Compiled 7 to 3 computations (57.1% 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 5 to 3 computations (40% saved)
Total -5.6b remaining (-∞%)
Threshold costs -5.6b (-∞%)
| Inputs |
|---|
(*.f64 a b) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(*.f64 a b) |
6 calls:
| 12.0ms | a |
| 7.0ms | (log.f64 b) |
| 3.0ms | (+.f64 (log.f64 a) (log.f64 b)) |
| 3.0ms | b |
| 3.0ms | (log.f64 a) |
| 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× | rem-exp-log |
| 2× | *-commutative |
| 2× | exp-sum |
| 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 15 to 9 computations (40% saved)
Loading profile data...