
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 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 0% | 0% | 50% | 0.1% | 0% | 50% | 0% | 2 |
| 100% | 25% | 0% | 0.1% | 0% | 74.9% | 0% | 3 |
Compiled 9 to 7 computations (22.2% saved)
ival-exp, time spent: 2.0ms, 81.0% of total-timeival-log, time spent: 0.0ms, 0.0% of total-timeival-add, time spent: 0.0ms, 0.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 1.2s | 7244× | 256 | valid |
| 146.0ms | 1011× | 256 | infinite |
| 0.0ms | 1× | 256 | valid |
ival-log, time spent: 342.0ms, 59.0% of total-timeival-exp, time spent: 139.0ms, 24.0% of total-timeival-add, time spent: 76.0ms, 13.0% of total-timeconst, time spent: 20.0ms, 3.0% of total-time| 1× | egg-herbie |
| 46× | fma-define |
| 32× | fma-neg |
| 28× | distribute-lft-neg-in |
| 18× | neg-sub0 |
| 16× | neg-mul-1 |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 154 | 17 | (3.735973469039191e-236 4.7097645080124873e-88) | 16 | (7.175534192227769e-103 3.814214550813492e+134) | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 3 | 0 | - | 1 | (6.81479741951032e-227 5.719172093714715e+219) | (+.f64 (log.f64 a) (log.f64 b)) |
| 0 | 0 | - | 0 | - | (log.f64 b) |
| 0 | 0 | - | 0 | - | (log.f64 a) |
| 0 | 0 | - | 0 | - | b |
| 0 | 0 | - | 0 | - | a |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 24 | 183 |
| 1 | 44 | 99 |
| 2 | 77 | 99 |
| 3 | 118 | 99 |
| 4 | 191 | 99 |
| 5 | 219 | 99 |
| 1× | saturated |
| Inputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(exp.f64 (+.f64 (log.f64 (neg.f64 a)) (log.f64 b))) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 (neg.f64 b)))) |
(neg.f64 (exp.f64 (+.f64 (log.f64 (neg.f64 a)) (log.f64 b)))) |
(neg.f64 (exp.f64 (+.f64 (log.f64 a) (log.f64 (neg.f64 b))))) |
(exp.f64 (+.f64 (log.f64 b) (log.f64 a))) |
| Outputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(exp.f64 (+.f64 (log.f64 (neg.f64 a)) (log.f64 b))) |
(exp.f64 (+.f64 (log.f64 b) (log.f64 (neg.f64 a)))) |
(*.f64 b (neg.f64 a)) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 (neg.f64 b)))) |
(exp.f64 (+.f64 (log.f64 b) (log.f64 (neg.f64 a)))) |
(*.f64 b (neg.f64 a)) |
(neg.f64 (exp.f64 (+.f64 (log.f64 (neg.f64 a)) (log.f64 b)))) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(neg.f64 (exp.f64 (+.f64 (log.f64 a) (log.f64 (neg.f64 b))))) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(exp.f64 (+.f64 (log.f64 b) (log.f64 a))) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(negabs a)
(negabs b)
(sort a b)
Compiled 48 to 20 computations (58.3% saved)
ival-log, time spent: 17.0ms, 64.0% of total-timeival-exp, time spent: 6.0ms, 23.0% of total-timeival-add, time spent: 3.0ms, 11.0% of total-timeconst, time spent: 1.0ms, 4.0% of total-timeCompiled 5 to 3 computations (40% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 b a) |
Compiled 5 to 3 computations (40% saved)
Compiled 8 to 4 computations (50% saved)
ival-mult, time spent: 9.0ms, 96.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-timeCompiled 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 b a) |
Compiled 16 to 10 computations (37.5% saved)
Total -5.0b remaining (-∞%)
Threshold costs -5b (-∞%)
| Inputs |
|---|
(*.f64 b a) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(*.f64 b a) |
6 calls:
| 37.0ms | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 3.0ms | (+.f64 (log.f64 a) (log.f64 b)) |
| 3.0ms | b |
| 3.0ms | (log.f64 a) |
| 3.0ms | (log.f64 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 29 to 21 computations (27.6% saved)
| 1× | egg-herbie |
| 2× | *-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 13 |
| 1 | 9 | 13 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(*.f64 b a) |
| Outputs |
|---|
(*.f64 b a) |
Compiled 5 to 3 computations (40% saved)
| 46× | fma-define |
| 32× | fma-neg |
| 28× | distribute-lft-neg-in |
| 18× | neg-sub0 |
| 16× | neg-mul-1 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 24 | 183 |
| 1 | 44 | 99 |
| 2 | 77 | 99 |
| 3 | 118 | 99 |
| 4 | 191 | 99 |
| 5 | 219 | 99 |
| 1× | saturated |
Compiled 29 to 13 computations (55.2% saved)
(sort a b)
(negabs b)
(negabs a)
Compiled 96 to 60 computations (37.5% saved)
Loading profile data...