
Time bar (total: 6.0s)
| 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 11 to 9 computations (18.2% saved)
| 2.8s | 8 256× | 0 | valid |
ival-sub: 2.0s (78.7% of total)exact: 308.0ms (11.9% of total)ival-mult: 238.0ms (9.2% of total)adjust: 3.0ms (0.1% of total)ival-assert: 3.0ms (0.1% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 10 | 0 | - | 0 | - | (-.f64 (*.f64 x x) (*.f64 x y)) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | y |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 0 | 0 | - | 0 | - | (*.f64 x x) |
| 0 | 0 | - | 0 | - | (*.f64 x y) |
| 0 | 0 | - | 0 | - | x |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
-.f64 | (-.f64 (*.f64 x x) (*.f64 x y)) | nan-rescue | 10 | 0 |
| ↳ | (*.f64 x x) | overflow | 60 | |
| ↳ | (*.f64 x y) | overflow | 29 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 10 | 0 |
| - | 0 | 246 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 10 | 0 | 0 |
| - | 0 | 0 | 246 |
| number | freq |
|---|---|
| 0 | 246 |
| 1 | 10 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 31.0ms | 512× | 0 | valid |
Compiled 63 to 25 computations (60.3% saved)
ival-mult: 13.0ms (78.5% of total)ival-sub: 2.0ms (12.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)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 22 | 46 |
| 1 | 74 | 42 |
| 2 | 277 | 42 |
| 3 | 1112 | 42 |
| 4 | 4746 | 42 |
| 5 | 7674 | 42 |
| 0 | 7 | 9 |
| 0 | 11 | 7 |
| 1 | 24 | 7 |
| 2 | 78 | 7 |
| 3 | 307 | 7 |
| 4 | 1275 | 7 |
| 5 | 4106 | 7 |
| 0 | 8191 | 7 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| Outputs |
|---|
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
(*.f64 (*.f64 #s(literal -2 binary64) x) (-.f64 y x)) |
Compiled 9 to 7 computations (22.2% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 96.1% | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
Compiled 9 to 7 computations (22.2% saved)
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 x y) | |
| cost-diff | 0 | (*.f64 x x) | |
| cost-diff | 0 | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) | |
| cost-diff | 2 | (-.f64 (*.f64 x x) (*.f64 x y)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 25 |
| 0 | 11 | 21 |
| 1 | 24 | 21 |
| 2 | 78 | 21 |
| 3 | 307 | 21 |
| 4 | 1275 | 21 |
| 5 | 4106 | 21 |
| 0 | 8191 | 21 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
#s(literal 2 binary64) |
(-.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 x x) |
x |
(*.f64 x y) |
y |
| Outputs |
|---|
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
(*.f64 (*.f64 #s(literal -2 binary64) x) (-.f64 y x)) |
#s(literal 2 binary64) |
(-.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 (-.f64 x y) x) |
(*.f64 x x) |
x |
(*.f64 x y) |
(*.f64 y x) |
y |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 x y) | |
| accuracy | 0.0 | (*.f64 x x) | |
| accuracy | 0.0 | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) | |
| accuracy | 2.1992104933208236 | (-.f64 (*.f64 x x) (*.f64 x y)) |
| 65.0ms | 256× | 0 | valid |
Compiled 27 to 9 computations (66.7% saved)
ival-mult: 31.0ms (94.6% of total)ival-sub: 1.0ms (3.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)| Inputs |
|---|
(-.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
(*.f64 x x) |
(*.f64 x y) |
| Outputs |
|---|
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* x y)))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* x (- x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x y) #s(hole binary64 (* x y))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (pow x 2))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ y x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (+ (* -1 (* x y)) (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* y (- (/ (pow x 2) y) x)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* y (- (* -1 (/ (pow x 2) y)) (* -1 x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | inf | ((- (* x x) (* x y)) (* 2 (- (* x x) (* x y))) (* x x) (* x y)) |
| 1.0ms | y | @ | inf | ((- (* x x) (* x y)) (* 2 (- (* x x) (* x y))) (* x x) (* x y)) |
| 1.0ms | x | @ | 0 | ((- (* x x) (* x y)) (* 2 (- (* x x) (* x y))) (* x x) (* x y)) |
| 1.0ms | x | @ | -inf | ((- (* x x) (* x y)) (* 2 (- (* x x) (* x y))) (* x x) (* x y)) |
| 1.0ms | y | @ | -inf | ((- (* x x) (* x y)) (* 2 (- (* x x) (* x y))) (* x x) (* x y)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 61 | 206 |
| 1 | 168 | 197 |
| 2 | 635 | 197 |
| 3 | 2655 | 197 |
| 4 | 6921 | 197 |
| 0 | 8156 | 196 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* x y)))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* x (- x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x y) #s(hole binary64 (* x y))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (pow x 2))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ y x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (+ (* -1 (* x y)) (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* y (- (/ (pow x 2) y) x)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* y (- (* -1 (/ (pow x 2) y)) (* -1 x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
| Outputs |
|---|
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* x y)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (neg.f64 y) x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* x (- x y)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (-.f64 y x) (*.f64 #s(literal -2 binary64) x))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x x) (*.f64 x x)) |
#s(approx (* x y) #s(hole binary64 (* x y))) |
#s(approx (* x y) (*.f64 y x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (pow x 2))) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ y x)))))) |
#s(approx (- (* x x) (* x y)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 y x)) x) x)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 x x) #s(literal 2 binary64))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (fma.f64 (/.f64 y x) #s(literal -2 binary64) #s(literal 2 binary64)) x) x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (+ (* -1 (* x y)) (pow x 2)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (-.f64 y x) (*.f64 #s(literal -2 binary64) x))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* y (- (/ (pow x 2) y) x)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (-.f64 y x) (*.f64 #s(literal -2 binary64) x))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* y (- (* -1 (/ (pow x 2) y)) (* -1 x)))))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (-.f64 y x) (*.f64 #s(literal -2 binary64) x))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 22 |
| 0 | 11 | 18 |
| 1 | 38 | 18 |
| 0 | 322 | 18 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
(*.f64 x x) |
(*.f64 x y) |
| Outputs |
|---|
(*.f64 (-.f64 x y) x) |
(*.f64 (neg.f64 x) (+.f64 (neg.f64 x) y)) |
(*.f64 x (-.f64 x y)) |
(/.f64 (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 (neg.f64 x) y) #s(literal 3 binary64))) (+.f64 (pow.f64 x #s(literal 4 binary64)) (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 x x) (*.f64 (neg.f64 x) y))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (neg.f64 (*.f64 x (+.f64 x y)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (*.f64 x (+.f64 x y))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64)))) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) (*.f64 (neg.f64 y) x)) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) (*.f64 (neg.f64 x) y)) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) (*.f64 (neg.f64 y) x)) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) (*.f64 (neg.f64 x) y)) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) (*.f64 (neg.f64 y) x)) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) (*.f64 (neg.f64 x) y)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) (*.f64 (neg.f64 y) x)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) (*.f64 (neg.f64 x) y)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) x (*.f64 (neg.f64 y) x)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) x (*.f64 (neg.f64 x) y)) |
(fma.f64 (neg.f64 x) (neg.f64 x) (*.f64 (neg.f64 y) x)) |
(fma.f64 (neg.f64 x) (neg.f64 x) (*.f64 (neg.f64 x) y)) |
(fma.f64 (neg.f64 x) y (*.f64 x x)) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) (*.f64 (neg.f64 y) x)) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) (*.f64 (neg.f64 x) y)) |
(fma.f64 y (neg.f64 x) (*.f64 x x)) |
(fma.f64 x x (*.f64 (neg.f64 y) x)) |
(fma.f64 x x (*.f64 (neg.f64 x) y)) |
(-.f64 (/.f64 (pow.f64 x #s(literal 4 binary64)) (*.f64 x (+.f64 x y))) (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x (+.f64 x y)))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 6 binary64)) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64)))) (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))))) |
(-.f64 (*.f64 x x) (*.f64 (neg.f64 (neg.f64 x)) y)) |
(-.f64 (*.f64 x x) (*.f64 y x)) |
(+.f64 (*.f64 (neg.f64 x) y) (*.f64 x x)) |
(+.f64 (*.f64 x x) (*.f64 (neg.f64 y) x)) |
(+.f64 (*.f64 x x) (*.f64 (neg.f64 x) y)) |
(*.f64 (*.f64 #s(literal 2 binary64) x) (-.f64 x y)) |
(*.f64 (-.f64 x y) (+.f64 x x)) |
(*.f64 #s(literal 2 binary64) (*.f64 (-.f64 x y) x)) |
(*.f64 (*.f64 (-.f64 x y) x) #s(literal 2 binary64)) |
(*.f64 x (*.f64 (-.f64 x y) #s(literal 2 binary64))) |
(*.f64 x (+.f64 (-.f64 x y) (-.f64 x y))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) #s(literal 2 binary64)) (*.f64 x (+.f64 x y))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) #s(literal 2 binary64)) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64)))) |
(/.f64 (*.f64 #s(literal 2 binary64) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (*.f64 x (+.f64 x y))) |
(/.f64 (*.f64 #s(literal 2 binary64) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64)))) |
(/.f64 (-.f64 (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x)) (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x))) (-.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 x y) x) #s(literal 3 binary64)) (pow.f64 (*.f64 (-.f64 x y) x) #s(literal 3 binary64))) (fma.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x) (-.f64 (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x)) (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x))))) |
(/.f64 (+.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (*.f64 x (+.f64 x y))) |
(/.f64 (+.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64)))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (*.f64 x (+.f64 x y)) (*.f64 (*.f64 x (+.f64 x y)) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) (*.f64 (*.f64 x (+.f64 x y)) (*.f64 x (+.f64 x y)))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))) (*.f64 (*.f64 x (+.f64 x y)) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))))) (*.f64 (*.f64 x (+.f64 x y)) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (*.f64 x (+.f64 x y)) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))) (*.f64 x (+.f64 x y)))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))))) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 x y)) (pow.f64 x #s(literal 4 binary64))))) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) x (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x) (*.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x))) |
(fma.f64 (-.f64 x y) x (*.f64 (-.f64 x y) x)) |
(fma.f64 (neg.f64 x) (+.f64 (neg.f64 x) y) (*.f64 (-.f64 x y) x)) |
(fma.f64 (neg.f64 x) (neg.f64 x) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 #s(literal 2 binary64) (*.f64 x x) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 x) y))) |
(fma.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64) (*.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64))) |
(fma.f64 (*.f64 x x) #s(literal 2 binary64) (*.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64))) |
(fma.f64 x (-.f64 x y) (*.f64 (-.f64 x y) x)) |
(fma.f64 x x (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(-.f64 (fma.f64 (-.f64 x y) x (*.f64 x x)) (*.f64 y x)) |
(-.f64 (*.f64 (-.f64 x y) x) (*.f64 (neg.f64 x) (-.f64 x y))) |
(-.f64 (*.f64 x x) (-.f64 (*.f64 y x) (*.f64 (-.f64 x y) x))) |
(+.f64 (fma.f64 (-.f64 x y) x (*.f64 x x)) (*.f64 (neg.f64 x) y)) |
(+.f64 (*.f64 (*.f64 x x) #s(literal 2 binary64)) (*.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64))) |
(+.f64 (*.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x)) (*.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x))) |
(+.f64 (*.f64 #s(literal 2 binary64) (*.f64 x x)) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 x) y))) |
(+.f64 (*.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64)) (*.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64))) |
(+.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x)) |
(+.f64 (*.f64 x x) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(*.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x))) |
(*.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x))) |
(*.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x))) |
(*.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64))) |
(*.f64 (pow.f64 x #s(literal 1 binary64)) x) |
(*.f64 (neg.f64 x) (neg.f64 x)) |
(*.f64 (fabs.f64 x) (fabs.f64 x)) |
(*.f64 x x) |
(pow.f64 (neg.f64 x) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 x) #s(literal 2 binary64)) |
(pow.f64 x #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 x) x)) |
(neg.f64 (*.f64 x (neg.f64 x))) |
(fabs.f64 (*.f64 x x)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 2 binary64))) |
(*.f64 y x) |
(*.f64 x y) |
Compiled 1 614 to 273 computations (83.1% saved)
4 alts after pruning (3 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 100 | 3 | 103 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 100 | 4 | 104 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 (-.f64 x y) (+.f64 x x)) |
| ✓ | 96.1% | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| ▶ | 58.4% | (*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
| ▶ | 58.4% | #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
Compiled 44 to 32 computations (27.3% saved)
Found 9 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (+.f64 x x) | |
| cost-diff | 0 | (-.f64 x y) | |
| cost-diff | 0 | (*.f64 (-.f64 x y) (+.f64 x x)) | |
| cost-diff | 0 | (*.f64 x x) | |
| cost-diff | 0 | #s(approx (- (* x x) (* x y)) (*.f64 x x)) | |
| cost-diff | 0 | (*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) | |
| cost-diff | 0 | (*.f64 y x) | |
| cost-diff | 0 | (*.f64 #s(literal -2 binary64) (*.f64 y x)) | |
| cost-diff | 0 | #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 70 |
| 0 | 24 | 64 |
| 1 | 46 | 64 |
| 2 | 113 | 64 |
| 3 | 357 | 64 |
| 4 | 1386 | 64 |
| 5 | 4330 | 64 |
| 0 | 8232 | 64 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 #s(literal -2 binary64) (*.f64 y x)) |
#s(literal -2 binary64) |
(*.f64 y x) |
y |
x |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
#s(literal 2 binary64) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
(*.f64 x x) |
x |
(*.f64 (-.f64 x y) (+.f64 x x)) |
(-.f64 x y) |
x |
y |
(+.f64 x x) |
| Outputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 #s(literal -2 binary64) y) x)) |
(*.f64 #s(literal -2 binary64) (*.f64 y x)) |
(*.f64 (*.f64 #s(literal -2 binary64) y) x) |
#s(literal -2 binary64) |
(*.f64 y x) |
y |
x |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
(*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 2 binary64)) |
#s(literal 2 binary64) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
(*.f64 x x) |
x |
(*.f64 (-.f64 x y) (+.f64 x x)) |
(*.f64 (*.f64 #s(literal -2 binary64) x) (-.f64 y x)) |
(-.f64 x y) |
x |
y |
(+.f64 x x) |
(*.f64 x #s(literal 2 binary64)) |
Found 9 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (-.f64 x y) | |
| accuracy | 0.0 | (+.f64 x x) | |
| accuracy | 0.00390625 | (*.f64 (-.f64 x y) (+.f64 x x)) | |
| accuracy | 0.0 | (*.f64 x x) | |
| accuracy | 0.0 | (*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) | |
| accuracy | 26.629501778672857 | #s(approx (- (* x x) (* x y)) (*.f64 x x)) | |
| accuracy | 0.0 | (*.f64 y x) | |
| accuracy | 0.00390625 | (*.f64 #s(literal -2 binary64) (*.f64 y x)) | |
| accuracy | 26.638039534443408 | #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
| 37.0ms | 256× | 0 | valid |
Compiled 58 to 15 computations (74.1% saved)
ival-sub: 16.0ms (58% of total)ival-mult: 10.0ms (36.2% of total)ival-add: 1.0ms (3.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 |
|---|
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 #s(literal -2 binary64) (*.f64 y x)) |
(*.f64 y x) |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
(*.f64 x x) |
(*.f64 (-.f64 x y) (+.f64 x x)) |
(-.f64 x y) |
(+.f64 x x) |
| Outputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* -2 (* y x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* y x) #s(hole binary64 (* x y))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* x y)))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* x (- x y)))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (+ x x) #s(hole binary64 (* 2 x))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (pow x 2))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ y x)))))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (+ (* -1 (* x y)) (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* y (- (/ (pow x 2) y) x)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* y (- (* -1 (/ (pow x 2) y)) (* -1 x)))))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | y | @ | inf | ((* 2 (- (* x x) (* x y))) (* -2 (* y x)) (* y x) (* 2 (- (* x x) (* x y))) (- (* x x) (* x y)) (* x x) (* (- x y) (+ x x)) (- x y) (+ x x)) |
| 2.0ms | x | @ | -inf | ((* 2 (- (* x x) (* x y))) (* -2 (* y x)) (* y x) (* 2 (- (* x x) (* x y))) (- (* x x) (* x y)) (* x x) (* (- x y) (+ x x)) (- x y) (+ x x)) |
| 2.0ms | x | @ | inf | ((* 2 (- (* x x) (* x y))) (* -2 (* y x)) (* y x) (* 2 (- (* x x) (* x y))) (- (* x x) (* x y)) (* x x) (* (- x y) (+ x x)) (- x y) (+ x x)) |
| 1.0ms | x | @ | 0 | ((* 2 (- (* x x) (* x y))) (* -2 (* y x)) (* y x) (* 2 (- (* x x) (* x y))) (- (* x x) (* x y)) (* x x) (* (- x y) (+ x x)) (- x y) (+ x x)) |
| 1.0ms | y | @ | -inf | ((* 2 (- (* x x) (* x y))) (* -2 (* y x)) (* y x) (* 2 (- (* x x) (* x y))) (- (* x x) (* x y)) (* x x) (* (- x y) (+ x x)) (- x y) (+ x x)) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 95 | 381 |
| 1 | 239 | 361 |
| 2 | 785 | 361 |
| 3 | 3133 | 361 |
| 4 | 6492 | 361 |
| 0 | 8039 | 361 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* -2 (* y x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* y x) #s(hole binary64 (* x y))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* x y)))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* x (- x y)))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (+ x x) #s(hole binary64 (* 2 x))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (pow x 2))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ y x)))))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (+ (* -1 (* x y)) (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* y (- (/ (pow x 2) y) x)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* y (- (* -1 (/ (pow x 2) y)) (* -1 x)))))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
| Outputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (* -2 (* y x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* -2 (* y x)) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
#s(approx (* y x) #s(hole binary64 (* x y))) |
#s(approx (* y x) (*.f64 y x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* x y)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (neg.f64 x) y)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* x (- x y)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x x) (*.f64 x x)) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) (neg.f64 y)) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (+ x x) #s(hole binary64 (* 2 x))) |
#s(approx (+ x x) (*.f64 x #s(literal 2 binary64))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 x x) #s(literal 2 binary64))) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (pow x 2))) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ y x)))))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 x x) #s(literal 2 binary64))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) x) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (+ (* -1 (* x y)) (pow x 2)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* y (- (/ (pow x 2) y) x)))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* 2 (- (* x x) (* x y))) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- (* x x) (* x y)) #s(hole binary64 (* -1 (* y (- (* -1 (/ (pow x 2) y)) (* -1 x)))))) |
#s(approx (- (* x x) (* x y)) (*.f64 (-.f64 x y) x)) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 (*.f64 (-.f64 y x) #s(literal -2 binary64)) x)) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
#s(approx (- x y) (-.f64 x y)) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 63 |
| 0 | 24 | 57 |
| 1 | 77 | 51 |
| 0 | 619 | 51 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 #s(literal -2 binary64) (*.f64 y x)) |
(*.f64 y x) |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
(*.f64 x x) |
(*.f64 (-.f64 x y) (+.f64 x x)) |
(-.f64 x y) |
(+.f64 x x) |
| Outputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 (*.f64 #s(literal -2 binary64) x) y) |
(*.f64 (*.f64 #s(literal -2 binary64) y) x) |
(*.f64 #s(literal -2 binary64) (*.f64 y x)) |
(*.f64 (*.f64 y x) #s(literal -2 binary64)) |
(*.f64 y (*.f64 x #s(literal -2 binary64))) |
(*.f64 x (*.f64 #s(literal -2 binary64) y)) |
(*.f64 y x) |
(*.f64 x y) |
(*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
(/.f64 (-.f64 (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x))) (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x)))) (-.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x)))) |
(/.f64 (+.f64 (pow.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 3 binary64)) (pow.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 3 binary64))) (fma.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x)) (-.f64 (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x))) (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x)))))) |
(fma.f64 #s(literal 1 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x)) (*.f64 #s(literal 1 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x)))) |
(fma.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 1 binary64) (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 1 binary64))) |
(+.f64 (*.f64 #s(literal 1 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) (*.f64 #s(literal 1 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x)))) |
(+.f64 (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 1 binary64)) (*.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(literal 1 binary64))) |
(+.f64 #s(approx (- (* x x) (* x y)) (*.f64 x x)) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
#s(approx (- (* x x) (* x y)) (*.f64 x x)) |
(*.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x))) |
(*.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x))) |
(*.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x))) |
(*.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64))) |
(*.f64 (pow.f64 x #s(literal 1 binary64)) x) |
(*.f64 (neg.f64 x) (neg.f64 x)) |
(*.f64 (fabs.f64 x) (fabs.f64 x)) |
(*.f64 x x) |
(pow.f64 (neg.f64 x) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 x) #s(literal 2 binary64)) |
(pow.f64 x #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 x) x)) |
(neg.f64 (*.f64 x (neg.f64 x))) |
(fabs.f64 (*.f64 x x)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 2 binary64))) |
(*.f64 (*.f64 (-.f64 x y) #s(literal 2 binary64)) x) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
(*.f64 (*.f64 (-.f64 x y) x) #s(literal 2 binary64)) |
(*.f64 x (*.f64 (-.f64 x y) #s(literal 2 binary64))) |
(*.f64 x (+.f64 (-.f64 x y) (-.f64 x y))) |
(*.f64 #s(literal 2 binary64) (-.f64 x y)) |
(*.f64 #s(literal 2 binary64) (*.f64 (-.f64 x y) x)) |
(/.f64 (*.f64 #s(literal 0 binary64) (-.f64 x y)) #s(literal 0 binary64)) |
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64))) (-.f64 x y)) (fma.f64 x x #s(literal 0 binary64))) |
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) #s(literal 2 binary64)) (+.f64 y x)) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 2 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) #s(literal 2 binary64)) (*.f64 x (+.f64 y x))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) #s(literal 2 binary64)) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64)))) |
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 (+.f64 y x) (-.f64 x y))) (+.f64 y x)) |
(/.f64 (*.f64 #s(literal 2 binary64) (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y (+.f64 y x) (*.f64 x x))) |
(/.f64 (*.f64 (-.f64 x y) #s(literal 0 binary64)) #s(literal 0 binary64)) |
(/.f64 (*.f64 (-.f64 x y) (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 x x #s(literal 0 binary64))) |
(/.f64 (*.f64 #s(literal 2 binary64) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (*.f64 x (+.f64 y x))) |
(/.f64 (*.f64 #s(literal 2 binary64) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64)))) |
(/.f64 (-.f64 (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x)) (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x))) (-.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 x y) x) #s(literal 3 binary64)) (pow.f64 (*.f64 (-.f64 x y) x) #s(literal 3 binary64))) (fma.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x) (-.f64 (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x)) (*.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x))))) |
(/.f64 (+.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (*.f64 x (+.f64 y x))) |
(/.f64 (+.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64)))) |
(/.f64 (*.f64 #s(literal 0 binary64) (*.f64 (+.f64 y x) (-.f64 x y))) (*.f64 #s(literal 0 binary64) (+.f64 y x))) |
(/.f64 (*.f64 #s(literal 0 binary64) (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (*.f64 #s(literal 0 binary64) (fma.f64 y (+.f64 y x) (*.f64 x x)))) |
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64))) (*.f64 (+.f64 y x) (-.f64 x y))) (*.f64 (fma.f64 x x #s(literal 0 binary64)) (+.f64 y x))) |
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64))) (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (*.f64 (fma.f64 x x #s(literal 0 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x)))) |
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) #s(literal 0 binary64)) (*.f64 (+.f64 y x) #s(literal 0 binary64))) |
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 (+.f64 y x) (fma.f64 x x #s(literal 0 binary64)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 0 binary64)) (*.f64 (fma.f64 y (+.f64 y x) (*.f64 x x)) #s(literal 0 binary64))) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 (fma.f64 y (+.f64 y x) (*.f64 x x)) (fma.f64 x x #s(literal 0 binary64)))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (*.f64 x (+.f64 y x)) (*.f64 (*.f64 x (+.f64 y x)) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) (*.f64 (*.f64 x (+.f64 y x)) (*.f64 x (+.f64 y x)))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))) (*.f64 (*.f64 x (+.f64 y x)) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))))) (*.f64 (*.f64 x (+.f64 y x)) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (*.f64 x (+.f64 y x)) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))) (-.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))) (*.f64 x (+.f64 y x)))) |
(/.f64 (fma.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))) (-.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))))) (*.f64 (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))) (fma.f64 (*.f64 y x) (*.f64 x (+.f64 y x)) (pow.f64 x #s(literal 4 binary64))))) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) x (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x) (*.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x))) |
(fma.f64 (neg.f64 x) (+.f64 (neg.f64 x) y) (*.f64 (-.f64 x y) x)) |
(fma.f64 (neg.f64 x) (neg.f64 x) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 (-.f64 x y) x (*.f64 (-.f64 x y) x)) |
(fma.f64 (*.f64 x x) #s(literal 2 binary64) (*.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64))) |
(fma.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64) (*.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64))) |
(fma.f64 x (-.f64 x y) (*.f64 (-.f64 x y) x)) |
(fma.f64 x x (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(fma.f64 #s(literal 2 binary64) (*.f64 x x) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 x) y))) |
(-.f64 (fma.f64 (-.f64 x y) x (*.f64 x x)) (*.f64 y x)) |
(-.f64 (*.f64 x x) (-.f64 (*.f64 y x) (*.f64 (-.f64 x y) x))) |
(-.f64 (*.f64 (-.f64 x y) x) (*.f64 (neg.f64 (-.f64 x y)) x)) |
(-.f64 (*.f64 (-.f64 x y) x) (*.f64 (neg.f64 x) (-.f64 x y))) |
(+.f64 (fma.f64 (-.f64 x y) x (*.f64 x x)) (*.f64 (neg.f64 x) y)) |
(+.f64 (*.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x)) (*.f64 #s(literal 1 binary64) (*.f64 (-.f64 x y) x))) |
(+.f64 (*.f64 (*.f64 x x) #s(literal 2 binary64)) (*.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64))) |
(+.f64 (*.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64)) (*.f64 (*.f64 (-.f64 x y) x) #s(literal 1 binary64))) |
(+.f64 (*.f64 #s(literal 2 binary64) (*.f64 x x)) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 x) y))) |
(+.f64 (*.f64 x x) (fma.f64 (neg.f64 x) y (*.f64 (-.f64 x y) x))) |
(+.f64 (*.f64 (-.f64 x y) x) (*.f64 (-.f64 x y) x)) |
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 x y))) (neg.f64 (+.f64 y x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (+.f64 y x) (*.f64 x x)))) |
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (+.f64 y x)) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (+.f64 y x) (*.f64 x x))) |
(-.f64 (/.f64 (*.f64 x x) (+.f64 y x)) (/.f64 (*.f64 y y) (+.f64 y x))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x)))) |
(-.f64 x y) |
#s(literal 2 binary64) |
Compiled 2 098 to 301 computations (85.7% saved)
5 alts after pruning (2 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 112 | 2 | 114 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 2 | 3 |
| Done | 0 | 1 | 1 |
| Total | 113 | 5 | 118 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 x y) (+.f64 x x)) |
| ▶ | 3.6% | (*.f64 (-.f64 x y) #s(literal 2 binary64)) |
| ▶ | 58.4% | (*.f64 #s(approx (- x y) x) (+.f64 x x)) |
| ✓ | 96.1% | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| ✓ | 58.4% | #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
Compiled 45 to 34 computations (24.4% saved)
Found 5 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (-.f64 x y) | |
| cost-diff | 0 | (*.f64 (-.f64 x y) #s(literal 2 binary64)) | |
| cost-diff | 0 | (+.f64 x x) | |
| cost-diff | 0 | #s(approx (- x y) x) | |
| cost-diff | 0 | (*.f64 #s(approx (- x y) x) (+.f64 x x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 29 |
| 0 | 13 | 29 |
| 1 | 22 | 29 |
| 2 | 44 | 29 |
| 3 | 96 | 29 |
| 4 | 221 | 29 |
| 5 | 869 | 29 |
| 6 | 4624 | 29 |
| 0 | 9216 | 29 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
#s(approx (- x y) x) |
x |
(+.f64 x x) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
(-.f64 x y) |
x |
y |
#s(literal 2 binary64) |
| Outputs |
|---|
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
(*.f64 (*.f64 #s(literal 2 binary64) #s(approx (- x y) x)) x) |
#s(approx (- x y) x) |
x |
(+.f64 x x) |
(*.f64 #s(literal 2 binary64) x) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) (-.f64 x y)) |
(-.f64 x y) |
x |
y |
#s(literal 2 binary64) |
Found 5 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (-.f64 x y) | |
| accuracy | 0.0 | (*.f64 (-.f64 x y) #s(literal 2 binary64)) | |
| accuracy | 0.0 | (+.f64 x x) | |
| accuracy | 0.00390625 | (*.f64 #s(approx (- x y) x) (+.f64 x x)) | |
| accuracy | 32.05479331720543 | #s(approx (- x y) x) |
| 17.0ms | 256× | 0 | valid |
Compiled 27 to 9 computations (66.7% saved)
ival-mult: 3.0ms (43.7% of total)ival-sub: 2.0ms (29.1% of total)ival-add: 1.0ms (14.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 #s(approx (- x y) x) (+.f64 x x)) |
#s(approx (- x y) x) |
(+.f64 x x) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
(-.f64 x y) |
| Outputs |
|---|
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (+ x x) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -2 y))) |
#s(approx (* (- x y) 2) #s(hole binary64 (+ (* -2 y) (* 2 x)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* x (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* x (- (* 2 (/ y x)) 2))))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* y (- (* 2 (/ x y)) 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* y (+ 2 (* -2 (/ x y))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | ((* (- x y) (+ x x)) (- x y) (+ x x) (* (- x y) 2) (- x y)) |
| 1.0ms | x | @ | inf | ((* (- x y) (+ x x)) (- x y) (+ x x) (* (- x y) 2) (- x y)) |
| 1.0ms | x | @ | 0 | ((* (- x y) (+ x x)) (- x y) (+ x x) (* (- x y) 2) (- x y)) |
| 1.0ms | y | @ | inf | ((* (- x y) (+ x x)) (- x y) (+ x x) (* (- x y) 2) (- x y)) |
| 0.0ms | y | @ | -inf | ((* (- x y) (+ x x)) (- x y) (+ x x) (* (- x y) 2) (- x y)) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 82 | 254 |
| 1 | 223 | 234 |
| 2 | 706 | 234 |
| 3 | 2479 | 234 |
| 4 | 6429 | 234 |
| 0 | 8154 | 234 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (+ x x) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -2 y))) |
#s(approx (* (- x y) 2) #s(hole binary64 (+ (* -2 y) (* 2 x)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* x (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* x (- (* 2 (/ y x)) 2))))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* y (- (* 2 (/ x y)) 2)))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* y (+ 2 (* -2 (/ x y))))))) |
| Outputs |
|---|
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -2 (* x y)))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 y x) #s(literal -2 binary64))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* x (+ (* -2 y) (* 2 x))))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 (-.f64 y x) x) #s(literal -2 binary64))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) (neg.f64 y)) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (+ x x) #s(hole binary64 (* 2 x))) |
#s(approx (+ x x) (*.f64 #s(literal 2 binary64) x)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -2 y))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (+ (* -2 y) (* 2 x)))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* 2 (pow x 2)))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 x x) #s(literal 2 binary64))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* (pow x 2) (+ 2 (* -2 (/ y x)))))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 (-.f64 y x) x) #s(literal -2 binary64))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) x) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) x)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* x (+ 2 (* -2 (/ y x)))))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* x (- (* 2 (/ y x)) 2))))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (+ (* -2 (* x y)) (* 2 (pow x 2))))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 (-.f64 y x) x) #s(literal -2 binary64))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* y (+ (* -2 x) (* 2 (/ (pow x 2) y)))))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 (-.f64 y x) x) #s(literal -2 binary64))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* y (- (* 2 (/ x y)) 2)))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (* (- x y) (+ x x)) #s(hole binary64 (* -1 (* y (+ (* -2 (/ (pow x 2) y)) (* 2 x)))))) |
#s(approx (* (- x y) (+ x x)) (*.f64 (*.f64 (-.f64 y x) x) #s(literal -2 binary64))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* y (+ 2 (* -2 (/ x y))))))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 25 |
| 0 | 13 | 25 |
| 1 | 41 | 21 |
| 0 | 264 | 21 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
#s(approx (- x y) x) |
(+.f64 x x) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
(-.f64 x y) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 2 binary64) #s(approx (- x y) x)) x) |
(*.f64 #s(literal 2 binary64) (*.f64 #s(approx (- x y) x) x)) |
(*.f64 #s(literal 2 binary64) #s(approx (- x y) x)) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
(*.f64 x (+.f64 #s(approx (- x y) x) #s(approx (- x y) x))) |
(/.f64 (*.f64 #s(literal 0 binary64) #s(approx (- x y) x)) #s(literal 0 binary64)) |
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64))) #s(approx (- x y) x)) (fma.f64 x x #s(literal 0 binary64))) |
(/.f64 (*.f64 #s(approx (- x y) x) #s(literal 0 binary64)) #s(literal 0 binary64)) |
(/.f64 (*.f64 #s(approx (- x y) x) (*.f64 #s(literal 2 binary64) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 x x #s(literal 0 binary64))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x)) (*.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x))) (-.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(approx (- x y) x) x) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(approx (- x y) x) x) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x) (-.f64 (*.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x)) (*.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x))))) |
(fma.f64 #s(approx (- x y) x) x (*.f64 #s(approx (- x y) x) x)) |
(fma.f64 x #s(approx (- x y) x) (*.f64 #s(approx (- x y) x) x)) |
(-.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 (neg.f64 x) #s(approx (- x y) x))) |
(-.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 (neg.f64 #s(approx (- x y) x)) x)) |
(+.f64 (*.f64 #s(approx (- x y) x) x) (*.f64 #s(approx (- x y) x) x)) |
#s(approx (- x y) x) |
#s(literal 2 binary64) |
(*.f64 #s(literal 2 binary64) (-.f64 x y)) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) #s(literal 2 binary64)) (+.f64 y x)) |
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 2 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x))) |
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 (+.f64 y x) (-.f64 x y))) (+.f64 y x)) |
(/.f64 (*.f64 #s(literal 2 binary64) (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y (+.f64 y x) (*.f64 x x))) |
(fma.f64 #s(literal 1 binary64) (-.f64 x y) (*.f64 #s(literal 1 binary64) (-.f64 x y))) |
(fma.f64 (-.f64 x y) #s(literal 1 binary64) (*.f64 (-.f64 x y) #s(literal 1 binary64))) |
(+.f64 (*.f64 #s(literal 1 binary64) (-.f64 x y)) (*.f64 #s(literal 1 binary64) (-.f64 x y))) |
(+.f64 (*.f64 (-.f64 x y) #s(literal 1 binary64)) (*.f64 (-.f64 x y) #s(literal 1 binary64))) |
(+.f64 (-.f64 x y) (-.f64 x y)) |
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 x y))) (neg.f64 (+.f64 y x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (+.f64 y x) (*.f64 x x)))) |
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (+.f64 y x)) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (+.f64 y x) (*.f64 x x))) |
(-.f64 (/.f64 (*.f64 x x) (+.f64 y x)) (/.f64 (*.f64 y y) (+.f64 y x))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (+.f64 y x) (*.f64 x x)))) |
(-.f64 x y) |
Compiled 639 to 116 computations (81.8% saved)
6 alts after pruning (2 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 43 | 2 | 45 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 1 | 2 |
| Done | 0 | 3 | 3 |
| Total | 44 | 6 | 50 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 x y) (+.f64 x x)) |
| ✓ | 58.4% | (*.f64 #s(approx (- x y) x) (+.f64 x x)) |
| ▶ | 3.8% | (*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
| ✓ | 96.1% | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| ▶ | 3.4% | #s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
| ✓ | 58.4% | #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
Compiled 56 to 43 computations (23.2% saved)
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | #s(approx (- x y) x) | |
| cost-diff | 0 | (*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) | |
| cost-diff | 0 | (*.f64 #s(literal -2 binary64) y) | |
| cost-diff | 0 | #s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 28 |
| 0 | 12 | 28 |
| 1 | 17 | 28 |
| 2 | 30 | 28 |
| 3 | 63 | 28 |
| 4 | 127 | 28 |
| 5 | 484 | 28 |
| 6 | 3514 | 28 |
| 0 | 8217 | 28 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(literal -2 binary64) y) |
#s(literal -2 binary64) |
y |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
#s(approx (- x y) x) |
x |
#s(literal 2 binary64) |
| Outputs |
|---|
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(literal -2 binary64) y) |
#s(literal -2 binary64) |
y |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
#s(approx (- x y) x) |
x |
#s(literal 2 binary64) |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) | |
| accuracy | 32.05479331720543 | #s(approx (- x y) x) | |
| accuracy | 0.0 | (*.f64 #s(literal -2 binary64) y) | |
| accuracy | 31.02532369976096 | #s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
| 15.0ms | 256× | 0 | valid |
Compiled 22 to 9 computations (59.1% saved)
ival-mult: 3.0ms (53.2% of total)ival-sub: 2.0ms (35.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)| Inputs |
|---|
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(literal -2 binary64) y) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
#s(approx (- x y) x) |
| Outputs |
|---|
#s(approx (* (- x y) 2) #s(hole binary64 (* -2 y))) |
#s(approx (* (- x y) 2) #s(hole binary64 (+ (* -2 y) (* 2 x)))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* x (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* x (- (* 2 (/ y x)) 2))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (* -2 y) #s(hole binary64 (* -2 y))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* y (- (* 2 (/ x y)) 2)))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* y (+ 2 (* -2 (/ x y))))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | inf | ((* (- x y) 2) (* -2 y) (* (- x y) 2) (- x y)) |
| 0.0ms | y | @ | -inf | ((* (- x y) 2) (* -2 y) (* (- x y) 2) (- x y)) |
| 0.0ms | y | @ | 0 | ((* (- x y) 2) (* -2 y) (* (- x y) 2) (- x y)) |
| 0.0ms | x | @ | -inf | ((* (- x y) 2) (* -2 y) (* (- x y) 2) (- x y)) |
| 0.0ms | x | @ | inf | ((* (- x y) 2) (* -2 y) (* (- x y) 2) (- x y)) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 57 | 143 |
| 1 | 144 | 133 |
| 2 | 436 | 133 |
| 3 | 1396 | 133 |
| 4 | 5731 | 133 |
| 0 | 8163 | 133 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (* (- x y) 2) #s(hole binary64 (* -2 y))) |
#s(approx (* (- x y) 2) #s(hole binary64 (+ (* -2 y) (* 2 x)))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* x (+ 2 (* -2 (/ y x)))))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* x (- (* 2 (/ y x)) 2))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (* -2 y) #s(hole binary64 (* -2 y))) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* y (- (* 2 (/ x y)) 2)))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* y (+ 2 (* -2 (/ x y))))))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
| Outputs |
|---|
#s(approx (* (- x y) 2) #s(hole binary64 (* -2 y))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (+ (* -2 y) (* 2 x)))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (- x y) #s(hole binary64 (* -1 y))) |
#s(approx (- x y) (neg.f64 y)) |
#s(approx (- x y) #s(hole binary64 (- x y))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* 2 x))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) x)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* x (+ 2 (* -2 (/ y x)))))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (- x y) #s(hole binary64 x)) |
#s(approx (- x y) x) |
#s(approx (- x y) #s(hole binary64 (* x (+ 1 (* -1 (/ y x)))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* x (- (* 2 (/ y x)) 2))))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* x (- (/ y x) 1))))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* -2 y) #s(hole binary64 (* -2 y))) |
#s(approx (* -2 y) (*.f64 #s(literal -2 binary64) y)) |
#s(approx (- x y) #s(hole binary64 (+ x (* -1 y)))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* y (- (* 2 (/ x y)) 2)))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (- x y) #s(hole binary64 (* y (- (/ x y) 1)))) |
#s(approx (- x y) (-.f64 x y)) |
#s(approx (* (- x y) 2) #s(hole binary64 (* -1 (* y (+ 2 (* -2 (/ x y))))))) |
#s(approx (* (- x y) 2) (*.f64 #s(literal 2 binary64) (-.f64 x y))) |
#s(approx (- x y) #s(hole binary64 (* -1 (* y (+ 1 (* -1 (/ x y))))))) |
#s(approx (- x y) (-.f64 x y)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 24 |
| 0 | 12 | 24 |
| 1 | 30 | 24 |
| 0 | 156 | 24 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(literal -2 binary64) y) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
#s(approx (- x y) x) |
| Outputs |
|---|
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(literal -2 binary64) y) |
(*.f64 y #s(literal -2 binary64)) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) #s(approx (- x y) x)) |
(fma.f64 #s(literal 1 binary64) #s(approx (- x y) x) (*.f64 #s(literal 1 binary64) #s(approx (- x y) x))) |
(fma.f64 #s(approx (- x y) x) #s(literal 1 binary64) (*.f64 #s(approx (- x y) x) #s(literal 1 binary64))) |
(+.f64 (*.f64 #s(literal 1 binary64) #s(approx (- x y) x)) (*.f64 #s(literal 1 binary64) #s(approx (- x y) x))) |
(+.f64 (*.f64 #s(approx (- x y) x) #s(literal 1 binary64)) (*.f64 #s(approx (- x y) x) #s(literal 1 binary64))) |
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
#s(approx (- x y) x) |
Compiled 167 to 36 computations (78.4% saved)
6 alts after pruning (1 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 15 | 1 | 16 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 1 | 2 |
| Done | 0 | 4 | 4 |
| Total | 16 | 6 | 22 |
| Status | Accuracy | Program |
|---|---|---|
| 3.8% | (+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) | |
| ✓ | 100.0% | (*.f64 (-.f64 x y) (+.f64 x x)) |
| ✓ | 58.4% | (*.f64 #s(approx (- x y) x) (+.f64 x x)) |
| ✓ | 96.1% | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| ✓ | 3.4% | #s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
| ✓ | 58.4% | #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
Compiled 145 to 72 computations (50.3% saved)
| Inputs |
|---|
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
(*.f64 (-.f64 x y) (+.f64 x x)) |
(*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| Outputs |
|---|
(*.f64 (-.f64 x y) (+.f64 x x)) |
4 calls:
| 3.0ms | y |
| 3.0ms | x |
| 3.0ms | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 3.0ms | (-.f64 (*.f64 x x) (*.f64 x y)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (-.f64 (*.f64 x x) (*.f64 x y)) |
| 100.0% | 1 | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 100.0% | 1 | x |
| 100.0% | 1 | y |
Compiled 18 to 16 computations (11.1% saved)
| Inputs |
|---|
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 #s(literal 2 binary64) #s(approx (- (* x x) (* x y)) (*.f64 x x))) |
| Outputs |
|---|
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
#s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) |
4 calls:
| 29.0ms | y |
| 3.0ms | x |
| 2.0ms | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 2.0ms | (-.f64 (*.f64 x x) (*.f64 x y)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 81.5% | 2 | (-.f64 (*.f64 x x) (*.f64 x y)) |
| 81.5% | 2 | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 84.2% | 3 | x |
| 86.2% | 3 | y |
Compiled 18 to 16 computations (11.1% saved)
| Inputs |
|---|
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
(*.f64 (-.f64 x y) #s(literal 2 binary64)) |
| Outputs |
|---|
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
4 calls:
| 6.0ms | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 2.0ms | y |
| 2.0ms | x |
| 2.0ms | (-.f64 (*.f64 x x) (*.f64 x y)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 58.4% | 1 | (-.f64 (*.f64 x x) (*.f64 x y)) |
| 58.4% | 1 | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 58.4% | 1 | x |
| 58.4% | 1 | y |
Compiled 18 to 16 computations (11.1% saved)
Total -1.1b remaining (-1.7%)
Threshold costs -1.1b (-1.7%)
| Inputs |
|---|
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
#s(approx (* (- x y) 2) (*.f64 #s(literal -2 binary64) y)) |
(*.f64 #s(approx (- x y) x) #s(literal 2 binary64)) |
| Outputs |
|---|
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
4 calls:
| 2.0ms | y |
| 1.0ms | x |
| 1.0ms | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 1.0ms | (-.f64 (*.f64 x x) (*.f64 x y)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 3.8% | 1 | x |
| 3.8% | 1 | (-.f64 (*.f64 x x) (*.f64 x y)) |
| 3.8% | 1 | (*.f64 #s(literal 2 binary64) (-.f64 (*.f64 x x) (*.f64 x y))) |
| 3.8% | 1 | y |
Compiled 18 to 16 computations (11.1% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 12.0ms | 0.006229499371052224 | 38133.571463955464 |
| 16.0ms | -4.40936373431324e+62 | -4.7957643851990985e+53 |
| 17.0ms | 288× | 0 | valid |
Compiled 444 to 354 computations (20.3% saved)
ival-mult: 6.0ms (78.3% of total)ival-sub: 1.0ms (13.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)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 24 | 58 |
| 1 | 41 | 58 |
| 2 | 98 | 58 |
| 3 | 325 | 58 |
| 4 | 1317 | 58 |
| 5 | 6084 | 58 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 (-.f64 x y) (+.f64 x x)) |
(if (<=.f64 y #s(literal -660000000000000038061121990195982397386553500654108672 binary64)) #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) (if (<=.f64 y #s(literal 56 binary64)) (*.f64 #s(approx (- x y) x) (+.f64 x x)) #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))))) |
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
| Outputs |
|---|
(*.f64 (-.f64 x y) (+.f64 x x)) |
(if (<=.f64 y #s(literal -660000000000000038061121990195982397386553500654108672 binary64)) #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) (if (<=.f64 y #s(literal 56 binary64)) (*.f64 #s(approx (- x y) x) (+.f64 x x)) #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))))) |
(if (or (<=.f64 y #s(literal -660000000000000038061121990195982397386553500654108672 binary64)) (not (<=.f64 y #s(literal 56 binary64)))) #s(approx (* 2 (- (* x x) (* x y))) (*.f64 #s(literal -2 binary64) (*.f64 y x))) (*.f64 #s(approx (- x y) x) (+.f64 x x))) |
(*.f64 #s(approx (- x y) x) (+.f64 x x)) |
(+.f64 #s(approx (- x y) x) #s(approx (- x y) x)) |
| 1× | fuel |
Compiled 60 to 25 computations (58.3% saved)
Compiled 152 to 76 computations (50% saved)
Loading profile data...