
Time bar (total: 2.6s)
| 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)
| 430.0ms | 6 335× | 0 | valid |
| 310.0ms | 1 919× | 1 | valid |
| 0.0ms | 2× | 2 | valid |
ival-sub: 161.0ms (38.3% of total)adjust: 93.0ms (22.1% of total)ival-add: 87.0ms (20.7% of total)ival-mult: 65.0ms (15.5% of total)ival-true: 6.0ms (1.4% of total)exact: 5.0ms (1.2% of total)ival-assert: 3.0ms (0.7% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 70 | 5 | (3801676012.908379 -2.3673145037464372e-102) | 0 | - | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 0 | 0 | - | 0 | - | (-.f64 #s(literal 1 binary64) y) |
| 0 | 0 | - | 0 | - | (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y)) |
| 0 | 0 | - | 0 | - | y |
| 0 | 0 | - | 0 | - | (-.f64 #s(literal 1 binary64) x) |
| 0 | 0 | - | 0 | - | #s(literal 1 binary64) |
| 0 | 0 | - | 0 | - | x |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
+.f64 | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) | cancellation | 75 | 0 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 70 | 0 |
| - | 5 | 181 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 70 | 0 | 0 |
| - | 5 | 0 | 181 |
| number | freq |
|---|---|
| 0 | 181 |
| 1 | 75 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 23.0ms | 362× | 0 | valid |
| 18.0ms | 150× | 1 | valid |
Compiled 63 to 25 computations (60.3% saved)
ival-sub: 12.0ms (47.9% of total)adjust: 5.0ms (19.9% of total)ival-mult: 4.0ms (16% of total)ival-add: 3.0ms (12% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 53 |
| 1 | 39 | 52 |
| 2 | 70 | 51 |
| 3 | 133 | 49 |
| 4 | 299 | 47 |
| 5 | 1523 | 35 |
| 0 | 7 | 9 |
| 0 | 11 | 9 |
| 1 | 18 | 9 |
| 2 | 29 | 9 |
| 3 | 52 | 9 |
| 4 | 138 | 9 |
| 5 | 772 | 7 |
| 6 | 7686 | 7 |
| 0 | 8111 | 6 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| Outputs |
|---|
(+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
(fma.f64 y (-.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
Compiled 9 to 7 computations (22.2% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 73.8% | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
Compiled 9 to 7 computations (22.2% saved)
| Inputs |
|---|
(+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
x |
(*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y)) |
(-.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
(-.f64 #s(literal 1 binary64) y) |
y |
| Outputs |
|---|
(- 1 y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
x |
(- (+ 1 (* -1 (* x (- 1 y)))) y) |
1 |
(+ 1 (* -1 x)) |
(* x (+ 1 (* -1 (- 1 y)))) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(* -1 (* x (- 1 y))) |
(* x (- (+ (* -1 (- 1 y)) (/ 1 x)) (/ y x))) |
(* -1 x) |
(* x (- (/ 1 x) 1)) |
(* x y) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(* -1 (* x (- (+ 1 (* -1 (/ (- 1 y) x))) y))) |
(* -1 (* x (- 1 (/ 1 x)))) |
(+ 1 (* -1 (* y (- 1 x)))) |
(- 1 x) |
(- (+ 1 (* -1 (* y (- 1 x)))) x) |
(+ 1 (* -1 y)) |
y |
(* -1 (* y (- 1 x))) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(* y (- (+ (* -1 (- 1 x)) (/ 1 y)) (/ x y))) |
(* -1 y) |
(* y (- (/ 1 y) 1)) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(* -1 (* y (- (+ 1 (* -1 (/ (- 1 x) y))) x))) |
(* -1 (* y (- 1 (/ 1 y)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 19.0ms | x | @ | inf | ((+ x (* (- 1 x) (- 1 y))) x (* (- 1 x) (- 1 y)) (- 1 x) 1 (- 1 y) y) |
| 1.0ms | x | @ | -inf | ((+ x (* (- 1 x) (- 1 y))) x (* (- 1 x) (- 1 y)) (- 1 x) 1 (- 1 y) y) |
| 1.0ms | y | @ | -inf | ((+ x (* (- 1 x) (- 1 y))) x (* (- 1 x) (- 1 y)) (- 1 x) 1 (- 1 y) y) |
| 1.0ms | y | @ | 0 | ((+ x (* (- 1 x) (- 1 y))) x (* (- 1 x) (- 1 y)) (- 1 x) 1 (- 1 y) y) |
| 0.0ms | x | @ | 0 | ((+ x (* (- 1 x) (- 1 y))) x (* (- 1 x) (- 1 y)) (- 1 x) 1 (- 1 y) y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 68 | 201 |
| 1 | 181 | 185 |
| 2 | 440 | 155 |
| 3 | 1780 | 139 |
| 0 | 8158 | 133 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(- 1 y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
x |
(- (+ 1 (* -1 (* x (- 1 y)))) y) |
1 |
(+ 1 (* -1 x)) |
(* x (+ 1 (* -1 (- 1 y)))) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(* -1 (* x (- 1 y))) |
(* x (- (+ (* -1 (- 1 y)) (/ 1 x)) (/ y x))) |
(* -1 x) |
(* x (- (/ 1 x) 1)) |
(* x y) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(* -1 (* x (- (+ 1 (* -1 (/ (- 1 y) x))) y))) |
(* -1 (* x (- 1 (/ 1 x)))) |
(+ 1 (* -1 (* y (- 1 x)))) |
(- 1 x) |
(- (+ 1 (* -1 (* y (- 1 x)))) x) |
(+ 1 (* -1 y)) |
y |
(* -1 (* y (- 1 x))) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(* y (- (+ (* -1 (- 1 x)) (/ 1 y)) (/ x y))) |
(* -1 y) |
(* y (- (/ 1 y) 1)) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(* -1 (* y (- (+ 1 (* -1 (/ (- 1 x) y))) x))) |
(* -1 (* y (- 1 (/ 1 y)))) |
| Outputs |
|---|
(- 1 y) |
(-.f64 #s(literal 1 binary64) y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
x |
(- (+ 1 (* -1 (* x (- 1 y)))) y) |
(*.f64 (-.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal 1 binary64))) |
1 |
#s(literal 1 binary64) |
(+ 1 (* -1 x)) |
(-.f64 #s(literal 1 binary64) x) |
(* x (+ 1 (* -1 (- 1 y)))) |
(*.f64 y x) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* x (- 1 y))) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(* x (- (+ (* -1 (- 1 y)) (/ 1 x)) (/ y x))) |
(*.f64 (-.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal 1 binary64))) |
(* -1 x) |
(neg.f64 x) |
(* x (- (/ 1 x) 1)) |
(*.f64 (-.f64 (/.f64 #s(literal 1 binary64) x) #s(literal 1 binary64)) x) |
(* x y) |
(*.f64 y x) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* x (- (+ 1 (* -1 (/ (- 1 y) x))) y))) |
(*.f64 (-.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal 1 binary64))) |
(* -1 (* x (- 1 (/ 1 x)))) |
(*.f64 (-.f64 (/.f64 #s(literal 1 binary64) x) #s(literal 1 binary64)) x) |
(+ 1 (* -1 (* y (- 1 x)))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(- 1 x) |
(-.f64 #s(literal 1 binary64) x) |
(- (+ 1 (* -1 (* y (- 1 x)))) x) |
(*.f64 (-.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal 1 binary64))) |
(+ 1 (* -1 y)) |
(-.f64 #s(literal 1 binary64) y) |
y |
(* -1 (* y (- 1 x))) |
(-.f64 (*.f64 y x) y) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* y (- (+ (* -1 (- 1 x)) (/ 1 y)) (/ x y))) |
(*.f64 (-.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal 1 binary64))) |
(* -1 y) |
(neg.f64 y) |
(* y (- (/ 1 y) 1)) |
(-.f64 #s(literal 1 binary64) y) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* y (- (+ 1 (* -1 (/ (- 1 x) y))) x))) |
(*.f64 (-.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal 1 binary64))) |
(* -1 (* y (- 1 (/ 1 y)))) |
(-.f64 #s(literal 1 binary64) y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 25 |
| 0 | 11 | 25 |
| 1 | 52 | 25 |
| 0 | 430 | 24 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
x |
(*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y)) |
(-.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
(-.f64 #s(literal 1 binary64) y) |
y |
| Outputs |
|---|
(/.f64 (-.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) x)) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 (-.f64 #s(literal 1 binary64) x)) (-.f64 #s(literal 1 binary64) y)) #s(literal 3 binary64))) (fma.f64 x x (+.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 2 binary64)) (*.f64 x (*.f64 (neg.f64 (-.f64 #s(literal 1 binary64) x)) (-.f64 #s(literal 1 binary64) y)))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x))))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) (-.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) x) (*.f64 x x)))) |
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 2 binary64))) (-.f64 x (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 2 binary64)) (-.f64 (*.f64 x x) (*.f64 (*.f64 x (-.f64 #s(literal 1 binary64) y)) (-.f64 #s(literal 1 binary64) x))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) (-.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) x) (*.f64 x x))) |
(fma.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x) x) |
(fma.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y) x) |
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)))) (/.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 2 binary64)) (-.f64 x (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x))))) |
(-.f64 x (*.f64 (neg.f64 (-.f64 #s(literal 1 binary64) y)) (-.f64 #s(literal 1 binary64) x))) |
(-.f64 x (*.f64 (neg.f64 (-.f64 #s(literal 1 binary64) x)) (-.f64 #s(literal 1 binary64) y))) |
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) (-.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) x) (*.f64 x x))) (/.f64 (pow.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) #s(literal 3 binary64)) (fma.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) (-.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) x) (*.f64 x x)))) |
(+.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) x) |
(+.f64 x (*.f64 (neg.f64 (neg.f64 (-.f64 #s(literal 1 binary64) x))) (-.f64 #s(literal 1 binary64) y))) |
(+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x))) |
x |
(*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) x)) |
(*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y)) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (-.f64 #s(literal 1 binary64) x)) (+.f64 y #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))) (-.f64 #s(literal 1 binary64) x)) (+.f64 (fma.f64 y y y) #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) (-.f64 #s(literal 1 binary64) y)) (+.f64 #s(literal 1 binary64) x)) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))) (-.f64 #s(literal 1 binary64) y)) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) (*.f64 x x))) (+.f64 #s(literal 1 binary64) x)) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) (*.f64 y y))) (+.f64 y #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (+.f64 (fma.f64 y y y) #s(literal 1 binary64))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (-.f64 #s(literal 1 binary64) (*.f64 x x))) (*.f64 (+.f64 y #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) x))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 (+.f64 y #s(literal 1 binary64)) (+.f64 (fma.f64 x x x) #s(literal 1 binary64)))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 x x))) (*.f64 (+.f64 (fma.f64 y y y) #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) x))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))) (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 (+.f64 (fma.f64 y y y) #s(literal 1 binary64)) (+.f64 (fma.f64 x x x) #s(literal 1 binary64)))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) (-.f64 #s(literal 1 binary64) (*.f64 y y))) (*.f64 (+.f64 #s(literal 1 binary64) x) (+.f64 y #s(literal 1 binary64)))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (*.f64 (+.f64 #s(literal 1 binary64) x) (+.f64 (fma.f64 y y y) #s(literal 1 binary64)))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 y y))) (*.f64 (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (+.f64 y #s(literal 1 binary64)))) |
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))) (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (*.f64 (+.f64 (fma.f64 x x x) #s(literal 1 binary64)) (+.f64 (fma.f64 y y y) #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x))) (neg.f64 (+.f64 #s(literal 1 binary64) x))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (+.f64 (fma.f64 x x x) #s(literal 1 binary64)))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) (+.f64 #s(literal 1 binary64) x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) x)) (/.f64 (*.f64 x x) (+.f64 #s(literal 1 binary64) x))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (fma.f64 x x x) #s(literal 1 binary64))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (+.f64 (fma.f64 x x x) #s(literal 1 binary64)))) |
(-.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y))) (neg.f64 (+.f64 y #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (+.f64 (fma.f64 y y y) #s(literal 1 binary64)))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (+.f64 y #s(literal 1 binary64))) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))) (+.f64 (fma.f64 y y y) #s(literal 1 binary64))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 y #s(literal 1 binary64))) (/.f64 (*.f64 y y) (+.f64 y #s(literal 1 binary64)))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (fma.f64 y y y) #s(literal 1 binary64))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (+.f64 (fma.f64 y y y) #s(literal 1 binary64)))) |
(-.f64 #s(literal 1 binary64) y) |
y |
Compiled 1 182 to 224 computations (81% saved)
4 alts after pruning (4 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 62 | 4 | 66 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 63 | 4 | 67 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | #s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
| ▶ | 61.0% | #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
| ▶ | 66.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
| ▶ | 35.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
Compiled 57 to 40 computations (29.8% saved)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
(*.f64 y x) |
y |
x |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
(-.f64 #s(literal 1 binary64) y) |
#s(literal 1 binary64) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
(-.f64 (*.f64 y x) y) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
| Outputs |
|---|
(- 1 y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(* x y) |
x |
(* -1 y) |
(- (* x y) y) |
(- (+ 1 (* x y)) y) |
(* x (+ 1 (* -1 (- 1 y)))) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(* x (+ y (* -1 (/ y x)))) |
(* x (- (+ y (/ 1 x)) (/ y x))) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(* -1 (* x (+ (* -1 y) (/ y x)))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- 1 y) x))))) |
1 |
(+ 1 (* -1 (* y (- 1 x)))) |
y |
(+ 1 (* -1 y)) |
(* y (- x 1)) |
(+ 1 (* y (- x 1))) |
(* -1 (* y (- 1 x))) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(* y (- (/ 1 y) 1)) |
(* y (- (+ x (/ 1 y)) 1)) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(* -1 (* y (- 1 (/ 1 y)))) |
(* -1 (* y (+ 1 (* -1 x)))) |
(* -1 (* y (- (+ 1 (* -1 x)) (/ 1 y)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | 0 | ((+ x (* (- 1 x) (- 1 y))) (* y x) y x (+ x (* (- 1 x) (- 1 y))) (- 1 y) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (+ x (* (- 1 x) (- 1 y))) (+ (* y x) (- 1 y))) |
| 1.0ms | y | @ | -inf | ((+ x (* (- 1 x) (- 1 y))) (* y x) y x (+ x (* (- 1 x) (- 1 y))) (- 1 y) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (+ x (* (- 1 x) (- 1 y))) (+ (* y x) (- 1 y))) |
| 1.0ms | x | @ | -inf | ((+ x (* (- 1 x) (- 1 y))) (* y x) y x (+ x (* (- 1 x) (- 1 y))) (- 1 y) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (+ x (* (- 1 x) (- 1 y))) (+ (* y x) (- 1 y))) |
| 1.0ms | x | @ | inf | ((+ x (* (- 1 x) (- 1 y))) (* y x) y x (+ x (* (- 1 x) (- 1 y))) (- 1 y) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (+ x (* (- 1 x) (- 1 y))) (+ (* y x) (- 1 y))) |
| 1.0ms | y | @ | inf | ((+ x (* (- 1 x) (- 1 y))) (* y x) y x (+ x (* (- 1 x) (- 1 y))) (- 1 y) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (+ x (* (- 1 x) (- 1 y))) (+ (* y x) (- 1 y))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 68 | 207 |
| 1 | 207 | 193 |
| 2 | 601 | 165 |
| 3 | 1935 | 137 |
| 0 | 9078 | 125 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(- 1 y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(* x y) |
x |
(* -1 y) |
(- (* x y) y) |
(- (+ 1 (* x y)) y) |
(* x (+ 1 (* -1 (- 1 y)))) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(* x (+ y (* -1 (/ y x)))) |
(* x (- (+ y (/ 1 x)) (/ y x))) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(* -1 (* x (+ (* -1 y) (/ y x)))) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- 1 y) x))))) |
1 |
(+ 1 (* -1 (* y (- 1 x)))) |
y |
(+ 1 (* -1 y)) |
(* y (- x 1)) |
(+ 1 (* y (- x 1))) |
(* -1 (* y (- 1 x))) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(* y (- (/ 1 y) 1)) |
(* y (- (+ x (/ 1 y)) 1)) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(* -1 (* y (- 1 (/ 1 y)))) |
(* -1 (* y (+ 1 (* -1 x)))) |
(* -1 (* y (- (+ 1 (* -1 x)) (/ 1 y)))) |
| Outputs |
|---|
(- 1 y) |
(-.f64 #s(literal 1 binary64) y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* x y) |
(*.f64 y x) |
x |
(* -1 y) |
(neg.f64 y) |
(- (* x y) y) |
(fma.f64 y x (neg.f64 y)) |
(- (+ 1 (* x y)) y) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* x (+ 1 (* -1 (- 1 y)))) |
(*.f64 y x) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* x (+ y (* -1 (/ y x)))) |
(fma.f64 y x (neg.f64 y)) |
(* x (- (+ y (/ 1 x)) (/ y x))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* x (+ (* -1 y) (/ y x)))) |
(fma.f64 y x (neg.f64 y)) |
(* -1 (* x (+ (* -1 y) (* -1 (/ (- 1 y) x))))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
1 |
#s(literal 1 binary64) |
(+ 1 (* -1 (* y (- 1 x)))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
y |
(+ 1 (* -1 y)) |
(-.f64 #s(literal 1 binary64) y) |
(* y (- x 1)) |
(fma.f64 y x (neg.f64 y)) |
(+ 1 (* y (- x 1))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* y (- 1 x))) |
(fma.f64 y x (neg.f64 y)) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* y (- (/ 1 y) 1)) |
(-.f64 #s(literal 1 binary64) y) |
(* y (- (+ x (/ 1 y)) 1)) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* y (- 1 (/ 1 y)))) |
(-.f64 #s(literal 1 binary64) y) |
(* -1 (* y (+ 1 (* -1 x)))) |
(fma.f64 y x (neg.f64 y)) |
(* -1 (* y (- (+ 1 (* -1 x)) (/ 1 y)))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 15 | 77 |
| 0 | 19 | 77 |
| 1 | 84 | 77 |
| 0 | 699 | 73 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
(*.f64 y x) |
y |
x |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
(-.f64 #s(literal 1 binary64) y) |
#s(literal 1 binary64) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
(-.f64 (*.f64 y x) y) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
(*.f64 y x) |
(*.f64 x y) |
y |
x |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y))) (neg.f64 (+.f64 y #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (+.f64 (fma.f64 y y y) #s(literal 1 binary64)))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (+.f64 y #s(literal 1 binary64))) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))) (+.f64 (fma.f64 y y y) #s(literal 1 binary64))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 y #s(literal 1 binary64))) (/.f64 (*.f64 y y) (+.f64 y #s(literal 1 binary64)))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (fma.f64 y y y) #s(literal 1 binary64))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (+.f64 (fma.f64 y y y) #s(literal 1 binary64)))) |
(-.f64 #s(literal 1 binary64) y) |
#s(literal 1 binary64) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y))) (neg.f64 (fma.f64 y x y))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (fma.f64 y x y) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y)) (fma.f64 y x y)) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (fma.f64 y x y) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (fma.f64 y x y)) (/.f64 (*.f64 y y) (fma.f64 y x y))) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 y (fma.f64 y x y) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (fma.f64 y x y) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) |
(-.f64 (*.f64 y x) y) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
(/.f64 (-.f64 (*.f64 (fma.f64 y x #s(literal 1 binary64)) (fma.f64 y x #s(literal 1 binary64))) (*.f64 y y)) (+.f64 (fma.f64 y x #s(literal 1 binary64)) y)) |
(/.f64 (-.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 2 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x))) |
(/.f64 (-.f64 (pow.f64 (fma.f64 y x #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 (fma.f64 y x #s(literal 1 binary64)) (fma.f64 y x #s(literal 1 binary64)) (fma.f64 y y (*.f64 (fma.f64 y x #s(literal 1 binary64)) y)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 2 binary64)))) (neg.f64 (-.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) y)))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 2 binary64))) (-.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) y))) |
(/.f64 (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x))))) |
(/.f64 (+.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(fma.f64 x y (-.f64 #s(literal 1 binary64) y)) |
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) y))) (/.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 2 binary64)) (-.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) y)))) |
(-.f64 (fma.f64 y x #s(literal 1 binary64)) y) |
(-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 (neg.f64 y) x)) |
(-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 (neg.f64 x) y)) |
(-.f64 #s(literal 1 binary64) (-.f64 y (*.f64 y x))) |
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (-.f64 #s(literal 1 binary64) y) #s(literal 3 binary64)) (fma.f64 (-.f64 #s(literal 1 binary64) y) (-.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) |
(+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y x)) |
(+.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) y)) |
Compiled 1 464 to 174 computations (88.1% saved)
6 alts after pruning (2 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 65 | 2 | 67 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 4 | 4 |
| Done | 0 | 0 | 0 |
| Total | 65 | 6 | 71 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | #s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
| ✓ | 61.0% | #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
| ✓ | 66.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
| ✓ | 35.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
| ▶ | 27.7% | #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
| ▶ | 40.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
Compiled 86 to 61 computations (29.1% saved)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (- (* y x) y) (neg.f64 y)) |
(neg.f64 y) |
y |
| Outputs |
|---|
(- 1 y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(* -1 y) |
(- (* x y) y) |
(* x (+ 1 (* -1 (- 1 y)))) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(* x y) |
(* x (+ y (* -1 (/ y x)))) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(* -1 (* x (+ (* -1 y) (/ y x)))) |
1 |
(+ 1 (* -1 (* y (- 1 x)))) |
(* y (- x 1)) |
y |
(* -1 (* y (- 1 x))) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(* -1 (* y (+ 1 (* -1 x)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y | @ | -inf | ((+ x (* (- 1 x) (- 1 y))) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (neg y) y) |
| 0.0ms | y | @ | inf | ((+ x (* (- 1 x) (- 1 y))) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (neg y) y) |
| 0.0ms | x | @ | -inf | ((+ x (* (- 1 x) (- 1 y))) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (neg y) y) |
| 0.0ms | x | @ | inf | ((+ x (* (- 1 x) (- 1 y))) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (neg y) y) |
| 0.0ms | y | @ | 0 | ((+ x (* (- 1 x) (- 1 y))) 1 (+ x (* (- 1 x) (- 1 y))) (- (* y x) y) (neg y) y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 48 | 125 |
| 1 | 147 | 117 |
| 2 | 418 | 101 |
| 3 | 1378 | 85 |
| 0 | 8043 | 79 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(- 1 y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(* -1 y) |
(- (* x y) y) |
(* x (+ 1 (* -1 (- 1 y)))) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(* x y) |
(* x (+ y (* -1 (/ y x)))) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(* -1 (* x (+ (* -1 y) (/ y x)))) |
1 |
(+ 1 (* -1 (* y (- 1 x)))) |
(* y (- x 1)) |
y |
(* -1 (* y (- 1 x))) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(* -1 (* y (+ 1 (* -1 x)))) |
| Outputs |
|---|
(- 1 y) |
(-.f64 #s(literal 1 binary64) y) |
(- (+ 1 (* x (+ 1 (* -1 (- 1 y))))) y) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 y) |
(neg.f64 y) |
(- (* x y) y) |
(fma.f64 y x (neg.f64 y)) |
(* x (+ 1 (* -1 (- 1 y)))) |
(*.f64 y x) |
(* x (- (+ 1 (+ (* -1 (- 1 y)) (/ 1 x))) (/ y x))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* x y) |
(*.f64 y x) |
(* x (+ y (* -1 (/ y x)))) |
(fma.f64 y x (neg.f64 y)) |
(* -1 (* x (- (* -1 (/ (- 1 y) x)) y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* x (+ (* -1 y) (/ y x)))) |
(fma.f64 y x (neg.f64 y)) |
1 |
#s(literal 1 binary64) |
(+ 1 (* -1 (* y (- 1 x)))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* y (- x 1)) |
(fma.f64 y x (neg.f64 y)) |
y |
(* -1 (* y (- 1 x))) |
(fma.f64 y x (neg.f64 y)) |
(* y (+ (* -1 (- 1 x)) (/ 1 y))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* y (- 1 (+ x (/ 1 y))))) |
(fma.f64 y x (-.f64 #s(literal 1 binary64) y)) |
(* -1 (* y (+ 1 (* -1 x)))) |
(fma.f64 y x (neg.f64 y)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 41 |
| 0 | 14 | 41 |
| 1 | 66 | 41 |
| 0 | 535 | 39 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (- (* y x) y) (neg.f64 y)) |
(neg.f64 y) |
y |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (- (* y x) y) (neg.f64 y)) |
(neg.f64 y) |
y |
Compiled 191 to 26 computations (86.4% saved)
6 alts after pruning (0 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 12 | 0 | 12 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 4 | 4 |
| Total | 12 | 6 | 18 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | #s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
| ✓ | 61.0% | #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
| ✓ | 66.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
| ✓ | 35.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
| ✓ | 27.7% | #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
| ✓ | 40.1% | #s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
Compiled 181 to 86 computations (52.5% saved)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
(+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
4 calls:
| 5.0ms | (-.f64 #s(literal 1 binary64) y) |
| 3.0ms | x |
| 3.0ms | y |
| 2.0ms | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (-.f64 #s(literal 1 binary64) y) |
| 100.0% | 1 | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 100.0% | 1 | x |
| 100.0% | 1 | y |
Compiled 14 to 15 computations (-7.1% saved)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 (*.f64 y x) y)) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) |
4 calls:
| 2.0ms | y |
| 2.0ms | x |
| 2.0ms | (-.f64 #s(literal 1 binary64) y) |
| 2.0ms | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 85.3% | 3 | (-.f64 #s(literal 1 binary64) y) |
| 86.5% | 3 | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 87.0% | 3 | x |
| 86.1% | 3 | y |
Compiled 14 to 15 computations (-7.1% saved)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
4 calls:
| 2.0ms | (-.f64 #s(literal 1 binary64) y) |
| 2.0ms | x |
| 2.0ms | y |
| 1.0ms | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 66.1% | 1 | (-.f64 #s(literal 1 binary64) y) |
| 66.1% | 1 | y |
| 66.1% | 1 | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 66.1% | 1 | x |
Compiled 14 to 15 computations (-7.1% saved)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) |
4 calls:
| 1.0ms | y |
| 1.0ms | x |
| 1.0ms | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 1.0ms | (-.f64 #s(literal 1 binary64) y) |
| Accuracy | Segments | Branch |
|---|---|---|
| 44.5% | 3 | x |
| 64.7% | 3 | (-.f64 #s(literal 1 binary64) y) |
| 64.7% | 3 | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 64.7% | 3 | y |
Compiled 14 to 15 computations (-7.1% saved)
Total 0.0b remaining (0%)
Threshold costs 0b (0%)
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
4 calls:
| 1.0ms | y |
| 1.0ms | x |
| 1.0ms | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 1.0ms | (-.f64 #s(literal 1 binary64) y) |
| Accuracy | Segments | Branch |
|---|---|---|
| 40.1% | 1 | x |
| 40.1% | 1 | (+.f64 x (*.f64 (-.f64 #s(literal 1 binary64) x) (-.f64 #s(literal 1 binary64) y))) |
| 40.1% | 1 | (-.f64 #s(literal 1 binary64) y) |
| 40.1% | 1 | y |
Compiled 14 to 15 computations (-7.1% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 16.0ms | 4.893593101139918e+46 | 5.632773668258716e+50 |
| 33.0ms | -7.785299996522692e+99 | -2.6996048841364015e+90 |
| 34.0ms | 148× | 1 | valid |
| 6.0ms | 124× | 0 | valid |
Compiled 454 to 369 computations (18.7% saved)
ival-sub: 20.0ms (61.9% of total)adjust: 7.0ms (21.7% of total)ival-mult: 3.0ms (9.3% of total)ival-add: 3.0ms (9.3% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 7.0ms | 0.13677341589256478 | 2.021225033378225 |
| 16.0ms | -2.049364059582504 | -5.167653268742867e-7 |
| 9.0ms | 203× | 0 | valid |
| 2.0ms | 17× | 2 | valid |
| 2.0ms | 20× | 1 | valid |
Compiled 447 to 357 computations (20.1% saved)
ival-sub: 3.0ms (40% of total)ival-mult: 2.0ms (26.6% of total)adjust: 1.0ms (13.3% of total)ival-add: 1.0ms (13.3% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 30 | 113 |
| 1 | 48 | 113 |
| 2 | 60 | 113 |
| 3 | 83 | 113 |
| 4 | 158 | 113 |
| 5 | 629 | 113 |
| 6 | 5848 | 113 |
| 1× | node limit |
| Inputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
(if (<=.f64 x #s(literal -145000000000000006637084329031730566897805487144094923769617153450658629987376513110231333470208 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) (if (<=.f64 x #s(literal 41000000000000000012827519726777094232637840556032 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
(if (<=.f64 y #s(literal -1 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) (if (<=.f64 y #s(literal 1 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
| Outputs |
|---|
#s(approx (+ x (* (- 1 x) (- 1 y))) (fma.f64 y x (-.f64 #s(literal 1 binary64) y))) |
(if (<=.f64 x #s(literal -145000000000000006637084329031730566897805487144094923769617153450658629987376513110231333470208 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) (if (<=.f64 x #s(literal 41000000000000000012827519726777094232637840556032 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)))) |
(if (or (<=.f64 x #s(literal -145000000000000006637084329031730566897805487144094923769617153450658629987376513110231333470208 binary64)) (not (<=.f64 x #s(literal 41000000000000000012827519726777094232637840556032 binary64)))) #s(approx (+ x (* (- 1 x) (- 1 y))) (*.f64 y x)) #s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) (-.f64 #s(literal 1 binary64) y)) |
(if (<=.f64 y #s(literal -1 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) (if (<=.f64 y #s(literal 1 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))))) |
(if (or (<=.f64 y #s(literal -1 binary64)) (not (<=.f64 y #s(literal 1 binary64)))) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(approx (- (* y x) y) (neg.f64 y))) #s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64))) |
#s(approx (+ x (* (- 1 x) (- 1 y))) #s(literal 1 binary64)) |
| 1× | done |
Compiled 113 to 33 computations (70.8% saved)
Compiled 258 to 92 computations (64.3% saved)
Loading profile data...