Time bar (total: 2.3s)
| 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 |
| 0% | 99.9% | 0.1% | 5 |
| 18.7% | 81.2% | 0.1% | 6 |
| 46.8% | 53.1% | 0.1% | 7 |
| 56.2% | 43.7% | 0.1% | 8 |
| 71% | 28.9% | 0.1% | 9 |
| 76.5% | 23.4% | 0.1% | 10 |
| 84.9% | 15% | 0.1% | 11 |
| 87.8% | 12.1% | 0.1% | 12 |
Compiled 11 to 7 computations (36.4% saved)
| 1.4s | 8256× | body | 256 | valid |
| 2× | egg-herbie |
| 762× | fma-neg_binary64 |
| 504× | fma-def_binary64 |
| 427× | times-frac_binary64 |
| 366× | div-sub_binary64 |
| 224× | associate-/l*_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 24 |
| 1 | 29 | 24 |
| 2 | 55 | 24 |
| 3 | 116 | 24 |
| 4 | 271 | 24 |
| 5 | 568 | 20 |
| 6 | 1410 | 20 |
| 7 | 3565 | 20 |
| 8 | 4602 | 20 |
| 9 | 4909 | 20 |
| 10 | 5050 | 20 |
| 11 | 5088 | 20 |
| 12 | 5098 | 20 |
| 13 | 5098 | 20 |
| 0 | 2 | 2 |
| 1× | saturated |
| 1× | saturated |
| Inputs |
|---|
0 |
1 |
| Outputs |
|---|
0 |
1 |
| Inputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
(/.f64 (neg.f64 (+.f64 n f)) (-.f64 n f)) |
| Outputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
(/.f64 (-.f64 (neg.f64 n) f) (-.f64 f n)) |
(/.f64 (-.f64 (neg.f64 f) n) (-.f64 f n)) |
(/.f64 (+.f64 f n) (-.f64 n f)) |
(/.f64 (neg.f64 (+.f64 n f)) (-.f64 n f)) |
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 n f)) |
(/.f64 (-.f64 (neg.f64 n) f) (-.f64 n f)) |
(/.f64 (-.f64 (neg.f64 f) n) (-.f64 n f)) |
(/.f64 (+.f64 f n) (-.f64 f n)) |
Compiled 12 to 8 computations (33.3% saved)
| 1× | egg-herbie |
| 694× | fma-def_binary64 |
| 621× | fma-neg_binary64 |
| 451× | times-frac_binary64 |
| 308× | div-sub_binary64 |
| 194× | associate-/l*_binary64 |
Useful iterations: 6 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 12 |
| 1 | 18 | 12 |
| 2 | 38 | 12 |
| 3 | 82 | 12 |
| 4 | 182 | 12 |
| 5 | 330 | 12 |
| 6 | 818 | 10 |
| 7 | 2533 | 10 |
| 8 | 3446 | 10 |
| 9 | 4154 | 10 |
| 10 | 4275 | 10 |
| 11 | 4318 | 10 |
| 12 | 4328 | 10 |
| 13 | 4328 | 10 |
| 1× | saturated |
| Inputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
| Outputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
(/.f64 (-.f64 (neg.f64 n) f) (-.f64 f n)) |
(/.f64 (-.f64 (neg.f64 f) n) (-.f64 f n)) |
(/.f64 (+.f64 f n) (-.f64 n f)) |
Compiled 17 to 8 computations (52.9% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 1 | 1 | 2 |
| Fresh | 1 | 0 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 2 | 1 | 3 |
| Status | Error | Program |
|---|---|---|
| ▶ | 0.0b | (/.f64 (+.f64 f n) (-.f64 n f)) |
Compiled 9 to 5 computations (44.4% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (/.f64 (+.f64 f n) (-.f64 n f)) |
Compiled 17 to 5 computations (70.6% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | f | @ | 0 | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 1.0ms | f | @ | inf | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 1.0ms | n | @ | -inf | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 1.0ms | f | @ | -inf | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 1.0ms | n | @ | inf | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 1× | batch-egg-rewrite |
| 945× | pow1_binary64 |
| 884× | add-log-exp_binary64 |
| 884× | log1p-expm1-u_binary64 |
| 884× | expm1-log1p-u_binary64 |
| 79× | add-sqr-sqrt_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 10 |
| 1 | 144 | 10 |
| 2 | 2313 | 10 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (+.f64 f n) (-.f64 n f)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (+.f64 f n) (-.f64 n f)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 f n) (/.f64 1 (-.f64 n f)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (+.f64 f n) (-.f64 n f)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))) (cbrt.f64 (pow.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 2)) (cbrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 f n)) 2) (*.f64 (cbrt.f64 (+.f64 f n)) (/.f64 1 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))) (sqrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 f n)) (*.f64 (sqrt.f64 (+.f64 f n)) (/.f64 1 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (+.f64 f n)) (/.f64 1 (neg.f64 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 n f)) (+.f64 f n))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 f n)) 2) 1) (/.f64 (cbrt.f64 (+.f64 f n)) (-.f64 n f)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 f n)) 1) (/.f64 (sqrt.f64 (+.f64 f n)) (-.f64 n f)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (-.f64 n f)) 2)) (/.f64 (+.f64 f n) (cbrt.f64 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 f n)) 2) (pow.f64 (cbrt.f64 (-.f64 n f)) 2)) (cbrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 f n)) (pow.f64 (cbrt.f64 (-.f64 n f)) 2)) (/.f64 (sqrt.f64 (+.f64 f n)) (cbrt.f64 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (-.f64 n f))) (/.f64 (+.f64 f n) (sqrt.f64 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 f n)) 2) (sqrt.f64 (-.f64 n f))) (/.f64 (cbrt.f64 (+.f64 f n)) (sqrt.f64 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 f n) (-.f64 (*.f64 n n) (*.f64 f f))) (+.f64 f n))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 f n) (-.f64 (pow.f64 n 3) (pow.f64 f 3))) (fma.f64 n n (*.f64 f (+.f64 f n))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (+.f64 f n) (-.f64 n f))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 n f) (+.f64 f n)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (+.f64 f n) (neg.f64 (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (+.f64 f n) (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (+.f64 f n) (-.f64 n f)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 f n) (-.f64 n f)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (+.f64 f n) 3) (pow.f64 (-.f64 n f) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (+.f64 f n) (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (+.f64 f n) (-.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (+.f64 f n) (-.f64 n f)))))))) |
| 1× | egg-herbie |
| 665× | times-frac_binary64 |
| 552× | div-sub_binary64 |
| 525× | fma-def_binary64 |
| 460× | distribute-frac-neg_binary64 |
| 352× | associate-/l*_binary64 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 79 | 504 |
| 1 | 264 | 441 |
| 2 | 942 | 327 |
| 3 | 4893 | 327 |
| 1× | node limit |
| Inputs |
|---|
1 |
(+.f64 (*.f64 2 (/.f64 f n)) 1) |
(+.f64 (*.f64 2 (/.f64 f n)) (+.f64 1 (*.f64 2 (/.f64 (pow.f64 f 2) (pow.f64 n 2))))) |
(+.f64 (*.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3))) (+.f64 (*.f64 2 (/.f64 f n)) (+.f64 1 (*.f64 2 (/.f64 (pow.f64 f 2) (pow.f64 n 2)))))) |
-1 |
(-.f64 (*.f64 -1 (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(-.f64 (+.f64 (/.f64 (*.f64 n (-.f64 (*.f64 -1 n) n)) (pow.f64 f 2)) (*.f64 -1 (/.f64 n f))) (+.f64 1 (/.f64 n f))) |
(-.f64 (+.f64 (/.f64 (*.f64 (pow.f64 n 2) (-.f64 (*.f64 -1 n) n)) (pow.f64 f 3)) (+.f64 (/.f64 (*.f64 n (-.f64 (*.f64 -1 n) n)) (pow.f64 f 2)) (*.f64 -1 (/.f64 n f)))) (+.f64 1 (/.f64 n f))) |
-1 |
(-.f64 (*.f64 -1 (/.f64 (-.f64 n (*.f64 -1 n)) f)) 1) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 n (-.f64 n (*.f64 -1 n))) (pow.f64 f 2))) (*.f64 -1 (/.f64 (-.f64 n (*.f64 -1 n)) f))) 1) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 n (-.f64 n (*.f64 -1 n))) (pow.f64 f 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 n 2) (-.f64 n (*.f64 -1 n))) (pow.f64 f 3))) (*.f64 -1 (/.f64 (-.f64 n (*.f64 -1 n)) f)))) 1) |
-1 |
(-.f64 (*.f64 -2 (/.f64 n f)) 1) |
(-.f64 (+.f64 (*.f64 -2 (/.f64 (pow.f64 n 2) (pow.f64 f 2))) (*.f64 -2 (/.f64 n f))) 1) |
(-.f64 (+.f64 (*.f64 -2 (/.f64 (pow.f64 n 3) (pow.f64 f 3))) (+.f64 (*.f64 -2 (/.f64 (pow.f64 n 2) (pow.f64 f 2))) (*.f64 -2 (/.f64 n f)))) 1) |
1 |
(-.f64 (+.f64 1 (/.f64 f n)) (*.f64 -1 (/.f64 f n))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 f n) (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) f) (pow.f64 n 2)))) (*.f64 -1 (/.f64 f n))) |
(-.f64 (+.f64 (/.f64 (*.f64 f (-.f64 f (*.f64 -1 f))) (pow.f64 n 2)) (+.f64 1 (+.f64 (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) (pow.f64 f 2)) (pow.f64 n 3)) (/.f64 f n)))) (*.f64 -1 (/.f64 f n))) |
1 |
(-.f64 (+.f64 1 (/.f64 f n)) (*.f64 -1 (/.f64 f n))) |
(-.f64 (+.f64 1 (+.f64 (/.f64 f n) (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) f) (pow.f64 n 2)))) (*.f64 -1 (/.f64 f n))) |
(-.f64 (+.f64 (/.f64 (*.f64 f (-.f64 f (*.f64 -1 f))) (pow.f64 n 2)) (+.f64 1 (+.f64 (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) (pow.f64 f 2)) (pow.f64 n 3)) (/.f64 f n)))) (*.f64 -1 (/.f64 f n))) |
| Outputs |
|---|
1 |
(+.f64 (*.f64 2 (/.f64 f n)) 1) |
(fma.f64 2 (/.f64 f n) 1) |
(+.f64 (*.f64 2 (/.f64 f n)) (+.f64 1 (*.f64 2 (/.f64 (pow.f64 f 2) (pow.f64 n 2))))) |
(+.f64 (fma.f64 2 (/.f64 f n) 1) (*.f64 2 (/.f64 (*.f64 f f) (*.f64 n n)))) |
(fma.f64 2 (/.f64 f n) (fma.f64 2 (*.f64 (/.f64 f n) (/.f64 f n)) 1)) |
(+.f64 1 (*.f64 (/.f64 f n) (+.f64 2 (*.f64 2 (/.f64 f n))))) |
(+.f64 (*.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3))) (+.f64 (*.f64 2 (/.f64 f n)) (+.f64 1 (*.f64 2 (/.f64 (pow.f64 f 2) (pow.f64 n 2)))))) |
(fma.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3)) (+.f64 (fma.f64 2 (/.f64 f n) 1) (*.f64 2 (/.f64 (*.f64 f f) (*.f64 n n))))) |
(fma.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3)) (fma.f64 2 (/.f64 f n) (fma.f64 2 (*.f64 (/.f64 f n) (/.f64 f n)) 1))) |
(+.f64 (*.f64 (/.f64 f n) (+.f64 2 (*.f64 2 (/.f64 f n)))) (fma.f64 2 (pow.f64 (/.f64 f n) 3) 1)) |
-1 |
(-.f64 (*.f64 -1 (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f))) |
(-.f64 (fma.f64 -1 (/.f64 n f) -1) (/.f64 n f)) |
(fma.f64 (/.f64 n f) -2 -1) |
(-.f64 (+.f64 (/.f64 (*.f64 n (-.f64 (*.f64 -1 n) n)) (pow.f64 f 2)) (*.f64 -1 (/.f64 n f))) (+.f64 1 (/.f64 n f))) |
(+.f64 (/.f64 n (/.f64 (*.f64 f f) (-.f64 (neg.f64 n) n))) (-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f)))) |
(-.f64 (-.f64 (*.f64 (/.f64 n f) (*.f64 (/.f64 n f) -2)) (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(fma.f64 -2 (*.f64 (+.f64 1 (/.f64 n f)) (/.f64 n f)) -1) |
(-.f64 (+.f64 (/.f64 (*.f64 (pow.f64 n 2) (-.f64 (*.f64 -1 n) n)) (pow.f64 f 3)) (+.f64 (/.f64 (*.f64 n (-.f64 (*.f64 -1 n) n)) (pow.f64 f 2)) (*.f64 -1 (/.f64 n f)))) (+.f64 1 (/.f64 n f))) |
(+.f64 (/.f64 (*.f64 n n) (/.f64 (pow.f64 f 3) (-.f64 (neg.f64 n) n))) (+.f64 (/.f64 n (/.f64 (*.f64 f f) (-.f64 (neg.f64 n) n))) (-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f))))) |
(-.f64 (-.f64 (*.f64 -2 (+.f64 (/.f64 (pow.f64 n 3) (pow.f64 f 3)) (*.f64 (/.f64 n f) (/.f64 n f)))) (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(fma.f64 -2 (+.f64 (pow.f64 (/.f64 n f) 3) (*.f64 (+.f64 1 (/.f64 n f)) (/.f64 n f))) -1) |
-1 |
(-.f64 (*.f64 -1 (/.f64 (-.f64 n (*.f64 -1 n)) f)) 1) |
(-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f))) |
(-.f64 (fma.f64 -1 (/.f64 n f) -1) (/.f64 n f)) |
(fma.f64 (/.f64 n f) -2 -1) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 n (-.f64 n (*.f64 -1 n))) (pow.f64 f 2))) (*.f64 -1 (/.f64 (-.f64 n (*.f64 -1 n)) f))) 1) |
(+.f64 (/.f64 n (/.f64 (*.f64 f f) (-.f64 (neg.f64 n) n))) (-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f)))) |
(-.f64 (-.f64 (*.f64 (/.f64 n f) (*.f64 (/.f64 n f) -2)) (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(fma.f64 -2 (*.f64 (+.f64 1 (/.f64 n f)) (/.f64 n f)) -1) |
(-.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 n (-.f64 n (*.f64 -1 n))) (pow.f64 f 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 n 2) (-.f64 n (*.f64 -1 n))) (pow.f64 f 3))) (*.f64 -1 (/.f64 (-.f64 n (*.f64 -1 n)) f)))) 1) |
(+.f64 (/.f64 (*.f64 n n) (/.f64 (pow.f64 f 3) (-.f64 (neg.f64 n) n))) (+.f64 (/.f64 n (/.f64 (*.f64 f f) (-.f64 (neg.f64 n) n))) (-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f))))) |
(-.f64 (-.f64 (*.f64 -2 (+.f64 (/.f64 (pow.f64 n 3) (pow.f64 f 3)) (*.f64 (/.f64 n f) (/.f64 n f)))) (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(fma.f64 -2 (+.f64 (pow.f64 (/.f64 n f) 3) (*.f64 (+.f64 1 (/.f64 n f)) (/.f64 n f))) -1) |
-1 |
(-.f64 (*.f64 -2 (/.f64 n f)) 1) |
(-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f))) |
(-.f64 (fma.f64 -1 (/.f64 n f) -1) (/.f64 n f)) |
(fma.f64 (/.f64 n f) -2 -1) |
(-.f64 (+.f64 (*.f64 -2 (/.f64 (pow.f64 n 2) (pow.f64 f 2))) (*.f64 -2 (/.f64 n f))) 1) |
(+.f64 (/.f64 n (/.f64 (*.f64 f f) (-.f64 (neg.f64 n) n))) (-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f)))) |
(-.f64 (-.f64 (*.f64 (/.f64 n f) (*.f64 (/.f64 n f) -2)) (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(fma.f64 -2 (*.f64 (+.f64 1 (/.f64 n f)) (/.f64 n f)) -1) |
(-.f64 (+.f64 (*.f64 -2 (/.f64 (pow.f64 n 3) (pow.f64 f 3))) (+.f64 (*.f64 -2 (/.f64 (pow.f64 n 2) (pow.f64 f 2))) (*.f64 -2 (/.f64 n f)))) 1) |
(+.f64 (/.f64 (*.f64 n n) (/.f64 (pow.f64 f 3) (-.f64 (neg.f64 n) n))) (+.f64 (/.f64 n (/.f64 (*.f64 f f) (-.f64 (neg.f64 n) n))) (-.f64 (/.f64 (neg.f64 n) f) (+.f64 1 (/.f64 n f))))) |
(-.f64 (-.f64 (*.f64 -2 (+.f64 (/.f64 (pow.f64 n 3) (pow.f64 f 3)) (*.f64 (/.f64 n f) (/.f64 n f)))) (/.f64 n f)) (+.f64 1 (/.f64 n f))) |
(fma.f64 -2 (+.f64 (pow.f64 (/.f64 n f) 3) (*.f64 (+.f64 1 (/.f64 n f)) (/.f64 n f))) -1) |
1 |
(-.f64 (+.f64 1 (/.f64 f n)) (*.f64 -1 (/.f64 f n))) |
(fma.f64 2 (/.f64 f n) 1) |
(-.f64 (+.f64 1 (+.f64 (/.f64 f n) (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) f) (pow.f64 n 2)))) (*.f64 -1 (/.f64 f n))) |
(+.f64 (fma.f64 2 (/.f64 f n) 1) (*.f64 2 (/.f64 (*.f64 f f) (*.f64 n n)))) |
(fma.f64 2 (/.f64 f n) (fma.f64 2 (*.f64 (/.f64 f n) (/.f64 f n)) 1)) |
(+.f64 1 (*.f64 (/.f64 f n) (+.f64 2 (*.f64 2 (/.f64 f n))))) |
(-.f64 (+.f64 (/.f64 (*.f64 f (-.f64 f (*.f64 -1 f))) (pow.f64 n 2)) (+.f64 1 (+.f64 (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) (pow.f64 f 2)) (pow.f64 n 3)) (/.f64 f n)))) (*.f64 -1 (/.f64 f n))) |
(fma.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3)) (+.f64 (fma.f64 2 (/.f64 f n) 1) (*.f64 2 (/.f64 (*.f64 f f) (*.f64 n n))))) |
(fma.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3)) (fma.f64 2 (/.f64 f n) (fma.f64 2 (*.f64 (/.f64 f n) (/.f64 f n)) 1))) |
(+.f64 (*.f64 (/.f64 f n) (+.f64 2 (*.f64 2 (/.f64 f n)))) (fma.f64 2 (pow.f64 (/.f64 f n) 3) 1)) |
1 |
(-.f64 (+.f64 1 (/.f64 f n)) (*.f64 -1 (/.f64 f n))) |
(fma.f64 2 (/.f64 f n) 1) |
(-.f64 (+.f64 1 (+.f64 (/.f64 f n) (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) f) (pow.f64 n 2)))) (*.f64 -1 (/.f64 f n))) |
(+.f64 (fma.f64 2 (/.f64 f n) 1) (*.f64 2 (/.f64 (*.f64 f f) (*.f64 n n)))) |
(fma.f64 2 (/.f64 f n) (fma.f64 2 (*.f64 (/.f64 f n) (/.f64 f n)) 1)) |
(+.f64 1 (*.f64 (/.f64 f n) (+.f64 2 (*.f64 2 (/.f64 f n))))) |
(-.f64 (+.f64 (/.f64 (*.f64 f (-.f64 f (*.f64 -1 f))) (pow.f64 n 2)) (+.f64 1 (+.f64 (/.f64 (*.f64 (-.f64 f (*.f64 -1 f)) (pow.f64 f 2)) (pow.f64 n 3)) (/.f64 f n)))) (*.f64 -1 (/.f64 f n))) |
(fma.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3)) (+.f64 (fma.f64 2 (/.f64 f n) 1) (*.f64 2 (/.f64 (*.f64 f f) (*.f64 n n))))) |
(fma.f64 2 (/.f64 (pow.f64 f 3) (pow.f64 n 3)) (fma.f64 2 (/.f64 f n) (fma.f64 2 (*.f64 (/.f64 f n) (/.f64 f n)) 1))) |
(+.f64 (*.f64 (/.f64 f n) (+.f64 2 (*.f64 2 (/.f64 f n)))) (fma.f64 2 (pow.f64 (/.f64 f n) 3) 1)) |
Compiled 845 to 389 computations (54% saved)
5 alts after pruning (4 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 53 | 4 | 57 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 53 | 5 | 58 |
| Status | Error | Program |
|---|---|---|
| 33.3b | 1 | |
| ✓ | 0.0b | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 30.3b | -1 | |
| ▶ | 29.7b | (-.f64 (*.f64 -2 (/.f64 n f)) 1) |
| ▶ | 32.9b | (+.f64 (*.f64 2 (/.f64 f n)) 1) |
Compiled 33 to 25 computations (24.2% saved)
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (*.f64 2 (/.f64 f n)) |
Compiled 21 to 11 computations (47.6% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | n | @ | 0 | (*.f64 2 (/.f64 f n)) |
| 1.0ms | f | @ | 0 | (*.f64 2 (/.f64 f n)) |
| 1.0ms | f | @ | inf | (*.f64 2 (/.f64 f n)) |
| 1.0ms | n | @ | inf | (*.f64 2 (/.f64 f n)) |
| 0.0ms | f | @ | -inf | (*.f64 2 (/.f64 f n)) |
| 1× | batch-egg-rewrite |
| 652× | pow1_binary64 |
| 604× | add-log-exp_binary64 |
| 604× | log1p-expm1-u_binary64 |
| 604× | expm1-log1p-u_binary64 |
| 592× | add-exp-log_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 7 |
| 1 | 127 | 7 |
| 2 | 1608 | 7 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 2 (/.f64 f n)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 2 (/.f64 f n))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 2 (/.f64 n f))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 n (*.f64 2 f)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 f) n)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 2 f)) (neg.f64 n))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 2 f) 1) n)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 2 f) (pow.f64 (cbrt.f64 n) 2)) (cbrt.f64 n))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 2 f) (sqrt.f64 n)) (sqrt.f64 n))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 f) 2) (neg.f64 n))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (neg.f64 f)) (neg.f64 n))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 (/.f64 f n)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 2 (/.f64 f n)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 2 (/.f64 f n))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 2 (/.f64 f n))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 (/.f64 f n) 2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 2) (/.f64 f n)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 2 (/.f64 f n)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 2 (/.f64 f n))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 2 (/.f64 f n))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 2 (/.f64 f n)))))))) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 0 | 0 |
| 1× | saturated |
| Inputs |
|---|
| Outputs |
|---|
Found 1 expressions with local error:
| New | Error | Program |
|---|---|---|
| ✓ | 0.0b | (*.f64 -2 (/.f64 n f)) |
Compiled 21 to 11 computations (47.6% saved)
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | n | @ | 0 | (*.f64 -2 (/.f64 n f)) |
| 1.0ms | n | @ | inf | (*.f64 -2 (/.f64 n f)) |
| 1.0ms | f | @ | 0 | (*.f64 -2 (/.f64 n f)) |
| 1.0ms | f | @ | inf | (*.f64 -2 (/.f64 n f)) |
| 1.0ms | n | @ | -inf | (*.f64 -2 (/.f64 n f)) |
| 1× | batch-egg-rewrite |
| 653× | pow1_binary64 |
| 606× | add-log-exp_binary64 |
| 606× | log1p-expm1-u_binary64 |
| 606× | expm1-log1p-u_binary64 |
| 594× | add-exp-log_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 7 |
| 1 | 127 | 7 |
| 2 | 1610 | 7 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 -2 (/.f64 n f)) |
| Outputs |
|---|
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 -2 (/.f64 n f))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -2 (/.f64 f n))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 f (*.f64 -2 n)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -2 n) f)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 -2 n)) (neg.f64 f))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 -2 n) 1) f)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 -2 n) (pow.f64 (cbrt.f64 f) 2)) (cbrt.f64 f))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 -2 n) (sqrt.f64 f)) (sqrt.f64 f))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 n) -2) (neg.f64 f))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -2 (neg.f64 n)) (neg.f64 f))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 -2 (/.f64 n f)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 -2 (/.f64 n f)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 -2 (/.f64 n f))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 -2 (/.f64 n f))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 (/.f64 n f) 2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 -2) (/.f64 n f)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 -2 (/.f64 n f)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 -2 (/.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 -2 (/.f64 n f))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 -2 (/.f64 n f)))))))) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 0 | 0 |
| 1× | saturated |
| Inputs |
|---|
| Outputs |
|---|
Compiled 382 to 264 computations (30.9% saved)
5 alts after pruning (2 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 40 | 0 | 40 |
| Fresh | 0 | 2 | 2 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 40 | 5 | 45 |
| Status | Error | Program |
|---|---|---|
| 33.3b | 1 | |
| ✓ | 0.0b | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 30.3b | -1 | |
| ✓ | 29.7b | (-.f64 (*.f64 -2 (/.f64 n f)) 1) |
| ✓ | 32.9b | (+.f64 (*.f64 2 (/.f64 f n)) 1) |
Compiled 33 to 25 computations (24.2% saved)
Compiled 2 to 2 computations (0% saved)
5 alts after pruning (2 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 2 | 2 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 3 | 3 |
| Total | 0 | 5 | 5 |
| Status | Error | Program |
|---|---|---|
| 33.3b | 1 | |
| ✓ | 0.0b | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 30.3b | -1 | |
| ✓ | 29.7b | (-.f64 (*.f64 -2 (/.f64 n f)) 1) |
| ✓ | 32.9b | (+.f64 (*.f64 2 (/.f64 f n)) 1) |
Compiled 33 to 25 computations (24.2% saved)
Compiled 2 to 2 computations (0% saved)
5 alts after pruning (2 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 0 | 0 |
| Fresh | 0 | 2 | 2 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 3 | 3 |
| Total | 0 | 5 | 5 |
| Status | Error | Program |
|---|---|---|
| 33.3b | 1 | |
| ✓ | 0.0b | (/.f64 (+.f64 f n) (-.f64 n f)) |
| 30.3b | -1 | |
| ✓ | 29.7b | (-.f64 (*.f64 -2 (/.f64 n f)) 1) |
| ✓ | 32.9b | (+.f64 (*.f64 2 (/.f64 f n)) 1) |
Compiled 33 to 25 computations (24.2% saved)
| Inputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
(-.f64 (*.f64 -2 (/.f64 n f)) 1) |
(+.f64 (*.f64 2 (/.f64 f n)) 1) |
(/.f64 (+.f64 f n) (-.f64 n f)) |
1 |
-1 |
| Outputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
3 calls:
| 5.0ms | f |
| 4.0ms | n |
| 2.0ms | (/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
| Error | Segments | Branch |
|---|---|---|
| 0.0b | 1 | f |
| 0.0b | 1 | n |
| 0.0b | 1 | (/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
Compiled 49 to 30 computations (38.8% saved)
| Inputs |
|---|
(-.f64 (*.f64 -2 (/.f64 n f)) 1) |
(+.f64 (*.f64 2 (/.f64 f n)) 1) |
(/.f64 (+.f64 f n) (-.f64 n f)) |
1 |
-1 |
| Outputs |
|---|
(/.f64 (+.f64 f n) (-.f64 n f)) |
2 calls:
| 5.0ms | n |
| 4.0ms | f |
| Error | Segments | Branch |
|---|---|---|
| 0.0b | 1 | f |
| 0.0b | 1 | n |
Compiled 31 to 21 computations (32.3% saved)
Total -50.5b remaining (-402.6%)
Threshold costs -50.5b (-402.6%)
| Inputs |
|---|
1 |
-1 |
| Outputs |
|---|
-1 |
1 |
-1 |
2 calls:
| 46.0ms | n |
| 9.0ms | f |
| Error | Segments | Branch |
|---|---|---|
| 12.5b | 3 | f |
| 13.7b | 3 | n |
Compiled 10 to 8 computations (20% saved)
| 2× | binary-search |
| Time | Left | Right |
|---|---|---|
| 17.0ms | 4.2399434910090636e-41 | 6.321981659271468e-34 |
| 18.0ms | -4.928140033601948e-129 | -1.4928502723946403e-136 |
Compiled 15 to 10 computations (33.3% saved)
| 1× | egg-herbie |
| 7× | +-commutative_binary64 |
| 6× | sub-neg_binary64 |
| 4× | *-commutative_binary64 |
| 4× | neg-sub0_binary64 |
| 4× | neg-mul-1_binary64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 18 | 37 |
| 1 | 30 | 37 |
| 2 | 42 | 37 |
| 3 | 50 | 37 |
| 4 | 53 | 37 |
| 1× | fuel |
| 1× | saturated |
| Inputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
(/.f64 (+.f64 f n) (-.f64 n f)) |
(if (<=.f64 f -15384414005651086/3121748550315992231381597229793166305748598142664971150859156959625371738819765620120306103063491971159826931121406622895447975679288285306290176) -1 (if (<=.f64 f 266145566453544544/6277101735386680763835789423207666416102355444464034512896) 1 -1)) |
| Outputs |
|---|
(/.f64 (neg.f64 (+.f64 f n)) (-.f64 f n)) |
(/.f64 (-.f64 (neg.f64 f) n) (-.f64 f n)) |
(/.f64 (-.f64 (neg.f64 n) f) (-.f64 f n)) |
(/.f64 (+.f64 f n) (-.f64 n f)) |
(if (<=.f64 f -15384414005651086/3121748550315992231381597229793166305748598142664971150859156959625371738819765620120306103063491971159826931121406622895447975679288285306290176) -1 (if (<=.f64 f 266145566453544544/6277101735386680763835789423207666416102355444464034512896) 1 -1)) |
(if (<=.f64 f -7692207002825543/1560874275157996115690798614896583152874299071332485575429578479812685869409882810060153051531745985579913465560703311447723987839644142653145088) -1 (if (<=.f64 f 8317048951673267/196159429230833773869868419475239575503198607639501078528) 1 -1)) |
Compiled 32 to 22 computations (31.3% saved)
Compiled 28 to 18 computations (35.7% saved)
Loading profile data...