Time bar (total: 4.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% | 99.9% | 0.1% | 0% | 0% | 0% | 4 |
| 25% | 25% | 74.9% | 0.1% | 0% | 0% | 0% | 5 |
| 37.5% | 37.5% | 62.4% | 0.1% | 0% | 0% | 0% | 6 |
| 56.3% | 56.2% | 43.7% | 0.1% | 0% | 0% | 0% | 7 |
| 65.6% | 65.6% | 34.3% | 0.1% | 0% | 0% | 0% | 8 |
| 76.6% | 76.5% | 23.4% | 0.1% | 0% | 0% | 0% | 9 |
| 82% | 82% | 18% | 0.1% | 0% | 0% | 0% | 10 |
| 87.9% | 87.8% | 12.1% | 0.1% | 0% | 0% | 0% | 11 |
| 90.8% | 90.7% | 9.2% | 0.1% | 0% | 0% | 0% | 12 |
Compiled 8 to 5 computations (37.5% saved)
| 1.9s | 4909× | body | 256 | valid |
| 1.1s | 1329× | body | 1024 | valid |
| 690.0ms | 1147× | body | 2048 | valid |
| 330.0ms | 869× | body | 512 | valid |
| 1.0ms | 2× | body | 4096 | valid |
| 2× | egg-herbie |
| 2× | rational.json-simplify-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 26 |
| 1 | 9 | 26 |
| 0 | 2 | 2 |
| 1× | saturated |
| 1× | saturated |
| Inputs |
|---|
0 |
1 |
| Outputs |
|---|
0 |
1 |
| Inputs |
|---|
(-.f64 (+.f64 x y) x) |
(-.f64 (+.f64 y x) y) |
| Outputs |
|---|
(-.f64 (+.f64 x y) x) |
(-.f64 (+.f64 y x) y) |
(-.f64 (+.f64 x y) y) |
Compiled 9 to 6 computations (33.3% saved)
| 1× | egg-herbie |
| 2× | rational.json-simplify-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 13 |
| 1 | 7 | 13 |
| 1× | saturated |
| Inputs |
|---|
(-.f64 (+.f64 x y) x) |
| Outputs |
|---|
(-.f64 (+.f64 x y) x) |
Compiled 7 to 4 computations (42.9% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 1 | 1 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 2 | 2 |
| Status | Error | Program |
|---|---|---|
| ▶ | 29.1b | (-.f64 (+.f64 x y) x) |
Compiled 7 to 4 computations (42.9% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 1.9b | (-.f64 (+.f64 x y) x) |
Compiled 12 to 4 computations (66.7% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | y | @ | inf | (-.f64 (+.f64 x y) x) |
| 0.0ms | y | @ | -inf | (-.f64 (+.f64 x y) x) |
| 0.0ms | x | @ | 0 | (-.f64 (+.f64 x y) x) |
| 0.0ms | x | @ | inf | (-.f64 (+.f64 x y) x) |
| 0.0ms | x | @ | -inf | (-.f64 (+.f64 x y) x) |
| 1× | batch-egg-rewrite |
| 1142× | rational.json-5 |
| 1140× | exponential.json-3 |
| 1140× | rational.json-1 |
| 1140× | rational.json-2 |
| 1140× | rational.json-4 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 13 |
| 1 | 51 | 13 |
| 2 | 182 | 13 |
| 3 | 672 | 1 |
| 4 | 2605 | 1 |
| 1× | node limit |
| Inputs |
|---|
(-.f64 (+.f64 x y) x) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 y 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 y)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (-.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 y 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (/.f64 y y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 y y) y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 y) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y y) (/.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y y) (/.f64 (/.f64 y y) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y y) (/.f64 -1 (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (/.f64 y y)) (-.f64 -1 (-.f64 y 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (*.f64 y y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (/.f64 (/.f64 1 y) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y))) (/.f64 (/.f64 (/.f64 1 y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 y 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 y (/.f64 y y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 y) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 y 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x . y))))) |
| 1× | egg-herbie |
| 1176× | exponential.json-simplify-26 |
| 922× | rational.json-simplify-1 |
| 914× | rational.json-simplify-49 |
| 640× | rational.json-simplify-104 |
| 640× | rational.json-simplify-58 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 43 | 47 |
| 1 | 83 | 47 |
| 2 | 278 | 47 |
| 3 | 1068 | 47 |
| 4 | 3523 | 47 |
| 5 | 5648 | 47 |
| 1× | node limit |
| Inputs |
|---|
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
(+.f64 y 0) |
(+.f64 0 y) |
(+.f64 1 (-.f64 y 1)) |
(+.f64 (-.f64 y 1) 1) |
(*.f64 y 1) |
(*.f64 y (/.f64 y y)) |
(*.f64 1 y) |
(*.f64 (/.f64 y y) y) |
(*.f64 (neg.f64 y) -1) |
(*.f64 (*.f64 y y) (/.f64 1 y)) |
(*.f64 (*.f64 y y) (/.f64 (/.f64 y y) y)) |
(*.f64 (*.f64 y y) (/.f64 -1 (neg.f64 y))) |
(*.f64 (neg.f64 (/.f64 y y)) (-.f64 -1 (-.f64 y 1))) |
(*.f64 (/.f64 1 y) (*.f64 y y)) |
(*.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (/.f64 (/.f64 1 y) (*.f64 y y))) |
(*.f64 -1 (neg.f64 y)) |
(*.f64 (/.f64 (/.f64 1 y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y))) |
(*.f64 (*.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y))) (/.f64 (/.f64 (/.f64 1 y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y)))) |
(/.f64 y 1) |
(/.f64 y (/.f64 y y)) |
(/.f64 (neg.f64 y) -1) |
(pow.f64 y 1) |
(neg.f64 (neg.f64 y)) |
| Outputs |
|---|
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
y |
(+.f64 y 0) |
y |
(+.f64 0 y) |
y |
(+.f64 1 (-.f64 y 1)) |
y |
(+.f64 (-.f64 y 1) 1) |
y |
(*.f64 y 1) |
y |
(*.f64 y (/.f64 y y)) |
y |
(*.f64 1 y) |
y |
(*.f64 (/.f64 y y) y) |
y |
(*.f64 (neg.f64 y) -1) |
y |
(*.f64 (*.f64 y y) (/.f64 1 y)) |
y |
(*.f64 (*.f64 y y) (/.f64 (/.f64 y y) y)) |
y |
(*.f64 (*.f64 y y) (/.f64 -1 (neg.f64 y))) |
y |
(*.f64 (neg.f64 (/.f64 y y)) (-.f64 -1 (-.f64 y 1))) |
y |
(*.f64 (/.f64 1 y) (*.f64 y y)) |
y |
(*.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (/.f64 (/.f64 1 y) (*.f64 y y))) |
y |
(*.f64 -1 (neg.f64 y)) |
y |
(*.f64 (/.f64 (/.f64 1 y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y))) |
y |
(*.f64 (*.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y))) (/.f64 (/.f64 (/.f64 1 y) (*.f64 y y)) (*.f64 (*.f64 y y) (*.f64 y y)))) |
y |
(/.f64 y 1) |
y |
(/.f64 y (/.f64 y y)) |
y |
(/.f64 (neg.f64 y) -1) |
y |
(pow.f64 y 1) |
y |
(neg.f64 (neg.f64 y)) |
y |
Compiled 163 to 67 computations (58.9% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 23 | 1 | 24 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 24 | 1 | 25 |
| Status | Error | Program |
|---|---|---|
| 0b | y |
Compiled 3 to 2 computations (33.3% saved)
Compiled 2 to 2 computations (0% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 1 | 1 |
| Status | Error | Program |
|---|---|---|
| 0b | y |
Compiled 3 to 2 computations (33.3% saved)
Compiled 2 to 2 computations (0% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 1 | 1 |
| Status | Error | Program |
|---|---|---|
| 0b | y |
Compiled 3 to 2 computations (33.3% saved)
Compiled 2 to 2 computations (0% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 1 | 1 |
| Status | Error | Program |
|---|---|---|
| 0b | y |
Compiled 3 to 2 computations (33.3% saved)
Total -29.1b remaining (-∞%)
Threshold costs -29.1b (-∞%)
| Inputs |
|---|
y |
(-.f64 (+.f64 x y) x) |
| Outputs |
|---|
y |
3 calls:
| 5.0ms | x |
| 5.0ms | y |
| 4.0ms | (-.f64 (+.f64 x y) x) |
| Error | Segments | Branch |
|---|---|---|
| 0b | 1 | x |
| 0b | 1 | y |
| 0b | 1 | (-.f64 (+.f64 x y) x) |
Compiled 21 to 12 computations (42.9% saved)
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 1 | 1 |
| 1× | fuel |
| 1× | saturated |
| Inputs |
|---|
y |
| Outputs |
|---|
y |
Compiled 3 to 2 computations (33.3% saved)
Compiled 3 to 2 computations (33.3% saved)
Loading profile data...