
Time bar (total: 4.7s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 0 |
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 1 |
| 100% | 100% | 0% | 0% | 0% | 0% | 0% | 2 |
Compiled 9 to 7 computations (22.2% saved)
| 696.0ms | 8 256× | 0 | valid |
ival-mult: 329.0ms (71.2% of total)ival-div: 74.0ms (16% of total)ival-add: 43.0ms (9.3% of total)ival-true: 6.0ms (1.3% of total)exact: 5.0ms (1.1% of total)ival-assert: 3.0ms (0.6% of total)adjust: 2.0ms (0.4% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 69 | 0 | - | 0 | - | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| 0 | 0 | - | 0 | - | #s(literal 1 binary64) |
| 0 | 0 | - | 0 | - | (+.f64 (*.f64 x x) #s(literal 1 binary64)) |
| 0 | 0 | - | 0 | - | (*.f64 x x) |
| 0 | 0 | - | 0 | - | x |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
/.f64 | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) | n/o | 69 | 0 |
| ↳ | (*.f64 x x) | overflow | 69 | |
| ↳ | (+.f64 (*.f64 x x) #s(literal 1 binary64)) | overflow | 69 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 69 | 0 |
| - | 0 | 187 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 69 | 0 | 0 |
| - | 0 | 0 | 187 |
| number | freq |
|---|---|
| 0 | 187 |
| 1 | 69 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 73.0ms | 512× | 0 | valid |
Compiled 45 to 19 computations (57.8% saved)
ival-mult: 52.0ms (87.9% of total)ival-div: 3.0ms (5.1% of total)ival-add: 2.0ms (3.4% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 17 |
| 1 | 24 | 15 |
| 2 | 59 | 14 |
| 3 | 88 | 14 |
| 4 | 161 | 14 |
| 5 | 405 | 14 |
| 6 | 2753 | 14 |
| 7 | 6468 | 14 |
| 0 | 5 | 7 |
| 0 | 8 | 7 |
| 1 | 15 | 7 |
| 2 | 37 | 7 |
| 3 | 77 | 7 |
| 4 | 138 | 7 |
| 5 | 347 | 7 |
| 6 | 2391 | 7 |
| 7 | 5991 | 7 |
| 0 | 8230 | 6 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| Outputs |
|---|
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(negabs x)
Compiled 7 to 5 computations (28.6% saved)
Compiled 0 to 1 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 74.9% | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
Compiled 7 to 5 computations (28.6% saved)
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 x x) | |
| cost-diff | 0 | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) | |
| cost-diff | 1 | (+.f64 (*.f64 x x) #s(literal 1 binary64)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 5 | 17 |
| 0 | 8 | 17 |
| 1 | 15 | 17 |
| 2 | 37 | 17 |
| 3 | 77 | 17 |
| 4 | 138 | 17 |
| 5 | 347 | 17 |
| 6 | 2391 | 17 |
| 7 | 5991 | 17 |
| 0 | 8230 | 15 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
x |
(+.f64 (*.f64 x x) #s(literal 1 binary64)) |
(*.f64 x x) |
#s(literal 1 binary64) |
| Outputs |
|---|
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
x |
(+.f64 (*.f64 x x) #s(literal 1 binary64)) |
(fma.f64 x x #s(literal 1 binary64)) |
(*.f64 x x) |
#s(literal 1 binary64) |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (+.f64 (*.f64 x x) #s(literal 1 binary64)) | |
| accuracy | 0.0 | (*.f64 x x) | |
| accuracy | 16.063434571778895 | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| 10.0ms | 256× | 0 | valid |
Compiled 19 to 7 computations (63.2% saved)
ival-div: 2.0ms (40.7% of total)ival-mult: 2.0ms (40.7% of total)ival-add: 1.0ms (20.3% 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) #s(literal 1 binary64)) |
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
(*.f64 x x) |
| Outputs |
|---|
#s(approx (+ (* x x) 1) #s(hole binary64 1)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | inf | ((+ (* x x) 1) (/ x (+ (* x x) 1)) (* x x)) |
| 1.0ms | x | @ | 0 | ((+ (* x x) 1) (/ x (+ (* x x) 1)) (* x x)) |
| 1.0ms | x | @ | -inf | ((+ (* x x) 1) (/ x (+ (* x x) 1)) (* x x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 64 | 271 |
| 1 | 152 | 269 |
| 2 | 465 | 261 |
| 3 | 3183 | 261 |
| 0 | 8036 | 240 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (+ (* x x) 1) #s(hole binary64 1)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
| Outputs |
|---|
#s(approx (+ (* x x) 1) #s(hole binary64 1)) |
#s(approx (+ (* x x) 1) #s(literal 1 binary64)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2)))) |
#s(approx (+ (* x x) 1) (fma.f64 x x #s(literal 1 binary64))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x #s(literal -1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (-.f64 x (pow.f64 x #s(literal 3 binary64))) x #s(literal -1 binary64)) x)) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x x) (*.f64 x x)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2)))))) |
#s(approx (+ (* x x) 1) (fma.f64 x x #s(literal 1 binary64))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64))) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 6 binary64)))) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64)) (neg.f64 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64)))) (neg.f64 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 6 binary64))) (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64)))) (neg.f64 x))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 5 | 15 |
| 0 | 8 | 15 |
| 1 | 33 | 15 |
| 0 | 249 | 13 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(+.f64 (*.f64 x x) #s(literal 1 binary64)) |
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
(*.f64 x x) |
| Outputs |
|---|
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 x x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 x x #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x)))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (fma.f64 x x #s(literal -1 binary64))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 x #s(literal 4 binary64)) (*.f64 x x)))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) |
(fma.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) #s(literal 1 binary64)) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 x) (neg.f64 x) #s(literal 1 binary64)) |
(fma.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) #s(literal 1 binary64)) |
(fma.f64 #s(literal 1 binary64) (*.f64 x x) #s(literal 1 binary64)) |
(fma.f64 (*.f64 x x) #s(literal 1 binary64) #s(literal 1 binary64)) |
(fma.f64 x (*.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 x x #s(literal 1 binary64)) |
(-.f64 (/.f64 (pow.f64 x #s(literal 4 binary64)) (fma.f64 x x #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 x x #s(literal -1 binary64)))) |
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (neg.f64 x)) (neg.f64 x))) |
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fabs.f64 x)) (fabs.f64 x))) |
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 x) x)) |
(-.f64 #s(literal 1 binary64) (*.f64 x (neg.f64 x))) |
(-.f64 (*.f64 x x) #s(literal -1 binary64)) |
(+.f64 (/.f64 (pow.f64 x #s(literal 6 binary64)) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x)))) |
(+.f64 #s(literal 1 binary64) (*.f64 x x)) |
(+.f64 (*.f64 x x) #s(literal 1 binary64)) |
(*.f64 (/.f64 x (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) (fma.f64 x x #s(literal -1 binary64))) |
(*.f64 (/.f64 x (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64))) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) |
(/.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 (fma.f64 x x #s(literal 1 binary64))))) |
(/.f64 (neg.f64 x) (neg.f64 (fma.f64 x x #s(literal 1 binary64)))) |
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(neg.f64 (/.f64 (neg.f64 x) (fma.f64 x x #s(literal 1 binary64)))) |
(neg.f64 (/.f64 x (neg.f64 (fma.f64 x x #s(literal 1 binary64))))) |
(*.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64))) |
(*.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64))) |
(*.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64))) |
(*.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64))) |
(*.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 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64))) |
(*.f64 (neg.f64 x) (neg.f64 x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 x) (fabs.f64 x)) |
(*.f64 #s(literal 1 binary64) (*.f64 x x)) |
(*.f64 (*.f64 x x) #s(literal 1 binary64)) |
(*.f64 x (*.f64 x #s(literal 1 binary64))) |
(*.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))) |
Compiled 870 to 222 computations (74.5% saved)
6 alts after pruning (6 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 68 | 6 | 74 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 69 | 6 | 75 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 74.9% | (/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
| ▶ | 25.2% | (/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
| ▶ | 49.6% | #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
| ▶ | 50.4% | #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
| 51.1% | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) | |
| ▶ | 51.8% | #s(approx (/ x (+ (* x x) 1)) x) |
Compiled 134 to 90 computations (32.8% saved)
Found 12 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (/.f64 #s(literal 1 binary64) (*.f64 x x)) | |
| cost-diff | 0 | (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) | |
| cost-diff | 0 | (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x) | |
| cost-diff | 0 | #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) | |
| cost-diff | 0 | (*.f64 x x) | |
| cost-diff | 0 | #s(approx (+ (* x x) 1) (*.f64 x x)) | |
| cost-diff | 0 | (/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) | |
| cost-diff | 0 | (/.f64 #s(literal 1 binary64) x) | |
| cost-diff | 0 | #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) | |
| cost-diff | 0 | #s(approx (/ x (+ (* x x) 1)) x) | |
| cost-diff | 0 | (fma.f64 x x #s(literal 1 binary64)) | |
| cost-diff | 0 | (/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 100 |
| 0 | 25 | 100 |
| 1 | 35 | 100 |
| 2 | 64 | 100 |
| 3 | 143 | 100 |
| 4 | 384 | 100 |
| 5 | 2024 | 100 |
| 6 | 6080 | 100 |
| 0 | 8098 | 100 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
x |
(fma.f64 x x #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (/ x (+ (* x x) 1)) x) |
x |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
(/.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
x |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
x |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
(*.f64 x x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x) |
(-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) |
#s(literal 1 binary64) |
(/.f64 #s(literal 1 binary64) (*.f64 x x)) |
(*.f64 x x) |
x |
| Outputs |
|---|
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
x |
(fma.f64 x x #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (/ x (+ (* x x) 1)) x) |
x |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
(/.f64 #s(literal 1 binary64) x) |
#s(literal 1 binary64) |
x |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
x |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
(*.f64 x x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x) |
(/.f64 (-.f64 #s(literal 1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) x) |
(-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) |
(-.f64 #s(literal 1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) |
#s(literal 1 binary64) |
(/.f64 #s(literal 1 binary64) (*.f64 x x)) |
(/.f64 (/.f64 #s(literal 1 binary64) x) x) |
(*.f64 x x) |
x |
Found 12 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 x x) | |
| accuracy | 0.03125 | (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x) | |
| accuracy | 0.3465047330347441 | (/.f64 #s(literal 1 binary64) (*.f64 x x)) | |
| accuracy | 32.23864448849109 | #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) | |
| accuracy | 0.0 | (*.f64 x x) | |
| accuracy | 16.063434571778895 | (/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) | |
| accuracy | 31.593210594553078 | #s(approx (+ (* x x) 1) (*.f64 x x)) | |
| accuracy | 0.0 | (/.f64 #s(literal 1 binary64) x) | |
| accuracy | 31.752281917571807 | #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) | |
| accuracy | 30.819777904085736 | #s(approx (/ x (+ (* x x) 1)) x) | |
| accuracy | 0.0 | (fma.f64 x x #s(literal 1 binary64)) | |
| accuracy | 16.063434571778895 | (/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
| 118.0ms | 256× | 0 | valid |
Compiled 85 to 11 computations (87.1% saved)
ival-mult: 51.0ms (85.5% of total)ival-div: 6.0ms (10.1% of total)ival-sub: 1.0ms (1.7% of total)ival-add: 1.0ms (1.7% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(fma.f64 x x #s(literal 1 binary64)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
(/.f64 #s(literal 1 binary64) x) |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
(*.f64 x x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x) |
(-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) |
(/.f64 #s(literal 1 binary64) (*.f64 x x)) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (+ (* x x) 1) #s(hole binary64 1)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2)))) |
#s(approx (/ 1 x) #s(hole binary64 (/ 1 x))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ -1 (pow x 3)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ (- (pow x 2) 1) (pow x 3)))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (/ -1 (pow x 2)))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (/ (- (pow x 2) 1) (pow x 2)))) |
#s(approx (/ 1 (* x x)) #s(hole binary64 (/ 1 (pow x 2)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2)))))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ 1 x))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 1)) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (- 1 (/ 1 (pow x 2))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | ((/ x (+ (* x x) 1)) (+ (* x x) 1) (/ x (+ (* x x) 1)) (/ x (+ (* x x) 1)) (/ 1 x) (/ x (+ (* x x) 1)) (+ (* x x) 1) (* x x) (/ x (+ (* x x) 1)) (/ (- 1 (/ 1 (* x x))) x) (- 1 (/ 1 (* x x))) (/ 1 (* x x))) |
| 1.0ms | x | @ | 0 | ((/ x (+ (* x x) 1)) (+ (* x x) 1) (/ x (+ (* x x) 1)) (/ x (+ (* x x) 1)) (/ 1 x) (/ x (+ (* x x) 1)) (+ (* x x) 1) (* x x) (/ x (+ (* x x) 1)) (/ (- 1 (/ 1 (* x x))) x) (- 1 (/ 1 (* x x))) (/ 1 (* x x))) |
| 1.0ms | x | @ | inf | ((/ x (+ (* x x) 1)) (+ (* x x) 1) (/ x (+ (* x x) 1)) (/ x (+ (* x x) 1)) (/ 1 x) (/ x (+ (* x x) 1)) (+ (* x x) 1) (* x x) (/ x (+ (* x x) 1)) (/ (- 1 (/ 1 (* x x))) x) (- 1 (/ 1 (* x x))) (/ 1 (* x x))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 84 | 429 |
| 1 | 186 | 415 |
| 2 | 559 | 415 |
| 3 | 4803 | 415 |
| 0 | 8830 | 381 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (+ (* x x) 1) #s(hole binary64 1)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2)))) |
#s(approx (/ 1 x) #s(hole binary64 (/ 1 x))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ -1 (pow x 3)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ (- (pow x 2) 1) (pow x 3)))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (/ -1 (pow x 2)))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (/ (- (pow x 2) 1) (pow x 2)))) |
#s(approx (/ 1 (* x x)) #s(hole binary64 (/ 1 (pow x 2)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2)))))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ 1 x))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 1)) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (- 1 (/ 1 (pow x 2))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x #s(literal -1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (-.f64 x (pow.f64 x #s(literal 3 binary64))) x #s(literal -1 binary64)) x)) |
#s(approx (+ (* x x) 1) #s(hole binary64 1)) |
#s(approx (+ (* x x) 1) #s(literal 1 binary64)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2)))) |
#s(approx (+ (* x x) 1) (fma.f64 x x #s(literal 1 binary64))) |
#s(approx (/ 1 x) #s(hole binary64 (/ 1 x))) |
#s(approx (/ 1 x) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x x) (*.f64 x x)) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ -1 (pow x 3)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) (/.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ (- (pow x 2) 1) (pow x 3)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (/ -1 (pow x 2)))) |
#s(approx (- 1 (/ 1 (* x x))) (/.f64 #s(literal -1 binary64) (*.f64 x x))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (/ (- (pow x 2) 1) (pow x 2)))) |
#s(approx (- 1 (/ 1 (* x x))) (/.f64 (-.f64 x (/.f64 #s(literal 1 binary64) x)) x)) |
#s(approx (/ 1 (* x x)) #s(hole binary64 (/ 1 (pow x 2)))) |
#s(approx (/ 1 (* x x)) (/.f64 #s(literal 1 binary64) (*.f64 x x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (+.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 5 binary64))) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 (+.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 5 binary64))) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 7 binary64))))) |
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2))) |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2)))))) |
#s(approx (+ (* x x) 1) (fma.f64 x x #s(literal 1 binary64))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ 1 x))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 1)) |
#s(approx (- 1 (/ 1 (* x x))) #s(literal 1 binary64)) |
#s(approx (- 1 (/ 1 (* x x))) #s(hole binary64 (- 1 (/ 1 (pow x 2))))) |
#s(approx (- 1 (/ 1 (* x x))) (/.f64 (-.f64 x (/.f64 #s(literal 1 binary64) x)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64)))) (neg.f64 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (neg.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 7 binary64))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 5 binary64)))) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ (- 1 (/ 1 (* x x))) x) (/.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 89 |
| 0 | 25 | 89 |
| 1 | 74 | 81 |
| 0 | 498 | 81 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(fma.f64 x x #s(literal 1 binary64)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
(/.f64 #s(literal 1 binary64) x) |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
(*.f64 x x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x) |
(-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) |
(/.f64 #s(literal 1 binary64) (*.f64 x x)) |
| Outputs |
|---|
(*.f64 (/.f64 x (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) (fma.f64 x x #s(literal -1 binary64))) |
(*.f64 (/.f64 x (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64))) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) |
(/.f64 (neg.f64 (neg.f64 x)) (neg.f64 (fma.f64 (neg.f64 x) x #s(literal -1 binary64)))) |
(/.f64 (neg.f64 x) (fma.f64 (neg.f64 x) x #s(literal -1 binary64))) |
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(neg.f64 (/.f64 (neg.f64 x) (fma.f64 x x #s(literal 1 binary64)))) |
(neg.f64 (/.f64 x (fma.f64 (neg.f64 x) x #s(literal -1 binary64)))) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 x x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 x x #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x)))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (fma.f64 x x #s(literal -1 binary64))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 x #s(literal 4 binary64)) (*.f64 x x)))) |
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) |
(fma.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) #s(literal 1 binary64)) |
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) #s(literal 1 binary64)) |
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (neg.f64 x) (neg.f64 x) #s(literal 1 binary64)) |
(fma.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 (fabs.f64 x) (fabs.f64 x) #s(literal 1 binary64)) |
(fma.f64 (*.f64 x x) #s(literal 1 binary64) #s(literal 1 binary64)) |
(fma.f64 #s(literal 1 binary64) (*.f64 x x) #s(literal 1 binary64)) |
(fma.f64 x (*.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(fma.f64 x x #s(literal 1 binary64)) |
(-.f64 (/.f64 (pow.f64 x #s(literal 4 binary64)) (fma.f64 x x #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 x x #s(literal -1 binary64)))) |
(-.f64 (*.f64 x x) #s(literal -1 binary64)) |
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 x) x)) |
(+.f64 (/.f64 (pow.f64 x #s(literal 6 binary64)) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x)))) |
(+.f64 (*.f64 x x) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) (*.f64 x x)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (pow.f64 x #s(literal -1 binary64))) |
(*.f64 (pow.f64 x #s(literal -1/2 binary64)) (pow.f64 x #s(literal -1/2 binary64))) |
(*.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -1 binary64))) |
(pow.f64 x #s(literal -1 binary64)) |
(/.f64 #s(literal -1 binary64) (neg.f64 x)) |
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 x))) |
(/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 1 binary64))) |
(/.f64 #s(literal 1 binary64) x) |
(neg.f64 (/.f64 #s(literal -1 binary64) x)) |
(neg.f64 (/.f64 #s(literal 1 binary64) (neg.f64 x))) |
(exp.f64 (*.f64 (log.f64 x) #s(literal -1 binary64))) |
(/.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 #s(approx (+ (* x x) 1) (*.f64 x x))))) |
(/.f64 (neg.f64 x) (neg.f64 #s(approx (+ (* x x) 1) (*.f64 x x)))) |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
(neg.f64 (/.f64 (neg.f64 x) #s(approx (+ (* x x) 1) (*.f64 x x)))) |
(neg.f64 (/.f64 x (neg.f64 #s(approx (+ (* x x) 1) (*.f64 x x))))) |
#s(approx (+ (* x x) 1) (*.f64 x x)) |
(*.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64))) |
(*.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64))) |
(*.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64))) |
(*.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 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64))) |
(*.f64 (neg.f64 x) (neg.f64 x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 x) (fabs.f64 x)) |
(*.f64 (*.f64 x x) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (*.f64 x x)) |
(*.f64 x (*.f64 x #s(literal 1 binary64))) |
(*.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)) |
(fabs.f64 (*.f64 x x)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 2 binary64))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64))) x)) |
(/.f64 (-.f64 (pow.f64 x #s(literal -2 binary64)) (*.f64 (/.f64 (pow.f64 x #s(literal -2 binary64)) x) (/.f64 (pow.f64 x #s(literal -2 binary64)) x))) (+.f64 (pow.f64 x #s(literal -1 binary64)) (/.f64 (pow.f64 x #s(literal -2 binary64)) x))) |
(/.f64 (-.f64 (pow.f64 (pow.f64 x #s(literal -1 binary64)) #s(literal 3 binary64)) (pow.f64 (/.f64 (pow.f64 x #s(literal -2 binary64)) x) #s(literal 3 binary64))) (+.f64 (pow.f64 x #s(literal -2 binary64)) (fma.f64 (/.f64 (pow.f64 x #s(literal -2 binary64)) x) (/.f64 (pow.f64 x #s(literal -2 binary64)) x) (*.f64 (pow.f64 x #s(literal -1 binary64)) (/.f64 (pow.f64 x #s(literal -2 binary64)) x))))) |
(/.f64 (neg.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64))))) (neg.f64 (neg.f64 x))) |
(/.f64 (-.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 (neg.f64 x) (pow.f64 x #s(literal -2 binary64)))) (*.f64 (neg.f64 x) x)) |
(/.f64 (-.f64 (*.f64 #s(literal 1 binary64) x) (*.f64 x (pow.f64 x #s(literal -2 binary64)))) (*.f64 x x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1 binary64))) (*.f64 (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 3 binary64))) (*.f64 (fma.f64 (pow.f64 x #s(literal -2 binary64)) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64)) x)) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64)))) (neg.f64 x)) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64))) x) |
(neg.f64 (/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64)))) x)) |
(neg.f64 (/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64))) (neg.f64 x))) |
(-.f64 (pow.f64 x #s(literal -1 binary64)) (/.f64 (pow.f64 x #s(literal -2 binary64)) x)) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1 binary64)))) (neg.f64 (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (pow.f64 x #s(literal -2 binary64)) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64)))) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1 binary64))) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64))) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 3 binary64))) (fma.f64 (pow.f64 x #s(literal -2 binary64)) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))) |
(-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64))) (/.f64 (pow.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1 binary64)) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)))) |
(-.f64 (/.f64 #s(literal 1 binary64) (fma.f64 (pow.f64 x #s(literal -2 binary64)) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))) (/.f64 (pow.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 3 binary64)) (fma.f64 (pow.f64 x #s(literal -2 binary64)) (+.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64)))) |
(-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64))) |
(*.f64 (pow.f64 (*.f64 x x) #s(literal -1/2 binary64)) (pow.f64 (*.f64 x x) #s(literal -1/2 binary64))) |
(*.f64 (/.f64 #s(literal 1 binary64) (neg.f64 x)) (/.f64 #s(literal 1 binary64) (neg.f64 x))) |
(*.f64 (/.f64 #s(literal 1 binary64) (fabs.f64 x)) (/.f64 #s(literal 1 binary64) (fabs.f64 x))) |
(*.f64 (pow.f64 (neg.f64 x) #s(literal -1 binary64)) (pow.f64 (neg.f64 x) #s(literal -1 binary64))) |
(*.f64 (pow.f64 (fabs.f64 x) #s(literal -1 binary64)) (pow.f64 (fabs.f64 x) #s(literal -1 binary64))) |
(*.f64 (pow.f64 x #s(literal -2 binary64)) #s(literal 1 binary64)) |
(*.f64 (pow.f64 x #s(literal -1 binary64)) (pow.f64 x #s(literal -1 binary64))) |
(*.f64 #s(literal 1 binary64) (pow.f64 x #s(literal -2 binary64))) |
(pow.f64 (*.f64 x x) #s(literal -1 binary64)) |
(pow.f64 x #s(literal -2 binary64)) |
(/.f64 (/.f64 #s(literal 1 binary64) (neg.f64 x)) (neg.f64 x)) |
(/.f64 (/.f64 #s(literal 1 binary64) (fabs.f64 x)) (fabs.f64 x)) |
(/.f64 (neg.f64 (pow.f64 x #s(literal -1 binary64))) (neg.f64 x)) |
(/.f64 #s(literal -1 binary64) (*.f64 (neg.f64 x) x)) |
(/.f64 (pow.f64 x #s(literal -1 binary64)) x) |
(/.f64 #s(literal 1 binary64) (pow.f64 (*.f64 x x) #s(literal 1 binary64))) |
(/.f64 #s(literal 1 binary64) (*.f64 x x)) |
(neg.f64 (/.f64 #s(literal -1 binary64) (*.f64 x x))) |
(neg.f64 (/.f64 #s(literal 1 binary64) (*.f64 (neg.f64 x) x))) |
(exp.f64 (*.f64 (log.f64 (*.f64 x x)) #s(literal -1 binary64))) |
Compiled 2 567 to 520 computations (79.7% saved)
6 alts after pruning (1 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 155 | 0 | 155 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 5 | 5 |
| Done | 0 | 0 | 0 |
| Total | 155 | 6 | 161 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 74.9% | (/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
| ✓ | 25.2% | (/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
| ✓ | 49.6% | #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
| ✓ | 50.4% | #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
| ▶ | 51.1% | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
| ✓ | 51.8% | #s(approx (/ x (+ (* x x) 1)) x) |
Compiled 67 to 45 computations (32.8% saved)
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (pow.f64 x #s(literal 3 binary64)) | |
| cost-diff | 0 | (-.f64 x (pow.f64 x #s(literal 3 binary64))) | |
| cost-diff | 0 | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 23 |
| 0 | 11 | 23 |
| 1 | 20 | 23 |
| 2 | 53 | 23 |
| 3 | 132 | 23 |
| 4 | 238 | 23 |
| 5 | 490 | 23 |
| 6 | 2945 | 23 |
| 7 | 6951 | 23 |
| 0 | 8838 | 22 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
x |
(pow.f64 x #s(literal 3 binary64)) |
#s(literal 3 binary64) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
x |
(pow.f64 x #s(literal 3 binary64)) |
#s(literal 3 binary64) |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (pow.f64 x #s(literal 3 binary64)) | |
| accuracy | 0.0078125 | (-.f64 x (pow.f64 x #s(literal 3 binary64))) | |
| accuracy | 31.274179523830327 | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
| 30.0ms | 256× | 0 | valid |
Compiled 19 to 10 computations (47.4% saved)
ival-add: 16.0ms (66.6% of total)ival-pow: 3.0ms (12.5% of total)ival-div: 2.0ms (8.3% of total)ival-mult: 2.0ms (8.3% of total)ival-sub: 1.0ms (4.2% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
(pow.f64 x #s(literal 3 binary64)) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (- x (pow x 3)) #s(hole binary64 x)) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (pow x 3) #s(hole binary64 (pow x 3))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* -1 (pow x 3)))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* (pow x 3) (- (/ 1 (pow x 2)) 1)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* -1 (* (pow x 3) (- 1 (/ 1 (pow x 2))))))) |
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | ((/ x (+ (* x x) 1)) (- x (pow x 3)) (pow x 3)) |
| 1.0ms | x | @ | inf | ((/ x (+ (* x x) 1)) (- x (pow x 3)) (pow x 3)) |
| 1.0ms | x | @ | 0 | ((/ x (+ (* x x) 1)) (- x (pow x 3)) (pow x 3)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 69 | 299 |
| 1 | 159 | 286 |
| 2 | 468 | 286 |
| 3 | 2091 | 283 |
| 0 | 8632 | 268 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (- x (pow x 3)) #s(hole binary64 x)) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (pow x 3) #s(hole binary64 (pow x 3))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* -1 (pow x 3)))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* (pow x 3) (- (/ 1 (pow x 2)) 1)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* -1 (* (pow x 3) (- 1 (/ 1 (pow x 2))))))) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x #s(literal -1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (-.f64 x (pow.f64 x #s(literal 3 binary64))) x #s(literal -1 binary64)) x)) |
#s(approx (- x (pow x 3)) #s(hole binary64 x)) |
#s(approx (- x (pow x 3)) x) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (- x (pow x 3)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (pow x 3) #s(hole binary64 (pow x 3))) |
#s(approx (pow x 3) (pow.f64 x #s(literal 3 binary64))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 6 binary64)))) x)) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* -1 (pow x 3)))) |
#s(approx (- x (pow x 3)) (pow.f64 (neg.f64 x) #s(literal 3 binary64))) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* (pow x 3) (- (/ 1 (pow x 2)) 1)))) |
#s(approx (- x (pow x 3)) (*.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal 1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 (/.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (/.f64 #s(literal -1 binary64) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal 1 binary64)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64)))) (neg.f64 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (/.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 6 binary64))) (-.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal 1 binary64)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))))) x)) |
#s(approx (- x (pow x 3)) #s(hole binary64 (* -1 (* (pow x 3) (- 1 (/ 1 (pow x 2))))))) |
#s(approx (- x (pow x 3)) (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) (pow.f64 x #s(literal 3 binary64)))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 21 |
| 0 | 11 | 21 |
| 1 | 54 | 21 |
| 0 | 411 | 20 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
(pow.f64 x #s(literal 3 binary64)) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 x #s(literal 6 binary64)))) (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 x #s(literal 9 binary64)))) (neg.f64 (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64)))))) |
(/.f64 (-.f64 (*.f64 x x) (pow.f64 x #s(literal 6 binary64))) (+.f64 (pow.f64 x #s(literal 3 binary64)) x)) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 x #s(literal 9 binary64))) (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64))))) |
(-.f64 (/.f64 (*.f64 x x) (+.f64 (pow.f64 x #s(literal 3 binary64)) x)) (/.f64 (pow.f64 x #s(literal 6 binary64)) (+.f64 (pow.f64 x #s(literal 3 binary64)) x))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64))))) (/.f64 (pow.f64 x #s(literal 9 binary64)) (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64)))))) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
(+.f64 x (*.f64 (neg.f64 (pow.f64 x #s(literal 3/2 binary64))) (pow.f64 x #s(literal 3/2 binary64)))) |
(+.f64 x (*.f64 (neg.f64 (*.f64 x x)) x)) |
(+.f64 x (*.f64 (neg.f64 x) (*.f64 x x))) |
(*.f64 (*.f64 x (neg.f64 x)) (neg.f64 x)) |
(*.f64 (*.f64 x (fabs.f64 x)) (fabs.f64 x)) |
(*.f64 (neg.f64 (pow.f64 x #s(literal 3/2 binary64))) (neg.f64 (pow.f64 x #s(literal 3/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 x #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 x #s(literal 3/2 binary64)))) |
(*.f64 (pow.f64 x #s(literal 3/2 binary64)) (pow.f64 x #s(literal 3/2 binary64))) |
(*.f64 (neg.f64 x) (*.f64 (neg.f64 x) x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) x)) |
(*.f64 (*.f64 x x) x) |
(*.f64 x (*.f64 x x)) |
(pow.f64 (exp.f64 (log.f64 x)) #s(literal 3 binary64)) |
(pow.f64 (pow.f64 x #s(literal 3/2 binary64)) #s(literal 2 binary64)) |
(pow.f64 (*.f64 x x) #s(literal 3/2 binary64)) |
(pow.f64 x #s(literal 3 binary64)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) (sinh.f64 (*.f64 (log.f64 x) #s(literal 3 binary64)))) |
Compiled 801 to 165 computations (79.4% saved)
6 alts after pruning (1 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 41 | 1 | 42 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 5 | 5 |
| Total | 42 | 6 | 48 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 74.9% | (/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
| ✓ | 25.2% | (/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
| ✓ | 49.6% | #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
| ✓ | 50.4% | #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
| ▶ | 51.1% | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
| ✓ | 51.8% | #s(approx (/ x (+ (* x x) 1)) x) |
Compiled 69 to 45 computations (34.8% saved)
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 x x) | |
| cost-diff | 0 | (-.f64 x (*.f64 (*.f64 x x) x)) | |
| cost-diff | 0 | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) | |
| cost-diff | 2 | (*.f64 (*.f64 x x) x) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 31 |
| 0 | 12 | 31 |
| 1 | 23 | 25 |
| 2 | 64 | 25 |
| 3 | 142 | 25 |
| 4 | 269 | 25 |
| 5 | 588 | 25 |
| 6 | 4321 | 25 |
| 0 | 8506 | 24 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
(-.f64 x (*.f64 (*.f64 x x) x)) |
x |
(*.f64 (*.f64 x x) x) |
(*.f64 x x) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(-.f64 x (*.f64 (*.f64 x x) x)) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
x |
(*.f64 (*.f64 x x) x) |
(pow.f64 x #s(literal 3 binary64)) |
(*.f64 x x) |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 x x) | |
| accuracy | 0.0078125 | (-.f64 x (*.f64 (*.f64 x x) x)) | |
| accuracy | 0.08203125 | (*.f64 (*.f64 x x) x) | |
| accuracy | 31.274179523830327 | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
| 13.0ms | 256× | 0 | valid |
Compiled 25 to 9 computations (64% saved)
ival-mult: 3.0ms (39.9% of total)ival-div: 2.0ms (26.6% of total)ival-sub: 1.0ms (13.3% of total)ival-add: 1.0ms (13.3% 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) x) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
(-.f64 x (*.f64 (*.f64 x x) x)) |
(*.f64 x x) |
| Outputs |
|---|
#s(approx (* (* x x) x) #s(hole binary64 (pow x 3))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 x)) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* -1 (pow x 3)))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* (pow x 3) (- (/ 1 (pow x 2)) 1)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* -1 (* (pow x 3) (- 1 (/ 1 (pow x 2))))))) |
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | ((* (* x x) x) (/ x (+ (* x x) 1)) (- x (* (* x x) x)) (* x x)) |
| 1.0ms | x | @ | inf | ((* (* x x) x) (/ x (+ (* x x) 1)) (- x (* (* x x) x)) (* x x)) |
| 1.0ms | x | @ | 0 | ((* (* x x) x) (/ x (+ (* x x) 1)) (- x (* (* x x) x)) (* x x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 71 | 306 |
| 1 | 167 | 293 |
| 2 | 474 | 293 |
| 3 | 2099 | 290 |
| 0 | 8609 | 275 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (* (* x x) x) #s(hole binary64 (pow x 3))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 x)) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* -1 (pow x 3)))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* (pow x 3) (- (/ 1 (pow x 2)) 1)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* -1 (* (pow x 3) (- 1 (/ 1 (pow x 2))))))) |
| Outputs |
|---|
#s(approx (* (* x x) x) #s(hole binary64 (pow x 3))) |
#s(approx (* (* x x) x) (pow.f64 x #s(literal 3 binary64))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 x)) |
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (pow x 2) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (fma.f64 x x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 1 (* -1 (pow x 2)))) 1)))))) |
#s(approx (/ x (+ (* x x) 1)) (fma.f64 (fma.f64 (-.f64 x (pow.f64 x #s(literal 3 binary64))) x #s(literal -1 binary64)) (pow.f64 x #s(literal 3 binary64)) x)) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 x)) |
#s(approx (- x (* (* x x) x)) x) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* x (+ 1 (* -1 (pow x 2)))))) |
#s(approx (- x (* (* x x) x)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (* x x) #s(hole binary64 (pow x 2))) |
#s(approx (* x x) (*.f64 x x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ 1 x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- 1 (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (/ 1 (pow x 2))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) x)) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (/ (- (+ 1 (/ 1 (pow x 4))) (+ (/ 1 (pow x 2)) (/ 1 (pow x 6)))) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 6 binary64)))) x)) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* -1 (pow x 3)))) |
#s(approx (- x (* (* x x) x)) (pow.f64 (neg.f64 x) #s(literal 3 binary64))) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* (pow x 3) (- (/ 1 (pow x 2)) 1)))) |
#s(approx (- x (* (* x x) x)) (*.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal 1 binary64)) (pow.f64 x #s(literal 3 binary64)))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) 1) x)))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 (/.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 3 binary64))) (/.f64 #s(literal -1 binary64) x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (/ 1 (pow x 2)) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal 1 binary64)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64)))) (neg.f64 x))) |
#s(approx (/ x (+ (* x x) 1)) #s(hole binary64 (* -1 (/ (- (+ (/ 1 (pow x 2)) (/ 1 (pow x 6))) (+ 1 (/ 1 (pow x 4)))) x)))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 (/.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 6 binary64))) (-.f64 (-.f64 (/.f64 (/.f64 #s(literal 1 binary64) x) x) #s(literal 1 binary64)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))))) x)) |
#s(approx (- x (* (* x x) x)) #s(hole binary64 (* -1 (* (pow x 3) (- 1 (/ 1 (pow x 2))))))) |
#s(approx (- x (* (* x x) x)) (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 (/.f64 #s(literal 1 binary64) x) x)) (pow.f64 x #s(literal 3 binary64)))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 30 |
| 0 | 12 | 24 |
| 1 | 52 | 24 |
| 0 | 393 | 23 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 (*.f64 x x) x) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
(-.f64 x (*.f64 (*.f64 x x) x)) |
(*.f64 x x) |
| Outputs |
|---|
(*.f64 (*.f64 x (fabs.f64 x)) (fabs.f64 x)) |
(*.f64 (pow.f64 x #s(literal 3/2 binary64)) (pow.f64 x #s(literal 3/2 binary64))) |
(*.f64 (*.f64 (neg.f64 x) x) (neg.f64 x)) |
(*.f64 (neg.f64 x) (*.f64 (neg.f64 x) x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) x)) |
(*.f64 (*.f64 x x) x) |
(*.f64 x (*.f64 x x)) |
(pow.f64 x #s(literal 3 binary64)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 3 binary64))) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
(*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x) |
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (neg.f64 (pow.f64 x #s(literal 3 binary64))) #s(literal 3 binary64))) (fma.f64 x x (-.f64 (pow.f64 x #s(literal 6 binary64)) (*.f64 x (neg.f64 (pow.f64 x #s(literal 3 binary64))))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 x #s(literal 6 binary64)))) (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) x))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 x #s(literal 9 binary64)))) (neg.f64 (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64)))))) |
(/.f64 (-.f64 (*.f64 x x) (pow.f64 x #s(literal 6 binary64))) (+.f64 (pow.f64 x #s(literal 3 binary64)) x)) |
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 x #s(literal 9 binary64))) (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64))))) |
(fma.f64 (*.f64 (neg.f64 x) x) x x) |
(fma.f64 x (*.f64 (neg.f64 x) x) x) |
(-.f64 (/.f64 (*.f64 x x) (+.f64 (pow.f64 x #s(literal 3 binary64)) x)) (/.f64 (pow.f64 x #s(literal 6 binary64)) (+.f64 (pow.f64 x #s(literal 3 binary64)) x))) |
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64))))) (/.f64 (pow.f64 x #s(literal 9 binary64)) (fma.f64 x x (+.f64 (pow.f64 x #s(literal 6 binary64)) (pow.f64 x #s(literal 4 binary64)))))) |
(-.f64 x (pow.f64 x #s(literal 3 binary64))) |
(+.f64 (neg.f64 (pow.f64 x #s(literal 3 binary64))) x) |
(+.f64 x (*.f64 (neg.f64 x) (*.f64 x x))) |
(+.f64 x (neg.f64 (pow.f64 x #s(literal 3 binary64)))) |
(*.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64))) |
(*.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64))) |
(*.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64))) |
(*.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64))) |
(*.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 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64))) |
(*.f64 (neg.f64 x) (neg.f64 x)) |
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 x) (fabs.f64 x)) |
(*.f64 #s(literal 1 binary64) (*.f64 x x)) |
(*.f64 (*.f64 x x) #s(literal 1 binary64)) |
(*.f64 x (*.f64 x #s(literal 1 binary64))) |
(*.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)) |
(fabs.f64 (*.f64 x x)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 2 binary64))) |
Compiled 1 171 to 244 computations (79.2% saved)
7 alts after pruning (1 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 61 | 1 | 62 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 5 | 5 |
| Total | 61 | 7 | 68 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 74.9% | (/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
| ✓ | 25.2% | (/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
| ✓ | 49.6% | #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
| ✓ | 50.4% | #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
| ✓ | 51.1% | #s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
| 51.1% | #s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) | |
| ✓ | 51.8% | #s(approx (/ x (+ (* x x) 1)) x) |
Compiled 188 to 86 computations (54.3% saved)
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (pow.f64 x #s(literal 3 binary64)))) |
| Outputs |
|---|
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x)) |
2 calls:
| 3.0ms | x |
| 3.0ms | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.9% | 2 | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| 100.0% | 2 | x |
Compiled 8 to 6 computations (25% saved)
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
(/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| Outputs |
|---|
(/.f64 x (fma.f64 x x #s(literal 1 binary64))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
1 calls:
| 2.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 2 | x |
Compiled 1 to 1 computations (0% saved)
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
(/.f64 x #s(approx (+ (* x x) 1) (*.f64 x x))) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
2 calls:
| 8.0ms | x |
| 2.0ms | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 81.6% | 4 | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| 99.0% | 2 | x |
Compiled 8 to 6 computations (25% saved)
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
1 calls:
| 2.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.0% | 2 | x |
Compiled 1 to 1 computations (0% saved)
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
#s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x)) |
1 calls:
| 1.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.5% | 2 | x |
Compiled 1 to 1 computations (0% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
| Outputs |
|---|
#s(approx (/ x (+ (* x x) 1)) x) |
2 calls:
| 1.0ms | x |
| 1.0ms | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.8% | 1 | (/.f64 x (+.f64 (*.f64 x x) #s(literal 1 binary64))) |
| 51.8% | 1 | x |
Compiled 8 to 6 computations (25% saved)
| 1× | binary-search |
| 1× | predicate-same |
| Time | Left | Right |
|---|---|---|
| 1.0ms | 7913.573294084999 | 167222.066959367 |
| 1.0ms | 16× | 0 | valid |
Compiled 33 to 26 computations (21.2% saved)
ival-div: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)ival-add: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-mult: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | predicate-same |
| Time | Left | Right |
|---|---|---|
| 1.0ms | 6132732.760920031 | 7.649585088288519e+23 |
| 1.0ms | 16× | 0 | valid |
Compiled 27 to 23 computations (14.8% saved)
ival-div: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)ival-add: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-mult: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 9.0ms | 0.012310832682871588 | 18.37504024598954 |
| 5.0ms | 128× | 0 | valid |
Compiled 218 to 161 computations (26.1% saved)
ival-div: 1.0ms (40.8% of total)ival-add: 1.0ms (40.8% of total)ival-mult: 1.0ms (40.8% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)exact: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 1.0ms | 0.012310832682871588 | 18.37504024598954 |
Compiled 218 to 169 computations (22.5% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 4.0ms | 0.012310832682871588 | 18.37504024598954 |
| 2.0ms | 48× | 0 | valid |
Compiled 170 to 137 computations (19.4% saved)
ival-div: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)ival-add: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-mult: 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 | 34 | 141 |
| 1 | 51 | 141 |
| 2 | 89 | 141 |
| 3 | 136 | 141 |
| 4 | 195 | 141 |
| 5 | 431 | 141 |
| 6 | 3032 | 141 |
| 7 | 7012 | 141 |
| 1× | node limit |
| Inputs |
|---|
(if (<=.f64 x #s(literal 10000 binary64)) (/.f64 x (fma.f64 x x #s(literal 1 binary64))) #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x))) |
(if (<=.f64 x #s(literal 10000000 binary64)) (/.f64 x (fma.f64 x x #s(literal 1 binary64))) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
(if (<=.f64 x #s(literal 7656119366529843/9007199254740992 binary64)) #s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
(if (<=.f64 x #s(literal 7656119366529843/9007199254740992 binary64)) #s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
(if (<=.f64 x #s(literal 1 binary64)) #s(approx (/ x (+ (* x x) 1)) x) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (/ x (+ (* x x) 1)) x) |
| Outputs |
|---|
(if (<=.f64 x #s(literal 10000 binary64)) (/.f64 x (fma.f64 x x #s(literal 1 binary64))) #s(approx (/ x (+ (* x x) 1)) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x x))) x))) |
(if (<=.f64 x #s(literal 10000000 binary64)) (/.f64 x (fma.f64 x x #s(literal 1 binary64))) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
(if (<=.f64 x #s(literal 7656119366529843/9007199254740992 binary64)) #s(approx (/ x (+ (* x x) 1)) (-.f64 x (*.f64 (*.f64 x x) x))) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
(if (<=.f64 x #s(literal 7656119366529843/9007199254740992 binary64)) #s(approx (/ x (+ (* x x) 1)) (*.f64 (fma.f64 (neg.f64 x) x #s(literal 1 binary64)) x)) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
(if (<=.f64 x #s(literal 1 binary64)) #s(approx (/ x (+ (* x x) 1)) x) #s(approx (/ x (+ (* x x) 1)) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (/ x (+ (* x x) 1)) x) |
| 1× | fuel |
Compiled 141 to 35 computations (75.2% saved)
Compiled 364 to 122 computations (66.5% saved)
Loading profile data...