Data.Random.Distribution.T:$ccdf from random-fu-0.2.6.2

Time bar (total: 2.8s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated

analyze15.0ms (0.5%)

Memory
0.4MiB live, 42.1MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
50%50%50%0.1%0%0%0%3
50%50%50%0.1%0%0%0%4
75%74.9%25%0.1%0%0%0%5
75%74.9%25%0.1%0%0%0%6
87.5%87.4%12.5%0.1%0%0%0%7
87.5%87.4%12.5%0.1%0%0%0%8
93.8%93.7%6.2%0.1%0%0%0%9
93.8%93.7%6.2%0.1%0%0%0%10
96.9%96.8%3.1%0.1%0%0%0%11
96.9%96.8%3.1%0.1%0%0%0%12
Compiler

Compiled 9 to 7 computations (22.2% saved)

sample835.0ms (29.4%)

Memory
-19.9MiB live, 655.1MiB allocated
Samples
547.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 363.0ms
ival-add: 242.0ms (66.7% of total)
ival-div: 111.0ms (30.6% of total)
ival-true: 6.0ms (1.7% of total)
ival-assert: 3.0ms (0.8% of total)
Bogosity

explain75.0ms (2.7%)

Memory
2.9MiB live, 79.4MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(+.f64 y y)
00-0-(/.f64 (+.f64 x y) (+.f64 y y))
00-0-y
00-0-(+.f64 x y)
00-0-x
Confusion
Predicted +Predicted -
+00
-0256
Precision
0/0
Recall
0/0
Confusion?
Predicted +Predicted MaybePredicted -
+000
-00256
Precision?
0/0
Recall?
0/0
Freqs
test
numberfreq
0256
Total Confusion?
Predicted +Predicted MaybePredicted -
+000
-001
Precision?
0/0
Recall?
0/0
Samples
20.0ms512×0valid
Compiler

Compiled 56 to 24 computations (57.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 9.0ms
ival-add: 5.0ms (54.8% of total)
ival-div: 4.0ms (43.8% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess90.0ms (3.2%)

Memory
11.0MiB live, 56.9MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01541
14235
210635
331035
4126235
5238835
6325235
7380135
8425335
9430335
10433535
11441135
12459535
057
087
1117
2147
3167
0167
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(/.f64 (+.f64 x y) (+.f64 y y))
Outputs
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (/.f64 (+.f64 y x) y) #s(literal 2 binary64))
Compiler

Compiled 7 to 5 computations (28.6% saved)

eval0.0ms (0%)

Memory
0.3MiB live, 0.3MiB allocated
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.6MiB live, 1.6MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(/.f64 (+.f64 x y) (+.f64 y y))
Compiler

Compiled 7 to 5 computations (28.6% saved)

simplify3.0ms (0.1%)

Memory
10.5MiB live, 10.5MiB allocated
Algorithm
egg-herbie
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
cost-diff-384
(/.f64 (+.f64 x y) (+.f64 y y))
cost-diff-128
(+.f64 y y)
cost-diff0
(+.f64 x y)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0515
0815
11115
21415
31615
01615
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(/.f64 (+.f64 x y) (+.f64 y y))
(+.f64 x y)
x
y
(+.f64 y y)
Outputs
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (/.f64 (+.f64 y x) y) #s(literal 2 binary64))
(+.f64 x y)
(+.f64 y x)
x
y
(+.f64 y y)
(*.f64 #s(literal 2 binary64) y)

localize36.0ms (1.3%)

Memory
-15.1MiB live, 24.2MiB allocated
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
accuracy0
(/.f64 (+.f64 x y) (+.f64 y y))
accuracy0
(+.f64 y y)
accuracy0
(+.f64 x y)
Samples
32.0ms256×0valid
Compiler

Compiled 32 to 12 computations (62.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 4.0ms
ival-div: 2.0ms (45% of total)
ival-add: 2.0ms (45% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series5.0ms (0.2%)

Memory
6.0MiB live, 6.0MiB allocated
Counts
3 → 13
Calls
Call 1
Inputs
(+.f64 x y)
(+.f64 y y)
(/.f64 (+.f64 x y) (+.f64 y y))
Outputs
y
(+ x y)
1/2
(+ 1/2 (* 1/2 (/ x y)))
x
(* x (+ 1 (/ y x)))
(* 1/2 (/ x y))
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* 2 y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(* y (+ 1 (/ x y)))
(* -1 (* y (- (* -1 (/ x y)) 1)))
Calls

6 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((+ x y) (+ y y) (/ (+ x y) (+ y y)))
1.0ms
y
@0
((+ x y) (+ y y) (/ (+ x y) (+ y y)))
1.0ms
y
@inf
((+ x y) (+ y y) (/ (+ x y) (+ y y)))
1.0ms
x
@inf
((+ x y) (+ y y) (/ (+ x y) (+ y y)))
1.0ms
x
@-inf
((+ x y) (+ y y) (/ (+ x y) (+ y y)))

simplify111.0ms (3.9%)

Memory
13.8MiB live, 52.2MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
03447
19547
219547
352947
4241747
5482147
6609447
7705047
8757347
0803644
Stop Event
iter limit
node limit
Counts
13 → 11
Calls
Call 1
Inputs
y
(+ x y)
1/2
(+ 1/2 (* 1/2 (/ x y)))
x
(* x (+ 1 (/ y x)))
(* 1/2 (/ x y))
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* 2 y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(* y (+ 1 (/ x y)))
(* -1 (* y (- (* -1 (/ x y)) 1)))
Outputs
y
(+ x y)
(+.f64 y x)
1/2
#s(literal 1/2 binary64)
(+ 1/2 (* 1/2 (/ x y)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
x
(* x (+ 1 (/ y x)))
(+.f64 y x)
(* 1/2 (/ x y))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
(* 2 y)
(*.f64 #s(literal 2 binary64) y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* y (+ 1 (/ x y)))
(+.f64 y x)
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)

rewrite67.0ms (2.3%)

Memory
-6.9MiB live, 32.5MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0513
0813
13813
030513
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
3 → 61
Calls
Call 1
Inputs
(+.f64 x y)
(+.f64 y y)
(/.f64 (+.f64 x y) (+.f64 y y))
Outputs
(*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (/.f64 #s(literal 1 binary64) (-.f64 x y)))
(*.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (-.f64 (*.f64 y y) (*.f64 x x)) (-.f64 y x))
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 x y))) (neg.f64 (-.f64 x y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (-.f64 x y))
(/.f64 #s(literal 1 binary64) (/.f64 (-.f64 x y) (*.f64 (+.f64 y x) (-.f64 x y))))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y (-.f64 y x) (*.f64 x x)) (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 y y (-.f64 (*.f64 x x) (*.f64 y x))))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x y)) (/.f64 (*.f64 y y) (-.f64 x y)))
(+.f64 y x)
(+.f64 x y)
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal -2 binary64) y)
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal -2 binary64) y))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal -2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 y #s(literal 2 binary64))
(pow.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64))
(/.f64 #s(literal 1/2 binary64) y)
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal -2 binary64) y))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal -2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal -2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(neg.f64 (*.f64 #s(literal -2 binary64) y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal -2 binary64) y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
(*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
(*.f64 (*.f64 #s(literal -2 binary64) y) (+.f64 y x))
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(pow.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))) #s(literal -1 binary64))
(/.f64 (/.f64 (+.f64 y x) #s(literal 2 binary64)) y)
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 #s(literal -2 binary64) y)) (-.f64 x y))
(/.f64 (*.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (*.f64 #s(literal -2 binary64) y)) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (*.f64 (+.f64 y x) #s(literal 1 binary64)) (*.f64 #s(literal -2 binary64) y))
(/.f64 (neg.f64 (neg.f64 (+.f64 y x))) (*.f64 #s(literal -2 binary64) y))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) #s(literal 1 binary64)) (*.f64 (-.f64 x y) (*.f64 #s(literal -2 binary64) y)))
(/.f64 (*.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) #s(literal 1 binary64)) (*.f64 (fma.f64 y (-.f64 y x) (*.f64 x x)) (*.f64 #s(literal -2 binary64) y)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x)))))
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 (*.f64 #s(literal -2 binary64) y) (-.f64 x y)))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (*.f64 (*.f64 #s(literal -2 binary64) y) (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
(/.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(neg.f64 (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))

eval6.0ms (0.2%)

Memory
9.8MiB live, 9.8MiB allocated
Compiler

Compiled 801 to 172 computations (78.5% saved)

prune3.0ms (0.1%)

Memory
4.3MiB live, 4.3MiB allocated
Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New62466
Fresh000
Picked011
Done000
Total62567
Accuracy
100.0%
Counts
67 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(/.f64 (+.f64 x y) (+.f64 y y))
1.2%
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
4.3%
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
56.1%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
45.5%
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
Compiler

Compiled 44 to 34 computations (22.7% saved)

simplify118.0ms (4.1%)

Memory
-21.3MiB live, 29.9MiB allocated
Algorithm
egg-herbie
Localize:

Found 11 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 #s(literal -2 binary64) y)
cost-diff0
(+.f64 y x)
cost-diff0
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
cost-diff0
(*.f64 #s(literal -2 binary64) y)
cost-diff0
(+.f64 y x)
cost-diff0
(neg.f64 (+.f64 y x))
cost-diff128
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
cost-diff0
(/.f64 #s(literal 1/2 binary64) y)
cost-diff0
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
cost-diff0
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
cost-diff0
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01671
02371
14471
210370
330970
453070
571870
6134070
7306170
8362370
9372170
10378270
11381570
12381570
13381570
0381568
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(literal 1/2 binary64)
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(/.f64 #s(literal 1/2 binary64) y)
#s(literal 1/2 binary64)
y
x
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
(neg.f64 (+.f64 y x))
(+.f64 y x)
y
x
(*.f64 #s(literal -2 binary64) y)
#s(literal -2 binary64)
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(+.f64 y x)
y
x
(*.f64 #s(literal -2 binary64) y)
#s(literal -2 binary64)
Outputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(literal 1/2 binary64)
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(/.f64 #s(literal 1/2 binary64) y)
#s(literal 1/2 binary64)
y
x
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))
(neg.f64 (+.f64 y x))
(+.f64 y x)
y
x
(*.f64 #s(literal -2 binary64) y)
#s(literal -2 binary64)
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal -2 binary64))
(+.f64 y x)
y
x
(*.f64 #s(literal -2 binary64) y)
#s(literal -2 binary64)

localize79.0ms (2.8%)

Memory
-4.4MiB live, 35.1MiB allocated
Localize:

Found 11 expressions of interest:

NewMetricScoreProgram
accuracy0
(+.f64 y x)
accuracy0
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
accuracy0
(*.f64 #s(literal -2 binary64) y)
accuracy0
(+.f64 y x)
accuracy0
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
accuracy0
(*.f64 #s(literal -2 binary64) y)
accuracy0
(neg.f64 (+.f64 y x))
accuracy0
(/.f64 #s(literal 1/2 binary64) y)
accuracy0.1953125
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
accuracy28.01605946079349
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
accuracy34.8758223084169
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
Samples
70.0ms256×0valid
Compiler

Compiled 136 to 32 computations (76.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 60.0ms
ival-add: 45.0ms (75.6% of total)
ival-mult: 9.0ms (15.1% of total)
ival-div: 3.0ms (5% of total)
ival-neg: 1.0ms (1.7% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series11.0ms (0.4%)

Memory
8.8MiB live, 8.8MiB allocated
Counts
9 → 36
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(/.f64 #s(literal 1/2 binary64) y)
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
(neg.f64 (+.f64 y x))
(+.f64 y x)
(*.f64 #s(literal -2 binary64) y)
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
Outputs
1/2
(+ 1/2 (* 1/2 (/ x y)))
(* 1/2 (/ x y))
(* 2 (pow y 2))
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(* -1 y)
(- (* -1 x) y)
y
(+ x y)
(* -2 (pow y 2))
(+ (* -2 (* x y)) (* -2 (pow y 2)))
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(* 2 (* x y))
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(* -1 x)
(* x (- (* -1 (/ y x)) 1))
x
(* x (+ 1 (/ y x)))
(* -2 (* x y))
(* x (+ (* -2 y) (* -2 (/ (pow y 2) x))))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(* -1 (* x (+ 1 (/ y x))))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* -1 (* x (+ (* 2 y) (* 2 (/ (pow y 2) x)))))
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(/ 1/2 y)
(* y (+ (* 2 x) (* 2 y)))
(- (* -1 y) x)
(* -2 y)
(* y (+ (* -2 x) (* -2 y)))
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(* y (- (* -1 (/ x y)) 1))
(* y (+ 1 (/ x y)))
(* (pow y 2) (- (* -2 (/ x y)) 2))
(* -1 (* y (+ 1 (/ x y))))
(* -1 (* y (- (* -1 (/ x y)) 1)))
Calls

6 calls:

TimeVariablePointExpression
3.0ms
x
@-inf
((/ (+ x y) (+ y y)) (/ (+ x y) (+ y y)) (* (/ 1/2 y) x) (/ 1/2 y) (* (neg (+ y x)) (* -2 y)) (neg (+ y x)) (+ y x) (* -2 y) (* (+ y x) (* -2 y)))
2.0ms
y
@-inf
((/ (+ x y) (+ y y)) (/ (+ x y) (+ y y)) (* (/ 1/2 y) x) (/ 1/2 y) (* (neg (+ y x)) (* -2 y)) (neg (+ y x)) (+ y x) (* -2 y) (* (+ y x) (* -2 y)))
2.0ms
y
@inf
((/ (+ x y) (+ y y)) (/ (+ x y) (+ y y)) (* (/ 1/2 y) x) (/ 1/2 y) (* (neg (+ y x)) (* -2 y)) (neg (+ y x)) (+ y x) (* -2 y) (* (+ y x) (* -2 y)))
2.0ms
y
@0
((/ (+ x y) (+ y y)) (/ (+ x y) (+ y y)) (* (/ 1/2 y) x) (/ 1/2 y) (* (neg (+ y x)) (* -2 y)) (neg (+ y x)) (+ y x) (* -2 y) (* (+ y x) (* -2 y)))
1.0ms
x
@inf
((/ (+ x y) (+ y y)) (/ (+ x y) (+ y y)) (* (/ 1/2 y) x) (/ 1/2 y) (* (neg (+ y x)) (* -2 y)) (neg (+ y x)) (+ y x) (* -2 y) (* (+ y x) (* -2 y)))

simplify105.0ms (3.7%)

Memory
5.1MiB live, 43.8MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
072188
1221168
2563168
31571168
44007168
56159168
08045165
Stop Event
iter limit
node limit
Counts
36 → 34
Calls
Call 1
Inputs
1/2
(+ 1/2 (* 1/2 (/ x y)))
(* 1/2 (/ x y))
(* 2 (pow y 2))
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(* -1 y)
(- (* -1 x) y)
y
(+ x y)
(* -2 (pow y 2))
(+ (* -2 (* x y)) (* -2 (pow y 2)))
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(* 2 (* x y))
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(* -1 x)
(* x (- (* -1 (/ y x)) 1))
x
(* x (+ 1 (/ y x)))
(* -2 (* x y))
(* x (+ (* -2 y) (* -2 (/ (pow y 2) x))))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(* -1 (* x (+ 1 (/ y x))))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* -1 (* x (+ (* 2 y) (* 2 (/ (pow y 2) x)))))
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(/ 1/2 y)
(* y (+ (* 2 x) (* 2 y)))
(- (* -1 y) x)
(* -2 y)
(* y (+ (* -2 x) (* -2 y)))
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(* y (- (* -1 (/ x y)) 1))
(* y (+ 1 (/ x y)))
(* (pow y 2) (- (* -2 (/ x y)) 2))
(* -1 (* y (+ 1 (/ x y))))
(* -1 (* y (- (* -1 (/ x y)) 1)))
Outputs
1/2
#s(literal 1/2 binary64)
(+ 1/2 (* 1/2 (/ x y)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* 1/2 (/ x y))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(* 2 (pow y 2))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))
(* -1 y)
(neg.f64 y)
(- (* -1 x) y)
(-.f64 (neg.f64 x) y)
y
(+ x y)
(+.f64 y x)
(* -2 (pow y 2))
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
(+ (* -2 (* x y)) (* -2 (pow y 2)))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* 2 (* x y))
(*.f64 (*.f64 y x) #s(literal 2 binary64))
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))
(* -1 x)
(neg.f64 x)
(* x (- (* -1 (/ y x)) 1))
(-.f64 (neg.f64 x) y)
x
(* x (+ 1 (/ y x)))
(+.f64 y x)
(* -2 (* x y))
(*.f64 (*.f64 #s(literal -2 binary64) x) y)
(* x (+ (* -2 y) (* -2 (/ (pow y 2) x))))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))
(* -1 (* x (+ 1 (/ y x))))
(-.f64 (neg.f64 x) y)
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
(* -1 (* x (+ (* 2 y) (* 2 (/ (pow y 2) x)))))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(/ 1/2 y)
(/.f64 #s(literal 1/2 binary64) y)
(* y (+ (* 2 x) (* 2 y)))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))
(- (* -1 y) x)
(-.f64 (neg.f64 x) y)
(* -2 y)
(*.f64 #s(literal -2 binary64) y)
(* y (+ (* -2 x) (* -2 y)))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))
(* y (- (* -1 (/ x y)) 1))
(-.f64 (neg.f64 x) y)
(* y (+ 1 (/ x y)))
(+.f64 y x)
(* (pow y 2) (- (* -2 (/ x y)) 2))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(* -1 (* y (+ 1 (/ x y))))
(-.f64 (neg.f64 x) y)
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)

rewrite97.0ms (3.4%)

Memory
-25.4MiB live, 14.4MiB allocated
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01655
02356
18954
063354
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
9 → 268
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(/.f64 #s(literal 1/2 binary64) y)
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
(neg.f64 (+.f64 y x))
(+.f64 y x)
(*.f64 #s(literal -2 binary64) y)
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
Outputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(*.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)))
(*.f64 (*.f64 #s(literal 2 binary64) y) x)
(*.f64 #s(literal 1/2 binary64) (/.f64 x y))
(*.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 y #s(literal -1 binary64)) x))
(*.f64 x (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal -1/2 binary64) x) (neg.f64 y))
(/.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 x #s(literal -1/2 binary64)) (neg.f64 y))
(/.f64 (neg.f64 (*.f64 #s(literal 1/2 binary64) x)) (neg.f64 y))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(/.f64 #s(literal 1 binary64) (/.f64 y (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 x (*.f64 #s(literal 2 binary64) y))
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 1/2 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) (neg.f64 y)))
(*.f64 #s(literal -2 binary64) y)
(*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal -1 binary64)))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 y) #s(literal -1/2 binary64))
(/.f64 #s(literal -1/2 binary64) (neg.f64 y))
(/.f64 #s(literal 1/2 binary64) (neg.f64 (neg.f64 y)))
(/.f64 #s(literal 1/2 binary64) y)
(/.f64 y #s(literal 1/2 binary64))
(neg.f64 (/.f64 #s(literal -1/2 binary64) y))
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
(*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal -2 binary64))
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64)) (+.f64 y x))
(*.f64 (*.f64 (neg.f64 (+.f64 y x)) y) #s(literal -2 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (neg.f64 (+.f64 y x))) y)
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) (neg.f64 y))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(*.f64 #s(literal -1 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 (+.f64 y x)))
(*.f64 (*.f64 #s(literal 2 binary64) y) (+.f64 y x))
(*.f64 #s(literal -2 binary64) (*.f64 y (+.f64 y x)))
(*.f64 #s(literal -2 binary64) (*.f64 y (neg.f64 (+.f64 y x))))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal 2 binary64) y))
(*.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) y))
(*.f64 y (*.f64 #s(literal -2 binary64) (neg.f64 (+.f64 y x))))
(*.f64 y (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(pow.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))) #s(literal -1 binary64))
(/.f64 (/.f64 (+.f64 y x) #s(literal 2 binary64)) y)
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (*.f64 #s(literal 2 binary64) y)) (-.f64 y x))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 #s(literal 2 binary64) y)) (-.f64 x y))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) y)) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) y)) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (*.f64 (+.f64 y x) (-.f64 y x))) (-.f64 y x))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (*.f64 (+.f64 y x) (-.f64 x y))) (-.f64 x y))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (*.f64 (+.f64 y x) #s(literal 1 binary64)) (*.f64 #s(literal 2 binary64) y))
(/.f64 (neg.f64 (neg.f64 (+.f64 y x))) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 y x)) #s(literal 1 binary64)) (*.f64 (-.f64 y x) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) #s(literal 1 binary64)) (*.f64 (-.f64 x y) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 1 binary64)) (*.f64 (fma.f64 x (-.f64 x y) (*.f64 y y)) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 1 binary64)) (*.f64 (fma.f64 y (-.f64 y x) (*.f64 x x)) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (*.f64 (*.f64 #s(literal 2 binary64) y) (-.f64 y x)))
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 (*.f64 #s(literal 2 binary64) y) (-.f64 x y)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 (*.f64 #s(literal 2 binary64) y) (fma.f64 x (-.f64 x y) (*.f64 y y))))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 (*.f64 #s(literal 2 binary64) y) (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal 2 binary64) y))
(/.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) y))
(neg.f64 (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 (neg.f64 y) (*.f64 #s(literal 2 binary64) y) (*.f64 (neg.f64 x) (*.f64 #s(literal 2 binary64) y)))
(fma.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 y) (*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 x)))
(fma.f64 (*.f64 #s(literal 2 binary64) y) y (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(fma.f64 (*.f64 #s(literal 2 binary64) y) x (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 (*.f64 #s(literal 2 binary64) y) x (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 #s(literal 1/2 binary64) (/.f64 x y) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 #s(literal 1/2 binary64) (/.f64 x y) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 y #s(literal -1 binary64)) x) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 y #s(literal -1 binary64)) x) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 y (*.f64 #s(literal 2 binary64) y) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(fma.f64 x (*.f64 #s(literal 2 binary64) y) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 x (*.f64 #s(literal 2 binary64) y) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(-.f64 #s(literal 0 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(+.f64 (*.f64 y (*.f64 #s(literal 2 binary64) y)) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) x) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) x) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(+.f64 (*.f64 (neg.f64 y) (*.f64 #s(literal 2 binary64) y)) (*.f64 (neg.f64 x) (*.f64 #s(literal 2 binary64) y)))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) y) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 x)))
(*.f64 #s(literal -1 binary64) (+.f64 y x))
(*.f64 (+.f64 y x) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal -1 binary64) (*.f64 (+.f64 y x) (-.f64 y x))) (-.f64 y x))
(/.f64 (*.f64 #s(literal -1 binary64) (*.f64 (+.f64 y x) (-.f64 x y))) (-.f64 x y))
(/.f64 (*.f64 #s(literal -1 binary64) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (*.f64 #s(literal -1 binary64) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (-.f64 #s(literal 0 binary64) (*.f64 (+.f64 y x) (+.f64 y x))) (+.f64 #s(literal 0 binary64) (+.f64 y x)))
(/.f64 (-.f64 (*.f64 (neg.f64 y) (neg.f64 y)) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (neg.f64 y) (neg.f64 x)))
(/.f64 (-.f64 #s(literal 0 binary64) (pow.f64 (+.f64 y x) #s(literal 3 binary64))) (+.f64 #s(literal 0 binary64) (fma.f64 (+.f64 y x) (+.f64 y x) (*.f64 #s(literal 0 binary64) (+.f64 y x)))))
(/.f64 (+.f64 (pow.f64 (neg.f64 y) #s(literal 3 binary64)) (pow.f64 (neg.f64 x) #s(literal 3 binary64))) (fma.f64 (neg.f64 y) (neg.f64 y) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (neg.f64 y) (neg.f64 x)))))
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 y x))) (-.f64 y x))
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 x y))) (-.f64 x y))
(/.f64 (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (neg.f64 (-.f64 y x)))
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (neg.f64 (-.f64 x y)))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 x (-.f64 x y) (*.f64 y y))))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y (-.f64 y x) (*.f64 x x))))
(neg.f64 (+.f64 y x))
(fma.f64 #s(literal -1 binary64) y (neg.f64 x))
(fma.f64 #s(literal -1 binary64) x (neg.f64 y))
(fma.f64 y #s(literal -1 binary64) (*.f64 x #s(literal -1 binary64)))
(fma.f64 x #s(literal -1 binary64) (*.f64 y #s(literal -1 binary64)))
(-.f64 (neg.f64 x) y)
(-.f64 #s(literal 0 binary64) (+.f64 y x))
(-.f64 (neg.f64 y) x)
(+.f64 (*.f64 y #s(literal -1 binary64)) (*.f64 x #s(literal -1 binary64)))
(+.f64 (*.f64 x #s(literal -1 binary64)) (*.f64 y #s(literal -1 binary64)))
(+.f64 (neg.f64 x) (neg.f64 y))
(+.f64 #s(literal 0 binary64) (neg.f64 (+.f64 y x)))
(+.f64 (neg.f64 y) (neg.f64 x))
(*.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (/.f64 #s(literal 1 binary64) (-.f64 y x)))
(*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (/.f64 #s(literal 1 binary64) (-.f64 x y)))
(*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 x (-.f64 x y) (*.f64 y y))))
(*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 y x))) (neg.f64 (-.f64 y x)))
(/.f64 (neg.f64 (*.f64 (+.f64 y x) (-.f64 x y))) (neg.f64 (-.f64 x y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x y) (*.f64 y y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (-.f64 y x))
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (-.f64 x y))
(/.f64 #s(literal 1 binary64) (/.f64 (-.f64 y x) (*.f64 (+.f64 y x) (-.f64 y x))))
(/.f64 #s(literal 1 binary64) (/.f64 (-.f64 x y) (*.f64 (+.f64 y x) (-.f64 x y))))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 x (-.f64 x y) (*.f64 y y)) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y (-.f64 y x) (*.f64 x x)) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(-.f64 (/.f64 (*.f64 y y) (-.f64 y x)) (/.f64 (*.f64 x x) (-.f64 y x)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x y)) (/.f64 (*.f64 y y) (-.f64 x y)))
(+.f64 y x)
(+.f64 x y)
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 1/2 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) (neg.f64 y)))
(*.f64 #s(literal -2 binary64) y)
(*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal -1 binary64)))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 y) #s(literal -1/2 binary64))
(/.f64 #s(literal -1/2 binary64) (neg.f64 y))
(/.f64 #s(literal 1/2 binary64) (neg.f64 (neg.f64 y)))
(/.f64 #s(literal 1/2 binary64) y)
(/.f64 y #s(literal 1/2 binary64))
(neg.f64 (/.f64 #s(literal -1/2 binary64) y))
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
(*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 (*.f64 (+.f64 y x) y) #s(literal -2 binary64))
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64)) (+.f64 y x))
(*.f64 (*.f64 (neg.f64 (+.f64 y x)) y) #s(literal -2 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (neg.f64 (+.f64 y x))) y)
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) (neg.f64 y))
(*.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) y)
(*.f64 #s(literal -1 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 (+.f64 y x)))
(*.f64 (*.f64 #s(literal 2 binary64) y) (+.f64 y x))
(*.f64 #s(literal -2 binary64) (*.f64 y (+.f64 y x)))
(*.f64 #s(literal -2 binary64) (*.f64 y (neg.f64 (+.f64 y x))))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal 2 binary64) y))
(*.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) y))
(*.f64 y (*.f64 #s(literal -2 binary64) (neg.f64 (+.f64 y x))))
(*.f64 y (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(pow.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))) #s(literal -1 binary64))
(/.f64 (/.f64 (+.f64 y x) #s(literal 2 binary64)) y)
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (*.f64 #s(literal 2 binary64) y)) (-.f64 y x))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 #s(literal 2 binary64) y)) (-.f64 x y))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) y)) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) y)) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (*.f64 (+.f64 y x) (-.f64 y x))) (-.f64 y x))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (*.f64 (+.f64 y x) (-.f64 x y))) (-.f64 x y))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 x (-.f64 x y) (*.f64 y y)))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y (-.f64 y x) (*.f64 x x)))
(/.f64 (*.f64 (+.f64 y x) #s(literal 1 binary64)) (*.f64 #s(literal 2 binary64) y))
(/.f64 (neg.f64 (neg.f64 (+.f64 y x))) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 y x)) #s(literal 1 binary64)) (*.f64 (-.f64 y x) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (*.f64 (+.f64 y x) (-.f64 x y)) #s(literal 1 binary64)) (*.f64 (-.f64 x y) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 1 binary64)) (*.f64 (fma.f64 x (-.f64 x y) (*.f64 y y)) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) #s(literal 1 binary64)) (*.f64 (fma.f64 y (-.f64 y x) (*.f64 x x)) (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 (+.f64 y x) (-.f64 y x)) (*.f64 (*.f64 #s(literal 2 binary64) y) (-.f64 y x)))
(/.f64 (*.f64 (+.f64 y x) (-.f64 x y)) (*.f64 (*.f64 #s(literal 2 binary64) y) (-.f64 x y)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 y x))))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 (*.f64 #s(literal 2 binary64) y) (fma.f64 x (-.f64 x y) (*.f64 y y))))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (*.f64 (*.f64 #s(literal 2 binary64) y) (fma.f64 y (-.f64 y x) (*.f64 x x))))
(/.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal 2 binary64) y))
(/.f64 (+.f64 y x) (*.f64 #s(literal 2 binary64) y))
(neg.f64 (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 (neg.f64 y) (*.f64 #s(literal 2 binary64) y) (*.f64 (neg.f64 x) (*.f64 #s(literal 2 binary64) y)))
(fma.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 y) (*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 x)))
(fma.f64 (*.f64 #s(literal 2 binary64) y) y (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(fma.f64 (*.f64 #s(literal 2 binary64) y) x (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 (*.f64 #s(literal 2 binary64) y) x (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 #s(literal 1/2 binary64) (/.f64 x y) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 #s(literal 1/2 binary64) (/.f64 x y) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 y #s(literal -1 binary64)) x) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 y #s(literal -1 binary64)) x) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(fma.f64 y (*.f64 #s(literal 2 binary64) y) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(fma.f64 x (*.f64 #s(literal 2 binary64) y) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(fma.f64 x (*.f64 #s(literal 2 binary64) y) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(-.f64 #s(literal 0 binary64) (*.f64 (/.f64 (+.f64 y x) #s(literal 0 binary64)) #s(literal 0 binary64)))
(+.f64 (*.f64 y (*.f64 #s(literal 2 binary64) y)) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) x) (*.f64 y (*.f64 #s(literal 2 binary64) y)))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) x) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(+.f64 (*.f64 (neg.f64 y) (*.f64 #s(literal 2 binary64) y)) (*.f64 (neg.f64 x) (*.f64 #s(literal 2 binary64) y)))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) y) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(+.f64 (*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) (neg.f64 x)))

eval66.0ms (2.3%)

Memory
0.3MiB live, 39.6MiB allocated
Compiler

Compiled 2 939 to 509 computations (82.7% saved)

prune5.0ms (0.2%)

Memory
12.1MiB live, 12.1MiB allocated
Pruning

7 alts after pruning (4 fresh and 3 done)

PrunedKeptTotal
New1994203
Fresh000
Picked224
Done011
Total2017208
Accuracy
100.0%
Counts
208 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(/.f64 (+.f64 x y) (+.f64 y y))
56.2%
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
56.1%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
3.7%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
45.5%
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
1.8%
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
3.2%
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
Compiler

Compiled 82 to 59 computations (28% saved)

simplify116.0ms (4.1%)

Memory
-2.6MiB live, 35.7MiB allocated
Algorithm
egg-herbie
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 #s(literal 1/2 binary64) x)
cost-diff0
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
cost-diff0
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
cost-diff-128
(+.f64 y y)
cost-diff0
(*.f64 (+.f64 y y) x)
cost-diff0
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
cost-diff0
(*.f64 #s(literal -2 binary64) y)
cost-diff0
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
cost-diff0
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
cost-diff0
(*.f64 #s(literal 2 binary64) y)
cost-diff0
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
cost-diff0
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02594
03494
16294
213293
331793
450693
572193
6138493
7296893
8340093
9350293
10357393
11360693
12360693
13360693
0360691
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) y)
#s(literal 2 binary64)
y
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
(*.f64 #s(literal -2 binary64) y)
#s(literal -2 binary64)
y
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
(*.f64 (+.f64 y y) x)
(+.f64 y y)
y
x
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(*.f64 #s(literal 1/2 binary64) x)
#s(literal 1/2 binary64)
x
y
Outputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 y y) #s(literal 2 binary64)))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 (*.f64 y y) #s(literal 2 binary64))
(*.f64 #s(literal 2 binary64) y)
#s(literal 2 binary64)
y
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
(*.f64 #s(literal -2 binary64) y)
#s(literal -2 binary64)
y
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (*.f64 x y) #s(literal 2 binary64)))
(*.f64 (+.f64 y y) x)
(*.f64 (*.f64 x y) #s(literal 2 binary64))
(+.f64 y y)
(*.f64 #s(literal 2 binary64) y)
y
x
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
#s(approx (/ (+ x y) (+ y y)) (/.f64 x (*.f64 #s(literal 2 binary64) y)))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(/.f64 x (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 1/2 binary64) x)
#s(literal 1/2 binary64)
x
y

localize56.0ms (2%)

Memory
16.3MiB live, 53.8MiB allocated
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
accuracy0
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
accuracy0
(*.f64 #s(literal 1/2 binary64) x)
accuracy28.01605946079349
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
accuracy0
(+.f64 y y)
accuracy0
(*.f64 (+.f64 y y) x)
accuracy61.62596332260513
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
accuracy0
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
accuracy0
(*.f64 #s(literal -2 binary64) y)
accuracy28.133766673358227
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
accuracy0
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
accuracy0
(*.f64 #s(literal 2 binary64) y)
accuracy28.133766673358227
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
Samples
45.0ms256×0valid
Compiler

Compiled 166 to 47 computations (71.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 20.0ms
ival-mult: 11.0ms (54.2% of total)
ival-add: 4.0ms (19.7% of total)
ival-div: 3.0ms (14.8% of total)
ival-neg: 1.0ms (4.9% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series16.0ms (0.6%)

Memory
-21.8MiB live, 14.8MiB allocated
Counts
12 → 22
Calls
Call 1
Inputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) y)
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
(*.f64 #s(literal -2 binary64) y)
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
(*.f64 (+.f64 y y) x)
(+.f64 y y)
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(*.f64 #s(literal 1/2 binary64) x)
Outputs
(* 2 (pow y 2))
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(* -2 (pow y 2))
(+ (* -2 (* x y)) (* -2 (pow y 2)))
1/2
(+ 1/2 (* 1/2 (/ x y)))
(* 2 (* x y))
(* 1/2 (/ x y))
(* 1/2 x)
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(* -2 (* x y))
(* x (+ (* -2 y) (* -2 (/ (pow y 2) x))))
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(* -1 (* x (+ (* 2 y) (* 2 (/ (pow y 2) x)))))
(* y (+ (* 2 x) (* 2 y)))
(* 2 y)
(* y (+ (* -2 x) (* -2 y)))
(* -2 y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(* (pow y 2) (- (* -2 (/ x y)) 2))
Calls

6 calls:

TimeVariablePointExpression
7.0ms
y
@0
((* (neg (+ y x)) (* -2 y)) (* (* 2 y) y) (* 2 y) (* (+ y x) (* -2 y)) (* (* -2 y) y) (* -2 y) (/ (+ x y) (+ y y)) (* (+ y y) x) (+ y y) (/ (+ x y) (+ y y)) (/ (* 1/2 x) y) (* 1/2 x))
2.0ms
y
@-inf
((* (neg (+ y x)) (* -2 y)) (* (* 2 y) y) (* 2 y) (* (+ y x) (* -2 y)) (* (* -2 y) y) (* -2 y) (/ (+ x y) (+ y y)) (* (+ y y) x) (+ y y) (/ (+ x y) (+ y y)) (/ (* 1/2 x) y) (* 1/2 x))
2.0ms
y
@inf
((* (neg (+ y x)) (* -2 y)) (* (* 2 y) y) (* 2 y) (* (+ y x) (* -2 y)) (* (* -2 y) y) (* -2 y) (/ (+ x y) (+ y y)) (* (+ y y) x) (+ y y) (/ (+ x y) (+ y y)) (/ (* 1/2 x) y) (* 1/2 x))
1.0ms
x
@-inf
((* (neg (+ y x)) (* -2 y)) (* (* 2 y) y) (* 2 y) (* (+ y x) (* -2 y)) (* (* -2 y) y) (* -2 y) (/ (+ x y) (+ y y)) (* (+ y y) x) (+ y y) (/ (+ x y) (+ y y)) (/ (* 1/2 x) y) (* 1/2 x))
1.0ms
x
@inf
((* (neg (+ y x)) (* -2 y)) (* (* 2 y) y) (* 2 y) (* (+ y x) (* -2 y)) (* (* -2 y) y) (* -2 y) (/ (+ x y) (+ y y)) (* (+ y y) x) (+ y y) (/ (+ x y) (+ y y)) (/ (* 1/2 x) y) (* 1/2 x))

simplify142.0ms (5%)

Memory
20.0MiB live, 103.5MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
051146
1155126
2372126
3803126
42283126
53808126
65600126
76698126
87877126
08212123
Stop Event
iter limit
node limit
Counts
22 → 22
Calls
Call 1
Inputs
(* 2 (pow y 2))
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(* -2 (pow y 2))
(+ (* -2 (* x y)) (* -2 (pow y 2)))
1/2
(+ 1/2 (* 1/2 (/ x y)))
(* 2 (* x y))
(* 1/2 (/ x y))
(* 1/2 x)
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(* -2 (* x y))
(* x (+ (* -2 y) (* -2 (/ (pow y 2) x))))
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(* -1 (* x (+ (* 2 y) (* 2 (/ (pow y 2) x)))))
(* y (+ (* 2 x) (* 2 y)))
(* 2 y)
(* y (+ (* -2 x) (* -2 y)))
(* -2 y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(* (pow y 2) (- (* -2 (/ x y)) 2))
Outputs
(* 2 (pow y 2))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(*.f64 (*.f64 (+.f64 x y) #s(literal 2 binary64)) y)
(* -2 (pow y 2))
(*.f64 (*.f64 y y) #s(literal -2 binary64))
(+ (* -2 (* x y)) (* -2 (pow y 2)))
(*.f64 (*.f64 (+.f64 x y) #s(literal -2 binary64)) y)
1/2
#s(literal 1/2 binary64)
(+ 1/2 (* 1/2 (/ x y)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* 2 (* x y))
(*.f64 (*.f64 #s(literal 2 binary64) x) y)
(* 1/2 (/ x y))
(*.f64 (/.f64 #s(literal 1/2 binary64) y) x)
(* 1/2 x)
(*.f64 #s(literal 1/2 binary64) x)
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(*.f64 (*.f64 (+.f64 x y) #s(literal 2 binary64)) y)
(* -2 (* x y))
(*.f64 (*.f64 #s(literal -2 binary64) x) y)
(* x (+ (* -2 y) (* -2 (/ (pow y 2) x))))
(*.f64 (*.f64 (+.f64 x y) #s(literal -2 binary64)) y)
(* x (+ (* 1/2 (/ 1 x)) (* 1/2 (/ 1 y))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(*.f64 (*.f64 (+.f64 x y) #s(literal 2 binary64)) y)
(* -1 (* x (+ (* 2 y) (* 2 (/ (pow y 2) x)))))
(*.f64 (*.f64 (+.f64 x y) #s(literal -2 binary64)) y)
(* y (+ (* 2 x) (* 2 y)))
(*.f64 (*.f64 (+.f64 x y) #s(literal 2 binary64)) y)
(* 2 y)
(*.f64 #s(literal 2 binary64) y)
(* y (+ (* -2 x) (* -2 y)))
(*.f64 (*.f64 (+.f64 x y) #s(literal -2 binary64)) y)
(* -2 y)
(*.f64 #s(literal -2 binary64) y)
(/ (+ (* 1/2 x) (* 1/2 y)) y)
(fma.f64 (/.f64 #s(literal 1/2 binary64) y) x #s(literal 1/2 binary64))
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(*.f64 (*.f64 (+.f64 x y) #s(literal 2 binary64)) y)
(* (pow y 2) (- (* -2 (/ x y)) 2))
(*.f64 (*.f64 (+.f64 x y) #s(literal -2 binary64)) y)

rewrite44.0ms (1.5%)

Memory
-3.8MiB live, 34.7MiB allocated
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
02585
03482
110576
065876
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
12 → 271
Calls
Call 1
Inputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) y)
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
(*.f64 (*.f64 #s(literal -2 binary64) y) y)
(*.f64 #s(literal -2 binary64) y)
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
(*.f64 (+.f64 y y) x)
(+.f64 y y)
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(*.f64 #s(literal 1/2 binary64) x)
Outputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal 2 binary64) y))
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 (*.f64 y y) #s(literal 2 binary64))
(*.f64 (*.f64 y y) #s(literal -2 binary64))
(*.f64 (neg.f64 y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) (*.f64 y y))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -2 binary64) (*.f64 y y))
(*.f64 #s(literal -2 binary64) y)
(*.f64 y (*.f64 #s(literal 2 binary64) y))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) y) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) y) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 y (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal 1/2 binary64) y)
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(fma.f64 y y (*.f64 y y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (*.f64 y y) (*.f64 y y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 (*.f64 y y) #s(literal 2 binary64))
(*.f64 (*.f64 y y) #s(literal -2 binary64))
(*.f64 (neg.f64 y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) (*.f64 y y))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -2 binary64) (*.f64 y y))
(*.f64 #s(literal -2 binary64) y)
(*.f64 y (*.f64 #s(literal 2 binary64) y))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) y) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) y) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 y (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal 1/2 binary64) y)
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(fma.f64 y y (*.f64 y y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (*.f64 y y) (*.f64 y y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal 2 binary64) y))
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 (*.f64 y y) #s(literal 2 binary64))
(*.f64 (*.f64 y y) #s(literal -2 binary64))
(*.f64 (neg.f64 y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) (*.f64 y y))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -2 binary64) (*.f64 y y))
(*.f64 #s(literal -2 binary64) y)
(*.f64 y (*.f64 #s(literal 2 binary64) y))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) y) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) y) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 y (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal 1/2 binary64) y)
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(fma.f64 y y (*.f64 y y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (*.f64 y y) (*.f64 y y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 (*.f64 y y) #s(literal 2 binary64))
(*.f64 (*.f64 y y) #s(literal -2 binary64))
(*.f64 (neg.f64 y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) (*.f64 y y))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -2 binary64) (*.f64 y y))
(*.f64 #s(literal -2 binary64) y)
(*.f64 y (*.f64 #s(literal 2 binary64) y))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) y) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) y) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 y (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal 1/2 binary64) y)
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(fma.f64 y y (*.f64 y y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (*.f64 y y) (*.f64 y y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(*.f64 (*.f64 x #s(literal 2 binary64)) y)
(*.f64 (/.f64 x y) #s(literal 1/2 binary64))
(*.f64 (pow.f64 y #s(literal -1 binary64)) (*.f64 #s(literal 1/2 binary64) x))
(*.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(*.f64 (*.f64 x y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal -1/2 binary64) x) (/.f64 #s(literal 1 binary64) (neg.f64 y)))
(*.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)))
(*.f64 #s(literal 1/2 binary64) (/.f64 x y))
(*.f64 (*.f64 #s(literal 2 binary64) y) x)
(*.f64 #s(literal 2 binary64) (*.f64 x y))
(*.f64 x (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal -1 binary64))))
(*.f64 x (*.f64 #s(literal 2 binary64) y))
(*.f64 y (*.f64 #s(literal 2 binary64) x))
(pow.f64 (/.f64 y (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) x) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) x) (fma.f64 y y #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 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) x) #s(literal 1 binary64)) y)
(/.f64 (neg.f64 (*.f64 #s(literal -1/2 binary64) x)) (neg.f64 (neg.f64 y)))
(/.f64 #s(literal -1 binary64) (neg.f64 (/.f64 y (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 #s(literal 1 binary64) (/.f64 (/.f64 y (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (/.f64 y (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (*.f64 #s(literal -1/2 binary64) x) (neg.f64 y))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(neg.f64 (/.f64 (*.f64 #s(literal -1/2 binary64) x) y))
(neg.f64 (/.f64 (*.f64 #s(literal 1/2 binary64) x) (neg.f64 y)))
(fma.f64 x y (*.f64 x y))
(fma.f64 y x (*.f64 x y))
(+.f64 (*.f64 x y) (*.f64 x y))
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)) #s(literal 0 binary64))
(*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 (*.f64 y y) #s(literal 2 binary64))
(*.f64 (*.f64 y y) #s(literal -2 binary64))
(*.f64 (neg.f64 y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(*.f64 #s(literal 2 binary64) (*.f64 y y))
(*.f64 #s(literal 2 binary64) (neg.f64 y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal -2 binary64) (*.f64 y y))
(*.f64 #s(literal -2 binary64) y)
(*.f64 y (*.f64 #s(literal 2 binary64) y))
(*.f64 y #s(literal 2 binary64))
(*.f64 y #s(literal -2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) y) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) y) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 y (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal -1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 #s(literal 1/2 binary64) y)
(neg.f64 (*.f64 #s(literal 2 binary64) y))
(fma.f64 #s(literal -1 binary64) y (neg.f64 y))
(fma.f64 y y (*.f64 y y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal 2 binary64) y))
(+.f64 (*.f64 y y) (*.f64 y y))
(+.f64 (neg.f64 y) (neg.f64 y))
(+.f64 y y)
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(*.f64 (*.f64 x #s(literal 2 binary64)) y)
(*.f64 (/.f64 x y) #s(literal 1/2 binary64))
(*.f64 (pow.f64 y #s(literal -1 binary64)) (*.f64 #s(literal 1/2 binary64) x))
(*.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 2 binary64) y) x))
(*.f64 (*.f64 x y) #s(literal 2 binary64))
(*.f64 (*.f64 #s(literal -1/2 binary64) x) (/.f64 #s(literal 1 binary64) (neg.f64 y)))
(*.f64 (*.f64 #s(literal 1/2 binary64) x) (pow.f64 y #s(literal -1 binary64)))
(*.f64 #s(literal 1/2 binary64) (/.f64 x y))
(*.f64 (*.f64 #s(literal 2 binary64) y) x)
(*.f64 #s(literal 2 binary64) (*.f64 x y))
(*.f64 x (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal -1 binary64))))
(*.f64 x (*.f64 #s(literal 2 binary64) y))
(*.f64 y (*.f64 #s(literal 2 binary64) x))
(pow.f64 (/.f64 y (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1 binary64))
(/.f64 (*.f64 #s(literal 0 binary64) x) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) x) (fma.f64 y y #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 y #s(literal 3 binary64)))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) x) #s(literal 1 binary64)) y)
(/.f64 (neg.f64 (*.f64 #s(literal -1/2 binary64) x)) (neg.f64 (neg.f64 y)))
(/.f64 #s(literal -1 binary64) (neg.f64 (/.f64 y (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 #s(literal 1 binary64) (/.f64 (/.f64 y (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (/.f64 y (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (*.f64 #s(literal -1/2 binary64) x) (neg.f64 y))
(/.f64 (*.f64 #s(literal 1/2 binary64) x) y)
(neg.f64 (/.f64 (*.f64 #s(literal -1/2 binary64) x) y))
(neg.f64 (/.f64 (*.f64 #s(literal 1/2 binary64) x) (neg.f64 y)))
(fma.f64 x y (*.f64 x y))
(fma.f64 y x (*.f64 x y))
(+.f64 (*.f64 x y) (*.f64 x y))
(*.f64 #s(literal 1/2 binary64) x)
(*.f64 x #s(literal 1/2 binary64))

eval15.0ms (0.5%)

Memory
-18.1MiB live, 19.8MiB allocated
Compiler

Compiled 1 302 to 237 computations (81.8% saved)

prune5.0ms (0.2%)

Memory
12.7MiB live, 12.7MiB allocated
Pruning

10 alts after pruning (3 fresh and 7 done)

PrunedKeptTotal
New84387
Fresh000
Picked044
Done033
Total841094
Accuracy
100.0%
Counts
94 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(/.f64 (+.f64 x y) (+.f64 y y))
56.2%
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
56.1%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
3.7%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
45.5%
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
1.8%
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
3.7%
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
3.1%
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
3.2%
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
2.6%
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
Compiler

Compiled 118 to 88 computations (25.4% saved)

simplify75.0ms (2.6%)

Memory
-12.3MiB live, 68.7MiB allocated
Algorithm
egg-herbie
Localize:

Found 6 expressions of interest:

NewMetricScoreProgram
cost-diff0
(/.f64 #s(literal 1/2 binary64) y)
cost-diff0
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
cost-diff-128
(+.f64 y y)
cost-diff0
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
cost-diff0
(*.f64 y #s(literal -2 binary64))
cost-diff0
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01450
01750
13350
27447
322947
441547
565647
6108247
7156247
8172947
9174247
10175147
11175247
12175247
0175247
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
(*.f64 y #s(literal -2 binary64))
y
#s(literal -2 binary64)
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
(+.f64 y y)
y
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(/.f64 #s(literal 1/2 binary64) y)
#s(literal 1/2 binary64)
y
Outputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal -2 binary64) y))
(*.f64 y #s(literal -2 binary64))
(*.f64 #s(literal -2 binary64) y)
y
#s(literal -2 binary64)
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal 2 binary64) y))
(+.f64 y y)
(*.f64 #s(literal 2 binary64) y)
y
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(/.f64 #s(literal 1/2 binary64) y)
#s(literal 1/2 binary64)
y

localize26.0ms (0.9%)

Memory
28.2MiB live, 66.9MiB allocated
Localize:

Found 6 expressions of interest:

NewMetricScoreProgram
accuracy0
(/.f64 #s(literal 1/2 binary64) y)
accuracy62.371660267801346
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
accuracy0
(+.f64 y y)
accuracy61.037094349407745
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
accuracy0
(*.f64 y #s(literal -2 binary64))
accuracy61.42021128496118
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
Samples
19.0ms256×0valid
Compiler

Compiled 90 to 28 computations (68.9% saved)

Precisions
Click to see histograms. Total time spent on operations: 11.0ms
ival-mult: 4.0ms (37.9% of total)
ival-add: 3.0ms (28.4% of total)
ival-div: 2.0ms (18.9% of total)
ival-neg: 1.0ms (9.5% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series5.0ms (0.2%)

Memory
-28.6MiB live, 10.2MiB allocated
Counts
6 → 10
Calls
Call 1
Inputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
(*.f64 y #s(literal -2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
(+.f64 y y)
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(/.f64 #s(literal 1/2 binary64) y)
Outputs
(* 2 (pow y 2))
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(* 2 (* x y))
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(* y (+ (* 2 x) (* 2 y)))
(* -2 y)
(* 2 y)
(/ 1/2 y)
(* (pow y 2) (+ 2 (* 2 (/ x y))))
Calls

6 calls:

TimeVariablePointExpression
2.0ms
y
@inf
((* (neg (+ y x)) (* -2 y)) (* y -2) (* (neg (+ y x)) (* -2 y)) (+ y y) (* (neg (+ y x)) (* -2 y)) (/ 1/2 y))
1.0ms
y
@-inf
((* (neg (+ y x)) (* -2 y)) (* y -2) (* (neg (+ y x)) (* -2 y)) (+ y y) (* (neg (+ y x)) (* -2 y)) (/ 1/2 y))
1.0ms
y
@0
((* (neg (+ y x)) (* -2 y)) (* y -2) (* (neg (+ y x)) (* -2 y)) (+ y y) (* (neg (+ y x)) (* -2 y)) (/ 1/2 y))
0.0ms
x
@-inf
((* (neg (+ y x)) (* -2 y)) (* y -2) (* (neg (+ y x)) (* -2 y)) (+ y y) (* (neg (+ y x)) (* -2 y)) (/ 1/2 y))
0.0ms
x
@inf
((* (neg (+ y x)) (* -2 y)) (* y -2) (* (neg (+ y x)) (* -2 y)) (+ y y) (* (neg (+ y x)) (* -2 y)) (/ 1/2 y))

simplify112.0ms (4%)

Memory
30.1MiB live, 111.6MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
02964
18754
221754
349154
4109354
5269554
6605554
0810254
Stop Event
iter limit
node limit
Counts
10 → 10
Calls
Call 1
Inputs
(* 2 (pow y 2))
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(* 2 (* x y))
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(* y (+ (* 2 x) (* 2 y)))
(* -2 y)
(* 2 y)
(/ 1/2 y)
(* (pow y 2) (+ 2 (* 2 (/ x y))))
Outputs
(* 2 (pow y 2))
(*.f64 (*.f64 #s(literal 2 binary64) y) y)
(+ (* 2 (* x y)) (* 2 (pow y 2)))
(*.f64 (+.f64 x y) (*.f64 #s(literal 2 binary64) y))
(* 2 (* x y))
(*.f64 (*.f64 x y) #s(literal 2 binary64))
(* x (+ (* 2 y) (* 2 (/ (pow y 2) x))))
(*.f64 (+.f64 x y) (*.f64 #s(literal 2 binary64) y))
(* -1 (* x (+ (* -2 y) (* -2 (/ (pow y 2) x)))))
(*.f64 (+.f64 x y) (*.f64 #s(literal 2 binary64) y))
(* y (+ (* 2 x) (* 2 y)))
(*.f64 (+.f64 x y) (*.f64 #s(literal 2 binary64) y))
(* -2 y)
(*.f64 #s(literal -2 binary64) y)
(* 2 y)
(*.f64 #s(literal 2 binary64) y)
(/ 1/2 y)
(/.f64 #s(literal 1/2 binary64) y)
(* (pow y 2) (+ 2 (* 2 (/ x y))))
(*.f64 (+.f64 x y) (*.f64 #s(literal 2 binary64) y))

rewrite35.0ms (1.2%)

Memory
-25.4MiB live, 53.3MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01445
01745
16045
033645
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
6 → 53
Calls
Call 1
Inputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
(*.f64 y #s(literal -2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
(+.f64 y y)
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(/.f64 #s(literal 1/2 binary64) y)
Outputs
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal -2 binary64) y))
(*.f64 #s(literal -2 binary64) y)
(*.f64 y #s(literal -2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 1/2 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) (neg.f64 y)))
(*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal -1 binary64)))
(*.f64 y #s(literal 2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 2 binary64) y)))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 y) #s(literal -1/2 binary64))
(/.f64 #s(literal -1/2 binary64) (neg.f64 y))
(/.f64 #s(literal 1/2 binary64) (neg.f64 (neg.f64 y)))
(/.f64 #s(literal 1/2 binary64) y)
(/.f64 y #s(literal 1/2 binary64))
(neg.f64 (/.f64 #s(literal -1/2 binary64) y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(+.f64 y y)
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 2 binary64) y)
(*.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 0 binary64)))
(*.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 1/2 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 y y #s(literal 0 binary64))))
(*.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) (neg.f64 y)))
(*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal -1 binary64)))
(*.f64 y #s(literal 2 binary64))
(pow.f64 (*.f64 #s(literal 2 binary64) y) #s(literal -1 binary64))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y #s(literal 0 binary64))))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 2 binary64) y)))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y y #s(literal 0 binary64)) (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) y) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) y))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y #s(literal 0 binary64)))
(/.f64 (neg.f64 y) #s(literal -1/2 binary64))
(/.f64 #s(literal -1/2 binary64) (neg.f64 y))
(/.f64 #s(literal 1/2 binary64) (neg.f64 (neg.f64 y)))
(/.f64 #s(literal 1/2 binary64) y)
(/.f64 y #s(literal 1/2 binary64))
(neg.f64 (/.f64 #s(literal -1/2 binary64) y))
(-.f64 (/.f64 (*.f64 y y) #s(literal 0 binary64)) (/.f64 (*.f64 y y) #s(literal 0 binary64)))
(+.f64 y y)

eval3.0ms (0.1%)

Memory
10.7MiB live, 10.7MiB allocated
Compiler

Compiled 497 to 102 computations (79.5% saved)

prune5.0ms (0.2%)

Memory
15.0MiB live, 15.0MiB allocated
Pruning

10 alts after pruning (0 fresh and 10 done)

PrunedKeptTotal
New34034
Fresh000
Picked033
Done077
Total341044
Accuracy
100.0%
Counts
44 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(/.f64 (+.f64 x y) (+.f64 y y))
56.2%
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
56.1%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
3.7%
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
45.5%
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
1.8%
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
3.7%
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
3.1%
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
3.2%
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
2.6%
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
Compiler

Compiled 251 to 128 computations (49% saved)

regimes29.0ms (1%)

Memory
-18.6MiB live, 64.1MiB allocated
Counts
12 → 1
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
(/.f64 (+.f64 x y) (+.f64 y y))
Outputs
(/.f64 (+.f64 x y) (+.f64 y y))
Calls

3 calls:

18.0ms
(/.f64 (+.f64 x y) (+.f64 y y))
5.0ms
y
4.0ms
x
Results
AccuracySegmentsBranch
100.0%1x
100.0%1y
100.0%1(/.f64 (+.f64 x y) (+.f64 y y))
Compiler

Compiled 9 to 9 computations (0% saved)

regimes13.0ms (0.5%)

Memory
-5.2MiB live, 34.3MiB allocated
Counts
11 → 3
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
Outputs
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))
Calls

3 calls:

5.0ms
x
4.0ms
y
4.0ms
(/.f64 (+.f64 x y) (+.f64 y y))
Results
AccuracySegmentsBranch
77.5%3x
81.3%3y
98.2%3(/.f64 (+.f64 x y) (+.f64 y y))
Compiler

Compiled 9 to 9 computations (0% saved)

regimes4.0ms (0.1%)

Memory
10.5MiB live, 10.5MiB allocated
Counts
10 → 3
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
Outputs
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))
Calls

1 calls:

3.0ms
(/.f64 (+.f64 x y) (+.f64 y y))
Results
AccuracySegmentsBranch
98.0%3(/.f64 (+.f64 x y) (+.f64 y y))
Compiler

Compiled 7 to 5 computations (28.6% saved)

regimes12.0ms (0.4%)

Memory
-10.0MiB live, 29.4MiB allocated
Accuracy

Total -28.6b remaining (-81.9%)

Threshold costs -28.6b (-81.9%)

Counts
9 → 1
Calls
Call 1
Inputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
#s(approx (* (neg (+ y x)) (* -2 y)) (+.f64 y y))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 y #s(literal -2 binary64)))
#s(approx (/ (+ x y) (+ y y)) (*.f64 (+.f64 y y) x))
#s(approx (* (neg (+ y x)) (* -2 y)) (*.f64 (*.f64 #s(literal 2 binary64) y) y))
#s(approx (* (+ y x) (* -2 y)) (*.f64 (*.f64 #s(literal -2 binary64) y) y))
#s(approx (* (neg (+ y x)) (* -2 y)) (/.f64 #s(literal 1/2 binary64) y))
(*.f64 (+.f64 y x) (*.f64 #s(literal -2 binary64) y))
(*.f64 (neg.f64 (+.f64 y x)) (*.f64 #s(literal -2 binary64) y))
Outputs
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
Calls

3 calls:

4.0ms
y
3.0ms
x
3.0ms
(/.f64 (+.f64 x y) (+.f64 y y))
Results
AccuracySegmentsBranch
45.5%1x
45.5%1y
45.5%1(/.f64 (+.f64 x y) (+.f64 y y))
Compiler

Compiled 9 to 9 computations (0% saved)

bsearch1.0ms (0%)

Memory
1.6MiB live, 1.6MiB allocated
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.5000034643357537
1297321.3334528492
0.0ms
-6441.256066116601
0.36625370704951743
Compiler

Compiled 10 to 10 computations (0% saved)

bsearch1.0ms (0%)

Memory
1.4MiB live, 1.4MiB allocated
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.5000034643357537
1297321.3334528492
0.0ms
-6441.256066116601
0.36625370704951743
Compiler

Compiled 10 to 10 computations (0% saved)

simplify25.0ms (0.9%)

Memory
-15.0MiB live, 66.1MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
024126
130126
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (+.f64 x y) (+.f64 y y))
(if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal -5000 binary64)) #s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y)) (if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal 1 binary64)) #s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64)) #s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))))
(if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal -5000 binary64)) #s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x)) (if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal 1 binary64)) #s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64)) #s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))))
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))
Outputs
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (+.f64 y x) (+.f64 y y))
(if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal -5000 binary64)) #s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y)) (if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal 1 binary64)) #s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64)) #s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))))
(if (<=.f64 (/.f64 (+.f64 y x) (+.f64 y y)) #s(literal -5000 binary64)) #s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y)) (if (<=.f64 (/.f64 (+.f64 y x) (+.f64 y y)) #s(literal 1 binary64)) #s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64)) #s(approx (/ (+ x y) (+ y y)) (/.f64 (*.f64 #s(literal 1/2 binary64) x) y))))
(if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal -5000 binary64)) #s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x)) (if (<=.f64 (/.f64 (+.f64 x y) (+.f64 y y)) #s(literal 1 binary64)) #s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64)) #s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))))
(if (<=.f64 (/.f64 (+.f64 y x) (+.f64 y y)) #s(literal -5000 binary64)) #s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x)) (if (<=.f64 (/.f64 (+.f64 y x) (+.f64 y y)) #s(literal 1 binary64)) #s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64)) #s(approx (/ (+ x y) (+ y y)) (*.f64 (/.f64 #s(literal 1/2 binary64) y) x))))
#s(approx (/ (+ x y) (+ y y)) #s(literal 1/2 binary64))

soundness337.0ms (11.9%)

Memory
15.6MiB live, 215.4MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01655
02356
18954
063354
03447
19547
219547
352947
4241747
5482147
6609447
7705047
8757347
0803644
Stop Event
done
iter limit
node limit
iter limit
iter limit
iter limit
unsound
iter limit
Compiler

Compiled 152 to 52 computations (65.8% saved)

preprocess41.0ms (1.4%)

Memory
20.6MiB live, 100.6MiB allocated
Compiler

Compiled 280 to 70 computations (75% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...