Time bar (total: 2.7s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 0 |
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 1 |
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 2 |
| 50% | 50% | 50% | 0% | 0% | 0% | 0% | 3 |
| 66.7% | 50% | 25% | 0% | 25% | 0% | 0% | 4 |
| 83.3% | 62.5% | 12.5% | 0% | 25% | 0% | 0% | 5 |
| 91.7% | 68.7% | 6.2% | 0% | 25% | 0% | 0% | 6 |
| 95.8% | 71.8% | 3.1% | 0% | 25% | 0% | 0% | 7 |
| 97.9% | 73.4% | 1.6% | 0% | 25% | 0% | 0% | 8 |
| 99% | 74.2% | 0.8% | 0% | 25% | 0% | 0% | 9 |
| 99.5% | 74.6% | 0.4% | 0% | 25% | 0% | 0% | 10 |
| 99.7% | 74.8% | 0.2% | 0% | 25% | 0% | 0% | 11 |
| 99.9% | 74.9% | 0.1% | 0% | 25% | 0% | 0% | 12 |
Compiled 11 to 9 computations (18.2% saved)
| 548.0ms | 2712× | body | 1024 | valid |
| 310.0ms | 3823× | body | 256 | valid |
| 173.0ms | 1432× | body | 512 | valid |
| 126.0ms | 289× | body | 2048 | valid |
| 0.0ms | 4× | body | 256 | infinite |
| 2× | egg-herbie |
| 4× | rational_best-simplify-1 |
| 2× | rational_best-simplify-22 |
| 2× | rational_best-simplify-17 |
| 2× | rational_best-simplify-19 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 25 |
| 1 | 12 | 25 |
| 2 | 14 | 25 |
| 0 | 1 | 1 |
| 1× | saturated |
| 1× | saturated |
| Inputs |
|---|
0 |
| Outputs |
|---|
0 |
| Inputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
(+.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) -1) |
Compiled 11 to 9 computations (18.2% saved)
| 1× | egg-herbie |
| 4× | rational_best-simplify-1 |
| 2× | rational_best-simplify-22 |
| 2× | rational_best-simplify-17 |
| 2× | rational_best-simplify-19 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 25 |
| 1 | 12 | 25 |
| 2 | 14 | 25 |
| 1× | saturated |
| Inputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
(+.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) -1) |
Compiled 19 to 15 computations (21.1% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 1 | 1 | 2 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 1 | 2 | 3 |
| Status | Error | Program |
|---|---|---|
| ▶ | 38.2b | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
Compiled 10 to 8 computations (20% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| ✓ | 2.6b | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
Compiled 22 to 16 computations (27.3% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | inf | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 0.0ms | x | @ | -inf | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 0.0ms | x | @ | 0 | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 0.0ms | x | @ | inf | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| 0.0ms | x | @ | 0 | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| 1× | batch-egg-rewrite |
| 32× | rational_best-simplify-2 |
| 28× | rational_best-4 |
| 28× | rational_best-2 |
| 28× | rational_best-3 |
| 28× | rational_best-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 44 |
| 1 | 48 | 44 |
| 2 | 81 | 44 |
| 3 | 92 | 44 |
| 4 | 97 | 44 |
| 5 | 110 | 44 |
| 6 | 125 | 44 |
| 7 | 146 | 44 |
| 8 | 169 | 44 |
| 9 | 183 | 44 |
| 10 | 184 | 44 |
| 1× | saturated |
| Inputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
(*.f64 (+.f64 x 1) (+.f64 x 1)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (-.f64 -1 x) (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 (+.f64 x 1) (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x))))))) |
| 1× | egg-herbie |
| 54× | rational_best-simplify-1 |
| 44× | rational_best-simplify-2 |
| 24× | rational_best-simplify-44 |
| 24× | rational_best-simplify-43 |
| 22× | rational_best-simplify-49 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 36 | 798 |
| 1 | 52 | 798 |
| 2 | 74 | 798 |
| 3 | 92 | 798 |
| 4 | 106 | 798 |
| 5 | 122 | 798 |
| 6 | 151 | 798 |
| 7 | 165 | 798 |
| 8 | 173 | 798 |
| 9 | 182 | 798 |
| 10 | 192 | 798 |
| 11 | 197 | 798 |
| 12 | 202 | 798 |
| 13 | 210 | 798 |
| 14 | 215 | 798 |
| 15 | 228 | 798 |
| 16 | 231 | 798 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 2 x) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
1 |
(+.f64 (*.f64 2 x) 1) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) |
(+.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 0) |
(+.f64 0 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1)) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(*.f64 1 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1)) |
(*.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1) |
(/.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1) |
(pow.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1) |
(+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 0) |
(+.f64 0 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(-.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 0) |
(-.f64 0 (*.f64 (+.f64 x 1) (-.f64 -1 x))) |
(/.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 1) |
(/.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x)) -1) |
(pow.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 1) |
(neg.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x))) |
(fabs.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(fabs.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x))) |
| Outputs |
|---|
(*.f64 2 x) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
1 |
(+.f64 (*.f64 2 x) 1) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) 1)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) 1)) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) 1)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) 1)) |
(pow.f64 x 2) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) 1)) |
(+.f64 (*.f64 2 x) (+.f64 1 (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) 1)) |
(+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(+.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 0) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(+.f64 0 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1)) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(*.f64 1 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1)) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(*.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(/.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(pow.f64 (+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) -1) 1) |
(+.f64 -1 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(+.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 0) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(+.f64 0 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(-.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 0) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(-.f64 0 (*.f64 (+.f64 x 1) (-.f64 -1 x))) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(/.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 1) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(/.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x)) -1) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(pow.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x)) 1) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(neg.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x))) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(fabs.f64 (*.f64 (-.f64 -1 x) (-.f64 -1 x))) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
(fabs.f64 (*.f64 (+.f64 x 1) (-.f64 -1 x))) |
(*.f64 (-.f64 -1 x) (-.f64 -1 x)) |
Compiled 246 to 199 computations (19.1% saved)
5 alts after pruning (4 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 22 | 4 | 26 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 22 | 5 | 27 |
| Status | Error | Program |
|---|---|---|
| ▶ | 60.2b | (-.f64 (+.f64 (*.f64 2 x) 1) 1) |
| ✓ | 38.2b | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| ▶ | 61.2b | (-.f64 1 1) |
| ▶ | 0.0b | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| ▶ | 22.2b | (*.f64 2 x) |
Compiled 34 to 28 computations (17.6% saved)
Compiled 6 to 4 computations (33.3% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (pow.f64 x 2) |
| ✓ | 0.0b | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
Compiled 16 to 11 computations (31.3% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | -inf | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| 0.0ms | x | @ | inf | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| 0.0ms | x | @ | 0 | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| 0.0ms | x | @ | -inf | (pow.f64 x 2) |
| 0.0ms | x | @ | inf | (pow.f64 x 2) |
| 1× | batch-egg-rewrite |
| 14× | rational_best-simplify-2 |
| 14× | rational_best-simplify-1 |
| 12× | rational_best-4 |
| 12× | rational_best-2 |
| 12× | rational_best-3 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 26 |
| 1 | 46 | 26 |
| 2 | 69 | 26 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(pow.f64 x 2) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 2 x) (pow.f64 x 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 x 2) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 x 2))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (pow.f64 x 2) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 x 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 x 2) 1))))) |
| 1× | egg-herbie |
| 10× | rational_best-simplify-1 |
| 6× | rational_best-simplify-2 |
| 4× | rational_best-simplify-5 |
| 4× | rational_best-simplify-4 |
| 4× | rational_best-simplify-3 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 20 | 158 |
| 1 | 22 | 158 |
| 2 | 29 | 158 |
| 3 | 32 | 158 |
| 4 | 32 | 158 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 2 x) |
(pow.f64 x 2) |
(pow.f64 x 2) |
(-.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 0) |
(*.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1) |
(*.f64 1 (+.f64 (*.f64 2 x) (pow.f64 x 2))) |
(/.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1) |
(pow.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1) |
(+.f64 (pow.f64 x 2) 0) |
(+.f64 0 (pow.f64 x 2)) |
(-.f64 (pow.f64 x 2) 0) |
(*.f64 (pow.f64 x 2) 1) |
(*.f64 1 (pow.f64 x 2)) |
(/.f64 (pow.f64 x 2) 1) |
| Outputs |
|---|
(*.f64 2 x) |
(pow.f64 x 2) |
(pow.f64 x 2) |
(-.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 0) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(*.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(*.f64 1 (+.f64 (*.f64 2 x) (pow.f64 x 2))) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(/.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(pow.f64 (+.f64 (*.f64 2 x) (pow.f64 x 2)) 1) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(+.f64 (pow.f64 x 2) 0) |
(pow.f64 x 2) |
(+.f64 0 (pow.f64 x 2)) |
(pow.f64 x 2) |
(-.f64 (pow.f64 x 2) 0) |
(pow.f64 x 2) |
(*.f64 (pow.f64 x 2) 1) |
(pow.f64 x 2) |
(*.f64 1 (pow.f64 x 2)) |
(pow.f64 x 2) |
(/.f64 (pow.f64 x 2) 1) |
(pow.f64 x 2) |
Compiled 5 to 5 computations (0% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 2.6b | (-.f64 (+.f64 (*.f64 2 x) 1) 1) |
Compiled 19 to 15 computations (21.1% saved)
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | 0 | (-.f64 (+.f64 (*.f64 2 x) 1) 1) |
| 0.0ms | x | @ | inf | (-.f64 (+.f64 (*.f64 2 x) 1) 1) |
| 0.0ms | x | @ | -inf | (-.f64 (+.f64 (*.f64 2 x) 1) 1) |
| 1× | batch-egg-rewrite |
| 11898× | rational_best-simplify-43 |
| 1996× | rational_best-simplify-1 |
| 332× | rational_best-4 |
| 332× | rational_best-2 |
| 332× | rational_best-3 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 19 |
| 1 | 53 | 19 |
| 2 | 77 | 7 |
| 3 | 83 | 7 |
| 4 | 97 | 7 |
| 5 | 114 | 7 |
| 6 | 151 | 7 |
| 7 | 209 | 7 |
| 8 | 329 | 7 |
| 9 | 574 | 7 |
| 10 | 768 | 7 |
| 11 | 801 | 7 |
| 12 | 801 | 7 |
| 13 | 801 | 7 |
| 14 | 1510 | 7 |
| 15 | 1929 | 7 |
| 16 | 2002 | 7 |
| 17 | 2002 | 7 |
| 18 | 2002 | 7 |
| 19 | 3611 | 7 |
| 20 | 4152 | 7 |
| 21 | 4245 | 7 |
| 22 | 4245 | 7 |
| 23 | 4855 | 7 |
| 24 | 4857 | 7 |
| 25 | 4857 | 7 |
| 26 | 4857 | 7 |
| 27 | 4857 | 7 |
| 1× | node limit |
| Inputs |
|---|
(-.f64 (+.f64 (*.f64 2 x) 1) 1) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 2 (+.f64 (*.f64 2 x) -2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 2 x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (+.f64 (*.f64 2 x) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 2 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (+.f64 (*.f64 2 x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 2 (*.f64 2 x)) -2)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -2 (+.f64 2 (*.f64 2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 3 (+.f64 (*.f64 2 x) -3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 3) -3)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -3 (+.f64 (*.f64 2 x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -3) 3)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -4 (+.f64 (*.f64 2 x) 4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 4 (+.f64 (*.f64 2 x) -4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 4) -4)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 5 (+.f64 (*.f64 2 x) -5))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 5) -5)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (+.f64 (*.f64 2 x) -6))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 6) -6)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 7 (+.f64 (*.f64 2 x) -7))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 7) -7)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -5 (+.f64 (*.f64 2 x) 5))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -5) 5)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -6 (+.f64 (*.f64 2 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -6) 6)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -7 (+.f64 (*.f64 2 x) 7))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -7) 7)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -8 (+.f64 (*.f64 2 x) 8))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -8) 8)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 8 (+.f64 (*.f64 2 x) -8))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 8) -8)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 9 (+.f64 (*.f64 2 x) -9))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -9 (+.f64 (*.f64 2 x) 9))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 10 (+.f64 (*.f64 2 x) -10))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 10) -10)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -9) 9)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -10 (+.f64 (*.f64 2 x) 10))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -11 (+.f64 (*.f64 2 x) 11))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -11) 11)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -12 (+.f64 (*.f64 2 x) 12))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -12) 12)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -10) 10)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 9) -9)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 11 (+.f64 (*.f64 2 x) -11))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 11) -11)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 12 (+.f64 (*.f64 2 x) -12))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 12) -12)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 13 (+.f64 (*.f64 2 x) -13))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 14 (+.f64 (*.f64 2 x) -14))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 15 (+.f64 (*.f64 2 x) -15))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 15) -15)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 16 (+.f64 (*.f64 2 x) -16))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -13 (+.f64 (*.f64 2 x) 13))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -13) 13)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -14 (+.f64 (*.f64 2 x) 14))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -15 (+.f64 (*.f64 2 x) 15))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -16 (+.f64 (*.f64 2 x) 16))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 17 (+.f64 (*.f64 2 x) -17))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 13) -13)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 16) -16)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 14) -14)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -14) 14)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -17 (+.f64 (*.f64 2 x) 17))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -17) 17)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -16) 16)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -18 (+.f64 (*.f64 2 x) 18))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -18) 18)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 18 (+.f64 (*.f64 2 x) -18))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 18) -18)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) -15) 15)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 2 x) 17) -17)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 2 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 x) 1))))) |
| 1× | egg-herbie |
| 58954× | rational_best-simplify-43 |
| 2558× | rational_best-simplify-1 |
| 80× | rational_best-simplify-6 |
| 76× | rational_best-simplify-53 |
| 76× | rational_best-simplify-17 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 156 | 644 |
| 1 | 199 | 644 |
| 2 | 571 | 644 |
| 3 | 754 | 644 |
| 4 | 758 | 644 |
| 5 | 760 | 644 |
| 6 | 760 | 644 |
| 7 | 760 | 644 |
| 8 | 760 | 644 |
| 9 | 760 | 644 |
| 10 | 5170 | 644 |
| 11 | 5236 | 644 |
| 12 | 5240 | 644 |
| 13 | 5244 | 644 |
| 14 | 5248 | 644 |
| 15 | 5252 | 644 |
| 16 | 5256 | 644 |
| 17 | 5260 | 644 |
| 18 | 5264 | 644 |
| 19 | 5268 | 644 |
| 20 | 5272 | 644 |
| 21 | 5276 | 644 |
| 22 | 5280 | 644 |
| 23 | 5284 | 644 |
| 24 | 5288 | 644 |
| 25 | 5292 | 644 |
| 26 | 6326 | 644 |
| 27 | 6332 | 644 |
| 28 | 6336 | 644 |
| 29 | 6336 | 644 |
| 30 | 6336 | 644 |
| 31 | 6336 | 644 |
| 32 | 6336 | 644 |
| 33 | 6336 | 644 |
| 34 | 6336 | 644 |
| 35 | 6336 | 644 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(+.f64 2 (+.f64 (*.f64 2 x) -2)) |
(+.f64 (*.f64 2 x) 0) |
(+.f64 1 (+.f64 (*.f64 2 x) -1)) |
(+.f64 (+.f64 (*.f64 2 x) 1) -1) |
(+.f64 0 (*.f64 2 x)) |
(+.f64 -1 (+.f64 (*.f64 2 x) 1)) |
(+.f64 (+.f64 (*.f64 2 x) -1) 1) |
(+.f64 (+.f64 2 (*.f64 2 x)) -2) |
(+.f64 -2 (+.f64 2 (*.f64 2 x))) |
(+.f64 (+.f64 (*.f64 2 x) -2) 2) |
(+.f64 3 (+.f64 (*.f64 2 x) -3)) |
(+.f64 (+.f64 (*.f64 2 x) 3) -3) |
(+.f64 -3 (+.f64 (*.f64 2 x) 3)) |
(+.f64 (+.f64 (*.f64 2 x) -3) 3) |
(+.f64 -4 (+.f64 (*.f64 2 x) 4)) |
(+.f64 (+.f64 (*.f64 2 x) -4) 4) |
(+.f64 4 (+.f64 (*.f64 2 x) -4)) |
(+.f64 (+.f64 (*.f64 2 x) 4) -4) |
(+.f64 5 (+.f64 (*.f64 2 x) -5)) |
(+.f64 (+.f64 (*.f64 2 x) 5) -5) |
(+.f64 6 (+.f64 (*.f64 2 x) -6)) |
(+.f64 (+.f64 (*.f64 2 x) 6) -6) |
(+.f64 7 (+.f64 (*.f64 2 x) -7)) |
(+.f64 (+.f64 (*.f64 2 x) 7) -7) |
(+.f64 -5 (+.f64 (*.f64 2 x) 5)) |
(+.f64 (+.f64 (*.f64 2 x) -5) 5) |
(+.f64 -6 (+.f64 (*.f64 2 x) 6)) |
(+.f64 (+.f64 (*.f64 2 x) -6) 6) |
(+.f64 -7 (+.f64 (*.f64 2 x) 7)) |
(+.f64 (+.f64 (*.f64 2 x) -7) 7) |
(+.f64 -8 (+.f64 (*.f64 2 x) 8)) |
(+.f64 (+.f64 (*.f64 2 x) -8) 8) |
(+.f64 8 (+.f64 (*.f64 2 x) -8)) |
(+.f64 (+.f64 (*.f64 2 x) 8) -8) |
(+.f64 9 (+.f64 (*.f64 2 x) -9)) |
(+.f64 -9 (+.f64 (*.f64 2 x) 9)) |
(+.f64 10 (+.f64 (*.f64 2 x) -10)) |
(+.f64 (+.f64 (*.f64 2 x) 10) -10) |
(+.f64 (+.f64 (*.f64 2 x) -9) 9) |
(+.f64 -10 (+.f64 (*.f64 2 x) 10)) |
(+.f64 -11 (+.f64 (*.f64 2 x) 11)) |
(+.f64 (+.f64 (*.f64 2 x) -11) 11) |
(+.f64 -12 (+.f64 (*.f64 2 x) 12)) |
(+.f64 (+.f64 (*.f64 2 x) -12) 12) |
(+.f64 (+.f64 (*.f64 2 x) -10) 10) |
(+.f64 (+.f64 (*.f64 2 x) 9) -9) |
(+.f64 11 (+.f64 (*.f64 2 x) -11)) |
(+.f64 (+.f64 (*.f64 2 x) 11) -11) |
(+.f64 12 (+.f64 (*.f64 2 x) -12)) |
(+.f64 (+.f64 (*.f64 2 x) 12) -12) |
(+.f64 13 (+.f64 (*.f64 2 x) -13)) |
(+.f64 14 (+.f64 (*.f64 2 x) -14)) |
(+.f64 15 (+.f64 (*.f64 2 x) -15)) |
(+.f64 (+.f64 (*.f64 2 x) 15) -15) |
(+.f64 16 (+.f64 (*.f64 2 x) -16)) |
(+.f64 -13 (+.f64 (*.f64 2 x) 13)) |
(+.f64 (+.f64 (*.f64 2 x) -13) 13) |
(+.f64 -14 (+.f64 (*.f64 2 x) 14)) |
(+.f64 -15 (+.f64 (*.f64 2 x) 15)) |
(+.f64 -16 (+.f64 (*.f64 2 x) 16)) |
(+.f64 17 (+.f64 (*.f64 2 x) -17)) |
(+.f64 (+.f64 (*.f64 2 x) 13) -13) |
(+.f64 (+.f64 (*.f64 2 x) 16) -16) |
(+.f64 (+.f64 (*.f64 2 x) 14) -14) |
(+.f64 (+.f64 (*.f64 2 x) -14) 14) |
(+.f64 -17 (+.f64 (*.f64 2 x) 17)) |
(+.f64 (+.f64 (*.f64 2 x) -17) 17) |
(+.f64 (+.f64 (*.f64 2 x) -16) 16) |
(+.f64 -18 (+.f64 (*.f64 2 x) 18)) |
(+.f64 (+.f64 (*.f64 2 x) -18) 18) |
(+.f64 18 (+.f64 (*.f64 2 x) -18)) |
(+.f64 (+.f64 (*.f64 2 x) 18) -18) |
(+.f64 (+.f64 (*.f64 2 x) -15) 15) |
(+.f64 (+.f64 (*.f64 2 x) 17) -17) |
(*.f64 2 x) |
(*.f64 x 2) |
(*.f64 (*.f64 2 x) 1) |
(*.f64 1 (*.f64 2 x)) |
(/.f64 (*.f64 2 x) 1) |
(pow.f64 (*.f64 2 x) 1) |
| Outputs |
|---|
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(+.f64 2 (+.f64 (*.f64 2 x) -2)) |
(*.f64 2 x) |
(+.f64 (*.f64 2 x) 0) |
(*.f64 2 x) |
(+.f64 1 (+.f64 (*.f64 2 x) -1)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 1) -1) |
(*.f64 2 x) |
(+.f64 0 (*.f64 2 x)) |
(*.f64 2 x) |
(+.f64 -1 (+.f64 (*.f64 2 x) 1)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -1) 1) |
(*.f64 2 x) |
(+.f64 (+.f64 2 (*.f64 2 x)) -2) |
(*.f64 2 x) |
(+.f64 -2 (+.f64 2 (*.f64 2 x))) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -2) 2) |
(*.f64 2 x) |
(+.f64 3 (+.f64 (*.f64 2 x) -3)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 3) -3) |
(*.f64 2 x) |
(+.f64 -3 (+.f64 (*.f64 2 x) 3)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -3) 3) |
(*.f64 2 x) |
(+.f64 -4 (+.f64 (*.f64 2 x) 4)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -4) 4) |
(*.f64 2 x) |
(+.f64 4 (+.f64 (*.f64 2 x) -4)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 4) -4) |
(*.f64 2 x) |
(+.f64 5 (+.f64 (*.f64 2 x) -5)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 5) -5) |
(*.f64 2 x) |
(+.f64 6 (+.f64 (*.f64 2 x) -6)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 6) -6) |
(*.f64 2 x) |
(+.f64 7 (+.f64 (*.f64 2 x) -7)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 7) -7) |
(*.f64 2 x) |
(+.f64 -5 (+.f64 (*.f64 2 x) 5)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -5) 5) |
(*.f64 2 x) |
(+.f64 -6 (+.f64 (*.f64 2 x) 6)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -6) 6) |
(*.f64 2 x) |
(+.f64 -7 (+.f64 (*.f64 2 x) 7)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -7) 7) |
(*.f64 2 x) |
(+.f64 -8 (+.f64 (*.f64 2 x) 8)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -8) 8) |
(*.f64 2 x) |
(+.f64 8 (+.f64 (*.f64 2 x) -8)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 8) -8) |
(*.f64 2 x) |
(+.f64 9 (+.f64 (*.f64 2 x) -9)) |
(*.f64 2 x) |
(+.f64 -9 (+.f64 (*.f64 2 x) 9)) |
(*.f64 2 x) |
(+.f64 10 (+.f64 (*.f64 2 x) -10)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 10) -10) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -9) 9) |
(*.f64 2 x) |
(+.f64 -10 (+.f64 (*.f64 2 x) 10)) |
(*.f64 2 x) |
(+.f64 -11 (+.f64 (*.f64 2 x) 11)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -11) 11) |
(*.f64 2 x) |
(+.f64 -12 (+.f64 (*.f64 2 x) 12)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -12) 12) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -10) 10) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 9) -9) |
(*.f64 2 x) |
(+.f64 11 (+.f64 (*.f64 2 x) -11)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 11) -11) |
(*.f64 2 x) |
(+.f64 12 (+.f64 (*.f64 2 x) -12)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 12) -12) |
(*.f64 2 x) |
(+.f64 13 (+.f64 (*.f64 2 x) -13)) |
(*.f64 2 x) |
(+.f64 14 (+.f64 (*.f64 2 x) -14)) |
(*.f64 2 x) |
(+.f64 15 (+.f64 (*.f64 2 x) -15)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 15) -15) |
(*.f64 2 x) |
(+.f64 16 (+.f64 (*.f64 2 x) -16)) |
(*.f64 2 x) |
(+.f64 -13 (+.f64 (*.f64 2 x) 13)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -13) 13) |
(*.f64 2 x) |
(+.f64 -14 (+.f64 (*.f64 2 x) 14)) |
(*.f64 2 x) |
(+.f64 -15 (+.f64 (*.f64 2 x) 15)) |
(*.f64 2 x) |
(+.f64 -16 (+.f64 (*.f64 2 x) 16)) |
(*.f64 2 x) |
(+.f64 17 (+.f64 (*.f64 2 x) -17)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 13) -13) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 16) -16) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 14) -14) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -14) 14) |
(*.f64 2 x) |
(+.f64 -17 (+.f64 (*.f64 2 x) 17)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -17) 17) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -16) 16) |
(*.f64 2 x) |
(+.f64 -18 (+.f64 (*.f64 2 x) 18)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -18) 18) |
(*.f64 2 x) |
(+.f64 18 (+.f64 (*.f64 2 x) -18)) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 18) -18) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) -15) 15) |
(*.f64 2 x) |
(+.f64 (+.f64 (*.f64 2 x) 17) -17) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 x 2) |
(*.f64 2 x) |
(*.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
(*.f64 1 (*.f64 2 x)) |
(*.f64 2 x) |
(/.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
(pow.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
Compiled 653 to 547 computations (16.2% saved)
6 alts after pruning (2 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 92 | 2 | 94 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 4 | 4 |
| Total | 93 | 6 | 99 |
| Status | Error | Program |
|---|---|---|
| ✓ | 38.2b | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| ✓ | 61.2b | (-.f64 1 1) |
| ▶ | 60.3b | (+.f64 (+.f64 (*.f64 2 x) 18) -18) |
| ▶ | 60.2b | (+.f64 (+.f64 (*.f64 2 x) 15) -15) |
| ✓ | 0.0b | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| ✓ | 22.2b | (*.f64 2 x) |
Compiled 42 to 35 computations (16.7% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 2.7b | (+.f64 (+.f64 (*.f64 2 x) 15) -15) |
Compiled 20 to 16 computations (20% saved)
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | 0 | (+.f64 (+.f64 (*.f64 2 x) 15) -15) |
| 0.0ms | x | @ | -inf | (+.f64 (+.f64 (*.f64 2 x) 15) -15) |
| 0.0ms | x | @ | inf | (+.f64 (+.f64 (*.f64 2 x) 15) -15) |
| 1× | batch-egg-rewrite |
| 13558× | rational_best-simplify-43 |
| 2006× | rational_best-simplify-1 |
| 332× | rational_best-4 |
| 332× | rational_best-2 |
| 332× | rational_best-3 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 19 |
| 1 | 59 | 7 |
| 2 | 84 | 7 |
| 3 | 100 | 7 |
| 4 | 122 | 7 |
| 5 | 154 | 7 |
| 6 | 214 | 7 |
| 7 | 331 | 7 |
| 8 | 580 | 7 |
| 9 | 767 | 7 |
| 10 | 799 | 7 |
| 11 | 799 | 7 |
| 12 | 799 | 7 |
| 13 | 1322 | 7 |
| 14 | 1729 | 7 |
| 15 | 1799 | 7 |
| 16 | 1799 | 7 |
| 17 | 1799 | 7 |
| 18 | 3602 | 7 |
| 19 | 4127 | 7 |
| 20 | 4220 | 7 |
| 21 | 4220 | 7 |
| 22 | 4835 | 7 |
| 23 | 4835 | 7 |
| 24 | 4835 | 7 |
| 25 | 4835 | 7 |
| 1× | node limit |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 2 x) 15) -15) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 2 x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 2 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 x) 1))))) |
| 1× | egg-herbie |
| 10× | rational_best-simplify-2 |
| 4× | rational_best-simplify-5 |
| 4× | rational_best-simplify-6 |
| 2× | rational_best-simplify-4 |
| 2× | exponential-simplify-11 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 133 |
| 1 | 16 | 133 |
| 2 | 24 | 133 |
| 3 | 26 | 133 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(-.f64 (*.f64 2 x) 0) |
(*.f64 2 x) |
(*.f64 x 2) |
(*.f64 (*.f64 2 x) 1) |
(*.f64 1 (*.f64 2 x)) |
(/.f64 (*.f64 2 x) 1) |
(pow.f64 (*.f64 2 x) 1) |
| Outputs |
|---|
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(-.f64 (*.f64 2 x) 0) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 x 2) |
(*.f64 2 x) |
(*.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
(*.f64 1 (*.f64 2 x)) |
(*.f64 2 x) |
(/.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
(pow.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 2.8b | (+.f64 (+.f64 (*.f64 2 x) 18) -18) |
Compiled 20 to 16 computations (20% saved)
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | 0 | (+.f64 (+.f64 (*.f64 2 x) 18) -18) |
| 0.0ms | x | @ | -inf | (+.f64 (+.f64 (*.f64 2 x) 18) -18) |
| 0.0ms | x | @ | inf | (+.f64 (+.f64 (*.f64 2 x) 18) -18) |
| 1× | batch-egg-rewrite |
| 13558× | rational_best-simplify-43 |
| 2006× | rational_best-simplify-1 |
| 332× | rational_best-4 |
| 332× | rational_best-2 |
| 332× | rational_best-3 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 19 |
| 1 | 59 | 7 |
| 2 | 84 | 7 |
| 3 | 100 | 7 |
| 4 | 122 | 7 |
| 5 | 154 | 7 |
| 6 | 214 | 7 |
| 7 | 331 | 7 |
| 8 | 580 | 7 |
| 9 | 767 | 7 |
| 10 | 799 | 7 |
| 11 | 799 | 7 |
| 12 | 799 | 7 |
| 13 | 1322 | 7 |
| 14 | 1729 | 7 |
| 15 | 1799 | 7 |
| 16 | 1799 | 7 |
| 17 | 1799 | 7 |
| 18 | 3602 | 7 |
| 19 | 4127 | 7 |
| 20 | 4220 | 7 |
| 21 | 4220 | 7 |
| 22 | 4835 | 7 |
| 23 | 4835 | 7 |
| 24 | 4835 | 7 |
| 25 | 4835 | 7 |
| 1× | node limit |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 2 x) 18) -18) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 2 x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 2 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 x) 1))))) |
| 1× | egg-herbie |
| 10× | rational_best-simplify-2 |
| 4× | rational_best-simplify-5 |
| 4× | rational_best-simplify-6 |
| 2× | rational_best-simplify-4 |
| 2× | exponential-simplify-11 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 133 |
| 1 | 16 | 133 |
| 2 | 24 | 133 |
| 3 | 26 | 133 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(-.f64 (*.f64 2 x) 0) |
(*.f64 2 x) |
(*.f64 x 2) |
(*.f64 (*.f64 2 x) 1) |
(*.f64 1 (*.f64 2 x)) |
(/.f64 (*.f64 2 x) 1) |
(pow.f64 (*.f64 2 x) 1) |
| Outputs |
|---|
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 2 x) |
(-.f64 (*.f64 2 x) 0) |
(*.f64 2 x) |
(*.f64 2 x) |
(*.f64 x 2) |
(*.f64 2 x) |
(*.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
(*.f64 1 (*.f64 2 x)) |
(*.f64 2 x) |
(/.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
(pow.f64 (*.f64 2 x) 1) |
(*.f64 2 x) |
Compiled 63 to 49 computations (22.2% saved)
6 alts after pruning (0 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 14 | 0 | 14 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 5 | 5 |
| Total | 14 | 6 | 20 |
| Status | Error | Program |
|---|---|---|
| ✓ | 38.2b | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| ✓ | 61.2b | (-.f64 1 1) |
| ✓ | 60.3b | (+.f64 (+.f64 (*.f64 2 x) 18) -18) |
| ✓ | 60.2b | (+.f64 (+.f64 (*.f64 2 x) 15) -15) |
| ✓ | 0.0b | (+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| ✓ | 22.2b | (*.f64 2 x) |
Compiled 42 to 35 computations (16.7% saved)
| Inputs |
|---|
(*.f64 2 x) |
(-.f64 1 1) |
(+.f64 (+.f64 (*.f64 2 x) 15) -15) |
(+.f64 (+.f64 (*.f64 2 x) 18) -18) |
(-.f64 (+.f64 (*.f64 2 x) 1) 1) |
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
| Outputs |
|---|
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
4 calls:
| 4.0ms | x |
| 3.0ms | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 3.0ms | (+.f64 x 1) |
| 2.0ms | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| Error | Segments | Branch |
|---|---|---|
| 0.0b | 1 | x |
| 0.0b | 1 | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 0.0b | 1 | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| 0.0b | 1 | (+.f64 x 1) |
Compiled 68 to 54 computations (20.6% saved)
| Inputs |
|---|
(*.f64 2 x) |
(-.f64 1 1) |
(+.f64 (+.f64 (*.f64 2 x) 15) -15) |
(+.f64 (+.f64 (*.f64 2 x) 18) -18) |
(-.f64 (+.f64 (*.f64 2 x) 1) 1) |
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
(*.f64 2 x) |
(-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
4 calls:
| 11.0ms | x |
| 7.0ms | (+.f64 x 1) |
| 4.0ms | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 4.0ms | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| Error | Segments | Branch |
|---|---|---|
| 0.2b | 3 | x |
| 0.2b | 2 | (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) |
| 0.2b | 2 | (*.f64 (+.f64 x 1) (+.f64 x 1)) |
| 0.2b | 3 | (+.f64 x 1) |
Compiled 61 to 49 computations (19.7% saved)
| 2× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 1.0000000000003428 | 1.0000001589638885 |
| 0.0ms | -2.1116772904995553 | 0.999999999985393 |
Compiled 12 to 9 computations (25% saved)
Total -39.2b remaining (-177%)
Threshold costs -39.2b (-177%)
| Inputs |
|---|
(*.f64 2 x) |
(-.f64 1 1) |
(+.f64 (+.f64 (*.f64 2 x) 15) -15) |
(+.f64 (+.f64 (*.f64 2 x) 18) -18) |
(-.f64 (+.f64 (*.f64 2 x) 1) 1) |
| Outputs |
|---|
(*.f64 2 x) |
1 calls:
| 4.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 22.2b | 1 | x |
Compiled 30 to 25 computations (16.7% saved)
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 20 | 113 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(if (<=.f64 (+.f64 x 1) -2) (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) (if (<=.f64 (+.f64 x 1) 4503600077730459/4503599627370496) (*.f64 2 x) (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1))) |
(*.f64 2 x) |
| Outputs |
|---|
(+.f64 (*.f64 2 x) (pow.f64 x 2)) |
(if (<=.f64 (+.f64 x 1) -2) (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1) (if (<=.f64 (+.f64 x 1) 4503600077730459/4503599627370496) (*.f64 2 x) (-.f64 (*.f64 (+.f64 x 1) (+.f64 x 1)) 1))) |
(*.f64 2 x) |
Compiled 46 to 36 computations (21.7% saved)
Compiled 44 to 34 computations (22.7% saved)
Loading profile data...