Data.Colour.RGBSpace.HSV:hsv from colour-2.3.3, I

Time bar (total: 2.5s)

start0.0ms (0%)

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

analyze0.0ms (0%)

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

Compiled 9 to 9 computations (0% saved)

sample846.0ms (33.6%)

Memory
-19.7MiB live, 685.2MiB allocated; 282ms collecting garbage
Samples
593.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 198.0ms
ival-mult!: 149.0ms (75.3% of total)
ival-sub!: 47.0ms (23.8% of total)
adjust: 2.0ms (1% of total)
Bogosity

preprocess69.0ms (2.7%)

Memory
2.6MiB live, 47.5MiB allocated; 7ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02973
19072
223370
356770
4312670
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
95.9%
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
Symmetry

(negabs x)

(sort y z)

Compiler

Compiled 14 to 14 computations (0% saved)

series83.0ms (3.3%)

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

9 calls:

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

rewrite190.0ms (7.6%)

Memory
-9.4MiB live, 180.1MiB allocated; 56ms collecting garbage
Counts
7 → 14
Calls
Call 1
Inputs
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
x
(-.f64 #s(literal 1 binary64) (*.f64 y z))
#s(literal 1 binary64)
(*.f64 y z)
y
z
Outputs
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
(*.f64 (-.f64 #s(literal 1 binary64) (*.f64 y z)) x)
x
(+.f64 #s(literal 1 binary64) (neg.f64 (*.f64 y z)))
(+.f64 #s(literal 1 binary64) (*.f64 (neg.f64 y) z))
(-.f64 #s(literal 1 binary64) (*.f64 y z))
(neg.f64 (-.f64 (*.f64 y z) #s(literal 1 binary64)))
#s(literal 1 binary64)
(cosh.f64 #s(literal 0 binary64))
(exp.f64 #s(literal 0 binary64))
(*.f64 y z)
(*.f64 z y)
y
z

eval3.0ms (0.1%)

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

Compiled 314 to 96 computations (69.4% saved)

prune2.0ms (0.1%)

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

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New21425
Fresh000
Picked011
Done000
Total21526
Accuracy
100.0%
Counts
26 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
95.9%
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
47.2%
(*.f64 x #s(approx (- 1 (* y z)) #s(literal 1 binary64)))
95.9%
#s(approx (* x (- 1 (* y z))) (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))))
82.3%
#s(approx (* x (- 1 (* y z))) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z))))
83.5%
#s(approx (* x (- 1 (* y z))) (*.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y))))
Compiler

Compiled 69 to 55 computations (20.3% saved)

series141.0ms (5.6%)

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

9 calls:

TimeVariablePoint
12.0ms
z
0
5.0ms
x
0
4.0ms
x
-inf
4.0ms
z
-inf
4.0ms
z
inf

rewrite184.0ms (7.3%)

Memory
22.8MiB live, 119.9MiB allocated; 29ms collecting garbage
Counts
22 → 67
Calls
Call 1
Inputs
#s(approx (* x (- 1 (* y z))) (*.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y))))
(*.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y)))
y
(fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y))
#s(literal -1 binary64)
(*.f64 x z)
x
z
(/.f64 x y)
#s(approx (* x (- 1 (* y z))) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z))))
(*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z)))
(fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z))
(*.f64 x y)
(/.f64 x z)
#s(approx (* x (- 1 (* y z))) (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))))
(+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z))))
(*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))
(*.f64 x (*.f64 y z))
(*.f64 y z)
(*.f64 x #s(approx (- 1 (* y z)) #s(literal 1 binary64)))
#s(approx (- 1 (* y z)) #s(literal 1 binary64))
#s(literal 1 binary64)
Outputs
#s(approx (* x (- 1 (* y z))) (*.f64 y (+.f64 (neg.f64 (*.f64 x z)) (/.f64 x y))))
(*.f64 y (+.f64 (neg.f64 (*.f64 x z)) (/.f64 x y)))
(*.f64 (+.f64 (neg.f64 (*.f64 x z)) (/.f64 x y)) y)
(+.f64 (*.f64 (neg.f64 (*.f64 x z)) y) (*.f64 (/.f64 x y) y))
(+.f64 (*.f64 y (neg.f64 (*.f64 x z))) (*.f64 y (/.f64 x y)))
(fma.f64 (neg.f64 (*.f64 x z)) y (*.f64 (/.f64 x y) y))
(fma.f64 y (neg.f64 (*.f64 x z)) (*.f64 y (/.f64 x y)))
y
(+.f64 (neg.f64 (*.f64 x z)) (/.f64 x y))
(+.f64 (/.f64 x y) (neg.f64 (*.f64 x z)))
(-.f64 (neg.f64 (*.f64 x z)) (neg.f64 (/.f64 x y)))
(/.f64 (fma.f64 (neg.f64 (*.f64 x z)) y x) y)
(fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y))
(fma.f64 (*.f64 #s(literal -1 binary64) x) z (/.f64 x y))
(fma.f64 (*.f64 x z) #s(literal -1 binary64) (/.f64 x y))
(fma.f64 x (/.f64 #s(literal 1 binary64) y) (neg.f64 (*.f64 x z)))
#s(literal -1 binary64)
(*.f64 x z)
(*.f64 z x)
x
z
(*.f64 x (/.f64 #s(literal 1 binary64) y))
(/.f64 x y)
(/.f64 (neg.f64 x) (neg.f64 y))
#s(approx (* x (- 1 (* y z))) (*.f64 z (+.f64 (neg.f64 (*.f64 x y)) (/.f64 x z))))
(*.f64 z (+.f64 (neg.f64 (*.f64 x y)) (/.f64 x z)))
(*.f64 (+.f64 (neg.f64 (*.f64 x y)) (/.f64 x z)) z)
(+.f64 (*.f64 (neg.f64 (*.f64 x y)) z) (*.f64 (/.f64 x z) z))
(+.f64 (*.f64 z (neg.f64 (*.f64 x y))) (*.f64 z (/.f64 x z)))
(fma.f64 (neg.f64 (*.f64 x y)) z (*.f64 (/.f64 x z) z))
(fma.f64 z (neg.f64 (*.f64 x y)) (*.f64 z (/.f64 x z)))
(+.f64 (neg.f64 (*.f64 x y)) (/.f64 x z))
(+.f64 (/.f64 x z) (neg.f64 (*.f64 x y)))
(-.f64 (neg.f64 (*.f64 x y)) (neg.f64 (/.f64 x z)))
(/.f64 (fma.f64 (neg.f64 (*.f64 x y)) z x) z)
(fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z))
(fma.f64 (*.f64 #s(literal -1 binary64) x) y (/.f64 x z))
(fma.f64 (*.f64 x y) #s(literal -1 binary64) (/.f64 x z))
(fma.f64 x (/.f64 #s(literal 1 binary64) z) (neg.f64 (*.f64 x y)))
(*.f64 x y)
(*.f64 y x)
(*.f64 x (/.f64 #s(literal 1 binary64) z))
(/.f64 x z)
(/.f64 (neg.f64 x) (neg.f64 z))
#s(approx (* x (- 1 (* y z))) (+.f64 x (neg.f64 (*.f64 x (*.f64 y z)))))
(+.f64 x (neg.f64 (*.f64 x (*.f64 y z))))
(+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x)
(-.f64 x (neg.f64 (neg.f64 (*.f64 x (*.f64 y z)))))
(-.f64 x (*.f64 #s(literal 1 binary64) (*.f64 x (*.f64 y z))))
(fma.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 y z) x)
(fma.f64 (*.f64 x (*.f64 y z)) #s(literal -1 binary64) x)
(fma.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)) x)
(*.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 y z))
(*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))
(*.f64 (*.f64 x (*.f64 y z)) #s(literal -1 binary64))
(neg.f64 (*.f64 x (*.f64 y z)))
(*.f64 x (*.f64 y z))
(*.f64 (*.f64 x y) z)
(*.f64 (*.f64 y z) x)
(*.f64 y z)
(*.f64 z y)
(*.f64 x #s(approx (- 1 (* y z)) #s(literal 1 binary64)))
#s(approx (- 1 (* y z)) #s(literal 1 binary64))
#s(literal 1 binary64)
(cosh.f64 #s(literal 0 binary64))
(exp.f64 #s(literal 0 binary64))
(neg.f64 #s(literal -1 binary64))

eval27.0ms (1.1%)

Memory
-26.0MiB live, 19.9MiB allocated; 22ms collecting garbage
Compiler

Compiled 1 983 to 379 computations (80.9% saved)

prune4.0ms (0.1%)

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

5 alts after pruning (3 fresh and 2 done)

PrunedKeptTotal
New94397
Fresh000
Picked314
Done011
Total975102
Accuracy
100.0%
Counts
102 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
95.9%
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
47.2%
(*.f64 x #s(approx (- 1 (* y z)) #s(literal 1 binary64)))
95.9%
#s(approx (* x (- 1 (* y z))) (+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x))
50.0%
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))))
50.5%
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))))
Compiler

Compiled 82 to 64 computations (22% saved)

series133.0ms (5.3%)

Memory
22.9MiB live, 68.6MiB allocated; 13ms collecting garbage
Counts
19 → 39
Calls
Call 1
Inputs
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))))
(*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z))))
y
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
(*.f64 #s(literal -1 binary64) (*.f64 x z))
#s(literal -1 binary64)
(*.f64 x z)
x
z
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))))
(*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))
(*.f64 #s(literal -1 binary64) (*.f64 x y))
(*.f64 x y)
#s(approx (* x (- 1 (* y z))) (+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x))
(+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x)
(neg.f64 (*.f64 x (*.f64 y z)))
(*.f64 x (*.f64 y z))
(*.f64 y z)
Outputs
#s(approx (* x (- 1 (* y z))) (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z))))
#s(approx (* y (+ (* -1 (* x z)) (/ x y))) (*.f64 x (*.f64 y (fma.f64 #s(literal -1 binary64) z (/.f64 #s(literal 1 binary64) y)))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 x (fma.f64 #s(literal -1 binary64) z (/.f64 #s(literal 1 binary64) y))))
#s(approx (* -1 (* x z)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
#s(approx (* x z) (*.f64 x z))
#s(approx x x)
#s(approx (* z (+ (* -1 (* x y)) (/ x z))) (*.f64 x (*.f64 z (fma.f64 #s(literal -1 binary64) y (/.f64 #s(literal 1 binary64) z)))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 #s(literal 1 binary64) z))))
#s(approx (* -1 (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))
#s(approx (* x y) (*.f64 x y))
#s(approx (neg (* x (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z))))
#s(approx (* x (* y z)) (*.f64 x (*.f64 y z)))
#s(approx (* y (+ (* -1 (* x z)) (/ x y))) (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y (-.f64 z (/.f64 #s(literal 1 binary64) y))))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 z (/.f64 #s(literal 1 binary64) y)))))
#s(approx (* z (+ (* -1 (* x y)) (/ x z))) (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 z (-.f64 y (/.f64 #s(literal 1 binary64) z))))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 y (/.f64 #s(literal 1 binary64) z)))))
#s(approx (+ (neg (* x (* y z))) x) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (*.f64 y z)))))
#s(approx (* x (- 1 (* y z))) (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))))
#s(approx y y)
#s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))
#s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))) y))
#s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))
#s(approx (+ (* -1 (* x y)) (/ x z)) (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z)))
#s(approx (* y z) (*.f64 y z))
#s(approx (* x (- 1 (* y z))) (*.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y)))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 y (fma.f64 #s(literal -1 binary64) x (/.f64 x (*.f64 y z)))))
#s(approx (+ (neg (* x (* y z))) x) (*.f64 y (-.f64 (/.f64 x y) (*.f64 x z))))
#s(approx (* x (- 1 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (/.f64 x y) (*.f64 x z)))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 y (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 x (*.f64 y z)))))))
#s(approx (+ (neg (* x (* y z))) x) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z))))))
#s(approx z z)
#s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))) z))
#s(approx (* x (- 1 (* y z))) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 z (fma.f64 #s(literal -1 binary64) x (/.f64 x (*.f64 y z)))))
#s(approx (+ (neg (* x (* y z))) x) (*.f64 z (-.f64 (/.f64 x z) (*.f64 x y))))
#s(approx (* x (- 1 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (/.f64 x z) (*.f64 x y)))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 x (*.f64 y z)))))))
#s(approx (+ (neg (* x (* y z))) x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y))))))
Calls

9 calls:

TimeVariablePoint
19.0ms
z
0
4.0ms
z
inf
4.0ms
z
-inf
3.0ms
x
-inf
2.0ms
x
inf

rewrite242.0ms (9.6%)

Memory
-34.3MiB live, 96.8MiB allocated; 213ms collecting garbage
Counts
19 → 36
Calls
Call 1
Inputs
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))))
(*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z))))
y
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
(*.f64 #s(literal -1 binary64) (*.f64 x z))
#s(literal -1 binary64)
(*.f64 x z)
x
z
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))))
(*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))
(*.f64 #s(literal -1 binary64) (*.f64 x y))
(*.f64 x y)
#s(approx (* x (- 1 (* y z))) (+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x))
(+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x)
(neg.f64 (*.f64 x (*.f64 y z)))
(*.f64 x (*.f64 y z))
(*.f64 y z)
Outputs
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (neg (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))))
(*.f64 y #s(approx (+ (neg (* x z)) (/ x y)) (neg.f64 (*.f64 x z))))
y
#s(approx (+ (neg (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))
(*.f64 #s(literal -1 binary64) (*.f64 x z))
(*.f64 (*.f64 #s(literal -1 binary64) x) z)
(*.f64 (*.f64 x z) #s(literal -1 binary64))
(neg.f64 (*.f64 x z))
#s(literal -1 binary64)
(*.f64 x z)
(*.f64 z x)
x
z
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (neg (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))))
(*.f64 z #s(approx (+ (neg (* x y)) (/ x z)) (neg.f64 (*.f64 x y))))
#s(approx (+ (neg (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))
(*.f64 #s(literal -1 binary64) (*.f64 x y))
(*.f64 (*.f64 #s(literal -1 binary64) x) y)
(*.f64 (*.f64 x y) #s(literal -1 binary64))
(neg.f64 (*.f64 x y))
(*.f64 x y)
(*.f64 y x)
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 x) (*.f64 y z) x))
(+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x)
(+.f64 x (neg.f64 (*.f64 x (*.f64 y z))))
(-.f64 (neg.f64 (*.f64 x (*.f64 y z))) (neg.f64 x))
(fma.f64 (neg.f64 x) (*.f64 y z) x)
(fma.f64 x (neg.f64 (*.f64 y z)) x)
(*.f64 (neg.f64 x) (*.f64 y z))
(*.f64 x (neg.f64 (*.f64 y z)))
(neg.f64 (*.f64 x (*.f64 y z)))
(*.f64 x (*.f64 y z))
(*.f64 (*.f64 x y) z)
(*.f64 (*.f64 y z) x)
(*.f64 y z)
(*.f64 z y)

eval23.0ms (0.9%)

Memory
-32.0MiB live, 22.5MiB allocated; 16ms collecting garbage
Compiler

Compiled 1 674 to 308 computations (81.6% saved)

prune8.0ms (0.3%)

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

8 alts after pruning (5 fresh and 3 done)

PrunedKeptTotal
New64569
Fresh000
Picked213
Done022
Total66874
Accuracy
100.0%
Counts
74 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
95.9%
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
47.2%
(*.f64 x #s(approx (- 1 (* y z)) #s(literal 1 binary64)))
95.9%
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 x) (*.f64 y z) x))
95.9%
#s(approx (* x (- 1 (* y z))) (+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x))
35.7%
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))))
50.0%
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))))
37.1%
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))))
50.5%
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))))
Compiler

Compiled 250 to 182 computations (27.2% saved)

series142.0ms (5.6%)

Memory
4.0MiB live, 144.6MiB allocated; 39ms collecting garbage
Counts
25 → 36
Calls
Call 1
Inputs
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 x) (*.f64 y z) x))
(fma.f64 (neg.f64 x) (*.f64 y z) x)
(neg.f64 x)
x
(*.f64 y z)
y
z
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))))
(*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y)))
#s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))
(/.f64 x y)
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))))
(*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z)))
#s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))
(/.f64 x z)
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))))
(*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))
(neg.f64 (*.f64 x z))
(*.f64 x z)
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))))
(*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))
(neg.f64 (*.f64 x y))
(*.f64 x y)
Outputs
#s(approx (* x (- 1 (* y z))) (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z))))
#s(approx (+ (* (neg x) (* y z)) x) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (*.f64 y z)))))
#s(approx (neg x) (*.f64 #s(literal -1 binary64) x))
#s(approx x x)
#s(approx (* y (+ (* -1 (* x z)) (/ x y))) (*.f64 x (*.f64 y (fma.f64 #s(literal -1 binary64) z (/.f64 #s(literal 1 binary64) y)))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 x (fma.f64 #s(literal -1 binary64) z (/.f64 #s(literal 1 binary64) y))))
#s(approx (/ x y) (/.f64 x y))
#s(approx (* z (+ (* -1 (* x y)) (/ x z))) (*.f64 x (*.f64 z (fma.f64 #s(literal -1 binary64) y (/.f64 #s(literal 1 binary64) z)))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 #s(literal 1 binary64) z))))
#s(approx (/ x z) (/.f64 x z))
#s(approx (neg (* x z)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
#s(approx (* x z) (*.f64 x z))
#s(approx (neg (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 x y)))
#s(approx (* x y) (*.f64 x y))
#s(approx (+ (* (neg x) (* y z)) x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 y z) #s(literal 1 binary64)))))
#s(approx (* y (+ (* -1 (* x z)) (/ x y))) (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y (-.f64 z (/.f64 #s(literal 1 binary64) y))))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 z (/.f64 #s(literal 1 binary64) y)))))
#s(approx (* z (+ (* -1 (* x y)) (/ x z))) (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 z (-.f64 y (/.f64 #s(literal 1 binary64) z))))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 y (/.f64 #s(literal 1 binary64) z)))))
#s(approx (* x (- 1 (* y z))) (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))))
#s(approx (* y z) (*.f64 y z))
#s(approx y y)
#s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))) y))
#s(approx (+ (* -1 (* x y)) (/ x z)) (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z)))
#s(approx (* x (- 1 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z))))
#s(approx (* x (- 1 (* y z))) (*.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (fma.f64 #s(literal -1 binary64) (*.f64 x z) (/.f64 x y)))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 y (fma.f64 #s(literal -1 binary64) x (/.f64 x (*.f64 y z)))))
#s(approx (* x (- 1 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (/.f64 x y) (*.f64 x z)))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (*.f64 #s(literal -1 binary64) (*.f64 y (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 x (*.f64 y z)))))))
#s(approx z z)
#s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x (*.f64 y z)))) z))
#s(approx (* x (- 1 (* y z))) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 x y) (/.f64 x z))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 z (fma.f64 #s(literal -1 binary64) x (/.f64 x (*.f64 y z)))))
#s(approx (* x (- 1 (* y z))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (/.f64 x z) (*.f64 x y)))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 x (*.f64 y z)))))))
Calls

9 calls:

TimeVariablePoint
8.0ms
x
-inf
4.0ms
x
inf
4.0ms
x
0
3.0ms
y
-inf
3.0ms
z
-inf

rewrite194.0ms (7.7%)

Memory
11.8MiB live, 147.3MiB allocated; 43ms collecting garbage
Counts
25 → 47
Calls
Call 1
Inputs
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 x) (*.f64 y z) x))
(fma.f64 (neg.f64 x) (*.f64 y z) x)
(neg.f64 x)
x
(*.f64 y z)
y
z
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))))
(*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y)))
#s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))
(/.f64 x y)
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))))
(*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z)))
#s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))
(/.f64 x z)
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))))
(*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z))))
#s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))
(neg.f64 (*.f64 x z))
(*.f64 x z)
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))))
(*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y))))
#s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))
(neg.f64 (*.f64 x y))
(*.f64 x y)
Outputs
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 x) (*.f64 y z) x))
(+.f64 (neg.f64 (*.f64 x (*.f64 y z))) x)
(+.f64 x (neg.f64 (*.f64 x (*.f64 y z))))
(-.f64 (neg.f64 (*.f64 x (*.f64 y z))) (neg.f64 x))
(fma.f64 (neg.f64 x) (*.f64 y z) x)
(fma.f64 (*.f64 y z) (neg.f64 x) x)
(fma.f64 (neg.f64 (*.f64 x y)) z x)
(neg.f64 x)
x
(*.f64 y z)
(*.f64 z y)
y
z
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (neg (* x z)) (/ x y)) (/.f64 x y))))
(*.f64 y #s(approx (+ (neg (* x z)) (/ x y)) (/.f64 x y)))
#s(approx (+ (neg (* x z)) (/ x y)) (/.f64 x y))
(*.f64 x (/.f64 #s(literal 1 binary64) y))
(/.f64 x y)
(/.f64 (neg.f64 x) (neg.f64 y))
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (neg (* x y)) (/ x z)) (/.f64 x z))))
(*.f64 z #s(approx (+ (neg (* x y)) (/ x z)) (/.f64 x z)))
#s(approx (+ (neg (* x y)) (/ x z)) (/.f64 x z))
(*.f64 x (/.f64 #s(literal 1 binary64) z))
(/.f64 x z)
(/.f64 (neg.f64 x) (neg.f64 z))
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (neg (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))))
(*.f64 y #s(approx (+ (neg (* x z)) (/ x y)) (neg.f64 (*.f64 x z))))
#s(approx (+ (neg (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))
(*.f64 (*.f64 #s(literal -1 binary64) x) z)
(*.f64 (*.f64 x z) #s(literal -1 binary64))
(*.f64 (neg.f64 x) z)
(*.f64 #s(literal -1 binary64) (*.f64 x z))
(*.f64 x (neg.f64 z))
(neg.f64 (*.f64 x z))
(*.f64 x z)
(*.f64 z x)
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (neg (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))))
(*.f64 z #s(approx (+ (neg (* x y)) (/ x z)) (neg.f64 (*.f64 x y))))
#s(approx (+ (neg (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))
(*.f64 (*.f64 #s(literal -1 binary64) x) y)
(*.f64 (*.f64 x y) #s(literal -1 binary64))
(*.f64 (neg.f64 x) y)
(*.f64 #s(literal -1 binary64) (*.f64 x y))
(*.f64 x (neg.f64 y))
(neg.f64 (*.f64 x y))
(*.f64 x y)
(*.f64 y x)

eval30.0ms (1.2%)

Memory
-25.7MiB live, 23.0MiB allocated; 29ms collecting garbage
Compiler

Compiled 1 918 to 324 computations (83.1% saved)

prune5.0ms (0.2%)

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

8 alts after pruning (1 fresh and 7 done)

PrunedKeptTotal
New78179
Fresh000
Picked055
Done123
Total79887
Accuracy
100.0%
Counts
87 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
95.9%
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
47.2%
(*.f64 x #s(approx (- 1 (* y z)) #s(literal 1 binary64)))
92.8%
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 (*.f64 x y)) z x))
95.9%
#s(approx (* x (- 1 (* y z))) (fma.f64 (neg.f64 x) (*.f64 y z) x))
35.7%
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (/.f64 x z))))
50.0%
#s(approx (* x (- 1 (* y z))) (*.f64 z #s(approx (+ (* -1 (* x y)) (/ x z)) (neg.f64 (*.f64 x y)))))
37.1%
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (/.f64 x y))))
50.5%
#s(approx (* x (- 1 (* y z))) (*.f64 y #s(approx (+ (* -1 (* x z)) (/ x y)) (neg.f64 (*.f64 x z)))))
Compiler

Compiled 140 to 104 computations (25.7% saved)

regimes88.0ms (3.5%)

Memory
-16.3MiB live, 173.8MiB allocated; 24ms collecting garbage
Accuracy

Total -12.0b remaining (-27.1%)

Threshold costs -12b (-27.1%)

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

26 calls:

7.0ms
x
6.0ms
(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
5.0ms
z
5.0ms
x
4.0ms
y
Results
AccuracySegmentsBranch
47.2%1x
47.2%1z
47.2%1y
47.2%1(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
47.2%1(*.f64 y z)
47.2%1(-.f64 #s(literal 1 binary64) (*.f64 y z))
94.0%3(*.f64 y z)
94.0%3(-.f64 #s(literal 1 binary64) (*.f64 y z))
79.4%3y
77.2%3z
60.9%4x
83.7%3(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
94.0%3(*.f64 y z)
94.0%3(-.f64 #s(literal 1 binary64) (*.f64 y z))
98.4%2(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
98.4%2(*.f64 y z)
98.4%2(-.f64 #s(literal 1 binary64) (*.f64 y z))
98.4%2(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
98.4%2(*.f64 y z)
98.4%2(-.f64 #s(literal 1 binary64) (*.f64 y z))
98.4%2(*.f64 y z)
98.4%2(-.f64 #s(literal 1 binary64) (*.f64 y z))
98.4%2(*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y z)))
97.7%2x
95.9%1y
95.9%1z
Compiler

Compiled 351 to 189 computations (46.2% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
7.295322009501489e+147
1.156435796443134e+148
Compiler

Compiled 10 to 13 computations (-30% saved)

bsearch0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
7.295322009501489e+147
1.156435796443134e+148
Compiler

Compiled 10 to 13 computations (-30% saved)

bsearch0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
7.295322009501489e+147
1.156435796443134e+148
Compiler

Compiled 10 to 13 computations (-30% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
1.4037380557541013
69.82011867851936
0.0ms
-9057727.599169198
0.9999998130873525
Compiler

Compiled 10 to 13 computations (-30% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
1.4037380557541013
69.82011867851936
0.0ms
-9057727.599169198
0.9999998130873525
Compiler

Compiled 10 to 13 computations (-30% saved)

derivations2.0ms (0.1%)

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

Compiled 289 to 51 computations (82.4% saved)

preprocess98.0ms (3.9%)

Memory
36.3MiB live, 128.3MiB allocated; 28ms collecting garbage
Remove

(sort y z)

(negabs x)

Compiler

Compiled 1 744 to 792 computations (54.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...