Optimisation.CirclePacking:place from circle-packing-0.1.0.4, G

Time bar (total: 3.0s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage

analyze0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
100%99.9%0%0.1%0%0%0%1
Compiler

Compiled 9 to 9 computations (0% saved)

sample849.0ms (28.7%)

Memory
-19.9MiB live, 788.2MiB allocated; 237ms collecting garbage
Samples
531.0ms8 255×0valid
0.0ms2valid
Precisions
Click to see histograms. Total time spent on operations: 217.0ms
ival-mult!: 120.0ms (55.3% of total)
ival-add!: 95.0ms (43.8% of total)
adjust: 2.0ms (0.9% of total)
Bogosity

preprocess50.0ms (1.7%)

Memory
1.1MiB live, 50.6MiB allocated; 14ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02779
119277
2204876
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
Symmetry

(sort x y)

Compiler

Compiled 14 to 14 computations (0% saved)

series104.0ms (3.5%)

Memory
2.6MiB live, 95.0MiB allocated; 39ms collecting garbage
Counts
7 → 22
Calls
Call 1
Inputs
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
(+.f64 x y)
x
y
(+.f64 z #s(literal 1 binary64))
z
#s(literal 1 binary64)
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
#s(approx (+ x y) y)
#s(approx (+ x y) (+.f64 x y))
#s(approx x x)
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x)))))
#s(approx (+ x y) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 y x))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x))))))
#s(approx (+ x y) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 y x)) #s(literal 1 binary64)))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y)))))
#s(approx (+ x y) (*.f64 y (+.f64 #s(literal 1 binary64) (/.f64 x y))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y))))))
#s(approx (+ x y) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x y)) #s(literal 1 binary64)))))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
#s(approx (+ z 1) #s(literal 1 binary64))
#s(approx (+ z 1) (+.f64 #s(literal 1 binary64) z))
#s(approx z z)
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x (+.f64 y (+.f64 (/.f64 x z) (/.f64 y z))))))
#s(approx (+ z 1) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) z))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x y) z))))))
Calls

9 calls:

TimeVariablePoint
1.0ms
y
inf
1.0ms
x
-inf
1.0ms
x
inf
1.0ms
y
-inf
1.0ms
z
-inf

rewrite199.0ms (6.7%)

Memory
6.0MiB live, 191.7MiB allocated; 88ms collecting garbage
Counts
7 → 35
Calls
Call 1
Inputs
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
(+.f64 x y)
x
y
(+.f64 z #s(literal 1 binary64))
z
#s(literal 1 binary64)
Outputs
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
(*.f64 (+.f64 z #s(literal 1 binary64)) (+.f64 x y))
(*.f64 (*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64))) #s(literal 1 binary64))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 (+.f64 z #s(literal 1 binary64)) (-.f64 x y)))
(*.f64 #s(literal 1 binary64) (*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64))))
(*.f64 (+.f64 x y) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 x y))
(*.f64 (neg.f64 (+.f64 x y)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 #s(literal 1 binary64) (-.f64 x y)))
(*.f64 (+.f64 x y) (/.f64 (-.f64 x y) (-.f64 x y)))
x
(*.f64 x #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) x)
(*.f64 (*.f64 x (neg.f64 #s(literal 1 binary64))) (neg.f64 #s(literal 1 binary64)))
(*.f64 (neg.f64 #s(literal 1 binary64)) (*.f64 (neg.f64 #s(literal 1 binary64)) x))
y
(*.f64 y #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) y)
(*.f64 (*.f64 y (neg.f64 #s(literal 1 binary64))) (neg.f64 #s(literal 1 binary64)))
(*.f64 (neg.f64 #s(literal 1 binary64)) (*.f64 (neg.f64 #s(literal 1 binary64)) y))
(*.f64 (+.f64 z #s(literal 1 binary64)) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 z #s(literal 1 binary64)))
(*.f64 (/.f64 (fma.f64 z z #s(literal -1 binary64)) (fma.f64 z z #s(literal -1 binary64))) (+.f64 z #s(literal 1 binary64)))
(*.f64 (+.f64 z #s(literal 1 binary64)) (/.f64 (-.f64 z #s(literal 1 binary64)) (-.f64 z #s(literal 1 binary64))))
(*.f64 (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 z z)) (-.f64 #s(literal 1 binary64) (*.f64 z z))) (+.f64 z #s(literal 1 binary64)))
z
(*.f64 z #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) z)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 z))
(*.f64 (neg.f64 z) (neg.f64 #s(literal 1 binary64)))
#s(literal 1 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64))
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (pow.f64 (neg.f64 #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 2 binary64))) (pow.f64 (neg.f64 #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 2 binary64))))
(*.f64 (pow.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))))

eval7.0ms (0.3%)

Memory
9.4MiB live, 9.4MiB allocated; 0ms collecting garbage
Compiler

Compiled 708 to 195 computations (72.5% saved)

prune7.0ms (0.2%)

Memory
8.3MiB live, 8.2MiB allocated; 0ms collecting garbage
Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New45752
Fresh000
Picked011
Done000
Total45853
Accuracy
100.0%
Counts
53 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
54.3%
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
71.1%
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 (+.f64 z #s(literal 1 binary64)) (-.f64 x y)))
51.1%
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
99.2%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
100.0%
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
47.7%
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
52.6%
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
Compiler

Compiled 195 to 151 computations (22.6% saved)

series133.0ms (4.5%)

Memory
-10.6MiB live, 83.0MiB allocated; 73ms collecting garbage
Counts
18 → 50
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
(+.f64 x (+.f64 y (*.f64 z (+.f64 x y))))
x
(+.f64 y (*.f64 z (+.f64 x y)))
y
(*.f64 z (+.f64 x y))
z
(+.f64 x y)
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
(*.f64 x (+.f64 #s(literal 1 binary64) z))
(+.f64 #s(literal 1 binary64) z)
#s(literal 1 binary64)
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
#s(approx (+ x y) y)
(+.f64 z #s(literal 1 binary64))
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
#s(approx (+ z 1) #s(literal 1 binary64))
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
#s(approx (+ x (+ y (* z (+ x y)))) (+.f64 y (*.f64 y z)))
#s(approx (+ x (+ y (* z (+ x y)))) (+.f64 y (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y z))))
#s(approx x x)
#s(approx (+ y (* z (+ x y))) (+.f64 y (fma.f64 x z (*.f64 y z))))
#s(approx (* z (+ x y)) (*.f64 y z))
#s(approx (* z (+ x y)) (fma.f64 x z (*.f64 y z)))
#s(approx (+ x y) y)
#s(approx (+ x y) (+.f64 x y))
#s(approx (* x (+ 1 z)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x)))))
#s(approx (+ x (+ y (* z (+ x y)))) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 z (+.f64 (/.f64 y x) (/.f64 (*.f64 y z) x))))))
#s(approx (+ y (* z (+ x y))) (*.f64 x z))
#s(approx (+ y (* z (+ x y))) (*.f64 x (+.f64 z (+.f64 (/.f64 y x) (/.f64 (*.f64 y z) x)))))
#s(approx (* z (+ x y)) (*.f64 x (+.f64 z (/.f64 (*.f64 y z) x))))
#s(approx (+ x y) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 y x))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x))))))
#s(approx (+ x (+ y (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) z) #s(literal 1 binary64)))))
#s(approx (+ x (+ y (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 y (*.f64 y z)) x))) #s(literal 1 binary64)))))
#s(approx (+ y (* z (+ x y))) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 y (*.f64 y z)) x))))))
#s(approx (* z (+ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))))))
#s(approx (+ x y) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 y x)) #s(literal 1 binary64)))))
#s(approx (+ x (+ y (* z (+ x y)))) (+.f64 x (*.f64 x z)))
#s(approx (+ x (+ y (* z (+ x y)))) (+.f64 x (fma.f64 x z (*.f64 y (+.f64 #s(literal 1 binary64) z)))))
#s(approx (+ y (* z (+ x y))) (fma.f64 x z (*.f64 y (+.f64 #s(literal 1 binary64) z))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y)))))
#s(approx (+ x (+ y (* z (+ x y)))) (*.f64 y (+.f64 #s(literal 1 binary64) (+.f64 z (+.f64 (/.f64 x y) (/.f64 (*.f64 x z) y))))))
#s(approx (+ y (* z (+ x y))) (*.f64 y (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 x z) y)))))
#s(approx (* z (+ x y)) (*.f64 y (+.f64 z (/.f64 (*.f64 x z) y))))
#s(approx (+ x y) (*.f64 y (+.f64 #s(literal 1 binary64) (/.f64 x y))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y))))))
#s(approx (+ x (+ y (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) z) #s(literal 1 binary64)))))
#s(approx (+ x (+ y (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 x z)) y))) #s(literal 1 binary64)))))
#s(approx (+ y (* z (+ x y))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y))) #s(literal 1 binary64)))))
#s(approx (* z (+ x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y))))))
#s(approx (+ x y) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x y)) #s(literal 1 binary64)))))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
#s(approx (+ y (* z (+ x y))) (+.f64 y (*.f64 z (+.f64 x y))))
#s(approx (* z (+ x y)) (*.f64 z (+.f64 x y)))
#s(approx z z)
#s(approx (+ 1 z) #s(literal 1 binary64))
#s(approx (+ 1 z) (+.f64 #s(literal 1 binary64) z))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x (+.f64 y (+.f64 (/.f64 x z) (/.f64 y z))))))
#s(approx (+ y (* z (+ x y))) (*.f64 z (+.f64 x (+.f64 y (/.f64 y z)))))
#s(approx (* x (+ 1 z)) (*.f64 z (+.f64 x (/.f64 x z))))
#s(approx (+ 1 z) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) z))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x y) z))))))
#s(approx (+ y (* z (+ x y))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (*.f64 #s(literal -1 binary64) (/.f64 y z))))))
#s(approx (* x (+ 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 x z))))))
Calls

9 calls:

TimeVariablePoint
2.0ms
x
inf
2.0ms
z
-inf
2.0ms
z
inf
2.0ms
x
-inf
1.0ms
x
0

rewrite321.0ms (10.9%)

Memory
37.8MiB live, 175.9MiB allocated; 26ms collecting garbage
Counts
18 → 62
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
(+.f64 x (+.f64 y (*.f64 z (+.f64 x y))))
x
(+.f64 y (*.f64 z (+.f64 x y)))
y
(*.f64 z (+.f64 x y))
z
(+.f64 x y)
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
(*.f64 x (+.f64 #s(literal 1 binary64) z))
(+.f64 #s(literal 1 binary64) z)
#s(literal 1 binary64)
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
#s(approx (+ x y) y)
(+.f64 z #s(literal 1 binary64))
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
#s(approx (+ z 1) #s(literal 1 binary64))
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 (+.f64 #s(literal 1 binary64) z) (+.f64 x y)))
(*.f64 (+.f64 #s(literal 1 binary64) z) (+.f64 x y))
(*.f64 (+.f64 x y) (+.f64 #s(literal 1 binary64) z))
(*.f64 (*.f64 (+.f64 #s(literal 1 binary64) z) (+.f64 x y)) #s(literal 1 binary64))
(*.f64 (-.f64 #s(literal 1 binary64) (*.f64 z z)) (/.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z)))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 (+.f64 #s(literal 1 binary64) z) (-.f64 x y)))
x
(*.f64 x #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) x)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 x))
(*.f64 (neg.f64 x) (neg.f64 #s(literal 1 binary64)))
(*.f64 (fma.f64 (+.f64 x y) z y) (/.f64 (-.f64 y (*.f64 z (+.f64 x y))) (-.f64 y (*.f64 z (+.f64 x y)))))
(*.f64 (/.f64 (*.f64 (fma.f64 (+.f64 x y) z y) (-.f64 y (*.f64 z (+.f64 x y)))) (*.f64 (fma.f64 (+.f64 x y) z y) (-.f64 y (*.f64 z (+.f64 x y))))) (fma.f64 (+.f64 x y) z y))
(*.f64 (fma.f64 (-.f64 (*.f64 z (+.f64 x y)) y) (*.f64 z (+.f64 x y)) (*.f64 y y)) (/.f64 (fma.f64 (+.f64 x y) z y) (fma.f64 (-.f64 (*.f64 z (+.f64 x y)) y) (*.f64 z (+.f64 x y)) (*.f64 y y))))
(*.f64 (/.f64 (fma.f64 (*.f64 y y) y (pow.f64 (*.f64 z (+.f64 x y)) #s(literal 3 binary64))) (-.f64 (*.f64 (*.f64 y y) (*.f64 y y)) (pow.f64 (*.f64 (-.f64 (*.f64 z (+.f64 x y)) y) (*.f64 z (+.f64 x y))) #s(literal 2 binary64)))) (-.f64 (*.f64 y y) (*.f64 (-.f64 (*.f64 z (+.f64 x y)) y) (*.f64 z (+.f64 x y)))))
(*.f64 (/.f64 (*.f64 (fma.f64 (+.f64 x y) z y) (-.f64 y (*.f64 z (+.f64 x y)))) (-.f64 (*.f64 (*.f64 y y) y) (pow.f64 (*.f64 z (+.f64 x y)) #s(literal 3 binary64)))) (fma.f64 (*.f64 z (+.f64 x y)) (fma.f64 (+.f64 x y) z y) (*.f64 y y)))
y
(*.f64 y #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) y)
(*.f64 (*.f64 y (neg.f64 #s(literal 1 binary64))) (neg.f64 #s(literal 1 binary64)))
(*.f64 (neg.f64 #s(literal 1 binary64)) (*.f64 (neg.f64 #s(literal 1 binary64)) y))
(*.f64 z (+.f64 x y))
(*.f64 (+.f64 x y) z)
(*.f64 (*.f64 z (+.f64 x y)) #s(literal 1 binary64))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y)))
(*.f64 #s(literal 1 binary64) (*.f64 z (+.f64 x y)))
z
(*.f64 z #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) z)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 z))
(*.f64 (neg.f64 z) (neg.f64 #s(literal 1 binary64)))
(*.f64 (+.f64 x y) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 x y))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 #s(literal 1 binary64) (-.f64 x y)))
(*.f64 (neg.f64 (+.f64 x y)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (+.f64 x y) (/.f64 (-.f64 x y) (-.f64 x y)))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
(*.f64 x (+.f64 #s(literal 1 binary64) z))
(*.f64 (+.f64 #s(literal 1 binary64) z) x)
(*.f64 (/.f64 x #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) z))
(*.f64 (fma.f64 z x x) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (fma.f64 z x x))
(*.f64 (+.f64 #s(literal 1 binary64) z) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) z))
(*.f64 (/.f64 (+.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) (/.f64 (-.f64 #s(literal 1 binary64) z) (-.f64 #s(literal 1 binary64) z)))
(*.f64 (/.f64 (fma.f64 z z #s(literal -1 binary64)) (fma.f64 z z #s(literal -1 binary64))) (+.f64 #s(literal 1 binary64) z))
(*.f64 (+.f64 #s(literal 1 binary64) z) (/.f64 (-.f64 z #s(literal 1 binary64)) (-.f64 z #s(literal 1 binary64))))
#s(literal 1 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64))
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (pow.f64 (neg.f64 #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 2 binary64))) (pow.f64 (neg.f64 #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 2 binary64))))
(*.f64 (pow.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
(*.f64 #s(approx (+ x y) y) (+.f64 #s(literal 1 binary64) z))
#s(approx (+ x y) y)
(*.f64 (+.f64 #s(literal 1 binary64) z) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) z))
(*.f64 (/.f64 (+.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) (/.f64 (-.f64 #s(literal 1 binary64) z) (-.f64 #s(literal 1 binary64) z)))
(*.f64 (/.f64 (fma.f64 z z #s(literal -1 binary64)) (fma.f64 z z #s(literal -1 binary64))) (+.f64 #s(literal 1 binary64) z))
(*.f64 (+.f64 #s(literal 1 binary64) z) (/.f64 (-.f64 z #s(literal 1 binary64)) (-.f64 z #s(literal 1 binary64))))
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
#s(approx (+ z 1) #s(literal 1 binary64))

eval28.0ms (1%)

Memory
-28.3MiB live, 23.4MiB allocated; 15ms collecting garbage
Compiler

Compiled 3 590 to 613 computations (82.9% saved)

prune8.0ms (0.3%)

Memory
10.7MiB live, 10.7MiB allocated; 0ms collecting garbage
Pruning

10 alts after pruning (5 fresh and 5 done)

PrunedKeptTotal
New1714175
Fresh112
Picked145
Done011
Total17310183
Accuracy
100.0%
Counts
183 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
54.3%
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
51.1%
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
52.6%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
99.2%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
100.0%
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
42.0%
#s(approx (* (+ x y) (+ z 1)) (*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y))))
47.7%
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
26.0%
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
23.1%
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
Compiler

Compiled 221 to 160 computations (27.6% saved)

series168.0ms (5.7%)

Memory
18.2MiB live, 64.2MiB allocated; 3ms collecting garbage
Counts
22 → 79
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
(fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z)))
x
(+.f64 #s(literal 1 binary64) z)
#s(literal 1 binary64)
z
(*.f64 y (+.f64 #s(literal 1 binary64) z))
y
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* z (+ x y)) (*.f64 y z))
(*.f64 y z)
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
(*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64)))
#s(approx (+ 1 z) #s(literal 1 binary64))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
(fma.f64 z x x)
#s(approx (* (+ x y) (+ z 1)) (*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y))))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y)))
(*.f64 (+.f64 x y) (-.f64 x y))
(+.f64 x y)
(-.f64 x y)
(/.f64 z (-.f64 x y))
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
#s(approx x x)
#s(approx (* z (+ x y)) (*.f64 y z))
#s(approx (* z (+ x y)) (fma.f64 x z (*.f64 y z)))
#s(approx (* x (+ 1 z)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (- x y)) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64))))
#s(approx (* (+ x y) (- x y)) (fma.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)) (*.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) y)))))
#s(approx (* (+ x y) (- x y)) (fma.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)) (*.f64 x (+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) y))))))
#s(approx (+ x y) y)
#s(approx (+ x y) (+.f64 x y))
#s(approx (- x y) (*.f64 #s(literal -1 binary64) y))
#s(approx (- x y) (-.f64 x y))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 z y)))
#s(approx (/ z (- x y)) (fma.f64 #s(literal -1 binary64) (/.f64 z y) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) (pow.f64 y #s(literal 2 binary64))))))
#s(approx (/ z (- x y)) (fma.f64 #s(literal -1 binary64) (/.f64 z y) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) (pow.f64 y #s(literal 3 binary64)))) (/.f64 z (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (/ z (- x y)) (fma.f64 #s(literal -1 binary64) (/.f64 z y) (*.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) (pow.f64 y #s(literal 4 binary64)))) (/.f64 z (pow.f64 y #s(literal 3 binary64))))) (/.f64 z (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x)))))
#s(approx (* z (+ x y)) (*.f64 x z))
#s(approx (* z (+ x y)) (*.f64 x (+.f64 z (/.f64 (*.f64 y z) x))))
#s(approx (* (+ x y) (- x y)) (pow.f64 x #s(literal 2 binary64)))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 y x) (/.f64 y x)))))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 y x) (fma.f64 #s(literal -1 binary64) (/.f64 (pow.f64 y #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) (/.f64 y x))))))
#s(approx (+ x y) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 y x))))
#s(approx (- x y) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 y x)))))
#s(approx (/ z (- x y)) (/.f64 z x))
#s(approx (/ z (- x y)) (/.f64 (+.f64 z (/.f64 (*.f64 y z) x)) x))
#s(approx (/ z (- x y)) (/.f64 (-.f64 (+.f64 z (/.f64 (*.f64 (pow.f64 y #s(literal 2 binary64)) z) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))) x))
#s(approx (/ z (- x y)) (/.f64 (-.f64 (+.f64 z (/.f64 (*.f64 (pow.f64 y #s(literal 3 binary64)) z) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 (pow.f64 y #s(literal 2 binary64)) z) (pow.f64 x #s(literal 2 binary64)))))) x))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x))))))
#s(approx (* z (+ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))))))
#s(approx (+ (* z x) x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) z) #s(literal 1 binary64)))))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (+.f64 y (*.f64 #s(literal -1 binary64) y)) (/.f64 (pow.f64 y #s(literal 2 binary64)) x)) x)))))
#s(approx (+ x y) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 y x)) #s(literal 1 binary64)))))
#s(approx (- x y) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 y x) #s(literal 1 binary64)))))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))) x)))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 y z (/.f64 (*.f64 (pow.f64 y #s(literal 2 binary64)) z) x)) x))) x)))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (*.f64 (pow.f64 y #s(literal 2 binary64)) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 (pow.f64 y #s(literal 3 binary64)) z) x))) x) (*.f64 y z)) x))) x)))
#s(approx (* (+ x y) (- x y)) (fma.f64 y (+.f64 x (*.f64 #s(literal -1 binary64) x)) (pow.f64 x #s(literal 2 binary64))))
#s(approx (* (+ x y) (- x y)) (fma.f64 y (+.f64 x (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) y))) (pow.f64 x #s(literal 2 binary64))))
#s(approx (- x y) (+.f64 x (*.f64 #s(literal -1 binary64) y)))
#s(approx (/ z (- x y)) (+.f64 (/.f64 z x) (/.f64 (*.f64 y z) (pow.f64 x #s(literal 2 binary64)))))
#s(approx (/ z (- x y)) (fma.f64 y (-.f64 (/.f64 (*.f64 y z) (pow.f64 x #s(literal 3 binary64))) (*.f64 #s(literal -1 binary64) (/.f64 z (pow.f64 x #s(literal 2 binary64))))) (/.f64 z x)))
#s(approx (/ z (- x y)) (fma.f64 y (-.f64 (*.f64 y (-.f64 (/.f64 (*.f64 y z) (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal -1 binary64) (/.f64 z (pow.f64 x #s(literal 3 binary64)))))) (*.f64 #s(literal -1 binary64) (/.f64 z (pow.f64 x #s(literal 2 binary64))))) (/.f64 z x)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y)))))
#s(approx (* z (+ x y)) (*.f64 y (+.f64 z (/.f64 (*.f64 x z) y))))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 x y) (/.f64 x y)) #s(literal 1 binary64))))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 x y) (+.f64 (/.f64 x y) (/.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) #s(literal 1 binary64))))
#s(approx (+ x y) (*.f64 y (+.f64 #s(literal 1 binary64) (/.f64 x y))))
#s(approx (- x y) (*.f64 y (-.f64 (/.f64 x y) #s(literal 1 binary64))))
#s(approx (/ z (- x y)) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y))) y))
#s(approx (/ z (- x y)) (/.f64 (-.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) z) (pow.f64 y #s(literal 2 binary64))))) (/.f64 (*.f64 x z) y)) y))
#s(approx (/ z (- x y)) (/.f64 (-.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) z) (pow.f64 y #s(literal 3 binary64))))) (+.f64 (/.f64 (*.f64 x z) y) (/.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) z) (pow.f64 y #s(literal 2 binary64))))) y))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y))))))
#s(approx (* z (+ x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y))))))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) x)) y)) #s(literal 1 binary64))))
#s(approx (* (+ x y) (- x y)) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (pow.f64 x #s(literal 2 binary64)) y)))) y)) #s(literal 1 binary64))))
#s(approx (+ x y) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x y)) #s(literal 1 binary64)))))
#s(approx (- x y) (*.f64 #s(literal -1 binary64) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x y))))))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (/.f64 (*.f64 x z) y)) y)))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) z) y)) (*.f64 x z)) y))) y)))
#s(approx (/ z (- x y)) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 (pow.f64 x #s(literal 3 binary64)) z) y) (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) z))) y)) (*.f64 x z)) y))) y)))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
#s(approx (+ 1 z) #s(literal 1 binary64))
#s(approx (+ 1 z) (+.f64 #s(literal 1 binary64) z))
#s(approx z z)
#s(approx (* y (+ 1 z)) (+.f64 y (*.f64 y z)))
#s(approx (* z (+ x y)) (*.f64 z (+.f64 x y)))
#s(approx (* x (+ 1 z)) (+.f64 x (*.f64 x z)))
#s(approx (/ z (- x y)) (/.f64 z (-.f64 x y)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x (+.f64 y (+.f64 (/.f64 x z) (/.f64 y z))))))
#s(approx (+ 1 z) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) z))))
#s(approx (* y (+ 1 z)) (*.f64 z (+.f64 y (/.f64 y z))))
#s(approx (* x (+ 1 z)) (*.f64 z (+.f64 x (/.f64 x z))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x y) z))))))
#s(approx (+ (* x (+ 1 z)) (* y (+ 1 z))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) y)))))
#s(approx (+ (* x (+ 1 z)) (* y (+ 1 z))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x y) z)))))))
#s(approx (* y (+ 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 y z))))))
#s(approx (* x (+ 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 x z))))))
Calls

9 calls:

TimeVariablePoint
3.0ms
x
0
2.0ms
z
-inf
2.0ms
x
-inf
2.0ms
z
inf
2.0ms
y
-inf

rewrite340.0ms (11.5%)

Memory
-17.4MiB live, 122.3MiB allocated; 31ms collecting garbage
Counts
22 → 77
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
(fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z)))
x
(+.f64 #s(literal 1 binary64) z)
#s(literal 1 binary64)
z
(*.f64 y (+.f64 #s(literal 1 binary64) z))
y
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* z (+ x y)) (*.f64 y z))
(*.f64 y z)
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
(*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64)))
#s(approx (+ 1 z) #s(literal 1 binary64))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
(fma.f64 z x x)
#s(approx (* (+ x y) (+ z 1)) (*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y))))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y)))
(*.f64 (+.f64 x y) (-.f64 x y))
(+.f64 x y)
(-.f64 x y)
(/.f64 z (-.f64 x y))
Outputs
#s(approx (* (+ x y) (+ 1 z)) (*.f64 (+.f64 #s(literal 1 binary64) z) (+.f64 x y)))
(*.f64 (+.f64 #s(literal 1 binary64) z) (+.f64 x y))
(*.f64 (+.f64 x y) (+.f64 #s(literal 1 binary64) z))
(*.f64 (*.f64 (+.f64 #s(literal 1 binary64) z) (+.f64 x y)) #s(literal 1 binary64))
(*.f64 (*.f64 (+.f64 #s(literal 1 binary64) z) (-.f64 x y)) (/.f64 (+.f64 x y) (-.f64 x y)))
(*.f64 (-.f64 #s(literal 1 binary64) (*.f64 z z)) (/.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z)))
x
(*.f64 x #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) x)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 x))
(*.f64 (neg.f64 x) (neg.f64 #s(literal 1 binary64)))
(*.f64 (+.f64 #s(literal 1 binary64) z) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) z))
(*.f64 (/.f64 (+.f64 #s(literal 1 binary64) z) #s(literal 1 binary64)) (/.f64 (-.f64 #s(literal 1 binary64) z) (-.f64 #s(literal 1 binary64) z)))
(*.f64 (/.f64 (fma.f64 z z #s(literal -1 binary64)) (fma.f64 z z #s(literal -1 binary64))) (+.f64 #s(literal 1 binary64) z))
(*.f64 (+.f64 #s(literal 1 binary64) z) (/.f64 (-.f64 z #s(literal 1 binary64)) (-.f64 z #s(literal 1 binary64))))
#s(literal 1 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64))
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1 binary64)) (pow.f64 #s(literal 1 binary64) #s(literal 1 binary64)))
(*.f64 (/.f64 (+.f64 x y) (-.f64 x y)) (/.f64 (-.f64 x y) (+.f64 x y)))
z
(*.f64 z #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) z)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 z))
(*.f64 (neg.f64 z) (neg.f64 #s(literal 1 binary64)))
(*.f64 y (+.f64 #s(literal 1 binary64) z))
(*.f64 (+.f64 #s(literal 1 binary64) z) y)
(*.f64 (/.f64 y #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) z))
(*.f64 (fma.f64 z y y) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (fma.f64 z y y))
y
(*.f64 y #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) y)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 y))
(*.f64 (neg.f64 y) (neg.f64 #s(literal 1 binary64)))
#s(approx (* (+ x y) (+ 1 z)) #s(approx (* (+ x y) z) (*.f64 y z)))
#s(approx (* (+ x y) z) (*.f64 y z))
(*.f64 y z)
(*.f64 z y)
(*.f64 (*.f64 y z) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 y z))
#s(approx (* (+ x y) (+ 1 z)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
(*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64)))
#s(approx (+ 1 z) #s(literal 1 binary64))
#s(approx (* (+ x y) (+ 1 z)) (fma.f64 z x x))
(*.f64 (+.f64 #s(literal 1 binary64) z) x)
(*.f64 (/.f64 x #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) z))
(*.f64 (fma.f64 z x x) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (fma.f64 z x x))
(*.f64 x (+.f64 #s(literal 1 binary64) z))
#s(approx (* (+ x y) (+ 1 z)) (*.f64 (+.f64 x y) z))
(*.f64 (+.f64 x y) z)
(*.f64 z (+.f64 x y))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y)))
(*.f64 (*.f64 (+.f64 x y) z) #s(literal 1 binary64))
(*.f64 (*.f64 (-.f64 x y) z) (/.f64 (+.f64 x y) (-.f64 x y)))
(*.f64 (+.f64 x y) (-.f64 x y))
(*.f64 (-.f64 x y) (+.f64 x y))
(*.f64 (*.f64 (+.f64 x y) (+.f64 x y)) (/.f64 (-.f64 x y) (+.f64 x y)))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) #s(literal 1 binary64))
(*.f64 (neg.f64 (+.f64 x y)) (-.f64 (neg.f64 x) (neg.f64 y)))
(*.f64 (+.f64 x y) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 x y))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 #s(literal 1 binary64) (-.f64 x y)))
(*.f64 (neg.f64 (+.f64 x y)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (/.f64 (+.f64 x y) (-.f64 x y)) (-.f64 x y))
(*.f64 (-.f64 x y) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (-.f64 x y))
(*.f64 (/.f64 (-.f64 x y) (+.f64 x y)) (+.f64 x y))
(*.f64 (+.f64 x y) (/.f64 (-.f64 x y) (+.f64 x y)))
(*.f64 (*.f64 (/.f64 (+.f64 x y) (fma.f64 (+.f64 x y) y (*.f64 x x))) #s(literal 1 binary64)) (*.f64 (fma.f64 (+.f64 x y) y (*.f64 x x)) (/.f64 (-.f64 x y) (+.f64 x y))))
(*.f64 (/.f64 #s(literal 1 binary64) (-.f64 x y)) z)
(*.f64 (/.f64 z (-.f64 x y)) #s(literal 1 binary64))
(*.f64 (/.f64 z (+.f64 x y)) (/.f64 (+.f64 x y) (-.f64 x y)))
(*.f64 #s(literal 1 binary64) (/.f64 z (-.f64 x y)))
(*.f64 z (/.f64 #s(literal 1 binary64) (-.f64 x y)))

eval51.0ms (1.7%)

Memory
-4.4MiB live, 39.2MiB allocated; 9ms collecting garbage
Compiler

Compiled 4 859 to 890 computations (81.7% saved)

prune6.0ms (0.2%)

Memory
8.5MiB live, 8.5MiB allocated; 0ms collecting garbage
Pruning

11 alts after pruning (1 fresh and 10 done)

PrunedKeptTotal
New1821183
Fresh000
Picked055
Done055
Total18211193
Accuracy
100.0%
Counts
193 → 11
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
54.3%
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
51.1%
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
52.6%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
99.2%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
100.0%
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
42.0%
#s(approx (* (+ x y) (+ z 1)) (*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y))))
47.7%
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
26.0%
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
23.1%
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
29.0%
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
Compiler

Compiled 155 to 114 computations (26.5% saved)

series96.0ms (3.2%)

Memory
23.5MiB live, 68.3MiB allocated; 14ms collecting garbage
Counts
5 → 21
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* z (+ x y)) (*.f64 x z))
(*.f64 x z)
x
z
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
#s(approx (* z (+ x y)) (*.f64 y z))
#s(approx (* z (+ x y)) (fma.f64 x z (*.f64 y z)))
#s(approx (* x z) (*.f64 x z))
#s(approx x x)
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x)))))
#s(approx (* z (+ x y)) (*.f64 x (+.f64 z (/.f64 (*.f64 y z) x))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 #s(literal 1 binary64) z)) x))))))
#s(approx (* z (+ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 y (+.f64 #s(literal 1 binary64) (+.f64 z (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y)))))
#s(approx (* z (+ x y)) (*.f64 y (+.f64 z (/.f64 (*.f64 x z) y))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (+.f64 #s(literal 1 binary64) z)) y))))))
#s(approx (* z (+ x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y))))))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
#s(approx (* z (+ x y)) (*.f64 z (+.f64 x y)))
#s(approx z z)
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x (+.f64 y (+.f64 (/.f64 x z) (/.f64 y z))))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x y) z))))))
Calls

9 calls:

TimeVariablePoint
1.0ms
z
-inf
1.0ms
x
-inf
1.0ms
z
inf
1.0ms
x
inf
0.0ms
z
0

rewrite327.0ms (11.1%)

Memory
-47.5MiB live, 128.9MiB allocated; 244ms collecting garbage
Counts
5 → 16
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* z (+ x y)) (*.f64 x z))
(*.f64 x z)
x
z
Outputs
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* z (+ x y)) (*.f64 x z))
(*.f64 x z)
(*.f64 z x)
(*.f64 (*.f64 x z) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 x z))
x
(*.f64 x #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) x)
(*.f64 (*.f64 x (neg.f64 #s(literal 1 binary64))) (neg.f64 #s(literal 1 binary64)))
(*.f64 (neg.f64 #s(literal 1 binary64)) (*.f64 (neg.f64 #s(literal 1 binary64)) x))
z
(*.f64 z #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) z)
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 z))
(*.f64 (neg.f64 z) (neg.f64 #s(literal 1 binary64)))

eval4.0ms (0.1%)

Memory
5.8MiB live, 5.8MiB allocated; 0ms collecting garbage
Compiler

Compiled 595 to 137 computations (77% saved)

prune4.0ms (0.1%)

Memory
5.9MiB live, 5.9MiB allocated; 0ms collecting garbage
Pruning

10 alts after pruning (1 fresh and 9 done)

PrunedKeptTotal
New28129
Fresh000
Picked011
Done2810
Total301040
Accuracy
100.0%
Counts
40 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
51.1%
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
52.6%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
99.2%
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
100.0%
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
54.3%
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
42.0%
#s(approx (* (+ x y) (+ z 1)) (*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y))))
47.7%
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
23.1%
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
29.0%
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
Compiler

Compiled 142 to 102 computations (28.2% saved)

regimes132.0ms (4.4%)

Memory
-19.8MiB live, 125.8MiB allocated; 30ms collecting garbage
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
4 → 3
6 → 3
7 → 3
9 → 2
14 → 1
Calls
Call 1
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
Outputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
Call 2
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
Outputs
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
Call 3
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
Outputs
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
Call 4
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
Call 5
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
Outputs
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
Call 6
Inputs
#s(approx (* (+ x y) (+ z 1)) (+.f64 x y))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 x z)))
#s(approx (* (+ x y) (+ z 1)) #s(approx (* z (+ x y)) (*.f64 y z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x #s(approx (+ 1 z) #s(literal 1 binary64))))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 z x x))
#s(approx (* (+ x y) (+ z 1)) (*.f64 x (+.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (+ z 1)) (*.f64 z (+.f64 x y)))
(*.f64 #s(approx (+ x y) y) (+.f64 z #s(literal 1 binary64)))
(*.f64 (+.f64 x y) #s(approx (+ z 1) #s(literal 1 binary64)))
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
#s(approx (* (+ x y) (+ z 1)) (+.f64 x (+.f64 y (*.f64 z (+.f64 x y)))))
#s(approx (* (+ x y) (+ z 1)) (fma.f64 x (+.f64 #s(literal 1 binary64) z) (*.f64 y (+.f64 #s(literal 1 binary64) z))))
#s(approx (* (+ x y) (+ z 1)) (*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 z (-.f64 x y))))
(*.f64 (*.f64 (+.f64 x y) (-.f64 x y)) (/.f64 (+.f64 z #s(literal 1 binary64)) (-.f64 x y)))
Outputs
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
Calls

29 calls:

34.0ms
(+.f64 z #s(literal 1 binary64))
10.0ms
y
8.0ms
z
7.0ms
x
6.0ms
(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
Results
AccuracySegmentsBranch
54.3%1(+.f64 x y)
54.3%1y
54.3%1x
54.3%1(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
54.3%1(+.f64 z #s(literal 1 binary64))
54.3%1z
57.6%2(+.f64 x y)
80.0%3(+.f64 z #s(literal 1 binary64))
80.0%3z
71.0%2y
74.2%3(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
71.9%2x
80.5%3(+.f64 z #s(literal 1 binary64))
80.5%3z
98.5%3(+.f64 z #s(literal 1 binary64))
98.5%3z
78.7%2(+.f64 x y)
98.5%3(+.f64 z #s(literal 1 binary64))
98.5%2(+.f64 x y)
87.6%4(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
86.9%2x
84.4%2y
98.5%3z
100.0%1(+.f64 z #s(literal 1 binary64))
100.0%1(+.f64 x y)
100.0%1(*.f64 (+.f64 x y) (+.f64 z #s(literal 1 binary64)))
100.0%1x
100.0%1y
100.0%1z
Compiler

Compiled 269 to 167 computations (37.9% saved)

bsearch1.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-2.592357772080859e-214
2.5042111024315367e-230
Compiler

Compiled 10 to 13 computations (-30% saved)

bsearch24.0ms (0.8%)

Memory
21.5MiB live, 21.5MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
10.0ms
0.7487567362269308
3035958.2687871926
11.0ms
-1.7658752100715067
-2.51378096712357e-11
Samples
10.0ms304×0valid
Compiler

Compiled 466 to 412 computations (11.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 3.0ms
ival-add!: 2.0ms (64% of total)
ival-mult!: 1.0ms (32% of total)
adjust: 0.0ms (0% of total)

bsearch23.0ms (0.8%)

Memory
-14.4MiB live, 32.6MiB allocated; 1ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
10.0ms
3.500949348551675e-14
0.7487567362269308
11.0ms
-2.51378096712357e-11
-6.754423238242063e-19
Samples
11.0ms304×0valid
Compiler

Compiled 447 to 393 computations (12.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 3.0ms
ival-add!: 2.0ms (65.1% of total)
ival-mult!: 1.0ms (32.6% of total)
adjust: 0.0ms (0% of total)

bsearch11.0ms (0.4%)

Memory
15.2MiB live, 15.2MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
9.0ms
3035958.2687871926
840153494194.139
1.0ms
-1.7658752100715067
-2.51378096712357e-11
Samples
4.0ms144×0valid
Compiler

Compiled 542 to 431 computations (20.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 1.0ms
ival-add!: 1.0ms (70.5% of total)
ival-mult!: 1.0ms (70.5% of total)
adjust: 0.0ms (0% of total)

derivations2.0ms (0.1%)

Memory
2.6MiB live, 2.6MiB allocated; 0ms collecting garbage
Stop Event
fuel
Compiler

Compiled 187 to 43 computations (77% saved)

preprocess58.0ms (2%)

Memory
-39.1MiB live, 104.4MiB allocated; 13ms collecting garbage
Remove

(sort x y)

Compiler

Compiled 568 to 224 computations (60.6% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated; 0ms collecting garbage

Profiling

Loading profile data...