Graphics.Rendering.Plot.Render.Plot.Legend:renderLegendInside from plot-0.2.3.4

Time bar (total: 3.1s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.5MiB live, 0.5MiB 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 13 to 10 computations (23.1% saved)

sample942.0ms (30%)

Memory
-8.7MiB live, 1 279.0MiB allocated; 317ms collecting garbage
Samples
641.0ms7 636×0valid
29.0ms78×3valid
27.0ms356×1valid
27.0ms186×2valid
Precisions
Click to see histograms. Total time spent on operations: 292.0ms
ival-add!: 257.0ms (87.9% of total)
adjust: 35.0ms (12% of total)
Bogosity

preprocess85.0ms (2.7%)

Memory
-39.8MiB live, 69.8MiB allocated; 21ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
041115
116791
285790
3334090
4452890
5490690
6541690
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.9%
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
Compiler

Compiled 16 to 16 computations (0% saved)

series13.0ms (0.4%)

Memory
24.4MiB live, 24.4MiB allocated; 0ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0157710
Stop Event
iter-limit
Counts
8 → 40
Calls
Call 1
Inputs
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
(+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z)
(+.f64 (+.f64 (+.f64 x y) y) x)
(+.f64 (+.f64 x y) y)
(+.f64 x y)
x
y
z
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y))
#s(approx (+ (+ (+ x y) y) x) (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ x y) y) (+.f64 x (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ x y) y)
#s(approx (+ x y) (+.f64 x y))
#s(approx x x)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 x (+.f64 #s(literal 3 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal 2 binary64) x))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 x (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 x (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y x)))))
#s(approx (+ (+ x y) y) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #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) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 3 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y x)) #s(literal 2 binary64)))))
#s(approx (+ (+ x y) y) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y x)) #s(literal 1 binary64)))))
#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) y) x) z) x) (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (+.f64 (/.f64 x y) (/.f64 z y))))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (/.f64 z y)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 y (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (/.f64 x y)))))
#s(approx (+ (+ x y) y) (*.f64 y (+.f64 #s(literal 2 binary64) (/.f64 x y))))
#s(approx (+ x y) (*.f64 y (+.f64 #s(literal 1 binary64) (/.f64 x y))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))) y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) x)) y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 x y)) #s(literal 2 binary64)))))
#s(approx (+ (+ x y) y) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x y)) #s(literal 2 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) y) x) z) x) (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx z z)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (/.f64 x z))))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (*.f64 #s(literal 2 binary64) (/.f64 y z))))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))) z)) #s(literal 1 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)) z)) #s(literal 1 binary64)))))
Calls

9 calls:

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

rewrite197.0ms (6.3%)

Memory
19.4MiB live, 158.9MiB allocated; 28ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0838
01338
110532
242932
3209832
4642732
0808228
1966728
Stop Event
saturated
node-limit
iter-limit
Counts
8 → 152
Calls
Call 1
Inputs
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
(+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z)
(+.f64 (+.f64 (+.f64 x y) y) x)
(+.f64 (+.f64 x y) y)
(+.f64 x y)
x
y
z
Outputs
(neg.f64 (neg.f64 (fma.f64 #s(literal 2 binary64) y (fma.f64 #s(literal 3 binary64) x z))))
(fma.f64 #s(literal -2 binary64) (-.f64 (neg.f64 x) y) (+.f64 z x))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (fma.f64 #s(literal 3 binary64) x z))
(fma.f64 #s(literal 2 binary64) (+.f64 y x) (+.f64 z x))
(fma.f64 #s(literal 2 binary64) y (fma.f64 #s(literal 3 binary64) x z))
(fma.f64 #s(literal 2 binary64) x (fma.f64 #s(literal 2 binary64) y (+.f64 z x)))
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
(fma.f64 (+.f64 y x) #s(literal 2 binary64) (+.f64 z x))
(fma.f64 y #s(literal 2 binary64) (fma.f64 #s(literal 3 binary64) x z))
(fma.f64 x #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) y (+.f64 z x)))
(-.f64 (*.f64 #s(literal 3 binary64) x) (-.f64 (*.f64 #s(literal -2 binary64) y) z))
(-.f64 (+.f64 z y) (+.f64 (-.f64 (neg.f64 x) y) (*.f64 #s(literal -2 binary64) x)))
(-.f64 (+.f64 z y) (-.f64 (-.f64 (neg.f64 x) y) (+.f64 x x)))
(-.f64 (+.f64 z y) (-.f64 (neg.f64 x) (fma.f64 #s(literal 2 binary64) x y)))
(-.f64 (fma.f64 #s(literal 2 binary64) y z) (+.f64 (neg.f64 x) (*.f64 #s(literal -2 binary64) x)))
(-.f64 (fma.f64 #s(literal 2 binary64) y z) (-.f64 (neg.f64 x) (+.f64 x x)))
(-.f64 (+.f64 (fma.f64 #s(literal 3 binary64) x z) y) (neg.f64 y))
(-.f64 (fma.f64 #s(literal 3 binary64) x z) (*.f64 #s(literal -2 binary64) y))
(-.f64 (fma.f64 #s(literal 3 binary64) x y) (-.f64 (neg.f64 z) y))
(-.f64 (+.f64 x x) (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) y) x) z))
(-.f64 (+.f64 (fma.f64 #s(literal 2 binary64) x y) z) (-.f64 (neg.f64 x) y))
(-.f64 (fma.f64 #s(literal 2 binary64) x y) (-.f64 (-.f64 (neg.f64 x) y) z))
(-.f64 (+.f64 (+.f64 z x) y) (-.f64 (*.f64 #s(literal -2 binary64) x) y))
(-.f64 (fma.f64 #s(literal 2 binary64) y (+.f64 z x)) (*.f64 #s(literal -2 binary64) x))
(-.f64 (fma.f64 #s(literal 2 binary64) (+.f64 y x) x) (neg.f64 z))
(-.f64 (fma.f64 #s(literal 2 binary64) x z) (-.f64 (*.f64 #s(literal -2 binary64) y) x))
(-.f64 (+.f64 y y) (+.f64 (-.f64 (neg.f64 z) x) (*.f64 #s(literal -2 binary64) x)))
(-.f64 (+.f64 y y) (-.f64 (-.f64 (neg.f64 z) x) (+.f64 x x)))
(-.f64 (+.f64 y y) (-.f64 (neg.f64 x) (fma.f64 #s(literal 2 binary64) x z)))
(-.f64 (+.f64 y y) (+.f64 (neg.f64 x) (-.f64 (*.f64 #s(literal -2 binary64) x) z)))
(-.f64 (+.f64 y y) (neg.f64 (fma.f64 #s(literal 3 binary64) x z)))
(-.f64 (+.f64 z x) (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(-.f64 (fma.f64 #s(literal 2 binary64) (+.f64 y x) z) (neg.f64 x))
(-.f64 z (-.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) x))
(-.f64 (*.f64 #s(literal 2 binary64) (+.f64 y x)) (-.f64 (neg.f64 z) x))
(-.f64 (fma.f64 #s(literal 2 binary64) y x) (-.f64 (*.f64 #s(literal -2 binary64) x) z))
(-.f64 (+.f64 y x) (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) y) z))
(-.f64 y (-.f64 (-.f64 (neg.f64 z) x) (fma.f64 #s(literal 2 binary64) x y)))
(-.f64 y (-.f64 (neg.f64 y) (fma.f64 #s(literal 3 binary64) x z)))
(-.f64 x (-.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) z))
(+.f64 (*.f64 #s(literal 3 binary64) x) (fma.f64 #s(literal 2 binary64) y z))
(+.f64 (+.f64 z y) (fma.f64 #s(literal 3 binary64) x y))
(+.f64 (fma.f64 #s(literal 2 binary64) y z) (*.f64 #s(literal 3 binary64) x))
(+.f64 (+.f64 (fma.f64 #s(literal 3 binary64) x z) y) y)
(+.f64 (fma.f64 #s(literal 3 binary64) x z) (+.f64 y y))
(+.f64 (fma.f64 #s(literal 3 binary64) x y) (+.f64 z y))
(+.f64 (+.f64 x x) (fma.f64 #s(literal 2 binary64) y (+.f64 z x)))
(+.f64 (+.f64 (fma.f64 #s(literal 2 binary64) x y) z) (+.f64 y x))
(+.f64 (fma.f64 #s(literal 2 binary64) x y) (+.f64 (+.f64 z x) y))
(+.f64 (+.f64 (+.f64 z x) y) (fma.f64 #s(literal 2 binary64) x y))
(+.f64 (fma.f64 #s(literal 2 binary64) y (+.f64 z x)) (+.f64 x x))
(+.f64 (fma.f64 #s(literal 2 binary64) (+.f64 y x) x) z)
(+.f64 (fma.f64 #s(literal 2 binary64) x z) (fma.f64 #s(literal 2 binary64) y x))
(+.f64 (+.f64 y y) (fma.f64 #s(literal 3 binary64) x z))
(+.f64 (+.f64 z x) (*.f64 #s(literal 2 binary64) (+.f64 y x)))
(+.f64 (fma.f64 #s(literal 2 binary64) (+.f64 y x) z) x)
(+.f64 z (fma.f64 #s(literal 2 binary64) (+.f64 y x) x))
(+.f64 (*.f64 #s(literal 2 binary64) (+.f64 y x)) (+.f64 z x))
(+.f64 (fma.f64 #s(literal 2 binary64) y x) (fma.f64 #s(literal 2 binary64) x z))
(+.f64 (+.f64 y x) (+.f64 (fma.f64 #s(literal 2 binary64) x y) z))
(+.f64 y (+.f64 (fma.f64 #s(literal 3 binary64) x z) y))
(+.f64 x (fma.f64 #s(literal 2 binary64) (+.f64 y x) z))
(neg.f64 (-.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)) z))
(fma.f64 #s(literal -2 binary64) (-.f64 (neg.f64 x) y) z)
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (fma.f64 #s(literal 2 binary64) x z))
(fma.f64 #s(literal 2 binary64) (+.f64 y x) z)
(fma.f64 #s(literal 2 binary64) y (fma.f64 #s(literal 2 binary64) x z))
(fma.f64 #s(literal 2 binary64) x (fma.f64 #s(literal 2 binary64) y z))
(fma.f64 (+.f64 y x) #s(literal 2 binary64) z)
(fma.f64 y #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) x z))
(fma.f64 x #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) y z))
(-.f64 (+.f64 z y) (-.f64 (*.f64 #s(literal -2 binary64) x) y))
(-.f64 (fma.f64 #s(literal 2 binary64) y z) (*.f64 #s(literal -2 binary64) x))
(-.f64 (+.f64 x x) (-.f64 (neg.f64 z) (+.f64 y y)))
(-.f64 (+.f64 x x) (-.f64 (*.f64 #s(literal -2 binary64) y) z))
(-.f64 (+.f64 (fma.f64 #s(literal 2 binary64) x y) z) (neg.f64 y))
(-.f64 (fma.f64 #s(literal 2 binary64) x y) (-.f64 (neg.f64 z) y))
(-.f64 (+.f64 (+.f64 z x) y) (-.f64 (neg.f64 x) y))
(-.f64 (fma.f64 #s(literal 2 binary64) y (+.f64 z x)) (neg.f64 x))
(-.f64 (fma.f64 #s(literal 2 binary64) x z) (*.f64 #s(literal -2 binary64) y))
(-.f64 (+.f64 y y) (-.f64 (*.f64 #s(literal -2 binary64) x) z))
(-.f64 (+.f64 z x) (-.f64 (*.f64 #s(literal -2 binary64) y) x))
(-.f64 z (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(-.f64 (*.f64 #s(literal 2 binary64) (+.f64 y x)) (neg.f64 z))
(-.f64 (fma.f64 #s(literal 2 binary64) y x) (-.f64 (neg.f64 z) x))
(-.f64 (+.f64 y x) (-.f64 (-.f64 (neg.f64 x) y) z))
(-.f64 y (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) y) z))
(-.f64 x (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) y) x) z))
(+.f64 (+.f64 z y) (fma.f64 #s(literal 2 binary64) x y))
(+.f64 (fma.f64 #s(literal 2 binary64) y z) (+.f64 x x))
(+.f64 (+.f64 x x) (fma.f64 #s(literal 2 binary64) y z))
(+.f64 (+.f64 (fma.f64 #s(literal 2 binary64) x y) z) y)
(+.f64 (fma.f64 #s(literal 2 binary64) x y) (+.f64 z y))
(+.f64 (+.f64 (+.f64 z x) y) (+.f64 y x))
(+.f64 (fma.f64 #s(literal 2 binary64) y (+.f64 z x)) x)
(+.f64 (fma.f64 #s(literal 2 binary64) x z) (+.f64 y y))
(+.f64 (+.f64 y y) (fma.f64 #s(literal 2 binary64) x z))
(+.f64 (+.f64 z x) (fma.f64 #s(literal 2 binary64) y x))
(+.f64 z (*.f64 #s(literal 2 binary64) (+.f64 y x)))
(+.f64 (*.f64 #s(literal 2 binary64) (+.f64 y x)) z)
(+.f64 (fma.f64 #s(literal 2 binary64) y x) (+.f64 z x))
(+.f64 (+.f64 y x) (+.f64 (+.f64 z x) y))
(+.f64 y (+.f64 (fma.f64 #s(literal 2 binary64) x y) z))
(+.f64 x (fma.f64 #s(literal 2 binary64) y (+.f64 z x)))
(*.f64 #s(literal -2 binary64) (-.f64 (neg.f64 x) y))
(*.f64 #s(literal 2 binary64) (+.f64 y x))
(*.f64 (+.f64 y x) #s(literal 2 binary64))
(neg.f64 (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (+.f64 x x))
(fma.f64 #s(literal 2 binary64) y (+.f64 x x))
(fma.f64 #s(literal 2 binary64) x (+.f64 y y))
(fma.f64 #s(literal 1 binary64) (+.f64 y x) (*.f64 #s(literal 1 binary64) (+.f64 y x)))
(fma.f64 (+.f64 y x) #s(literal 1 binary64) (*.f64 (+.f64 y x) #s(literal 1 binary64)))
(fma.f64 y #s(literal 2 binary64) (+.f64 x x))
(fma.f64 x #s(literal 2 binary64) (+.f64 y y))
(-.f64 (+.f64 x x) (*.f64 #s(literal -2 binary64) y))
(-.f64 (fma.f64 #s(literal 2 binary64) x y) (neg.f64 y))
(-.f64 (+.f64 y y) (*.f64 (neg.f64 x) #s(literal 2 binary64)))
(-.f64 (+.f64 y y) (*.f64 #s(literal -2 binary64) x))
(-.f64 (fma.f64 #s(literal 2 binary64) y x) (neg.f64 x))
(-.f64 (+.f64 y x) (-.f64 (neg.f64 x) y))
(-.f64 y (-.f64 (*.f64 #s(literal -2 binary64) x) y))
(-.f64 x (-.f64 (*.f64 #s(literal -2 binary64) y) x))
(+.f64 (*.f64 (+.f64 y x) #s(literal 1 binary64)) (*.f64 (+.f64 y x) #s(literal 1 binary64)))
(+.f64 (*.f64 #s(literal 1 binary64) (+.f64 y x)) (*.f64 #s(literal 1 binary64) (+.f64 y x)))
(+.f64 (+.f64 x x) (+.f64 y y))
(+.f64 (fma.f64 #s(literal 2 binary64) x y) y)
(+.f64 (+.f64 y y) (+.f64 x x))
(+.f64 (fma.f64 #s(literal 2 binary64) y x) x)
(+.f64 (+.f64 y x) (+.f64 y x))
(+.f64 y (fma.f64 #s(literal 2 binary64) x y))
(+.f64 x (fma.f64 #s(literal 2 binary64) y x))
(neg.f64 (-.f64 (*.f64 #s(literal -2 binary64) y) x))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) x)
(fma.f64 #s(literal 2 binary64) y x)
(fma.f64 y #s(literal 2 binary64) x)
(-.f64 (+.f64 y y) (neg.f64 x))
(-.f64 (+.f64 y x) (neg.f64 y))
(-.f64 y (-.f64 (neg.f64 x) y))
(-.f64 x (*.f64 #s(literal -2 binary64) y))
(+.f64 (+.f64 y y) x)
(+.f64 (+.f64 y x) y)
(+.f64 y (+.f64 y x))
(+.f64 x (+.f64 y y))
(neg.f64 (-.f64 (neg.f64 x) y))
(-.f64 y (neg.f64 x))
(-.f64 x (neg.f64 y))
(+.f64 y x)
(+.f64 x y)
x
y
z

eval35.0ms (1.1%)

Memory
-0.3MiB live, 44.6MiB allocated; 6ms collecting garbage
Compiler

Compiled 1 057 to 563 computations (46.7% saved)

prune11.0ms (0.4%)

Memory
-28.3MiB live, 17.4MiB allocated; 5ms collecting garbage
Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New1835188
Fresh000
Picked101
Done000
Total1845189
Accuracy
100.0%
Counts
189 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
71.5%
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z) x)
66.0%
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x))) x)
66.7%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
34.6%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
Compiler

Compiled 106 to 106 computations (0% saved)

series18.0ms (0.6%)

Memory
-2.1MiB live, 42.7MiB allocated; 7ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0183782
Stop Event
iter-limit
Counts
19 → 44
Calls
Call 1
Inputs
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
#s(literal 3 binary64)
x
(fma.f64 #s(literal 2 binary64) y z)
#s(literal 2 binary64)
y
z
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
(*.f64 #s(literal 3 binary64) x)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
(+.f64 z (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 2 binary64) y)
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x))) x)
#s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x)))
(+.f64 z (*.f64 #s(literal 2 binary64) x))
(*.f64 #s(literal 2 binary64) x)
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z) x)
(+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z)
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y))
Outputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x))))
#s(approx x x)
#s(approx (* 3 x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx (+ z (* 2 x)) z)
#s(approx (+ z (* 2 x)) (+.f64 z (*.f64 #s(literal 2 binary64) x)))
#s(approx (* 2 x) (*.f64 #s(literal 2 binary64) x))
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y))
#s(approx (+ (+ (+ x y) y) x) (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 x (+.f64 #s(literal 3 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 x (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ z (* 2 x)) (*.f64 x (+.f64 #s(literal 2 binary64) (/.f64 z x))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 x (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y x)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 3 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 2 binary64)))))
#s(approx (+ z (* 2 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y x)) #s(literal 2 binary64)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx y y)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 3 binary64) (/.f64 x y) (/.f64 z y)))))
#s(approx (+ (* 2 y) z) (*.f64 y (+.f64 #s(literal 2 binary64) (/.f64 z y))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (+.f64 (/.f64 x y) (/.f64 z y))))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (/.f64 z y)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 y (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (/.f64 x y)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 3 binary64) x)) y)) #s(literal 2 binary64)))))
#s(approx (+ (* 2 y) z) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))) y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) x)) y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 x y)) #s(literal 2 binary64)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (*.f64 #s(literal 3 binary64) (/.f64 x z))))))
#s(approx (+ (* 2 y) z) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y z)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (/.f64 x z))))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (*.f64 #s(literal 2 binary64) (/.f64 y z))))))
#s(approx (+ z (* 2 x)) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 x z)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)) z)) #s(literal 1 binary64)))))
#s(approx (+ (* 2 y) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y z)) #s(literal 1 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))) z)) #s(literal 1 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)) z)) #s(literal 1 binary64)))))
#s(approx (+ z (* 2 x)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 x z)) #s(literal 1 binary64)))))
Calls

9 calls:

TimeVariablePointExpression
2.0ms
x
@inf
((+ (* 3 x) (+ (* 2 y) z)) 3 x (+ (* 2 y) z) 2 y z (+ (+ (+ (+ (+ x y) y) x) z) x) (* 3 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ z (* 2 y)) (* 2 y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)) (* 2 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ (+ (+ x y) y) x))
1.0ms
x
@-inf
((+ (* 3 x) (+ (* 2 y) z)) 3 x (+ (* 2 y) z) 2 y z (+ (+ (+ (+ (+ x y) y) x) z) x) (* 3 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ z (* 2 y)) (* 2 y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)) (* 2 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ (+ (+ x y) y) x))
1.0ms
y
@-inf
((+ (* 3 x) (+ (* 2 y) z)) 3 x (+ (* 2 y) z) 2 y z (+ (+ (+ (+ (+ x y) y) x) z) x) (* 3 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ z (* 2 y)) (* 2 y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)) (* 2 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ (+ (+ x y) y) x))
1.0ms
z
@-inf
((+ (* 3 x) (+ (* 2 y) z)) 3 x (+ (* 2 y) z) 2 y z (+ (+ (+ (+ (+ x y) y) x) z) x) (* 3 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ z (* 2 y)) (* 2 y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)) (* 2 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ (+ (+ x y) y) x))
1.0ms
y
@inf
((+ (* 3 x) (+ (* 2 y) z)) 3 x (+ (* 2 y) z) 2 y z (+ (+ (+ (+ (+ x y) y) x) z) x) (* 3 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ z (* 2 y)) (* 2 y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)) (* 2 x) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ (+ (+ x y) y) x))

rewrite182.0ms (5.8%)

Memory
12.7MiB live, 296.6MiB allocated; 39ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
024138
034136
1246122
2904122
33559122
08326115
110350115
Stop Event
saturated
node-limit
iter-limit
Counts
19 → 155
Calls
Call 1
Inputs
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
#s(literal 3 binary64)
x
(fma.f64 #s(literal 2 binary64) y z)
#s(literal 2 binary64)
y
z
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
(*.f64 #s(literal 3 binary64) x)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
(+.f64 z (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 2 binary64) y)
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x))) x)
#s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x)))
(+.f64 z (*.f64 #s(literal 2 binary64) x))
(*.f64 #s(literal 2 binary64) x)
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z) x)
(+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z)
#s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y))
Outputs
(neg.f64 (fma.f64 #s(literal -3 binary64) x (-.f64 (*.f64 #s(literal -2 binary64) y) z)))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 y #s(literal 2 binary64) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 #s(literal 2 binary64) y (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 x #s(literal 3 binary64) (fma.f64 y #s(literal 2 binary64) z))
(fma.f64 #s(literal 3 binary64) x (fma.f64 y #s(literal 2 binary64) z))
(-.f64 (fma.f64 x #s(literal 3 binary64) (+.f64 z y)) (neg.f64 y))
(-.f64 (+.f64 z (fma.f64 x #s(literal 3 binary64) y)) (neg.f64 y))
(-.f64 (+.f64 (fma.f64 x #s(literal 3 binary64) z) y) (neg.f64 y))
(-.f64 (fma.f64 x #s(literal 3 binary64) y) (-.f64 (neg.f64 y) z))
(-.f64 (fma.f64 x #s(literal 3 binary64) z) (*.f64 #s(literal -2 binary64) y))
(-.f64 (+.f64 z y) (neg.f64 (fma.f64 x #s(literal 3 binary64) y)))
(-.f64 (fma.f64 x #s(literal 3 binary64) (+.f64 y y)) (neg.f64 z))
(-.f64 (+.f64 y y) (-.f64 (*.f64 #s(literal -3 binary64) x) z))
(-.f64 (*.f64 x #s(literal 3 binary64)) (-.f64 (*.f64 #s(literal -2 binary64) y) z))
(-.f64 (fma.f64 y #s(literal 2 binary64) z) (neg.f64 (neg.f64 (*.f64 #s(literal -3 binary64) x))))
(-.f64 (fma.f64 y #s(literal 2 binary64) z) (*.f64 #s(literal -3 binary64) x))
(-.f64 z (fma.f64 #s(literal -2 binary64) y (*.f64 #s(literal -3 binary64) x)))
(-.f64 y (neg.f64 (+.f64 y (fma.f64 x #s(literal 3 binary64) z))))
(-.f64 y (neg.f64 (-.f64 (+.f64 z y) (*.f64 #s(literal -3 binary64) x))))
(-.f64 y (-.f64 (neg.f64 y) (fma.f64 x #s(literal 3 binary64) z)))
(+.f64 (fma.f64 x #s(literal 3 binary64) (+.f64 z y)) y)
(+.f64 (+.f64 z (fma.f64 x #s(literal 3 binary64) y)) y)
(+.f64 (+.f64 (fma.f64 x #s(literal 3 binary64) z) y) y)
(+.f64 (fma.f64 x #s(literal 3 binary64) y) (+.f64 z y))
(+.f64 (fma.f64 x #s(literal 3 binary64) z) (*.f64 #s(literal -2 binary64) (*.f64 #s(literal 1 binary64) (neg.f64 y))))
(+.f64 (fma.f64 x #s(literal 3 binary64) z) (+.f64 y y))
(+.f64 (+.f64 z y) (fma.f64 x #s(literal 3 binary64) y))
(+.f64 (fma.f64 x #s(literal 3 binary64) (+.f64 y y)) z)
(+.f64 (+.f64 y y) (fma.f64 x #s(literal 3 binary64) z))
(+.f64 (*.f64 x #s(literal 3 binary64)) (fma.f64 y #s(literal 2 binary64) z))
(+.f64 (fma.f64 y #s(literal 2 binary64) z) (*.f64 (neg.f64 x) #s(literal -3 binary64)))
(+.f64 (fma.f64 y #s(literal 2 binary64) z) (*.f64 #s(literal -3 binary64) (neg.f64 x)))
(+.f64 (fma.f64 y #s(literal 2 binary64) z) (neg.f64 (*.f64 #s(literal -3 binary64) x)))
(+.f64 (fma.f64 y #s(literal 2 binary64) z) (*.f64 x #s(literal 3 binary64)))
(+.f64 z (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
(+.f64 y (+.f64 (fma.f64 x #s(literal 3 binary64) z) y))
(+.f64 y (+.f64 y (fma.f64 x #s(literal 3 binary64) z)))
(+.f64 y (-.f64 (+.f64 z y) (*.f64 #s(literal -3 binary64) x)))
#s(literal 3 binary64)
x
(neg.f64 (-.f64 (*.f64 #s(literal -2 binary64) y) z))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) z)
(fma.f64 (neg.f64 y) #s(literal -2 binary64) z)
(fma.f64 #s(literal 1 binary64) (+.f64 y y) z)
(fma.f64 (+.f64 y y) #s(literal 1 binary64) z)
(fma.f64 y #s(literal 2 binary64) z)
(fma.f64 #s(literal 2 binary64) y z)
(-.f64 (+.f64 z y) (neg.f64 y))
(-.f64 (+.f64 y y) (neg.f64 z))
(-.f64 z (*.f64 #s(literal -2 binary64) y))
(-.f64 y (-.f64 (neg.f64 y) z))
(+.f64 (+.f64 z y) y)
(+.f64 (+.f64 y y) z)
(+.f64 z (*.f64 #s(literal -2 binary64) (*.f64 #s(literal 1 binary64) (neg.f64 y))))
(+.f64 z (+.f64 y y))
(+.f64 y (+.f64 z y))
#s(literal 2 binary64)
y
z
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 x #s(literal 3 binary64)))
(*.f64 x #s(literal 3 binary64))
(*.f64 #s(literal 3 binary64) x)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
(neg.f64 (-.f64 (*.f64 #s(literal -2 binary64) y) z))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) z)
(fma.f64 (neg.f64 y) #s(literal -2 binary64) z)
(fma.f64 #s(literal 1 binary64) (+.f64 y y) z)
(fma.f64 (+.f64 y y) #s(literal 1 binary64) z)
(fma.f64 y #s(literal 2 binary64) z)
(fma.f64 #s(literal 2 binary64) y z)
(-.f64 (+.f64 z y) (neg.f64 y))
(-.f64 (+.f64 y y) (neg.f64 z))
(-.f64 z (*.f64 #s(literal -2 binary64) y))
(-.f64 y (-.f64 (neg.f64 y) z))
(+.f64 (+.f64 z y) y)
(+.f64 (+.f64 y y) z)
(+.f64 z (*.f64 #s(literal -2 binary64) (*.f64 #s(literal 1 binary64) (neg.f64 y))))
(+.f64 z (+.f64 y y))
(+.f64 y (+.f64 z y))
(*.f64 #s(literal -2 binary64) (neg.f64 y))
(*.f64 (neg.f64 y) #s(literal -2 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 y y))
(*.f64 (+.f64 y y) #s(literal 1 binary64))
(*.f64 y #s(literal 2 binary64))
(*.f64 #s(literal 2 binary64) y)
(neg.f64 (*.f64 #s(literal -2 binary64) y))
(-.f64 y (*.f64 (neg.f64 y) #s(literal 1 binary64)))
(-.f64 y (*.f64 #s(literal -1 binary64) y))
(-.f64 y (neg.f64 y))
(+.f64 y (neg.f64 (*.f64 (neg.f64 y) #s(literal 1 binary64))))
(+.f64 y (neg.f64 (*.f64 #s(literal -1 binary64) y)))
(+.f64 y y)
(neg.f64 (-.f64 (neg.f64 x) #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z))))
(-.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z)) (neg.f64 x))
(-.f64 x (neg.f64 (neg.f64 (neg.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z))))))
(-.f64 x (neg.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z))))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z)) x)
(+.f64 x (neg.f64 (neg.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z)))))
(+.f64 x #s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z)))
#s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x z))
(neg.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) z))
(fma.f64 #s(literal -2 binary64) (neg.f64 x) z)
(fma.f64 (neg.f64 x) #s(literal -2 binary64) z)
(fma.f64 #s(literal 1 binary64) (+.f64 x x) z)
(fma.f64 (+.f64 x x) #s(literal 1 binary64) z)
(fma.f64 #s(literal 2 binary64) x z)
(fma.f64 x #s(literal 2 binary64) z)
(-.f64 (+.f64 z x) (neg.f64 x))
(-.f64 (+.f64 x x) (neg.f64 z))
(-.f64 z (*.f64 #s(literal -2 binary64) x))
(-.f64 x (-.f64 (neg.f64 x) z))
(+.f64 (+.f64 z x) x)
(+.f64 (+.f64 x x) z)
(+.f64 z (*.f64 #s(literal -2 binary64) (*.f64 #s(literal 1 binary64) (neg.f64 x))))
(+.f64 z (+.f64 x x))
(+.f64 x (+.f64 z x))
(*.f64 #s(literal -2 binary64) (neg.f64 x))
(*.f64 (neg.f64 x) #s(literal -2 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 x x))
(*.f64 (+.f64 x x) #s(literal 1 binary64))
(*.f64 #s(literal 2 binary64) x)
(*.f64 x #s(literal 2 binary64))
(neg.f64 (*.f64 #s(literal -2 binary64) x))
(-.f64 x (*.f64 (neg.f64 x) #s(literal 1 binary64)))
(-.f64 x (*.f64 #s(literal -1 binary64) x))
(-.f64 x (neg.f64 x))
(+.f64 x (neg.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64))))
(+.f64 x (neg.f64 (*.f64 #s(literal -1 binary64) x)))
(+.f64 x x)
(neg.f64 (-.f64 (-.f64 (neg.f64 x) z) #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))
(-.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) x) (neg.f64 z))
(-.f64 (+.f64 z x) (neg.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))
(-.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) z) (neg.f64 x))
(-.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) (-.f64 (neg.f64 x) z))
(-.f64 z (-.f64 (neg.f64 x) #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))
(-.f64 x (-.f64 (neg.f64 z) #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) x) z)
(+.f64 (+.f64 z x) (neg.f64 (neg.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)))))
(+.f64 (+.f64 z x) #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)))
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) z) x)
(+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) (+.f64 z x))
(+.f64 z (+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) x))
(+.f64 x (+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) z))
(neg.f64 (-.f64 (neg.f64 z) #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))
(-.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) (neg.f64 z))
(-.f64 z (neg.f64 (neg.f64 (neg.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))))
(-.f64 z (neg.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y))))
(+.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)) z)
(+.f64 z (neg.f64 (neg.f64 #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)))))
(+.f64 z #s(approx (+ (+ (+ x y) y) x) (+.f64 y y)))
#s(approx (+ (+ (+ x y) y) x) (+.f64 y y))

eval20.0ms (0.6%)

Memory
10.6MiB live, 55.9MiB allocated; 6ms collecting garbage
Compiler

Compiled 1 148 to 567 computations (50.6% saved)

prune5.0ms (0.2%)

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

6 alts after pruning (4 fresh and 2 done)

PrunedKeptTotal
New1864190
Fresh000
Picked325
Done000
Total1896195
Accuracy
100.0%
Counts
195 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
38.9%
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
66.7%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
34.6%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
68.4%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
66.0%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
Compiler

Compiled 69 to 69 computations (0% saved)

series16.0ms (0.5%)

Memory
-0.1MiB live, 45.2MiB allocated; 5ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0201844
Stop Event
iter-limit
Counts
15 → 48
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
(+.f64 z (*.f64 #s(literal 3 binary64) x))
z
(*.f64 #s(literal 3 binary64) x)
#s(literal 3 binary64)
x
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
(fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x))
#s(literal 2 binary64)
y
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
(fma.f64 y #s(literal 2 binary64) z)
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z))
#s(approx (+ z (* 2 x)) z)
Outputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x))))
#s(approx (+ z (* 3 x)) z)
#s(approx (+ z (* 3 x)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx (* 3 x) (*.f64 #s(literal 3 binary64) x))
#s(approx x x)
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y))
#s(approx (+ (* 2 y) (* 3 x)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx (+ z (* 2 x)) (+.f64 z (*.f64 #s(literal 2 binary64) x)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 x (+.f64 #s(literal 3 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ z (* 3 x)) (*.f64 x (+.f64 #s(literal 3 binary64) (/.f64 z x))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 x (+.f64 #s(literal 3 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y x)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal 2 binary64) x))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 x (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ z (* 2 x)) (*.f64 x (+.f64 #s(literal 2 binary64) (/.f64 z x))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 3 binary64)))))
#s(approx (+ z (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 3 binary64)))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y x)) #s(literal 3 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 2 binary64)))))
#s(approx (+ z (* 2 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 2 binary64)))))
#s(approx y y)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 3 binary64) (/.f64 x y) (/.f64 z y)))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 y (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 3 binary64) (/.f64 x y)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (+.f64 (/.f64 x y) (/.f64 z y))))))
#s(approx (+ (* y 2) z) (*.f64 y (+.f64 #s(literal 2 binary64) (/.f64 z y))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (/.f64 z y)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 3 binary64) x)) y)) #s(literal 2 binary64)))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -3 binary64) (/.f64 x y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))) y)) #s(literal 2 binary64)))))
#s(approx (+ (* y 2) z) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) x)) y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (*.f64 #s(literal 3 binary64) (/.f64 x z))))))
#s(approx (+ z (* 3 x)) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 3 binary64) (/.f64 x z)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (/.f64 x z))))))
#s(approx (+ (* y 2) z) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y z)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (*.f64 #s(literal 2 binary64) (/.f64 y z))))))
#s(approx (+ z (* 2 x)) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 x z)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)) z)) #s(literal 1 binary64)))))
#s(approx (+ z (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -3 binary64) (/.f64 x z)) #s(literal 1 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))) z)) #s(literal 1 binary64)))))
#s(approx (+ (* y 2) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y z)) #s(literal 1 binary64)))))
#s(approx (+ (+ (+ (+ x y) y) x) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)) z)) #s(literal 1 binary64)))))
#s(approx (+ z (* 2 x)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 x z)) #s(literal 1 binary64)))))
Calls

9 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (* 3 x) 3 x (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) 2 y (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* y 2) z) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)))
1.0ms
x
@-inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (* 3 x) 3 x (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) 2 y (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* y 2) z) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)))
1.0ms
x
@inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (* 3 x) 3 x (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) 2 y (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* y 2) z) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)))
1.0ms
z
@-inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (* 3 x) 3 x (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) 2 y (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* y 2) z) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)))
1.0ms
x
@0
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (* 3 x) 3 x (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) 2 y (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* y 2) z) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (+ (+ (+ x y) y) x) z) (+ z (* 2 x)))

rewrite205.0ms (6.5%)

Memory
-6.5MiB live, 237.0MiB allocated; 60ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
026113
032111
1248105
2882105
33393104
0839894
11110994
Stop Event
saturated
node-limit
iter-limit
Counts
15 → 124
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
(+.f64 z (*.f64 #s(literal 3 binary64) x))
z
(*.f64 #s(literal 3 binary64) x)
#s(literal 3 binary64)
x
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
(fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x))
#s(literal 2 binary64)
y
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
(fma.f64 y #s(literal 2 binary64) z)
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z))
#s(approx (+ z (* 2 x)) z)
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
(neg.f64 (+.f64 (neg.f64 x) (-.f64 (*.f64 #s(literal -2 binary64) x) z)))
(neg.f64 (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) z) x))
(neg.f64 (-.f64 (*.f64 #s(literal -3 binary64) x) z))
(fma.f64 (*.f64 #s(literal -2 binary64) x) #s(literal -1 binary64) (+.f64 z x))
(fma.f64 #s(literal -2 binary64) (neg.f64 x) (+.f64 z x))
(fma.f64 #s(literal -3 binary64) (neg.f64 x) z)
(fma.f64 (neg.f64 x) #s(literal -2 binary64) (+.f64 z x))
(fma.f64 (neg.f64 x) #s(literal -3 binary64) z)
(fma.f64 #s(literal 1 binary64) (+.f64 x x) (+.f64 z x))
(fma.f64 #s(literal 1 binary64) (*.f64 x #s(literal 3 binary64)) z)
(fma.f64 (+.f64 x x) #s(literal 1 binary64) (+.f64 z x))
(fma.f64 (*.f64 x #s(literal 3 binary64)) #s(literal 1 binary64) z)
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 x)) (+.f64 z x))
(fma.f64 #s(literal 2 binary64) x (+.f64 z x))
(fma.f64 x #s(literal 2 binary64) (+.f64 z x))
(fma.f64 x #s(literal 3 binary64) z)
(fma.f64 #s(literal 3 binary64) x z)
(-.f64 (*.f64 x #s(literal 3 binary64)) (neg.f64 z))
(-.f64 z (*.f64 #s(literal -3 binary64) x))
(-.f64 x (-.f64 (*.f64 #s(literal -2 binary64) x) z))
(+.f64 (fma.f64 #s(literal 2 binary64) x z) x)
(+.f64 (+.f64 x x) (+.f64 z x))
(+.f64 (*.f64 x #s(literal 3 binary64)) z)
(+.f64 z (*.f64 x #s(literal 3 binary64)))
(+.f64 x (fma.f64 #s(literal 2 binary64) x z))
z
(*.f64 #s(literal -3 binary64) (neg.f64 x))
(*.f64 (neg.f64 x) #s(literal -3 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 x #s(literal 3 binary64)))
(*.f64 (*.f64 x #s(literal 3 binary64)) #s(literal 1 binary64))
(*.f64 x #s(literal 3 binary64))
(*.f64 #s(literal 3 binary64) x)
(neg.f64 (+.f64 (neg.f64 x) (*.f64 #s(literal -2 binary64) x)))
(neg.f64 (*.f64 #s(literal -3 binary64) x))
(-.f64 x (*.f64 #s(literal -2 binary64) x))
(+.f64 x (+.f64 x x))
#s(literal 3 binary64)
x
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 (+.f64 y x) #s(literal 2 binary64) x))
(neg.f64 (fma.f64 #s(literal -2 binary64) y (*.f64 #s(literal -3 binary64) x)))
(fma.f64 (*.f64 (+.f64 y x) #s(literal 1 binary64)) #s(literal 2 binary64) x)
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 (*.f64 #s(literal -2 binary64) x) #s(literal -1 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal -2 binary64) (-.f64 (neg.f64 y) x) x)
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal -2 binary64) (neg.f64 x) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal -3 binary64) (neg.f64 x) (+.f64 y y))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 (neg.f64 x) #s(literal -2 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 (neg.f64 x) #s(literal -3 binary64) (+.f64 y y))
(fma.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) x y) (+.f64 y x))
(fma.f64 #s(literal 1 binary64) (+.f64 x x) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal 1 binary64) (*.f64 (+.f64 y x) #s(literal 2 binary64)) x)
(fma.f64 #s(literal 1 binary64) (fma.f64 y #s(literal 2 binary64) x) (+.f64 x x))
(fma.f64 #s(literal 1 binary64) (+.f64 y x) (fma.f64 #s(literal 2 binary64) x y))
(fma.f64 #s(literal 1 binary64) (*.f64 x #s(literal 3 binary64)) (+.f64 y y))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (*.f64 x #s(literal 3 binary64)))
(fma.f64 (+.f64 x x) #s(literal 1 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 (*.f64 (+.f64 y x) #s(literal 2 binary64)) #s(literal 1 binary64) x)
(fma.f64 (+.f64 y x) #s(literal 2 binary64) x)
(fma.f64 (*.f64 x #s(literal 3 binary64)) #s(literal 1 binary64) (+.f64 y y))
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 y #s(literal 2 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 x)) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal 2 binary64) (+.f64 y x) x)
(fma.f64 #s(literal 2 binary64) y (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal 2 binary64) x (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 x #s(literal 2 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 x #s(literal 3 binary64) (+.f64 y y))
(fma.f64 #s(literal 3 binary64) x (+.f64 y y))
(-.f64 (+.f64 x (fma.f64 #s(literal 2 binary64) x y)) (neg.f64 y))
(-.f64 (fma.f64 #s(literal 2 binary64) x y) (-.f64 (neg.f64 y) x))
(-.f64 (fma.f64 x #s(literal 3 binary64) y) (neg.f64 y))
(-.f64 (+.f64 x x) (-.f64 (*.f64 #s(literal -2 binary64) y) x))
(-.f64 (*.f64 (+.f64 y x) #s(literal 2 binary64)) (neg.f64 x))
(-.f64 (fma.f64 y #s(literal 2 binary64) x) (*.f64 #s(literal -2 binary64) x))
(-.f64 (+.f64 y x) (-.f64 (*.f64 #s(literal -2 binary64) x) y))
(-.f64 (*.f64 x #s(literal 3 binary64)) (*.f64 #s(literal -2 binary64) y))
(-.f64 (+.f64 y y) (*.f64 #s(literal -3 binary64) x))
(-.f64 y (neg.f64 (+.f64 (fma.f64 #s(literal 2 binary64) x y) x)))
(-.f64 y (-.f64 (*.f64 #s(literal -3 binary64) x) y))
(-.f64 x (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(+.f64 (-.f64 (+.f64 x x) (-.f64 (neg.f64 y) x)) y)
(+.f64 (+.f64 x (fma.f64 #s(literal 2 binary64) x y)) y)
(+.f64 (+.f64 (fma.f64 #s(literal 2 binary64) x y) x) y)
(+.f64 (fma.f64 #s(literal 2 binary64) x y) (+.f64 y x))
(+.f64 (fma.f64 x #s(literal 3 binary64) y) y)
(+.f64 (+.f64 x x) (fma.f64 y #s(literal 2 binary64) x))
(+.f64 (*.f64 (+.f64 y x) #s(literal 2 binary64)) x)
(+.f64 (fma.f64 y #s(literal 2 binary64) x) (+.f64 x x))
(+.f64 (+.f64 y x) (fma.f64 #s(literal 2 binary64) x y))
(+.f64 (*.f64 x #s(literal 3 binary64)) (+.f64 y y))
(+.f64 (+.f64 y y) (*.f64 x #s(literal 3 binary64)))
(+.f64 y (+.f64 (fma.f64 #s(literal 2 binary64) x y) x))
(+.f64 y (fma.f64 x #s(literal 3 binary64) y))
(+.f64 x (*.f64 (+.f64 y x) #s(literal 2 binary64)))
#s(literal 2 binary64)
y
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
(neg.f64 (-.f64 (*.f64 #s(literal -2 binary64) y) z))
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) z)
(fma.f64 #s(literal -2 binary64) (neg.f64 y) z)
(fma.f64 (neg.f64 y) #s(literal -2 binary64) z)
(fma.f64 #s(literal 1 binary64) (+.f64 y y) z)
(fma.f64 (+.f64 y y) #s(literal 1 binary64) z)
(fma.f64 y #s(literal 2 binary64) z)
(fma.f64 #s(literal 2 binary64) y z)
(-.f64 (+.f64 z y) (neg.f64 y))
(-.f64 z (*.f64 #s(literal -2 binary64) y))
(-.f64 (+.f64 y y) (neg.f64 z))
(-.f64 y (-.f64 (neg.f64 y) z))
(+.f64 (+.f64 z y) y)
(+.f64 z (+.f64 y y))
(+.f64 (+.f64 y y) z)
(+.f64 y (+.f64 z y))
(neg.f64 (-.f64 (neg.f64 x) #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z))))
(-.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) (neg.f64 x))
(-.f64 x (neg.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z))))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
(+.f64 x #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)))
#s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z))
(neg.f64 (neg.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z))))
#s(approx (+ z (* 2 x)) z)

eval19.0ms (0.6%)

Memory
25.7MiB live, 65.7MiB allocated; 7ms collecting garbage
Compiler

Compiled 995 to 539 computations (45.8% saved)

prune8.0ms (0.3%)

Memory
-24.4MiB live, 19.4MiB allocated; 8ms collecting garbage
Pruning

7 alts after pruning (4 fresh and 3 done)

PrunedKeptTotal
New1704174
Fresh000
Picked224
Done112
Total1737180
Accuracy
100.0%
Counts
180 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
38.9%
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
66.7%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
66.1%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
34.6%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
68.5%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
35.5%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
33.7%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
Compiler

Compiled 88 to 85 computations (3.4% saved)

series20.0ms (0.6%)

Memory
1.1MiB live, 41.7MiB allocated; 11ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0137526
Stop Event
iter-limit
Counts
15 → 30
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ z (* 3 x)) z)
z
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 2 binary64) y)
#s(literal 2 binary64)
y
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
(fma.f64 x #s(literal 3 binary64) (+.f64 y y))
x
#s(literal 3 binary64)
(+.f64 y y)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 x #s(literal 3 binary64) z)
Outputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x))))
#s(approx (+ z (* 3 x)) z)
#s(approx (+ z (* 3 x)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y))
#s(approx (+ (* 2 y) (* 3 x)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
#s(approx x x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 x (+.f64 #s(literal 3 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y x) (/.f64 z x)))))
#s(approx (+ z (* 3 x)) (*.f64 x (+.f64 #s(literal 3 binary64) (/.f64 z x))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 x (+.f64 #s(literal 3 binary64) (*.f64 #s(literal 2 binary64) (/.f64 y x)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 2 binary64) y)) x)) #s(literal 3 binary64)))))
#s(approx (+ z (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 3 binary64)))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -2 binary64) (/.f64 y x)) #s(literal 3 binary64)))))
#s(approx y y)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (+.f64 z (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y)))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 3 binary64) (/.f64 x y) (/.f64 z y)))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 y (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 3 binary64) (/.f64 x y)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 y (+.f64 #s(literal 2 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x y) (+.f64 (/.f64 x y) (/.f64 z y))))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 z (*.f64 #s(literal 3 binary64) x)) y)) #s(literal 2 binary64)))))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -3 binary64) (/.f64 x y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (+.f64 z (*.f64 #s(literal 2 binary64) x))) y)) #s(literal 2 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (*.f64 #s(literal 3 binary64) (/.f64 x z))))))
#s(approx (+ z (* 3 x)) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 3 binary64) (/.f64 x z)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 z (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) (/.f64 x z) (fma.f64 #s(literal 2 binary64) (/.f64 y z) (/.f64 x z))))))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)) z)) #s(literal 1 binary64)))))
#s(approx (+ z (* 3 x)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -3 binary64) (/.f64 x z)) #s(literal 1 binary64)))))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal 2 binary64) x (*.f64 #s(literal 2 binary64) y))) z)) #s(literal 1 binary64)))))
Calls

9 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) (* 2 y) 2 y (+ (* 3 x) (+ (* 2 y) z)) (+ (* x 3) (+ y y)) x 3 (+ y y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* x 3) z))
1.0ms
y
@inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) (* 2 y) 2 y (+ (* 3 x) (+ (* 2 y) z)) (+ (* x 3) (+ y y)) x 3 (+ y y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* x 3) z))
1.0ms
x
@-inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) (* 2 y) 2 y (+ (* 3 x) (+ (* 2 y) z)) (+ (* x 3) (+ y y)) x 3 (+ y y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* x 3) z))
1.0ms
x
@inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) (* 2 y) 2 y (+ (* 3 x) (+ (* 2 y) z)) (+ (* x 3) (+ y y)) x 3 (+ y y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* x 3) z))
1.0ms
z
@-inf
((+ (* 3 x) (+ (* 2 y) z)) (+ z (* 3 x)) z (+ (* 3 x) (+ (* 2 y) z)) (+ (* 2 y) (* 3 x)) (* 2 y) 2 y (+ (* 3 x) (+ (* 2 y) z)) (+ (* x 3) (+ y y)) x 3 (+ y y) (+ (+ (+ (+ (+ x y) y) x) z) x) (+ (* x 3) z))

rewrite148.0ms (4.7%)

Memory
21.8MiB live, 209.1MiB allocated; 49ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
026109
031102
1256100
2839100
3324499
0835195
11074595
Stop Event
saturated
node-limit
iter-limit
Counts
15 → 163
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ z (* 3 x)) z)
z
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y))
(*.f64 #s(literal 2 binary64) y)
#s(literal 2 binary64)
y
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
(fma.f64 x #s(literal 3 binary64) (+.f64 y y))
x
#s(literal 3 binary64)
(+.f64 y y)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
(fma.f64 x #s(literal 3 binary64) z)
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ z (* 3 x)) z))
#s(approx (+ z (* 3 x)) z)
z
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
#s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y))
(*.f64 #s(literal -2 binary64) (neg.f64 y))
(*.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64))
(*.f64 (neg.f64 y) #s(literal -2 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 y y))
(*.f64 (+.f64 y y) #s(literal 1 binary64))
(*.f64 y #s(literal 2 binary64))
(*.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)))
(*.f64 #s(literal 2 binary64) y)
(/.f64 (*.f64 (+.f64 y y) #s(literal 2 binary64)) #s(literal 2 binary64))
(/.f64 (*.f64 #s(literal 2 binary64) (+.f64 y y)) #s(literal 2 binary64))
(neg.f64 (*.f64 #s(literal -2 binary64) y))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 #s(literal -1 binary64) (neg.f64 y) (*.f64 #s(literal -1 binary64) (neg.f64 y)))
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 (neg.f64 y) #s(literal -1 binary64) (*.f64 (neg.f64 y) #s(literal -1 binary64)))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 y #s(literal 2 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 y #s(literal 2 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 #s(literal 2 binary64) y (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(-.f64 y (neg.f64 y))
(+.f64 (*.f64 (neg.f64 y) #s(literal -1 binary64)) (*.f64 (neg.f64 y) #s(literal -1 binary64)))
(+.f64 (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 #s(literal -1 binary64) (neg.f64 y)))
(+.f64 (+.f64 y y) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(+.f64 (+.f64 y y) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(+.f64 y y)
#s(literal 2 binary64)
y
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 (+.f64 y x) #s(literal 2 binary64) x))
(neg.f64 (fma.f64 #s(literal -2 binary64) y (*.f64 #s(literal -3 binary64) x)))
(fma.f64 (*.f64 x #s(literal 1 binary64)) #s(literal 2 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 (+.f64 x x) #s(literal 1 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal -2 binary64) (-.f64 (neg.f64 x) y) x)
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal -3 binary64) (neg.f64 x) (+.f64 y y))
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 (neg.f64 x) #s(literal -3 binary64) (+.f64 y y))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal 1 binary64) (+.f64 x x) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal 1 binary64) (*.f64 (+.f64 y x) #s(literal 2 binary64)) x)
(fma.f64 #s(literal 1 binary64) (+.f64 y x) (fma.f64 #s(literal 2 binary64) x y))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (*.f64 x #s(literal 3 binary64)))
(fma.f64 (*.f64 (+.f64 y x) #s(literal 2 binary64)) #s(literal 1 binary64) x)
(fma.f64 (+.f64 y x) #s(literal 1 binary64) (fma.f64 #s(literal 2 binary64) x y))
(fma.f64 (+.f64 y x) #s(literal 2 binary64) x)
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 y #s(literal 2 binary64) (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal 1 binary64) x) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal 2 binary64) (+.f64 y x) x)
(fma.f64 #s(literal 2 binary64) y (*.f64 x #s(literal 3 binary64)))
(fma.f64 #s(literal 2 binary64) x (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 x #s(literal 2 binary64) (fma.f64 y #s(literal 2 binary64) x))
(fma.f64 x #s(literal 3 binary64) (+.f64 y y))
(fma.f64 #s(literal 3 binary64) x (+.f64 y y))
(-.f64 (+.f64 x x) (-.f64 (*.f64 #s(literal -2 binary64) y) x))
(-.f64 (fma.f64 #s(literal 2 binary64) x y) (-.f64 (neg.f64 x) y))
(-.f64 (fma.f64 x #s(literal 3 binary64) y) (neg.f64 y))
(-.f64 (*.f64 (+.f64 y x) #s(literal 2 binary64)) (neg.f64 x))
(-.f64 (fma.f64 y #s(literal 2 binary64) x) (*.f64 #s(literal -2 binary64) x))
(-.f64 (+.f64 y x) (-.f64 (*.f64 #s(literal -2 binary64) x) y))
(-.f64 (+.f64 y y) (+.f64 (neg.f64 x) (*.f64 #s(literal -2 binary64) x)))
(-.f64 (+.f64 y y) (-.f64 (neg.f64 x) (+.f64 x x)))
(-.f64 (+.f64 y y) (*.f64 #s(literal -3 binary64) x))
(-.f64 y (fma.f64 #s(literal -2 binary64) x (-.f64 (neg.f64 x) y)))
(-.f64 y (+.f64 (-.f64 (neg.f64 x) y) (*.f64 #s(literal -2 binary64) x)))
(-.f64 y (-.f64 (*.f64 #s(literal -2 binary64) x) (+.f64 y x)))
(-.f64 y (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) y) x))
(-.f64 y (-.f64 (-.f64 (neg.f64 x) y) (+.f64 x x)))
(-.f64 y (+.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) y) (neg.f64 x)))
(-.f64 y (+.f64 (neg.f64 x) (-.f64 (*.f64 #s(literal -2 binary64) x) y)))
(-.f64 y (-.f64 (neg.f64 x) (fma.f64 #s(literal 2 binary64) x y)))
(-.f64 y (-.f64 (*.f64 #s(literal -3 binary64) x) y))
(-.f64 (*.f64 x #s(literal 3 binary64)) (*.f64 #s(literal -2 binary64) y))
(-.f64 x (*.f64 #s(literal -2 binary64) (+.f64 y x)))
(+.f64 (+.f64 x x) (fma.f64 y #s(literal 2 binary64) x))
(+.f64 (fma.f64 #s(literal 2 binary64) x y) (+.f64 y x))
(+.f64 (fma.f64 x #s(literal 3 binary64) y) y)
(+.f64 (*.f64 (+.f64 y x) #s(literal 2 binary64)) x)
(+.f64 (fma.f64 y #s(literal 2 binary64) x) (+.f64 x x))
(+.f64 (+.f64 y x) (fma.f64 #s(literal 2 binary64) x y))
(+.f64 (+.f64 y y) (*.f64 x #s(literal 3 binary64)))
(+.f64 y (fma.f64 x #s(literal 3 binary64) y))
(+.f64 (*.f64 x #s(literal 3 binary64)) (+.f64 y y))
(+.f64 x (*.f64 (+.f64 y x) #s(literal 2 binary64)))
x
#s(literal 3 binary64)
(*.f64 #s(literal -2 binary64) (neg.f64 y))
(*.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64))
(*.f64 (neg.f64 y) #s(literal -2 binary64))
(*.f64 #s(literal 1 binary64) (+.f64 y y))
(*.f64 (+.f64 y y) #s(literal 1 binary64))
(*.f64 y #s(literal 2 binary64))
(*.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)))
(*.f64 #s(literal 2 binary64) y)
(/.f64 (*.f64 (+.f64 y y) #s(literal 2 binary64)) #s(literal 2 binary64))
(/.f64 (*.f64 #s(literal 2 binary64) (+.f64 y y)) #s(literal 2 binary64))
(neg.f64 (*.f64 #s(literal -2 binary64) y))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal -2 binary64) (neg.f64 y) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 #s(literal -1 binary64) (neg.f64 y) (*.f64 #s(literal -1 binary64) (neg.f64 y)))
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 (*.f64 #s(literal -2 binary64) y) #s(literal -1 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 (neg.f64 y) #s(literal -2 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 (neg.f64 y) #s(literal -1 binary64) (*.f64 (neg.f64 y) #s(literal -1 binary64)))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal 1 binary64) (+.f64 y y) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 (+.f64 y y) #s(literal 1 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 y #s(literal 2 binary64) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 y #s(literal 2 binary64) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(fma.f64 #s(literal 2 binary64) y (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(-.f64 y (neg.f64 y))
(+.f64 (*.f64 (neg.f64 y) #s(literal -1 binary64)) (*.f64 (neg.f64 y) #s(literal -1 binary64)))
(+.f64 (*.f64 #s(literal -1 binary64) (neg.f64 y)) (*.f64 #s(literal -1 binary64) (neg.f64 y)))
(+.f64 (+.f64 y y) (*.f64 (+.f64 y y) #s(literal 0 binary64)))
(+.f64 (+.f64 y y) (*.f64 #s(literal 0 binary64) (+.f64 y y)))
(+.f64 y y)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
(neg.f64 (+.f64 (neg.f64 x) (-.f64 (*.f64 #s(literal -2 binary64) x) z)))
(neg.f64 (-.f64 (-.f64 (*.f64 #s(literal -2 binary64) x) z) x))
(neg.f64 (-.f64 (*.f64 #s(literal -3 binary64) x) z))
(fma.f64 (*.f64 x #s(literal 1 binary64)) #s(literal 2 binary64) (+.f64 z x))
(fma.f64 (+.f64 x x) #s(literal 1 binary64) (+.f64 z x))
(fma.f64 #s(literal -3 binary64) (neg.f64 x) z)
(fma.f64 (neg.f64 x) #s(literal -3 binary64) z)
(fma.f64 #s(literal 1 binary64) (+.f64 x x) (+.f64 z x))
(fma.f64 #s(literal 2 binary64) (*.f64 #s(literal 1 binary64) x) (+.f64 z x))
(fma.f64 #s(literal 2 binary64) x (+.f64 z x))
(fma.f64 x #s(literal 2 binary64) (+.f64 z x))
(fma.f64 x #s(literal 3 binary64) z)
(fma.f64 #s(literal 3 binary64) x z)
(-.f64 (+.f64 x x) (-.f64 (neg.f64 z) x))
(-.f64 (fma.f64 #s(literal 2 binary64) x z) (neg.f64 x))
(-.f64 (+.f64 z x) (*.f64 #s(literal -2 binary64) x))
(-.f64 z (-.f64 (neg.f64 x) (+.f64 x x)))
(-.f64 z (*.f64 #s(literal -3 binary64) x))
(-.f64 (*.f64 x #s(literal 3 binary64)) (neg.f64 z))
(-.f64 x (-.f64 (*.f64 #s(literal -2 binary64) x) z))
(+.f64 (+.f64 x x) (+.f64 z x))
(+.f64 (fma.f64 #s(literal 2 binary64) x z) x)
(+.f64 (+.f64 z x) (+.f64 x x))
(+.f64 z (*.f64 x #s(literal 3 binary64)))
(+.f64 (*.f64 x #s(literal 3 binary64)) z)
(+.f64 x (fma.f64 #s(literal 2 binary64) x z))

eval26.0ms (0.8%)

Memory
0.6MiB live, 47.7MiB allocated; 21ms collecting garbage
Compiler

Compiled 839 to 469 computations (44.1% saved)

prune7.0ms (0.2%)

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

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New1471148
Fresh000
Picked134
Done033
Total1487155
Accuracy
100.0%
Counts
155 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
38.9%
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
66.7%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
66.1%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
34.6%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
35.5%
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
68.5%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
33.7%
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
Compiler

Compiled 189 to 146 computations (22.8% saved)

regimes25.0ms (0.8%)

Memory
-38.8MiB live, 51.9MiB allocated; 11ms collecting garbage
Counts
15 → 1
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x))) x)
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z) x)
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
Outputs
(fma.f64 #s(literal 3 binary64) x (fma.f64 #s(literal 2 binary64) y z))
Calls

4 calls:

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

Compiled 11 to 17 computations (-54.5% saved)

regimes20.0ms (0.6%)

Memory
2.4MiB live, 47.3MiB allocated; 6ms collecting garbage
Counts
13 → 3
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x))) x)
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z) x)
Outputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
(+.f64 (+.f64 #s(approx (+ (+ (+ x y) y) x) (*.f64 #s(literal 2 binary64) y)) z) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
Calls

4 calls:

7.0ms
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
4.0ms
z
4.0ms
x
4.0ms
y
Results
AccuracySegmentsBranch
82.4%6(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
91.6%3x
90.5%3y
89.5%3z
Compiler

Compiled 11 to 17 computations (-54.5% saved)

regimes5.0ms (0.1%)

Memory
14.4MiB live, 14.4MiB allocated; 0ms collecting garbage
Counts
12 → 3
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 #s(literal 2 binary64) y (*.f64 #s(literal 3 binary64) x)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) (+.f64 z (*.f64 #s(literal 2 binary64) x))) x)
Outputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (fma.f64 x #s(literal 3 binary64) (+.f64 y y)))
Calls

1 calls:

4.0ms
x
Results
AccuracySegmentsBranch
90.6%3x
Compiler

Compiled 1 to 3 computations (-200% saved)

regimes47.0ms (1.5%)

Memory
-19.1MiB live, 34.7MiB allocated; 55ms collecting garbage
Counts
9 → 3
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) (+.f64 z (*.f64 #s(literal 3 binary64) x)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (+.f64 z (*.f64 #s(literal 2 binary64) y)))
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 y #s(literal 2 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
Calls

3 calls:

40.0ms
z
3.0ms
x
3.0ms
y
Results
AccuracySegmentsBranch
73.0%3z
85.8%3y
86.0%3x
Compiler

Compiled 3 to 9 computations (-200% saved)

regimes5.0ms (0.2%)

Memory
18.8MiB live, 18.8MiB allocated; 0ms collecting garbage
Counts
6 → 3
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (fma.f64 x #s(literal 3 binary64) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
Calls

2 calls:

2.0ms
x
2.0ms
y
Results
AccuracySegmentsBranch
83.8%3y
66.1%1x
Compiler

Compiled 2 to 6 computations (-200% saved)

regimes11.0ms (0.4%)

Memory
-20.2MiB live, 27.4MiB allocated; 5ms collecting garbage
Counts
5 → 4
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) (*.f64 #s(literal 3 binary64) x))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
Calls

4 calls:

5.0ms
x
2.0ms
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
2.0ms
z
2.0ms
y
Results
AccuracySegmentsBranch
60.0%4x
59.9%5z
47.0%3(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
62.9%4y
Compiler

Compiled 11 to 17 computations (-54.5% saved)

regimes3.0ms (0.1%)

Memory
7.2MiB live, 7.2MiB allocated; 0ms collecting garbage
Counts
4 → 3
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ (* 2 y) (* 3 x)) (*.f64 #s(literal 2 binary64) y)))
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
(+.f64 #s(approx (+ (+ (+ (+ x y) y) x) z) #s(approx (+ z (* 2 x)) z)) x)
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
Calls

1 calls:

2.0ms
y
Results
AccuracySegmentsBranch
60.6%3y
Compiler

Compiled 1 to 3 computations (-200% saved)

regimes3.0ms (0.1%)

Memory
9.3MiB live, 9.3MiB allocated; 0ms collecting garbage
Counts
2 → 3
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
Outputs
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
#s(approx (+ (+ (+ (+ (+ x y) y) x) z) x) #s(approx (+ (* 2 y) (* 3 x)) (+.f64 y y)))
Calls

2 calls:

1.0ms
y
1.0ms
x
Results
AccuracySegmentsBranch
41.2%3x
57.3%3y
Compiler

Compiled 2 to 6 computations (-200% saved)

regimes4.0ms (0.1%)

Memory
15.5MiB live, 15.5MiB allocated; 0ms collecting garbage
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
Outputs
#s(approx (+ (* 3 x) (+ (* 2 y) z)) #s(approx (+ z (* 3 x)) z))
Calls

4 calls:

1.0ms
(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
1.0ms
z
1.0ms
y
1.0ms
x
Results
AccuracySegmentsBranch
33.7%1x
33.7%1(+.f64 (+.f64 (+.f64 (+.f64 (+.f64 x y) y) x) z) x)
33.7%1z
33.7%1y
Compiler

Compiled 11 to 17 computations (-54.5% saved)

bsearch24.0ms (0.8%)

Memory
7.3MiB live, 53.3MiB allocated; 4ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
9.0ms
3.366936823698617e+77
2.049581301793043e+79
13.0ms
-6.461111614623016e+86
-1.0721269280302025e+81
Samples
7.0ms216×0valid
2.0ms25×1valid
2.0ms15×2valid
Compiler

Compiled 398 to 430 computations (-8% saved)

Precisions
Click to see histograms. Total time spent on operations: 5.0ms
ival-add!: 3.0ms (59.6% of total)
adjust: 2.0ms (39.7% of total)

bsearch19.0ms (0.6%)

Memory
-7.1MiB live, 36.9MiB allocated; 7ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
14.0ms
3.3055675560496543e+69
4.407945911852039e+76
3.0ms
-6.461111614623016e+86
-1.0721269280302025e+81
Samples
5.0ms160×0valid
1.0ms2valid
1.0ms10×1valid
0.0ms3valid
Compiler

Compiled 446 to 482 computations (-8.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 3.0ms
ival-add!: 2.0ms (63% of total)
adjust: 1.0ms (31.5% of total)

bsearch27.0ms (0.9%)

Memory
-4.8MiB live, 43.5MiB allocated; 14ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
6.0ms
5.059550934917381e+28
1.1845149815977076e+29
20.0ms
-7.965386455421766e+96
-4.24511219598581e+88
Samples
7.0ms206×0valid
1.0ms11×1valid
1.0ms2valid
Compiler

Compiled 322 to 350 computations (-8.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 3.0ms
ival-add!: 3.0ms (87.5% of total)
adjust: 1.0ms (29.2% of total)

bsearch26.0ms (0.8%)

Memory
8.6MiB live, 54.2MiB allocated; 5ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
7.0ms
2.3314917637450344e+159
9.081182228630137e+160
16.0ms
-9.505476115264889e+164
-9.734562906417407e+133
Samples
9.0ms267×0valid
2.0ms21×1valid
Compiler

Compiled 500 to 536 computations (-7.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 4.0ms
ival-add!: 3.0ms (75.7% of total)
adjust: 1.0ms (25.2% of total)

bsearch30.0ms (0.9%)

Memory
17.9MiB live, 63.0MiB allocated; 8ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
narrow-enough
Steps
TimeLeftRight
7.0ms
3.739924275652876e+67
2.0556406936878038e+69
4.0ms
9.842458269924986e-151
1.299673972778338e-150
16.0ms
-3.2442264368532446e+40
-2.1388775700088888e+24
Samples
9.0ms293×0valid
1.0ms12×2valid
1.0ms13×1valid
0.0ms3valid
Compiler

Compiled 565 to 605 computations (-7.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 5.0ms
ival-add!: 4.0ms (77% of total)
adjust: 1.0ms (19.3% of total)

bsearch15.0ms (0.5%)

Memory
-17.0MiB live, 28.3MiB allocated; 6ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
13.0ms
3.2770465971232286e-10
8.480014924645548e-8
1.0ms
-3.2442264368532446e+40
-2.1388775700088888e+24
Samples
4.0ms1valid
4.0ms112×0valid
1.0ms2valid
Compiler

Compiled 536 to 572 computations (-6.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
adjust: 4.0ms (66.5% of total)
ival-add!: 2.0ms (33.3% of total)

bsearch22.0ms (0.7%)

Memory
-17.9MiB live, 30.9MiB allocated; 13ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
14.0ms
3.2770465971232286e-10
8.480014924645548e-8
6.0ms
-3.2442264368532446e+40
-2.1388775700088888e+24
Samples
10.0ms2valid
4.0ms129×0valid
1.0ms1valid
Compiler

Compiled 536 to 554 computations (-3.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 11.0ms
ival-add!: 11.0ms (95.8% of total)
adjust: 1.0ms (8.7% of total)

derivations94.0ms (3%)

Memory
13.2MiB live, 150.8MiB allocated; 14ms collecting garbage
Stop Event
fuel
Compiler

Compiled 117 to 85 computations (27.4% saved)

preprocess807.0ms (25.7%)

Memory
27.0MiB live, 219.6MiB allocated; 18ms collecting garbage
Compiler

Compiled 125 to 93 computations (25.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...