Diagrams.Solve.Polynomial:quartForm from diagrams-solve-0.1, B

Time bar (total: 2.7s)

start0.0ms (0%)

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

analyze1.0ms (0%)

Memory
0.6MiB live, 0.6MiB 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 15 to 15 computations (0% saved)

sample1.1s (39.1%)

Memory
6.7MiB live, 1 043.8MiB allocated; 345ms collecting garbage
Samples
677.0ms8 253×0valid
0.0ms2valid
0.0ms1valid
Precisions
Click to see histograms. Total time spent on operations: 212.0ms
ival-mult!: 110.0ms (51.8% of total)
ival-div!: 51.0ms (24% of total)
ival-sub!: 26.0ms (12.2% of total)
ival-add!: 24.0ms (11.3% of total)
adjust: 2.0ms (0.9% of total)
Bogosity

preprocess19.0ms (0.7%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
059175
1250175
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
Symmetry

(sort y z)

Compiler

Compiled 26 to 26 computations (0% saved)

series108.0ms (3.9%)

Memory
0.8MiB live, 94.1MiB allocated; 9ms collecting garbage
Counts
13 → 28
Calls
Call 1
Inputs
(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
(/.f64 #s(literal 1 binary64) #s(literal 8 binary64))
#s(literal 1 binary64)
#s(literal 8 binary64)
x
(/.f64 (*.f64 y z) #s(literal 2 binary64))
(*.f64 y z)
y
z
#s(literal 2 binary64)
t
Outputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1/2 binary64) (*.f64 y z)))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (* (/ 1 8) x) (*.f64 #s(literal 1/8 binary64) x))
#s(approx x x)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 x (-.f64 (+.f64 #s(literal 1/8 binary64) (/.f64 t x)) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 x (+.f64 #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) x)) #s(literal 1/8 binary64)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)) #s(literal 1/8 binary64)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (/ (* y z) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 y z)))
#s(approx (* y z) (*.f64 y z))
#s(approx y y)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 y (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x y) (/.f64 t y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx z z)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 z (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x z) (/.f64 t z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx t t)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 t (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (/.f64 x t))) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) t)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) t)) #s(literal 1 binary64)))))
Calls

12 calls:

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

rewrite159.0ms (5.8%)

Memory
-43.4MiB live, 114.1MiB allocated; 55ms collecting garbage
Counts
13 → 34
Calls
Call 1
Inputs
(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
(/.f64 #s(literal 1 binary64) #s(literal 8 binary64))
#s(literal 1 binary64)
#s(literal 8 binary64)
x
(/.f64 (*.f64 y z) #s(literal 2 binary64))
(*.f64 y z)
y
z
#s(literal 2 binary64)
t
Outputs
(+.f64 (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 (*.f64 y z) #s(literal 1/2 binary64))) t)
(+.f64 t (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 (*.f64 y z) #s(literal 1/2 binary64))))
(-.f64 (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 (*.f64 y z) #s(literal 1/2 binary64))) (neg.f64 t))
(-.f64 (*.f64 #s(literal 1/8 binary64) x) (-.f64 (*.f64 (*.f64 y z) #s(literal 1/2 binary64)) t))
(+.f64 (*.f64 #s(literal 1/8 binary64) x) (neg.f64 (*.f64 (*.f64 y z) #s(literal 1/2 binary64))))
(-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 (*.f64 y z) #s(literal 1/2 binary64)))
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/8 binary64) x) #s(literal 2 binary64)) (*.f64 y z)) #s(literal 2 binary64))
(fma.f64 #s(literal 1/8 binary64) x (neg.f64 (*.f64 (*.f64 y z) #s(literal 1/2 binary64))))
(fma.f64 x #s(literal 1/8 binary64) (neg.f64 (*.f64 (*.f64 y z) #s(literal 1/2 binary64))))
(neg.f64 (-.f64 (*.f64 (*.f64 y z) #s(literal 1/2 binary64)) (*.f64 #s(literal 1/8 binary64) x)))
(*.f64 #s(literal 1/8 binary64) x)
(*.f64 x #s(literal 1/8 binary64))
(/.f64 (*.f64 #s(literal 1 binary64) x) #s(literal 8 binary64))
#s(literal 1/8 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1/8 binary64))
(/.f64 #s(literal 1 binary64) #s(literal 8 binary64))
(/.f64 #s(literal -1 binary64) #s(literal -8 binary64))
(pow.f64 #s(literal 8 binary64) #s(literal -1 binary64))
#s(literal 1 binary64)
(cosh.f64 #s(literal 0 binary64))
(exp.f64 #s(literal 0 binary64))
#s(literal 8 binary64)
x
(*.f64 (*.f64 y z) #s(literal 1/2 binary64))
(*.f64 y (/.f64 z #s(literal 2 binary64)))
(/.f64 (*.f64 y z) #s(literal 2 binary64))
(/.f64 (neg.f64 (*.f64 y z)) #s(literal -2 binary64))
(*.f64 y z)
(*.f64 z y)
y
z
#s(literal 2 binary64)
(+.f64 #s(literal 1 binary64) #s(literal 1 binary64))
t

eval5.0ms (0.2%)

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

Compiled 960 to 232 computations (75.8% saved)

prune3.0ms (0.1%)

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

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New48452
Fresh000
Picked101
Done000
Total49453
Accuracy
100.0%
Counts
53 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
88.5%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))) t)
67.0%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
67.2%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
Compiler

Compiled 87 to 75 computations (13.8% saved)

series150.0ms (5.5%)

Memory
13.1MiB live, 152.9MiB allocated; 27ms collecting garbage
Counts
24 → 54
Calls
Call 1
Inputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
(+.f64 t (*.f64 #s(literal 1/8 binary64) x))
t
(*.f64 #s(literal 1/8 binary64) x)
#s(literal 1/8 binary64)
x
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
(-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z)))
(*.f64 #s(literal 1/2 binary64) (*.f64 y z))
#s(literal 1/2 binary64)
(*.f64 y z)
y
z
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))))
(*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))
(-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))
(*.f64 #s(literal 1/8 binary64) (/.f64 x z))
(/.f64 x z)
(*.f64 #s(literal 1/2 binary64) y)
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)))
(fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))
#s(literal -1/2 binary64)
Outputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ t (* 1/8 x)) t)
#s(approx (+ t (* 1/8 x)) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (* 1/8 x) (*.f64 #s(literal 1/8 binary64) x))
#s(approx x x)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1/2 binary64) (*.f64 y z)))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))
#s(approx (* 1/8 (/ x z)) (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))
#s(approx (/ x z) (/.f64 x z))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 x (-.f64 (+.f64 #s(literal 1/8 binary64) (/.f64 t x)) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (+ t (* 1/8 x)) (*.f64 x (+.f64 #s(literal 1/8 binary64) (/.f64 t x))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 x (+.f64 #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 x (fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (*.f64 #s(literal 1/8 binary64) (/.f64 #s(literal 1 binary64) z)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) x)) #s(literal 1/8 binary64)))))
#s(approx (+ t (* 1/8 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 t x)) #s(literal 1/8 binary64)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)) #s(literal 1/8 binary64)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) (/.f64 y x)) (*.f64 #s(literal 1/8 binary64) (/.f64 #s(literal 1 binary64) z))))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))))
#s(approx (- t (* 1/2 (* y z))) (+.f64 t (*.f64 #s(literal -1/2 binary64) (*.f64 y z))))
#s(approx (* 1/2 (* y z)) (*.f64 #s(literal 1/2 binary64) (*.f64 y z)))
#s(approx (* y z) (*.f64 y z))
#s(approx y y)
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z))))
#s(approx (* 1/2 y) (*.f64 #s(literal 1/2 binary64) y))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 y (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x y) (/.f64 t y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (- t (* 1/2 (* y z))) (*.f64 y (-.f64 (/.f64 t y) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 y (fma.f64 #s(literal -1/2 binary64) z (*.f64 #s(literal 1/8 binary64) (/.f64 x y)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x (*.f64 y z))) #s(literal 1/2 binary64))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (- t (* 1/2 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 t y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1/8 binary64) (/.f64 x y) (*.f64 #s(literal 1/2 binary64) z)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1 binary64) (*.f64 y (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/8 binary64) (/.f64 x (*.f64 y z)))))))
#s(approx z z)
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (/.f64 (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)) z))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 z (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x z) (/.f64 t z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (- t (* 1/2 (* y z))) (*.f64 z (-.f64 (/.f64 t z) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 z (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (- t (* 1/2 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 t z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1/8 binary64) (/.f64 x z) (*.f64 #s(literal 1/2 binary64) y)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 t (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (/.f64 x t))) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) t)))))
#s(approx (+ t (* 1/8 x)) (*.f64 t (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (/.f64 x t)))))
#s(approx (- t (* 1/2 (* y z))) (*.f64 t (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (/.f64 (*.f64 y z) t)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) t)) #s(literal 1 binary64)))))
#s(approx (+ t (* 1/8 x)) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x t)) #s(literal 1 binary64)))))
#s(approx (- t (* 1/2 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) t)) #s(literal 1 binary64)))))
Calls

12 calls:

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

rewrite175.0ms (6.4%)

Memory
-18.7MiB live, 117.1MiB allocated; 50ms collecting garbage
Counts
24 → 25
Calls
Call 1
Inputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
(+.f64 t (*.f64 #s(literal 1/8 binary64) x))
t
(*.f64 #s(literal 1/8 binary64) x)
#s(literal 1/8 binary64)
x
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
(-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z)))
(*.f64 #s(literal 1/2 binary64) (*.f64 y z))
#s(literal 1/2 binary64)
(*.f64 y z)
y
z
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))))
(*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))
(-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))
(*.f64 #s(literal 1/8 binary64) (/.f64 x z))
(/.f64 x z)
(*.f64 #s(literal 1/2 binary64) y)
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)))
(fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))
#s(literal -1/2 binary64)
Outputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
(+.f64 t (*.f64 #s(literal 1/8 binary64) x))
t
(*.f64 #s(literal 1/8 binary64) x)
#s(literal 1/8 binary64)
x
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
(-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z)))
(*.f64 #s(literal 1/2 binary64) (*.f64 y z))
#s(literal 1/2 binary64)
(*.f64 y z)
y
z
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))))
(*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))
(-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))
(*.f64 #s(literal 1/8 binary64) (/.f64 x z))
(/.f64 x z)
(*.f64 #s(literal 1/2 binary64) y)
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)))
(+.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 y z)) (*.f64 #s(literal 1/8 binary64) x))
(fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))
#s(literal -1/2 binary64)

eval6.0ms (0.2%)

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

Compiled 1 789 to 335 computations (81.3% saved)

prune4.0ms (0.2%)

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

6 alts after pruning (3 fresh and 3 done)

PrunedKeptTotal
New58361
Fresh000
Picked134
Done000
Total59665
Accuracy
100.0%
Counts
65 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
88.5%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))) t)
67.3%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))) t)
67.0%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
67.2%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
34.9%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) #s(approx (+ t (* 1/8 x)) t))
Compiler

Compiled 146 to 123 computations (15.8% saved)

series129.0ms (4.7%)

Memory
-0.7MiB live, 144.4MiB allocated; 30ms collecting garbage
Counts
20 → 44
Calls
Call 1
Inputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) #s(approx (+ t (* 1/8 x)) t))
#s(approx (+ t (* 1/8 x)) t)
t
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y))))
(*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))
z
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y))
(*.f64 #s(literal -1/2 binary64) y)
#s(literal -1/2 binary64)
y
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z))))))
(*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z))))
(fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))
(*.f64 #s(literal 1/8 binary64) (/.f64 x z))
#s(literal 1/8 binary64)
(/.f64 x z)
x
Outputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ t (* 1/8 x)) t)
#s(approx (+ t (* 1/8 x)) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1/2 binary64) (*.f64 y z)))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y)))
#s(approx (+ (* -1/2 y) (* 1/8 (/ x z))) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z))))
#s(approx (* 1/8 (/ x z)) (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))
#s(approx (/ x z) (/.f64 x z))
#s(approx x x)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal 1/8 binary64) x))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 x (-.f64 (+.f64 #s(literal 1/8 binary64) (/.f64 t x)) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (+ t (* 1/8 x)) (*.f64 x (+.f64 #s(literal 1/8 binary64) (/.f64 t x))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 x (+.f64 #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 x (fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (*.f64 #s(literal 1/8 binary64) (/.f64 #s(literal 1 binary64) z)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) x)) #s(literal 1/8 binary64)))))
#s(approx (+ t (* 1/8 x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 t x)) #s(literal 1/8 binary64)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)) #s(literal 1/8 binary64)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) (/.f64 y x)) (*.f64 #s(literal 1/8 binary64) (/.f64 #s(literal 1 binary64) z))))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))))
#s(approx y y)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 y (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x y) (/.f64 t y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 y (fma.f64 #s(literal -1/2 binary64) z (*.f64 #s(literal 1/8 binary64) (/.f64 x y)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x (*.f64 y z))) #s(literal 1/2 binary64))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1/8 binary64) (/.f64 x y) (*.f64 #s(literal 1/2 binary64) z)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1 binary64) (*.f64 y (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/8 binary64) (/.f64 x (*.f64 y z)))))))
#s(approx z z)
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (/.f64 (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x)) z))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 z (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x z) (/.f64 t z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z (-.f64 (*.f64 #s(literal 1/8 binary64) (/.f64 x z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 z (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (* z (- (* 1/8 (/ x z)) (* 1/2 y))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1/8 binary64) (/.f64 x z) (*.f64 #s(literal 1/2 binary64) y)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 t (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (/.f64 x t))) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) t)))))
#s(approx (+ t (* 1/8 x)) (*.f64 t (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (/.f64 x t)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) t)) #s(literal 1 binary64)))))
#s(approx (+ t (* 1/8 x)) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1/8 binary64) (/.f64 x t)) #s(literal 1 binary64)))))
Calls

12 calls:

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

rewrite184.0ms (6.7%)

Memory
-7.2MiB live, 223.6MiB allocated; 56ms collecting garbage
Counts
20 → 42
Calls
Call 1
Inputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) #s(approx (+ t (* 1/8 x)) t))
#s(approx (+ t (* 1/8 x)) t)
t
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y))))
(*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))
z
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y))
(*.f64 #s(literal -1/2 binary64) y)
#s(literal -1/2 binary64)
y
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))) t)
#s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z))))))
(*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))
#s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z))))
(fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))
(*.f64 #s(literal 1/8 binary64) (/.f64 x z))
#s(literal 1/8 binary64)
(/.f64 x z)
x
Outputs
#s(approx (- (* 1/8 x) (- (* (* y z) 1/2) t)) #s(approx (+ (* 1/8 x) t) t))
#s(approx (+ (* 1/8 x) t) t)
t
(+.f64 #s(approx (- (* 1/8 x) (* (* y z) 1/2)) (*.f64 z #s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))) t)
#s(approx (- (* 1/8 x) (* (* y z) 1/2)) (*.f64 z #s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (*.f64 #s(literal -1/2 binary64) y))))
(*.f64 z #s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))
z
#s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (*.f64 #s(literal -1/2 binary64) y))
(*.f64 #s(literal -1/2 binary64) y)
(*.f64 y #s(literal -1/2 binary64))
#s(literal -1/2 binary64)
(neg.f64 #s(literal 1/2 binary64))
y
(+.f64 #s(approx (- (* 1/8 x) (* (* y z) 1/2)) (*.f64 z #s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (fma.f64 (/.f64 x z) #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) y))))) t)
#s(approx (- (* 1/8 x) (* (* y z) 1/2)) (*.f64 z #s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (fma.f64 (/.f64 x z) #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) y)))))
(*.f64 z #s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (fma.f64 (/.f64 x z) #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) y))))
#s(approx (+ (/ (* 1/8 x) z) (* -1/2 y)) (fma.f64 (/.f64 x z) #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) y)))
(+.f64 (/.f64 (*.f64 #s(literal 1/8 binary64) x) z) (neg.f64 (*.f64 #s(literal 1/2 binary64) y)))
(+.f64 (/.f64 (*.f64 #s(literal 1/8 binary64) x) z) (*.f64 #s(literal -1/2 binary64) y))
(+.f64 (*.f64 #s(literal -1/2 binary64) y) (/.f64 (*.f64 #s(literal 1/8 binary64) x) z))
(-.f64 (/.f64 (*.f64 #s(literal 1/8 binary64) x) z) (*.f64 #s(literal 1/2 binary64) y))
(-.f64 (*.f64 #s(literal -1/2 binary64) y) (*.f64 #s(literal -1/8 binary64) (/.f64 x z)))
(-.f64 (*.f64 #s(literal -1/2 binary64) y) (neg.f64 (/.f64 (*.f64 #s(literal 1/8 binary64) x) z)))
(fma.f64 (/.f64 x z) #s(literal 1/8 binary64) (*.f64 #s(literal -1/2 binary64) y))
(fma.f64 #s(literal 1/8 binary64) (/.f64 x z) (*.f64 #s(literal -1/2 binary64) y))
(fma.f64 #s(literal -1/2 binary64) y (/.f64 (*.f64 #s(literal 1/8 binary64) x) z))
(fma.f64 #s(literal 1/8 binary64) (/.f64 x z) (neg.f64 (*.f64 #s(literal 1/2 binary64) y)))
(fma.f64 (/.f64 x z) #s(literal 1/8 binary64) (neg.f64 (*.f64 #s(literal 1/2 binary64) y)))
(fma.f64 y #s(literal -1/2 binary64) (/.f64 (*.f64 #s(literal 1/8 binary64) x) z))
(neg.f64 (-.f64 (*.f64 #s(literal 1/2 binary64) y) (/.f64 (*.f64 #s(literal 1/8 binary64) x) z)))
(*.f64 #s(literal 1/8 binary64) (/.f64 x z))
(*.f64 (/.f64 x z) #s(literal 1/8 binary64))
(/.f64 (*.f64 #s(literal 1/8 binary64) x) z)
#s(literal 1/8 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1/8 binary64))
(/.f64 #s(literal 1 binary64) #s(literal 8 binary64))
(/.f64 #s(literal -1 binary64) #s(literal -8 binary64))
(pow.f64 #s(literal 8 binary64) #s(literal -1 binary64))
(*.f64 x (/.f64 #s(literal 1 binary64) z))
(/.f64 x z)
(/.f64 (neg.f64 x) (neg.f64 z))
x

eval8.0ms (0.3%)

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

Compiled 2 467 to 430 computations (82.6% saved)

prune4.0ms (0.2%)

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

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New76177
Fresh000
Picked033
Done033
Total76783
Accuracy
100.0%
Counts
83 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
88.5%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))) t)
67.3%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))) t)
67.0%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
67.2%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
34.7%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal 1/8 binary64) x))
34.9%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) #s(approx (+ t (* 1/8 x)) t))
Compiler

Compiled 163 to 139 computations (14.7% saved)

series218.0ms (7.9%)

Memory
-34.9MiB live, 78.0MiB allocated; 187ms collecting garbage
Counts
4 → 17
Calls
Call 1
Inputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal 1/8 binary64) x))
(*.f64 #s(literal 1/8 binary64) x)
#s(literal 1/8 binary64)
x
Outputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (* 1/8 x) (*.f64 #s(literal 1/8 binary64) x))
#s(approx x x)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 x (-.f64 (+.f64 #s(literal 1/8 binary64) (/.f64 t x)) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) x)) #s(literal 1/8 binary64)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1/2 binary64) (*.f64 y z)))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 y (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x y) (/.f64 t y)) (*.f64 #s(literal 1/2 binary64) z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) y)) (*.f64 #s(literal -1/2 binary64) z)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 z (-.f64 (fma.f64 #s(literal 1/8 binary64) (/.f64 x z) (/.f64 t z)) (*.f64 #s(literal 1/2 binary64) y))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 t (*.f64 #s(literal 1/8 binary64) x)) z)) (*.f64 #s(literal -1/2 binary64) y)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) t)
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 t (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (/.f64 x t))) (*.f64 #s(literal 1/2 binary64) (/.f64 (*.f64 y z) t)))))
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))) t)) #s(literal 1 binary64)))))
Calls

12 calls:

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

rewrite152.0ms (5.5%)

Memory
1.7MiB live, 91.7MiB allocated; 47ms collecting garbage
Counts
4 → 10
Calls
Call 1
Inputs
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal 1/8 binary64) x))
(*.f64 #s(literal 1/8 binary64) x)
#s(literal 1/8 binary64)
x
Outputs
#s(approx (- (* 1/8 x) (- (* (* y z) 1/2) t)) (*.f64 #s(literal 1/8 binary64) x))
(*.f64 #s(literal 1/8 binary64) x)
(*.f64 x #s(literal 1/8 binary64))
(/.f64 (*.f64 #s(literal 1 binary64) x) #s(literal 8 binary64))
#s(literal 1/8 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1/8 binary64))
(/.f64 #s(literal 1 binary64) #s(literal 8 binary64))
(/.f64 #s(literal -1 binary64) #s(literal -8 binary64))
(pow.f64 #s(literal 8 binary64) #s(literal -1 binary64))
x

eval3.0ms (0.1%)

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

Compiled 515 to 119 computations (76.9% saved)

prune4.0ms (0.1%)

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

9 alts after pruning (2 fresh and 7 done)

PrunedKeptTotal
New20222
Fresh000
Picked011
Done066
Total20929
Accuracy
100.0%
Counts
29 → 9
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (fma.f64 #s(literal -1/2 binary64) (*.f64 y z) (*.f64 #s(literal 1/8 binary64) x))) t)
88.5%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (fma.f64 #s(literal -1/2 binary64) y (*.f64 #s(literal 1/8 binary64) (/.f64 x z)))))) t)
67.3%
(+.f64 #s(approx (- (* (/ 1 8) x) (/ (* y z) 2)) (*.f64 z #s(approx (- (* 1/8 (/ x z)) (* 1/2 y)) (*.f64 #s(literal -1/2 binary64) y)))) t)
67.4%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 (*.f64 #s(literal 1/8 binary64) x) (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
67.0%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (-.f64 t (*.f64 #s(literal 1/2 binary64) (*.f64 y z))))
67.2%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (+.f64 t (*.f64 #s(literal 1/8 binary64) x)))
34.7%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal 1/8 binary64) x))
34.8%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) (*.f64 #s(literal -1/2 binary64) (*.f64 y z)))
34.9%
#s(approx (+ (- (* (/ 1 8) x) (/ (* y z) 2)) t) #s(approx (+ t (* 1/8 x)) t))
Compiler

Compiled 205 to 176 computations (14.1% saved)

regimes203.0ms (7.4%)

Memory
-18.1MiB live, 317.4MiB allocated; 74ms collecting garbage
Accuracy

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

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

52 calls:

24.0ms
z
20.0ms
y
16.0ms
y
7.0ms
(*.f64 y z)
4.0ms
(*.f64 y z)
Results
AccuracySegmentsBranch
34.9%1y
34.9%1(*.f64 y z)
34.9%1(/.f64 (*.f64 y z) #s(literal 2 binary64))
34.9%1(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
34.9%1z
34.9%1(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
34.9%1(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
34.9%1x
34.9%1t
39.9%3(*.f64 y z)
39.9%3(/.f64 (*.f64 y z) #s(literal 2 binary64))
53.2%3(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
53.2%3x
36.6%2y
50.5%3(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
41.8%4(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
56.2%3t
41.2%3z
67.2%1(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
67.2%1z
67.2%1y
67.2%1(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
67.2%1x
67.2%1(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
67.2%1(*.f64 y z)
67.2%1(/.f64 (*.f64 y z) #s(literal 2 binary64))
80.9%3z
67.2%1t
86.4%3(*.f64 y z)
86.4%3(/.f64 (*.f64 y z) #s(literal 2 binary64))
90.9%3(*.f64 y z)
90.9%3(/.f64 (*.f64 y z) #s(literal 2 binary64))
91.3%3(*.f64 y z)
91.3%3(/.f64 (*.f64 y z) #s(literal 2 binary64))
92.4%3(*.f64 y z)
92.4%3(/.f64 (*.f64 y z) #s(literal 2 binary64))
86.3%3(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
86.4%3(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
82.6%5(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
86.3%3x
82.5%3y
86.7%3z
88.6%3t
99.7%1(*.f64 y z)
99.7%1(/.f64 (*.f64 y z) #s(literal 2 binary64))
99.7%1(*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x)
99.7%1(-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64)))
99.7%1(+.f64 (-.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 8 binary64)) x) (/.f64 (*.f64 y z) #s(literal 2 binary64))) t)
99.7%1x
99.7%1y
99.7%1z
99.7%1t
Compiler

Compiled 473 to 411 computations (13.1% saved)

bsearch1.0ms (0%)

Memory
1.5MiB live, 1.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
3.969275398392706e+35
1.0102578018060599e+39
0.0ms
-1.6371729006798225e+34
-2.0815713756707897e+33
Compiler

Compiled 16 to 20 computations (-25% saved)

bsearch0.0ms (0%)

Memory
1.2MiB live, 1.2MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
3.3395307581636776e+29
1.966671411842075e+31
0.0ms
-1.6371729006798225e+34
-2.0815713756707897e+33
Compiler

Compiled 16 to 20 computations (-25% saved)

bsearch0.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
3.3395307581636776e+29
1.966671411842075e+31
0.0ms
-1.6371729006798225e+34
-2.0815713756707897e+33
Compiler

Compiled 16 to 20 computations (-25% saved)

bsearch1.0ms (0%)

Memory
1.5MiB live, 1.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
4.913636451001132e+79
1.4494525493852786e+82
0.0ms
-1.6371729006798225e+34
-2.0815713756707897e+33
Compiler

Compiled 16 to 20 computations (-25% saved)

bsearch55.0ms (2%)

Memory
4.8MiB live, 48.4MiB allocated; 30ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
49.0ms
5.8670568181724695e-87
8.939513210715797e-84
4.0ms
-0.00014342181078479815
-0.00011324782493073114
Samples
31.0ms176×0valid
Compiler

Compiled 434 to 416 computations (4.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 4.0ms
ival-mult!: 2.0ms (45.6% of total)
ival-sub!: 1.0ms (22.8% of total)
ival-div!: 1.0ms (22.8% of total)
adjust: 0.0ms (0% of total)
ival-add!: 0.0ms (0% of total)

derivations3.0ms (0.1%)

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

Compiled 443 to 70 computations (84.2% saved)

preprocess79.0ms (2.9%)

Memory
-1.7MiB live, 137.7MiB allocated; 39ms collecting garbage
Remove

(sort y z)

Compiler

Compiled 1 342 to 511 computations (61.9% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...