Language.Haskell.HsColour.ColourHighlight:unbase from hscolour-1.23

Time bar (total: 3.0s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB 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.8%0.2%0%0%0%0
100%99.8%0%0.2%0%0%0%1
Compiler

Compiled 11 to 10 computations (9.1% saved)

sample1.0s (33.3%)

Memory
8.3MiB live, 1 374.8MiB allocated; 454ms collecting garbage
Samples
504.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 144.0ms
ival-mult!: 105.0ms (72.7% of total)
ival-add!: 38.0ms (26.3% of total)
adjust: 1.0ms (0.7% of total)
Bogosity

preprocess97.0ms (3.2%)

Memory
-1.2MiB live, 90.5MiB allocated; 19ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
051149
1126135
2373135
31205135
42170135
52534135
62964135
73377135
86471135
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.9%
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Compiler

Compiled 16 to 16 computations (0% saved)

series15.0ms (0.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0129535
Stop Event
iter-limit
Counts
8 → 33
Calls
Call 1
Inputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(*.f64 (+.f64 (*.f64 x y) z) y)
(+.f64 (*.f64 x y) z)
(*.f64 x y)
x
y
z
t
Outputs
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y z)))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z))))
#s(approx (* (+ (* x y) z) y) (*.f64 y z))
#s(approx (* (+ (* x y) z) y) (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z)))
#s(approx (+ (* x y) z) z)
#s(approx (+ (* x y) z) (+.f64 z (*.f64 x y)))
#s(approx (* x y) (*.f64 x y))
#s(approx x x)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (pow.f64 y #s(literal 2 binary64))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (+.f64 (/.f64 t x) (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64))))))
#s(approx (* (+ (* x y) z) y) (*.f64 x (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* x y) z) (*.f64 x (+.f64 y (/.f64 z x))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 y z)) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (* (+ (* x y) z) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 z x))))))
#s(approx (+ (* (+ (* x y) z) y) t) t)
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y (+.f64 z (*.f64 x y)))))
#s(approx (* (+ (* x y) z) y) (*.f64 y (+.f64 z (*.f64 x y))))
#s(approx y y)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (+.f64 (/.f64 t (pow.f64 y #s(literal 2 binary64))) (/.f64 z y)))))
#s(approx (+ (* x y) z) (*.f64 y (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 t y))) y)))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 z y))))))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 z (+.f64 y (+.f64 (/.f64 t z) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z)))))
#s(approx (* (+ (* x y) z) y) (*.f64 z (+.f64 y (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z))))
#s(approx (+ (* x y) z) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) z))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))) z))))))
#s(approx (* (+ (* x y) z) y) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)) #s(literal 1 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 t (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t)) #s(literal 1 binary64)))))
Calls

12 calls:

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

rewrite324.0ms (10.7%)

Memory
13.2MiB live, 293.5MiB allocated; 70ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0828
01228
15228
213428
349328
4129528
5220628
6503828
0824524
11451124
Stop Event
saturated
node-limit
iter-limit
Counts
8 → 84
Calls
Call 1
Inputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(*.f64 (+.f64 (*.f64 x y) z) y)
(+.f64 (*.f64 x y) z)
(*.f64 x y)
x
y
z
t
Outputs
(neg.f64 (neg.f64 (fma.f64 (fma.f64 y x z) y t)))
(fma.f64 (*.f64 (neg.f64 x) (neg.f64 (fabs.f64 y))) (fabs.f64 y) (fma.f64 z y t))
(fma.f64 (*.f64 x (neg.f64 (fabs.f64 y))) (neg.f64 (fabs.f64 y)) (fma.f64 z y t))
(fma.f64 (*.f64 (fabs.f64 y) (neg.f64 x)) (neg.f64 (fabs.f64 y)) (fma.f64 z y t))
(fma.f64 (*.f64 (fabs.f64 y) x) (fabs.f64 y) (fma.f64 z y t))
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (neg.f64 (fabs.f64 y)) x) (fma.f64 z y t))
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (fabs.f64 y) (neg.f64 x)) (fma.f64 z y t))
(fma.f64 (*.f64 (neg.f64 y) y) (neg.f64 x) (fma.f64 z y t))
(fma.f64 (fabs.f64 y) (*.f64 (neg.f64 (fabs.f64 y)) (neg.f64 x)) (fma.f64 z y t))
(fma.f64 (fabs.f64 y) (*.f64 (fabs.f64 y) x) (fma.f64 z y t))
(fma.f64 (*.f64 y y) x (fma.f64 z y t))
(fma.f64 (*.f64 y x) y (fma.f64 z y t))
(fma.f64 (neg.f64 y) (neg.f64 (fma.f64 y x z)) t)
(fma.f64 (neg.f64 y) (*.f64 (neg.f64 y) x) (fma.f64 z y t))
(fma.f64 (neg.f64 y) (neg.f64 z) (fma.f64 (*.f64 y y) x t))
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 y) y) (fma.f64 z y t))
(fma.f64 (neg.f64 (fma.f64 y x z)) (neg.f64 y) t)
(fma.f64 (*.f64 (neg.f64 y) x) (neg.f64 y) (fma.f64 z y t))
(fma.f64 (neg.f64 z) (neg.f64 y) (fma.f64 (*.f64 y y) x t))
(fma.f64 (fma.f64 y x z) y t)
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
(fma.f64 y (*.f64 y x) (fma.f64 z y t))
(fma.f64 y (fma.f64 y x z) t)
(fma.f64 y z (fma.f64 (*.f64 y y) x t))
(fma.f64 x (*.f64 y y) (fma.f64 z y t))
(-.f64 (fma.f64 z y t) (*.f64 (*.f64 (neg.f64 y) y) x))
(-.f64 (fma.f64 (*.f64 y y) x t) (*.f64 (neg.f64 y) z))
(-.f64 (*.f64 z y) (neg.f64 (fma.f64 (*.f64 y y) x t)))
(-.f64 (*.f64 (*.f64 y y) x) (neg.f64 (fma.f64 z y t)))
(-.f64 t (*.f64 (neg.f64 y) (fma.f64 y x z)))
(-.f64 (*.f64 (fma.f64 y x z) y) (neg.f64 t))
(+.f64 (fma.f64 z y t) (*.f64 (*.f64 y y) x))
(+.f64 (fma.f64 (*.f64 y y) x t) (*.f64 z y))
(+.f64 (*.f64 z y) (fma.f64 (*.f64 y y) x t))
(+.f64 (*.f64 (*.f64 y y) x) (fma.f64 z y t))
(+.f64 t (*.f64 (fma.f64 y x z) y))
(+.f64 (*.f64 (fma.f64 y x z) y) t)
(*.f64 (neg.f64 y) (neg.f64 (fma.f64 y x z)))
(*.f64 (neg.f64 (fma.f64 y x z)) (neg.f64 y))
(*.f64 (fma.f64 y x z) y)
(*.f64 y (fma.f64 y x z))
(neg.f64 (*.f64 (neg.f64 y) (fma.f64 y x z)))
(fma.f64 (*.f64 (neg.f64 x) (neg.f64 (fabs.f64 y))) (fabs.f64 y) (*.f64 z y))
(fma.f64 (*.f64 x (neg.f64 (fabs.f64 y))) (neg.f64 (fabs.f64 y)) (*.f64 z y))
(fma.f64 (*.f64 (fabs.f64 y) (neg.f64 x)) (neg.f64 (fabs.f64 y)) (*.f64 z y))
(fma.f64 (*.f64 (fabs.f64 y) x) (fabs.f64 y) (*.f64 z y))
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (neg.f64 (fabs.f64 y)) x) (*.f64 z y))
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (fabs.f64 y) (neg.f64 x)) (*.f64 z y))
(fma.f64 (*.f64 (neg.f64 y) y) (neg.f64 x) (*.f64 z y))
(fma.f64 (fabs.f64 y) (*.f64 (neg.f64 (fabs.f64 y)) (neg.f64 x)) (*.f64 z y))
(fma.f64 (fabs.f64 y) (*.f64 (fabs.f64 y) x) (*.f64 z y))
(fma.f64 (*.f64 y y) x (*.f64 z y))
(fma.f64 (*.f64 y x) y (*.f64 z y))
(fma.f64 (neg.f64 y) (*.f64 (neg.f64 y) x) (*.f64 z y))
(fma.f64 (neg.f64 y) (neg.f64 z) (*.f64 (*.f64 y y) x))
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 y) y) (*.f64 z y))
(fma.f64 (*.f64 (neg.f64 y) x) (neg.f64 y) (*.f64 z y))
(fma.f64 (neg.f64 z) (neg.f64 y) (*.f64 (*.f64 y y) x))
(fma.f64 z y (*.f64 (*.f64 y y) x))
(fma.f64 y (*.f64 y x) (*.f64 z y))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(-.f64 (*.f64 z y) (*.f64 (*.f64 (neg.f64 y) y) x))
(-.f64 (*.f64 (*.f64 y y) x) (*.f64 (neg.f64 y) z))
(+.f64 (*.f64 z y) (*.f64 (*.f64 y y) x))
(+.f64 (*.f64 (*.f64 y y) x) (*.f64 z y))
(neg.f64 (neg.f64 (fma.f64 y x z)))
(fma.f64 (neg.f64 y) (neg.f64 x) z)
(fma.f64 (neg.f64 x) (neg.f64 y) z)
(fma.f64 y x z)
(fma.f64 x y z)
(-.f64 (*.f64 y x) (neg.f64 z))
(-.f64 z (*.f64 (neg.f64 y) x))
(+.f64 (*.f64 y x) z)
(+.f64 z (*.f64 y x))
(*.f64 (neg.f64 y) (neg.f64 x))
(*.f64 (neg.f64 x) (neg.f64 y))
(*.f64 y x)
(*.f64 x y)
(neg.f64 (*.f64 (neg.f64 y) x))
x
y
z
t

eval14.0ms (0.5%)

Memory
-18.5MiB live, 26.4MiB allocated; 5ms collecting garbage
Compiler

Compiled 701 to 317 computations (54.8% saved)

prune4.0ms (0.1%)

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

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New1084112
Fresh000
Picked101
Done000
Total1094113
Accuracy
100.0%
Counts
113 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (fma.f64 y x z) y t)
95.3%
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
71.3%
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
38.7%
#s(approx (+ (* (+ (* x y) z) y) t) t)
Compiler

Compiled 31 to 31 computations (0% saved)

series27.0ms (0.9%)

Memory
-1.5MiB live, 44.0MiB allocated; 5ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0166691
Stop Event
iter-limit
Counts
13 → 41
Calls
Call 1
Inputs
#s(approx (+ (* (+ (* x y) z) y) t) t)
t
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
(*.f64 #s(approx (+ (* x y) z) z) y)
#s(approx (+ (* x y) z) z)
z
y
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
(fma.f64 (*.f64 y y) x t)
(*.f64 y y)
x
(fma.f64 (fma.f64 y x z) y t)
(fma.f64 y x z)
Outputs
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y z)))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z))))
#s(approx (* (+ (* x y) z) y) (*.f64 y z))
#s(approx (* (+ (* x y) z) y) (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z)))
#s(approx (+ (* x y) z) z)
#s(approx (+ (* x y) z) (+.f64 z (*.f64 x y)))
#s(approx (+ (* (* y y) x) t) t)
#s(approx (+ (* (* y y) x) t) (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))))
#s(approx x x)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (pow.f64 y #s(literal 2 binary64))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (+.f64 (/.f64 t x) (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64))))))
#s(approx (* (+ (* x y) z) y) (*.f64 x (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* x y) z) (*.f64 x y))
#s(approx (+ (* x y) z) (*.f64 x (+.f64 y (/.f64 z x))))
#s(approx (+ (* (* y y) x) t) (*.f64 x (+.f64 (/.f64 t x) (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 y z)) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (* (+ (* x y) z) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 z x))))))
#s(approx (+ (* (* y y) x) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 t x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y (+.f64 z (*.f64 x y)))))
#s(approx (* (+ (* x y) z) y) (*.f64 y (+.f64 z (*.f64 x y))))
#s(approx y y)
#s(approx (* y y) (pow.f64 y #s(literal 2 binary64)))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (+.f64 (/.f64 t (pow.f64 y #s(literal 2 binary64))) (/.f64 z y)))))
#s(approx (+ (* x y) z) (*.f64 y (+.f64 x (/.f64 z y))))
#s(approx (+ (* (* y y) x) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (/.f64 t (pow.f64 y #s(literal 2 binary64))))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 t y))) y)))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 z y))))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 z (+.f64 y (+.f64 (/.f64 t z) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z)))))
#s(approx (* (+ (* x y) z) y) (*.f64 z (+.f64 y (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z))))
#s(approx (+ (* x y) z) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) z))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))) z))))))
#s(approx (* (+ (* x y) z) y) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)) #s(literal 1 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 t (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t))))
#s(approx (+ (* z y) (+ (* (* y y) x) t)) (*.f64 t (+.f64 #s(literal 1 binary64) (+.f64 (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) t) (/.f64 (*.f64 y z) t)))))
#s(approx (+ (* (* y y) x) t) (*.f64 t (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) t))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t)) #s(literal 1 binary64)))))
#s(approx (+ (* z y) (+ (* (* y y) x) t)) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z)) t)) #s(literal 1 binary64)))))
#s(approx (+ (* (* y y) x) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) t)) #s(literal 1 binary64)))))
Calls

12 calls:

TimeVariablePointExpression
10.0ms
y
@-inf
((+ (* (+ (* x y) z) y) t) t (+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) z y (+ (* z y) (+ (* (* y y) x) t)) (+ (* (* y y) x) t) (* y y) x (+ (* (+ (* y x) z) y) t) (+ (* y x) z))
2.0ms
y
@0
((+ (* (+ (* x y) z) y) t) t (+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) z y (+ (* z y) (+ (* (* y y) x) t)) (+ (* (* y y) x) t) (* y y) x (+ (* (+ (* y x) z) y) t) (+ (* y x) z))
1.0ms
x
@-inf
((+ (* (+ (* x y) z) y) t) t (+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) z y (+ (* z y) (+ (* (* y y) x) t)) (+ (* (* y y) x) t) (* y y) x (+ (* (+ (* y x) z) y) t) (+ (* y x) z))
1.0ms
y
@inf
((+ (* (+ (* x y) z) y) t) t (+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) z y (+ (* z y) (+ (* (* y y) x) t)) (+ (* (* y y) x) t) (* y y) x (+ (* (+ (* y x) z) y) t) (+ (* y x) z))
1.0ms
x
@inf
((+ (* (+ (* x y) z) y) t) t (+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) z y (+ (* z y) (+ (* (* y y) x) t)) (+ (* (* y y) x) t) (* y y) x (+ (* (+ (* y x) z) y) t) (+ (* y x) z))

rewrite207.0ms (6.8%)

Memory
-7.0MiB live, 178.5MiB allocated; 24ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01771
02868
116664
241364
3128364
4210764
5387364
0811563
11212863
Stop Event
saturated
node-limit
iter-limit
Counts
13 → 131
Calls
Call 1
Inputs
#s(approx (+ (* (+ (* x y) z) y) t) t)
t
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
(*.f64 #s(approx (+ (* x y) z) z) y)
#s(approx (+ (* x y) z) z)
z
y
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
(fma.f64 (*.f64 y y) x t)
(*.f64 y y)
x
(fma.f64 (fma.f64 y x z) y t)
(fma.f64 y x z)
Outputs
#s(approx (+ (* (+ (* x y) z) y) t) t)
t
(neg.f64 (neg.f64 (fma.f64 #s(approx (+ (* x y) z) z) y t)))
(fma.f64 (neg.f64 #s(approx (+ (* x y) z) z)) (neg.f64 y) t)
(fma.f64 (neg.f64 y) (neg.f64 #s(approx (+ (* x y) z) z)) t)
(fma.f64 #s(approx (+ (* x y) z) z) y t)
(fma.f64 y #s(approx (+ (* x y) z) z) t)
(-.f64 (*.f64 #s(approx (+ (* x y) z) z) y) (neg.f64 t))
(-.f64 t (*.f64 (neg.f64 y) #s(approx (+ (* x y) z) z)))
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
(+.f64 t (*.f64 #s(approx (+ (* x y) z) z) y))
(*.f64 (neg.f64 #s(approx (+ (* x y) z) z)) (neg.f64 y))
(*.f64 (neg.f64 y) (neg.f64 #s(approx (+ (* x y) z) z)))
(*.f64 #s(approx (+ (* x y) z) z) y)
(*.f64 y #s(approx (+ (* x y) z) z))
(neg.f64 (*.f64 (neg.f64 y) #s(approx (+ (* x y) z) z)))
#s(approx (+ (* x y) z) z)
(neg.f64 (neg.f64 #s(approx (+ (* x y) z) z)))
z
y
(neg.f64 (neg.f64 (fma.f64 (fma.f64 y x z) y t)))
(fma.f64 (*.f64 (fabs.f64 y) x) (fabs.f64 y) (fma.f64 z y t))
(fma.f64 (*.f64 (neg.f64 x) (fabs.f64 y)) (neg.f64 (fabs.f64 y)) (fma.f64 z y t))
(fma.f64 (*.f64 (neg.f64 y) y) (neg.f64 x) (fma.f64 z y t))
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 y) y) (fma.f64 z y t))
(fma.f64 (neg.f64 (fma.f64 y x z)) (neg.f64 y) t)
(fma.f64 (*.f64 (neg.f64 y) x) (neg.f64 y) (fma.f64 z y t))
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (neg.f64 x) (fabs.f64 y)) (fma.f64 z y t))
(fma.f64 (neg.f64 z) (neg.f64 y) (fma.f64 (*.f64 y y) x t))
(fma.f64 (fabs.f64 y) (*.f64 (fabs.f64 y) x) (fma.f64 z y t))
(fma.f64 (neg.f64 y) (neg.f64 (fma.f64 y x z)) t)
(fma.f64 (neg.f64 y) (*.f64 (neg.f64 y) x) (fma.f64 z y t))
(fma.f64 (neg.f64 y) (neg.f64 z) (fma.f64 (*.f64 y y) x t))
(fma.f64 (*.f64 y x) y (fma.f64 z y t))
(fma.f64 (fma.f64 y x z) y t)
(fma.f64 (*.f64 y y) x (fma.f64 z y t))
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
(fma.f64 y (*.f64 y x) (fma.f64 z y t))
(fma.f64 y (fma.f64 y x z) t)
(fma.f64 y z (fma.f64 (*.f64 y y) x t))
(fma.f64 x (*.f64 y y) (fma.f64 z y t))
(-.f64 (fma.f64 z y t) (*.f64 (*.f64 (neg.f64 y) y) x))
(-.f64 (*.f64 z y) (neg.f64 (fma.f64 (*.f64 y y) x t)))
(-.f64 (*.f64 (*.f64 y y) x) (neg.f64 (fma.f64 z y t)))
(-.f64 (*.f64 (fma.f64 y x z) y) (neg.f64 t))
(-.f64 (fma.f64 (*.f64 y y) x t) (*.f64 (neg.f64 z) y))
(-.f64 t (*.f64 (neg.f64 y) (fma.f64 y x z)))
(+.f64 (fma.f64 z y t) (*.f64 (*.f64 y y) x))
(+.f64 (*.f64 z y) (fma.f64 (*.f64 y y) x t))
(+.f64 (*.f64 (*.f64 y y) x) (fma.f64 z y t))
(+.f64 (*.f64 (fma.f64 y x z) y) t)
(+.f64 (fma.f64 (*.f64 y y) x t) (*.f64 z y))
(+.f64 t (*.f64 (fma.f64 y x z) y))
(neg.f64 (neg.f64 (fma.f64 (*.f64 y y) x t)))
(fma.f64 (*.f64 (fabs.f64 y) x) (fabs.f64 y) t)
(fma.f64 (*.f64 (neg.f64 x) (fabs.f64 y)) (neg.f64 (fabs.f64 y)) t)
(fma.f64 (*.f64 (neg.f64 y) y) (neg.f64 x) t)
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 y) y) t)
(fma.f64 (*.f64 (neg.f64 y) x) (neg.f64 y) t)
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (neg.f64 x) (fabs.f64 y)) t)
(fma.f64 (fabs.f64 y) (*.f64 (fabs.f64 y) x) t)
(fma.f64 (neg.f64 y) (*.f64 (neg.f64 y) x) t)
(fma.f64 (*.f64 y x) y t)
(fma.f64 (*.f64 y y) x t)
(fma.f64 y (*.f64 y x) t)
(fma.f64 x (*.f64 y y) t)
(-.f64 (*.f64 (*.f64 y y) x) (neg.f64 t))
(-.f64 t (*.f64 (*.f64 (neg.f64 y) y) x))
(+.f64 (*.f64 (*.f64 y y) x) t)
(+.f64 t (*.f64 (*.f64 y y) x))
(*.f64 (neg.f64 (fabs.f64 y)) (neg.f64 (fabs.f64 y)))
(*.f64 (fabs.f64 y) (fabs.f64 y))
(*.f64 (neg.f64 y) (neg.f64 y))
(*.f64 y y)
(pow.f64 (pow.f64 y #s(literal 16 binary64)) #s(literal 1/8 binary64))
(pow.f64 (pow.f64 y #s(literal 8 binary64)) #s(literal 1/4 binary64))
(pow.f64 (*.f64 (*.f64 (*.f64 y y) y) y) #s(literal 1/2 binary64))
(pow.f64 (neg.f64 (fabs.f64 y)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 y) #s(literal 2 binary64))
(pow.f64 (neg.f64 y) #s(literal 2 binary64))
(pow.f64 (*.f64 y y) #s(literal 1 binary64))
(pow.f64 y #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 y) y))
(sqrt.f64 (*.f64 (*.f64 (*.f64 y y) y) y))
(fabs.f64 (*.f64 (fabs.f64 y) (neg.f64 y)))
(fabs.f64 (*.f64 (fabs.f64 y) y))
(fabs.f64 (*.f64 (neg.f64 y) y))
(fabs.f64 (*.f64 y y))
x
(neg.f64 (neg.f64 (fma.f64 (fma.f64 y x z) y t)))
(fma.f64 (*.f64 (fabs.f64 y) x) (fabs.f64 y) (fma.f64 z y t))
(fma.f64 (*.f64 (neg.f64 x) (fabs.f64 y)) (neg.f64 (fabs.f64 y)) (fma.f64 z y t))
(fma.f64 (*.f64 (neg.f64 y) y) (neg.f64 x) (fma.f64 z y t))
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 y) y) (fma.f64 z y t))
(fma.f64 (neg.f64 (fma.f64 y x z)) (neg.f64 y) t)
(fma.f64 (*.f64 (neg.f64 y) x) (neg.f64 y) (fma.f64 z y t))
(fma.f64 (neg.f64 (fabs.f64 y)) (*.f64 (neg.f64 x) (fabs.f64 y)) (fma.f64 z y t))
(fma.f64 (neg.f64 z) (neg.f64 y) (fma.f64 (*.f64 y y) x t))
(fma.f64 (fabs.f64 y) (*.f64 (fabs.f64 y) x) (fma.f64 z y t))
(fma.f64 (neg.f64 y) (neg.f64 (fma.f64 y x z)) t)
(fma.f64 (neg.f64 y) (*.f64 (neg.f64 y) x) (fma.f64 z y t))
(fma.f64 (neg.f64 y) (neg.f64 z) (fma.f64 (*.f64 y y) x t))
(fma.f64 (*.f64 y x) y (fma.f64 z y t))
(fma.f64 (fma.f64 y x z) y t)
(fma.f64 (*.f64 y y) x (fma.f64 z y t))
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
(fma.f64 y (*.f64 y x) (fma.f64 z y t))
(fma.f64 y (fma.f64 y x z) t)
(fma.f64 y z (fma.f64 (*.f64 y y) x t))
(fma.f64 x (*.f64 y y) (fma.f64 z y t))
(-.f64 (fma.f64 z y t) (*.f64 (*.f64 (neg.f64 y) y) x))
(-.f64 (*.f64 z y) (neg.f64 (fma.f64 (*.f64 y y) x t)))
(-.f64 (*.f64 (*.f64 y y) x) (neg.f64 (fma.f64 z y t)))
(-.f64 (*.f64 (fma.f64 y x z) y) (neg.f64 t))
(-.f64 (fma.f64 (*.f64 y y) x t) (*.f64 (neg.f64 z) y))
(-.f64 t (*.f64 (neg.f64 y) (fma.f64 y x z)))
(+.f64 (fma.f64 z y t) (*.f64 (*.f64 y y) x))
(+.f64 (*.f64 z y) (fma.f64 (*.f64 y y) x t))
(+.f64 (*.f64 (*.f64 y y) x) (fma.f64 z y t))
(+.f64 (*.f64 (fma.f64 y x z) y) t)
(+.f64 (fma.f64 (*.f64 y y) x t) (*.f64 z y))
(+.f64 t (*.f64 (fma.f64 y x z) y))
(neg.f64 (neg.f64 (fma.f64 y x z)))
(fma.f64 (neg.f64 x) (neg.f64 y) z)
(fma.f64 (neg.f64 y) (neg.f64 x) z)
(fma.f64 y x z)
(fma.f64 x y z)
(-.f64 (*.f64 y x) (neg.f64 z))
(-.f64 z (*.f64 (neg.f64 y) x))
(+.f64 (*.f64 y x) z)
(+.f64 z (*.f64 y x))

eval15.0ms (0.5%)

Memory
-10.9MiB live, 35.0MiB allocated; 4ms collecting garbage
Compiler

Compiled 803 to 393 computations (51.1% saved)

prune3.0ms (0.1%)

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

5 alts after pruning (2 fresh and 3 done)

PrunedKeptTotal
New1262128
Fresh000
Picked134
Done000
Total1275132
Accuracy
100.0%
Counts
132 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (fma.f64 y x z) y t)
71.3%
(fma.f64 #s(approx (+ (* x y) z) z) y t)
95.3%
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
73.0%
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y) t)
38.7%
#s(approx (+ (* (+ (* x y) z) y) t) t)
Compiler

Compiled 40 to 40 computations (0% saved)

series11.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0129535
Stop Event
iter-limit
Counts
10 → 33
Calls
Call 1
Inputs
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y) t)
(*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y)
#s(approx (+ (* x y) z) (*.f64 x y))
(*.f64 x y)
x
y
t
(fma.f64 #s(approx (+ (* x y) z) z) y t)
#s(approx (+ (* x y) z) z)
z
Outputs
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y z)))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z))))
#s(approx (* (+ (* x y) z) y) (*.f64 y z))
#s(approx (* (+ (* x y) z) y) (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z)))
#s(approx (+ (* x y) z) z)
#s(approx (+ (* x y) z) (+.f64 z (*.f64 x y)))
#s(approx (* x y) (*.f64 x y))
#s(approx x x)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (pow.f64 y #s(literal 2 binary64))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (+.f64 (/.f64 t x) (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64))))))
#s(approx (* (+ (* x y) z) y) (*.f64 x (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* x y) z) (*.f64 x (+.f64 y (/.f64 z x))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 y z)) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (* (+ (* x y) z) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 z x))))))
#s(approx (+ (* (+ (* x y) z) y) t) t)
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y (+.f64 z (*.f64 x y)))))
#s(approx (* (+ (* x y) z) y) (*.f64 y (+.f64 z (*.f64 x y))))
#s(approx y y)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (+.f64 (/.f64 t (pow.f64 y #s(literal 2 binary64))) (/.f64 z y)))))
#s(approx (+ (* x y) z) (*.f64 y (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 t y))) y)))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 z y))))))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 z (+.f64 y (+.f64 (/.f64 t z) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z)))))
#s(approx (* (+ (* x y) z) y) (*.f64 z (+.f64 y (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z))))
#s(approx (+ (* x y) z) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) z))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))) z))))))
#s(approx (* (+ (* x y) z) y) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)) #s(literal 1 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 t (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t)) #s(literal 1 binary64)))))
Calls

12 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) (* x y) x y t (+ (* (+ (* x y) z) y) t) (+ (* x y) z) z)
1.0ms
x
@-inf
((+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) (* x y) x y t (+ (* (+ (* x y) z) y) t) (+ (* x y) z) z)
1.0ms
y
@inf
((+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) (* x y) x y t (+ (* (+ (* x y) z) y) t) (+ (* x y) z) z)
1.0ms
x
@inf
((+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) (* x y) x y t (+ (* (+ (* x y) z) y) t) (+ (* x y) z) z)
0.0ms
z
@-inf
((+ (* (+ (* x y) z) y) t) (* (+ (* x y) z) y) (+ (* x y) z) (* x y) x y t (+ (* (+ (* x y) z) y) t) (+ (* x y) z) z)

rewrite370.0ms (12.2%)

Memory
-29.3MiB live, 219.1MiB allocated; 73ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01257
01757
17357
217957
347557
486257
5121157
6389157
0811851
11393851
Stop Event
saturated
node-limit
iter-limit
Counts
10 → 36
Calls
Call 1
Inputs
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y) t)
(*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y)
#s(approx (+ (* x y) z) (*.f64 x y))
(*.f64 x y)
x
y
t
(fma.f64 #s(approx (+ (* x y) z) z) y t)
#s(approx (+ (* x y) z) z)
z
Outputs
(neg.f64 (neg.f64 (fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)))
(fma.f64 (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))) (neg.f64 y) t)
(fma.f64 (neg.f64 y) (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))) t)
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
(fma.f64 y #s(approx (+ (* x y) z) (*.f64 y x)) t)
(-.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y) (neg.f64 t))
(-.f64 t (*.f64 (neg.f64 y) #s(approx (+ (* x y) z) (*.f64 y x))))
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y) t)
(+.f64 t (*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y))
(*.f64 (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))) (neg.f64 y))
(*.f64 (neg.f64 y) (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))))
(*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y)
(*.f64 y #s(approx (+ (* x y) z) (*.f64 y x)))
(neg.f64 (*.f64 (neg.f64 y) #s(approx (+ (* x y) z) (*.f64 y x))))
#s(approx (+ (* x y) z) (*.f64 y x))
(neg.f64 (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))))
(*.f64 (neg.f64 y) (neg.f64 x))
(*.f64 (neg.f64 x) (neg.f64 y))
(*.f64 y x)
(*.f64 x y)
(neg.f64 (*.f64 (neg.f64 x) y))
x
y
t
(neg.f64 (neg.f64 (fma.f64 #s(approx (+ (* x y) z) z) y t)))
(fma.f64 (neg.f64 #s(approx (+ (* x y) z) z)) (neg.f64 y) t)
(fma.f64 (neg.f64 y) (neg.f64 #s(approx (+ (* x y) z) z)) t)
(fma.f64 #s(approx (+ (* x y) z) z) y t)
(fma.f64 y #s(approx (+ (* x y) z) z) t)
(-.f64 (*.f64 #s(approx (+ (* x y) z) z) y) (neg.f64 t))
(-.f64 t (*.f64 (neg.f64 y) #s(approx (+ (* x y) z) z)))
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
(+.f64 t (*.f64 #s(approx (+ (* x y) z) z) y))
#s(approx (+ (* x y) z) z)
(neg.f64 (neg.f64 #s(approx (+ (* x y) z) z)))
z

eval6.0ms (0.2%)

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

Compiled 487 to 214 computations (56.1% saved)

prune3.0ms (0.1%)

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

5 alts after pruning (1 fresh and 4 done)

PrunedKeptTotal
New60161
Fresh000
Picked112
Done033
Total61566
Accuracy
100.0%
Counts
66 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (fma.f64 y x z) y t)
73.0%
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
71.3%
(fma.f64 #s(approx (+ (* x y) z) z) y t)
95.3%
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
38.7%
#s(approx (+ (* (+ (* x y) z) y) t) t)
Compiler

Compiled 39 to 39 computations (0% saved)

series55.0ms (1.8%)

Memory
-20.7MiB live, 25.3MiB allocated; 5ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0114440
Stop Event
iter-limit
Counts
6 → 28
Calls
Call 1
Inputs
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
#s(approx (+ (* x y) z) (*.f64 y x))
(*.f64 y x)
y
x
t
Outputs
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y z)))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (fma.f64 x (pow.f64 y #s(literal 2 binary64)) (*.f64 y z))))
#s(approx (+ (* x y) z) z)
#s(approx (+ (* x y) z) (+.f64 z (*.f64 x y)))
#s(approx (* y x) (*.f64 x y))
#s(approx x x)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (pow.f64 y #s(literal 2 binary64))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 x (+.f64 (/.f64 t x) (+.f64 (/.f64 (*.f64 y z) x) (pow.f64 y #s(literal 2 binary64))))))
#s(approx (+ (* x y) z) (*.f64 x (+.f64 y (/.f64 z x))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 y z)) x) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 z x))))))
#s(approx (+ (* (+ (* x y) z) y) t) t)
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 y (+.f64 z (*.f64 x y)))))
#s(approx y y)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (+.f64 (/.f64 t (pow.f64 y #s(literal 2 binary64))) (/.f64 z y)))))
#s(approx (+ (* x y) z) (*.f64 y (+.f64 x (/.f64 z y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 t y))) y)))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 z y))))))
#s(approx (+ (* (+ (* x y) z) y) t) (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y z))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 z (+.f64 y (+.f64 (/.f64 t z) (/.f64 (*.f64 x (pow.f64 y #s(literal 2 binary64))) z)))))
#s(approx (+ (* x y) z) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) z))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 x (pow.f64 y #s(literal 2 binary64)))) z))))))
#s(approx (+ (* x y) z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)) #s(literal 1 binary64)))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y (+.f64 z (*.f64 x y))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 t (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t))))
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (+.f64 z (*.f64 x y))) t)) #s(literal 1 binary64)))))
Calls

12 calls:

TimeVariablePointExpression
46.0ms
y
@-inf
((+ (* (+ (* x y) z) y) t) (+ (* x y) z) (* y x) y x t)
1.0ms
x
@-inf
((+ (* (+ (* x y) z) y) t) (+ (* x y) z) (* y x) y x t)
1.0ms
x
@inf
((+ (* (+ (* x y) z) y) t) (+ (* x y) z) (* y x) y x t)
1.0ms
t
@inf
((+ (* (+ (* x y) z) y) t) (+ (* x y) z) (* y x) y x t)
0.0ms
y
@inf
((+ (* (+ (* x y) z) y) t) (+ (* x y) z) (* y x) y x t)

rewrite290.0ms (9.5%)

Memory
30.4MiB live, 261.6MiB allocated; 37ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0927
01227
15227
212627
332827
460527
594327
6362327
0827625
11404825
Stop Event
saturated
node-limit
iter-limit
Counts
6 → 19
Calls
Call 1
Inputs
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
#s(approx (+ (* x y) z) (*.f64 y x))
(*.f64 y x)
y
x
t
Outputs
(neg.f64 (neg.f64 (fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)))
(fma.f64 (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))) (neg.f64 y) t)
(fma.f64 (neg.f64 y) (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))) t)
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
(fma.f64 y #s(approx (+ (* x y) z) (*.f64 y x)) t)
(-.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y) (neg.f64 t))
(-.f64 t (*.f64 (neg.f64 y) #s(approx (+ (* x y) z) (*.f64 y x))))
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y) t)
(+.f64 t (*.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y))
#s(approx (+ (* x y) z) (*.f64 y x))
(neg.f64 (neg.f64 #s(approx (+ (* x y) z) (*.f64 y x))))
(*.f64 (neg.f64 y) (neg.f64 x))
(*.f64 (neg.f64 x) (neg.f64 y))
(*.f64 y x)
(*.f64 x y)
(neg.f64 (*.f64 (neg.f64 y) x))
y
x
t

eval7.0ms (0.2%)

Memory
-32.6MiB live, 12.2MiB allocated; 6ms collecting garbage
Compiler

Compiled 318 to 156 computations (50.9% saved)

prune3.0ms (0.1%)

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

7 alts after pruning (2 fresh and 5 done)

PrunedKeptTotal
New37239
Fresh000
Picked011
Done044
Total37744
Accuracy
100.0%
Counts
44 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (fma.f64 y x z) y t)
73.0%
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
71.3%
(fma.f64 #s(approx (+ (* x y) z) z) y t)
95.3%
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
63.2%
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y (+.f64 z (*.f64 x y))))
34.9%
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y z))
38.7%
#s(approx (+ (* (+ (* x y) z) y) t) t)
Compiler

Compiled 113 to 94 computations (16.8% saved)

regimes27.0ms (0.9%)

Memory
0.1MiB live, 51.4MiB allocated; 11ms collecting garbage
Counts
10 → 1
Calls
Call 1
Inputs
#s(approx (+ (* (+ (* x y) z) y) t) t)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y z))
(fma.f64 #s(approx (+ (* x y) z) z) y t)
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y (+.f64 z (*.f64 x y))))
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y) t)
(fma.f64 (fma.f64 y x z) y t)
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(fma.f64 z y (fma.f64 (*.f64 y y) x t))
Outputs
(fma.f64 (fma.f64 y x z) y t)
Calls

6 calls:

10.0ms
x
3.0ms
t
3.0ms
z
3.0ms
y
3.0ms
(*.f64 (+.f64 (*.f64 x y) z) y)
Results
AccuracySegmentsBranch
100.0%1(*.f64 (+.f64 (*.f64 x y) z) y)
100.0%1(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
100.0%1x
100.0%1y
100.0%1z
100.0%1t
Compiler

Compiled 18 to 31 computations (-72.2% saved)

regimes71.0ms (2.3%)

Memory
-14.7MiB live, 30.9MiB allocated; 3ms collecting garbage
Counts
7 → 3
Calls
Call 1
Inputs
#s(approx (+ (* (+ (* x y) z) y) t) t)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y z))
(fma.f64 #s(approx (+ (* x y) z) z) y t)
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
(fma.f64 #s(approx (+ (* x y) z) (*.f64 y x)) y t)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y (+.f64 z (*.f64 x y))))
(+.f64 (*.f64 #s(approx (+ (* x y) z) (*.f64 x y)) y) t)
Outputs
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y (+.f64 z (*.f64 x y))))
(fma.f64 #s(approx (+ (* x y) z) z) y t)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y (+.f64 z (*.f64 x y))))
Calls

6 calls:

3.0ms
t
2.0ms
z
2.0ms
x
2.0ms
y
2.0ms
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Results
AccuracySegmentsBranch
93.9%3(*.f64 (+.f64 (*.f64 x y) z) y)
93.4%4(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
83.5%3x
92.9%3y
90.4%3z
86.8%3t
Compiler

Compiled 18 to 31 computations (-72.2% saved)

regimes9.0ms (0.3%)

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

4 calls:

2.0ms
z
2.0ms
y
2.0ms
(*.f64 (+.f64 (*.f64 x y) z) y)
2.0ms
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Results
AccuracySegmentsBranch
90.4%3z
87.1%3(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
87.2%3y
87.1%3(*.f64 (+.f64 (*.f64 x y) z) y)
Compiler

Compiled 16 to 23 computations (-43.8% saved)

regimes36.0ms (1.2%)

Memory
-17.2MiB live, 28.7MiB allocated; 4ms collecting garbage
Counts
4 → 1
Calls
Call 1
Inputs
#s(approx (+ (* (+ (* x y) z) y) t) t)
#s(approx (+ (* (+ (* x y) z) y) t) (*.f64 y z))
(fma.f64 #s(approx (+ (* x y) z) z) y t)
(+.f64 (*.f64 #s(approx (+ (* x y) z) z) y) t)
Outputs
(fma.f64 #s(approx (+ (* x y) z) z) y t)
Calls

6 calls:

26.0ms
x
2.0ms
t
2.0ms
z
2.0ms
y
2.0ms
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Results
AccuracySegmentsBranch
71.3%1x
71.3%1t
71.3%1(*.f64 (+.f64 (*.f64 x y) z) y)
71.3%1(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
71.3%1y
71.3%1z
Compiler

Compiled 18 to 31 computations (-72.2% saved)

regimes8.0ms (0.3%)

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

6 calls:

1.0ms
t
1.0ms
z
1.0ms
x
1.0ms
y
1.0ms
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Results
AccuracySegmentsBranch
59.4%3z
51.3%3y
45.7%4x
59.2%3(*.f64 (+.f64 (*.f64 x y) z) y)
51.3%3(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
55.6%3t
Compiler

Compiled 18 to 31 computations (-72.2% saved)

regimes6.0ms (0.2%)

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

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

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

6 calls:

1.0ms
z
1.0ms
x
1.0ms
y
1.0ms
t
1.0ms
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Results
AccuracySegmentsBranch
38.7%1x
38.7%1(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
38.7%1y
38.7%1t
38.7%1(*.f64 (+.f64 (*.f64 x y) z) y)
38.7%1z
Compiler

Compiled 18 to 31 computations (-72.2% saved)

bsearch0.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.344328850167122e+50
7.62523669531209e+55
0.0ms
-1.0062732361617113e+78
-2.483458686176517e+69
Compiler

Compiled 11 to 15 computations (-36.4% saved)

bsearch102.0ms (3.4%)

Memory
-57.7MiB live, 50.6MiB allocated; 25ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
12.0ms
4112119.11823101
1.3432457063260191e+29
47.0ms
-2.26456786165923e+96
-2.3227868465849918e+92
Samples
11.0ms304×0valid
Compiler

Compiled 335 to 376 computations (-12.2% saved)

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

bsearch24.0ms (0.8%)

Memory
18.8MiB live, 64.2MiB allocated; 5ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
13.0ms
2.6425549947249504e+90
8.583013020606217e+108
9.0ms
-26692053303019250.0
-3106539751487.0806
Samples
13.0ms288×0valid
Compiler

Compiled 354 to 393 computations (-11% saved)

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

derivations232.0ms (7.6%)

Memory
14.9MiB live, 108.0MiB allocated; 6ms collecting garbage
Stop Event
fuel
Compiler

Compiled 55 to 42 computations (23.6% saved)

preprocess62.0ms (2%)

Memory
-0.8MiB live, 96.6MiB allocated; 10ms collecting garbage
Compiler

Compiled 63 to 50 computations (20.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...