
Time bar (total: 1.7s)
| 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-log, time spent: 0.0ms, 0.0% of total-timeival-add, time spent: 0.0ms, 0.0% of total-timeival-exp, time spent: 0.0ms, 0.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 1.1s | 7181× | 0 | valid |
| 154.0ms | 1074× | 0 | infinite |
| 0.0ms | 1× | 0 | infinite |
ival-log, time spent: 327.0ms, 67.0% of total-timeival-exp, time spent: 95.0ms, 19.0% of total-timeival-add, time spent: 55.0ms, 11.0% of total-timeconst, time spent: 8.0ms, 2.0% of total-timebackward-pass, time spent: 4.0ms, 1.0% of total-time| 1× | egg-herbie |
| 23× | fma-define |
| 16× | fma-neg |
| 14× | distribute-lft-neg-in |
| 9× | neg-sub0 |
| 8× | neg-mul-1 |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 150 | 14 | (2.94202644691678e-210 2.9267973923075616e-105) | 9 | (4.3756710533205194e-240 5.233816234678587e+269) | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 4 | 1 | (9.672995569509687e-306 6.251597112464526e+305) | 3 | (2.4473867773892987e-172 4.590887337638388e+168) | (+.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: 20.0ms, 69.0% of total-timeival-exp, time spent: 6.0ms, 21.0% of total-timeival-add, time spent: 3.0ms, 10.0% of total-timeconst, time spent: 0.0ms, 0.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: 2.0ms, 87.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:
| 3.0ms | (log.f64 a) |
| 2.0ms | b |
| 2.0ms | (+.f64 (log.f64 a) (log.f64 b)) |
| 2.0ms | (log.f64 b) |
| 2.0ms | 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 29 to 21 computations (27.6% saved)
| 1× | egg-herbie |
| 1× | *-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)
| 23× | fma-define |
| 16× | fma-neg |
| 14× | distribute-lft-neg-in |
| 9× | neg-sub0 |
| 8× | 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...