
Time bar (total: 4.9s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 25.7% | 74.3% | 0% | 0% | 0% | 0 |
| 100% | 25.7% | 0% | 74.3% | 0% | 0% | 0% | 1 |
Compiled 25 to 18 computations (28% saved)
| 1.4s | 5 137× | 0 | valid |
| 391.0ms | 2 543× | 1 | valid |
| 175.0ms | 576× | 2 | valid |
ival-pow2: 1.3s (80.7% of total)ival-add: 119.0ms (7.6% of total)adjust: 117.0ms (7.5% of total)ival-sub: 62.0ms (4% of total)ival-assert: 3.0ms (0.2% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 70 | 1 | (1.2256559543115053e-118 5.937451827388107e-121) | 0 | - | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| 0 | 0 | - | 0 | - | eps |
| 0 | 0 | - | 0 | - | (pow.f64 x #s(literal 2 binary64)) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) |
| 0 | 0 | - | 0 | - | (+.f64 x eps) |
| 0 | 0 | - | 0 | - | x |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
-.f64 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) | cancellation | 71 | 0 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 70 | 0 |
| - | 1 | 185 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 70 | 0 | 0 |
| - | 1 | 0 | 185 |
| number | freq |
|---|---|
| 0 | 185 |
| 1 | 71 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 27.0ms | 312× | 0 | valid |
| 26.0ms | 176× | 1 | valid |
| 5.0ms | 24× | 2 | valid |
Compiled 59 to 25 computations (57.6% saved)
ival-pow2: 19.0ms (54.5% of total)adjust: 7.0ms (20.1% of total)ival-add: 5.0ms (14.3% of total)ival-sub: 4.0ms (11.5% of total)ival-true: 1.0ms (2.9% of total)ival-assert: 0.0ms (0% of total)exact: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 22 | 64 |
| 1 | 34 | 60 |
| 2 | 118 | 60 |
| 3 | 553 | 58 |
| 4 | 1771 | 44 |
| 5 | 5314 | 44 |
| 0 | 7 | 9 |
| 0 | 11 | 9 |
| 1 | 16 | 9 |
| 2 | 44 | 9 |
| 3 | 157 | 9 |
| 4 | 570 | 7 |
| 5 | 1812 | 7 |
| 0 | 8588 | 6 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| Outputs |
|---|
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
Compiled 9 to 7 computations (22.2% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 76.8% | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
Compiled 9 to 7 computations (22.2% saved)
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (pow.f64 x #s(literal 2 binary64)) | |
| cost-diff | 0 | (+.f64 x eps) | |
| cost-diff | 0 | (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) | |
| cost-diff | 3 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 23 |
| 0 | 11 | 23 |
| 1 | 16 | 23 |
| 2 | 44 | 23 |
| 3 | 157 | 23 |
| 4 | 570 | 21 |
| 5 | 1812 | 21 |
| 0 | 8588 | 20 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
(pow.f64 (+.f64 x eps) #s(literal 2 binary64)) |
(+.f64 x eps) |
x |
eps |
#s(literal 2 binary64) |
(pow.f64 x #s(literal 2 binary64)) |
| Outputs |
|---|
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(pow.f64 (+.f64 x eps) #s(literal 2 binary64)) |
(pow.f64 (+.f64 eps x) #s(literal 2 binary64)) |
(+.f64 x eps) |
(+.f64 eps x) |
x |
eps |
#s(literal 2 binary64) |
(pow.f64 x #s(literal 2 binary64)) |
(*.f64 x x) |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (pow.f64 x #s(literal 2 binary64)) | |
| accuracy | 0.0 | (+.f64 x eps) | |
| accuracy | 0.029628759768442016 | (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) | |
| accuracy | 14.753625464374428 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| 11.0ms | 88× | 1 | valid |
| 9.0ms | 156× | 0 | valid |
| 2.0ms | 12× | 2 | valid |
Compiled 25 to 9 computations (64% saved)
ival-pow2: 7.0ms (51.5% of total)adjust: 3.0ms (22.1% of total)ival-add: 2.0ms (14.7% of total)ival-sub: 2.0ms (14.7% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Inputs |
|---|
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
(pow.f64 (+.f64 x eps) #s(literal 2 binary64)) |
(+.f64 x eps) |
(pow.f64 x #s(literal 2 binary64)) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (pow eps 2))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* x (+ x (* 2 eps))) (pow eps 2)))) |
#s(approx (+ x eps) #s(hole binary64 eps)) |
#s(approx (+ x eps) #s(hole binary64 (+ eps x))) |
#s(approx (pow x 2) #s(hole binary64 (pow x 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (pow x 2))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (* 2 (/ eps x)))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (+ (* 2 (/ eps x)) (/ (pow eps 2) (pow x 2))))))) |
#s(approx (+ x eps) #s(hole binary64 x)) |
#s(approx (+ x eps) #s(hole binary64 (* x (+ 1 (/ eps x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ (+ (* -2 eps) (* -1 (/ (pow eps 2) x))) x)))))) |
#s(approx (+ x eps) #s(hole binary64 (* -1 (* x (- (* -1 (/ eps x)) 1))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* 2 (* eps x)) (pow x 2)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* eps (+ eps (* 2 x))) (pow x 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (+ (* 2 (/ x eps)) (/ (pow x 2) (pow eps 2))))))) |
#s(approx (+ x eps) #s(hole binary64 (* eps (+ 1 (/ x eps))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (* -1 (/ (+ (* -2 x) (* -1 (/ (pow x 2) eps))) eps)))))) |
#s(approx (+ x eps) #s(hole binary64 (* -1 (* eps (- (* -1 (/ x eps)) 1))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (pow (+ x eps) 2) (+ x eps) (pow x 2)) |
| 1.0ms | x | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (pow (+ x eps) 2) (+ x eps) (pow x 2)) |
| 1.0ms | x | @ | 0 | ((- (pow (+ x eps) 2) (pow x 2)) (pow (+ x eps) 2) (+ x eps) (pow x 2)) |
| 1.0ms | eps | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (pow (+ x eps) 2) (+ x eps) (pow x 2)) |
| 1.0ms | eps | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (pow (+ x eps) 2) (+ x eps) (pow x 2)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 99 | 415 |
| 1 | 271 | 401 |
| 2 | 924 | 377 |
| 3 | 4052 | 377 |
| 0 | 8199 | 364 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (pow eps 2))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* x (+ x (* 2 eps))) (pow eps 2)))) |
#s(approx (+ x eps) #s(hole binary64 eps)) |
#s(approx (+ x eps) #s(hole binary64 (+ eps x))) |
#s(approx (pow x 2) #s(hole binary64 (pow x 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (pow x 2))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (* 2 (/ eps x)))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (+ (* 2 (/ eps x)) (/ (pow eps 2) (pow x 2))))))) |
#s(approx (+ x eps) #s(hole binary64 x)) |
#s(approx (+ x eps) #s(hole binary64 (* x (+ 1 (/ eps x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ (+ (* -2 eps) (* -1 (/ (pow eps 2) x))) x)))))) |
#s(approx (+ x eps) #s(hole binary64 (* -1 (* x (- (* -1 (/ eps x)) 1))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* 2 (* eps x)) (pow x 2)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* eps (+ eps (* 2 x))) (pow x 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (+ (* 2 (/ x eps)) (/ (pow x 2) (pow eps 2))))))) |
#s(approx (+ x eps) #s(hole binary64 (* eps (+ 1 (/ x eps))))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (* -1 (/ (+ (* -2 x) (* -1 (/ (pow x 2) eps))) eps)))))) |
#s(approx (+ x eps) #s(hole binary64 (* -1 (* eps (- (* -1 (/ x eps)) 1))))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (pow eps 2))) |
#s(approx (pow (+ x eps) 2) (*.f64 eps eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (pow (+ x eps) 2) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* x (+ x (* 2 eps))) (pow eps 2)))) |
#s(approx (pow (+ x eps) 2) (pow.f64 (+.f64 eps x) #s(literal 2 binary64))) |
#s(approx (+ x eps) #s(hole binary64 eps)) |
#s(approx (+ x eps) eps) |
#s(approx (+ x eps) #s(hole binary64 (+ eps x))) |
#s(approx (+ x eps) (+.f64 eps x)) |
#s(approx (pow x 2) #s(hole binary64 (pow x 2))) |
#s(approx (pow x 2) (*.f64 x x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) (-.f64 (/.f64 eps x) #s(literal -2 binary64)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (pow x 2))) |
#s(approx (pow (+ x eps) 2) (*.f64 x x)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (* 2 (/ eps x)))))) |
#s(approx (pow (+ x eps) 2) (*.f64 (*.f64 (fma.f64 (/.f64 eps x) #s(literal 2 binary64) #s(literal 1 binary64)) x) x)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (+ (* 2 (/ eps x)) (/ (pow eps 2) (pow x 2))))))) |
#s(approx (pow (+ x eps) 2) (*.f64 (fma.f64 (/.f64 eps x) (-.f64 (/.f64 eps x) #s(literal -2 binary64)) #s(literal 1 binary64)) (*.f64 x x))) |
#s(approx (+ x eps) #s(hole binary64 x)) |
#s(approx (+ x eps) x) |
#s(approx (+ x eps) #s(hole binary64 (* x (+ 1 (/ eps x))))) |
#s(approx (+ x eps) (fma.f64 (/.f64 eps x) x x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) (-.f64 (/.f64 eps x) #s(literal -2 binary64)))) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow x 2) (+ 1 (* -1 (/ (+ (* -2 eps) (* -1 (/ (pow eps 2) x))) x)))))) |
#s(approx (pow (+ x eps) 2) (*.f64 (fma.f64 (/.f64 eps x) (-.f64 (/.f64 eps x) #s(literal -2 binary64)) #s(literal 1 binary64)) (*.f64 x x))) |
#s(approx (+ x eps) #s(hole binary64 (* -1 (* x (- (* -1 (/ eps x)) 1))))) |
#s(approx (+ x eps) (*.f64 (neg.f64 x) (-.f64 (/.f64 (neg.f64 eps) x) #s(literal 1 binary64)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* 2 (* eps x)) (pow x 2)))) |
#s(approx (pow (+ x eps) 2) (*.f64 (fma.f64 #s(literal 2 binary64) eps x) x)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (+ (* eps (+ eps (* 2 x))) (pow x 2)))) |
#s(approx (pow (+ x eps) 2) (pow.f64 (+.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 (fma.f64 (/.f64 x eps) #s(literal 2 binary64) #s(literal 1 binary64)) eps) eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (pow (+ x eps) 2) (*.f64 (*.f64 (fma.f64 (/.f64 x eps) #s(literal 2 binary64) #s(literal 1 binary64)) eps) eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (+ (* 2 (/ x eps)) (/ (pow x 2) (pow eps 2))))))) |
#s(approx (pow (+ x eps) 2) (*.f64 (fma.f64 (/.f64 x eps) (-.f64 (/.f64 x eps) #s(literal -2 binary64)) #s(literal 1 binary64)) (*.f64 eps eps))) |
#s(approx (+ x eps) #s(hole binary64 (* eps (+ 1 (/ x eps))))) |
#s(approx (+ x eps) (fma.f64 (/.f64 x eps) eps eps)) |
#s(approx (pow (+ x eps) 2) #s(hole binary64 (* (pow eps 2) (+ 1 (* -1 (/ (+ (* -2 x) (* -1 (/ (pow x 2) eps))) eps)))))) |
#s(approx (pow (+ x eps) 2) (*.f64 (fma.f64 (/.f64 x eps) (-.f64 (/.f64 x eps) #s(literal -2 binary64)) #s(literal 1 binary64)) (*.f64 eps eps))) |
#s(approx (+ x eps) #s(hole binary64 (* -1 (* eps (- (* -1 (/ x eps)) 1))))) |
#s(approx (+ x eps) (*.f64 (neg.f64 eps) (-.f64 (/.f64 (neg.f64 x) eps) #s(literal 1 binary64)))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 20 |
| 0 | 11 | 20 |
| 1 | 51 | 20 |
| 0 | 386 | 20 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
(pow.f64 (+.f64 x eps) #s(literal 2 binary64)) |
(+.f64 x eps) |
(pow.f64 x #s(literal 2 binary64)) |
| Outputs |
|---|
(*.f64 (+.f64 (+.f64 eps x) x) (-.f64 (+.f64 eps x) x)) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 eps x) #s(literal 4 binary64)) (pow.f64 x #s(literal 4 binary64)))) (neg.f64 (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 eps x) #s(literal 6 binary64)) (pow.f64 x #s(literal 6 binary64)))) (neg.f64 (fma.f64 (*.f64 x x) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64))) (pow.f64 (+.f64 eps x) #s(literal 4 binary64))))) |
(/.f64 (-.f64 (pow.f64 (+.f64 eps x) #s(literal 4 binary64)) (pow.f64 x #s(literal 4 binary64))) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64)))) |
(/.f64 (-.f64 (pow.f64 (+.f64 eps x) #s(literal 6 binary64)) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 x x) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64))) (pow.f64 (+.f64 eps x) #s(literal 4 binary64)))) |
(fma.f64 (neg.f64 (+.f64 eps x)) (neg.f64 (+.f64 eps x)) (*.f64 (neg.f64 x) x)) |
(fma.f64 (fabs.f64 (+.f64 eps x)) (fabs.f64 (+.f64 eps x)) (*.f64 (neg.f64 x) x)) |
(fma.f64 (exp.f64 (log.f64 (+.f64 eps x))) (exp.f64 (log.f64 (+.f64 eps x))) (*.f64 (neg.f64 x) x)) |
(fma.f64 (+.f64 eps x) (+.f64 eps x) (*.f64 (neg.f64 x) x)) |
(-.f64 (/.f64 (pow.f64 (+.f64 eps x) #s(literal 4 binary64)) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 4 binary64)) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64))))) |
(-.f64 (/.f64 (pow.f64 (+.f64 eps x) #s(literal 6 binary64)) (fma.f64 (*.f64 x x) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64))) (pow.f64 (+.f64 eps x) #s(literal 4 binary64)))) (/.f64 (pow.f64 x #s(literal 6 binary64)) (fma.f64 (*.f64 x x) (fma.f64 x x (pow.f64 (+.f64 eps x) #s(literal 2 binary64))) (pow.f64 (+.f64 eps x) #s(literal 4 binary64))))) |
(-.f64 (pow.f64 (+.f64 eps x) #s(literal 2 binary64)) (*.f64 x x)) |
(+.f64 (pow.f64 (+.f64 eps x) #s(literal 2 binary64)) (*.f64 (neg.f64 x) x)) |
(*.f64 (neg.f64 (+.f64 eps x)) (neg.f64 (+.f64 eps x))) |
(*.f64 (fabs.f64 (+.f64 eps x)) (fabs.f64 (+.f64 eps x))) |
(*.f64 (exp.f64 (log.f64 (+.f64 eps x))) (exp.f64 (log.f64 (+.f64 eps x)))) |
(*.f64 (+.f64 eps x) (+.f64 eps x)) |
(pow.f64 (exp.f64 (log.f64 (+.f64 eps x))) #s(literal 2 binary64)) |
(pow.f64 (pow.f64 (+.f64 eps x) #s(literal 2 binary64)) #s(literal 1 binary64)) |
(pow.f64 (+.f64 eps x) #s(literal 2 binary64)) |
(/.f64 (*.f64 (*.f64 (+.f64 eps x) (-.f64 x eps)) (+.f64 eps x)) (-.f64 x eps)) |
(/.f64 (*.f64 (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 eps x)) (fma.f64 eps (-.f64 eps x) (*.f64 x x))) |
(/.f64 (*.f64 (+.f64 eps x) (*.f64 (+.f64 eps x) (-.f64 x eps))) (-.f64 x eps)) |
(/.f64 (*.f64 (+.f64 eps x) (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 eps (-.f64 eps x) (*.f64 x x))) |
(/.f64 (*.f64 (*.f64 (+.f64 eps x) (-.f64 x eps)) (*.f64 (+.f64 eps x) (-.f64 x eps))) (*.f64 (-.f64 x eps) (-.f64 x eps))) |
(/.f64 (*.f64 (*.f64 (+.f64 eps x) (-.f64 x eps)) (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (*.f64 (-.f64 x eps) (fma.f64 eps (-.f64 eps x) (*.f64 x x)))) |
(/.f64 (*.f64 (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (*.f64 (+.f64 eps x) (-.f64 x eps))) (*.f64 (fma.f64 eps (-.f64 eps x) (*.f64 x x)) (-.f64 x eps))) |
(/.f64 (*.f64 (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (*.f64 (fma.f64 eps (-.f64 eps x) (*.f64 x x)) (fma.f64 eps (-.f64 eps x) (*.f64 x x)))) |
(fma.f64 (+.f64 eps x) eps (*.f64 (+.f64 eps x) x)) |
(fma.f64 (+.f64 eps x) x (*.f64 (+.f64 eps x) eps)) |
(fma.f64 eps (+.f64 eps x) (*.f64 x (+.f64 eps x))) |
(fma.f64 x (+.f64 eps x) (*.f64 eps (+.f64 eps x))) |
(exp.f64 (*.f64 (log.f64 (+.f64 eps x)) #s(literal 2 binary64))) |
(+.f64 (*.f64 eps (+.f64 eps x)) (*.f64 x (+.f64 eps x))) |
(+.f64 (*.f64 x (+.f64 eps x)) (*.f64 eps (+.f64 eps x))) |
(+.f64 (*.f64 (+.f64 eps x) eps) (*.f64 (+.f64 eps x) x)) |
(+.f64 (*.f64 (+.f64 eps x) x) (*.f64 (+.f64 eps x) eps)) |
(+.f64 (cosh.f64 (*.f64 (log.f64 (+.f64 eps x)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (+.f64 eps x)) #s(literal 2 binary64)))) |
(*.f64 (pow.f64 (+.f64 eps x) #s(literal 1/2 binary64)) (pow.f64 (+.f64 eps x) #s(literal 1/2 binary64))) |
(pow.f64 (+.f64 eps x) #s(literal 1 binary64)) |
(/.f64 (-.f64 (*.f64 eps eps) (*.f64 x x)) (-.f64 eps x)) |
(/.f64 (neg.f64 (*.f64 (+.f64 eps x) (-.f64 x eps))) (neg.f64 (-.f64 x eps))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 eps (-.f64 eps x) (*.f64 x x)))) |
(/.f64 (*.f64 (+.f64 eps x) (-.f64 x eps)) (-.f64 x eps)) |
(/.f64 (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 eps eps (-.f64 (*.f64 x x) (*.f64 eps x)))) |
(/.f64 (+.f64 (pow.f64 eps #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 eps (-.f64 eps x) (*.f64 x x))) |
(-.f64 (/.f64 (*.f64 x x) (-.f64 x eps)) (/.f64 (*.f64 eps eps) (-.f64 x eps))) |
(exp.f64 (*.f64 (log.f64 (+.f64 eps x)) #s(literal 1 binary64))) |
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 eps (-.f64 eps x) (*.f64 x x))) (/.f64 (pow.f64 eps #s(literal 3 binary64)) (fma.f64 eps (-.f64 eps x) (*.f64 x x)))) |
(+.f64 eps x) |
(+.f64 x eps) |
(*.f64 (neg.f64 x) (neg.f64 x)) |
(*.f64 (fabs.f64 x) (fabs.f64 x)) |
(*.f64 (exp.f64 (log.f64 x)) (exp.f64 (log.f64 x))) |
(*.f64 x x) |
(pow.f64 (exp.f64 (log.f64 x)) #s(literal 2 binary64)) |
(pow.f64 (*.f64 x x) #s(literal 1 binary64)) |
(pow.f64 x #s(literal 2 binary64)) |
(exp.f64 (*.f64 (log.f64 x) #s(literal 2 binary64))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 x) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 x) #s(literal 2 binary64)))) |
Compiled 1 390 to 277 computations (80.1% saved)
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 79 | 3 | 82 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 80 | 3 | 83 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
| ▶ | 64.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
| ▶ | 74.8% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
Compiled 44 to 31 computations (29.5% saved)
Found 8 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (fma.f64 #s(literal 2 binary64) x eps) | |
| cost-diff | 0 | (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) | |
| cost-diff | 0 | (*.f64 eps x) | |
| cost-diff | 0 | (*.f64 (*.f64 eps x) #s(literal 2 binary64)) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) | |
| cost-diff | 0 | (*.f64 eps eps) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 15 | 72 |
| 0 | 21 | 72 |
| 1 | 38 | 72 |
| 2 | 106 | 72 |
| 3 | 318 | 69 |
| 4 | 938 | 63 |
| 5 | 3274 | 63 |
| 0 | 8212 | 63 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
(*.f64 eps eps) |
eps |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
(*.f64 (*.f64 eps x) #s(literal 2 binary64)) |
(*.f64 eps x) |
eps |
x |
#s(literal 2 binary64) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(fma.f64 #s(literal 2 binary64) x eps) |
#s(literal 2 binary64) |
x |
eps |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
(*.f64 eps eps) |
eps |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
(*.f64 (*.f64 eps x) #s(literal 2 binary64)) |
(*.f64 eps x) |
eps |
x |
#s(literal 2 binary64) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(fma.f64 #s(literal 2 binary64) x eps) |
#s(literal 2 binary64) |
x |
eps |
Found 8 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (fma.f64 #s(literal 2 binary64) x eps) | |
| accuracy | 0.0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) | |
| accuracy | 0.00390625 | (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) | |
| accuracy | 0.0 | (*.f64 eps x) | |
| accuracy | 0.02734375 | (*.f64 (*.f64 eps x) #s(literal 2 binary64)) | |
| accuracy | 22.991792412081494 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) | |
| accuracy | 0.0 | (*.f64 eps eps) | |
| accuracy | 16.110001370322124 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
| 20.0ms | 156× | 0 | valid |
| 19.0ms | 88× | 1 | valid |
| 3.0ms | 12× | 2 | valid |
Compiled 59 to 15 computations (74.6% saved)
ival-pow2: 10.0ms (36.3% of total)ival-mult: 7.0ms (25.4% of total)adjust: 4.0ms (14.5% of total)ival-add: 3.0ms (10.9% of total)ival-sub: 2.0ms (7.3% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
(*.f64 eps eps) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
(*.f64 (*.f64 eps x) #s(literal 2 binary64)) |
(*.f64 eps x) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(fma.f64 #s(literal 2 binary64) x eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (* (* eps x) 2) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* eps x) #s(hole binary64 (* eps x))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (+ eps (* 2 x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* 2 x))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* x (+ 2 (/ eps x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* -1 (* x (- (* -1 (/ eps x)) 2))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* eps (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* -1 (* eps (- (* -2 (/ x eps)) 1))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 3.0ms | eps | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (* eps eps) (- (pow (+ x eps) 2) (pow x 2)) (* (* eps x) 2) (* eps x) (- (pow (+ x eps) 2) (pow x 2)) (* (+ (* 2 x) eps) eps) (+ (* 2 x) eps)) |
| 2.0ms | x | @ | 0 | ((- (pow (+ x eps) 2) (pow x 2)) (* eps eps) (- (pow (+ x eps) 2) (pow x 2)) (* (* eps x) 2) (* eps x) (- (pow (+ x eps) 2) (pow x 2)) (* (+ (* 2 x) eps) eps) (+ (* 2 x) eps)) |
| 1.0ms | eps | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (* eps eps) (- (pow (+ x eps) 2) (pow x 2)) (* (* eps x) 2) (* eps x) (- (pow (+ x eps) 2) (pow x 2)) (* (+ (* 2 x) eps) eps) (+ (* 2 x) eps)) |
| 1.0ms | x | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (* eps eps) (- (pow (+ x eps) 2) (pow x 2)) (* (* eps x) 2) (* eps x) (- (pow (+ x eps) 2) (pow x 2)) (* (+ (* 2 x) eps) eps) (+ (* 2 x) eps)) |
| 1.0ms | eps | @ | 0 | ((- (pow (+ x eps) 2) (pow x 2)) (* eps eps) (- (pow (+ x eps) 2) (pow x 2)) (* (* eps x) 2) (* eps x) (- (pow (+ x eps) 2) (pow x 2)) (* (+ (* 2 x) eps) eps) (+ (* 2 x) eps)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 70 | 322 |
| 1 | 170 | 322 |
| 2 | 508 | 322 |
| 3 | 1811 | 294 |
| 4 | 7985 | 294 |
| 0 | 8051 | 258 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (* (* eps x) 2) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* eps x) #s(hole binary64 (* eps x))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (+ eps (* 2 x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* 2 x))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* x (+ 2 (/ eps x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* -1 (* x (- (* -1 (/ eps x)) 2))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* eps (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* -1 (* eps (- (* -2 (/ x eps)) 1))))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* (* eps x) 2) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* (* eps x) 2) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (* eps x) #s(hole binary64 (* eps x))) |
#s(approx (* eps x) (*.f64 eps x)) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 eps)) |
#s(approx (+ (* 2 x) eps) eps) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (+ eps (* 2 x)))) |
#s(approx (+ (* 2 x) eps) (fma.f64 #s(literal 2 binary64) x eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* 2 x))) |
#s(approx (+ (* 2 x) eps) (*.f64 #s(literal 2 binary64) x)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* x (+ 2 (/ eps x))))) |
#s(approx (+ (* 2 x) eps) (fma.f64 #s(literal 2 binary64) x eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* -1 (* x (- (* -1 (/ eps x)) 2))))) |
#s(approx (+ (* 2 x) eps) (fma.f64 #s(literal 2 binary64) x eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* eps eps) (*.f64 eps eps)) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* (+ (* 2 x) eps) eps) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* eps (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* 2 x) eps) (fma.f64 #s(literal 2 binary64) x eps)) |
#s(approx (+ (* 2 x) eps) #s(hole binary64 (* -1 (* eps (- (* -2 (/ x eps)) 1))))) |
#s(approx (+ (* 2 x) eps) (fma.f64 #s(literal 2 binary64) x eps)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 15 | 65 |
| 0 | 21 | 65 |
| 1 | 83 | 65 |
| 0 | 592 | 65 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
(*.f64 eps eps) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
(*.f64 (*.f64 eps x) #s(literal 2 binary64)) |
(*.f64 eps x) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(fma.f64 #s(literal 2 binary64) x eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
(*.f64 (neg.f64 (neg.f64 eps)) (neg.f64 (neg.f64 eps))) |
(*.f64 (neg.f64 (fabs.f64 eps)) (neg.f64 (fabs.f64 eps))) |
(*.f64 (fabs.f64 (fabs.f64 eps)) (fabs.f64 (fabs.f64 eps))) |
(*.f64 (pow.f64 eps #s(literal 1 binary64)) (pow.f64 eps #s(literal 1 binary64))) |
(*.f64 (pow.f64 eps #s(literal 1 binary64)) eps) |
(*.f64 (neg.f64 eps) (neg.f64 eps)) |
(*.f64 (fabs.f64 eps) (fabs.f64 eps)) |
(*.f64 eps eps) |
(pow.f64 (neg.f64 eps) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 eps) #s(literal 2 binary64)) |
(pow.f64 eps #s(literal 2 binary64)) |
(neg.f64 (*.f64 eps (neg.f64 eps))) |
(neg.f64 (*.f64 (neg.f64 eps) eps)) |
(fabs.f64 (*.f64 eps eps)) |
(exp.f64 (*.f64 (log.f64 eps) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(*.f64 (*.f64 #s(literal 2 binary64) eps) x) |
(*.f64 (*.f64 eps #s(literal 2 binary64)) x) |
(*.f64 (*.f64 #s(literal 2 binary64) x) eps) |
(*.f64 (*.f64 eps x) #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) (*.f64 eps x)) |
(*.f64 eps (*.f64 #s(literal 2 binary64) x)) |
(*.f64 x (*.f64 #s(literal 2 binary64) eps)) |
(*.f64 x (*.f64 eps #s(literal 2 binary64))) |
(fma.f64 #s(literal 1 binary64) (*.f64 eps x) (*.f64 #s(literal 1 binary64) (*.f64 eps x))) |
(fma.f64 (*.f64 eps x) #s(literal 1 binary64) (*.f64 (*.f64 eps x) #s(literal 1 binary64))) |
(fma.f64 eps x (*.f64 eps x)) |
(fma.f64 x eps (*.f64 eps x)) |
(+.f64 (*.f64 #s(literal 1 binary64) (*.f64 eps x)) (*.f64 #s(literal 1 binary64) (*.f64 eps x))) |
(+.f64 (*.f64 (*.f64 eps x) #s(literal 1 binary64)) (*.f64 (*.f64 eps x) #s(literal 1 binary64))) |
(+.f64 (*.f64 eps x) (*.f64 eps x)) |
(*.f64 eps x) |
(*.f64 x eps) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(*.f64 eps (fma.f64 #s(literal 2 binary64) x eps)) |
(/.f64 (*.f64 (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (neg.f64 eps))) eps) (-.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(/.f64 (*.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 3 binary64))) eps) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (-.f64 eps (*.f64 #s(literal 2 binary64) x))))) |
(/.f64 (*.f64 eps (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (neg.f64 eps)))) (-.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(/.f64 (*.f64 eps (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 3 binary64)))) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (-.f64 eps (*.f64 #s(literal 2 binary64) x))))) |
(fma.f64 (*.f64 #s(literal 2 binary64) eps) x (*.f64 eps eps)) |
(fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) |
(fma.f64 (neg.f64 (neg.f64 eps)) (neg.f64 (neg.f64 eps)) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (neg.f64 (fabs.f64 eps)) (neg.f64 (fabs.f64 eps)) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (fabs.f64 (fabs.f64 eps)) (fabs.f64 (fabs.f64 eps)) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (pow.f64 eps #s(literal 1 binary64)) (pow.f64 eps #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (pow.f64 eps #s(literal 1 binary64)) eps (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (neg.f64 eps) (neg.f64 eps) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (fabs.f64 eps) (fabs.f64 eps) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) eps (*.f64 eps eps)) |
(fma.f64 (*.f64 eps x) #s(literal 2 binary64) (*.f64 eps eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 eps x) (*.f64 eps eps)) |
(fma.f64 eps (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps)) |
(fma.f64 eps eps (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(fma.f64 x (*.f64 #s(literal 2 binary64) eps) (*.f64 eps eps)) |
(fma.f64 x (*.f64 eps #s(literal 2 binary64)) (*.f64 eps eps)) |
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) eps) (*.f64 eps eps)) |
(+.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(/.f64 (-.f64 (*.f64 eps eps) (*.f64 #s(literal 4 binary64) (*.f64 x x))) (-.f64 eps (*.f64 #s(literal 2 binary64) x))) |
(/.f64 (neg.f64 (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (neg.f64 eps)))) (neg.f64 (-.f64 (*.f64 #s(literal 2 binary64) x) eps))) |
(/.f64 (neg.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 3 binary64)))) (neg.f64 (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (-.f64 eps (*.f64 #s(literal 2 binary64) x)))))) |
(/.f64 (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (neg.f64 eps))) (-.f64 (*.f64 #s(literal 2 binary64) x) eps)) |
(/.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 3 binary64))) (fma.f64 eps eps (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 x x)) (*.f64 (*.f64 #s(literal 2 binary64) x) eps)))) |
(/.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 3 binary64))) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (-.f64 eps (*.f64 #s(literal 2 binary64) x))))) |
(fma.f64 (pow.f64 (+.f64 eps x) #s(literal 1/2 binary64)) (pow.f64 (+.f64 eps x) #s(literal 1/2 binary64)) x) |
(fma.f64 #s(literal 2 binary64) x eps) |
(fma.f64 x #s(literal 2 binary64) eps) |
(-.f64 (/.f64 (*.f64 #s(literal 4 binary64) (*.f64 x x)) (-.f64 (*.f64 #s(literal 2 binary64) x) eps)) (/.f64 (*.f64 eps eps) (-.f64 (*.f64 #s(literal 2 binary64) x) eps))) |
(-.f64 eps (*.f64 #s(literal -2 binary64) x)) |
(-.f64 eps (*.f64 (neg.f64 x) #s(literal 2 binary64))) |
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 2 binary64) x) #s(literal 3 binary64)) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (-.f64 eps (*.f64 #s(literal 2 binary64) x))))) (/.f64 (pow.f64 eps #s(literal 3 binary64)) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (*.f64 eps (-.f64 eps (*.f64 #s(literal 2 binary64) x)))))) |
(+.f64 (*.f64 #s(literal 2 binary64) x) eps) |
(+.f64 (+.f64 eps x) x) |
(+.f64 eps (*.f64 #s(literal 2 binary64) x)) |
(+.f64 x (+.f64 eps x)) |
Compiled 1 610 to 242 computations (85% saved)
4 alts after pruning (2 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 81 | 2 | 83 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 2 | 3 |
| Done | 0 | 0 | 0 |
| Total | 82 | 4 | 86 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) |
| ✓ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
| ▶ | 64.1% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
| ✓ | 74.8% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
Compiled 62 to 43 computations (30.6% saved)
Found 7 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 eps eps) | |
| cost-diff | 0 | (*.f64 eps #s(literal 2 binary64)) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) | |
| cost-diff | 2 | (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) | |
| cost-diff | 0 | (*.f64 eps #s(literal 2 binary64)) | |
| cost-diff | 0 | (*.f64 (*.f64 eps #s(literal 2 binary64)) x) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 61 |
| 0 | 17 | 61 |
| 1 | 33 | 59 |
| 2 | 105 | 59 |
| 3 | 342 | 59 |
| 4 | 927 | 55 |
| 5 | 3443 | 55 |
| 0 | 8633 | 51 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
(*.f64 (*.f64 eps #s(literal 2 binary64)) x) |
(*.f64 eps #s(literal 2 binary64)) |
eps |
#s(literal 2 binary64) |
x |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) |
(fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) |
(*.f64 eps #s(literal 2 binary64)) |
eps |
#s(literal 2 binary64) |
x |
(*.f64 eps eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(*.f64 (*.f64 eps #s(literal 2 binary64)) x) |
(*.f64 (*.f64 #s(literal 2 binary64) eps) x) |
(*.f64 eps #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) eps) |
eps |
#s(literal 2 binary64) |
x |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(*.f64 eps #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) eps) |
eps |
#s(literal 2 binary64) |
x |
(*.f64 eps eps) |
Found 7 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) | |
| accuracy | 0.0 | (*.f64 eps eps) | |
| accuracy | 0.0 | (*.f64 eps #s(literal 2 binary64)) | |
| accuracy | 0.0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) | |
| accuracy | 0.0 | (*.f64 (*.f64 eps #s(literal 2 binary64)) x) | |
| accuracy | 0.0 | (*.f64 eps #s(literal 2 binary64)) | |
| accuracy | 22.991792412081494 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
| 38.0ms | 156× | 0 | valid |
| 34.0ms | 88× | 1 | valid |
| 3.0ms | 12× | 2 | valid |
Compiled 49 to 13 computations (73.5% saved)
ival-mult: 29.0ms (63.1% of total)ival-pow2: 7.0ms (15.2% of total)adjust: 4.0ms (8.7% of total)ival-add: 4.0ms (8.7% of total)ival-sub: 2.0ms (4.3% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
(*.f64 (*.f64 eps #s(literal 2 binary64)) x) |
(*.f64 eps #s(literal 2 binary64)) |
(fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) |
(*.f64 eps eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (* (* eps 2) x) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (pow eps 2))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps 2) #s(hole binary64 (* 2 eps))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | eps | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (* eps 2) x) (* eps 2) (+ (* (* eps 2) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | eps | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (* eps 2) x) (* eps 2) (+ (* (* eps 2) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | x | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (* eps 2) x) (* eps 2) (+ (* (* eps 2) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | x | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (* eps 2) x) (* eps 2) (+ (* (* eps 2) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | eps | @ | 0 | ((- (pow (+ x eps) 2) (pow x 2)) (* (* eps 2) x) (* eps 2) (+ (* (* eps 2) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 51 | 259 |
| 1 | 132 | 259 |
| 2 | 421 | 259 |
| 3 | 1632 | 231 |
| 4 | 7079 | 231 |
| 0 | 8290 | 207 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (* (* eps 2) x) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (pow eps 2))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps 2) #s(hole binary64 (* 2 eps))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* (* eps 2) x) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* (* eps 2) x) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* eps 2) #s(hole binary64 (* 2 eps))) |
#s(approx (* eps 2) (*.f64 #s(literal 2 binary64) eps)) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* eps eps) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 (fma.f64 (/.f64 x eps) #s(literal 2 binary64) #s(literal 1 binary64)) eps) eps)) |
#s(approx (+ (* (* eps 2) x) (* eps eps)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 (fma.f64 (/.f64 x eps) #s(literal 2 binary64) #s(literal 1 binary64)) eps) eps)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 52 |
| 0 | 17 | 52 |
| 1 | 80 | 50 |
| 0 | 641 | 48 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
(*.f64 (*.f64 eps #s(literal 2 binary64)) x) |
(*.f64 eps #s(literal 2 binary64)) |
(fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) |
(*.f64 eps eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(*.f64 (*.f64 #s(literal 2 binary64) x) eps) |
(*.f64 (*.f64 eps x) #s(literal 2 binary64)) |
(*.f64 (*.f64 #s(literal 2 binary64) eps) x) |
(*.f64 #s(literal 2 binary64) (*.f64 eps x)) |
(*.f64 eps (*.f64 #s(literal 2 binary64) x)) |
(*.f64 x (*.f64 #s(literal 2 binary64) eps)) |
(*.f64 #s(literal 2 binary64) eps) |
(*.f64 eps #s(literal 2 binary64)) |
(fma.f64 #s(literal 1 binary64) eps (*.f64 #s(literal 1 binary64) eps)) |
(fma.f64 eps #s(literal 1 binary64) (*.f64 eps #s(literal 1 binary64))) |
(+.f64 (*.f64 #s(literal 1 binary64) eps) (*.f64 #s(literal 1 binary64) eps)) |
(+.f64 (*.f64 eps #s(literal 1 binary64)) (*.f64 eps #s(literal 1 binary64))) |
(+.f64 eps eps) |
(*.f64 eps (+.f64 eps (*.f64 #s(literal 2 binary64) x))) |
(*.f64 eps (fma.f64 #s(literal 2 binary64) x eps)) |
(/.f64 (-.f64 (pow.f64 eps #s(literal 4 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64))) (-.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 eps) eps) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)) (+.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) (*.f64 (neg.f64 eps) eps))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)) (pow.f64 eps #s(literal 4 binary64)))) (neg.f64 (*.f64 eps (-.f64 (*.f64 #s(literal 2 binary64) x) eps)))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 eps #s(literal 6 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 eps eps) (-.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)) (pow.f64 eps #s(literal 4 binary64))) (*.f64 eps (-.f64 (*.f64 #s(literal 2 binary64) x) eps))) |
(/.f64 (+.f64 (pow.f64 eps #s(literal 6 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 3 binary64))) (+.f64 (pow.f64 eps #s(literal 4 binary64)) (-.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)) (*.f64 (*.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) eps) eps)))) |
(/.f64 (+.f64 (pow.f64 eps #s(literal 6 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 3 binary64))) (fma.f64 (*.f64 eps eps) (-.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)))) |
(fma.f64 (neg.f64 (neg.f64 eps)) (neg.f64 (neg.f64 eps)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (neg.f64 (fabs.f64 eps)) (neg.f64 (fabs.f64 eps)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (fabs.f64 (fabs.f64 eps)) (fabs.f64 (fabs.f64 eps)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (pow.f64 eps #s(literal 1 binary64)) (pow.f64 eps #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (pow.f64 eps #s(literal 1 binary64)) eps (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) eps (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) eps (*.f64 eps eps)) |
(fma.f64 (*.f64 eps x) #s(literal 2 binary64) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 eps x) #s(literal 2 binary64) (*.f64 eps eps)) |
(fma.f64 (neg.f64 eps) (neg.f64 eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (fabs.f64 eps) (fabs.f64 eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 (*.f64 #s(literal 2 binary64) eps) x (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) eps) x (*.f64 eps eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 eps x) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 eps x) (*.f64 eps eps)) |
(fma.f64 eps (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 eps (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps)) |
(fma.f64 eps eps (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(fma.f64 x (*.f64 #s(literal 2 binary64) eps) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 x (*.f64 #s(literal 2 binary64) eps) (*.f64 eps eps)) |
(-.f64 (/.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)) (*.f64 eps (-.f64 (*.f64 #s(literal 2 binary64) x) eps))) (/.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 eps (-.f64 (*.f64 #s(literal 2 binary64) x) eps)))) |
(-.f64 (*.f64 eps eps) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) eps)) x)) |
(-.f64 (*.f64 eps eps) (*.f64 (neg.f64 eps) (*.f64 #s(literal 2 binary64) x))) |
(-.f64 (*.f64 eps eps) (*.f64 (neg.f64 x) (*.f64 #s(literal 2 binary64) eps))) |
(-.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) (*.f64 (neg.f64 (neg.f64 eps)) (neg.f64 eps))) |
(-.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) (*.f64 (neg.f64 (fabs.f64 eps)) (fabs.f64 eps))) |
(-.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) (*.f64 (neg.f64 eps) eps)) |
(+.f64 (/.f64 (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 3 binary64)) (fma.f64 (*.f64 eps eps) (-.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64)))) (/.f64 (pow.f64 eps #s(literal 6 binary64)) (fma.f64 (*.f64 eps eps) (-.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) (pow.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) #s(literal 2 binary64))))) |
(+.f64 (*.f64 eps eps) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) eps) x) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps (fma.f64 #s(literal 2 binary64) x eps))) |
(*.f64 (neg.f64 (neg.f64 eps)) (neg.f64 (neg.f64 eps))) |
(*.f64 (neg.f64 (fabs.f64 eps)) (neg.f64 (fabs.f64 eps))) |
(*.f64 (fabs.f64 (fabs.f64 eps)) (fabs.f64 (fabs.f64 eps))) |
(*.f64 (pow.f64 eps #s(literal 1 binary64)) (pow.f64 eps #s(literal 1 binary64))) |
(*.f64 (pow.f64 eps #s(literal 1 binary64)) eps) |
(*.f64 (neg.f64 eps) (neg.f64 eps)) |
(*.f64 (fabs.f64 eps) (fabs.f64 eps)) |
(*.f64 eps eps) |
(pow.f64 (neg.f64 eps) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 eps) #s(literal 2 binary64)) |
(pow.f64 eps #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 eps) eps)) |
(fabs.f64 (*.f64 eps eps)) |
(exp.f64 (*.f64 (log.f64 eps) #s(literal 2 binary64))) |
Compiled 1 786 to 247 computations (86.2% saved)
4 alts after pruning (2 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 82 | 2 | 84 |
| Fresh | 0 | 0 | 0 |
| Picked | 2 | 0 | 2 |
| Done | 0 | 2 | 2 |
| Total | 84 | 4 | 88 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
| ✓ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
| ▶ | 64.1% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
| ✓ | 74.8% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
Compiled 62 to 41 computations (33.9% saved)
Found 7 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 eps eps) | |
| cost-diff | 0 | (+.f64 eps eps) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) | |
| cost-diff | 2 | (fma.f64 (+.f64 eps eps) x (*.f64 eps eps)) | |
| cost-diff | 0 | (+.f64 eps eps) | |
| cost-diff | 0 | (*.f64 (+.f64 eps eps) x) | |
| cost-diff | 0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 59 |
| 0 | 17 | 59 |
| 1 | 31 | 59 |
| 2 | 92 | 57 |
| 3 | 295 | 57 |
| 4 | 879 | 53 |
| 5 | 3035 | 53 |
| 0 | 8190 | 49 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
(*.f64 (+.f64 eps eps) x) |
(+.f64 eps eps) |
eps |
x |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
(fma.f64 (+.f64 eps eps) x (*.f64 eps eps)) |
(+.f64 eps eps) |
eps |
x |
(*.f64 eps eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 #s(literal 2 binary64) eps) x)) |
(*.f64 (+.f64 eps eps) x) |
(*.f64 (*.f64 #s(literal 2 binary64) eps) x) |
(+.f64 eps eps) |
(*.f64 #s(literal 2 binary64) eps) |
eps |
x |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(fma.f64 (+.f64 eps eps) x (*.f64 eps eps)) |
(*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps) |
(+.f64 eps eps) |
(*.f64 #s(literal 2 binary64) eps) |
eps |
x |
(*.f64 eps eps) |
Found 7 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (fma.f64 (+.f64 eps eps) x (*.f64 eps eps)) | |
| accuracy | 0.0 | (+.f64 eps eps) | |
| accuracy | 0.0 | (*.f64 eps eps) | |
| accuracy | 0.0 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) | |
| accuracy | 0.0 | (+.f64 eps eps) | |
| accuracy | 0.0 | (*.f64 (+.f64 eps eps) x) | |
| accuracy | 22.991792412081494 | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
| 22.0ms | 88× | 1 | valid |
| 18.0ms | 156× | 0 | valid |
| 3.0ms | 12× | 2 | valid |
Compiled 47 to 12 computations (74.5% saved)
ival-pow2: 7.0ms (33% of total)ival-add: 5.0ms (23.6% of total)adjust: 4.0ms (18.9% of total)ival-mult: 4.0ms (18.9% of total)ival-sub: 2.0ms (9.4% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
(*.f64 (+.f64 eps eps) x) |
(+.f64 eps eps) |
(fma.f64 (+.f64 eps eps) x (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
(*.f64 eps eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (* (+ eps eps) x) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (pow eps 2))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (+ eps eps) #s(hole binary64 (* 2 eps))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | eps | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (+ eps eps) x) (+ eps eps) (+ (* (+ eps eps) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | eps | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (+ eps eps) x) (+ eps eps) (+ (* (+ eps eps) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | x | @ | inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (+ eps eps) x) (+ eps eps) (+ (* (+ eps eps) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | x | @ | -inf | ((- (pow (+ x eps) 2) (pow x 2)) (* (+ eps eps) x) (+ eps eps) (+ (* (+ eps eps) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
| 1.0ms | eps | @ | 0 | ((- (pow (+ x eps) 2) (pow x 2)) (* (+ eps eps) x) (+ eps eps) (+ (* (+ eps eps) x) (* eps eps)) (- (pow (+ x eps) 2) (pow x 2)) (* eps eps)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 51 | 275 |
| 1 | 130 | 259 |
| 2 | 420 | 259 |
| 3 | 1628 | 231 |
| 4 | 7099 | 231 |
| 0 | 8314 | 207 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (* (+ eps eps) x) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (pow eps 2))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (+ eps eps) #s(hole binary64 (* 2 eps))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* (+ eps eps) x) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (* (+ eps eps) x) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (pow eps 2))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (+ (* 2 (* eps x)) (pow eps 2)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* 2 (* eps x)))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* x (+ (* 2 eps) (/ (pow eps 2) x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* -1 (* x (+ (* -2 eps) (* -1 (/ (pow eps 2) x))))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (+ eps eps) #s(hole binary64 (* 2 eps))) |
#s(approx (+ eps eps) (*.f64 #s(literal 2 binary64) eps)) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* eps (+ eps (* 2 x))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (* eps eps) #s(hole binary64 (pow eps 2))) |
#s(approx (* eps eps) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 (fma.f64 (/.f64 x eps) #s(literal 2 binary64) #s(literal 1 binary64)) eps) eps)) |
#s(approx (+ (* (+ eps eps) x) (* eps eps)) #s(hole binary64 (* (pow eps 2) (+ 1 (* 2 (/ x eps)))))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 (fma.f64 (/.f64 x eps) #s(literal 2 binary64) #s(literal 1 binary64)) eps) eps)) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 52 |
| 0 | 17 | 52 |
| 1 | 84 | 42 |
| 0 | 744 | 42 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
(*.f64 (+.f64 eps eps) x) |
(+.f64 eps eps) |
(fma.f64 (+.f64 eps eps) x (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
(*.f64 eps eps) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 #s(literal 2 binary64) x)) |
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) (neg.f64 eps)) (neg.f64 eps)) |
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) (fabs.f64 eps)) (fabs.f64 eps)) |
(*.f64 (*.f64 eps eps) (*.f64 #s(literal 2 binary64) x)) |
(*.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps)) |
(*.f64 (*.f64 #s(literal 2 binary64) x) eps) |
(*.f64 #s(literal 2 binary64) (*.f64 x (*.f64 eps eps))) |
(*.f64 #s(literal 2 binary64) (*.f64 eps x)) |
(*.f64 #s(literal 2 binary64) x) |
(*.f64 x (*.f64 #s(literal 2 binary64) (*.f64 eps eps))) |
(*.f64 x #s(literal 2 binary64)) |
(/.f64 (*.f64 #s(literal 0 binary64) x) #s(literal 0 binary64)) |
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 eps #s(literal 3 binary64))) x) (fma.f64 eps eps #s(literal 0 binary64))) |
(/.f64 (*.f64 x #s(literal 0 binary64)) #s(literal 0 binary64)) |
(/.f64 (*.f64 x (*.f64 #s(literal 2 binary64) (pow.f64 eps #s(literal 3 binary64)))) (fma.f64 eps eps #s(literal 0 binary64))) |
(fma.f64 eps x (*.f64 eps x)) |
(fma.f64 x eps (*.f64 eps x)) |
(+.f64 (*.f64 eps x) (*.f64 eps x)) |
#s(literal 2 binary64) |
(/.f64 (-.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 #s(literal 4 binary64) (*.f64 x x))) (-.f64 (*.f64 eps eps) (*.f64 #s(literal 2 binary64) x))) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(literal 2 binary64) x) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 eps) eps) #s(literal 3 binary64))) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (+.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 eps) eps))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 x x)) (pow.f64 eps #s(literal 4 binary64)))) (neg.f64 (fma.f64 #s(literal 2 binary64) x (*.f64 (neg.f64 eps) eps)))) |
(/.f64 (neg.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 6 binary64)))) (neg.f64 (fma.f64 #s(literal 4 binary64) (*.f64 x x) (-.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 #s(literal 2 binary64) x))))) |
(/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 x x)) (pow.f64 eps #s(literal 4 binary64))) (fma.f64 #s(literal 2 binary64) x (*.f64 (neg.f64 eps) eps))) |
(/.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 6 binary64))) (+.f64 (pow.f64 eps #s(literal 4 binary64)) (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 x x)) (*.f64 #s(literal 2 binary64) x)))) |
(/.f64 (fma.f64 #s(literal 8 binary64) (pow.f64 x #s(literal 3 binary64)) (pow.f64 eps #s(literal 6 binary64))) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (-.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 #s(literal 2 binary64) x)))) |
(fma.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) (neg.f64 eps)) (neg.f64 eps) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) (neg.f64 eps)) (neg.f64 eps) (*.f64 eps eps)) |
(fma.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) (fabs.f64 eps)) (fabs.f64 eps) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 (*.f64 #s(literal 2 binary64) x) (fabs.f64 eps)) (fabs.f64 eps) (*.f64 eps eps)) |
(fma.f64 (neg.f64 (neg.f64 eps)) (neg.f64 (neg.f64 eps)) (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (neg.f64 (fabs.f64 eps)) (neg.f64 (fabs.f64 eps)) (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (fabs.f64 (fabs.f64 eps)) (fabs.f64 (fabs.f64 eps)) (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (pow.f64 eps #s(literal 1 binary64)) (pow.f64 eps #s(literal 1 binary64)) (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (pow.f64 eps #s(literal 1 binary64)) eps (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (neg.f64 eps) (neg.f64 eps) (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (fabs.f64 eps) (fabs.f64 eps) (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 (*.f64 eps eps) (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 eps eps) (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps) (*.f64 eps eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) eps (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 (*.f64 #s(literal 2 binary64) x) eps (*.f64 eps eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 x (*.f64 eps eps)) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 x (*.f64 eps eps)) (*.f64 eps eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 eps x) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 #s(literal 2 binary64) (*.f64 eps x) (*.f64 eps eps)) |
(fma.f64 #s(literal 2 binary64) x (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 #s(literal 2 binary64) x (*.f64 eps eps)) |
(fma.f64 eps eps (*.f64 #s(literal 2 binary64) x)) |
(fma.f64 x (*.f64 #s(literal 2 binary64) (*.f64 eps eps)) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 x (*.f64 #s(literal 2 binary64) (*.f64 eps eps)) (*.f64 eps eps)) |
(fma.f64 x #s(literal 2 binary64) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(fma.f64 x #s(literal 2 binary64) (*.f64 eps eps)) |
(-.f64 (/.f64 (*.f64 #s(literal 4 binary64) (*.f64 x x)) (fma.f64 #s(literal 2 binary64) x (*.f64 (neg.f64 eps) eps))) (/.f64 (pow.f64 eps #s(literal 4 binary64)) (fma.f64 #s(literal 2 binary64) x (*.f64 (neg.f64 eps) eps)))) |
(-.f64 (*.f64 eps eps) (*.f64 #s(literal -2 binary64) x)) |
(-.f64 (*.f64 eps eps) (*.f64 (neg.f64 x) #s(literal 2 binary64))) |
(-.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 (neg.f64 eps)) (neg.f64 eps))) |
(-.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 (fabs.f64 eps)) (fabs.f64 eps))) |
(-.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 eps) eps)) |
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 2 binary64) x) #s(literal 3 binary64)) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (-.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 #s(literal 2 binary64) x)))) (/.f64 (pow.f64 eps #s(literal 6 binary64)) (fma.f64 #s(literal 4 binary64) (*.f64 x x) (-.f64 (pow.f64 eps #s(literal 4 binary64)) (*.f64 #s(literal 2 binary64) x))))) |
(+.f64 (*.f64 eps eps) (*.f64 #s(literal 2 binary64) x)) |
(+.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 (neg.f64 (neg.f64 eps)) eps)) |
(+.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 #s(literal 2 binary64) x (*.f64 eps eps))) |
(*.f64 (neg.f64 (neg.f64 eps)) (neg.f64 (neg.f64 eps))) |
(*.f64 (neg.f64 (fabs.f64 eps)) (neg.f64 (fabs.f64 eps))) |
(*.f64 (fabs.f64 (fabs.f64 eps)) (fabs.f64 (fabs.f64 eps))) |
(*.f64 (pow.f64 eps #s(literal 1 binary64)) (pow.f64 eps #s(literal 1 binary64))) |
(*.f64 (pow.f64 eps #s(literal 1 binary64)) eps) |
(*.f64 (neg.f64 eps) (neg.f64 eps)) |
(*.f64 (fabs.f64 eps) (fabs.f64 eps)) |
(*.f64 eps eps) |
(pow.f64 (neg.f64 eps) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 eps) #s(literal 2 binary64)) |
(pow.f64 eps #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 eps) eps)) |
(fabs.f64 (*.f64 eps eps)) |
(exp.f64 (*.f64 (log.f64 eps) #s(literal 2 binary64))) |
Compiled 1 771 to 262 computations (85.2% saved)
5 alts after pruning (1 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 87 | 1 | 88 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 2 | 2 |
| Total | 87 | 5 | 92 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
| ✓ | 100.0% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
| ✓ | 64.1% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
| 5.4% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 x #s(literal 2 binary64))) | |
| ✓ | 74.8% | #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
Compiled 207 to 83 computations (59.9% saved)
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 x #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (*.f64 eps #s(literal 2 binary64)) x (*.f64 eps eps))) |
(-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
3 calls:
| 9.0ms | eps |
| 3.0ms | x |
| 2.0ms | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| 100.0% | 1 | x |
| 100.0% | 1 | eps |
Compiled 11 to 11 computations (0% saved)
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 x #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
3 calls:
| 2.0ms | eps |
| 2.0ms | x |
| 2.0ms | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| 100.0% | 1 | x |
| 100.0% | 1 | eps |
Compiled 11 to 11 computations (0% saved)
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 x #s(literal 2 binary64))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps #s(literal 2 binary64)) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (*.f64 eps x) #s(literal 2 binary64))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
3 calls:
| 2.0ms | x |
| 2.0ms | eps |
| 2.0ms | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 97.5% | 2 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| 92.2% | 3 | x |
| 85.4% | 3 | eps |
Compiled 11 to 11 computations (0% saved)
Total -44.5b remaining (-276.1%)
Threshold costs -44.5b (-276.1%)
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 x #s(literal 2 binary64))) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
3 calls:
| 3.0ms | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
| 1.0ms | x |
| 1.0ms | eps |
| Accuracy | Segments | Branch |
|---|---|---|
| 74.8% | 1 | eps |
| 74.8% | 1 | x |
| 74.8% | 1 | (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) |
Compiled 11 to 11 computations (0% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 0.0 | 4.849497e-317 |
Compiled 12 to 12 computations (0% saved)
Useful iterations: 4 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 24 | 87 |
| 1 | 31 | 87 |
| 2 | 62 | 87 |
| 3 | 181 | 87 |
| 4 | 606 | 77 |
| 5 | 2081 | 77 |
| 6 | 7836 | 77 |
| 1× | node limit |
| Inputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(if (<=.f64 (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) #s(literal 0 binary64)) #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
| Outputs |
|---|
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (fma.f64 (+.f64 eps eps) x (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (fma.f64 #s(literal 2 binary64) x eps) eps)) |
(if (<=.f64 (-.f64 (pow.f64 (+.f64 x eps) #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) #s(literal 0 binary64)) #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 (+.f64 eps eps) x)) #s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps))) |
#s(approx (- (pow (+ x eps) 2) (pow x 2)) (*.f64 eps eps)) |
| 1× | fuel |
Compiled 87 to 25 computations (71.3% saved)
Compiled 192 to 64 computations (66.7% saved)
Loading profile data...