
Time bar (total: 2.7s)
| 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 10 to 7 computations (30% saved)
ival-sub, time spent: 0.0ms, 0.0% of total-timeival-mult, 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.1s | 7229× | 256 | valid |
| 165.0ms | 1024× | 256 | infinite |
| 0.0ms | 2× | 512 | valid |
| 0.0ms | 1× | 256 | valid |
ival-add, time spent: 87.0ms, 39.0% of total-timeival-mult, time spent: 69.0ms, 31.0% of total-timeival-sub, time spent: 52.0ms, 23.0% of total-timeconst, time spent: 15.0ms, 7.0% of total-time| 1× | egg-herbie |
| 2514× | fma-def |
| 248× | distribute-rgt-in |
| 232× | unsub-neg |
| 146× | distribute-lft-in |
| 144× | fma-neg |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 0 | 0 | - | 0 | - | (-.f64 (*.f64 (+.f64 x 1) y) x) |
| 0 | 0 | - | 0 | - | x |
| 0 | 0 | - | 0 | - | (*.f64 (+.f64 x 1) y) |
| 0 | 0 | - | 0 | - | (+.f64 x 1) |
| 0 | 0 | - | 0 | - | y |
| 0 | 0 | - | 0 | - | 1 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 24 | 228 |
| 1 | 56 | 204 |
| 2 | 152 | 185 |
| 3 | 693 | 182 |
| 4 | 1618 | 176 |
| 5 | 2514 | 176 |
| 6 | 2806 | 176 |
| 7 | 2856 | 176 |
| 1× | saturated |
| Inputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(-.f64 (*.f64 (+.f64 (neg.f64 x) 1) y) (neg.f64 x)) |
(-.f64 (*.f64 (+.f64 x 1) (neg.f64 y)) x) |
(neg.f64 (-.f64 (*.f64 (+.f64 (neg.f64 x) 1) y) (neg.f64 x))) |
(neg.f64 (-.f64 (*.f64 (+.f64 x 1) (neg.f64 y)) x)) |
(-.f64 (*.f64 (+.f64 y 1) x) y) |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(fma.f64 (+.f64 x 1) y (neg.f64 x)) |
(-.f64 (fma.f64 x y y) x) |
(fma.f64 x (+.f64 y -1) y) |
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(fma.f64 (+.f64 x 1) y (neg.f64 x)) |
(-.f64 (fma.f64 x y y) x) |
(fma.f64 x (+.f64 y -1) y) |
(-.f64 (*.f64 (+.f64 (neg.f64 x) 1) y) (neg.f64 x)) |
(-.f64 (*.f64 y (+.f64 1 (neg.f64 x))) (neg.f64 x)) |
(fma.f64 y (-.f64 1 x) x) |
(fma.f64 x (-.f64 1 y) y) |
(-.f64 (*.f64 (+.f64 x 1) (neg.f64 y)) x) |
(neg.f64 (fma.f64 (+.f64 x 1) y x)) |
(-.f64 (*.f64 y (-.f64 -1 x)) x) |
(neg.f64 (-.f64 (*.f64 (+.f64 (neg.f64 x) 1) y) (neg.f64 x))) |
(neg.f64 (-.f64 (*.f64 y (+.f64 1 (neg.f64 x))) (neg.f64 x))) |
(neg.f64 (fma.f64 y (-.f64 1 x) x)) |
(-.f64 (*.f64 x (+.f64 y -1)) y) |
(neg.f64 (fma.f64 x (-.f64 1 y) y)) |
(neg.f64 (-.f64 (*.f64 (+.f64 x 1) (neg.f64 y)) x)) |
(fma.f64 (+.f64 x 1) y x) |
(-.f64 (*.f64 (+.f64 y 1) x) y) |
(-.f64 (*.f64 x (+.f64 1 y)) y) |
(-.f64 (fma.f64 x y x) y) |
(fma.f64 y (+.f64 x -1) x) |
Compiled 51 to 32 computations (37.3% saved)
ival-add, time spent: 10.0ms, 43.0% of total-timeival-mult, time spent: 8.0ms, 34.0% of total-timeival-sub, time spent: 3.0ms, 13.0% of total-timeconst, time spent: 2.0ms, 9.0% of total-timeCompiled 21 to 11 computations (47.6% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (fma.f64 x (+.f64 y -1) y) |
| ▶ | 100.0% | (-.f64 (*.f64 (+.f64 x 1) y) x) |
Compiled 17 to 11 computations (35.3% saved)
Found 1 expressions with local error:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (+.f64 x 1) y) |
Compiled 33 to 19 computations (42.4% saved)
ival-add, time spent: 7.0ms, 42.0% of total-timeival-mult, time spent: 4.0ms, 24.0% of total-timeival-fma, time spent: 3.0ms, 18.0% of total-timeival-sub, time spent: 1.0ms, 6.0% of total-timeconst, time spent: 1.0ms, 6.0% of total-time6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 3.0ms | y | @ | -inf | (*.f64 (+.f64 x 1) y) |
| 0.0ms | y | @ | 0 | (*.f64 (+.f64 x 1) y) |
| 0.0ms | y | @ | inf | (*.f64 (+.f64 x 1) y) |
| 0.0ms | x | @ | inf | (*.f64 (+.f64 x 1) y) |
| 0.0ms | x | @ | 0 | (*.f64 (+.f64 x 1) y) |
| 1× | batch-egg-rewrite |
| 624× | unpow-prod-down |
| 442× | log-prod |
| 433× | log1p-expm1-u |
| 433× | expm1-log1p-u |
| 432× | cbrt-prod |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 19 |
| 1 | 102 | 19 |
| 2 | 1205 | 18 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 (+.f64 x 1) y) |
| Outputs |
|---|
(+.f64 y (*.f64 y x)) |
(+.f64 y (*.f64 x y)) |
(+.f64 0 (fma.f64 x y y)) |
(+.f64 (*.f64 y x) y) |
(+.f64 (*.f64 x y) y) |
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 x y y))) 2)) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 x y y))))) |
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x y y)))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x y y))))) |
(-.f64 (+.f64 1 (fma.f64 x y y)) 1) |
(/.f64 (*.f64 y (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (*.f64 y (fma.f64 x x -1)) (+.f64 x -1)) |
(/.f64 (*.f64 (+.f64 1 (pow.f64 x 3)) y) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (*.f64 (fma.f64 x x -1) y) (+.f64 x -1)) |
(pow.f64 (fma.f64 x y y) 1) |
(pow.f64 (cbrt.f64 (fma.f64 x y y)) 3) |
(pow.f64 (pow.f64 (fma.f64 x y y) 2) 1/2) |
(pow.f64 (pow.f64 (fma.f64 x y y) 3) 1/3) |
(pow.f64 (sqrt.f64 (fma.f64 x y y)) 2) |
(pow.f64 (E.f64) (+.f64 (log1p.f64 x) (log.f64 y))) |
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (+.f64 (log1p.f64 x) (log.f64 y))) 2)) (cbrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) |
(pow.f64 (exp.f64 (sqrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) (sqrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) |
(sqrt.f64 (pow.f64 (fma.f64 x y y) 2)) |
(log.f64 (exp.f64 (fma.f64 x y y))) |
(cbrt.f64 (pow.f64 (fma.f64 x y y) 3)) |
(expm1.f64 (log1p.f64 (fma.f64 x y y))) |
(exp.f64 (+.f64 (log1p.f64 x) (log.f64 y))) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x y y))) 3)) |
(exp.f64 (*.f64 (*.f64 3 (+.f64 (log1p.f64 x) (log.f64 y))) 1/3)) |
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x y y))) 2)) |
(log1p.f64 (expm1.f64 (fma.f64 x y y))) |
(fma.f64 x y y) |
(fma.f64 1 y (*.f64 y x)) |
(fma.f64 1 y (*.f64 x y)) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 y x)) |
(fma.f64 y 1 (*.f64 x y)) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 y x)) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 x y)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 y x)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 x y)) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 y x)) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 x y)) |
| 1× | egg-herbie |
| 1612× | fma-neg |
| 874× | associate-+r+ |
| 764× | associate-*r* |
| 724× | log-prod |
| 692× | associate-*l* |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 103 | 1419 |
| 1 | 226 | 1384 |
| 2 | 608 | 1382 |
| 3 | 3517 | 1352 |
| 4 | 6989 | 1352 |
| 1× | node limit |
| Inputs |
|---|
y |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(*.f64 x y) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(*.f64 x y) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(+.f64 y (*.f64 y x)) |
(+.f64 y (*.f64 x y)) |
(+.f64 0 (fma.f64 x y y)) |
(+.f64 (*.f64 y x) y) |
(+.f64 (*.f64 x y) y) |
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 x y y))) 2)) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 x y y))))) |
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x y y)))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x y y))))) |
(-.f64 (+.f64 1 (fma.f64 x y y)) 1) |
(/.f64 (*.f64 y (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (*.f64 y (fma.f64 x x -1)) (+.f64 x -1)) |
(/.f64 (*.f64 (+.f64 1 (pow.f64 x 3)) y) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (*.f64 (fma.f64 x x -1) y) (+.f64 x -1)) |
(pow.f64 (fma.f64 x y y) 1) |
(pow.f64 (cbrt.f64 (fma.f64 x y y)) 3) |
(pow.f64 (pow.f64 (fma.f64 x y y) 2) 1/2) |
(pow.f64 (pow.f64 (fma.f64 x y y) 3) 1/3) |
(pow.f64 (sqrt.f64 (fma.f64 x y y)) 2) |
(pow.f64 (E.f64) (+.f64 (log1p.f64 x) (log.f64 y))) |
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (+.f64 (log1p.f64 x) (log.f64 y))) 2)) (cbrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) |
(pow.f64 (exp.f64 (sqrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) (sqrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) |
(sqrt.f64 (pow.f64 (fma.f64 x y y) 2)) |
(log.f64 (exp.f64 (fma.f64 x y y))) |
(cbrt.f64 (pow.f64 (fma.f64 x y y) 3)) |
(expm1.f64 (log1p.f64 (fma.f64 x y y))) |
(exp.f64 (+.f64 (log1p.f64 x) (log.f64 y))) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x y y))) 3)) |
(exp.f64 (*.f64 (*.f64 3 (+.f64 (log1p.f64 x) (log.f64 y))) 1/3)) |
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x y y))) 2)) |
(log1p.f64 (expm1.f64 (fma.f64 x y y))) |
(fma.f64 x y y) |
(fma.f64 1 y (*.f64 y x)) |
(fma.f64 1 y (*.f64 x y)) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 y x)) |
(fma.f64 y 1 (*.f64 x y)) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 y x)) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 x y)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 y x)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 x y)) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 y x)) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 x y)) |
| Outputs |
|---|
y |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(*.f64 x y) |
(*.f64 y x) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(*.f64 x y) |
(*.f64 y x) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 y x)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 0 (fma.f64 x y y)) |
(fma.f64 y x y) |
(+.f64 (*.f64 y x) y) |
(fma.f64 y x y) |
(+.f64 (*.f64 x y) y) |
(fma.f64 y x y) |
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 x y y))) 2)) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 x y y))))) |
(+.f64 (*.f64 2 (log.f64 (cbrt.f64 (exp.f64 (fma.f64 y x y))))) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 y x y))))) |
(*.f64 3 (log.f64 (cbrt.f64 (exp.f64 (fma.f64 y x y))))) |
(*.f64 (log.f64 (cbrt.f64 (exp.f64 (fma.f64 y x y)))) 3) |
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x y y)))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x y y))))) |
(*.f64 2 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 y x y))))) |
(-.f64 (+.f64 1 (fma.f64 x y y)) 1) |
(fma.f64 y x y) |
(/.f64 (*.f64 y (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (+.f64 1 (pow.f64 x 3)) (/.f64 (-.f64 (fma.f64 x x 1) x) y)) |
(*.f64 (/.f64 y (-.f64 (fma.f64 x x 1) x)) (+.f64 1 (pow.f64 x 3))) |
(/.f64 (fma.f64 y (pow.f64 x 3) y) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (*.f64 y (fma.f64 x x -1)) (+.f64 x -1)) |
(/.f64 (fma.f64 y x y) 1) |
(/.f64 (*.f64 (+.f64 1 (pow.f64 x 3)) y) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (+.f64 1 (pow.f64 x 3)) (/.f64 (-.f64 (fma.f64 x x 1) x) y)) |
(*.f64 (/.f64 y (-.f64 (fma.f64 x x 1) x)) (+.f64 1 (pow.f64 x 3))) |
(/.f64 (fma.f64 y (pow.f64 x 3) y) (-.f64 (fma.f64 x x 1) x)) |
(/.f64 (*.f64 (fma.f64 x x -1) y) (+.f64 x -1)) |
(/.f64 (*.f64 y (fma.f64 x x -1)) (+.f64 x -1)) |
(/.f64 (fma.f64 y x y) 1) |
(pow.f64 (fma.f64 x y y) 1) |
(fma.f64 y x y) |
(pow.f64 (cbrt.f64 (fma.f64 x y y)) 3) |
(fma.f64 y x y) |
(pow.f64 (pow.f64 (fma.f64 x y y) 2) 1/2) |
(fma.f64 y x y) |
(pow.f64 (pow.f64 (fma.f64 x y y) 3) 1/3) |
(fma.f64 y x y) |
(pow.f64 (sqrt.f64 (fma.f64 x y y)) 2) |
(fma.f64 y x y) |
(pow.f64 (E.f64) (+.f64 (log1p.f64 x) (log.f64 y))) |
(fma.f64 y x y) |
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (+.f64 (log1p.f64 x) (log.f64 y))) 2)) (cbrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) |
(pow.f64 (exp.f64 (sqrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) (sqrt.f64 (+.f64 (log1p.f64 x) (log.f64 y)))) |
(sqrt.f64 (pow.f64 (fma.f64 x y y) 2)) |
(fma.f64 y x y) |
(log.f64 (exp.f64 (fma.f64 x y y))) |
(fma.f64 y x y) |
(cbrt.f64 (pow.f64 (fma.f64 x y y) 3)) |
(fma.f64 y x y) |
(expm1.f64 (log1p.f64 (fma.f64 x y y))) |
(fma.f64 y x y) |
(exp.f64 (+.f64 (log1p.f64 x) (log.f64 y))) |
(fma.f64 y x y) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x y y))) 3)) |
(fma.f64 y x y) |
(exp.f64 (*.f64 (*.f64 3 (+.f64 (log1p.f64 x) (log.f64 y))) 1/3)) |
(fma.f64 y x y) |
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x y y))) 2)) |
(fma.f64 y x y) |
(log1p.f64 (expm1.f64 (fma.f64 x y y))) |
(fma.f64 y x y) |
(fma.f64 x y y) |
(fma.f64 y x y) |
(fma.f64 1 y (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 1 y (*.f64 x y)) |
(fma.f64 y x y) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 x y)) |
(fma.f64 y x y) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 x y)) |
(fma.f64 y x y) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 x y)) |
(fma.f64 y x y) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 x y)) |
(fma.f64 y x y) |
Compiled 552 to 231 computations (58.2% saved)
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 50 | 3 | 53 |
| Fresh | 0 | 0 | 0 |
| Picked | 2 | 0 | 2 |
| Done | 0 | 0 | 0 |
| Total | 52 | 3 | 55 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (-.f64 (+.f64 (*.f64 y x) y) x) |
| ▶ | 60.2% | (-.f64 (*.f64 y x) x) |
| ▶ | 74.8% | (-.f64 y x) |
Compiled 21 to 12 computations (42.9% saved)
Found 1 expressions with local error:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (+.f64 (*.f64 y x) y) |
Compiled 35 to 8 computations (77.1% saved)
ival-sub, time spent: 4.0ms, 49.0% of total-timeival-mult, time spent: 2.0ms, 25.0% of total-timeival-add, time spent: 1.0ms, 12.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | 0 | (+.f64 (*.f64 y x) y) |
| 1.0ms | y | @ | inf | (+.f64 (*.f64 y x) y) |
| 0.0ms | y | @ | -inf | (+.f64 (*.f64 y x) y) |
| 0.0ms | x | @ | inf | (+.f64 (*.f64 y x) y) |
| 0.0ms | x | @ | 0 | (+.f64 (*.f64 y x) y) |
| 1× | batch-egg-rewrite |
| 1582× | prod-diff |
| 744× | unpow-prod-down |
| 530× | fma-def |
| 482× | log-prod |
| 480× | log1p-expm1-u |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 18 |
| 1 | 98 | 18 |
| 2 | 1328 | 18 |
| 1× | node limit |
| Inputs |
|---|
(+.f64 (*.f64 y x) y) |
| Outputs |
|---|
(-.f64 (exp.f64 (log1p.f64 (fma.f64 y x y))) 1) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) 2) (*.f64 y (-.f64 x 1))) (/.f64 (pow.f64 y 2) (*.f64 y (-.f64 x 1)))) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 x 1)) |
(*.f64 (fma.f64 y x y) 1) |
(*.f64 (fma.f64 y x y) (log.f64 (exp.f64 1))) |
(*.f64 1 (fma.f64 y x y)) |
(*.f64 (cbrt.f64 (fma.f64 y x y)) (pow.f64 (cbrt.f64 (fma.f64 y x y)) 2)) |
(*.f64 (pow.f64 (cbrt.f64 (fma.f64 y x y)) 2) (cbrt.f64 (fma.f64 y x y))) |
(*.f64 (sqrt.f64 (fma.f64 y x y)) (sqrt.f64 (fma.f64 y x y))) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (/.f64 1 (*.f64 y (-.f64 x 1)))) |
(*.f64 (+.f64 x 1) y) |
(*.f64 (pow.f64 1 1/3) (fma.f64 y x y)) |
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y x y))) 2) 3) (cbrt.f64 (fma.f64 y x y))) |
(*.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 y x y))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 y x y))) 3)) |
(*.f64 (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 y x y) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 y x y) 3)) 1/3)) |
(*.f64 (pow.f64 (pow.f64 (*.f64 (fma.f64 y x y) (cbrt.f64 (fma.f64 y x y))) 2) 1/3) (cbrt.f64 (cbrt.f64 (fma.f64 y x y)))) |
(*.f64 (pow.f64 (pow.f64 (fma.f64 y x y) 5/2) 1/3) (cbrt.f64 (sqrt.f64 (fma.f64 y x y)))) |
(/.f64 1 (/.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)))) |
(/.f64 1 (/.f64 (*.f64 y (-.f64 x 1)) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y y (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (pow.f64 y 2))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (-.f64 x 1))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3))) (neg.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2))) (neg.f64 (*.f64 y (-.f64 x 1)))) |
(/.f64 (-.f64 (pow.f64 y 2) (pow.f64 (*.f64 y x) 2)) (-.f64 y (*.f64 y x))) |
(pow.f64 (fma.f64 y x y) 1) |
(pow.f64 (cbrt.f64 (fma.f64 y x y)) 3) |
(pow.f64 (pow.f64 (fma.f64 y x y) 2) 1/2) |
(pow.f64 (pow.f64 (fma.f64 y x y) 3) 1/3) |
(pow.f64 (sqrt.f64 (fma.f64 y x y)) 2) |
(pow.f64 (/.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3))) -1) |
(pow.f64 (/.f64 (*.f64 y (-.f64 x 1)) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2))) -1) |
(sqrt.f64 (pow.f64 (fma.f64 y x y) 2)) |
(log.f64 (exp.f64 (fma.f64 y x y))) |
(cbrt.f64 (pow.f64 (fma.f64 y x y) 3)) |
(expm1.f64 (log1p.f64 (fma.f64 y x y))) |
(exp.f64 (+.f64 (log.f64 y) (log1p.f64 x))) |
(exp.f64 (*.f64 (+.f64 (log.f64 y) (log1p.f64 x)) 1)) |
(exp.f64 (*.f64 (*.f64 (+.f64 (log.f64 y) (log1p.f64 x)) 1) 1)) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 y x y))) 3)) |
(exp.f64 (*.f64 (*.f64 3 (+.f64 (log.f64 y) (log1p.f64 x))) 1/3)) |
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 y x y))) 2)) |
(log1p.f64 (expm1.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 y x)) |
(fma.f64 x y y) |
(fma.f64 (*.f64 y x) 1 y) |
(fma.f64 1 y (*.f64 y x)) |
(fma.f64 1 (*.f64 y x) y) |
(fma.f64 (cbrt.f64 (*.f64 y x)) (pow.f64 (cbrt.f64 (*.f64 y x)) 2) y) |
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) y) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 y x)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 y x)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) x) y) |
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) y) y) |
(fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) y) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 y x)) |
(fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) x) y) |
(fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) y) y) |
(fma.f64 (*.f64 y (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) y) |
(fma.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 x) y) |
(fma.f64 (*.f64 x (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) y) |
(fma.f64 (*.f64 x (sqrt.f64 y)) (sqrt.f64 y) y) |
| 1× | egg-herbie |
| 1082× | div-sub |
| 1072× | fma-neg |
| 920× | times-frac |
| 788× | prod-exp |
| 544× | unswap-sqr |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 167 | 2463 |
| 1 | 422 | 2394 |
| 2 | 1174 | 2310 |
| 3 | 5533 | 2310 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 1 x)) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
y |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(*.f64 x y) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(*.f64 x y) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(+.f64 y (*.f64 x y)) |
(-.f64 (exp.f64 (log1p.f64 (fma.f64 y x y))) 1) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) 2) (*.f64 y (-.f64 x 1))) (/.f64 (pow.f64 y 2) (*.f64 y (-.f64 x 1)))) |
(*.f64 y (+.f64 1 x)) |
(*.f64 y (+.f64 x 1)) |
(*.f64 (fma.f64 y x y) 1) |
(*.f64 (fma.f64 y x y) (log.f64 (exp.f64 1))) |
(*.f64 1 (fma.f64 y x y)) |
(*.f64 (cbrt.f64 (fma.f64 y x y)) (pow.f64 (cbrt.f64 (fma.f64 y x y)) 2)) |
(*.f64 (pow.f64 (cbrt.f64 (fma.f64 y x y)) 2) (cbrt.f64 (fma.f64 y x y))) |
(*.f64 (sqrt.f64 (fma.f64 y x y)) (sqrt.f64 (fma.f64 y x y))) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (/.f64 1 (*.f64 y (-.f64 x 1)))) |
(*.f64 (+.f64 x 1) y) |
(*.f64 (pow.f64 1 1/3) (fma.f64 y x y)) |
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y x y))) 2) 3) (cbrt.f64 (fma.f64 y x y))) |
(*.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 y x y))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 y x y))) 3)) |
(*.f64 (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 y x y) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 y x y) 3)) 1/3)) |
(*.f64 (pow.f64 (pow.f64 (*.f64 (fma.f64 y x y) (cbrt.f64 (fma.f64 y x y))) 2) 1/3) (cbrt.f64 (cbrt.f64 (fma.f64 y x y)))) |
(*.f64 (pow.f64 (pow.f64 (fma.f64 y x y) 5/2) 1/3) (cbrt.f64 (sqrt.f64 (fma.f64 y x y)))) |
(/.f64 1 (/.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)))) |
(/.f64 1 (/.f64 (*.f64 y (-.f64 x 1)) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y y (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (pow.f64 y 2))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (-.f64 x 1))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3))) (neg.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2))) (neg.f64 (*.f64 y (-.f64 x 1)))) |
(/.f64 (-.f64 (pow.f64 y 2) (pow.f64 (*.f64 y x) 2)) (-.f64 y (*.f64 y x))) |
(pow.f64 (fma.f64 y x y) 1) |
(pow.f64 (cbrt.f64 (fma.f64 y x y)) 3) |
(pow.f64 (pow.f64 (fma.f64 y x y) 2) 1/2) |
(pow.f64 (pow.f64 (fma.f64 y x y) 3) 1/3) |
(pow.f64 (sqrt.f64 (fma.f64 y x y)) 2) |
(pow.f64 (/.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3))) -1) |
(pow.f64 (/.f64 (*.f64 y (-.f64 x 1)) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2))) -1) |
(sqrt.f64 (pow.f64 (fma.f64 y x y) 2)) |
(log.f64 (exp.f64 (fma.f64 y x y))) |
(cbrt.f64 (pow.f64 (fma.f64 y x y) 3)) |
(expm1.f64 (log1p.f64 (fma.f64 y x y))) |
(exp.f64 (+.f64 (log.f64 y) (log1p.f64 x))) |
(exp.f64 (*.f64 (+.f64 (log.f64 y) (log1p.f64 x)) 1)) |
(exp.f64 (*.f64 (*.f64 (+.f64 (log.f64 y) (log1p.f64 x)) 1) 1)) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 y x y))) 3)) |
(exp.f64 (*.f64 (*.f64 3 (+.f64 (log.f64 y) (log1p.f64 x))) 1/3)) |
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 y x y))) 2)) |
(log1p.f64 (expm1.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 y x)) |
(fma.f64 x y y) |
(fma.f64 (*.f64 y x) 1 y) |
(fma.f64 1 y (*.f64 y x)) |
(fma.f64 1 (*.f64 y x) y) |
(fma.f64 (cbrt.f64 (*.f64 y x)) (pow.f64 (cbrt.f64 (*.f64 y x)) 2) y) |
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) y) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 y x)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 y x)) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) x) y) |
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) y) y) |
(fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) y) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 y x)) |
(fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) x) y) |
(fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) y) y) |
(fma.f64 (*.f64 y (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) y) |
(fma.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 x) y) |
(fma.f64 (*.f64 x (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) y) |
(fma.f64 (*.f64 x (sqrt.f64 y)) (sqrt.f64 y) y) |
| Outputs |
|---|
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(fma.f64 y x y) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(fma.f64 y x y) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(fma.f64 y x y) |
(*.f64 -1 (*.f64 y (-.f64 (*.f64 -1 x) 1))) |
(fma.f64 y x y) |
y |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(*.f64 x y) |
(*.f64 y x) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(*.f64 x y) |
(*.f64 y x) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(+.f64 y (*.f64 x y)) |
(fma.f64 y x y) |
(-.f64 (exp.f64 (log1p.f64 (fma.f64 y x y))) 1) |
(fma.f64 y x y) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) 2) (*.f64 y (-.f64 x 1))) (/.f64 (pow.f64 y 2) (*.f64 y (-.f64 x 1)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(*.f64 y (+.f64 1 x)) |
(fma.f64 y x y) |
(*.f64 y (+.f64 x 1)) |
(fma.f64 y x y) |
(*.f64 (fma.f64 y x y) 1) |
(fma.f64 y x y) |
(*.f64 (fma.f64 y x y) (log.f64 (exp.f64 1))) |
(fma.f64 y x y) |
(*.f64 1 (fma.f64 y x y)) |
(fma.f64 y x y) |
(*.f64 (cbrt.f64 (fma.f64 y x y)) (pow.f64 (cbrt.f64 (fma.f64 y x y)) 2)) |
(fma.f64 y x y) |
(*.f64 (pow.f64 (cbrt.f64 (fma.f64 y x y)) 2) (cbrt.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(*.f64 (sqrt.f64 (fma.f64 y x y)) (sqrt.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (*.f64 (+.f64 (pow.f64 x 3) 1) (pow.f64 y 3)) (fma.f64 y y (*.f64 (*.f64 x (pow.f64 y 2)) (+.f64 x -1)))) |
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (/.f64 1 (*.f64 y (-.f64 x 1)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(*.f64 (+.f64 x 1) y) |
(fma.f64 y x y) |
(*.f64 (pow.f64 1 1/3) (fma.f64 y x y)) |
(fma.f64 y x y) |
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y x y))) 2) 3) (cbrt.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(*.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 y x y))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 y x y))) 3)) |
(fma.f64 y x y) |
(*.f64 (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 y x y) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 y x y) 3)) 1/3)) |
(fma.f64 y x y) |
(*.f64 (pow.f64 (pow.f64 (*.f64 (fma.f64 y x y) (cbrt.f64 (fma.f64 y x y))) 2) 1/3) (cbrt.f64 (cbrt.f64 (fma.f64 y x y)))) |
(*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y x y))) (cbrt.f64 (pow.f64 (*.f64 (fma.f64 y x y) (cbrt.f64 (fma.f64 y x y))) 2))) |
(*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y x y))) (cbrt.f64 (pow.f64 (pow.f64 (cbrt.f64 (fma.f64 y x y)) 4) 2))) |
(*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y x y))) (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 y x y)) 8))) |
(*.f64 (pow.f64 (pow.f64 (fma.f64 y x y) 5/2) 1/3) (cbrt.f64 (sqrt.f64 (fma.f64 y x y)))) |
(*.f64 (cbrt.f64 (pow.f64 (fma.f64 y x y) 5/2)) (cbrt.f64 (sqrt.f64 (fma.f64 y x y)))) |
(/.f64 1 (/.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)))) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (*.f64 (+.f64 (pow.f64 x 3) 1) (pow.f64 y 3)) (fma.f64 y y (*.f64 (*.f64 x (pow.f64 y 2)) (+.f64 x -1)))) |
(/.f64 1 (/.f64 (*.f64 y (-.f64 x 1)) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (*.f64 (+.f64 (pow.f64 x 3) 1) (pow.f64 y 3)) (fma.f64 y y (*.f64 (*.f64 x (pow.f64 y 2)) (+.f64 x -1)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y y (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (pow.f64 y 2))))) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (*.f64 (+.f64 (pow.f64 x 3) 1) (pow.f64 y 3)) (fma.f64 y y (*.f64 (*.f64 x (pow.f64 y 2)) (+.f64 x -1)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (-.f64 x 1))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3))) (neg.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (*.f64 (+.f64 (pow.f64 x 3) 1) (pow.f64 y 3)) (fma.f64 y y (*.f64 (*.f64 x (pow.f64 y 2)) (+.f64 x -1)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2))) (neg.f64 (*.f64 y (-.f64 x 1)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(/.f64 (-.f64 (pow.f64 y 2) (pow.f64 (*.f64 y x) 2)) (-.f64 y (*.f64 y x))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(pow.f64 (fma.f64 y x y) 1) |
(fma.f64 y x y) |
(pow.f64 (cbrt.f64 (fma.f64 y x y)) 3) |
(fma.f64 y x y) |
(pow.f64 (pow.f64 (fma.f64 y x y) 2) 1/2) |
(fma.f64 y x y) |
(pow.f64 (pow.f64 (fma.f64 y x y) 3) 1/3) |
(fma.f64 y x y) |
(pow.f64 (sqrt.f64 (fma.f64 y x y)) 2) |
(fma.f64 y x y) |
(pow.f64 (/.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3))) -1) |
(*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (/.f64 1 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 y 3)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) 2))) |
(/.f64 (*.f64 (+.f64 (pow.f64 x 3) 1) (pow.f64 y 3)) (fma.f64 y y (*.f64 (*.f64 x (pow.f64 y 2)) (+.f64 x -1)))) |
(pow.f64 (/.f64 (*.f64 y (-.f64 x 1)) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2))) -1) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 y 2)) (*.f64 y (+.f64 x -1))) |
(/.f64 (-.f64 (*.f64 y (/.f64 (*.f64 x x) 1)) y) (+.f64 x -1)) |
(/.f64 (fma.f64 (/.f64 x 1) (*.f64 y x) (neg.f64 y)) (+.f64 x -1)) |
(sqrt.f64 (pow.f64 (fma.f64 y x y) 2)) |
(fma.f64 y x y) |
(log.f64 (exp.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(cbrt.f64 (pow.f64 (fma.f64 y x y) 3)) |
(fma.f64 y x y) |
(expm1.f64 (log1p.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(exp.f64 (+.f64 (log.f64 y) (log1p.f64 x))) |
(*.f64 y (exp.f64 (log1p.f64 x))) |
(exp.f64 (*.f64 (+.f64 (log.f64 y) (log1p.f64 x)) 1)) |
(exp.f64 (+.f64 (log.f64 y) (log1p.f64 x))) |
(*.f64 y (exp.f64 (log1p.f64 x))) |
(exp.f64 (*.f64 (*.f64 (+.f64 (log.f64 y) (log1p.f64 x)) 1) 1)) |
(exp.f64 (+.f64 (log.f64 y) (log1p.f64 x))) |
(*.f64 y (exp.f64 (log1p.f64 x))) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 y x y))) 3)) |
(fma.f64 y x y) |
(exp.f64 (*.f64 (*.f64 3 (+.f64 (log.f64 y) (log1p.f64 x))) 1/3)) |
(exp.f64 (+.f64 (log.f64 y) (log1p.f64 x))) |
(*.f64 y (exp.f64 (log1p.f64 x))) |
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 y x y))) 2)) |
(fma.f64 y x y) |
(log1p.f64 (expm1.f64 (fma.f64 y x y))) |
(fma.f64 y x y) |
(fma.f64 y x y) |
(fma.f64 y 1 (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 x y y) |
(fma.f64 y x y) |
(fma.f64 (*.f64 y x) 1 y) |
(fma.f64 y x y) |
(fma.f64 1 y (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 1 (*.f64 y x) y) |
(fma.f64 y x y) |
(fma.f64 (cbrt.f64 (*.f64 y x)) (pow.f64 (cbrt.f64 (*.f64 y x)) 2) y) |
(fma.f64 y x y) |
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) y) |
(fma.f64 y x y) |
(fma.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) x) y) |
(fma.f64 y x y) |
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) y) y) |
(fma.f64 y x y) |
(fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) y) |
(fma.f64 y x y) |
(fma.f64 (sqrt.f64 y) (sqrt.f64 y) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) x) y) |
(fma.f64 y x y) |
(fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) y) y) |
(fma.f64 y x y) |
(fma.f64 (*.f64 y (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) y) |
(fma.f64 y x y) |
(fma.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 x) y) |
(fma.f64 y x y) |
(fma.f64 (*.f64 x (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) y) |
(fma.f64 y x y) |
(fma.f64 (*.f64 x (sqrt.f64 y)) (sqrt.f64 y) y) |
(fma.f64 y x y) |
Compiled 1038 to 462 computations (55.5% saved)
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 79 | 0 | 79 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 3 | 3 |
| Done | 0 | 0 | 0 |
| Total | 79 | 3 | 82 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (-.f64 (+.f64 (*.f64 y x) y) x) |
| ✓ | 60.2% | (-.f64 (*.f64 y x) x) |
| ✓ | 74.8% | (-.f64 y x) |
Compiled 51 to 26 computations (49% saved)
| Inputs |
|---|
(-.f64 y x) |
(-.f64 (*.f64 y x) x) |
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(-.f64 (+.f64 (*.f64 y x) y) x) |
(fma.f64 x (+.f64 y -1) y) |
| Outputs |
|---|
(-.f64 (+.f64 (*.f64 y x) y) x) |
3 calls:
| 5.0ms | (-.f64 (*.f64 (+.f64 x 1) y) x) |
| 4.0ms | y |
| 4.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | x |
| 100.0% | 1 | y |
| 100.0% | 1 | (-.f64 (*.f64 (+.f64 x 1) y) x) |
Compiled 15 to 10 computations (33.3% saved)
| Inputs |
|---|
(-.f64 y x) |
(-.f64 (*.f64 y x) x) |
(-.f64 (*.f64 (+.f64 x 1) y) x) |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) y) x) |
3 calls:
| 4.0ms | (-.f64 (*.f64 (+.f64 x 1) y) x) |
| 4.0ms | y |
| 3.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | x |
| 100.0% | 1 | y |
| 100.0% | 1 | (-.f64 (*.f64 (+.f64 x 1) y) x) |
Compiled 15 to 10 computations (33.3% saved)
| Inputs |
|---|
(-.f64 y x) |
(-.f64 (*.f64 y x) x) |
| Outputs |
|---|
(-.f64 (*.f64 y x) x) |
(-.f64 y x) |
(-.f64 (*.f64 y x) x) |
2 calls:
| 20.0ms | y |
| 9.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.4% | 3 | x |
| 84.4% | 7 | y |
Compiled 6 to 4 computations (33.3% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
(-.f64 y x) |
| Outputs |
|---|
(-.f64 y x) |
2 calls:
| 3.0ms | x |
| 3.0ms | y |
| Accuracy | Segments | Branch |
|---|---|---|
| 74.8% | 1 | y |
| 74.8% | 1 | x |
Compiled 6 to 4 computations (33.3% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 18.0ms | 3.7422676746401594e-14 | 2.3727819601590624e-6 |
| 11.0ms | -7.013908638691079e+20 | -1.662529272701324e+20 |
| 24.0ms | 236× | 256 | valid |
| 0.0ms | 3× | 256 | infinite |
| 0.0ms | 1× | 256 | valid |
Compiled 224 to 145 computations (35.3% saved)
ival-add, time spent: 2.0ms, 39.0% of total-timeival-mult, time spent: 2.0ms, 39.0% of total-timeival-sub, time spent: 1.0ms, 19.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 1× | egg-herbie |
| 14× | +-commutative |
| 10× | sub-neg |
| 6× | *-commutative |
| 3× | 1-exp |
| 2× | neg-mul-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 25 | 138 |
| 1 | 45 | 138 |
| 2 | 52 | 138 |
| 3 | 54 | 138 |
| 4 | 55 | 138 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(-.f64 (+.f64 (*.f64 y x) y) x) |
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(if (<=.f64 x -170000000000000000000) (-.f64 (*.f64 y x) x) (if (<=.f64 x 1357680363825023/590295810358705651712) (-.f64 y x) (-.f64 (*.f64 y x) x))) |
(-.f64 y x) |
| Outputs |
|---|
(-.f64 (+.f64 (*.f64 y x) y) x) |
(-.f64 (+.f64 y (*.f64 y x)) x) |
(-.f64 (*.f64 (+.f64 x 1) y) x) |
(-.f64 (*.f64 y (+.f64 x 1)) x) |
(if (<=.f64 x -170000000000000000000) (-.f64 (*.f64 y x) x) (if (<=.f64 x 1357680363825023/590295810358705651712) (-.f64 y x) (-.f64 (*.f64 y x) x))) |
(if (or (<=.f64 x -170000000000000000000) (not (<=.f64 x 1357680363825023/590295810358705651712))) (-.f64 (*.f64 y x) x) (-.f64 y x)) |
(-.f64 y x) |
Compiled 42 to 26 computations (38.1% saved)
| 1612× | fma-neg |
| 874× | associate-+r+ |
| 764× | associate-*r* |
| 724× | log-prod |
| 692× | associate-*l* |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 19 |
| 1 | 102 | 19 |
| 2 | 1205 | 18 |
| 0 | 103 | 1419 |
| 1 | 226 | 1384 |
| 2 | 608 | 1382 |
| 3 | 3517 | 1352 |
| 4 | 6989 | 1352 |
| 1× | node limit |
| 1× | node limit |
Compiled 53 to 27 computations (49.1% saved)
Compiled 90 to 48 computations (46.7% saved)
Loading profile data...