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

Time bar (total: 3.1s)

start0.0ms (0%)

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

analyze1.0ms (0%)

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

Compiled 9 to 9 computations (0% saved)

sample1.2s (38%)

Memory
-6.9MiB live, 390.5MiB allocated; 280ms collecting garbage
Samples
727.0ms8 254×0valid
0.0ms1valid
Precisions
Click to see histograms. Total time spent on operations: 200.0ms
ival-sub!: 86.0ms (42.9% of total)
ival-mult!: 61.0ms (30.4% of total)
ival-add!: 52.0ms (26% of total)
adjust: 2.0ms (1% of total)
Bogosity

preprocess86.0ms (2.8%)

Memory
-6.0MiB live, 39.1MiB allocated; 8ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

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

(sort x y)

Compiler

Compiled 14 to 14 computations (0% saved)

series179.0ms (5.8%)

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

9 calls:

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

rewrite194.0ms (6.3%)

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

eval4.0ms (0.1%)

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

Compiled 442 to 125 computations (71.7% saved)

prune4.0ms (0.1%)

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

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New26531
Fresh000
Picked011
Done000
Total26632
Accuracy
100.0%
Counts
32 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
49.3%
(*.f64 (+.f64 x y) #s(approx (- 1 z) #s(literal 1 binary64)))
49.8%
(*.f64 #s(approx (+ x y) y) (-.f64 #s(literal 1 binary64) z))
99.6%
#s(approx (* (+ x y) (- 1 z)) (fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z))))
100.0%
#s(approx (* (+ x y) (- 1 z)) (+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y))))))
51.1%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
Compiler

Compiled 143 to 115 computations (19.6% saved)

series163.0ms (5.3%)

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

9 calls:

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

rewrite192.0ms (6.3%)

Memory
-14.8MiB live, 123.5MiB allocated; 62ms collecting garbage
Counts
21 → 56
Calls
Call 1
Inputs
#s(approx (* (+ x y) (- 1 z)) (+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y))))))
(+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y)))))
x
(+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y))))
y
(*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y)))
#s(literal -1 binary64)
(*.f64 z (+.f64 x y))
z
(+.f64 x y)
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
(*.f64 x (-.f64 #s(literal 1 binary64) z))
(-.f64 #s(literal 1 binary64) z)
#s(literal 1 binary64)
(*.f64 #s(approx (+ x y) y) (-.f64 #s(literal 1 binary64) z))
#s(approx (+ x y) y)
(*.f64 (+.f64 x y) #s(approx (- 1 z) #s(literal 1 binary64)))
#s(approx (- 1 z) #s(literal 1 binary64))
#s(approx (* (+ x y) (- 1 z)) (fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z))))
(fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z)))
(*.f64 y (-.f64 #s(literal 1 binary64) z))
Outputs
#s(approx (* (+ x y) (- 1 z)) (+.f64 x (+.f64 y (neg.f64 (*.f64 z (+.f64 x y))))))
(+.f64 x (+.f64 y (neg.f64 (*.f64 z (+.f64 x y)))))
(+.f64 (+.f64 y (neg.f64 (*.f64 z (+.f64 x y)))) x)
(+.f64 (+.f64 x y) (neg.f64 (*.f64 z (+.f64 x y))))
(-.f64 x (neg.f64 (+.f64 y (neg.f64 (*.f64 z (+.f64 x y))))))
x
(+.f64 y (neg.f64 (*.f64 z (+.f64 x y))))
(+.f64 (neg.f64 (*.f64 z (+.f64 x y))) y)
(-.f64 y (*.f64 #s(literal 1 binary64) (*.f64 z (+.f64 x y))))
(-.f64 y (neg.f64 (neg.f64 (*.f64 z (+.f64 x y)))))
(fma.f64 (*.f64 #s(literal -1 binary64) z) (+.f64 x y) y)
(fma.f64 (*.f64 z (+.f64 x y)) #s(literal -1 binary64) y)
(fma.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y)) y)
y
(*.f64 (*.f64 #s(literal -1 binary64) z) (+.f64 x y))
(*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y)))
(*.f64 (*.f64 z (+.f64 x y)) #s(literal -1 binary64))
(neg.f64 (*.f64 z (+.f64 x y)))
#s(literal -1 binary64)
(*.f64 z (+.f64 x y))
(*.f64 (+.f64 x y) z)
(+.f64 (*.f64 x z) (*.f64 y z))
(+.f64 (*.f64 z x) (*.f64 z y))
(fma.f64 x z (*.f64 y z))
(fma.f64 z x (*.f64 z y))
z
(+.f64 x y)
(+.f64 y x)
(-.f64 x (neg.f64 y))
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
(*.f64 x (-.f64 #s(literal 1 binary64) z))
(*.f64 (-.f64 #s(literal 1 binary64) z) x)
(+.f64 #s(literal 1 binary64) (neg.f64 z))
(-.f64 #s(literal 1 binary64) z)
(neg.f64 (-.f64 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))
(*.f64 #s(approx (+ x y) y) (-.f64 #s(literal 1 binary64) z))
#s(approx (+ x y) y)
(*.f64 (+.f64 x y) #s(approx (- 1 z) #s(literal 1 binary64)))
#s(approx (- 1 z) #s(literal 1 binary64))
#s(approx (* (+ x y) (- 1 z)) (*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z)))
(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
(*.f64 (-.f64 #s(literal 1 binary64) z) (+.f64 x y))
(+.f64 (*.f64 x (-.f64 #s(literal 1 binary64) z)) (*.f64 y (-.f64 #s(literal 1 binary64) z)))
(+.f64 (*.f64 y (-.f64 #s(literal 1 binary64) z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
(-.f64 (*.f64 x (-.f64 #s(literal 1 binary64) z)) (*.f64 (neg.f64 y) (-.f64 #s(literal 1 binary64) z)))
(-.f64 (*.f64 x (-.f64 #s(literal 1 binary64) z)) (neg.f64 (*.f64 y (-.f64 #s(literal 1 binary64) z))))
(fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z)))
(fma.f64 y (-.f64 #s(literal 1 binary64) z) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
(fma.f64 (-.f64 #s(literal 1 binary64) z) y (*.f64 x (-.f64 #s(literal 1 binary64) z)))
(fma.f64 (-.f64 #s(literal 1 binary64) z) x (*.f64 y (-.f64 #s(literal 1 binary64) z)))
(*.f64 y (-.f64 #s(literal 1 binary64) z))
(*.f64 (-.f64 #s(literal 1 binary64) z) y)

eval17.0ms (0.5%)

Memory
-14.7MiB live, 30.3MiB allocated; 6ms collecting garbage
Compiler

Compiled 3 033 to 550 computations (81.9% saved)

prune4.0ms (0.1%)

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

7 alts after pruning (2 fresh and 5 done)

PrunedKeptTotal
New1342136
Fresh000
Picked145
Done011
Total1357142
Accuracy
100.0%
Counts
142 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
49.3%
(*.f64 (+.f64 x y) #s(approx (- 1 z) #s(literal 1 binary64)))
49.8%
(*.f64 #s(approx (+ x y) y) (-.f64 #s(literal 1 binary64) z))
99.6%
#s(approx (* (+ x y) (- 1 z)) (fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z))))
51.1%
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z)))))
51.1%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
27.5%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z))))
Compiler

Compiled 98 to 76 computations (22.4% saved)

series150.0ms (4.9%)

Memory
5.7MiB live, 146.6MiB allocated; 67ms collecting garbage
Counts
12 → 45
Calls
Call 1
Inputs
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z))))
(*.f64 x #s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z)))
x
#s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z))
(*.f64 #s(literal -1 binary64) z)
#s(literal -1 binary64)
z
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z)))))
(+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
(*.f64 #s(literal -1 binary64) (*.f64 x z))
(*.f64 x z)
Outputs
#s(approx (* (+ x y) (- 1 z)) (*.f64 y (-.f64 #s(literal 1 binary64) z)))
#s(approx (* (+ x y) (- 1 z)) (fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z))))
#s(approx (* x (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
#s(approx x x)
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 y z))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (+.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 y z) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) z))))))
#s(approx (+ y (* -1 (* z (+ x y)))) (+.f64 y (fma.f64 #s(literal -1 binary64) (*.f64 x z) (*.f64 #s(literal -1 binary64) (*.f64 y z)))))
#s(approx (* -1 (* x z)) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
#s(approx (* x z) (*.f64 x z))
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 y (-.f64 #s(literal 1 binary64) z)) x)) z)))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) z))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x) (/.f64 y x))))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 x (fma.f64 #s(literal -1 binary64) z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x) (/.f64 y x)))))
#s(approx (* (+ x y) (- 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y (-.f64 #s(literal 1 binary64) z)) x))))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 z #s(literal 1 binary64)))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (+.f64 z (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 y z))) x))) #s(literal 1 binary64)))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x (+.f64 z (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 y z))) x))))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x z))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (+.f64 x (fma.f64 #s(literal -1 binary64) (*.f64 x z) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) z))))))
#s(approx (+ y (* -1 (* z (+ x y)))) (fma.f64 #s(literal -1 binary64) (*.f64 x z) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) z)))))
#s(approx (* (+ x y) (- 1 z)) (*.f64 y (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x (-.f64 #s(literal 1 binary64) z)) y)) z)))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) z))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 y (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y) (/.f64 x y))))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 y (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x z) y))))))
#s(approx (* (+ x y) (- 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal 1 binary64) z) (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x (-.f64 #s(literal 1 binary64) z)) y))))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 z #s(literal 1 binary64)))))
#s(approx (+ x (+ y (* -1 (* z (+ x y))))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (+.f64 z (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 x z))) y))) #s(literal 1 binary64)))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (+.f64 z (/.f64 (*.f64 x z) y)) #s(literal 1 binary64)))))
#s(approx (* (+ x y) (- 1 z)) (+.f64 x y))
#s(approx (* (+ x y) (- 1 z)) (+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y))))))
#s(approx (- 1 z) #s(literal 1 binary64))
#s(approx (- 1 z) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) z)))
#s(approx (* -1 z) (*.f64 #s(literal -1 binary64) z))
#s(approx z z)
#s(approx (+ y (* -1 (* z (+ x y)))) y)
#s(approx (+ y (* -1 (* z (+ x y)))) (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y)))))
#s(approx (* (+ x y) (- 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x y))))
#s(approx (* (+ x y) (- 1 z)) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (+.f64 (/.f64 x z) (/.f64 y z)))))
#s(approx (* x (- 1 z)) (*.f64 z (fma.f64 #s(literal -1 binary64) x (/.f64 x z))))
#s(approx (- 1 z) (*.f64 z (-.f64 (/.f64 #s(literal 1 binary64) z) #s(literal 1 binary64))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 z (fma.f64 #s(literal -1 binary64) (+.f64 x y) (/.f64 y z))))
#s(approx (* (+ x y) (- 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x y) z)))))))
#s(approx (* x (- 1 z)) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 x z))))))
#s(approx (- 1 z) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) z)))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 y z)))))))
Calls

9 calls:

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

rewrite224.0ms (7.3%)

Memory
-30.2MiB live, 127.1MiB allocated; 49ms collecting garbage
Counts
12 → 18
Calls
Call 1
Inputs
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z))))
(*.f64 x #s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z)))
x
#s(approx (- 1 z) (*.f64 #s(literal -1 binary64) z))
(*.f64 #s(literal -1 binary64) z)
#s(literal -1 binary64)
z
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z)))))
(+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z))))
#s(approx (+ y (* -1 (* z (+ x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x z)))
(*.f64 #s(literal -1 binary64) (*.f64 x z))
(*.f64 x z)
Outputs
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (neg.f64 z))))
(*.f64 x #s(approx (- 1 z) (neg.f64 z)))
x
#s(approx (- 1 z) (neg.f64 z))
(*.f64 #s(literal -1 binary64) z)
(*.f64 z #s(literal -1 binary64))
(neg.f64 z)
#s(literal -1 binary64)
z
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z)))))
(+.f64 x #s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z))))
#s(approx (+ y (* (neg 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))
(*.f64 x z)
(*.f64 z x)

eval6.0ms (0.2%)

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

Compiled 1 463 to 274 computations (81.3% saved)

prune7.0ms (0.2%)

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

8 alts after pruning (4 fresh and 4 done)

PrunedKeptTotal
New54458
Fresh000
Picked202
Done145
Total57865
Accuracy
100.0%
Counts
65 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
49.8%
(*.f64 #s(approx (+ x y) y) (-.f64 #s(literal 1 binary64) z))
99.6%
#s(approx (* (+ x y) (- 1 z)) (fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z))))
51.1%
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z)))))
49.3%
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) y)))
51.1%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
27.5%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (neg.f64 z))))
25.9%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) #s(literal 1 binary64))))
Compiler

Compiled 122 to 89 computations (27% saved)

series220.0ms (7.2%)

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

9 calls:

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

rewrite212.0ms (6.9%)

Memory
-9.4MiB live, 82.3MiB allocated; 40ms collecting garbage
Counts
19 → 25
Calls
Call 1
Inputs
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) #s(literal 1 binary64))))
(*.f64 x #s(approx (- 1 z) #s(literal 1 binary64)))
x
#s(approx (- 1 z) #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (neg.f64 z))))
(*.f64 x #s(approx (- 1 z) (neg.f64 z)))
#s(approx (- 1 z) (neg.f64 z))
(neg.f64 z)
z
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) y)))
(+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) y))
#s(approx (+ y (* -1 (* z (+ x y)))) y)
y
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z)))))
(+.f64 x #s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z))))
#s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z)))
(neg.f64 (*.f64 x z))
(*.f64 x z)
Outputs
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) #s(literal 1 binary64))))
(*.f64 x #s(approx (- 1 z) #s(literal 1 binary64)))
x
#s(approx (- 1 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))
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (neg.f64 z))))
(*.f64 x #s(approx (- 1 z) (neg.f64 z)))
#s(approx (- 1 z) (neg.f64 z))
(neg.f64 z)
z
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (- y (* z (+ x y))) y)))
(+.f64 x #s(approx (- y (* z (+ x y))) y))
#s(approx (- y (* z (+ x y))) y)
y
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (- y (* z (+ x y))) (neg.f64 (*.f64 x z)))))
(+.f64 x #s(approx (- y (* z (+ x y))) (neg.f64 (*.f64 x z))))
#s(approx (- y (* z (+ x y))) (neg.f64 (*.f64 x z)))
(*.f64 (neg.f64 x) z)
(*.f64 x (neg.f64 z))
(neg.f64 (*.f64 x z))
(*.f64 x z)
(*.f64 z x)

eval8.0ms (0.2%)

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

Compiled 1 470 to 284 computations (80.7% saved)

prune8.0ms (0.3%)

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

8 alts after pruning (0 fresh and 8 done)

PrunedKeptTotal
New59059
Fresh000
Picked044
Done044
Total59867
Accuracy
100.0%
Counts
67 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
49.8%
(*.f64 #s(approx (+ x y) y) (-.f64 #s(literal 1 binary64) z))
99.6%
#s(approx (* (+ x y) (- 1 z)) (fma.f64 x (-.f64 #s(literal 1 binary64) z) (*.f64 y (-.f64 #s(literal 1 binary64) z))))
51.1%
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* (neg z) (+ x y))) (neg.f64 (*.f64 x z)))))
49.3%
#s(approx (* (+ x y) (- 1 z)) (+.f64 x #s(approx (+ y (* -1 (* z (+ x y)))) y)))
51.1%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x (-.f64 #s(literal 1 binary64) z)))
27.5%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) (neg.f64 z))))
25.9%
#s(approx (* (+ x y) (- 1 z)) (*.f64 x #s(approx (- 1 z) #s(literal 1 binary64))))
Compiler

Compiled 122 to 89 computations (27% saved)

regimes168.0ms (5.5%)

Memory
15.2MiB live, 110.6MiB allocated; 65ms collecting garbage
Accuracy

Total -15.1b remaining (-22.1%)

Threshold costs -15.1b (-22.1%)

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

26 calls:

35.0ms
x
8.0ms
(+.f64 x y)
7.0ms
z
7.0ms
(-.f64 #s(literal 1 binary64) z)
6.0ms
y
Results
AccuracySegmentsBranch
49.3%1(+.f64 x y)
49.3%1y
49.3%1x
49.3%1(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
49.3%1z
49.3%1(-.f64 #s(literal 1 binary64) z)
73.7%3(-.f64 #s(literal 1 binary64) z)
73.7%3z
51.7%2(+.f64 x y)
74.0%3z
74.0%3(-.f64 #s(literal 1 binary64) z)
68.0%2y
68.4%2x
73.2%2(+.f64 x y)
77.9%4(-.f64 #s(literal 1 binary64) z)
97.2%2(+.f64 x y)
73.2%3(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
84.7%2x
84.2%2y
77.9%4z
100.0%1(-.f64 #s(literal 1 binary64) z)
100.0%1(+.f64 x y)
100.0%1(*.f64 (+.f64 x y) (-.f64 #s(literal 1 binary64) z))
100.0%1x
100.0%1y
100.0%1z
Compiler

Compiled 256 to 160 computations (37.5% saved)

bsearch0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-5.845799932507982e-296
5.196966441612491e-248
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
-5.845799932507982e-296
5.196966441612491e-248
Compiler

Compiled 10 to 13 computations (-30% saved)

bsearch0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2811242769426671.5
4.309707714350622e+22
0.0ms
-30.790318319670646
0.9991018269086942
Compiler

Compiled 10 to 13 computations (-30% saved)

derivations2.0ms (0.1%)

Memory
2.3MiB live, 2.3MiB allocated; 0ms collecting garbage
Stop Event
done
Compiler

Compiled 161 to 36 computations (77.6% saved)

preprocess48.0ms (1.6%)

Memory
-21.1MiB live, 72.9MiB allocated; 8ms collecting garbage
Remove

(sort x y)

Compiler

Compiled 490 to 215 computations (56.1% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...