Time bar (total: 15.4s)
| 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 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 5 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 6 |
| 12.5% | 12.5% | 87.4% | 0.1% | 0% | 0% | 0% | 7 |
| 18.8% | 18.7% | 81.1% | 0.1% | 0% | 0% | 0% | 8 |
| 25.6% | 25% | 72.5% | 0.1% | 2.3% | 0% | 0% | 9 |
| 36.7% | 34.3% | 59.3% | 0.1% | 6.2% | 0% | 0% | 10 |
| 44.2% | 40.6% | 51.3% | 0.1% | 8% | 0% | 0% | 11 |
| 52.1% | 46.8% | 43% | 0.1% | 10% | 0% | 0% | 12 |
Compiled 11 to 7 computations (36.4% saved)
| 2.0s | 8256× | body | 256 | valid |
| 96.0ms | 1134× | body | 256 | infinite |
| 2× | egg-herbie |
| 8× | rational.json-simplify-2 |
| 8× | rational.json-simplify-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 76 |
| 1 | 25 | 76 |
| 0 | 3 | 3 |
| 1× | saturated |
| 1× | saturated |
| Inputs |
|---|
0 |
1 |
2 |
| Outputs |
|---|
0 |
1 |
2 |
| Inputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 y (*.f64 x (-.f64 z y))) |
(+.f64 z (*.f64 y (-.f64 x z))) |
(+.f64 x (*.f64 z (-.f64 y x))) |
| Outputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 y (*.f64 x (-.f64 z y))) |
(+.f64 z (*.f64 y (-.f64 x z))) |
(+.f64 x (*.f64 z (-.f64 y x))) |
Compiled 13 to 9 computations (30.8% saved)
| 1× | egg-herbie |
| 2× | rational.json-simplify-2 |
| 2× | rational.json-simplify-1 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 19 |
| 1 | 10 | 19 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
| Outputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
Compiled 10 to 6 computations (40% 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 |
|---|---|---|
| ▶ | 0.0b | (+.f64 x (*.f64 y (-.f64 z x))) |
Compiled 10 to 6 computations (40% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (*.f64 y (-.f64 z x)) |
| ✓ | 0.0b | (+.f64 x (*.f64 y (-.f64 z x))) |
Compiled 21 to 6 computations (71.4% saved)
18 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | y | @ | inf | (+.f64 x (*.f64 y (-.f64 z x))) |
| 0.0ms | x | @ | inf | (+.f64 x (*.f64 y (-.f64 z x))) |
| 0.0ms | y | @ | -inf | (+.f64 x (*.f64 y (-.f64 z x))) |
| 0.0ms | z | @ | -inf | (+.f64 x (*.f64 y (-.f64 z x))) |
| 0.0ms | z | @ | inf | (+.f64 x (*.f64 y (-.f64 z x))) |
| 1× | batch-egg-rewrite |
| 1812× | rational.json-1 |
| 1576× | rational.json-simplify-35 |
| 1284× | rational.json-2 |
| 1284× | rational.json-3 |
| 1276× | exponential.json-3 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 32 |
| 1 | 52 | 32 |
| 2 | 114 | 32 |
| 3 | 248 | 32 |
| 4 | 474 | 32 |
| 5 | 1114 | 32 |
| 6 | 3168 | 32 |
| 7 | 5876 | 32 |
| 8 | 7870 | 32 |
| 1× | node limit |
| Inputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 y (-.f64 z x)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 x (*.f64 y (-.f64 z x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 x (*.f64 y (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8) 1/8)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (-.f64 z x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 y (-.f64 z x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (*.f64 (-.f64 x z) -1/2)) (*.f64 y (*.f64 (-.f64 x z) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 y (-.f64 z x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (-.f64 z x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (*.f64 (-.f64 x z) -2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (*.f64 (-.f64 x z) -4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (*.f64 (-.f64 z x) 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8)))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8)))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (-.f64 z x)) 1))))) |
| 1× | egg-herbie |
| 3632× | rational.json-simplify-41 |
| 2560× | rational.json-simplify-35 |
| 1826× | rational.json-simplify-2 |
| 610× | exponential.json-simplify-26 |
| 608× | rational.json-simplify-51 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 96 | 1912 |
| 1 | 217 | 1666 |
| 2 | 565 | 1666 |
| 3 | 1448 | 1622 |
| 4 | 2598 | 1622 |
| 5 | 3384 | 1622 |
| 6 | 3839 | 1622 |
| 7 | 4131 | 1622 |
| 8 | 4315 | 1622 |
| 9 | 4452 | 1622 |
| 10 | 4589 | 1622 |
| 11 | 4924 | 1622 |
| 12 | 5103 | 1622 |
| 13 | 5171 | 1622 |
| 14 | 5191 | 1622 |
| 15 | 5208 | 1622 |
| 16 | 5232 | 1622 |
| 17 | 5302 | 1622 |
| 18 | 5533 | 1622 |
| 19 | 5721 | 1622 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 (-.f64 y 1) x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 (-.f64 y 1) x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 (-.f64 y 1) x))) |
x |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(*.f64 y (-.f64 z x)) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(*.f64 y (-.f64 z x)) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(-.f64 (+.f64 x (*.f64 y (-.f64 z x))) 0) |
(*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1) |
(*.f64 1 (+.f64 x (*.f64 y (-.f64 z x)))) |
(*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/2)) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2) 1/2) |
(*.f64 4 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/4)) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4) 1/4) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8) 1/8) |
(*.f64 1/2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2)) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/2) 2) |
(*.f64 1/4 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4)) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/4) 4) |
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1) |
(/.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2) 2) |
(/.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4) 4) |
(/.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8) 8) |
(/.f64 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)) 16) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8))) 32) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)))) 64) |
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8))))) 128) |
(pow.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1) |
(+.f64 (*.f64 y (-.f64 z x)) 0) |
(+.f64 0 (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (*.f64 (-.f64 x z) -1/2)) (*.f64 y (*.f64 (-.f64 x z) -1/2))) |
(-.f64 (*.f64 y (-.f64 z x)) 0) |
(/.f64 (*.f64 y (-.f64 z x)) 1) |
(/.f64 (*.f64 y (*.f64 (-.f64 x z) -2)) 2) |
(/.f64 (*.f64 y (*.f64 (-.f64 x z) -4)) 4) |
(/.f64 (*.f64 y (*.f64 (-.f64 z x) 8)) 8) |
(/.f64 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))) 16) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8)))) 32) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))))) 64) |
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8)))))) 128) |
(pow.f64 (*.f64 y (-.f64 z x)) 1) |
| Outputs |
|---|
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 y -1)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 (-.f64 1 y) x) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 -1 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 (+.f64 1 (*.f64 y -1)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 (-.f64 1 y) x) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 (-.f64 y 1) x))) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 (-.f64 y 1) x))) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 (-.f64 y 1) x))) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (*.f64 y -1)) x)) |
(+.f64 (*.f64 y z) (*.f64 (+.f64 1 (neg.f64 y)) x)) |
(+.f64 (*.f64 y z) (*.f64 (-.f64 1 y) x)) |
x |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 y (-.f64 z x)) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 y (-.f64 z x)) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) x) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 x (*.f64 y (*.f64 x -1))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 (neg.f64 y) x)) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 -1 (*.f64 y x)))) |
(+.f64 (*.f64 y z) (+.f64 x (*.f64 y (*.f64 x -1)))) |
(+.f64 x (*.f64 y (+.f64 z (neg.f64 x)))) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 y (*.f64 x -1)) |
(*.f64 y (neg.f64 x)) |
(*.f64 (neg.f64 y) x) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(*.f64 y z) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 y (*.f64 x -1)) |
(*.f64 y (neg.f64 x)) |
(*.f64 (neg.f64 y) x) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 y (*.f64 x -1)) |
(*.f64 y (neg.f64 x)) |
(*.f64 (neg.f64 y) x) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(+.f64 (*.f64 y z) (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 y z) (*.f64 y (*.f64 x -1))) |
(*.f64 y (+.f64 z (neg.f64 x))) |
(-.f64 (+.f64 x (*.f64 y (-.f64 z x))) 0) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 1 (+.f64 x (*.f64 y (-.f64 z x)))) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/2)) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2) 1/2) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 4 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/4)) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4) 1/4) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8) 1/8) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 1/2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2)) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/2) 2) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 1/4 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4)) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(*.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1/4) 4) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 2) 2) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 4) 4) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8) 8) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)) 16) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8))) 32) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)))) 64) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8)))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 x (*.f64 y (-.f64 z x))) 8))))) 128) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(pow.f64 (+.f64 x (*.f64 y (-.f64 z x))) 1) |
(+.f64 x (*.f64 y (-.f64 z x))) |
(+.f64 (*.f64 y (-.f64 z x)) 0) |
(*.f64 y (-.f64 z x)) |
(+.f64 0 (*.f64 y (-.f64 z x))) |
(*.f64 y (-.f64 z x)) |
(+.f64 (*.f64 y (*.f64 (-.f64 x z) -1/2)) (*.f64 y (*.f64 (-.f64 x z) -1/2))) |
(*.f64 y (-.f64 z x)) |
(-.f64 (*.f64 y (-.f64 z x)) 0) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 y (-.f64 z x)) 1) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 y (*.f64 (-.f64 x z) -2)) 2) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 y (*.f64 (-.f64 x z) -4)) 4) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 y (*.f64 (-.f64 z x) 8)) 8) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))) 16) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8)))) 32) |
(*.f64 y (-.f64 z x)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))))) 64) |
(*.f64 y (-.f64 z x)) |
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 y (*.f64 (-.f64 z x) 8)))))) 128) |
(*.f64 y (-.f64 z x)) |
(pow.f64 (*.f64 y (-.f64 z x)) 1) |
(*.f64 y (-.f64 z x)) |
Compiled 648 to 292 computations (54.9% saved)
6 alts after pruning (5 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 58 | 5 | 63 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 58 | 6 | 64 |
| Status | Error | Program |
|---|---|---|
| ▶ | 22.9b | (+.f64 x (*.f64 (neg.f64 y) x)) |
| ✓ | 0.0b | (+.f64 x (*.f64 y (-.f64 z x))) |
| ▶ | 22.9b | (*.f64 (-.f64 1 y) x) |
| ▶ | 30.6b | (*.f64 y (-.f64 z x)) |
| ▶ | 40.2b | (*.f64 y z) |
| 33.5b | x |
Compiled 45 to 30 computations (33.3% saved)
Compiled 8 to 4 computations (50% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| 0.0b | (*.f64 y (-.f64 z x)) |
Compiled 14 to 5 computations (64.3% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (*.f64 (-.f64 1 y) x) |
Compiled 14 to 9 computations (35.7% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | 0 | (*.f64 (-.f64 1 y) x) |
| 0.0ms | x | @ | -inf | (*.f64 (-.f64 1 y) x) |
| 0.0ms | x | @ | inf | (*.f64 (-.f64 1 y) x) |
| 0.0ms | x | @ | 0 | (*.f64 (-.f64 1 y) x) |
| 0.0ms | y | @ | inf | (*.f64 (-.f64 1 y) x) |
| 1× | batch-egg-rewrite |
| 1618× | rational.json-simplify-35 |
| 1384× | exponential.json-3 |
| 1384× | rational.json-1 |
| 1384× | rational.json-2 |
| 1384× | rational.json-4 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 13 |
| 1 | 55 | 13 |
| 2 | 128 | 13 |
| 3 | 238 | 13 |
| 4 | 428 | 13 |
| 5 | 912 | 13 |
| 6 | 2338 | 13 |
| 7 | 4229 | 13 |
| 8 | 5306 | 13 |
| 9 | 6566 | 13 |
| 10 | 7666 | 13 |
| 11 | 7848 | 13 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 (-.f64 1 y) x) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 1 y) x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (-.f64 1 y) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (-.f64 1 (*.f64 x (+.f64 y -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (-.f64 1 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 1 y) (*.f64 x 1/2)) (*.f64 (-.f64 1 y) (*.f64 x 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (-.f64 1 y) x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 x (+.f64 y -1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1 y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1 y) (+.f64 x x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1 y) (*.f64 x 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1 y) (*.f64 x 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8)))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 y -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8)))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))))))) 256)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (-.f64 1 y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 x (+.f64 y -1)))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2))))))) |
| 1× | egg-herbie |
| 2988× | rational.json-simplify-35 |
| 1920× | rational.json-simplify-2 |
| 1694× | rational.json-simplify-53 |
| 988× | rational.json-simplify-1 |
| 912× | rational.json-simplify-43 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 64 | 484 |
| 1 | 166 | 462 |
| 2 | 329 | 462 |
| 3 | 718 | 462 |
| 4 | 2353 | 462 |
| 5 | 4060 | 462 |
| 6 | 4685 | 462 |
| 7 | 4924 | 462 |
| 8 | 5113 | 462 |
| 9 | 5320 | 462 |
| 10 | 6042 | 462 |
| 11 | 7111 | 462 |
| 12 | 7197 | 462 |
| 13 | 7265 | 462 |
| 14 | 7286 | 462 |
| 15 | 7468 | 462 |
| 16 | 7639 | 462 |
| 17 | 7806 | 462 |
| 18 | 7971 | 462 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 (*.f64 (-.f64 1 y) x) 0) |
(+.f64 0 (*.f64 (-.f64 1 y) x)) |
(+.f64 -1 (-.f64 1 (*.f64 x (+.f64 y -1)))) |
(+.f64 -1 (-.f64 1 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2)))) |
(+.f64 (*.f64 (-.f64 1 y) (*.f64 x 1/2)) (*.f64 (-.f64 1 y) (*.f64 x 1/2))) |
(-.f64 (*.f64 (-.f64 1 y) x) 0) |
(-.f64 0 (*.f64 x (+.f64 y -1))) |
(-.f64 0 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2))) |
(/.f64 (*.f64 (-.f64 1 y) x) 1) |
(/.f64 (*.f64 (-.f64 1 y) (+.f64 x x)) 2) |
(/.f64 (*.f64 (-.f64 1 y) (*.f64 x 4)) 4) |
(/.f64 (*.f64 (-.f64 1 y) (*.f64 x 8)) 8) |
(/.f64 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))) 16) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8)))) 32) |
(/.f64 (*.f64 x (+.f64 y -1)) -1) |
(/.f64 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2)) -1) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))))) 64) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8)))))) 128) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))))))) 256) |
(pow.f64 (*.f64 (-.f64 1 y) x) 1) |
(neg.f64 (*.f64 x (+.f64 y -1))) |
(neg.f64 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2))) |
| Outputs |
|---|
x |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 -1 (*.f64 x y)) |
(*.f64 y (neg.f64 x)) |
(*.f64 x (neg.f64 y)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 -1 (*.f64 x y)) |
(*.f64 y (neg.f64 x)) |
(*.f64 x (neg.f64 y)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 x y))) |
(+.f64 x (*.f64 y (neg.f64 x))) |
(+.f64 x (*.f64 x (neg.f64 y))) |
(+.f64 (*.f64 (-.f64 1 y) x) 0) |
(*.f64 x (-.f64 1 y)) |
(+.f64 0 (*.f64 (-.f64 1 y) x)) |
(*.f64 x (-.f64 1 y)) |
(+.f64 -1 (-.f64 1 (*.f64 x (+.f64 y -1)))) |
(*.f64 x (-.f64 1 y)) |
(+.f64 -1 (-.f64 1 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2)))) |
(*.f64 x (-.f64 1 y)) |
(+.f64 (*.f64 (-.f64 1 y) (*.f64 x 1/2)) (*.f64 (-.f64 1 y) (*.f64 x 1/2))) |
(*.f64 x (-.f64 1 y)) |
(-.f64 (*.f64 (-.f64 1 y) x) 0) |
(*.f64 x (-.f64 1 y)) |
(-.f64 0 (*.f64 x (+.f64 y -1))) |
(*.f64 x (-.f64 1 y)) |
(-.f64 0 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2))) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 (-.f64 1 y) x) 1) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 (-.f64 1 y) (+.f64 x x)) 2) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 (-.f64 1 y) (*.f64 x 4)) 4) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 (-.f64 1 y) (*.f64 x 8)) 8) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))) 16) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8)))) 32) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 x (+.f64 y -1)) -1) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2)) -1) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))))) 64) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8)))))) 128) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (-.f64 1 y) (*.f64 x 8))))))) 256) |
(*.f64 x (-.f64 1 y)) |
(pow.f64 (*.f64 (-.f64 1 y) x) 1) |
(*.f64 x (-.f64 1 y)) |
(neg.f64 (*.f64 x (+.f64 y -1))) |
(*.f64 x (-.f64 1 y)) |
(neg.f64 (*.f64 (+.f64 x x) (*.f64 (+.f64 y -1) 1/2))) |
(*.f64 x (-.f64 1 y)) |
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (+.f64 x (*.f64 (neg.f64 y) x)) |
Compiled 17 to 6 computations (64.7% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | inf | (+.f64 x (*.f64 (neg.f64 y) x)) |
| 0.0ms | x | @ | 0 | (+.f64 x (*.f64 (neg.f64 y) x)) |
| 0.0ms | y | @ | 0 | (+.f64 x (*.f64 (neg.f64 y) x)) |
| 0.0ms | y | @ | inf | (+.f64 x (*.f64 (neg.f64 y) x)) |
| 0.0ms | x | @ | -inf | (+.f64 x (*.f64 (neg.f64 y) x)) |
| 1× | batch-egg-rewrite |
| 1622× | rational.json-1 |
| 1622× | rational.json-2 |
| 1622× | rational.json-3 |
| 1616× | rational.json-4 |
| 1380× | rational.json-simplify-35 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 17 |
| 1 | 56 | 17 |
| 2 | 133 | 17 |
| 3 | 301 | 13 |
| 4 | 638 | 13 |
| 5 | 1510 | 13 |
| 6 | 3090 | 13 |
| 7 | 4917 | 13 |
| 8 | 7173 | 13 |
| 1× | node limit |
| Inputs |
|---|
(+.f64 x (*.f64 (neg.f64 y) x)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (-.f64 1 y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (-.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (-.f64 1 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (-.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 x (/.f64 (-.f64 1 y) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 (*.f64 (-.f64 1 y) 1/2) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (*.f64 (+.f64 y -1) -2)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -2 (*.f64 (+.f64 y -1) (*.f64 x 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x x) (*.f64 (-.f64 1 y) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x x) (/.f64 (-.f64 1 y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x x) (+.f64 1/2 (*.f64 y -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 1 y) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (/.f64 (*.f64 x (-.f64 1 y)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (*.f64 4 (-.f64 1 y))) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 y -1) -2) (*.f64 x 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 x (*.f64 (+.f64 y -1) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (+.f64 (+.f64 x x) (*.f64 y (*.f64 x -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 1/2) (*.f64 (+.f64 y -1) -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (/.f64 (-.f64 1 y) 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 y -1)) (/.f64 x -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (-.f64 1 y) 1/2) (+.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 x (*.f64 4 (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (-.f64 1 y) 2) (+.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 x (-.f64 1 y)) 4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 1 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 (+.f64 y -1) -2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 4 (-.f64 1 y))) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x (-.f64 1 y)) 8) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (-.f64 1 y)) 1))))) |
| 1× | egg-herbie |
| 2322× | rational.json-simplify-2 |
| 1920× | rational.json-simplify-35 |
| 964× | rational.json-simplify-1 |
| 906× | rational.json-simplify-53 |
| 886× | rational.json-simplify-45 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 87 | 1071 |
| 1 | 203 | 963 |
| 2 | 421 | 963 |
| 3 | 1310 | 749 |
| 4 | 2836 | 749 |
| 5 | 4017 | 749 |
| 6 | 4861 | 749 |
| 7 | 5402 | 749 |
| 8 | 5721 | 749 |
| 9 | 5979 | 749 |
| 10 | 6362 | 749 |
| 11 | 7000 | 749 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
x |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 -1 (*.f64 y x)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(-.f64 (*.f64 x (-.f64 1 y)) 0) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 x (-.f64 1 y)) 1) |
(*.f64 1 (*.f64 x (-.f64 1 y))) |
(*.f64 2 (*.f64 x (/.f64 (-.f64 1 y) 2))) |
(*.f64 2 (*.f64 (*.f64 (-.f64 1 y) 1/2) x)) |
(*.f64 (*.f64 x (*.f64 (+.f64 y -1) -2)) 1/2) |
(*.f64 -2 (*.f64 (+.f64 y -1) (*.f64 x 1/2))) |
(*.f64 (+.f64 x x) (*.f64 (-.f64 1 y) 1/2)) |
(*.f64 (+.f64 x x) (/.f64 (-.f64 1 y) 2)) |
(*.f64 (+.f64 x x) (+.f64 1/2 (*.f64 y -1/2))) |
(*.f64 (-.f64 1 y) x) |
(*.f64 4 (/.f64 (*.f64 x (-.f64 1 y)) 4)) |
(*.f64 (*.f64 x (*.f64 4 (-.f64 1 y))) 1/4) |
(*.f64 (*.f64 (+.f64 y -1) -2) (*.f64 x 1/2)) |
(*.f64 1/2 (*.f64 x (*.f64 (+.f64 y -1) -2))) |
(*.f64 1/2 (+.f64 (+.f64 x x) (*.f64 y (*.f64 x -2)))) |
(*.f64 (*.f64 x 1/2) (*.f64 (+.f64 y -1) -2)) |
(*.f64 (*.f64 x (/.f64 (-.f64 1 y) 2)) 2) |
(*.f64 (*.f64 2 (+.f64 y -1)) (/.f64 x -2)) |
(*.f64 (*.f64 (-.f64 1 y) 1/2) (+.f64 x x)) |
(*.f64 1/4 (*.f64 x (*.f64 4 (-.f64 1 y)))) |
(*.f64 (/.f64 (-.f64 1 y) 2) (+.f64 x x)) |
(*.f64 (/.f64 (*.f64 x (-.f64 1 y)) 4) 4) |
(/.f64 (*.f64 x (-.f64 1 y)) 1) |
(/.f64 (*.f64 x (*.f64 (+.f64 y -1) -2)) 2) |
(/.f64 (*.f64 x (*.f64 4 (-.f64 1 y))) 4) |
(/.f64 (*.f64 (*.f64 x (-.f64 1 y)) 8) 8) |
(/.f64 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)) 16) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8))) 32) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)))) 64) |
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8))))) 128) |
(pow.f64 (*.f64 x (-.f64 1 y)) 1) |
| Outputs |
|---|
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -1 (*.f64 (-.f64 y 1) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
x |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(+.f64 (*.f64 -1 (*.f64 y x)) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 y (neg.f64 x)) |
(*.f64 (neg.f64 y) x) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -1 (*.f64 y x)) |
(*.f64 y (neg.f64 x)) |
(*.f64 (neg.f64 y) x) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(+.f64 x (*.f64 -1 (*.f64 y x))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(-.f64 (*.f64 x (-.f64 1 y)) 0) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 (*.f64 x (-.f64 1 y)) 1) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 1 (*.f64 x (-.f64 1 y))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 2 (*.f64 x (/.f64 (-.f64 1 y) 2))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 2 (*.f64 (*.f64 (-.f64 1 y) 1/2) x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 x (*.f64 (+.f64 y -1) -2)) 1/2) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 -2 (*.f64 (+.f64 y -1) (*.f64 x 1/2))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 x x) (*.f64 (-.f64 1 y) 1/2)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 x x) (/.f64 (-.f64 1 y) 2)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (+.f64 x x) (+.f64 1/2 (*.f64 y -1/2))) |
(*.f64 (-.f64 1 y) x) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 4 (/.f64 (*.f64 x (-.f64 1 y)) 4)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 x (*.f64 4 (-.f64 1 y))) 1/4) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 (+.f64 y -1) -2) (*.f64 x 1/2)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 1/2 (*.f64 x (*.f64 (+.f64 y -1) -2))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 1/2 (+.f64 (+.f64 x x) (*.f64 y (*.f64 x -2)))) |
(*.f64 1/2 (*.f64 x (+.f64 (*.f64 y -2) 2))) |
(*.f64 1/2 (*.f64 x (+.f64 2 (*.f64 y -2)))) |
(*.f64 (*.f64 x 1/2) (*.f64 (+.f64 y -1) -2)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 x (/.f64 (-.f64 1 y) 2)) 2) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 2 (+.f64 y -1)) (/.f64 x -2)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (*.f64 (-.f64 1 y) 1/2) (+.f64 x x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 1/4 (*.f64 x (*.f64 4 (-.f64 1 y)))) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (/.f64 (-.f64 1 y) 2) (+.f64 x x)) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(*.f64 (/.f64 (*.f64 x (-.f64 1 y)) 4) 4) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 x (-.f64 1 y)) 1) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 x (*.f64 (+.f64 y -1) -2)) 2) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 x (*.f64 4 (-.f64 1 y))) 4) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 (*.f64 x (-.f64 1 y)) 8) 8) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)) 16) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8))) 32) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)))) 64) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8)))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 x (-.f64 1 y)) 8))))) 128) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
(pow.f64 (*.f64 x (-.f64 1 y)) 1) |
(*.f64 (+.f64 1 (*.f64 -1 y)) x) |
(*.f64 (+.f64 1 (neg.f64 y)) x) |
(*.f64 x (-.f64 1 y)) |
Compiled 852 to 564 computations (33.8% saved)
7 alts after pruning (2 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 96 | 1 | 97 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 4 | 4 |
| Total | 96 | 7 | 103 |
| Status | Error | Program |
|---|---|---|
| ✓ | 22.9b | (+.f64 x (*.f64 (neg.f64 y) x)) |
| ✓ | 0.0b | (+.f64 x (*.f64 y (-.f64 z x))) |
| ✓ | 22.9b | (*.f64 (-.f64 1 y) x) |
| ▶ | 52.6b | (*.f64 (neg.f64 y) x) |
| ✓ | 30.6b | (*.f64 y (-.f64 z x)) |
| ✓ | 40.2b | (*.f64 y z) |
| 33.5b | x |
Compiled 52 to 35 computations (32.7% saved)
Compiled 11 to 5 computations (54.5% saved)
Compiled 3 to 3 computations (0% saved)
7 alts after pruning (1 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 5 | 5 |
| Total | 0 | 7 | 7 |
| Status | Error | Program |
|---|---|---|
| ✓ | 22.9b | (+.f64 x (*.f64 (neg.f64 y) x)) |
| ✓ | 0.0b | (+.f64 x (*.f64 y (-.f64 z x))) |
| ✓ | 22.9b | (*.f64 (-.f64 1 y) x) |
| ✓ | 52.6b | (*.f64 (neg.f64 y) x) |
| ✓ | 30.6b | (*.f64 y (-.f64 z x)) |
| ✓ | 40.2b | (*.f64 y z) |
| 33.5b | x |
Compiled 52 to 35 computations (32.7% saved)
Compiled 3 to 3 computations (0% saved)
7 alts after pruning (1 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 6 | 6 |
| Total | 0 | 7 | 7 |
| Status | Error | Program |
|---|---|---|
| ✓ | 22.9b | (+.f64 x (*.f64 (neg.f64 y) x)) |
| ✓ | 0.0b | (+.f64 x (*.f64 y (-.f64 z x))) |
| ✓ | 22.9b | (*.f64 (-.f64 1 y) x) |
| ✓ | 52.6b | (*.f64 (neg.f64 y) x) |
| ✓ | 30.6b | (*.f64 y (-.f64 z x)) |
| ✓ | 40.2b | (*.f64 y z) |
| 33.5b | x |
Compiled 52 to 35 computations (32.7% saved)
| Inputs |
|---|
x |
(*.f64 y z) |
(*.f64 (neg.f64 y) x) |
(*.f64 y (-.f64 z x)) |
(*.f64 (-.f64 1 y) x) |
(+.f64 x (*.f64 (neg.f64 y) x)) |
(+.f64 x (*.f64 y (-.f64 z x))) |
| Outputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
4 calls:
| 84.0ms | (+.f64 x (*.f64 y (-.f64 z x))) |
| 5.0ms | z |
| 5.0ms | x |
| 5.0ms | y |
| Error | Segments | Branch |
|---|---|---|
| 0.0b | 1 | x |
| 0.0b | 1 | y |
| 0.0b | 1 | z |
| 0.0b | 1 | (+.f64 x (*.f64 y (-.f64 z x))) |
Compiled 56 to 28 computations (50% saved)
| Inputs |
|---|
x |
(*.f64 y z) |
(*.f64 (neg.f64 y) x) |
(*.f64 y (-.f64 z x)) |
(*.f64 (-.f64 1 y) x) |
(+.f64 x (*.f64 (neg.f64 y) x)) |
| Outputs |
|---|
(*.f64 y (-.f64 z x)) |
(+.f64 x (*.f64 (neg.f64 y) x)) |
(*.f64 y (-.f64 z x)) |
3 calls:
| 145.0ms | z |
| 77.0ms | x |
| 50.0ms | y |
| Error | Segments | Branch |
|---|---|---|
| 12.0b | 3 | x |
| 11.4b | 3 | y |
| 13.0b | 5 | z |
Compiled 39 to 21 computations (46.2% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 82.0ms | 1.2141786235318232e-27 | 8.078871710173054e-26 |
| 14.0ms | -53869.33640430183 | -0.2794585548801859 |
| 94.0ms | 256× | body | 256 | valid |
Compiled 320 to 219 computations (31.6% saved)
| Inputs |
|---|
x |
(*.f64 y z) |
(*.f64 (neg.f64 y) x) |
(*.f64 y (-.f64 z x)) |
(*.f64 (-.f64 1 y) x) |
| Outputs |
|---|
(*.f64 y (-.f64 z x)) |
(*.f64 (-.f64 1 y) x) |
(*.f64 y (-.f64 z x)) |
3 calls:
| 51.0ms | z |
| 16.0ms | y |
| 16.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 12.0b | 3 | x |
| 11.4b | 3 | y |
| 13.0b | 5 | z |
Compiled 33 to 20 computations (39.4% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 11.0ms | 1.2141786235318232e-27 | 8.078871710173054e-26 |
| 53.0ms | -53869.33640430183 | -0.2794585548801859 |
| 61.0ms | 256× | body | 256 | valid |
Compiled 304 to 219 computations (28% saved)
| Inputs |
|---|
x |
(*.f64 y z) |
(*.f64 (neg.f64 y) x) |
(*.f64 y (-.f64 z x)) |
| Outputs |
|---|
(*.f64 y (-.f64 z x)) |
x |
(*.f64 y (-.f64 z x)) |
3 calls:
| 98.0ms | x |
| 85.0ms | z |
| 11.0ms | y |
| Error | Segments | Branch |
|---|---|---|
| 16.0b | 9 | x |
| 11.8b | 3 | y |
| 18.7b | 9 | z |
Compiled 28 to 17 computations (39.3% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 11.0ms | 1.2141786235318232e-27 | 8.078871710173054e-26 |
| 8.0ms | -4.511103482871198e-58 | -2.070765082117659e-58 |
| 16.0ms | 192× | body | 256 | valid |
Compiled 184 to 131 computations (28.8% saved)
| Inputs |
|---|
x |
(*.f64 y z) |
(*.f64 (neg.f64 y) x) |
| Outputs |
|---|
(*.f64 (neg.f64 y) x) |
(*.f64 y z) |
x |
(*.f64 y z) |
3 calls:
| 50.0ms | z |
| 15.0ms | x |
| 13.0ms | y |
| Error | Segments | Branch |
|---|---|---|
| 21.3b | 5 | x |
| 19.0b | 4 | y |
| 23.3b | 5 | z |
Compiled 23 to 15 computations (34.8% saved)
| 3× | binary-search |
| Time | Left | Right |
|---|---|---|
| 12.0ms | 3.3277109109082598e-65 | 9.756929326824905e-61 |
| 2.3s | -4.511103482871198e-58 | -2.070765082117659e-58 |
| 15.0ms | -1.6747126527793546e+107 | -9.018637547029746e+104 |
| 2.3s | 320× | body | 256 | valid |
| 5.0ms | 35× | body | 256 | infinite |
Compiled 277 to 205 computations (26% saved)
Total -40.6b remaining (-190.1%)
Threshold costs -40.6b (-190.1%)
| Inputs |
|---|
x |
(*.f64 y z) |
| Outputs |
|---|
(*.f64 y z) |
x |
(*.f64 y z) |
3 calls:
| 6.3s | y |
| 16.0ms | z |
| 11.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 22.6b | 3 | x |
| 21.4b | 3 | y |
| 23.3b | 5 | z |
Compiled 19 to 13 computations (31.6% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 12.0ms | 3.3277109109082598e-65 | 9.756929326824905e-61 |
| 82.0ms | -4.511103482871198e-58 | -2.070765082117659e-58 |
| 18.0ms | 208× | body | 256 | valid |
Compiled 172 to 128 computations (25.6% saved)
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 52 | 269 |
| 1× | fuel |
| 1× | saturated |
| Inputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
(if (<=.f64 y -2386907802506363/4503599627370496) (*.f64 y (-.f64 z x)) (if (<=.f64 y 8920298079412249/2787593149816327892691964784081045188247552) (+.f64 x (*.f64 (neg.f64 y) x)) (*.f64 y (-.f64 z x)))) |
(if (<=.f64 y -165) (*.f64 y (-.f64 z x)) (if (<=.f64 y 6620533730813779/87112285931760246646623899502532662132736) (*.f64 (-.f64 1 y) x) (*.f64 y (-.f64 z x)))) |
(if (<=.f64 y -4664476251014935/14134776518227074636666380005943348126619871175004951664972849610340958208) (*.f64 y (-.f64 z x)) (if (<=.f64 y 3902630409742859/696898287454081973172991196020261297061888) x (*.f64 y (-.f64 z x)))) |
(if (<=.f64 y -1849999999999999923972281083043274417138357281949270804559702374433216959303142895622767346444793513246720) (*.f64 (neg.f64 y) x) (if (<=.f64 y -5088519546561747/14134776518227074636666380005943348126619871175004951664972849610340958208) (*.f64 y z) (if (<=.f64 y 578960446186581/115792089237316195423570985008687907853269984665640564039457584007913129639936) x (*.f64 y z)))) |
(if (<=.f64 y -3038976951418821/7067388259113537318333190002971674063309935587502475832486424805170479104) (*.f64 y z) (if (<=.f64 y 407588154115353/926336713898529563388567880069503262826159877325124512315660672063305037119488) x (*.f64 y z))) |
x |
| Outputs |
|---|
(+.f64 x (*.f64 y (-.f64 z x))) |
(if (<=.f64 y -2386907802506363/4503599627370496) (*.f64 y (-.f64 z x)) (if (<=.f64 y 8920298079412249/2787593149816327892691964784081045188247552) (+.f64 x (*.f64 (neg.f64 y) x)) (*.f64 y (-.f64 z x)))) |
(if (<=.f64 y -165) (*.f64 y (-.f64 z x)) (if (<=.f64 y 6620533730813779/87112285931760246646623899502532662132736) (*.f64 (-.f64 1 y) x) (*.f64 y (-.f64 z x)))) |
(if (<=.f64 y -4664476251014935/14134776518227074636666380005943348126619871175004951664972849610340958208) (*.f64 y (-.f64 z x)) (if (<=.f64 y 3902630409742859/696898287454081973172991196020261297061888) x (*.f64 y (-.f64 z x)))) |
(if (<=.f64 y -1849999999999999923972281083043274417138357281949270804559702374433216959303142895622767346444793513246720) (*.f64 (neg.f64 y) x) (if (<=.f64 y -5088519546561747/14134776518227074636666380005943348126619871175004951664972849610340958208) (*.f64 y z) (if (<=.f64 y 578960446186581/115792089237316195423570985008687907853269984665640564039457584007913129639936) x (*.f64 y z)))) |
(if (<=.f64 y -3038976951418821/7067388259113537318333190002971674063309935587502475832486424805170479104) (*.f64 y z) (if (<=.f64 y 407588154115353/926336713898529563388567880069503262826159877325124512315660672063305037119488) x (*.f64 y z))) |
x |
Compiled 133 to 73 computations (45.1% saved)
Compiled 115 to 46 computations (60% saved)
Loading profile data...