
Time bar (total: 4.5s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 100% | 99.9% | 0% | 0.1% | 0% | 0% | 0% | 1 |
Compiled 9 to 8 computations (11.1% saved)
| 503.0ms | 8 254× | 0 | valid |
| 0.0ms | 2× | 1 | valid |
ival-add: 106.0ms (46.4% of total)ival-mult: 69.0ms (30.2% of total)ival-sub: 37.0ms (16.2% of total)ival-true: 6.0ms (2.6% of total)exact: 5.0ms (2.2% of total)ival-assert: 3.0ms (1.3% of total)adjust: 2.0ms (0.9% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 0 | 0 | - | 0 | - | (+.f64 x #s(literal 1 binary64)) |
| 0 | 0 | - | 0 | - | (*.f64 (+.f64 x #s(literal 1 binary64)) y) |
| 0 | 0 | - | 0 | - | y |
| 0 | 0 | - | 0 | - | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 0 | 0 | - | 0 | - | #s(literal 1 binary64) |
| 0 | 0 | - | 0 | - | x |
| Predicted + | Predicted - | |
|---|---|---|
| + | 0 | 0 |
| - | 0 | 256 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 0 | 0 | 0 |
| - | 0 | 0 | 256 |
| number | freq |
|---|---|
| 0 | 256 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 0 | 0 | 0 |
| - | 0 | 0 | 1 |
| 22.0ms | 512× | 0 | valid |
Compiled 47 to 22 computations (53.2% saved)
ival-add: 3.0ms (31.4% of total)ival-mult: 3.0ms (31.4% of total)ival-sub: 2.0ms (20.9% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 16 | 43 |
| 1 | 26 | 43 |
| 2 | 57 | 41 |
| 3 | 194 | 40 |
| 4 | 746 | 36 |
| 5 | 2315 | 36 |
| 6 | 7181 | 36 |
| 0 | 6 | 7 |
| 0 | 9 | 7 |
| 1 | 13 | 7 |
| 2 | 24 | 7 |
| 3 | 72 | 7 |
| 4 | 260 | 7 |
| 5 | 1077 | 7 |
| 0 | 8229 | 6 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
(-.f64 (fma.f64 y x y) x) |
Compiled 7 to 6 computations (14.3% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
Compiled 7 to 6 computations (14.3% saved)
| 1× | egg-herbie |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (+.f64 x #s(literal 1 binary64)) | |
| cost-diff | 0 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) | |
| cost-diff | 1 | (*.f64 (+.f64 x #s(literal 1 binary64)) y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 18 |
| 0 | 9 | 18 |
| 1 | 13 | 18 |
| 2 | 24 | 18 |
| 3 | 72 | 18 |
| 4 | 260 | 18 |
| 5 | 1077 | 18 |
| 0 | 8229 | 16 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
(*.f64 (+.f64 x #s(literal 1 binary64)) y) |
(+.f64 x #s(literal 1 binary64)) |
x |
#s(literal 1 binary64) |
y |
| Outputs |
|---|
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
(-.f64 (fma.f64 y x y) x) |
(*.f64 (+.f64 x #s(literal 1 binary64)) y) |
(fma.f64 y x y) |
(+.f64 x #s(literal 1 binary64)) |
(-.f64 x #s(literal -1 binary64)) |
x |
#s(literal 1 binary64) |
y |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (+.f64 x #s(literal 1 binary64)) | |
| accuracy | 0.01171875 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) | |
| accuracy | 0.01171875 | (*.f64 (+.f64 x #s(literal 1 binary64)) y) |
| 11.0ms | 256× | 0 | valid |
Compiled 20 to 8 computations (60% saved)
ival-mult: 2.0ms (41.2% of total)ival-sub: 1.0ms (20.6% of total)ival-add: 1.0ms (20.6% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(*.f64 (+.f64 x #s(literal 1 binary64)) y) |
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
(+.f64 x #s(literal 1 binary64)) |
| Outputs |
|---|
y |
(+ y (* x y)) |
(+ y (* x (- y 1))) |
1 |
(+ 1 x) |
(* x y) |
(* x (+ y (/ y x))) |
(* x (- y 1)) |
(* x (- (+ y (/ y x)) 1)) |
x |
(* x (+ 1 (/ 1 x))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* y (+ 1 x)) |
(* -1 x) |
(- (* y (+ 1 x)) x) |
(* y (+ 1 (+ x (* -1 (/ x y))))) |
(* -1 (* y (+ (* -1 (+ 1 x)) (/ x y)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 26.0ms | x | @ | 0 | ((* (+ x 1) y) (- (* (+ x 1) y) x) (+ x 1)) |
| 1.0ms | y | @ | inf | ((* (+ x 1) y) (- (* (+ x 1) y) x) (+ x 1)) |
| 0.0ms | x | @ | -inf | ((* (+ x 1) y) (- (* (+ x 1) y) x) (+ x 1)) |
| 0.0ms | x | @ | inf | ((* (+ x 1) y) (- (* (+ x 1) y) x) (+ x 1)) |
| 0.0ms | y | @ | -inf | ((* (+ x 1) y) (- (* (+ x 1) y) x) (+ x 1)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 41 | 86 |
| 1 | 147 | 86 |
| 2 | 516 | 86 |
| 3 | 1778 | 86 |
| 4 | 5823 | 86 |
| 0 | 8272 | 76 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
y |
(+ y (* x y)) |
(+ y (* x (- y 1))) |
1 |
(+ 1 x) |
(* x y) |
(* x (+ y (/ y x))) |
(* x (- y 1)) |
(* x (- (+ y (/ y x)) 1)) |
x |
(* x (+ 1 (/ 1 x))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* y (+ 1 x)) |
(* -1 x) |
(- (* y (+ 1 x)) x) |
(* y (+ 1 (+ x (* -1 (/ x y))))) |
(* -1 (* y (+ (* -1 (+ 1 x)) (/ x y)))) |
| Outputs |
|---|
y |
(+ y (* x y)) |
(fma.f64 y x y) |
(+ y (* x (- y 1))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
1 |
#s(literal 1 binary64) |
(+ 1 x) |
(-.f64 x #s(literal -1 binary64)) |
(* x y) |
(*.f64 y x) |
(* x (+ y (/ y x))) |
(fma.f64 y x y) |
(* x (- y 1)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* x (- (+ y (/ y x)) 1)) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
x |
(* x (+ 1 (/ 1 x))) |
(-.f64 x #s(literal -1 binary64)) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(fma.f64 y x y) |
(* -1 (* x (+ 1 (* -1 y)))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* y (+ 1 x)) |
(fma.f64 y x y) |
(* -1 x) |
(neg.f64 x) |
(- (* y (+ 1 x)) x) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* y (+ 1 (+ x (* -1 (/ x y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* -1 (* y (+ (* -1 (+ 1 x)) (/ x y)))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 15 |
| 0 | 9 | 15 |
| 1 | 37 | 15 |
| 0 | 279 | 15 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 (+.f64 x #s(literal 1 binary64)) y) |
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
(+.f64 x #s(literal 1 binary64)) |
| Outputs |
|---|
(*.f64 y (-.f64 x #s(literal -1 binary64))) |
(*.f64 (-.f64 x #s(literal -1 binary64)) y) |
(/.f64 (*.f64 (fma.f64 x x #s(literal -1 binary64)) y) (-.f64 x #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(/.f64 (*.f64 y (fma.f64 x x #s(literal -1 binary64))) (-.f64 x #s(literal 1 binary64))) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(fma.f64 y #s(literal 1 binary64) (*.f64 y x)) |
(fma.f64 y x (*.f64 y #s(literal 1 binary64))) |
(fma.f64 #s(literal 1 binary64) y (*.f64 x y)) |
(fma.f64 x y (*.f64 #s(literal 1 binary64) y)) |
(+.f64 (*.f64 #s(literal 1 binary64) y) (*.f64 x y)) |
(+.f64 (*.f64 x y) (*.f64 #s(literal 1 binary64) y)) |
(+.f64 (*.f64 y #s(literal 1 binary64)) (*.f64 y x)) |
(+.f64 (*.f64 y x) (*.f64 y #s(literal 1 binary64))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (fma.f64 y (-.f64 x #s(literal -1 binary64)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (fma.f64 y (-.f64 x #s(literal -1 binary64)) x) (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 x x)) (fma.f64 y (-.f64 x #s(literal -1 binary64)) x)) |
(/.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (fma.f64 y (-.f64 x #s(literal -1 binary64)) x) (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64)) (fma.f64 y (-.f64 x #s(literal -1 binary64)) x)) (/.f64 (*.f64 x x) (fma.f64 y (-.f64 x #s(literal -1 binary64)) x))) |
(-.f64 (/.f64 (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 3 binary64)) (fma.f64 x (fma.f64 y (-.f64 x #s(literal -1 binary64)) x) (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (fma.f64 y (-.f64 x #s(literal -1 binary64)) x) (pow.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) #s(literal 2 binary64))))) |
(-.f64 (*.f64 y (-.f64 x #s(literal -1 binary64))) x) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) (-.f64 #s(literal 1 binary64) x)) |
(/.f64 (neg.f64 (fma.f64 x x #s(literal -1 binary64))) (neg.f64 (-.f64 x #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (fma.f64 x x #s(literal -1 binary64)) (-.f64 x #s(literal 1 binary64))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 x x) x))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(fma.f64 #s(literal 1 binary64) x #s(literal 1 binary64)) |
(fma.f64 x #s(literal 1 binary64) #s(literal 1 binary64)) |
(-.f64 (/.f64 (*.f64 x x) (-.f64 x #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 x #s(literal 1 binary64)))) |
(-.f64 x #s(literal -1 binary64)) |
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (/.f64 #s(literal 1 binary64) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(+.f64 #s(literal 1 binary64) x) |
(+.f64 x #s(literal 1 binary64)) |
Compiled 554 to 139 computations (74.9% saved)
6 alts after pruning (6 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 35 | 6 | 41 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 36 | 6 | 42 |
| Status | Accuracy | Program |
|---|---|---|
| 66.4% | (-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) | |
| ▶ | 73.8% | (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
| ▶ | 100.0% | (-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
| ▶ | 60.2% | (-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
| ▶ | 60.2% | #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
| ▶ | 34.6% | #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
Compiled 142 to 108 computations (23.9% saved)
| 1× | egg-herbie |
Found 14 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | #s(approx (+ x 1) #s(literal 1 binary64)) | |
| cost-diff | 0 | (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) | |
| cost-diff | 0 | (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) | |
| cost-diff | 0 | (*.f64 y x) | |
| cost-diff | 0 | #s(approx (* (+ x 1) y) (*.f64 y x)) | |
| cost-diff | 0 | (-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) | |
| cost-diff | 0 | (-.f64 y #s(literal 1 binary64)) | |
| cost-diff | 0 | (*.f64 (-.f64 y #s(literal 1 binary64)) x) | |
| cost-diff | 0 | #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) | |
| cost-diff | 0 | (neg.f64 x) | |
| cost-diff | 0 | #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) | |
| cost-diff | 0 | (fma.f64 y x y) | |
| cost-diff | 0 | #s(approx (* (+ x 1) y) (fma.f64 y x y)) | |
| cost-diff | 0 | (-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 20 | 114 |
| 0 | 29 | 114 |
| 1 | 37 | 108 |
| 2 | 52 | 108 |
| 3 | 95 | 108 |
| 4 | 332 | 108 |
| 5 | 1361 | 108 |
| 0 | 8085 | 108 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
#s(approx (* (+ x 1) y) (fma.f64 y x y)) |
(fma.f64 y x y) |
y |
x |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
(neg.f64 x) |
x |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(-.f64 y #s(literal 1 binary64)) |
y |
#s(literal 1 binary64) |
x |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
#s(approx (* (+ x 1) y) (*.f64 y x)) |
(*.f64 y x) |
y |
x |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
(*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) |
#s(approx (+ x 1) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
y |
x |
| Outputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
#s(approx (* (+ x 1) y) (fma.f64 y x y)) |
(fma.f64 y x y) |
y |
x |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
(neg.f64 x) |
x |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(-.f64 y #s(literal 1 binary64)) |
y |
#s(literal 1 binary64) |
x |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
#s(approx (* (+ x 1) y) (*.f64 y x)) |
(*.f64 y x) |
y |
x |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
(fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y (neg.f64 x)) |
(*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) |
#s(approx (+ x 1) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
y |
x |
Found 14 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.01171875 | (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) | |
| accuracy | 0.01171875 | (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) | |
| accuracy | 31.343362743845674 | #s(approx (+ x 1) #s(literal 1 binary64)) | |
| accuracy | 0.0 | (*.f64 y x) | |
| accuracy | 0.01171875 | (-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) | |
| accuracy | 31.30764590179701 | #s(approx (* (+ x 1) y) (*.f64 y x)) | |
| accuracy | 0.0 | (-.f64 y #s(literal 1 binary64)) | |
| accuracy | 0.0078125 | (*.f64 (-.f64 y #s(literal 1 binary64)) x) | |
| accuracy | 25.47548273023534 | #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) | |
| accuracy | 0.0 | (neg.f64 x) | |
| accuracy | 41.856009287375855 | #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) | |
| accuracy | 0.0 | (fma.f64 y x y) | |
| accuracy | 0.0 | #s(approx (* (+ x 1) y) (fma.f64 y x y)) | |
| accuracy | 0.01171875 | (-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
| 120.0ms | 256× | 0 | valid |
Compiled 84 to 13 computations (84.5% saved)
ival-add: 34.0ms (80.2% of total)ival-mult: 5.0ms (11.8% of total)ival-sub: 2.0ms (4.7% of total)ival-neg: 1.0ms (2.4% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
#s(approx (* (+ x 1) y) (fma.f64 y x y)) |
(fma.f64 y x y) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
(neg.f64 x) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(-.f64 y #s(literal 1 binary64)) |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
#s(approx (* (+ x 1) y) (*.f64 y x)) |
(*.f64 y x) |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
(*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) |
#s(approx (+ x 1) #s(literal 1 binary64)) |
| Outputs |
|---|
y |
(+ y (* x (- y 1))) |
(+ y (* x y)) |
(* -1 x) |
(* x (- y 1)) |
(* x y) |
1 |
(+ 1 x) |
(* x (- (+ y (/ y x)) 1)) |
(* x (+ y (/ y x))) |
x |
(* x (+ 1 (/ 1 x))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(- (* y (+ 1 x)) x) |
(* y (+ 1 x)) |
(+ (* -1 x) (* x y)) |
-1 |
(- y 1) |
(* y (+ 1 (+ x (* -1 (/ x y))))) |
(* y (+ x (* -1 (/ x y)))) |
(* y (- 1 (/ 1 y))) |
(* -1 (* y (+ (* -1 (+ 1 x)) (/ x y)))) |
(* -1 (* y (- (* -1 x) 1))) |
(* -1 (* y (+ (* -1 x) (/ x y)))) |
(* -1 (* y (- (/ 1 y) 1))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | x | @ | inf | ((- (* (+ x 1) y) x) (* (+ x 1) y) (+ (* y x) y) (- (* (+ x 1) y) x) (neg x) (- (* (+ x 1) y) x) (* (- y 1) x) (- y 1) (- (* (+ x 1) y) x) (* (+ x 1) y) (* y x) (- (* (+ x 1) y) x) (* (+ x 1) y) (+ x 1)) |
| 1.0ms | y | @ | -inf | ((- (* (+ x 1) y) x) (* (+ x 1) y) (+ (* y x) y) (- (* (+ x 1) y) x) (neg x) (- (* (+ x 1) y) x) (* (- y 1) x) (- y 1) (- (* (+ x 1) y) x) (* (+ x 1) y) (* y x) (- (* (+ x 1) y) x) (* (+ x 1) y) (+ x 1)) |
| 1.0ms | x | @ | -inf | ((- (* (+ x 1) y) x) (* (+ x 1) y) (+ (* y x) y) (- (* (+ x 1) y) x) (neg x) (- (* (+ x 1) y) x) (* (- y 1) x) (- y 1) (- (* (+ x 1) y) x) (* (+ x 1) y) (* y x) (- (* (+ x 1) y) x) (* (+ x 1) y) (+ x 1)) |
| 1.0ms | y | @ | inf | ((- (* (+ x 1) y) x) (* (+ x 1) y) (+ (* y x) y) (- (* (+ x 1) y) x) (neg x) (- (* (+ x 1) y) x) (* (- y 1) x) (- y 1) (- (* (+ x 1) y) x) (* (+ x 1) y) (* y x) (- (* (+ x 1) y) x) (* (+ x 1) y) (+ x 1)) |
| 1.0ms | x | @ | 0 | ((- (* (+ x 1) y) x) (* (+ x 1) y) (+ (* y x) y) (- (* (+ x 1) y) x) (neg x) (- (* (+ x 1) y) x) (* (- y 1) x) (- y 1) (- (* (+ x 1) y) x) (* (+ x 1) y) (* y x) (- (* (+ x 1) y) x) (* (+ x 1) y) (+ x 1)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 55 | 124 |
| 1 | 187 | 124 |
| 2 | 642 | 124 |
| 3 | 2246 | 124 |
| 4 | 6720 | 124 |
| 0 | 8162 | 113 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
y |
(+ y (* x (- y 1))) |
(+ y (* x y)) |
(* -1 x) |
(* x (- y 1)) |
(* x y) |
1 |
(+ 1 x) |
(* x (- (+ y (/ y x)) 1)) |
(* x (+ y (/ y x))) |
x |
(* x (+ 1 (/ 1 x))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(- (* y (+ 1 x)) x) |
(* y (+ 1 x)) |
(+ (* -1 x) (* x y)) |
-1 |
(- y 1) |
(* y (+ 1 (+ x (* -1 (/ x y))))) |
(* y (+ x (* -1 (/ x y)))) |
(* y (- 1 (/ 1 y))) |
(* -1 (* y (+ (* -1 (+ 1 x)) (/ x y)))) |
(* -1 (* y (- (* -1 x) 1))) |
(* -1 (* y (+ (* -1 x) (/ x y)))) |
(* -1 (* y (- (/ 1 y) 1))) |
| Outputs |
|---|
y |
(+ y (* x (- y 1))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x y)) |
(fma.f64 y x y) |
(* -1 x) |
(neg.f64 x) |
(* x (- y 1)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* x y) |
(*.f64 y x) |
1 |
#s(literal 1 binary64) |
(+ 1 x) |
(-.f64 x #s(literal -1 binary64)) |
(* x (- (+ y (/ y x)) 1)) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* x (+ y (/ y x))) |
(fma.f64 y x y) |
x |
(* x (+ 1 (/ 1 x))) |
(-.f64 x #s(literal -1 binary64)) |
(* -1 (* x (+ 1 (* -1 y)))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(fma.f64 y x y) |
(- (* y (+ 1 x)) x) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* y (+ 1 x)) |
(fma.f64 y x y) |
(+ (* -1 x) (* x y)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
-1 |
#s(literal -1 binary64) |
(- y 1) |
(-.f64 y #s(literal 1 binary64)) |
(* y (+ 1 (+ x (* -1 (/ x y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* y (+ x (* -1 (/ x y)))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* y (- 1 (/ 1 y))) |
(*.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) y)) y) |
(* -1 (* y (+ (* -1 (+ 1 x)) (/ x y)))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(* -1 (* y (- (* -1 x) 1))) |
(fma.f64 y x y) |
(* -1 (* y (+ (* -1 x) (/ x y)))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* -1 (* y (- (/ 1 y) 1))) |
(*.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) y)) y) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 20 | 103 |
| 0 | 29 | 103 |
| 1 | 111 | 97 |
| 0 | 808 | 97 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
#s(approx (* (+ x 1) y) (fma.f64 y x y)) |
(fma.f64 y x y) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
(neg.f64 x) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(-.f64 y #s(literal 1 binary64)) |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
#s(approx (* (+ x 1) y) (*.f64 y x)) |
(*.f64 y x) |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
(*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) |
#s(approx (+ x 1) #s(literal 1 binary64)) |
| Outputs |
|---|
(/.f64 (neg.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64)) (*.f64 x x)) (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x)) |
(/.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64)))) |
(-.f64 (/.f64 (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64)) (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x)) (/.f64 (*.f64 x x) (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x))) |
(-.f64 (/.f64 (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 3 binary64)) (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) (pow.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) #s(literal 2 binary64))))) |
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
#s(approx (* (+ x 1) y) (fma.f64 y x y)) |
(*.f64 y (-.f64 x #s(literal -1 binary64))) |
(*.f64 (-.f64 x #s(literal -1 binary64)) y) |
(/.f64 (*.f64 (fma.f64 x x #s(literal -1 binary64)) y) (-.f64 x #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(/.f64 (*.f64 y (fma.f64 x x #s(literal -1 binary64))) (-.f64 x #s(literal 1 binary64))) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(/.f64 (-.f64 (*.f64 y y) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 y (*.f64 y x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y))) (neg.f64 (-.f64 (*.f64 y x) y))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y)) (-.f64 (*.f64 y x) y)) |
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 y y (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 y x) y)))) |
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) |
(fma.f64 y #s(literal 1 binary64) (*.f64 y x)) |
(fma.f64 y x y) |
(fma.f64 #s(literal 1 binary64) y (*.f64 y x)) |
(fma.f64 x y y) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) y)) (/.f64 (*.f64 y y) (-.f64 (*.f64 y x) y))) |
(-.f64 y (*.f64 (neg.f64 y) x)) |
(-.f64 y (*.f64 (neg.f64 x) y)) |
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) |
(+.f64 (*.f64 y x) y) |
(+.f64 y (*.f64 y x)) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
(neg.f64 x) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(*.f64 x (-.f64 y #s(literal 1 binary64))) |
(/.f64 (*.f64 (fma.f64 y y #s(literal -1 binary64)) x) (-.f64 y #s(literal -1 binary64))) |
(/.f64 (*.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64)) x) (fma.f64 y y (-.f64 y #s(literal -1 binary64)))) |
(/.f64 (*.f64 x (fma.f64 y y #s(literal -1 binary64))) (-.f64 y #s(literal -1 binary64))) |
(/.f64 (*.f64 x (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64))) (fma.f64 y y (-.f64 y #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (fma.f64 y y #s(literal -1 binary64))) (neg.f64 (-.f64 y #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 y y (-.f64 y #s(literal -1 binary64))))) |
(/.f64 (fma.f64 y y #s(literal -1 binary64)) (-.f64 y #s(literal -1 binary64))) |
(/.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64)) (fma.f64 y y (-.f64 y #s(literal -1 binary64)))) |
(fma.f64 y #s(literal 1 binary64) #s(literal -1 binary64)) |
(fma.f64 #s(literal 1 binary64) y #s(literal -1 binary64)) |
(-.f64 (/.f64 (*.f64 y y) (-.f64 y #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 y #s(literal -1 binary64)))) |
(-.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y y (-.f64 y #s(literal -1 binary64)))) (/.f64 #s(literal 1 binary64) (fma.f64 y y (-.f64 y #s(literal -1 binary64))))) |
(-.f64 y #s(literal 1 binary64)) |
(+.f64 y #s(literal -1 binary64)) |
(/.f64 (neg.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64)) (*.f64 x x)) (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x)) |
(/.f64 (-.f64 (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64)))) |
(-.f64 (/.f64 (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64)) (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x)) (/.f64 (*.f64 x x) (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x))) |
(-.f64 (/.f64 (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 3 binary64)) (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (+.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) (pow.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) #s(literal 2 binary64))))) |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
#s(approx (* (+ x 1) y) (*.f64 y x)) |
(*.f64 y x) |
(*.f64 x y) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x) (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64)) (*.f64 x x)) (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x)) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x) (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64)) (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x)) (/.f64 (*.f64 x x) (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x))) |
(-.f64 (/.f64 (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 3 binary64)) (fma.f64 x (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x) (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (fma.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y x) (pow.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) #s(literal 2 binary64))))) |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
(*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) |
(*.f64 y #s(approx (+ x 1) #s(literal 1 binary64))) |
#s(approx (+ x 1) #s(literal 1 binary64)) |
Compiled 1 725 to 273 computations (84.2% saved)
6 alts after pruning (1 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 78 | 0 | 78 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 5 | 5 |
| Done | 0 | 0 | 0 |
| Total | 78 | 6 | 84 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 66.4% | (-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
| ✓ | 73.8% | (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
| ✓ | 100.0% | (-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
| ✓ | 60.2% | (-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
| ✓ | 60.2% | #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
| ✓ | 34.6% | #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
Compiled 71 to 54 computations (23.9% saved)
| 1× | egg-herbie |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) | |
| cost-diff | 0 | (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) | |
| cost-diff | 0 | (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) | |
| cost-diff | 0 | (-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 59 |
| 0 | 20 | 59 |
| 1 | 34 | 59 |
| 2 | 68 | 59 |
| 3 | 144 | 59 |
| 4 | 286 | 59 |
| 5 | 747 | 59 |
| 6 | 5051 | 59 |
| 0 | 8642 | 59 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
x |
#s(literal 3 binary64) |
#s(literal -1 binary64) |
y |
(fma.f64 x x (-.f64 #s(literal 1 binary64) x)) |
(-.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
| Outputs |
|---|
(-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
(-.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) x) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) |
(*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
x |
#s(literal 3 binary64) |
#s(literal -1 binary64) |
y |
(fma.f64 x x (-.f64 #s(literal 1 binary64) x)) |
(-.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.00390625 | (pow.f64 x #s(literal 3 binary64)) | |
| accuracy | 0.01171875 | (-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) | |
| accuracy | 2.833482893421166 | (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) | |
| accuracy | 18.717002525649978 | (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
| 44.0ms | 256× | 0 | valid |
Compiled 64 to 15 computations (76.6% saved)
ival-pow: 26.0ms (72.9% of total)ival-mult: 3.0ms (8.4% of total)ival-sub: 3.0ms (8.4% of total)ival-div: 2.0ms (5.6% of total)ival-add: 1.0ms (2.8% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Inputs |
|---|
(-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
| Outputs |
|---|
y |
(+ y (* -1 (* x (+ 1 (* -1 y))))) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x y)) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* (pow x 3) y)) |
1 |
(+ 1 (pow x 3)) |
(pow x 3) |
(* x (- y 1)) |
(* x (- (+ y (/ y x)) 1)) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (+ 1 (* -1 (/ y x))))) |
(* x (- (+ y (/ y (pow x 3))) (+ 1 (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2))))))))) |
(* x y) |
(* x (+ y (/ y x))) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (* -1 (/ y x)))) |
(* x (- (+ y (/ y (pow x 3))) (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2)))))))) |
(* (pow x 3) y) |
(* (pow x 3) (+ y (/ y (pow x 3)))) |
(* (pow x 3) (+ 1 (/ 1 (pow x 3)))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x)))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x))))) |
(* -1 (* (pow x 3) (+ (* -1 y) (* -1 (/ y (pow x 3)))))) |
(* -1 x) |
(- (* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) x) |
(/ (* y (+ 1 (pow x 3))) (- (+ 1 (pow x 2)) x)) |
(* y (+ 1 (pow x 3))) |
(* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) |
(* y (+ (* -1 (/ x y)) (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x))))) |
(* -1 (* y (+ (* -1 (/ (+ 1 (pow x 3)) (- (+ 1 (pow x 2)) x))) (/ x y)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 3.0ms | x | @ | -inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) (* (- (pow x 3) -1) y) (- (pow x 3) -1) (pow x 3)) |
| 2.0ms | y | @ | inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) (* (- (pow x 3) -1) y) (- (pow x 3) -1) (pow x 3)) |
| 2.0ms | y | @ | 0 | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) (* (- (pow x 3) -1) y) (- (pow x 3) -1) (pow x 3)) |
| 2.0ms | y | @ | -inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) (* (- (pow x 3) -1) y) (- (pow x 3) -1) (pow x 3)) |
| 1.0ms | x | @ | inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) (* (- (pow x 3) -1) y) (- (pow x 3) -1) (pow x 3)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 126 | 300 |
| 1 | 456 | 292 |
| 2 | 1973 | 288 |
| 0 | 8171 | 270 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
y |
(+ y (* -1 (* x (+ 1 (* -1 y))))) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x y)) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* (pow x 3) y)) |
1 |
(+ 1 (pow x 3)) |
(pow x 3) |
(* x (- y 1)) |
(* x (- (+ y (/ y x)) 1)) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (+ 1 (* -1 (/ y x))))) |
(* x (- (+ y (/ y (pow x 3))) (+ 1 (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2))))))))) |
(* x y) |
(* x (+ y (/ y x))) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (* -1 (/ y x)))) |
(* x (- (+ y (/ y (pow x 3))) (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2)))))))) |
(* (pow x 3) y) |
(* (pow x 3) (+ y (/ y (pow x 3)))) |
(* (pow x 3) (+ 1 (/ 1 (pow x 3)))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x)))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x))))) |
(* -1 (* (pow x 3) (+ (* -1 y) (* -1 (/ y (pow x 3)))))) |
(* -1 x) |
(- (* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) x) |
(/ (* y (+ 1 (pow x 3))) (- (+ 1 (pow x 2)) x)) |
(* y (+ 1 (pow x 3))) |
(* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) |
(* y (+ (* -1 (/ x y)) (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x))))) |
(* -1 (* y (+ (* -1 (/ (+ 1 (pow x 3)) (- (+ 1 (pow x 2)) x))) (/ x y)))) |
| Outputs |
|---|
y |
(+ y (* -1 (* x (+ 1 (* -1 y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x y)) |
(fma.f64 y x y) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (* -1 y)))) |
(fma.f64 y x y) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (* -1 y)))) |
(fma.f64 y x y) |
(+ y (* (pow x 3) y)) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
1 |
#s(literal 1 binary64) |
(+ 1 (pow x 3)) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(pow x 3) |
(pow.f64 x #s(literal 3 binary64)) |
(* x (- y 1)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* x (- (+ y (/ y x)) 1)) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (+ 1 (* -1 (/ y x))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* x (- (+ y (/ y (pow x 3))) (+ 1 (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2))))))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* x y) |
(*.f64 y x) |
(* x (+ y (/ y x))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (* -1 (/ y x)))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* x (- (+ y (/ y (pow x 3))) (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2)))))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* (pow x 3) y) |
(*.f64 (pow.f64 x #s(literal 3 binary64)) y) |
(* (pow x 3) (+ y (/ y (pow x 3)))) |
(fma.f64 (/.f64 y #s(literal 1 binary64)) #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) |
(* (pow x 3) (+ 1 (/ 1 (pow x 3)))) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(* -1 (* x (+ 1 (* -1 y)))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x)))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x)))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* -1 (* (pow x 3) (+ (* -1 y) (* -1 (/ y (pow x 3)))))) |
(fma.f64 (/.f64 y #s(literal 1 binary64)) #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) |
(* -1 x) |
(neg.f64 x) |
(- (* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) x) |
(-.f64 (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) x) |
(/ (* y (+ 1 (pow x 3))) (- (+ 1 (pow x 2)) x)) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) |
(* y (+ 1 (pow x 3))) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
(* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) |
(* y (+ (* -1 (/ x y)) (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x))))) |
(*.f64 (-.f64 (/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) (/.f64 x y)) y) |
(* -1 (* y (+ (* -1 (/ (+ 1 (pow x 3)) (- (+ 1 (pow x 2)) x))) (/ x y)))) |
(*.f64 (-.f64 (/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) (/.f64 x y)) y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 45 |
| 0 | 20 | 45 |
| 1 | 91 | 45 |
| 0 | 769 | 45 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
| Outputs |
|---|
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x) (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 x x)) (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x)) |
(/.f64 (-.f64 (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x) (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64)) (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x)) (/.f64 (*.f64 x x) (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 3 binary64)) (fma.f64 x (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x) (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (fma.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) x) (pow.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) #s(literal 2 binary64))))) |
(-.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) x) |
(*.f64 (/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)))) (-.f64 (*.f64 x x) (-.f64 #s(literal 1 binary64) x))) |
(*.f64 (/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64)))) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64)))) |
(*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(*.f64 y (/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) |
(/.f64 (neg.f64 (*.f64 (neg.f64 y) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)))) (neg.f64 (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) y) (*.f64 (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) y) (*.f64 (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (*.f64 (neg.f64 y) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(neg.f64 (/.f64 (*.f64 (neg.f64 y) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(neg.f64 (/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64))) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64)))) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64))) (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) y) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) y) (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) |
(*.f64 (fma.f64 x x (+.f64 #s(literal 1 binary64) (*.f64 x #s(literal -1 binary64)))) (-.f64 x #s(literal -1 binary64))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64))) (neg.f64 (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64))))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64)))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 6 binary64)) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64)))) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 9 binary64)) (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) (/.f64 #s(literal -1 binary64) (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64))))) |
(-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) |
(*.f64 (*.f64 x (neg.f64 x)) (neg.f64 x)) |
(*.f64 (*.f64 x (fabs.f64 x)) (fabs.f64 x)) |
(*.f64 (neg.f64 (pow.f64 x #s(literal 3/2 binary64))) (neg.f64 (pow.f64 x #s(literal 3/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 x #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 x #s(literal 3/2 binary64)))) |
(*.f64 (pow.f64 x #s(literal 3/2 binary64)) (pow.f64 x #s(literal 3/2 binary64))) |
(*.f64 (neg.f64 x) (*.f64 (neg.f64 x) x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) x)) |
(*.f64 (*.f64 x x) x) |
(*.f64 x (*.f64 x x)) |
(pow.f64 (exp.f64 (log.f64 x)) #s(literal 3 binary64)) |
(pow.f64 (pow.f64 x #s(literal 3/2 binary64)) #s(literal 2 binary64)) |
(pow.f64 (*.f64 x x) #s(literal 3/2 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) (sinh.f64 (*.f64 (log.f64 x) #s(literal 3 binary64)))) |
Compiled 1 691 to 306 computations (81.9% saved)
6 alts after pruning (1 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 66 | 1 | 67 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 5 | 5 |
| Total | 67 | 6 | 73 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 73.8% | (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
| ✓ | 100.0% | (-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
| ✓ | 60.2% | (-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
| ▶ | 48.2% | #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
| ✓ | 60.2% | #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
| ✓ | 34.6% | #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
Compiled 86 to 63 computations (26.7% saved)
| 1× | egg-herbie |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (pow.f64 x #s(literal 3 binary64)) | |
| cost-diff | 0 | (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) | |
| cost-diff | 0 | (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) | |
| cost-diff | 0 | #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 19 | 67 |
| 0 | 25 | 66 |
| 1 | 45 | 66 |
| 2 | 105 | 66 |
| 3 | 361 | 66 |
| 4 | 1031 | 65 |
| 5 | 3172 | 65 |
| 6 | 7723 | 65 |
| 0 | 8447 | 65 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
(pow.f64 x #s(literal 3 binary64)) |
x |
#s(literal 3 binary64) |
y |
(-.f64 (fma.f64 x x #s(literal 1 binary64)) x) |
(fma.f64 x x #s(literal 1 binary64)) |
#s(literal 1 binary64) |
| Outputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
(pow.f64 x #s(literal 3 binary64)) |
x |
#s(literal 3 binary64) |
y |
(-.f64 (fma.f64 x x #s(literal 1 binary64)) x) |
(fma.f64 x x (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 x x #s(literal 1 binary64)) |
#s(literal 1 binary64) |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.01171875 | (-.f64 (fma.f64 x x #s(literal 1 binary64)) x) | |
| accuracy | 2.833482893421166 | (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) | |
| accuracy | 18.717002525649978 | (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) | |
| accuracy | 21.286420109172322 | #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
| 72.0ms | 256× | 0 | valid |
Compiled 60 to 20 computations (66.7% saved)
ival-pow: 47.0ms (74.8% of total)ival-mult: 5.0ms (8% of total)ival-sub: 5.0ms (8% of total)ival-div: 3.0ms (4.8% of total)ival-add: 3.0ms (4.8% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
(pow.f64 x #s(literal 3 binary64)) |
(-.f64 (fma.f64 x x #s(literal 1 binary64)) x) |
| Outputs |
|---|
y |
(+ y (* -1 (* x (+ 1 (* -1 y))))) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x y)) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* (pow x 3) y)) |
(pow x 3) |
1 |
(+ 1 (* -1 x)) |
(+ 1 (* x (- x 1))) |
(* x (- y 1)) |
(* x (- (+ y (/ y x)) 1)) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (+ 1 (* -1 (/ y x))))) |
(* x (- (+ y (/ y (pow x 3))) (+ 1 (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2))))))))) |
(* x y) |
(* x (+ y (/ y x))) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (* -1 (/ y x)))) |
(* x (- (+ y (/ y (pow x 3))) (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2)))))))) |
(* (pow x 3) y) |
(* (pow x 3) (+ y (/ y (pow x 3)))) |
(pow x 2) |
(* (pow x 2) (- 1 (/ 1 x))) |
(* (pow x 2) (- (+ 1 (/ 1 (pow x 2))) (/ 1 x))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x)))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x))))) |
(* -1 (* (pow x 3) (+ (* -1 y) (* -1 (/ y (pow x 3)))))) |
(* (pow x 2) (+ 1 (* -1 (/ (- 1 (/ 1 x)) x)))) |
(* -1 x) |
(- (* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) x) |
(/ (* y (+ 1 (pow x 3))) (- (+ 1 (pow x 2)) x)) |
(* y (+ 1 (pow x 3))) |
(* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) |
(* y (+ (* -1 (/ x y)) (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x))))) |
(* -1 (* y (+ (* -1 (/ (+ 1 (pow x 3)) (- (+ 1 (pow x 2)) x))) (/ x y)))) |
(* -1 (/ (* y (- (* -1 (pow x 3)) 1)) (- (+ 1 (pow x 2)) x))) |
(* -1 (* y (- (* -1 (pow x 3)) 1))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 38.0ms | y | @ | -inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (+ (* (pow x 3) y) y) (pow x 3) (- (+ (* x x) 1) x)) |
| 1.0ms | y | @ | inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (+ (* (pow x 3) y) y) (pow x 3) (- (+ (* x x) 1) x)) |
| 1.0ms | y | @ | 0 | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (+ (* (pow x 3) y) y) (pow x 3) (- (+ (* x x) 1) x)) |
| 1.0ms | x | @ | -inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (+ (* (pow x 3) y) y) (pow x 3) (- (+ (* x x) 1) x)) |
| 1.0ms | x | @ | inf | ((- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (+ (* (pow x 3) y) y) (pow x 3) (- (+ (* x x) 1) x)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 144 | 364 |
| 1 | 504 | 354 |
| 2 | 2108 | 350 |
| 0 | 8177 | 330 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
y |
(+ y (* -1 (* x (+ 1 (* -1 y))))) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(+ y (* x y)) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (* -1 y)))) |
(+ y (* (pow x 3) y)) |
(pow x 3) |
1 |
(+ 1 (* -1 x)) |
(+ 1 (* x (- x 1))) |
(* x (- y 1)) |
(* x (- (+ y (/ y x)) 1)) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (+ 1 (* -1 (/ y x))))) |
(* x (- (+ y (/ y (pow x 3))) (+ 1 (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2))))))))) |
(* x y) |
(* x (+ y (/ y x))) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (* -1 (/ y x)))) |
(* x (- (+ y (/ y (pow x 3))) (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2)))))))) |
(* (pow x 3) y) |
(* (pow x 3) (+ y (/ y (pow x 3)))) |
(pow x 2) |
(* (pow x 2) (- 1 (/ 1 x))) |
(* (pow x 2) (- (+ 1 (/ 1 (pow x 2))) (/ 1 x))) |
(* -1 (* x (+ 1 (* -1 y)))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x)))))) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x)))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x))))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x))))) |
(* -1 (* (pow x 3) (+ (* -1 y) (* -1 (/ y (pow x 3)))))) |
(* (pow x 2) (+ 1 (* -1 (/ (- 1 (/ 1 x)) x)))) |
(* -1 x) |
(- (* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) x) |
(/ (* y (+ 1 (pow x 3))) (- (+ 1 (pow x 2)) x)) |
(* y (+ 1 (pow x 3))) |
(* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) |
(* y (+ (* -1 (/ x y)) (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x))))) |
(* -1 (* y (+ (* -1 (/ (+ 1 (pow x 3)) (- (+ 1 (pow x 2)) x))) (/ x y)))) |
(* -1 (/ (* y (- (* -1 (pow x 3)) 1)) (- (+ 1 (pow x 2)) x))) |
(* -1 (* y (- (* -1 (pow x 3)) 1))) |
| Outputs |
|---|
y |
(+ y (* -1 (* x (+ 1 (* -1 y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (+ 1 (* -1 y))))) |
(fma.f64 (-.f64 y #s(literal 1 binary64)) x y) |
(+ y (* x y)) |
(fma.f64 y x y) |
(+ y (* x (- (* -1 (* x (+ y (* -1 y)))) (* -1 y)))) |
(fma.f64 y x y) |
(+ y (* x (- (* x (- (* x (- y (+ (* -1 y) (* 2 y)))) (+ y (* -1 y)))) (* -1 y)))) |
(fma.f64 y x y) |
(+ y (* (pow x 3) y)) |
(fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) |
(pow x 3) |
(pow.f64 x #s(literal 3 binary64)) |
1 |
#s(literal 1 binary64) |
(+ 1 (* -1 x)) |
(-.f64 #s(literal 1 binary64) x) |
(+ 1 (* x (- x 1))) |
(fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64)) |
(* x (- y 1)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* x (- (+ y (/ y x)) 1)) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (+ 1 (* -1 (/ y x))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* x (- (+ y (/ y (pow x 3))) (+ 1 (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2))))))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* x y) |
(*.f64 y x) |
(* x (+ y (/ y x))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* x (- (+ y (* -1 (/ (+ y (* -1 y)) (pow x 2)))) (* -1 (/ y x)))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* x (- (+ y (/ y (pow x 3))) (+ (* -1 (/ y x)) (+ (* -1 (/ y (pow x 2))) (+ (* -1 (/ y (pow x 3))) (+ (* 2 (/ y (pow x 3))) (/ y (pow x 2)))))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* (pow x 3) y) |
(*.f64 y (pow.f64 x #s(literal 3 binary64))) |
(* (pow x 3) (+ y (/ y (pow x 3)))) |
(*.f64 (+.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) y) (pow.f64 x #s(literal 3 binary64))) |
(pow x 2) |
(*.f64 x x) |
(* (pow x 2) (- 1 (/ 1 x))) |
(*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) x)) x) x) |
(* (pow x 2) (- (+ 1 (/ 1 (pow x 2))) (/ 1 x))) |
(*.f64 (-.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal -1 binary64)) (/.f64 #s(literal 1 binary64) x)) (*.f64 x x)) |
(* -1 (* x (+ 1 (* -1 y)))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ y x)))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x)))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* -1 (* x (+ 1 (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x)))))) |
(*.f64 (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64)) x) |
(* -1 (* x (+ (* -1 y) (* -1 (/ y x))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (+ (* -1 (/ y x)) (/ y x)) (* -1 y)) x))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (* -1 (/ (- (* -1 (/ (+ y (* -1 y)) x)) (+ y (* -1 y))) x)) (* -1 y)) x))))) |
(*.f64 (+.f64 (/.f64 y x) y) x) |
(* -1 (* (pow x 3) (+ (* -1 y) (* -1 (/ y (pow x 3)))))) |
(*.f64 (+.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) y) (pow.f64 x #s(literal 3 binary64))) |
(* (pow x 2) (+ 1 (* -1 (/ (- 1 (/ 1 x)) x)))) |
(*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) x)) x)) x) x) |
(* -1 x) |
(neg.f64 x) |
(- (* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) x) |
(-.f64 (/.f64 (fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) (fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64))) x) |
(/ (* y (+ 1 (pow x 3))) (- (+ 1 (pow x 2)) x)) |
(/.f64 (fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) (fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64))) |
(* y (+ 1 (pow x 3))) |
(fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) |
(* y (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x)))) |
(/.f64 (fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) (fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64))) |
(* y (+ (* -1 (/ x y)) (+ (/ 1 (- (+ 1 (pow x 2)) x)) (/ (pow x 3) (- (+ 1 (pow x 2)) x))))) |
(*.f64 (-.f64 (/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64))) (/.f64 x y)) y) |
(* -1 (* y (+ (* -1 (/ (+ 1 (pow x 3)) (- (+ 1 (pow x 2)) x))) (/ x y)))) |
(*.f64 (-.f64 (/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64))) (/.f64 x y)) y) |
(* -1 (/ (* y (- (* -1 (pow x 3)) 1)) (- (+ 1 (pow x 2)) x))) |
(/.f64 (fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) (fma.f64 (-.f64 x #s(literal 1 binary64)) x #s(literal 1 binary64))) |
(* -1 (* y (- (* -1 (pow x 3)) 1))) |
(fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 19 | 59 |
| 0 | 25 | 58 |
| 1 | 136 | 33 |
| 0 | 1259 | 33 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x)) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
(pow.f64 x #s(literal 3 binary64)) |
(-.f64 (fma.f64 x x #s(literal 1 binary64)) x) |
| Outputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (*.f64 y (+.f64 #s(literal 1 binary64) x))) |
(*.f64 (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 x x))) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) |
(*.f64 (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)))) (+.f64 (fma.f64 x x #s(literal -1 binary64)) x)) |
(*.f64 (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)))) |
(*.f64 (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64)))) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64)))) |
(*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(*.f64 y (+.f64 #s(literal 1 binary64) x)) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (fma.f64 #s(literal -1 binary64) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (pow.f64 x #s(literal 6 binary64)))) |
(/.f64 (-.f64 (*.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) (-.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) #s(literal 3 binary64)) (pow.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) #s(literal 3 binary64))) (fma.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (-.f64 (*.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (*.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))))) |
(/.f64 (neg.f64 (neg.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y))) (neg.f64 (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) y) (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) y) (*.f64 (fma.f64 #s(literal -1 binary64) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (pow.f64 x #s(literal 6 binary64))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)) (*.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x)) y)) (*.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 (neg.f64 y) y)) (*.f64 (-.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 9 binary64)) (pow.f64 y #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 y (-.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y)) (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) |
(neg.f64 (/.f64 (neg.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(neg.f64 (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (neg.f64 (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(fma.f64 (/.f64 y (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 x x))) (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(fma.f64 (/.f64 y (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)))) (+.f64 (fma.f64 x x #s(literal -1 binary64)) x) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(fma.f64 (/.f64 y (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64))) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(fma.f64 (/.f64 y (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64)))) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64))) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(fma.f64 (/.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 x x))) (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(fma.f64 (/.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)))) (+.f64 (fma.f64 x x #s(literal -1 binary64)) x) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(fma.f64 (/.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(fma.f64 (/.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64)))) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(fma.f64 y (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(+.f64 (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x))))) |
(+.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) (/.f64 y (fma.f64 x x (-.f64 #s(literal 1 binary64) x)))) |
(*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64))) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64))) (fma.f64 #s(literal -1 binary64) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (pow.f64 x #s(literal 6 binary64)))) |
(/.f64 (-.f64 (*.f64 y y) (pow.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) #s(literal 2 binary64))) (-.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 (neg.f64 y) y))) (neg.f64 (-.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 x #s(literal 9 binary64)) (pow.f64 y #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 y (-.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1 binary64)) y) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 9 binary64)) #s(literal -1 binary64)) y) (fma.f64 #s(literal -1 binary64) (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) (pow.f64 x #s(literal 6 binary64)))) |
(/.f64 (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 (neg.f64 y) y)) (-.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y)) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 9 binary64)) (pow.f64 y #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y (-.f64 (pow.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) #s(literal 2 binary64)) (*.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y)))) |
(/.f64 (fma.f64 (pow.f64 x #s(literal 9 binary64)) (pow.f64 y #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 y (-.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))) |
(fma.f64 (*.f64 y (pow.f64 x #s(literal 3/2 binary64))) (pow.f64 x #s(literal 3/2 binary64)) y) |
(fma.f64 (*.f64 y (*.f64 x x)) x y) |
(fma.f64 (*.f64 y x) (*.f64 x x) y) |
(fma.f64 (pow.f64 x #s(literal 3/2 binary64)) (*.f64 (pow.f64 x #s(literal 3/2 binary64)) y) y) |
(fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) |
(fma.f64 (*.f64 x x) (*.f64 x y) y) |
(fma.f64 y (pow.f64 x #s(literal 3 binary64)) y) |
(fma.f64 x (*.f64 (*.f64 x x) y) y) |
(-.f64 (/.f64 (pow.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) #s(literal 2 binary64)) (-.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y)) (/.f64 (*.f64 y y) (-.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y))) |
(-.f64 y (*.f64 (neg.f64 (pow.f64 x #s(literal 3 binary64))) y)) |
(-.f64 y (*.f64 (neg.f64 y) (pow.f64 x #s(literal 3 binary64)))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) #s(literal 3 binary64)) (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 y (-.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (*.f64 y y) (pow.f64 x #s(literal 6 binary64)) (*.f64 y (-.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))))) |
(+.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) y) y) |
(+.f64 y (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) |
(*.f64 (*.f64 x (neg.f64 x)) (neg.f64 x)) |
(*.f64 (*.f64 x (fabs.f64 x)) (fabs.f64 x)) |
(*.f64 (neg.f64 (pow.f64 x #s(literal 3/2 binary64))) (neg.f64 (pow.f64 x #s(literal 3/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 x #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 x #s(literal 3/2 binary64)))) |
(*.f64 (pow.f64 x #s(literal 3/2 binary64)) (pow.f64 x #s(literal 3/2 binary64))) |
(*.f64 (neg.f64 x) (*.f64 (neg.f64 x) x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) x)) |
(*.f64 (*.f64 x x) x) |
(*.f64 x (*.f64 x x)) |
(pow.f64 (exp.f64 (log.f64 x)) #s(literal 3 binary64)) |
(pow.f64 (pow.f64 x #s(literal 3/2 binary64)) #s(literal 2 binary64)) |
(pow.f64 (*.f64 x x) #s(literal 3/2 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) (sinh.f64 (*.f64 (log.f64 x) #s(literal 3 binary64)))) |
(/.f64 (-.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)) (pow.f64 x #s(literal 4 binary64))) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (+.f64 (fma.f64 x x x) #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)))) (neg.f64 (+.f64 (fma.f64 x x #s(literal -1 binary64)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64))))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64)))) (neg.f64 (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64))))) |
(/.f64 (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 x x)) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64))) (+.f64 (fma.f64 x x #s(literal -1 binary64)) x)) |
(/.f64 (-.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)))) |
(/.f64 (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64))) (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)) (-.f64 (pow.f64 x #s(literal 4 binary64)) (*.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x))))) |
(/.f64 (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64)))) |
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1 binary64)) #s(literal -1 binary64) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (*.f64 (neg.f64 x) #s(literal -1 binary64)) (*.f64 (neg.f64 x) #s(literal -1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (*.f64 (fabs.f64 x) #s(literal -1 binary64)) (*.f64 (fabs.f64 x) #s(literal -1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (*.f64 x #s(literal -1 binary64)) (*.f64 x #s(literal -1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (neg.f64 x) (neg.f64 x) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 #s(literal 1 binary64) (*.f64 x x) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 (*.f64 x x) #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) x)) |
(fma.f64 x x (-.f64 #s(literal 1 binary64) x)) |
(-.f64 (/.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) (/.f64 (*.f64 x x) (+.f64 (fma.f64 x x x) #s(literal 1 binary64)))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 4 binary64)) (+.f64 (fma.f64 x x #s(literal -1 binary64)) x)) (/.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 2 binary64)) (+.f64 (fma.f64 x x #s(literal -1 binary64)) x))) |
(-.f64 (/.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 3 binary64)) (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 2 binary64))))) |
(-.f64 (fma.f64 x x #s(literal 1 binary64)) x) |
(-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 (neg.f64 (neg.f64 x)) (neg.f64 x))) |
(-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 (neg.f64 (fabs.f64 x)) (fabs.f64 x))) |
(-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 (neg.f64 x) x)) |
(-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x (neg.f64 x))) |
(-.f64 #s(literal 1 binary64) (-.f64 x (*.f64 x x))) |
(+.f64 (/.f64 (pow.f64 x #s(literal 6 binary64)) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64)))) (/.f64 (pow.f64 (-.f64 #s(literal 1 binary64) x) #s(literal 3 binary64)) (fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) (pow.f64 x #s(literal 4 binary64))))) |
(+.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x x)) |
(+.f64 #s(literal 1 binary64) (-.f64 (*.f64 x x) x)) |
(+.f64 (*.f64 x x) (-.f64 #s(literal 1 binary64) x)) |
Compiled 5 457 to 578 computations (89.4% saved)
8 alts after pruning (3 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 134 | 3 | 137 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 5 | 5 |
| Total | 135 | 8 | 143 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 73.8% | (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
| ✓ | 100.0% | (-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
| ✓ | 60.2% | (-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
| 48.2% | #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (*.f64 y (*.f64 x x)) x y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) | |
| 66.7% | #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) | |
| 27.6% | #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) | |
| ✓ | 60.2% | #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
| ✓ | 34.6% | #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
Compiled 380 to 167 computations (56.1% saved)
| Inputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
(-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (*.f64 y (*.f64 x x)) x y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) (/.f64 (fma.f64 (pow.f64 x #s(literal 3 binary64)) y y) (-.f64 (fma.f64 x x #s(literal 1 binary64)) x))) |
(-.f64 (/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 x x (-.f64 #s(literal 1 binary64) x))) x) |
| Outputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
3 calls:
| 12.0ms | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 3.0ms | y |
| 3.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 100.0% | 1 | x |
| 100.0% | 1 | y |
Compiled 9 to 10 computations (-11.1% saved)
| Inputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
| Outputs |
|---|
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
3 calls:
| 2.0ms | y |
| 2.0ms | x |
| 2.0ms | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| Accuracy | Segments | Branch |
|---|---|---|
| 91.3% | 3 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 98.9% | 3 | x |
| 98.5% | 3 | y |
Compiled 9 to 10 computations (-11.1% saved)
| Inputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
(-.f64 #s(approx (* (+ x 1) y) (*.f64 y x)) x) |
| Outputs |
|---|
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
#s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) |
3 calls:
| 2.0ms | x |
| 2.0ms | y |
| 2.0ms | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| Accuracy | Segments | Branch |
|---|---|---|
| 71.3% | 2 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 88.4% | 3 | y |
| 90.4% | 3 | x |
Compiled 9 to 10 computations (-11.1% saved)
| Inputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
| Outputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) |
2 calls:
| 2.0ms | y |
| 2.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 88.4% | 3 | y |
| 69.6% | 2 | x |
Compiled 2 to 4 computations (-100% saved)
| Inputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
| Outputs |
|---|
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
#s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) |
3 calls:
| 33.0ms | x |
| 1.0ms | y |
| 1.0ms | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| Accuracy | Segments | Branch |
|---|---|---|
| 38.2% | 2 | x |
| 50.5% | 3 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 58.8% | 3 | y |
Compiled 9 to 10 computations (-11.1% saved)
Total 0.0b remaining (0%)
Threshold costs 0b (0%)
| Inputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
| Outputs |
|---|
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
3 calls:
| 1.0ms | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 1.0ms | y |
| 1.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 34.6% | 1 | x |
| 34.6% | 1 | (-.f64 (*.f64 (+.f64 x #s(literal 1 binary64)) y) x) |
| 34.6% | 1 | y |
Compiled 9 to 10 computations (-11.1% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 11.0ms | 2.9906477932777394e-6 | 1001.7755838503765 |
| 16.0ms | -2416.0571827205617 | -5.8292287741782993e-5 |
| 12.0ms | 288× | 0 | valid |
Compiled 406 to 371 computations (8.6% saved)
ival-add: 2.0ms (36.2% of total)ival-mult: 2.0ms (36.2% of total)ival-sub: 1.0ms (18.1% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 21.0ms | 17747818750613028.0 | 7.352090912450396e+19 |
| 26.0ms | -5.8292287741782993e-5 | -2.032159504233436e-19 |
| 35.0ms | 288× | 0 | valid |
Compiled 928 to 605 computations (34.8% saved)
ival-add: 2.0ms (37% of total)ival-mult: 2.0ms (37% of total)ival-sub: 1.0ms (18.5% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 50.0ms | 4.189000159534821e-27 | 1.0486565350903754e-17 |
| 19.0ms | -5.702201451619498e-79 | -6.970330341344049e-86 |
| 53.0ms | 288× | 0 | valid |
Compiled 874 to 569 computations (34.9% saved)
ival-add: 3.0ms (32.2% of total)ival-mult: 3.0ms (32.2% of total)ival-sub: 2.0ms (21.4% of total)ival-assert: 1.0ms (10.7% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 23.0ms | 0.009370437176943747 | 0.042596190400089 |
| 15.0ms | -308.2847589629082 | -0.470654468652669 |
| 28.0ms | 224× | 0 | valid |
Compiled 668 to 445 computations (33.4% saved)
ival-add: 17.0ms (79.3% of total)ival-mult: 2.0ms (9.3% of total)ival-sub: 1.0ms (4.7% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 58 | 226 |
| 1 | 98 | 226 |
| 2 | 168 | 226 |
| 3 | 463 | 226 |
| 4 | 1541 | 226 |
| 5 | 6661 | 226 |
| 1× | node limit |
| Inputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) (if (<=.f64 x #s(literal 1 binary64)) (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)))) |
(if (<=.f64 x #s(literal -8318957063997755/19807040628566084398385987584 binary64)) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) (if (<=.f64 x #s(literal 18000000000000000 binary64)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)))) |
(if (<=.f64 y #s(literal -3827688768370271/34175792574734561318320347298712833833643272357706444319152665725155515612490248800367393390985216 binary64)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) (if (<=.f64 y #s(literal 6620178494631905/649037107316853453566312041152512 binary64)) #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))))) |
(if (<=.f64 y #s(literal -1 binary64)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) (if (<=.f64 y #s(literal 6052837899185947/144115188075855872 binary64)) #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))))) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
| Outputs |
|---|
(-.f64 #s(approx (* (+ x 1) y) (fma.f64 y x y)) x) |
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) (if (<=.f64 x #s(literal 1 binary64)) (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)))) |
(if (or (<=.f64 x #s(literal -1 binary64)) (not (<=.f64 x #s(literal 1 binary64)))) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) (-.f64 (*.f64 #s(approx (+ x 1) #s(literal 1 binary64)) y) x)) |
(if (<=.f64 x #s(literal -8318957063997755/19807040628566084398385987584 binary64)) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) (if (<=.f64 x #s(literal 18000000000000000 binary64)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)))) |
(if (or (<=.f64 x #s(literal -8318957063997755/19807040628566084398385987584 binary64)) (not (<=.f64 x #s(literal 18000000000000000 binary64)))) #s(approx (- (* (+ x 1) y) x) (*.f64 (-.f64 y #s(literal 1 binary64)) x)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y)))) |
(if (<=.f64 y #s(literal -3827688768370271/34175792574734561318320347298712833833643272357706444319152665725155515612490248800367393390985216 binary64)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) (if (<=.f64 y #s(literal 6620178494631905/649037107316853453566312041152512 binary64)) #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))))) |
(if (or (<=.f64 y #s(literal -3827688768370271/34175792574734561318320347298712833833643272357706444319152665725155515612490248800367393390985216 binary64)) (not (<=.f64 y #s(literal 6620178494631905/649037107316853453566312041152512 binary64)))) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (fma.f64 y x y))) #s(approx (- (* (+ x 1) y) x) (neg.f64 x))) |
(if (<=.f64 y #s(literal -1 binary64)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) (if (<=.f64 y #s(literal 6052837899185947/144115188075855872 binary64)) #s(approx (- (* (+ x 1) y) x) (neg.f64 x)) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))))) |
(if (or (<=.f64 y #s(literal -1 binary64)) (not (<=.f64 y #s(literal 6052837899185947/144115188075855872 binary64)))) #s(approx (- (/ (* (- (pow x 3) -1) y) (+ (* x x) (- 1 x))) x) #s(approx (/ (+ (* (pow x 3) y) y) (- (+ (* x x) 1) x)) (*.f64 y x))) #s(approx (- (* (+ x 1) y) x) (neg.f64 x))) |
#s(approx (- (* (+ x 1) y) x) (neg.f64 x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 126 | 300 |
| 1 | 456 | 292 |
| 2 | 1973 | 288 |
| 0 | 8171 | 270 |
| 0 | 6 | 15 |
| 0 | 9 | 15 |
| 1 | 37 | 15 |
| 0 | 279 | 15 |
| 0 | 144 | 364 |
| 1 | 504 | 354 |
| 2 | 2108 | 350 |
| 0 | 8177 | 330 |
| 0 | 41 | 86 |
| 1 | 147 | 86 |
| 2 | 516 | 86 |
| 3 | 1778 | 86 |
| 4 | 5823 | 86 |
| 0 | 8272 | 76 |
| 1× | fuel |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
Compiled 226 to 64 computations (71.7% saved)
Compiled 466 to 140 computations (70% saved)
Loading profile data...