Time bar (total: 7.5s)
| 1× | search |
| True | Other | False | Iter |
|---|---|---|---|
| 0% | 99.9% | 0.1% | 0 |
| 0% | 99.9% | 0.1% | 1 |
| 0% | 99.9% | 0.1% | 2 |
| 0% | 99.9% | 0.1% | 3 |
| 0% | 99.9% | 0.1% | 4 |
| 12.5% | 87.4% | 0.1% | 5 |
| 31.2% | 68.7% | 0.1% | 6 |
| 40.6% | 59.3% | 0.1% | 7 |
| 57.8% | 42.1% | 0.1% | 8 |
| 63.2% | 36.7% | 0.1% | 9 |
| 72.2% | 25.8% | 2% | 10 |
| 75.1% | 21.7% | 3.2% | 11 |
| 79.7% | 14.2% | 6% | 12 |
Compiled 14 to 10 computations (28.6% saved)
| 1.6s | 8256× | body | 256 | valid |
| 211.0ms | 619× | body | 256 | invalid |
| 2× | egg-herbie |
| 1036× | fma-def_binary64 |
| 832× | cube-prod_binary64 |
| 475× | distribute-rgt-in_binary64 |
| 432× | distribute-lft-in_binary64 |
| 422× | swap-sqr_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 14 | 32 |
| 1 | 38 | 28 |
| 2 | 66 | 28 |
| 3 | 170 | 28 |
| 4 | 368 | 28 |
| 5 | 830 | 28 |
| 6 | 1247 | 28 |
| 7 | 1553 | 28 |
| 8 | 2731 | 28 |
| 9 | 3477 | 28 |
| 10 | 4351 | 28 |
| 11 | 4902 | 28 |
| 12 | 5718 | 28 |
| 13 | 6277 | 28 |
| 14 | 7134 | 28 |
| 0 | 2 | 2 |
| 1× | saturated |
| 1× | node limit |
| Inputs |
|---|
0 |
1 |
| Outputs |
|---|
0 |
1 |
| Inputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 (*.f64 y (+.f64 (/.f64 y x) 1)) (+.f64 y 1)) |
| Outputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
(/.f64 (*.f64 y (+.f64 (/.f64 y x) 1)) (+.f64 y 1)) |
(/.f64 y (/.f64 (+.f64 y 1) (+.f64 1 (/.f64 y x)))) |
(/.f64 (fma.f64 y (/.f64 y x) y) (+.f64 y 1)) |
Compiled 15 to 11 computations (26.7% saved)
| 1× | egg-herbie |
| 971× | fma-def_binary64 |
| 682× | distribute-rgt-in_binary64 |
| 629× | distribute-lft-in_binary64 |
| 559× | associate-/l*_binary64 |
| 519× | associate-/l/_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 16 |
| 1 | 22 | 14 |
| 2 | 36 | 14 |
| 3 | 81 | 14 |
| 4 | 143 | 14 |
| 5 | 285 | 14 |
| 6 | 742 | 14 |
| 7 | 1089 | 14 |
| 8 | 1620 | 14 |
| 9 | 1850 | 14 |
| 10 | 2280 | 14 |
| 11 | 2944 | 14 |
| 12 | 3273 | 14 |
| 13 | 3812 | 14 |
| 14 | 7717 | 14 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| Outputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(/.f64 x (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))) |
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
Compiled 23 to 13 computations (43.5% saved)
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 2 | 2 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 3 | 3 |
| Status | Error | Program |
|---|---|---|
| ▶ | 10.3b | (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
| ▶ | 10.3b | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
Compiled 25 to 16 computations (36% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.1b | (*.f64 x (+.f64 (/.f64 x y) 1)) |
| ✓ | 9.6b | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
Compiled 34 to 17 computations (50% saved)
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | inf | (*.f64 x (+.f64 (/.f64 x y) 1)) |
| 1.0ms | y | @ | 0 | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 1.0ms | x | @ | 0 | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 1.0ms | y | @ | -inf | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 1.0ms | x | @ | -inf | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 1× | batch-egg-rewrite |
| 574× | log-prod_binary64 |
| 475× | prod-diff_binary64 |
| 279× | pow2_binary64 |
| 271× | fma-def_binary64 |
| 207× | fma-neg_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 26 |
| 1 | 209 | 22 |
| 2 | 3245 | 22 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(*.f64 x (+.f64 (/.f64 x y) 1)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 1 (/.f64 (+.f64 x 1) (+.f64 (/.f64 x y) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 (+.f64 (/.f64 x y) 1) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (/.f64 x y) 1) (*.f64 x (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (*.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (*.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1) (/.f64 (+.f64 (/.f64 x y) 1) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (/.f64 x y) 1) 1) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) 1) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 1) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (+.f64 (/.f64 x y) 1) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) -2) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (/.f64 x y) 1) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 x (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (hypot.f64 1 (sqrt.f64 x))) (/.f64 (+.f64 (/.f64 x y) 1) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (/.f64 x y) 1) (hypot.f64 1 (sqrt.f64 x))) (/.f64 x (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 x 1) -1/2) (/.f64 (fma.f64 x (/.f64 x y) x) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (hypot.f64 1 (sqrt.f64 x))) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 x x -1)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)) 1)))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 x (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x (/.f64 x y)) 1) x)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x))) 2)) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x (/.f64 x y) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x (/.f64 x y)) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (*.f64 x (/.f64 x y)) 2) (-.f64 (*.f64 x x) (*.f64 (*.f64 x (/.f64 x y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x (/.f64 x y)) 2) (*.f64 x x)) (fma.f64 x (/.f64 x y) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) x) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (+.f64 (/.f64 x y) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 1 (pow.f64 (/.f64 x y) 3))) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (pow.f64 (/.f64 x y) 2) -1)) (+.f64 (/.f64 x y) -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x (/.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 3) (pow.f64 (+.f64 (/.f64 x y) 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (+.f64 (/.f64 x y) 1) 3) (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x (/.f64 x y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 x) (exp.f64 (*.f64 x (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 x)) (exp.f64 (*.f64 x (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 x (/.f64 x y))) (+.f64 1 (expm1.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (+.f64 (/.f64 x y) 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 (/.f64 x y) 1) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (/.f64 x y) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 1 (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x y) x x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 x (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x x) (/.f64 1 y) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 x) (pow.f64 (cbrt.f64 x) 2) (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 x) (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) 1) (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 x y)) 2) (*.f64 (cbrt.f64 (/.f64 x y)) x) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (sqrt.f64 x) (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) 1) (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x y)) (*.f64 (sqrt.f64 (/.f64 x y)) x) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (/.f64 x y)) 1 x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x (/.f64 x y))) 2) (cbrt.f64 (*.f64 x (/.f64 x y))) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x (/.f64 x y))) (sqrt.f64 (*.f64 x (/.f64 x y))) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 x) (sqrt.f64 (/.f64 x y))) (*.f64 (sqrt.f64 x) (sqrt.f64 (/.f64 x y))) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 x)) (*.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 x)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (pow.f64 (cbrt.f64 (/.f64 x y)) 2)) (cbrt.f64 (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (sqrt.f64 (/.f64 x y))) (sqrt.f64 (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x y) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x y) (sqrt.f64 x)) (sqrt.f64 x) x))))) |
| 1× | egg-herbie |
| 657× | associate--l+_binary64 |
| 656× | associate-+l-_binary64 |
| 508× | unsub-neg_binary64 |
| 421× | +-commutative_binary64 |
| 361× | associate--r+_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 57 | 699 |
| 1 | 153 | 699 |
| 2 | 446 | 625 |
| 3 | 2032 | 596 |
| 4 | 7592 | 590 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(/.f64 x y) |
(+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1)))) (/.f64 1 x)) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2))) (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))))) (/.f64 1 x)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
| Outputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x) |
(fma.f64 x (+.f64 (/.f64 x y) (neg.f64 x)) x) |
(fma.f64 x (-.f64 (/.f64 x y) x) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x)) |
(+.f64 x (*.f64 x (*.f64 (+.f64 (/.f64 1 y) -1) (+.f64 x (*.f64 x (neg.f64 x)))))) |
(+.f64 x (*.f64 x (*.f64 (+.f64 (/.f64 1 y) -1) (-.f64 x (*.f64 x x))))) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x))) |
(+.f64 x (*.f64 (*.f64 x x) (+.f64 (+.f64 (/.f64 1 y) -1) (*.f64 (+.f64 (/.f64 x y) (neg.f64 x)) (+.f64 x -1))))) |
(+.f64 x (*.f64 (*.f64 x x) (+.f64 (+.f64 (/.f64 1 y) -1) (*.f64 (-.f64 (/.f64 x y) x) (+.f64 x -1))))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 x y)) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 1 (/.f64 -1 y)) (-.f64 (/.f64 x y) (/.f64 1 x)))) |
(+.f64 (+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 x y)) (/.f64 (+.f64 (/.f64 1 y) -1) x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 (+.f64 1 (/.f64 -1 y)) x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 (/.f64 1 (*.f64 x x)) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y))))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (-.f64 (/.f64 (+.f64 1 (/.f64 -1 y)) (*.f64 x x)) (+.f64 (/.f64 1 y) (/.f64 1 x)))))) |
(+.f64 1 (+.f64 (/.f64 -1 y) (+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (+.f64 (/.f64 1 y) -1) x))))) |
(/.f64 x y) |
(+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 x y)) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1)))) (/.f64 1 x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 1 (/.f64 -1 y)) (-.f64 (/.f64 x y) (/.f64 1 x)))) |
(+.f64 (+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 x y)) (/.f64 (+.f64 (/.f64 1 y) -1) x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 (+.f64 1 (/.f64 -1 y)) x))) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2))) (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))))) (/.f64 1 x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 (/.f64 1 (*.f64 x x)) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y))))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (-.f64 (/.f64 (+.f64 1 (/.f64 -1 y)) (*.f64 x x)) (+.f64 (/.f64 1 y) (/.f64 1 x)))))) |
(+.f64 1 (+.f64 (/.f64 -1 y) (+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (+.f64 (/.f64 1 y) -1) x))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.1b | (fma.f64 x (/.f64 x y) x) |
| ✓ | 9.6b | (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
Compiled 27 to 10 computations (63% saved)
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | (fma.f64 x (/.f64 x y) x) |
| 1.0ms | x | @ | -inf | (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
| 1.0ms | y | @ | -inf | (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
| 0.0ms | y | @ | inf | (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
| 0.0ms | y | @ | 0 | (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
| 1× | batch-egg-rewrite |
| 643× | unpow-prod-down_binary64 |
| 447× | log-prod_binary64 |
| 263× | pow-prod-down_binary64 |
| 235× | pow2_binary64 |
| 199× | prod-diff_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 22 |
| 1 | 175 | 22 |
| 2 | 2470 | 22 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
(fma.f64 x (/.f64 x y) x) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (*.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (*.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (/.f64 1 (fma.f64 -1 x -1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) (pow.f64 (/.f64 1 (fma.f64 x (/.f64 x y) x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) 1) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 1) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) -2) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 x 1) -1/2) (/.f64 (fma.f64 x (/.f64 x y) x) (sqrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (sqrt.f64 (+.f64 x 1))) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (sqrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 x x -1)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) 1) 1) (pow.f64 (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 1) 1) (pow.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) -2) 1) (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) 1) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) 1) (pow.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (cbrt.f64 (+.f64 x 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (+.f64 x 1) -1/2) 1) (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (sqrt.f64 (+.f64 x 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (sqrt.f64 (+.f64 x 1))) 1) (pow.f64 (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (sqrt.f64 (+.f64 x 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 1 (pow.f64 x 3))) 1) (-.f64 (fma.f64 x x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 x x -1)) 1) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2) (fma.f64 x (/.f64 x y) x)) 1/3) (cbrt.f64 (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2) 1/3) (cbrt.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 5/2) 1/3) (cbrt.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2) 3) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x))) 2) -1) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) 2) 1) -1) (pow.f64 (/.f64 (cbrt.f64 (+.f64 x 1)) (fma.f64 x (/.f64 x y) x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (+.f64 x 1)) 1) -1) (pow.f64 (/.f64 (sqrt.f64 (+.f64 x 1)) (fma.f64 x (/.f64 x y) x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) -2) -1) (pow.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) 2) (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2)) -1) (pow.f64 (/.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (+.f64 x 1)) (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2)) -1) (pow.f64 (/.f64 (sqrt.f64 (+.f64 x 1)) (cbrt.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) -1/2) -1) (pow.f64 (/.f64 (+.f64 x 1) (sqrt.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) 2) (sqrt.f64 (fma.f64 x (/.f64 x y) x))) -1) (pow.f64 (/.f64 (cbrt.f64 (+.f64 x 1)) (sqrt.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (+.f64 x 1)) (sqrt.f64 (fma.f64 x (/.f64 x y) x))) -1) (pow.f64 (/.f64 (sqrt.f64 (+.f64 x 1)) (sqrt.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/3 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/2 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log1p.f64 x) (log.f64 (fma.f64 x (/.f64 x y) x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)) 1) 1)))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 x (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x (/.f64 x y)) 1) x)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x))) 2)) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x (/.f64 x y) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (/.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (cbrt.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (sqrt.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (fma.f64 x (/.f64 x y) x))) 2) 1/3) (cbrt.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 5/2) 1/3) (cbrt.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x))) 2) 3) (cbrt.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x (/.f64 x y)) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (*.f64 x (/.f64 x y)) 2) (-.f64 (*.f64 x x) (*.f64 (*.f64 x (/.f64 x y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x (/.f64 x y)) 2) (*.f64 x x)) (-.f64 (*.f64 x (/.f64 x y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x (/.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x (/.f64 x y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 x) (pow.f64 (exp.f64 x) (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 x)) (pow.f64 (exp.f64 x) (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 x) (/.f64 x y)) (+.f64 1 (expm1.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (fma.f64 x (/.f64 x y) x))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) 1) 1)))))) |
| 1× | egg-herbie |
| 630× | associate--l+_binary64 |
| 573× | associate-+l-_binary64 |
| 409× | +-commutative_binary64 |
| 381× | unsub-neg_binary64 |
| 331× | associate-*l*_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 59 | 699 |
| 1 | 158 | 699 |
| 2 | 446 | 643 |
| 3 | 1901 | 607 |
| 4 | 6695 | 603 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x)))) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (pow.f64 x 2)) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x))))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
| Outputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x) |
(fma.f64 x (*.f64 x (+.f64 (/.f64 1 y) -1)) x) |
(fma.f64 x (+.f64 (/.f64 x y) (neg.f64 x)) x) |
(fma.f64 x (-.f64 (/.f64 x y) x) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 x (*.f64 x (+.f64 (/.f64 1 y) -1)) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x)) |
(+.f64 x (*.f64 (*.f64 x x) (*.f64 (+.f64 1 (/.f64 -1 y)) (+.f64 x -1)))) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 x (*.f64 x (+.f64 (/.f64 1 y) -1)) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x))) |
(+.f64 (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x) (*.f64 (+.f64 (/.f64 x y) (neg.f64 x)) (+.f64 x (pow.f64 x 3)))) |
(+.f64 (fma.f64 (*.f64 x x) (-.f64 x (/.f64 x y)) x) (*.f64 (-.f64 (/.f64 x y) x) (+.f64 x (pow.f64 x 3)))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (+.f64 1 (/.f64 -1 y))) |
(+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 x y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y)))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 1 (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 -1 x)))) |
(+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y)))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (-.f64 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (/.f64 1 (*.f64 x x))) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 (*.f64 x x))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 x (*.f64 x y)))))) (/.f64 -1 x))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x x)) (-.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x x)) (+.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 (/.f64 -1 x) (*.f64 x y))))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (+.f64 1 (/.f64 -1 y))) |
(+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 x y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x)))) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y)))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 1 (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 -1 x)))) |
(+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y)))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (pow.f64 x 2)) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x))))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (-.f64 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (/.f64 1 (*.f64 x x))) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 (*.f64 x x))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 x (*.f64 x y)))))) (/.f64 -1 x))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x x)) (-.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x x)) (+.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 (/.f64 -1 x) (*.f64 x y))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(+.f64 x (*.f64 x (/.f64 x y))) |
Compiled 4627 to 2166 computations (53.2% saved)
12 alts after pruning (11 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 263 | 11 | 274 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 1 | 1 |
| Total | 264 | 12 | 276 |
| Status | Error | Program |
|---|---|---|
| ▶ | 10.3b | (/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
| 28.2b | (/.f64 x (+.f64 x 1)) | |
| 17.6b | (/.f64 (/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (+.f64 (/.f64 x y) -1)) (+.f64 x 1)) | |
| ▶ | 33.0b | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| 38.2b | x | |
| 21.3b | (/.f64 (/.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) x) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y)))) (+.f64 x 1)) | |
| ▶ | 42.0b | (/.f64 x y) |
| ▶ | 44.9b | (/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
| 44.2b | (/.f64 (*.f64 x (/.f64 x y)) (+.f64 x 1)) | |
| ▶ | 0.1b | (*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
| 32.5b | (+.f64 x (*.f64 (*.f64 x x) (*.f64 (+.f64 1 (/.f64 -1 y)) (+.f64 x -1)))) | |
| ✓ | 10.3b | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
Compiled 288 to 193 computations (33% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (/.f64 x (+.f64 x 1)) |
| ✓ | 0.0b | (*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
Compiled 32 to 17 computations (46.9% saved)
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | inf | (/.f64 x (+.f64 x 1)) |
| 0.0ms | x | @ | 0 | (*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
| 0.0ms | x | @ | inf | (*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
| 0.0ms | x | @ | -inf | (/.f64 x (+.f64 x 1)) |
| 0.0ms | x | @ | 0 | (/.f64 x (+.f64 x 1)) |
| 1× | batch-egg-rewrite |
| 778× | prod-diff_binary64 |
| 554× | log-prod_binary64 |
| 308× | fma-def_binary64 |
| 276× | pow2_binary64 |
| 233× | log-div_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 23 |
| 1 | 209 | 23 |
| 2 | 3257 | 21 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
(/.f64 x (+.f64 x 1)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 x (+.f64 x 1)) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) 1) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 x (/.f64 (+.f64 x 1) (+.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 (+.f64 x 1) x) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) (*.f64 (/.f64 (+.f64 x 1) x) (+.f64 (/.f64 x y) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 x (/.f64 x y) x)) (fma.f64 -1 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 1 (pow.f64 (/.f64 x y) 3))) (*.f64 (+.f64 x 1) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 x) (+.f64 1 (pow.f64 (/.f64 x y) 3))) (*.f64 (fma.f64 -1 x -1) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (pow.f64 (/.f64 x y) 2) -1)) (*.f64 (+.f64 x 1) (+.f64 (/.f64 x y) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 x) (+.f64 (pow.f64 (/.f64 x y) 2) -1)) (*.f64 (fma.f64 -1 x -1) (+.f64 (/.f64 x y) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) x) (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (*.f64 (+.f64 (/.f64 x y) -1) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) 1) (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))) (/.f64 (+.f64 x 1) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) 1) (*.f64 (+.f64 (/.f64 x y) -1) (/.f64 (+.f64 x 1) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) (neg.f64 x)) (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))) (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) (neg.f64 x)) (*.f64 (+.f64 (/.f64 x y) -1) (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) 3) (pow.f64 (/.f64 x (+.f64 x 1)) 3)) (+.f64 (pow.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) 2) (-.f64 (pow.f64 (/.f64 x (+.f64 x 1)) 2) (*.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) (/.f64 x (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) 2) (pow.f64 (/.f64 x (+.f64 x 1)) 2)) (-.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (fma.f64 x (/.f64 x y) x) 1) (+.f64 x 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (sqrt.f64 (+.f64 x 1))) (sqrt.f64 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 x) (+.f64 1 (/.f64 x y))) (fma.f64 -1 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) (/.f64 x (+.f64 x 1))) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) (/.f64 x (+.f64 x 1))) (+.f64 (/.f64 x y) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 x (+.f64 x 1)) (+.f64 1 (pow.f64 (/.f64 x y) 3))) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (pow.f64 (/.f64 x y) 2) -1)) (+.f64 (/.f64 x y) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (/.f64 x y)) (neg.f64 x)) (fma.f64 -1 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 x (+.f64 x 1)) 3) (pow.f64 (+.f64 1 (/.f64 x y)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 (/.f64 x (+.f64 x 1)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (/.f64 x (+.f64 x 1))) (exp.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (/.f64 x (+.f64 x 1)))) (exp.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))) (+.f64 1 (expm1.f64 (/.f64 x (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 x (+.f64 x 1)) 3) (pow.f64 (+.f64 1 (/.f64 x y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 (/.f64 x (+.f64 x 1)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (/.f64 1 (+.f64 x 1)) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 (/.f64 1 (+.f64 x 1)) 1) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 (/.f64 1 y) (/.f64 x (+.f64 x 1))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 (/.f64 1 (+.f64 x 1)) (/.f64 x y)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 x (+.f64 x 1)) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x (+.f64 x 1)) 1 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x y) (/.f64 x (+.f64 x 1)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2) (cbrt.f64 (/.f64 x (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2) (*.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 1) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2) (*.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) (/.f64 x y)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (/.f64 1 (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 x y)) 2) (*.f64 (cbrt.f64 (/.f64 x y)) (/.f64 x (+.f64 x 1))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (sqrt.f64 (/.f64 x (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (*.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) 1) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (*.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (/.f64 x y)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (/.f64 1 (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x y)) (*.f64 (sqrt.f64 (/.f64 x y)) (/.f64 x (+.f64 x 1))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 x) (/.f64 1 (fma.f64 -1 x -1)) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (+.f64 x 1)) x (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) 1 (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))) 2) (cbrt.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))) (sqrt.f64 (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (cbrt.f64 (*.f64 x x)) 1) (/.f64 (cbrt.f64 x) (+.f64 x 1)) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 x) 1) (/.f64 (sqrt.f64 x) (+.f64 x 1)) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 x (cbrt.f64 (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (/.f64 x (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (sqrt.f64 x) (cbrt.f64 (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (sqrt.f64 (+.f64 x 1))) (/.f64 x (sqrt.f64 (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (cbrt.f64 (*.f64 x x)) (sqrt.f64 (+.f64 x 1))) (/.f64 (cbrt.f64 x) (sqrt.f64 (+.f64 x 1))) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 (/.f64 x (+.f64 x 1)))) (*.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 (/.f64 x (+.f64 x 1)))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (sqrt.f64 (/.f64 x y))) (*.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (sqrt.f64 (/.f64 x y))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x y) x) (/.f64 1 (+.f64 x 1)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x (fma.f64 x x -1)) (+.f64 x -1) (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x (+.f64 x 1)) x) (/.f64 1 y) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x y) (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2)) (cbrt.f64 (/.f64 x (+.f64 x 1))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x y) (sqrt.f64 (/.f64 x (+.f64 x 1)))) (sqrt.f64 (/.f64 x (+.f64 x 1))) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x (+.f64 x 1)) (pow.f64 (cbrt.f64 (/.f64 x y)) 2)) (cbrt.f64 (/.f64 x y)) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (/.f64 x (+.f64 x 1)) (sqrt.f64 (/.f64 x y))) (sqrt.f64 (/.f64 x y)) (/.f64 x (+.f64 x 1))))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 x (+.f64 x 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 x (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 x (+.f64 x 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 x (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 x (+.f64 x 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 (/.f64 1 (+.f64 x 1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2) (cbrt.f64 (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 2) (*.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (sqrt.f64 (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) (*.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 x) (/.f64 1 (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) 1) (/.f64 (cbrt.f64 x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) 1) (/.f64 (sqrt.f64 x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 x (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (sqrt.f64 x) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (+.f64 x 1))) (/.f64 x (sqrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) (sqrt.f64 (+.f64 x 1))) (/.f64 (cbrt.f64 x) (sqrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (fma.f64 x x -1)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (+.f64 x 1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 x (+.f64 x 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 x (+.f64 x 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x 1) x) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 x 3) (pow.f64 (+.f64 x 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (+.f64 x 1) x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 x (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 x (+.f64 x 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 x (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 x (+.f64 x 1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 x 3) (pow.f64 (+.f64 x 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 x (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 x) (log1p.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log.f64 x) (log1p.f64 x)) 1)))))) |
| 1× | egg-herbie |
| 628× | unsub-neg_binary64 |
| 500× | +-commutative_binary64 |
| 392× | associate--r+_binary64 |
| 381× | associate-*l*_binary64 |
| 332× | sub-neg_binary64 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 67 | 637 |
| 1 | 194 | 633 |
| 2 | 572 | 555 |
| 3 | 2438 | 517 |
| 4 | 7440 | 517 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(/.f64 x y) |
(+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1)))) (/.f64 1 x)) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2))) (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))))) (/.f64 1 x)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
x |
(+.f64 (*.f64 -1 (pow.f64 x 2)) x) |
(+.f64 (*.f64 -1 (pow.f64 x 2)) (+.f64 (pow.f64 x 3) x)) |
(+.f64 (*.f64 -1 (pow.f64 x 2)) (+.f64 (*.f64 -1 (pow.f64 x 4)) (+.f64 (pow.f64 x 3) x))) |
1 |
(-.f64 1 (/.f64 1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (/.f64 1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (+.f64 (/.f64 1 x) (/.f64 1 (pow.f64 x 3)))) |
1 |
(-.f64 1 (/.f64 1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (/.f64 1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (+.f64 (/.f64 1 x) (/.f64 1 (pow.f64 x 3)))) |
| Outputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x) |
(fma.f64 x (*.f64 x (+.f64 (/.f64 1 y) -1)) x) |
(fma.f64 x (-.f64 (/.f64 x y) x) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 x (*.f64 x (+.f64 (/.f64 1 y) -1)) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x)) |
(+.f64 x (*.f64 x (*.f64 (+.f64 (/.f64 1 y) -1) (fma.f64 x (neg.f64 x) x)))) |
(+.f64 x (*.f64 x (*.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x (-.f64 1 x))))) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 x (*.f64 x (+.f64 (/.f64 1 y) -1)) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x))) |
(+.f64 x (*.f64 (*.f64 x x) (+.f64 (+.f64 (/.f64 1 y) -1) (*.f64 (-.f64 (/.f64 x y) x) (+.f64 x -1))))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y)))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) (/.f64 (+.f64 1 (/.f64 -1 y)) x)) |
(-.f64 1 (+.f64 (-.f64 (/.f64 1 y) (/.f64 x y)) (/.f64 (+.f64 1 (/.f64 -1 y)) x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 (/.f64 1 (*.f64 x x)) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y))))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (-.f64 (/.f64 (+.f64 1 (/.f64 -1 y)) (*.f64 x x)) (+.f64 (/.f64 1 y) (/.f64 1 x)))))) |
(+.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) (*.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (+.f64 (/.f64 1 y) -1) x))) |
(/.f64 x y) |
(+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1)))) (/.f64 1 x)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y)))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 (+.f64 1 (/.f64 -1 y)) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) (/.f64 (+.f64 1 (/.f64 -1 y)) x)) |
(-.f64 1 (+.f64 (-.f64 (/.f64 1 y) (/.f64 x y)) (/.f64 (+.f64 1 (/.f64 -1 y)) x))) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2))) (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))))) (/.f64 1 x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (-.f64 (/.f64 1 (*.f64 x x)) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y))))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (-.f64 (/.f64 (+.f64 1 (/.f64 -1 y)) (*.f64 x x)) (+.f64 (/.f64 1 y) (/.f64 1 x)))))) |
(+.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) (*.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (+.f64 (/.f64 1 y) -1) x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x)) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
x |
(+.f64 (*.f64 -1 (pow.f64 x 2)) x) |
(fma.f64 -1 (*.f64 x x) x) |
(-.f64 x (*.f64 x x)) |
(fma.f64 x (neg.f64 x) x) |
(*.f64 x (-.f64 1 x)) |
(+.f64 (*.f64 -1 (pow.f64 x 2)) (+.f64 (pow.f64 x 3) x)) |
(fma.f64 -1 (*.f64 x x) (+.f64 x (pow.f64 x 3))) |
(+.f64 x (*.f64 (*.f64 x x) (+.f64 -1 x))) |
(fma.f64 (*.f64 x x) (+.f64 x -1) x) |
(*.f64 x (-.f64 (fma.f64 x x 1) x)) |
(+.f64 (*.f64 -1 (pow.f64 x 2)) (+.f64 (*.f64 -1 (pow.f64 x 4)) (+.f64 (pow.f64 x 3) x))) |
(fma.f64 -1 (*.f64 x x) (fma.f64 -1 (pow.f64 x 4) (+.f64 x (pow.f64 x 3)))) |
(-.f64 (-.f64 (+.f64 x (pow.f64 x 3)) (pow.f64 x 4)) (*.f64 x x)) |
(-.f64 (+.f64 x (pow.f64 x 3)) (fma.f64 x x (pow.f64 x 4))) |
(*.f64 (fma.f64 x x 1) (fma.f64 x (neg.f64 x) x)) |
(*.f64 (fma.f64 x x 1) (*.f64 x (-.f64 1 x))) |
1 |
(-.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 -1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (/.f64 1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (*.f64 x x))) (/.f64 1 x)) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x x)) (/.f64 -1 x))) |
(+.f64 (/.f64 1 (*.f64 x x)) (+.f64 1 (/.f64 -1 x))) |
(-.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (/.f64 -1 x) x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (+.f64 (/.f64 1 x) (/.f64 1 (pow.f64 x 3)))) |
(+.f64 1 (-.f64 (/.f64 1 (*.f64 x x)) (+.f64 (/.f64 1 x) (/.f64 1 (pow.f64 x 3))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x x)) (+.f64 (/.f64 -1 x) (/.f64 -1 (pow.f64 x 3))))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 -1 x) (/.f64 -1 (pow.f64 x 3))) (/.f64 (/.f64 -1 x) x))) |
1 |
(-.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 -1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (/.f64 1 x)) |
(-.f64 (+.f64 1 (/.f64 1 (*.f64 x x))) (/.f64 1 x)) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x x)) (/.f64 -1 x))) |
(+.f64 (/.f64 1 (*.f64 x x)) (+.f64 1 (/.f64 -1 x))) |
(-.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (/.f64 -1 x) x)) |
(-.f64 (+.f64 1 (/.f64 1 (pow.f64 x 2))) (+.f64 (/.f64 1 x) (/.f64 1 (pow.f64 x 3)))) |
(+.f64 1 (-.f64 (/.f64 1 (*.f64 x x)) (+.f64 (/.f64 1 x) (/.f64 1 (pow.f64 x 3))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x x)) (+.f64 (/.f64 -1 x) (/.f64 -1 (pow.f64 x 3))))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 -1 x) (/.f64 -1 (pow.f64 x 3))) (/.f64 (/.f64 -1 x) x))) |
Compiled 7 to 3 computations (57.1% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
Compiled 25 to 13 computations (48% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | -inf | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| 1.0ms | x | @ | 0 | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| 1.0ms | y | @ | 0 | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| 1.0ms | x | @ | -inf | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| 0.0ms | x | @ | inf | (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| 1× | batch-egg-rewrite |
| 495× | fma-def_binary64 |
| 435× | log-prod_binary64 |
| 335× | exp-prod_binary64 |
| 303× | pow-prod-down_binary64 |
| 248× | fma-neg_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 13 |
| 1 | 184 | 10 |
| 2 | 2838 | 10 |
| 1× | node limit |
| Inputs |
|---|
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (/.f64 (-.f64 x 1) y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (*.f64 (/.f64 (-.f64 x 1) y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 x y) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 x y) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (/.f64 x y)) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (/.f64 x y)) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (+.f64 1 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 -1 y) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (-.f64 x 1) y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))) (log.f64 (sqrt.f64 (exp.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 1 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2)) (/.f64 1 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y))) (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3)) (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2)) (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3))) (neg.f64 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2))) (neg.f64 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) y) (*.f64 (fma.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1) 1) 1)) (*.f64 (fma.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1) 1) y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (/.f64 y x) -2)) y) (*.f64 (-.f64 1 (/.f64 x y)) 1)) (*.f64 (-.f64 1 (/.f64 x y)) y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) (neg.f64 y)) (*.f64 (fma.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1) 1) -1)) (*.f64 (fma.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1) 1) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (/.f64 y x) -2)) (neg.f64 y)) (*.f64 (-.f64 1 (/.f64 x y)) -1)) (*.f64 (-.f64 1 (/.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 (/.f64 (-.f64 x 1) y) 3)) (+.f64 1 (-.f64 (pow.f64 (/.f64 (-.f64 x 1) y) 2) (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 (/.f64 -1 y) 3)) (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (-.f64 (pow.f64 (/.f64 -1 y) 2) (*.f64 (+.f64 1 (/.f64 x y)) (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 (/.f64 (-.f64 x 1) y) 2)) (-.f64 1 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 (/.f64 -1 y) 2)) (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log1p.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y))) (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log1p.f64 (/.f64 (-.f64 x 1) y))) 2)) (cbrt.f64 (log1p.f64 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log1p.f64 (/.f64 (-.f64 x 1) y)))) (sqrt.f64 (log1p.f64 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 x y)))) (exp.f64 (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (exp.f64 (+.f64 1 (/.f64 x y))) (+.f64 1 (expm1.f64 (/.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 x y)))) (+.f64 1 (expm1.f64 (/.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 x y)))) (exp.f64 (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (/.f64 -1 y)) (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log1p.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log1p.f64 (/.f64 (-.f64 x 1) y)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log1p.f64 (/.f64 (-.f64 x 1) y))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/3 (log1p.f64 (/.f64 (-.f64 x 1) y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/2 (log1p.f64 (/.f64 (-.f64 x 1) y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log1p.f64 (/.f64 (-.f64 x 1) y)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 x y) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 x y) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (/.f64 x y)) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (/.f64 x y)) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (/.f64 (-.f64 x 1) y)) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (/.f64 (-.f64 x 1) y)) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (/.f64 (-.f64 x 1) y)) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 -1 y) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 (-.f64 x 1) y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (/.f64 1 y) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (/.f64 1 y) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x y) 1 (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 x y) 1 (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (/.f64 x y)) 1 (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (/.f64 x y)) 1 (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 y) x (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 y) x (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 y) (-.f64 x 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 1 (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 1 (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (/.f64 (-.f64 x 1) y)) 1 (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) 2) (cbrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (/.f64 x y)) (cbrt.f64 (pow.f64 (/.f64 y x) -2)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (/.f64 x y)) (cbrt.f64 (pow.f64 (/.f64 y x) -2)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (/.f64 y x) -2)) (cbrt.f64 (/.f64 x y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (/.f64 y x) -2)) (cbrt.f64 (/.f64 x y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (cbrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (cbrt.f64 (+.f64 1 (/.f64 x y))) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (/.f64 1 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (/.f64 1 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 y -2)) (neg.f64 (/.f64 1 (cbrt.f64 y))) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (sqrt.f64 (+.f64 1 (/.f64 (-.f64 x 1) y))) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 (/.f64 x y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 (/.f64 x y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (sqrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (sqrt.f64 (+.f64 1 (/.f64 x y))) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (/.f64 1 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (/.f64 1 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 y -1/2) (neg.f64 (pow.f64 y -1/2)) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 y -1/2) (/.f64 x (sqrt.f64 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 y -1/2) (/.f64 x (sqrt.f64 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1 (/.f64 1 y) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 x) (/.f64 -1 y) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 x) (/.f64 -1 y) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y)))) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y)))) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 y -3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (+.f64 (pow.f64 y -2) (/.f64 (+.f64 1 (/.f64 x y)) y)))) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) (/.f64 1 (fma.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1) 1)) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) (/.f64 1 (fma.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1) 1)) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2)) (/.f64 1 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y))) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2)) (/.f64 1 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y))) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 2) (pow.f64 y -2)) (/.f64 1 (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y))) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (/.f64 y x) -2)) (/.f64 1 (-.f64 1 (/.f64 x y))) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (/.f64 y x) -2)) (/.f64 1 (-.f64 1 (/.f64 x y))) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 -1 y)) 2) (cbrt.f64 (/.f64 -1 y)) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 x 1) y)) 2) (cbrt.f64 (/.f64 (-.f64 x 1) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 -1 y)) (sqrt.f64 (/.f64 -1 y)) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 (-.f64 x 1) y)) (sqrt.f64 (/.f64 (-.f64 x 1) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (pow.f64 y -1/2)) (pow.f64 y -1/2) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) 1) (/.f64 (cbrt.f64 x) y) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) 1) (/.f64 (cbrt.f64 x) y) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 x) 1) (/.f64 (sqrt.f64 x) y) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 x) 1) (/.f64 (sqrt.f64 x) y) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) -2) (/.f64 x (cbrt.f64 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) -2) (/.f64 x (cbrt.f64 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (/.f64 x y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (/.f64 x y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 y) 2)) (/.f64 (sqrt.f64 x) (cbrt.f64 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 y) 2)) (/.f64 (sqrt.f64 x) (cbrt.f64 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) (sqrt.f64 y)) (/.f64 (cbrt.f64 x) (sqrt.f64 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) (sqrt.f64 y)) (/.f64 (cbrt.f64 x) (sqrt.f64 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (/.f64 x y)) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (/.f64 x y)) (pow.f64 y -1/2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 y -1/2)) (+.f64 (/.f64 -1 y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (cbrt.f64 (pow.f64 y -2))) (/.f64 1 (cbrt.f64 y)) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (cbrt.f64 (pow.f64 y -2))) (/.f64 1 (cbrt.f64 y)) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (cbrt.f64 (pow.f64 y -2))) (/.f64 1 (cbrt.f64 y)) (+.f64 1 (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (pow.f64 y -1/2)) (pow.f64 y -1/2) (-.f64 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (pow.f64 y -1/2)) (pow.f64 y -1/2) (+.f64 1 (/.f64 -1 y))))))) |
| 1× | egg-herbie |
| 203× | fma-neg_binary64 |
| 192× | fma-def_binary64 |
| 74× | unsub-neg_binary64 |
| 44× | cancel-sign-sub-inv_binary64 |
| 40× | sub-neg_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 15 | 66 |
| 1 | 30 | 54 |
| 2 | 57 | 54 |
| 3 | 82 | 54 |
| 4 | 147 | 54 |
| 5 | 407 | 54 |
| 6 | 861 | 54 |
| 7 | 1033 | 54 |
| 8 | 1087 | 54 |
| 9 | 1093 | 54 |
| 1× | saturated |
| Inputs |
|---|
(-.f64 1 (/.f64 1 y)) |
(/.f64 x y) |
(/.f64 x y) |
(/.f64 (-.f64 x 1) y) |
1 |
1 |
(+.f64 1 (*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y))) |
(+.f64 1 (*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y))) |
(+.f64 1 (*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y))) |
| Outputs |
|---|
(-.f64 1 (/.f64 1 y)) |
(+.f64 1 (/.f64 -1 y)) |
(/.f64 x y) |
(/.f64 x y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
1 |
1 |
(+.f64 1 (*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y))) |
(+.f64 1 (neg.f64 (/.f64 (+.f64 1 (neg.f64 x)) y))) |
(-.f64 1 (/.f64 (-.f64 1 x) y)) |
(+.f64 1 (/.f64 (-.f64 x 1) y)) |
(+.f64 1 (/.f64 (+.f64 x -1) y)) |
(+.f64 1 (*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y))) |
(+.f64 1 (neg.f64 (/.f64 (+.f64 1 (neg.f64 x)) y))) |
(-.f64 1 (/.f64 (-.f64 1 x) y)) |
(+.f64 1 (/.f64 (-.f64 x 1) y)) |
(+.f64 1 (/.f64 (+.f64 x -1) y)) |
(+.f64 1 (*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y))) |
(+.f64 1 (neg.f64 (/.f64 (+.f64 1 (neg.f64 x)) y))) |
(-.f64 1 (/.f64 (-.f64 1 x) y)) |
(+.f64 1 (/.f64 (-.f64 x 1) y)) |
(+.f64 1 (/.f64 (+.f64 x -1) y)) |
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.1b | (*.f64 x (/.f64 x y)) |
| ✓ | 9.6b | (/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
Compiled 34 to 11 computations (67.6% saved)
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 4.0ms | y | @ | -inf | (/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
| 1.0ms | y | @ | 0 | (/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
| 1.0ms | x | @ | 0 | (*.f64 x (/.f64 x y)) |
| 1.0ms | y | @ | inf | (/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
| 1.0ms | x | @ | inf | (*.f64 x (/.f64 x y)) |
| 1× | batch-egg-rewrite |
| 548× | log-prod_binary64 |
| 352× | pow-prod-down_binary64 |
| 325× | fma-def_binary64 |
| 277× | pow2_binary64 |
| 219× | fma-neg_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 21 |
| 1 | 205 | 21 |
| 2 | 3069 | 21 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
(*.f64 x (/.f64 x y)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (*.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (*.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) 1) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 1) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) -2) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 x 1) -1/2) (/.f64 (fma.f64 x (/.f64 x y) x) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (hypot.f64 1 (sqrt.f64 x))) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 x x -1)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/2 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log1p.f64 x) (log.f64 (fma.f64 x (/.f64 x y) x))) -1)))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (/.f64 x y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 x (/.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 y (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x x) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 x x)) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 x) x) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (neg.f64 x)) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 x x) 1) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 x x) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 x x) (sqrt.f64 y)) (sqrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (/.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (sqrt.f64 y)) 4) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (/.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (sqrt.f64 y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (sqrt.f64 y)) 6) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (*.f64 x x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 x (sqrt.f64 y)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 y)) 6))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (/.f64 x y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x (/.f64 x y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 x (sqrt.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (/.f64 x (sqrt.f64 y)) 6)) 1/3)))))) |
| 1× | egg-herbie |
| 629× | associate--l+_binary64 |
| 575× | associate-+l-_binary64 |
| 407× | +-commutative_binary64 |
| 381× | unsub-neg_binary64 |
| 330× | associate-*l*_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 57 | 663 |
| 1 | 156 | 663 |
| 2 | 444 | 607 |
| 3 | 1896 | 571 |
| 4 | 6690 | 567 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x)))) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (pow.f64 x 2)) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x))))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
| Outputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x) |
(fma.f64 x (+.f64 (/.f64 x y) (neg.f64 x)) x) |
(fma.f64 x (-.f64 (/.f64 x y) x) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x)) |
(+.f64 x (*.f64 (*.f64 x x) (*.f64 (+.f64 1 (/.f64 -1 y)) (+.f64 x -1)))) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x))) |
(+.f64 (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x) (*.f64 (+.f64 (/.f64 x y) (neg.f64 x)) (+.f64 x (pow.f64 x 3)))) |
(+.f64 (fma.f64 (*.f64 x x) (-.f64 x (/.f64 x y)) x) (*.f64 (-.f64 (/.f64 x y) x) (+.f64 x (pow.f64 x 3)))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 1 (-.f64 (/.f64 1 y) (/.f64 x y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))))) |
(+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y)))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 (*.f64 x x)))) (-.f64 1 (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 1 (*.f64 x (*.f64 x y))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (+.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 -1 (*.f64 x (*.f64 x y))))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 1 (-.f64 (/.f64 1 y) (/.f64 x y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x)))) (/.f64 1 y)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))))) |
(+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y)))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (pow.f64 x 2)) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x))))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 (*.f64 x x)))) (-.f64 1 (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 1 (*.f64 x (*.f64 x y))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (+.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 -1 (*.f64 x (*.f64 x y))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (pow.f64 x 2) |
| ✓ | 17.6b | (/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
Compiled 26 to 17 computations (34.6% saved)
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | 0 | (/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
| 1.0ms | x | @ | 0 | (/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
| 0.0ms | x | @ | -inf | (pow.f64 x 2) |
| 0.0ms | y | @ | -inf | (/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
| 0.0ms | x | @ | inf | (pow.f64 x 2) |
| 1× | batch-egg-rewrite |
| 458× | log-prod_binary64 |
| 383× | prod-diff_binary64 |
| 349× | exp-prod_binary64 |
| 297× | pow-prod-down_binary64 |
| 236× | pow2_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 17 |
| 1 | 198 | 17 |
| 2 | 2680 | 15 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(pow.f64 x 2) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 x (/.f64 (fma.f64 x y y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 x (/.f64 1 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x x) (/.f64 1 (fma.f64 x y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 x (/.f64 (fma.f64 x y y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))) (cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4)) (cbrt.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 x) x) (*.f64 (cbrt.f64 (*.f64 x x)) (/.f64 1 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) (/.f64 x (sqrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (neg.f64 x)) (/.f64 1 (neg.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 x y y)) (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (/.f64 y x)) (/.f64 1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x y) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (/.f64 (*.f64 x x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) y) (/.f64 (cbrt.f64 (*.f64 x x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1) (/.f64 x (fma.f64 x y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) 1) (/.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 x y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) (/.f64 x (/.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) (+.f64 x 1)) (/.f64 (cbrt.f64 (*.f64 x x)) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (pow.f64 (cbrt.f64 (fma.f64 x y y)) 2)) (/.f64 x (cbrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x y y)) -2) (/.f64 (*.f64 x x) (cbrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) (pow.f64 (cbrt.f64 (fma.f64 x y y)) 2)) (cbrt.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 x y y) -1/2) (/.f64 (*.f64 x x) (sqrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) (sqrt.f64 (fma.f64 x y y))) (/.f64 (cbrt.f64 (*.f64 x x)) (sqrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 x (/.f64 y x)) (+.f64 1 (pow.f64 x 3))) (fma.f64 x (-.f64 x 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 x (/.f64 y x)) (-.f64 1 (*.f64 x x))) (-.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 6) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (fma.f64 x y y) (pow.f64 x -2)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 x 6) (pow.f64 (fma.f64 x y y) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 (fma.f64 x y y) (pow.f64 x -2)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))) 2)) (cbrt.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))) (sqrt.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 x x) (neg.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 6))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 x 6) (pow.f64 (fma.f64 x y y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 6)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 x (/.f64 (fma.f64 x y y) x)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (fma.f64 x y y) (pow.f64 x -2))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 x (/.f64 (fma.f64 x y y) x))) 1) 1)))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) x)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 x) x) (cbrt.f64 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (pow.f64 x 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x 3/2) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 5) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 x 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 x 6)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 x) 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x x)) 1) 1)))))) |
| 1× | egg-herbie |
| 716× | times-frac_binary64 |
| 594× | fma-def_binary64 |
| 566× | fma-neg_binary64 |
| 504× | cancel-sign-sub-inv_binary64 |
| 456× | associate-/r*_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 35 | 214 |
| 1 | 90 | 210 |
| 2 | 215 | 210 |
| 3 | 552 | 201 |
| 4 | 1805 | 189 |
| 5 | 7278 | 189 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (pow.f64 x 2) y) |
(+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y)) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 5) y)) (/.f64 (pow.f64 x 2) y)))) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
| Outputs |
|---|
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y)) |
(fma.f64 -1 (/.f64 (pow.f64 x 3) y) (/.f64 (*.f64 x x) y)) |
(-.f64 (/.f64 (*.f64 x x) y) (/.f64 (pow.f64 x 3) y)) |
(*.f64 (/.f64 x y) (-.f64 x (*.f64 x x))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y))) |
(+.f64 (fma.f64 -1 (/.f64 (pow.f64 x 3) y) (/.f64 (*.f64 x x) y)) (/.f64 (pow.f64 x 4) y)) |
(+.f64 (-.f64 (/.f64 (*.f64 x x) y) (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 4) y)) |
(+.f64 (/.f64 (*.f64 x x) y) (-.f64 (/.f64 (pow.f64 x 4) y) (/.f64 (pow.f64 x 3) y))) |
(+.f64 (*.f64 (/.f64 x y) (-.f64 x (*.f64 x x))) (/.f64 (pow.f64 x 4) y)) |
(*.f64 (/.f64 x y) (-.f64 (pow.f64 x 3) (-.f64 (*.f64 x x) x))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 5) y)) (/.f64 (pow.f64 x 2) y)))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (fma.f64 -1 (/.f64 (pow.f64 x 3) y) (fma.f64 -1 (/.f64 (pow.f64 x 5) y) (/.f64 (*.f64 x x) y)))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (-.f64 (-.f64 (/.f64 (*.f64 x x) y) (/.f64 (pow.f64 x 5) y)) (/.f64 (pow.f64 x 3) y))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (-.f64 (/.f64 (*.f64 x x) y) (+.f64 (/.f64 (pow.f64 x 3) y) (/.f64 (pow.f64 x 5) y)))) |
(-.f64 (*.f64 (/.f64 x y) (-.f64 x (*.f64 x x))) (-.f64 (/.f64 (pow.f64 x 5) y) (/.f64 (pow.f64 x 4) y))) |
(-.f64 (*.f64 (/.f64 x y) (-.f64 (pow.f64 x 3) (-.f64 (*.f64 x x) x))) (/.f64 (pow.f64 x 5) y)) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 1 (*.f64 x y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 y))) |
(-.f64 (/.f64 (/.f64 1 x) y) (-.f64 (/.f64 1 y) (/.f64 x y))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (/.f64 1 (*.f64 x y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y)))) |
(+.f64 (/.f64 x y) (-.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y))))) |
(+.f64 (/.f64 x y) (+.f64 (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 (*.f64 x (*.f64 x y)))) (/.f64 -1 y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 -1 (*.f64 (*.f64 x x) y)) (-.f64 (/.f64 (/.f64 1 x) y) (/.f64 1 y)))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (*.f64 (+.f64 (/.f64 -1 x) 1) (/.f64 1 (*.f64 x y)))) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 1 (*.f64 x y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 y))) |
(-.f64 (/.f64 (/.f64 1 x) y) (-.f64 (/.f64 1 y) (/.f64 x y))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (/.f64 1 (*.f64 x y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y)))) |
(+.f64 (/.f64 x y) (-.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y))))) |
(+.f64 (/.f64 x y) (+.f64 (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 (*.f64 x (*.f64 x y)))) (/.f64 -1 y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 -1 (*.f64 (*.f64 x x) y)) (-.f64 (/.f64 (/.f64 1 x) y) (/.f64 1 y)))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (*.f64 (+.f64 (/.f64 -1 x) 1) (/.f64 1 (*.f64 x y)))) |
Compiled 8639 to 4859 computations (43.8% saved)
13 alts after pruning (12 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 520 | 10 | 530 |
| Fresh | 4 | 2 | 6 |
| Picked | 1 | 0 | 1 |
| Done | 4 | 1 | 5 |
| Total | 529 | 13 | 542 |
| Status | Error | Program |
|---|---|---|
| ▶ | 42.4b | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| ▶ | 0.4b | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
| ▶ | 54.1b | (*.f64 x (/.f64 x y)) |
| 52.5b | 1 | |
| 33.9b | (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) | |
| 33.0b | (+.f64 (/.f64 (-.f64 x 1) y) 1) | |
| ▶ | 42.4b | (/.f64 (-.f64 x 1) y) |
| ▶ | 44.9b | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| 38.2b | x | |
| ✓ | 42.0b | (/.f64 x y) |
| 10.3b | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) | |
| 28.2b | (/.f64 x (+.f64 x 1)) | |
| 17.6b | (/.f64 (/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (+.f64 (/.f64 x y) -1)) (+.f64 x 1)) |
Compiled 227 to 152 computations (33% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (/.f64 (+.f64 x 1) x) |
| ✓ | 0.4b | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
Compiled 32 to 17 computations (46.9% saved)
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | -inf | (/.f64 (+.f64 x 1) x) |
| 0.0ms | x | @ | 0 | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
| 0.0ms | x | @ | 0 | (/.f64 (+.f64 x 1) x) |
| 0.0ms | x | @ | inf | (/.f64 (+.f64 x 1) x) |
| 0.0ms | x | @ | inf | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
| 1× | batch-egg-rewrite |
| 576× | log-prod_binary64 |
| 418× | prod-diff_binary64 |
| 293× | fma-def_binary64 |
| 281× | pow2_binary64 |
| 243× | log-div_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 23 |
| 1 | 209 | 23 |
| 2 | 3276 | 23 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
(/.f64 (+.f64 x 1) x) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x)))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))) (pow.f64 (cbrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))) 2) (cbrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (*.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))) (sqrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (*.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (neg.f64 (/.f64 x y)) -1) (/.f64 1 (/.f64 (fma.f64 -1 x -1) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 1 x)) (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) 1) (/.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) 1) (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (+.f64 1 x)) (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 1 x)) (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (+.f64 1 x)) (/.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) 2)) (/.f64 (+.f64 1 (/.f64 x y)) (cbrt.f64 (/.f64 (+.f64 1 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (pow.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) 2)) (cbrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) 2)) (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (cbrt.f64 (/.f64 (+.f64 1 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (/.f64 (+.f64 1 x) x))) (/.f64 (+.f64 1 (/.f64 x y)) (sqrt.f64 (/.f64 (+.f64 1 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (sqrt.f64 (/.f64 (+.f64 1 x) x))) (/.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (sqrt.f64 (/.f64 (+.f64 1 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 1 (/.f64 x y)) 1) (/.f64 x (+.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 1 (/.f64 x y)) (fma.f64 -1 x -1)) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)) 1) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 1 x) (*.f64 (+.f64 1 (/.f64 x y)) x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 (/.f64 (+.f64 1 x) x) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (+.f64 1 x) (*.f64 (+.f64 1 (/.f64 x y)) x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (fma.f64 -1 x -1) x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) (/.f64 x (+.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 (/.f64 (+.f64 1 x) x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (/.f64 (+.f64 1 (/.f64 x y)) (+.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log1p.f64 (/.f64 x y)) (-.f64 (log.f64 x) (log1p.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (+.f64 (log1p.f64 (/.f64 x y)) (-.f64 (log.f64 x) (log1p.f64 x))) 1)))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (+.f64 1 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (+.f64 1 x) x))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (+.f64 1 x) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (+.f64 1 x) x)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (+.f64 1 x) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (+.f64 1 x) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (+.f64 1 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1 x) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 1 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) (pow.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) 2) (cbrt.f64 (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 1 x)) 2) (*.f64 (cbrt.f64 (+.f64 1 x)) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (+.f64 1 x) x)) (sqrt.f64 (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 1 x)) (*.f64 (sqrt.f64 (+.f64 1 x)) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 -1 x -1) (/.f64 1 (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 x) (+.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 x)) 2) 1) (/.f64 (cbrt.f64 (+.f64 1 x)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 x)) 1) (/.f64 (sqrt.f64 (+.f64 1 x)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 x) 2)) (/.f64 (+.f64 1 x) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 x)) 2) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 x)) (pow.f64 (cbrt.f64 x) 2)) (/.f64 (sqrt.f64 (+.f64 1 x)) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 x)) (/.f64 (+.f64 1 x) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 x)) 2) (sqrt.f64 x)) (/.f64 (cbrt.f64 (+.f64 1 x)) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 1 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 1 x) x) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 1 x) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (+.f64 1 x) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (+.f64 1 x) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (+.f64 1 x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (+.f64 1 x) 3) (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 x (+.f64 1 x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (+.f64 1 x) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 1 x) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (+.f64 1 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 1 x) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (+.f64 1 x) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (+.f64 1 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log1p.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log1p.f64 x) (log.f64 x)) 1)))))) |
| 1× | egg-herbie |
| 655× | associate--l+_binary64 |
| 653× | associate-+l-_binary64 |
| 508× | unsub-neg_binary64 |
| 420× | +-commutative_binary64 |
| 362× | associate--r+_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 55 | 564 |
| 1 | 153 | 564 |
| 2 | 446 | 490 |
| 3 | 2044 | 461 |
| 4 | 7604 | 455 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(/.f64 x y) |
(+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1)))) (/.f64 1 x)) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2))) (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))))) (/.f64 1 x)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 1 x) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
1 |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
1 |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
| Outputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x) |
(fma.f64 x (+.f64 (/.f64 x y) (neg.f64 x)) x) |
(fma.f64 x (-.f64 (/.f64 x y) x) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x)) |
(+.f64 x (*.f64 x (*.f64 (+.f64 (/.f64 1 y) -1) (+.f64 x (*.f64 x (neg.f64 x)))))) |
(+.f64 x (*.f64 x (*.f64 (+.f64 (/.f64 1 y) -1) (-.f64 x (*.f64 x x))))) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x))) |
(+.f64 x (*.f64 (*.f64 x x) (+.f64 (+.f64 (/.f64 1 y) -1) (*.f64 (+.f64 (/.f64 x y) (neg.f64 x)) (+.f64 -1 x))))) |
(+.f64 x (*.f64 (*.f64 x x) (+.f64 (+.f64 (/.f64 1 y) -1) (*.f64 (-.f64 (/.f64 x y) x) (+.f64 -1 x))))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y)))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 1 (/.f64 -1 y)) (-.f64 (/.f64 x y) (/.f64 1 x)))) |
(+.f64 (+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) (/.f64 (+.f64 (/.f64 1 y) -1) x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 (+.f64 1 (/.f64 -1 y)) x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y))))))) |
(+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 (/.f64 x y) (-.f64 (/.f64 (+.f64 1 (/.f64 -1 y)) (*.f64 x x)) (+.f64 (/.f64 1 y) (/.f64 1 x)))) 1)) |
(+.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) (*.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (+.f64 (/.f64 1 y) -1) x))) |
(/.f64 x y) |
(+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1)))) (/.f64 1 x)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y)))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 1 (/.f64 -1 y)) (-.f64 (/.f64 x y) (/.f64 1 x)))) |
(+.f64 (+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) (/.f64 (+.f64 (/.f64 1 y) -1) x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 (+.f64 1 (/.f64 -1 y)) x))) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2))) (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (*.f64 -1 (-.f64 (/.f64 1 y) 1))))) (/.f64 1 x)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 1 (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y))))))) |
(+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (+.f64 (/.f64 x y) (-.f64 (/.f64 (+.f64 1 (/.f64 -1 y)) (*.f64 x x)) (+.f64 (/.f64 1 y) (/.f64 1 x)))) 1)) |
(+.f64 (+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) (*.f64 (+.f64 1 (/.f64 -1 x)) (/.f64 (+.f64 (/.f64 1 y) -1) x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x)) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 x (/.f64 (+.f64 y (*.f64 x y)) x))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (+.f64 x (/.f64 x (/.f64 y x))) (+.f64 x 1)) |
(/.f64 1 x) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
1 |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
1 |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
(+.f64 1 (/.f64 1 x)) |
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| 0.1b | (*.f64 x (/.f64 x y)) |
Compiled 12 to 4 computations (66.7% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (/.f64 (-.f64 x 1) y) |
Compiled 13 to 8 computations (38.5% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | inf | (/.f64 (-.f64 x 1) y) |
| 1.0ms | x | @ | 0 | (/.f64 (-.f64 x 1) y) |
| 0.0ms | x | @ | -inf | (/.f64 (-.f64 x 1) y) |
| 0.0ms | y | @ | 0 | (/.f64 (-.f64 x 1) y) |
| 0.0ms | y | @ | -inf | (/.f64 (-.f64 x 1) y) |
| 1× | batch-egg-rewrite |
| 735× | pow1_binary64 |
| 687× | add-log-exp_binary64 |
| 686× | log1p-expm1-u_binary64 |
| 686× | expm1-log1p-u_binary64 |
| 673× | add-exp-log_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 7 |
| 1 | 132 | 7 |
| 2 | 1830 | 7 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (-.f64 x 1) y) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 x y) (neg.f64 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 x y) (/.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (/.f64 (+.f64 x -1) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (+.f64 x -1) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x -1) (/.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 x -1) y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (+.f64 x -1) y)) (pow.f64 (cbrt.f64 (/.f64 (+.f64 x -1) y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (+.f64 x -1) y)) 2) (cbrt.f64 (/.f64 (+.f64 x -1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x -1)) 2) (*.f64 (cbrt.f64 (+.f64 x -1)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (+.f64 x -1) y)) (sqrt.f64 (/.f64 (+.f64 x -1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 x -1)) (*.f64 (sqrt.f64 (+.f64 x -1)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (neg.f64 x) 1) (/.f64 1 (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x -1)) 2) 1) (/.f64 (cbrt.f64 (+.f64 x -1)) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 x -1)) 1) (/.f64 (sqrt.f64 (+.f64 x -1)) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 y) 2)) (/.f64 (+.f64 x -1) (cbrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x -1)) 2) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (/.f64 (+.f64 x -1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 x -1)) (pow.f64 (cbrt.f64 y) 2)) (/.f64 (sqrt.f64 (+.f64 x -1)) (cbrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 y)) (/.f64 (+.f64 x -1) (sqrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x -1)) 2) (sqrt.f64 y)) (/.f64 (cbrt.f64 (+.f64 x -1)) (sqrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x -1) y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x -1) y) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (+.f64 x -1) y)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (+.f64 x -1) y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (+.f64 x -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (+.f64 x -1) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 x -1) y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (+.f64 x -1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 x -1) y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (+.f64 x -1) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (+.f64 x -1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (+.f64 x -1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (+.f64 x -1) y))))))) |
| 1× | egg-herbie |
| 97× | fma-def_binary64 |
| 93× | fma-neg_binary64 |
| 32× | distribute-rgt-in_binary64 |
| 31× | cancel-sign-sub-inv_binary64 |
| 26× | associate-*l*_binary64 |
Useful iterations: 10 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 102 |
| 1 | 13 | 102 |
| 2 | 17 | 102 |
| 3 | 25 | 102 |
| 4 | 35 | 102 |
| 5 | 54 | 102 |
| 6 | 95 | 102 |
| 7 | 140 | 102 |
| 8 | 208 | 102 |
| 9 | 295 | 102 |
| 10 | 466 | 75 |
| 11 | 615 | 75 |
| 12 | 672 | 75 |
| 13 | 675 | 75 |
| 1× | saturated |
| Inputs |
|---|
(/.f64 -1 y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
| Outputs |
|---|
(/.f64 -1 y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(*.f64 (/.f64 1 y) (+.f64 -1 x)) |
(/.f64 (+.f64 -1 x) y) |
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (-.f64 (/.f64 x y) (/.f64 1 y)) |
Compiled 18 to 9 computations (50% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | y | @ | -inf | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 0.0ms | y | @ | 0 | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 0.0ms | x | @ | 0 | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 0.0ms | y | @ | inf | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 0.0ms | x | @ | inf | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 1× | batch-egg-rewrite |
| 949× | pow1_binary64 |
| 890× | log1p-expm1-u_binary64 |
| 890× | expm1-log1p-u_binary64 |
| 889× | add-log-exp_binary64 |
| 83× | add-sqr-sqrt_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 7 |
| 1 | 159 | 7 |
| 2 | 2432 | 7 |
| 1× | node limit |
| Inputs |
|---|
(-.f64 (/.f64 x y) (/.f64 1 y)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 x y) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 x y) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (-.f64 x 1) y) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (-.f64 x 1) y) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (-.f64 x 1) y) (fma.f64 (neg.f64 (pow.f64 y -1/2)) (pow.f64 y -1/2) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 -1 y) (/.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (-.f64 x 1) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (-.f64 x 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (-.f64 x 1) y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (-.f64 x 1) y)) (pow.f64 (cbrt.f64 (/.f64 (-.f64 x 1) y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 x 1) y)) 2) (cbrt.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (-.f64 x 1) y)) (sqrt.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 x y) y) (pow.f64 y -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 x 1) (/.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (/.f64 x y) 3) (pow.f64 y -3)) (/.f64 1 (+.f64 (pow.f64 (/.f64 x y) 2) (+.f64 (pow.f64 y -2) (*.f64 x (pow.f64 y -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (/.f64 x y) 2) (pow.f64 y -2)) (/.f64 1 (+.f64 (/.f64 x y) (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (/.f64 x y)) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (/.f64 x y)) (pow.f64 y -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 y y) (-.f64 (*.f64 x y) y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 y (-.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (/.f64 x y) 2) (+.f64 (pow.f64 y -2) (*.f64 x (pow.f64 y -2)))) (-.f64 (pow.f64 (/.f64 x y) 3) (pow.f64 y -3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (/.f64 x y) (/.f64 1 y)) (-.f64 (pow.f64 (/.f64 x y) 2) (pow.f64 y -2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 x y) y) (*.f64 y y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 x 1) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (/.f64 x y) 3) (pow.f64 y -3)) (+.f64 (pow.f64 (/.f64 x y) 2) (+.f64 (pow.f64 y -2) (*.f64 x (pow.f64 y -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (/.f64 x y) 2) (pow.f64 y -2)) (+.f64 (/.f64 x y) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 x y) y)) (neg.f64 (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 x 1)) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (/.f64 x y) 3) (pow.f64 y -3))) (neg.f64 (+.f64 (pow.f64 (/.f64 x y) 2) (+.f64 (pow.f64 y -2) (*.f64 x (pow.f64 y -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (/.f64 x y) 2) (pow.f64 y -2))) (neg.f64 (+.f64 (/.f64 x y) (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 y (*.f64 (/.f64 y x) 1)) (*.f64 (/.f64 y x) y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (neg.f64 x) y) (*.f64 (neg.f64 y) 1)) (*.f64 (neg.f64 y) y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 x (neg.f64 y)) (*.f64 y -1)) (*.f64 y (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (neg.f64 y) (*.f64 (/.f64 y x) -1)) (*.f64 (/.f64 y x) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (neg.f64 x) (neg.f64 y)) (*.f64 (neg.f64 y) -1)) (*.f64 (neg.f64 y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (neg.f64 x) -1) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (/.f64 x y) 3) (pow.f64 (/.f64 -1 y) 3)) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 (*.f64 (/.f64 -1 y) (/.f64 -1 y)) (*.f64 (/.f64 x y) (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (/.f64 x y) 2) (*.f64 (/.f64 -1 y) (/.f64 -1 y))) (-.f64 (/.f64 x y) (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (-.f64 (*.f64 x y) y) y) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (-.f64 x 1) 1) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (-.f64 x 1) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (-.f64 x 1) (sqrt.f64 y)) (sqrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 x 1) y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (-.f64 x 1) y) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (-.f64 x 1) y)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (-.f64 x 1) y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (-.f64 x 1) y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 x 1) y))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (-.f64 x 1) y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (-.f64 x 1) y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (/.f64 1 y) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 x y) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 x y)) 2) (cbrt.f64 (/.f64 x y)) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 x y)) (sqrt.f64 (/.f64 x y)) (/.f64 -1 y)))))) |
| 1× | egg-herbie |
| 91× | fma-def_binary64 |
| 81× | fma-neg_binary64 |
| 43× | unsub-neg_binary64 |
| 28× | cancel-sign-sub-inv_binary64 |
| 25× | div-sub_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 96 |
| 1 | 26 | 96 |
| 2 | 47 | 96 |
| 3 | 65 | 96 |
| 4 | 115 | 96 |
| 5 | 316 | 96 |
| 6 | 611 | 96 |
| 7 | 640 | 96 |
| 1× | saturated |
| Inputs |
|---|
(/.f64 -1 y) |
(/.f64 x y) |
(/.f64 x y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (-.f64 x 1) y) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
| Outputs |
|---|
(/.f64 -1 y) |
(/.f64 x y) |
(/.f64 x y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(/.f64 (-.f64 x 1) y) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
(*.f64 -1 (/.f64 (+.f64 1 (*.f64 -1 x)) y)) |
(/.f64 (+.f64 x -1) y) |
(/.f64 (+.f64 -1 x) y) |
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 17.6b | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
Compiled 25 to 13 computations (48% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | 0 | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| 0.0ms | x | @ | inf | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| 0.0ms | x | @ | -inf | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| 0.0ms | y | @ | inf | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| 0.0ms | y | @ | -inf | (/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| 1× | batch-egg-rewrite |
| 493× | log-prod_binary64 |
| 401× | prod-diff_binary64 |
| 380× | exp-prod_binary64 |
| 326× | pow-prod-down_binary64 |
| 233× | pow2_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 13 |
| 1 | 179 | 13 |
| 2 | 2742 | 11 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 x (fma.f64 x y y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 x (fma.f64 x y y))) x)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 x (fma.f64 x y y))) x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 x (fma.f64 x y y))) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 x (fma.f64 x y y))) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 1 (/.f64 (fma.f64 x y y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 x (/.f64 1 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x x) (/.f64 1 (fma.f64 x y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (/.f64 x (fma.f64 x y y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)) (cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4)) (cbrt.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 x) x) (*.f64 (pow.f64 (cbrt.f64 x) 2) (/.f64 1 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) (/.f64 x (sqrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (neg.f64 x)) (/.f64 1 (neg.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x y) (/.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 x y y)) (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 x x) y) (/.f64 1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (/.f64 (*.f64 x x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) y) (/.f64 (pow.f64 (cbrt.f64 x) 2) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1) (/.f64 x (fma.f64 x y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (fma.f64 x y y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) 1) (/.f64 (pow.f64 (cbrt.f64 x) 2) (fma.f64 x y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x 1)) (/.f64 (*.f64 x x) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) (+.f64 x 1)) (/.f64 (pow.f64 (cbrt.f64 x) 2) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (pow.f64 (cbrt.f64 (fma.f64 x y y)) 2)) (/.f64 x (cbrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x y y)) -2) (/.f64 (*.f64 x x) (cbrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) (pow.f64 (cbrt.f64 (fma.f64 x y y)) 2)) (cbrt.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 x y y) -1/2) (/.f64 (*.f64 x x) (sqrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (cbrt.f64 x) x) (sqrt.f64 (fma.f64 x y y))) (/.f64 (pow.f64 (cbrt.f64 x) 2) (sqrt.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (*.f64 x x) y) (+.f64 1 (pow.f64 x 3))) (fma.f64 x (-.f64 x 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (*.f64 x x) y) (-.f64 1 (*.f64 x x))) (-.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 6) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (fma.f64 x y y) (pow.f64 x -2)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 x 6) (pow.f64 (fma.f64 x y y) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 (fma.f64 x y y) (pow.f64 x -2)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x))) 2)) (cbrt.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))) (sqrt.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 x x) (neg.f64 (fma.f64 x y y))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (/.f64 x (fma.f64 x y y))) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 6))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 x 6) (pow.f64 (fma.f64 x y y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y))) 6)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 x (sqrt.f64 (fma.f64 x y y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (fma.f64 x y y) (pow.f64 x -2))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 (/.f64 x (fma.f64 x y y)) x)) 1) 1)))))) |
| 1× | egg-herbie |
| 436× | sub-neg_binary64 |
| 296× | div-sub_binary64 |
| 273× | times-frac_binary64 |
| 268× | distribute-rgt-neg-in_binary64 |
| 263× | *-commutative_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 38 | 370 |
| 1 | 101 | 366 |
| 2 | 237 | 342 |
| 3 | 727 | 329 |
| 4 | 3734 | 321 |
| 5 | 7021 | 321 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (pow.f64 x 2) y) |
(+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y)) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 5) y)) (/.f64 (pow.f64 x 2) y)))) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
| Outputs |
|---|
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y)) |
(fma.f64 -1 (/.f64 (pow.f64 x 3) y) (/.f64 (*.f64 x x) y)) |
(-.f64 (/.f64 (*.f64 x x) y) (/.f64 (pow.f64 x 3) y)) |
(-.f64 (*.f64 (/.f64 x y) x) (/.f64 (pow.f64 x 3) y)) |
(*.f64 (/.f64 x y) (-.f64 x (*.f64 x x))) |
(*.f64 (*.f64 x (/.f64 x y)) (-.f64 1 x)) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (/.f64 (pow.f64 x 2) y))) |
(+.f64 (fma.f64 -1 (/.f64 (pow.f64 x 3) y) (/.f64 (*.f64 x x) y)) (/.f64 (pow.f64 x 4) y)) |
(+.f64 (/.f64 (*.f64 x x) y) (-.f64 (/.f64 (pow.f64 x 4) y) (/.f64 (pow.f64 x 3) y))) |
(+.f64 (*.f64 (/.f64 x y) x) (-.f64 (/.f64 (pow.f64 x 4) y) (/.f64 (pow.f64 x 3) y))) |
(fma.f64 x (/.f64 x y) (*.f64 (/.f64 (pow.f64 x 3) y) (+.f64 -1 x))) |
(*.f64 (/.f64 x y) (-.f64 x (-.f64 (*.f64 x x) (pow.f64 x 3)))) |
(*.f64 (/.f64 x y) (+.f64 (pow.f64 x 3) (-.f64 x (*.f64 x x)))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 3) y)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 x 5) y)) (/.f64 (pow.f64 x 2) y)))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (fma.f64 -1 (/.f64 (pow.f64 x 3) y) (fma.f64 -1 (/.f64 (pow.f64 x 5) y) (/.f64 (*.f64 x x) y)))) |
(+.f64 (/.f64 (pow.f64 x 4) y) (-.f64 (-.f64 (/.f64 (*.f64 x x) y) (/.f64 (pow.f64 x 5) y)) (/.f64 (pow.f64 x 3) y))) |
(+.f64 (*.f64 (/.f64 x y) x) (-.f64 (/.f64 (pow.f64 x 4) y) (+.f64 (/.f64 (pow.f64 x 3) y) (/.f64 (pow.f64 x 5) y)))) |
(fma.f64 x (/.f64 x y) (-.f64 (*.f64 (/.f64 (pow.f64 x 3) y) (+.f64 -1 x)) (/.f64 (pow.f64 x 5) y))) |
(-.f64 (*.f64 (/.f64 x y) (-.f64 x (-.f64 (*.f64 x x) (pow.f64 x 3)))) (/.f64 (pow.f64 x 5) y)) |
(-.f64 (*.f64 (/.f64 x y) (+.f64 (pow.f64 x 3) (-.f64 x (*.f64 x x)))) (/.f64 (pow.f64 x 5) y)) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (/.f64 1 (*.f64 x y))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 1 (*.f64 x y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 y))) |
(+.f64 (/.f64 x y) (-.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 x y) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y))))) |
(+.f64 (/.f64 x y) (-.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y))))) |
(+.f64 (/.f64 x y) (+.f64 (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 (*.f64 x (*.f64 x y)))) (/.f64 -1 y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 -1 y) (/.f64 (/.f64 -1 (*.f64 x x)) y)))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (*.f64 (+.f64 (/.f64 -1 x) 1) (/.f64 1 (*.f64 x y)))) |
(/.f64 x y) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 x y) (/.f64 -1 y)) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (/.f64 1 y)) |
(+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (/.f64 1 (*.f64 x y))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 -1 y)) (/.f64 1 (*.f64 x y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 y))) |
(+.f64 (/.f64 x y) (-.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 y))) |
(-.f64 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 x y) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y))))) |
(+.f64 (/.f64 x y) (-.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 (*.f64 x x) y))))) |
(+.f64 (/.f64 x y) (+.f64 (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 -1 (*.f64 x (*.f64 x y)))) (/.f64 -1 y))) |
(+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 -1 y) (/.f64 (/.f64 -1 (*.f64 x x)) y)))) |
(+.f64 (-.f64 (/.f64 x y) (/.f64 1 y)) (*.f64 (+.f64 (/.f64 -1 x) 1) (/.f64 1 (*.f64 x y)))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(*.f64 (/.f64 x (fma.f64 x y y)) x) |
(*.f64 x (/.f64 x (fma.f64 x y y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
Compiled 4156 to 2268 computations (45.4% saved)
15 alts after pruning (11 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 311 | 6 | 317 |
| Fresh | 2 | 5 | 7 |
| Picked | 1 | 0 | 1 |
| Done | 1 | 4 | 5 |
| Total | 315 | 15 | 330 |
| Status | Error | Program |
|---|---|---|
| 42.5b | (*.f64 (/.f64 1 y) (-.f64 x 1)) | |
| ✓ | 42.4b | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 33.9b | (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) | |
| 54.1b | (/.f64 x (/.f64 y x)) | |
| ✓ | 54.1b | (*.f64 x (/.f64 x y)) |
| 52.5b | 1 | |
| ▶ | 55.7b | (/.f64 (*.f64 x x) y) |
| ✓ | 42.4b | (/.f64 (-.f64 x 1) y) |
| ▶ | 32.9b | (/.f64 (+.f64 1 (/.f64 x y)) 1) |
| 38.2b | x | |
| ✓ | 42.0b | (/.f64 x y) |
| ▶ | 10.3b | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| ▶ | 28.2b | (/.f64 x (+.f64 x 1)) |
| ▶ | 30.9b | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 17.6b | (/.f64 (/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (+.f64 (/.f64 x y) -1)) (+.f64 x 1)) |
Compiled 224 to 151 computations (32.6% saved)
Found 2 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.2b | (/.f64 x (/.f64 y x)) |
| ✓ | 9.6b | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
Compiled 34 to 11 computations (67.6% saved)
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | 0 | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| 0.0ms | x | @ | -inf | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| 0.0ms | x | @ | inf | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| 0.0ms | y | @ | inf | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| 0.0ms | y | @ | -inf | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| 1× | batch-egg-rewrite |
| 582× | log-prod_binary64 |
| 352× | pow-prod-down_binary64 |
| 326× | fma-def_binary64 |
| 284× | pow2_binary64 |
| 229× | log-div_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 23 |
| 1 | 209 | 21 |
| 2 | 3288 | 21 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
(/.f64 x (/.f64 y x)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (/.f64 x y) x) (exp.f64 (neg.f64 (log1p.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (*.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (exp.f64 (neg.f64 (log1p.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (*.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (exp.f64 (neg.f64 (log1p.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 x (/.f64 x y) x)) (/.f64 1 (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 (neg.f64 (log1p.f64 x))) (fma.f64 x (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) 1) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) 1) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x 1)) -2) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (pow.f64 (cbrt.f64 (+.f64 x 1)) 2)) (/.f64 (sqrt.f64 (fma.f64 x (/.f64 x y) x)) (cbrt.f64 (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 x 1) -1/2) (/.f64 (fma.f64 x (/.f64 x y) x) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) 2) (hypot.f64 1 (sqrt.f64 x))) (/.f64 (cbrt.f64 (fma.f64 x (/.f64 x y) x)) (hypot.f64 1 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 1 (pow.f64 x 3))) (-.f64 (fma.f64 x x 1) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 x x -1)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (fma.f64 -1 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)) -3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (fma.f64 x (/.f64 x y) x) 3) (pow.f64 (+.f64 x 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (log.f64 (fma.f64 x (/.f64 x y) x)) (log1p.f64 x)) 1)))))) |
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (/.f64 x y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (/.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (/.f64 x y))) (pow.f64 (cbrt.f64 (*.f64 x (/.f64 x y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (/.f64 x y))) 2) (cbrt.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (/.f64 x y))) (sqrt.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 x) (/.f64 1 (/.f64 (neg.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x y) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 y -1) (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) y) (/.f64 (cbrt.f64 x) (pow.f64 x -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) y) (pow.f64 x 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) 1) (/.f64 (cbrt.f64 x) (/.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) 1) (/.f64 (sqrt.f64 x) (/.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 y x)) -2) (/.f64 x (cbrt.f64 (/.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 (cbrt.f64 (/.f64 y x)) 2)) (cbrt.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (/.f64 y x)) 2)) (/.f64 (sqrt.f64 x) (cbrt.f64 (/.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 y x) -1/2) (/.f64 x (sqrt.f64 (/.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 x x)) (sqrt.f64 (/.f64 y x))) (/.f64 (cbrt.f64 x) (sqrt.f64 (/.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1) (/.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (neg.f64 y)) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 x y) 1) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 x y) (cbrt.f64 (*.f64 x x))) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 x y) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (/.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (/.f64 x y)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (/.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (/.f64 x y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (/.f64 x y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (*.f64 x x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 y (*.f64 x x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 x (/.f64 (neg.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (/.f64 x y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (/.f64 x y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (/.f64 x y))) 1)))))) |
| 1× | egg-herbie |
| 629× | associate--l+_binary64 |
| 575× | associate-+l-_binary64 |
| 407× | +-commutative_binary64 |
| 381× | unsub-neg_binary64 |
| 330× | associate-*l*_binary64 |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 57 | 663 |
| 1 | 156 | 663 |
| 2 | 444 | 607 |
| 3 | 1896 | 571 |
| 4 | 6690 | 567 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x)))) (/.f64 1 y)) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (pow.f64 x 2)) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x))))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 x (+.f64 1 x)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
| Outputs |
|---|
x |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x) |
(fma.f64 x (+.f64 (/.f64 x y) (neg.f64 x)) x) |
(fma.f64 x (-.f64 (/.f64 x y) x) x) |
(+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x)) |
(fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x)) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x)) |
(+.f64 x (*.f64 (*.f64 x x) (*.f64 (+.f64 1 (/.f64 -1 y)) (+.f64 x -1)))) |
(+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 4)) (+.f64 (*.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3)) (+.f64 (*.f64 (-.f64 (/.f64 1 y) 1) (pow.f64 x 2)) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (-.f64 1 (/.f64 1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) x))) |
(fma.f64 (+.f64 (/.f64 1 y) -1) (pow.f64 x 4) (fma.f64 (+.f64 (/.f64 1 y) -1) (*.f64 x x) (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x))) |
(+.f64 (fma.f64 (+.f64 1 (/.f64 -1 y)) (pow.f64 x 3) x) (*.f64 (+.f64 (/.f64 x y) (neg.f64 x)) (+.f64 x (pow.f64 x 3)))) |
(+.f64 (fma.f64 (*.f64 x x) (-.f64 x (/.f64 x y)) x) (*.f64 (-.f64 (/.f64 x y) x) (+.f64 x (pow.f64 x 3)))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 1 (-.f64 (/.f64 1 y) (/.f64 x y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (/.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))))) |
(+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y)))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 1 (*.f64 y x)) (+.f64 (/.f64 x y) (/.f64 1 (pow.f64 x 2))))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 (*.f64 y (pow.f64 x 2))) (/.f64 1 x)))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 (*.f64 x x)))) (-.f64 1 (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 1 (*.f64 x (*.f64 x y))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (+.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 -1 (*.f64 x (*.f64 x y))))) |
(/.f64 x y) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(+.f64 1 (-.f64 (/.f64 x y) (/.f64 1 y))) |
(+.f64 1 (+.f64 (/.f64 x y) (/.f64 -1 y))) |
(-.f64 1 (-.f64 (/.f64 1 y) (/.f64 x y))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x)))) (/.f64 1 y)) |
(+.f64 1 (-.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x y))) (+.f64 (/.f64 1 y) (/.f64 1 x)))) |
(+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))))) |
(+.f64 (/.f64 x y) (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y)))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (pow.f64 x 2)) (*.f64 -1 (/.f64 (-.f64 1 (/.f64 1 y)) x))))) (+.f64 (/.f64 1 y) (/.f64 1 (*.f64 y (pow.f64 x 2))))) |
(+.f64 1 (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x)))) (+.f64 (/.f64 1 y) (+.f64 (/.f64 1 x) (/.f64 1 (*.f64 y (*.f64 x x))))))) |
(+.f64 (+.f64 (/.f64 x y) (+.f64 (/.f64 1 (*.f64 x y)) (/.f64 1 (*.f64 x x)))) (-.f64 1 (+.f64 (+.f64 (/.f64 1 y) (/.f64 1 x)) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 1 (+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (+.f64 (/.f64 1 (*.f64 x y)) (-.f64 (/.f64 -1 x) (/.f64 1 y))) (/.f64 1 (*.f64 x (*.f64 x y)))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (-.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 1 (*.f64 x (*.f64 x y))))) |
(+.f64 (+.f64 (/.f64 x y) (/.f64 1 (*.f64 x x))) (+.f64 (*.f64 (+.f64 1 (/.f64 -1 x)) (+.f64 1 (/.f64 -1 y))) (/.f64 -1 (*.f64 x (*.f64 x y))))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1))) |
(/.f64 (*.f64 x x) (+.f64 y (*.f64 x y))) |
(/.f64 (*.f64 x x) (fma.f64 x y y)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 x (+.f64 1 x)) |
(/.f64 x (+.f64 x 1)) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(+.f64 (/.f64 x (+.f64 1 x)) (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (*.f64 y (+.f64 x 1)))) |
(+.f64 (/.f64 x (+.f64 x 1)) (/.f64 (*.f64 x x) (+.f64 y (*.f64 x y)))) |
(*.f64 (+.f64 1 (/.f64 x y)) (/.f64 x (+.f64 x 1))) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| 0.0b | (/.f64 x (+.f64 x 1)) |
Compiled 12 to 8 computations (33.3% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 8.5b | (/.f64 (*.f64 x x) y) |
Compiled 12 to 4 computations (66.7% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | 0 | (/.f64 (*.f64 x x) y) |
| 0.0ms | x | @ | inf | (/.f64 (*.f64 x x) y) |
| 0.0ms | y | @ | -inf | (/.f64 (*.f64 x x) y) |
| 0.0ms | y | @ | inf | (/.f64 (*.f64 x x) y) |
| 0.0ms | y | @ | 0 | (/.f64 (*.f64 x x) y) |
| 1× | batch-egg-rewrite |
| 567× | pow1_binary64 |
| 527× | add-log-exp_binary64 |
| 527× | log1p-expm1-u_binary64 |
| 527× | expm1-log1p-u_binary64 |
| 513× | add-exp-log_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 5 | 7 |
| 1 | 106 | 7 |
| 2 | 1446 | 7 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (*.f64 x x) y) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (/.f64 x y) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 1 (/.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 x (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x x) (/.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (/.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 x 4)) (*.f64 (pow.f64 (cbrt.f64 x) 2) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (/.f64 x y) x)) (pow.f64 (cbrt.f64 (*.f64 (/.f64 x y) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (/.f64 x y) x)) 2) (cbrt.f64 (*.f64 (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (sqrt.f64 y)) (/.f64 x (sqrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (neg.f64 x)) (/.f64 1 (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1) (/.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x y) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 x 4)) 1) (/.f64 (pow.f64 (cbrt.f64 x) 2) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (pow.f64 (cbrt.f64 y) 2)) (/.f64 x (cbrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 y) 2)) (/.f64 (*.f64 x x) (cbrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 x 4)) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (*.f64 (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 y)) (/.f64 (*.f64 x x) (sqrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 x 4)) (sqrt.f64 y)) (/.f64 (pow.f64 (cbrt.f64 x) 2) (sqrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 x y) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 x y) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (sqrt.f64 y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (*.f64 x x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 x x) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 x y) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 x y) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 x y) x))))))) |
| 1× | egg-herbie |
| 759× | sqr-pow_binary64 |
| 434× | unswap-sqr_binary64 |
| 423× | *-commutative_binary64 |
| 423× | associate-*r/_binary64 |
| 393× | associate-/r/_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 168 |
| 1 | 11 | 168 |
| 2 | 20 | 168 |
| 3 | 37 | 168 |
| 4 | 83 | 168 |
| 5 | 266 | 168 |
| 6 | 1091 | 168 |
| 7 | 3478 | 168 |
| 8 | 4280 | 168 |
| 9 | 4465 | 168 |
| 10 | 4681 | 168 |
| 11 | 5028 | 168 |
| 12 | 5456 | 168 |
| 13 | 5935 | 168 |
| 14 | 6584 | 168 |
| 15 | 7273 | 168 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (pow.f64 x 2) y) |
| Outputs |
|---|
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
Compiled 20 to 10 computations (50% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.4b | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
Compiled 25 to 13 computations (48% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | inf | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 1.0ms | x | @ | 0 | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 0.0ms | x | @ | -inf | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 0.0ms | y | @ | -inf | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 0.0ms | y | @ | inf | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 1× | batch-egg-rewrite |
| 440× | log-prod_binary64 |
| 345× | exp-prod_binary64 |
| 325× | prod-diff_binary64 |
| 268× | pow-prod-down_binary64 |
| 228× | pow2_binary64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 13 |
| 1 | 180 | 10 |
| 2 | 2567 | 10 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (+.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) x)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (+.f64 1 (/.f64 x y))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (+.f64 1 (/.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (+.f64 1 (/.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1 (/.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (+.f64 1 (/.f64 x y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))) (pow.f64 (cbrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))) 2) (cbrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (*.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))) (sqrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (*.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (/.f64 (+.f64 1 (/.f64 x y)) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 -1 (neg.f64 (/.f64 x y))) (/.f64 1 (/.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) 1) (/.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) 1) (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 1 (cbrt.f64 x)) -2) (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (cbrt.f64 (pow.f64 x -2))) (cbrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (cbrt.f64 (pow.f64 x -2))) (/.f64 (sqrt.f64 (+.f64 1 (/.f64 x y))) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) 2) (pow.f64 x -1/2)) (/.f64 (cbrt.f64 (+.f64 1 (/.f64 x y))) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 1 (/.f64 x y)) -1) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 1 (/.f64 x y)) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 1 (/.f64 x y)) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (+.f64 1 (/.f64 x y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (+.f64 1 (/.f64 x y))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (+.f64 1 (/.f64 x y))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (+.f64 1 (/.f64 x y)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (*.f64 x (+.f64 1 (/.f64 x y)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 x -3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 1 (*.f64 x (+.f64 1 (/.f64 x y)))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 3) (pow.f64 (+.f64 1 (/.f64 x y)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cbrt.f64 x) (cbrt.f64 (+.f64 1 (/.f64 x y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 x) (sqrt.f64 (+.f64 1 (/.f64 x y)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x))) 2)) (cbrt.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x)))) (sqrt.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (+.f64 1 (/.f64 x y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (+.f64 1 (/.f64 x y))) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (+.f64 1 (/.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (+.f64 1 (/.f64 x y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (+.f64 1 (/.f64 x y)) 3) (pow.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (+.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (+.f64 1 (/.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/3 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/2 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (neg.f64 (log.f64 x)) (log1p.f64 (/.f64 x y))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (+.f64 (log1p.f64 (/.f64 x y)) (log.f64 x)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log1p.f64 (/.f64 x y)) 1) (neg.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log1p.f64 (/.f64 x y)) (*.f64 (log.f64 x) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log1p.f64 (/.f64 x y)) 1) (*.f64 (log.f64 x) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log1p.f64 (/.f64 x y)) (*.f64 (neg.f64 (log.f64 x)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log1p.f64 (/.f64 x y)) 1) (*.f64 (neg.f64 (log.f64 x)) 1))))))) |
| 1× | egg-herbie |
| 1365× | fma-def_binary64 |
| 434× | unswap-sqr_binary64 |
| 423× | associate-*r/_binary64 |
| 392× | associate-/r*_binary64 |
| 389× | associate-/r/_binary64 |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 8 | 204 |
| 1 | 13 | 204 |
| 2 | 22 | 204 |
| 3 | 40 | 168 |
| 4 | 89 | 168 |
| 5 | 296 | 168 |
| 6 | 1247 | 168 |
| 7 | 4103 | 168 |
| 8 | 5649 | 168 |
| 9 | 6272 | 168 |
| 10 | 6521 | 168 |
| 11 | 6922 | 168 |
| 12 | 7405 | 168 |
| 13 | 7982 | 168 |
| 1× | node limit |
| Inputs |
|---|
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(/.f64 (pow.f64 x 2) y) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
| Outputs |
|---|
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(/.f64 (pow.f64 x 2) y) |
(/.f64 (*.f64 x x) y) |
(/.f64 x (/.f64 y x)) |
(*.f64 (/.f64 x y) x) |
(*.f64 x (/.f64 x y)) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 x (/.f64 (pow.f64 x 2) y)) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
x |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
(+.f64 (/.f64 (pow.f64 x 2) y) x) |
(+.f64 x (/.f64 (*.f64 x x) y)) |
(+.f64 x (/.f64 x (/.f64 y x))) |
(+.f64 x (*.f64 (/.f64 x y) x)) |
(fma.f64 (/.f64 x y) x x) |
(fma.f64 x (/.f64 x y) x) |
Compiled 3426 to 1775 computations (48.2% saved)
17 alts after pruning (8 fresh and 9 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 262 | 2 | 264 |
| Fresh | 0 | 6 | 6 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 8 | 8 |
| Total | 262 | 17 | 279 |
| Status | Error | Program |
|---|---|---|
| 42.5b | (*.f64 (/.f64 1 y) (-.f64 x 1)) | |
| ✓ | 42.4b | (-.f64 (/.f64 x y) (/.f64 1 y)) |
| 30.6b | (*.f64 (+.f64 1 (/.f64 x y)) x) | |
| 33.9b | (*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) | |
| 54.1b | (/.f64 x (/.f64 y x)) | |
| ✓ | 54.1b | (*.f64 x (/.f64 x y)) |
| 52.5b | 1 | |
| ✓ | 55.7b | (/.f64 (*.f64 x x) y) |
| ✓ | 42.4b | (/.f64 (-.f64 x 1) y) |
| ✓ | 32.9b | (/.f64 (+.f64 1 (/.f64 x y)) 1) |
| 38.2b | x | |
| ✓ | 42.0b | (/.f64 x y) |
| 55.7b | (*.f64 (/.f64 1 y) (*.f64 x x)) | |
| ✓ | 10.3b | (/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
| ✓ | 28.2b | (/.f64 x (+.f64 x 1)) |
| ✓ | 30.9b | (/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
| 17.6b | (/.f64 (/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (+.f64 (/.f64 x y) -1)) (+.f64 x 1)) |
Compiled 147 to 99 computations (32.7% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(*.f64 (/.f64 1 y) (*.f64 x x)) |
(*.f64 (/.f64 1 y) (-.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(/.f64 (*.f64 x (/.f64 x y)) (+.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
(/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
(/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
(/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
(+.f64 x (*.f64 (*.f64 x x) (*.f64 (+.f64 1 (/.f64 -1 y)) (+.f64 x -1)))) |
(/.f64 (pow.f64 x 2) (*.f64 y (+.f64 1 x))) |
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1)) |
(/.f64 (/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x y) 2) -1) x) (+.f64 (/.f64 x y) -1)) (+.f64 x 1)) |
(/.f64 (/.f64 (*.f64 (+.f64 1 (pow.f64 (/.f64 x y) 3)) x) (+.f64 (pow.f64 (/.f64 x y) 2) (-.f64 1 (/.f64 x y)))) (+.f64 x 1)) |
| Outputs |
|---|
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
4 calls:
| 34.0ms | y |
| 33.0ms | x |
| 29.0ms | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 28.0ms | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| Error | Segments | Branch |
|---|---|---|
| 0.1b | 1 | x |
| 0.1b | 1 | y |
| 0.1b | 1 | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
| 0.1b | 1 | (/.f64 (*.f64 x (+.f64 (/.f64 x y) 1)) (+.f64 x 1)) |
Compiled 298 to 158 computations (47% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(*.f64 (/.f64 1 y) (*.f64 x x)) |
(*.f64 (/.f64 1 y) (-.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(/.f64 (*.f64 x (/.f64 x y)) (+.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
(/.f64 (+.f64 (/.f64 x (/.f64 y x)) x) (+.f64 x 1)) |
(/.f64 (+.f64 (*.f64 x (/.f64 x y)) x) (+.f64 x 1)) |
| Outputs |
|---|
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
2 calls:
| 427.0ms | y |
| 28.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 0.4b | 1 | x |
| 0.4b | 1 | y |
Compiled 172 to 84 computations (51.2% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(*.f64 (/.f64 1 y) (*.f64 x x)) |
(*.f64 (/.f64 1 y) (-.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
(/.f64 (*.f64 x (/.f64 x y)) (+.f64 x 1)) |
| Outputs |
|---|
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)) |
2 calls:
| 109.0ms | y |
| 66.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 1.3b | 3 | x |
| 13.4b | 5 | y |
Compiled 139 to 70 computations (49.6% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 37.0ms | 4.680103889293689e-6 | 145833.86116618643 |
| 38.0ms | -145.44762207373262 | -0.10212425355022259 |
Compiled 18 to 13 computations (27.8% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(*.f64 (/.f64 1 y) (*.f64 x x)) |
(*.f64 (/.f64 1 y) (-.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 x)) |
(*.f64 (/.f64 x (+.f64 x 1)) (/.f64 x y)) |
(/.f64 (*.f64 x x) (*.f64 y (+.f64 1 x))) |
| Outputs |
|---|
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(+.f64 (/.f64 (-.f64 x 1) y) 1) |
2 calls:
| 102.0ms | y |
| 64.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 1.3b | 3 | x |
| 13.4b | 5 | y |
Compiled 121 to 62 computations (48.8% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 20.0ms | 4.680103889293689e-6 | 145833.86116618643 |
| 31.0ms | -145.44762207373262 | -0.10212425355022259 |
Compiled 18 to 13 computations (27.8% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(*.f64 (/.f64 1 y) (*.f64 x x)) |
(*.f64 (/.f64 1 y) (-.f64 x 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
(-.f64 (/.f64 x y) (/.f64 1 y)) |
| Outputs |
|---|
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(/.f64 (+.f64 1 (/.f64 x y)) 1) |
2 calls:
| 43.0ms | y |
| 24.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 1.5b | 3 | x |
| 15.2b | 5 | y |
Compiled 78 to 40 computations (48.7% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 20.0ms | 4.680103889293689e-6 | 145833.86116618643 |
| 21.0ms | -145.44762207373262 | -0.10212425355022259 |
Compiled 18 to 13 computations (27.8% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(*.f64 (/.f64 1 y) (*.f64 x x)) |
(*.f64 (/.f64 1 y) (-.f64 x 1)) |
| Outputs |
|---|
(/.f64 x y) |
(/.f64 x (+.f64 x 1)) |
(*.f64 (+.f64 1 (/.f64 x y)) x) |
(/.f64 (-.f64 x 1) y) |
2 calls:
| 39.0ms | y |
| 27.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 9.9b | 4 | x |
| 15.5b | 5 | y |
Compiled 64 to 33 computations (48.4% saved)
| 3× | binary-search |
| Time | Left | Right |
|---|---|---|
| 20.0ms | 4.680103889293689e-6 | 145833.86116618643 |
| 20.0ms | -3.154475503618697e-8 | -4.6925646308736895e-17 |
| 20.0ms | -898395338016137000.0 | -533130845138881.3 |
Compiled 18 to 13 computations (27.8% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (+.f64 x 1)) |
| Outputs |
|---|
(/.f64 x y) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x (/.f64 y x)) |
(/.f64 x (+.f64 x 1)) |
(/.f64 x y) |
2 calls:
| 36.0ms | y |
| 30.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 16.0b | 5 | x |
| 17.9b | 6 | y |
Compiled 43 to 22 computations (48.8% saved)
| 4× | binary-search |
| Time | Left | Right |
|---|---|---|
| 84.0ms | 5.432496940205923e+70 | 1.2738671336804938e+71 |
| 20.0ms | -1.5731849930078254e-59 | -1.5612886725260498e-62 |
| 20.0ms | -2.2806669886895275e-23 | -1.3363672948443478e-25 |
| 21.0ms | -898395338016137000.0 | -533130845138881.3 |
Compiled 88 to 63 computations (28.4% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
(/.f64 (-.f64 x 1) y) |
| Outputs |
|---|
(/.f64 (-.f64 x 1) y) |
x |
(/.f64 (-.f64 x 1) y) |
1 |
(/.f64 x y) |
2 calls:
| 31.0ms | y |
| 24.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 17.7b | 5 | x |
| 26.1b | 7 | y |
Compiled 33 to 16 computations (51.5% saved)
| 4× | binary-search |
| Time | Left | Right |
|---|---|---|
| 83.0ms | 5.432496940205923e+70 | 1.2738671336804938e+71 |
| 20.0ms | 9.163755937181652e+52 | 3.7028772418974887e+56 |
| 20.0ms | 4.680103889293689e-6 | 145833.86116618643 |
| 20.0ms | -145.44762207373262 | -0.10212425355022259 |
Compiled 68 to 53 computations (22.1% saved)
| Inputs |
|---|
1 |
x |
(/.f64 x y) |
(/.f64 x (/.f64 y x)) |
(/.f64 (*.f64 x x) y) |
(*.f64 x (/.f64 x y)) |
| Outputs |
|---|
(/.f64 x y) |
x |
(/.f64 x y) |
2 calls:
| 38.0ms | y |
| 30.0ms | x |
| Error | Segments | Branch |
|---|---|---|
| 19.0b | 3 | x |
| 26.1b | 7 | y |
Compiled 28 to 13 computations (53.6% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 39.0ms | 4.680103889293689e-6 | 145833.86116618643 |
| 39.0ms | -145.44762207373262 | -0.10212425355022259 |
Compiled 18 to 13 computations (27.8% saved)
Total -33.1b remaining (-114.4%)
Threshold costs -33.1b (-114.4%)
| Inputs |
|---|
1 |
x |
| Outputs |
|---|
1 |
x |
1 |
2 calls:
| 26.0ms | x |
| 14.0ms | y |
| Error | Segments | Branch |
|---|---|---|
| 29.0b | 3 | x |
| 36.5b | 2 | y |
Compiled 10 to 7 computations (30% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 39.0ms | 938589.368396747 | 130900458484441.92 |
| 39.0ms | -145.44762207373262 | -0.10212425355022259 |
Compiled 18 to 13 computations (27.8% saved)
| 1× | egg-herbie |
| 6× | +-commutative_binary64 |
| 3× | *-commutative_binary64 |
| 3× | sub-neg_binary64 |
| 1× | distribute-neg-frac_binary64 |
| 1× | /-rgt-identity_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 61 | 335 |
| 1 | 76 | 335 |
| 2 | 81 | 335 |
| 3 | 83 | 335 |
| 4 | 84 | 335 |
| 1× | fuel |
| 1× | saturated |
| Inputs |
|---|
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 (/.f64 (-.f64 x 1) y) 1) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)))) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 (/.f64 (-.f64 x 1) y) 1) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (+.f64 (/.f64 (-.f64 x 1) y) 1))) |
(if (<=.f64 x -5117483254478023/35184372088832) (/.f64 (+.f64 1 (/.f64 x y)) 1) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (/.f64 (+.f64 1 (/.f64 x y)) 1))) |
(if (<=.f64 x -898395338016136960) (/.f64 x y) (if (<=.f64 x -4766908604583129/151115727451828646838272) (/.f64 x (+.f64 x 1)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (/.f64 (-.f64 x 1) y)))) |
(if (<=.f64 x -898395338016136960) (/.f64 x y) (if (<=.f64 x -15157632052143/664613997892457936451903530140172288) (/.f64 x (+.f64 x 1)) (if (<=.f64 x -7115717855358155/452312848583266388373324160190187140051835877600158453279131187530910662656) (/.f64 x (/.f64 y x)) (if (<=.f64 x 124999999999999992975226368599321378007153016127568816443015486507057152) (/.f64 x (+.f64 x 1)) (/.f64 x y))))) |
(if (<=.f64 x -5117483254478023/35184372088832) (/.f64 (-.f64 x 1) y) (if (<=.f64 x 690661429473387/147573952589676412928) x (if (<=.f64 x 91637559371816518869539319089025458678297772544753664) (/.f64 (-.f64 x 1) y) (if (<=.f64 x 124999999999999992975226368599321378007153016127568816443015486507057152) 1 (/.f64 x y))))) |
(if (<=.f64 x -5117483254478023/35184372088832) (/.f64 x y) (if (<=.f64 x 690661429473387/147573952589676412928) x (/.f64 x y))) |
(if (<=.f64 x -5117483254478023/35184372088832) 1 (if (<=.f64 x 8062421283274649/8589934592) x 1)) |
1 |
| Outputs |
|---|
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 (/.f64 x y) 1)) |
(*.f64 (/.f64 x (+.f64 x 1)) (+.f64 1 (/.f64 x y))) |
(/.f64 (+.f64 1 (/.f64 x y)) (/.f64 (+.f64 x 1) x)) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 (/.f64 (-.f64 x 1) y) 1) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)))) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 1 (/.f64 (-.f64 x 1) y)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 x (+.f64 1 (/.f64 x y))) (-.f64 (+.f64 1 (/.f64 x y)) (/.f64 1 y)))) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 1 (/.f64 (-.f64 x 1) y)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 x (+.f64 1 (/.f64 x y))) (+.f64 (+.f64 1 (/.f64 x y)) (/.f64 -1 y)))) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 (/.f64 (-.f64 x 1) y) 1) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (+.f64 (/.f64 (-.f64 x 1) y) 1))) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 1 (/.f64 (-.f64 x 1) y)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 x (+.f64 1 (/.f64 x y))) (+.f64 1 (/.f64 (-.f64 x 1) y)))) |
(if (<=.f64 x -5117483254478023/35184372088832) (/.f64 (+.f64 1 (/.f64 x y)) 1) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (/.f64 (+.f64 1 (/.f64 x y)) 1))) |
(if (<=.f64 x -5117483254478023/35184372088832) (+.f64 1 (/.f64 x y)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 x (+.f64 1 (/.f64 x y))) (+.f64 1 (/.f64 x y)))) |
(if (<=.f64 x -898395338016136960) (/.f64 x y) (if (<=.f64 x -4766908604583129/151115727451828646838272) (/.f64 x (+.f64 x 1)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 (+.f64 1 (/.f64 x y)) x) (/.f64 (-.f64 x 1) y)))) |
(if (<=.f64 x -898395338016136960) (/.f64 x y) (if (<=.f64 x -4766908604583129/151115727451828646838272) (/.f64 x (+.f64 x 1)) (if (<=.f64 x 690661429473387/147573952589676412928) (*.f64 x (+.f64 1 (/.f64 x y))) (/.f64 (-.f64 x 1) y)))) |
(if (<=.f64 x -898395338016136960) (/.f64 x y) (if (<=.f64 x -15157632052143/664613997892457936451903530140172288) (/.f64 x (+.f64 x 1)) (if (<=.f64 x -7115717855358155/452312848583266388373324160190187140051835877600158453279131187530910662656) (/.f64 x (/.f64 y x)) (if (<=.f64 x 124999999999999992975226368599321378007153016127568816443015486507057152) (/.f64 x (+.f64 x 1)) (/.f64 x y))))) |
(if (<=.f64 x -5117483254478023/35184372088832) (/.f64 (-.f64 x 1) y) (if (<=.f64 x 690661429473387/147573952589676412928) x (if (<=.f64 x 91637559371816518869539319089025458678297772544753664) (/.f64 (-.f64 x 1) y) (if (<=.f64 x 124999999999999992975226368599321378007153016127568816443015486507057152) 1 (/.f64 x y))))) |
(if (<=.f64 x -5117483254478023/35184372088832) (/.f64 x y) (if (<=.f64 x 690661429473387/147573952589676412928) x (/.f64 x y))) |
(if (<=.f64 x -5117483254478023/35184372088832) 1 (if (<=.f64 x 8062421283274649/8589934592) x 1)) |
1 |
Compiled 256 to 166 computations (35.2% saved)
Compiled 236 to 138 computations (41.5% saved)
Loading profile data...