Main:bigenough2 from A

Time bar (total: 2.5s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.6MiB live, 0.6MiB 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 8 computations (11.1% saved)

sample827.0ms (33.7%)

Memory
29.2MiB live, 1 160.6MiB allocated; 285ms collecting garbage
Samples
559.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 289.0ms
ival-add: 184.0ms (63.6% of total)
ival-mult: 101.0ms (34.9% of total)
ival-assert: 3.0ms (1% of total)
adjust: 2.0ms (0.7% of total)
Bogosity

explain106.0ms (4.3%)

Memory
0.1MiB live, 98.5MiB allocated; 24ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(+.f64 z x)
00-0-y
00-0-(*.f64 y (+.f64 z x))
00-0-(+.f64 x (*.f64 y (+.f64 z x)))
00-0-z
00-0-x
Confusion
Predicted +Predicted -
+00
-0256
Precision
0/0
Recall
0/0
Confusion?
Predicted +Predicted MaybePredicted -
+000
-00256
Precision?
0/0
Recall?
0/0
Freqs
test
numberfreq
0256
Total Confusion?
Predicted +Predicted MaybePredicted -
+000
-001
Precision?
0/0
Recall?
0/0
Samples
24.0ms512×0valid
Compiler

Compiled 47 to 22 computations (53.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 10.0ms
ival-add: 5.0ms (51.3% of total)
ival-mult: 4.0ms (41% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess167.0ms (6.8%)

Memory
-25.1MiB live, 207.1MiB allocated; 39ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02977
110077
237073
365773
487371
5119270
6161870
7384270
8771370
067
097
1217
2537
31187
41867
52587
63577
77157
822677
081576
Stop Event
iter limit
node limit
iter limit
node limit
Calls
Call 1
Inputs
(+.f64 x (*.f64 y (+.f64 z x)))
Outputs
(+.f64 x (*.f64 y (+.f64 z x)))
(fma.f64 (+.f64 z x) y x)
Compiler

Compiled 7 to 6 computations (14.3% saved)

eval0.0ms (0%)

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

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.7MiB live, 1.7MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(+.f64 x (*.f64 y (+.f64 z x)))
Compiler

Compiled 7 to 6 computations (14.3% saved)

series7.0ms (0.3%)

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

9 calls:

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

rewrite275.0ms (11.2%)

Memory
-12.5MiB live, 340.7MiB allocated; 130ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0109465
0112439
1608429
25308429
08974397
Stop Event
iter limit
node limit
iter limit
Counts
39 → 119
Calls
Call 1
Inputs
(+.f64 x (*.f64 y (+.f64 z x)))
x
(*.f64 y (+.f64 z x))
y
(+.f64 z x)
z
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y z)))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx x #s(hole binary64 x))
#s(approx (* y (+ z x)) #s(hole binary64 (* y z)))
#s(approx (* y (+ z x)) #s(hole binary64 (+ (* x y) (* y z))))
#s(approx (+ z x) #s(hole binary64 z))
#s(approx (+ z x) #s(hole binary64 (+ x z)))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (* y (+ z x)) #s(hole binary64 (* x y)))
#s(approx (* y (+ z x)) #s(hole binary64 (* x (+ y (/ (* y z) x)))))
#s(approx (+ z x) #s(hole binary64 x))
#s(approx (+ z x) #s(hole binary64 (* x (+ 1 (/ z x)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (* y (+ z x)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ (* y z) x)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* x (- (* -1 (/ z x)) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (* y (+ z x)) #s(hole binary64 (* y (+ x z))))
#s(approx y #s(hole binary64 y))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* x y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx z #s(hole binary64 z))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (* y (+ z x)) #s(hole binary64 (* z (+ y (/ (* x y) z)))))
#s(approx (+ z x) #s(hole binary64 (* z (+ 1 (/ x z)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (* y (+ z x)) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (* x y) z)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* z (- (* -1 (/ x z)) 1)))))
Outputs
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 (+.f64 z x) y) x))
(/.f64 (-.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))) (-.f64 (*.f64 z y) (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64))) (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (+.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (*.f64 (fma.f64 y x x) (*.f64 (neg.f64 z) y)))))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 3 binary64))) (fma.f64 x x (+.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 2 binary64)) (*.f64 x (*.f64 (neg.f64 (+.f64 z x)) y)))))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (*.f64 (+.f64 z x) y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 (+.f64 z x) y) (-.f64 (*.f64 (+.f64 z x) y) x) (*.f64 x x))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (pow.f64 (*.f64 z y) #s(literal 2 binary64)))) (neg.f64 (+.f64 x (*.f64 y (-.f64 x z)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 z y) #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 2 binary64))) (-.f64 x (*.f64 (+.f64 z x) y)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (pow.f64 (*.f64 z y) #s(literal 2 binary64))) (+.f64 x (*.f64 y (-.f64 x z))))
(/.f64 (+.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 2 binary64)) (-.f64 (*.f64 x x) (*.f64 (*.f64 (+.f64 z x) y) x))))
(/.f64 (+.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (*.f64 (+.f64 z x) y) (-.f64 (*.f64 (+.f64 z x) y) x) (*.f64 x x)))
(/.f64 (+.f64 (pow.f64 (*.f64 z y) #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 (*.f64 (fma.f64 y x x) z) y))))
(/.f64 (+.f64 (pow.f64 (*.f64 z y) #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64))) (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))))
(fma.f64 (-.f64 y #s(literal -1 binary64)) x (*.f64 z y))
(fma.f64 (+.f64 z x) y x)
(fma.f64 z y (fma.f64 y x x))
(fma.f64 y (+.f64 z x) x)
(fma.f64 y z (fma.f64 y x x))
(fma.f64 y x (+.f64 x (*.f64 z y)))
(fma.f64 y x (fma.f64 z y x))
(fma.f64 x (-.f64 y #s(literal -1 binary64)) (*.f64 z y))
(fma.f64 x y (+.f64 x (*.f64 z y)))
(fma.f64 x y (fma.f64 z y x))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (*.f64 (+.f64 z x) y))) (/.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 2 binary64)) (-.f64 x (*.f64 (+.f64 z x) y))))
(-.f64 (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (+.f64 x (*.f64 y (-.f64 x z)))) (/.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (+.f64 x (*.f64 y (-.f64 x z)))))
(-.f64 (*.f64 y x) (-.f64 (*.f64 (neg.f64 z) y) x))
(-.f64 (fma.f64 y x x) (*.f64 (neg.f64 z) y))
(-.f64 (*.f64 z y) (*.f64 (neg.f64 (-.f64 y #s(literal -1 binary64))) x))
(-.f64 (*.f64 z y) (*.f64 (neg.f64 x) (-.f64 y #s(literal -1 binary64))))
(-.f64 x (-.f64 (*.f64 (neg.f64 y) x) (*.f64 z y)))
(-.f64 x (*.f64 (neg.f64 (+.f64 z x)) y))
(+.f64 (+.f64 x (*.f64 z y)) (*.f64 y x))
(+.f64 (fma.f64 z y x) (*.f64 y x))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (*.f64 (+.f64 z x) y) (-.f64 (*.f64 (+.f64 z x) y) x) (*.f64 x x))) (/.f64 (pow.f64 (*.f64 (+.f64 z x) y) #s(literal 3 binary64)) (fma.f64 (*.f64 (+.f64 z x) y) (-.f64 (*.f64 (+.f64 z x) y) x) (*.f64 x x))))
(+.f64 (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 z y) #s(literal 3 binary64)) (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))))
(+.f64 (*.f64 (+.f64 z x) y) x)
(+.f64 (*.f64 y x) (+.f64 x (*.f64 z y)))
(+.f64 (*.f64 y x) (fma.f64 z y x))
(+.f64 (fma.f64 y x x) (*.f64 z y))
(+.f64 (*.f64 z y) (fma.f64 y x x))
(+.f64 x (*.f64 (+.f64 z x) y))
x
(*.f64 (+.f64 z x) y)
(*.f64 y (+.f64 z x))
(/.f64 (*.f64 y (*.f64 (+.f64 z x) (-.f64 z x))) (-.f64 z x))
(/.f64 (*.f64 y (*.f64 (+.f64 z x) (-.f64 x z))) (-.f64 x z))
(/.f64 (*.f64 y (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 x (-.f64 x z) (*.f64 z z)))
(/.f64 (*.f64 y (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(/.f64 (-.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (*.f64 z y) (*.f64 y x)))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (+.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (*.f64 (*.f64 y x) (*.f64 (neg.f64 z) y)))))
(/.f64 (neg.f64 (*.f64 (*.f64 (+.f64 z x) y) (*.f64 y (-.f64 x z)))) (neg.f64 (*.f64 y (-.f64 x z))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(/.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 z x)) y) (-.f64 z x))
(/.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) y) (-.f64 x z))
(/.f64 (*.f64 (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) y) (fma.f64 x (-.f64 x z) (*.f64 z z)))
(/.f64 (*.f64 (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) y) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(/.f64 (*.f64 (*.f64 (+.f64 z x) y) (*.f64 y (-.f64 x z))) (*.f64 y (-.f64 x z)))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 (*.f64 z x) y) y))))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64))) (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))
(fma.f64 z y (*.f64 y x))
(fma.f64 y z (*.f64 y x))
(fma.f64 y x (*.f64 z y))
(fma.f64 x y (*.f64 z y))
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y (-.f64 x z))) (/.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (*.f64 y (-.f64 x z))))
(-.f64 (*.f64 y x) (*.f64 (neg.f64 z) y))
(-.f64 (*.f64 z y) (*.f64 (neg.f64 y) x))
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 z y) #s(literal 3 binary64)) (fma.f64 (*.f64 z y) (-.f64 (*.f64 z y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(+.f64 (*.f64 y x) (*.f64 z y))
(+.f64 (*.f64 z y) (*.f64 y x))
y
(/.f64 (neg.f64 (*.f64 (+.f64 z x) (-.f64 z x))) (neg.f64 (-.f64 z x)))
(/.f64 (neg.f64 (*.f64 (+.f64 z x) (-.f64 x z))) (neg.f64 (-.f64 x z)))
(/.f64 (neg.f64 (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x z) (*.f64 z z))))
(/.f64 (neg.f64 (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 z (-.f64 z x) (*.f64 x x))))
(/.f64 (*.f64 (+.f64 z x) (-.f64 z x)) (-.f64 z x))
(/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (-.f64 x z))
(/.f64 (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (-.f64 x z) (*.f64 z z)))
(/.f64 (+.f64 (pow.f64 z #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(-.f64 (/.f64 (*.f64 z z) (-.f64 z x)) (/.f64 (*.f64 x x) (-.f64 z x)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x z)) (/.f64 (*.f64 z z) (-.f64 x z)))
(+.f64 (/.f64 (pow.f64 z #s(literal 3 binary64)) (fma.f64 x (-.f64 x z) (*.f64 z z))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (-.f64 x z) (*.f64 z z))))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 z (-.f64 z x) (*.f64 x x))) (/.f64 (pow.f64 z #s(literal 3 binary64)) (fma.f64 z (-.f64 z x) (*.f64 x x))))
(+.f64 z x)
(+.f64 x z)
z
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx x x)
#s(approx (* y (+ z x)) (*.f64 z y))
#s(approx (* y (+ z x)) (*.f64 (+.f64 z x) y))
#s(approx (+ z x) z)
#s(approx (+ z x) (+.f64 z x))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (fma.f64 (/.f64 z x) y y) x x))
#s(approx (* y (+ z x)) (*.f64 y x))
#s(approx (* y (+ z x)) (*.f64 (fma.f64 (/.f64 z x) y y) x))
#s(approx (+ z x) x)
#s(approx (+ z x) (fma.f64 (/.f64 z x) x x))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (fma.f64 (/.f64 z x) y y) #s(literal -1 binary64))))
#s(approx (* y (+ z x)) (*.f64 (fma.f64 (/.f64 z x) y y) x))
#s(approx (+ z x) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (/.f64 z x) #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx (* y (+ z x)) (*.f64 (+.f64 z x) y))
#s(approx y y)
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (+.f64 (/.f64 x y) z) x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 (+.f64 (+.f64 (/.f64 x y) z) x)) (neg.f64 y)))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx z z)
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (/.f64 (fma.f64 y x x) z) y) z))
#s(approx (* y (+ z x)) (*.f64 (fma.f64 y (/.f64 x z) y) z))
#s(approx (+ z x) (fma.f64 (/.f64 x z) z z))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 z) (neg.f64 (+.f64 (/.f64 (fma.f64 y x x) z) y))))
#s(approx (* y (+ z x)) (*.f64 (neg.f64 z) (neg.f64 (fma.f64 y (/.f64 x z) y))))
#s(approx (+ z x) (*.f64 (neg.f64 z) (fma.f64 (/.f64 x z) #s(literal -1 binary64) #s(literal -1 binary64))))

eval18.0ms (0.7%)

Memory
-22.7MiB live, 27.0MiB allocated; 10ms collecting garbage
Compiler

Compiled 1 887 to 355 computations (81.2% saved)

prune4.0ms (0.2%)

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

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New1106116
Fresh000
Picked101
Done000
Total1116117
Accuracy
100.0%
Counts
117 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (+.f64 z x) y x)
75.8%
(+.f64 x (*.f64 y #s(approx (+ z x) z)))
64.5%
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
63.2%
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
40.3%
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
37.2%
#s(approx (+ x (* y (+ z x))) x)
Compiler

Compiled 120 to 88 computations (26.7% saved)

series8.0ms (0.3%)

Memory
20.0MiB live, 20.0MiB allocated; 0ms collecting garbage
Counts
12 → 56
Calls
Call 1
Inputs
(fma.f64 (+.f64 z x) y x)
(+.f64 z x)
z
x
y
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
(*.f64 z y)
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
(fma.f64 y x x)
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
(*.f64 (+.f64 z x) y)
Outputs
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y z)))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (+ z x) #s(hole binary64 z))
#s(approx (+ z x) #s(hole binary64 (+ x z)))
#s(approx x #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y z)))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (+ (* y x) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y z)))
#s(approx (* (+ z x) y) #s(hole binary64 (+ (* x y) (* y z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (+ z x) #s(hole binary64 x))
#s(approx (+ z x) #s(hole binary64 (* x (+ 1 (/ z x)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* x y)))
#s(approx (* (+ z x) y) #s(hole binary64 (* x (+ y (/ (* y z) x)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* x (- (* -1 (/ z x)) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ (* y z) x)))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 x))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx y #s(hole binary64 y))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (* z y) #s(hole binary64 (* y z)))
#s(approx (+ (* y x) x) #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (+ x (* x y))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y (+ x z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ (* y x) x) #s(hole binary64 (* x y)))
#s(approx (+ (* y x) x) #s(hole binary64 (* y (+ x (/ x y)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx z #s(hole binary64 z))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* x y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (+ z x) #s(hole binary64 (* z (+ 1 (/ x z)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* z (+ y (/ (* x y) z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* z (- (* -1 (/ x z)) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (* x y) z)))))))
Calls

9 calls:

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

rewrite245.0ms (10%)

Memory
13.6MiB live, 238.0MiB allocated; 44ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0148841
0153752
1727744
25896744
08086732
Stop Event
iter limit
node limit
iter limit
Counts
68 → 179
Calls
Call 1
Inputs
(fma.f64 (+.f64 z x) y x)
(+.f64 z x)
z
x
y
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
(*.f64 z y)
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
(fma.f64 y x x)
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
(*.f64 (+.f64 z x) y)
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y z)))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (+ z x) #s(hole binary64 z))
#s(approx (+ z x) #s(hole binary64 (+ x z)))
#s(approx x #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y z)))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (+ (* y x) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y z)))
#s(approx (* (+ z x) y) #s(hole binary64 (+ (* x y) (* y z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (+ z x) #s(hole binary64 x))
#s(approx (+ z x) #s(hole binary64 (* x (+ 1 (/ z x)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* x y)))
#s(approx (* (+ z x) y) #s(hole binary64 (* x (+ y (/ (* y z) x)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* x (- (* -1 (/ z x)) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ (* y z) x)))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 x))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx y #s(hole binary64 y))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (* z y) #s(hole binary64 (* y z)))
#s(approx (+ (* y x) x) #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (+ x (* x y))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y (+ x z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ (* y x) x) #s(hole binary64 (* x y)))
#s(approx (+ (* y x) x) #s(hole binary64 (* y (+ x (/ x y)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx z #s(hole binary64 z))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* x y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (+ z x) #s(hole binary64 (* z (+ 1 (/ x z)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* z (+ y (/ (* x y) z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* z (- (* -1 (/ x z)) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (* x y) z)))))))
Outputs
(/.f64 (-.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))) (-.f64 (*.f64 y z) (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 z) y) #s(literal 3 binary64))) (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (+.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (*.f64 (fma.f64 y x x) (*.f64 (neg.f64 z) y)))))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 (+.f64 x z)) y) #s(literal 3 binary64))) (fma.f64 x x (+.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)) (*.f64 x (*.f64 (neg.f64 (+.f64 x z)) y)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (-.f64 (*.f64 (+.f64 x z) y) x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (pow.f64 (*.f64 y z) #s(literal 2 binary64)))) (neg.f64 (+.f64 x (*.f64 y (-.f64 x z)))))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (*.f64 (+.f64 x z) y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y z) #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x (*.f64 (+.f64 x z) y)) (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 (+.f64 x z) y) (-.f64 (*.f64 (+.f64 x z) y) x) (*.f64 x x))))
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 (+.f64 x z) y) x))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (pow.f64 (*.f64 y z) #s(literal 2 binary64))) (+.f64 x (*.f64 y (-.f64 x z))))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64))) (-.f64 x (*.f64 (+.f64 x z) y)))
(/.f64 (+.f64 (pow.f64 (*.f64 y z) #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 (*.f64 (fma.f64 y x x) y) z))))
(/.f64 (+.f64 (pow.f64 (*.f64 y z) #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64))) (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))))
(/.f64 (+.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (-.f64 x (*.f64 (+.f64 x z) y)) (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64))))
(/.f64 (+.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (*.f64 (+.f64 x z) y) (-.f64 (*.f64 (+.f64 x z) y) x) (*.f64 x x)))
(fma.f64 (-.f64 y #s(literal -1 binary64)) x (*.f64 y z))
(fma.f64 (+.f64 x z) y x)
(fma.f64 y (+.f64 x z) x)
(fma.f64 y x (-.f64 x (*.f64 (neg.f64 z) y)))
(fma.f64 y x (fma.f64 y z x))
(fma.f64 y x (+.f64 x (*.f64 y z)))
(fma.f64 y z (fma.f64 y x x))
(fma.f64 x (-.f64 y #s(literal -1 binary64)) (*.f64 y z))
(fma.f64 x y (-.f64 x (*.f64 (neg.f64 z) y)))
(fma.f64 x y (fma.f64 y z x))
(fma.f64 x y (+.f64 x (*.f64 y z)))
(fma.f64 z y (fma.f64 y x x))
(-.f64 (fma.f64 y z x) (*.f64 (neg.f64 x) y))
(-.f64 (/.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)) (-.f64 (*.f64 (+.f64 x z) y) x)) (/.f64 (*.f64 x x) (-.f64 (*.f64 (+.f64 x z) y) x)))
(-.f64 (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (+.f64 x (*.f64 y (-.f64 x z)))) (/.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (+.f64 x (*.f64 y (-.f64 x z)))))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (*.f64 (+.f64 x z) y))) (/.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)) (-.f64 x (*.f64 (+.f64 x z) y))))
(-.f64 (*.f64 y x) (-.f64 (*.f64 (neg.f64 z) y) x))
(-.f64 (fma.f64 y x x) (*.f64 (neg.f64 z) y))
(-.f64 (*.f64 y z) (neg.f64 (fma.f64 y x x)))
(-.f64 x (-.f64 (*.f64 (neg.f64 x) y) (*.f64 y z)))
(-.f64 x (*.f64 (neg.f64 (+.f64 x z)) y))
(+.f64 (fma.f64 y z x) (*.f64 y x))
(+.f64 (+.f64 x (*.f64 y z)) (*.f64 y x))
(+.f64 (/.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 (+.f64 x z) y)) (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 (+.f64 x z) y)) (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 2 binary64)))))
(+.f64 (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 y z) #s(literal 3 binary64)) (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (*.f64 (+.f64 x z) y) (-.f64 (*.f64 (+.f64 x z) y) x) (*.f64 x x))) (/.f64 (pow.f64 (*.f64 (+.f64 x z) y) #s(literal 3 binary64)) (fma.f64 (*.f64 (+.f64 x z) y) (-.f64 (*.f64 (+.f64 x z) y) x) (*.f64 x x))))
(+.f64 (*.f64 y x) (-.f64 x (*.f64 (neg.f64 z) y)))
(+.f64 (*.f64 y x) (fma.f64 y z x))
(+.f64 (*.f64 y x) (+.f64 x (*.f64 y z)))
(+.f64 (fma.f64 y x x) (*.f64 y z))
(+.f64 (*.f64 y z) (fma.f64 y x x))
(+.f64 (*.f64 (+.f64 x z) y) x)
(+.f64 x (*.f64 (+.f64 x z) y))
(/.f64 (neg.f64 (*.f64 (+.f64 x z) (-.f64 x z))) (neg.f64 (-.f64 x z)))
(/.f64 (neg.f64 (*.f64 (+.f64 x z) (-.f64 z x))) (neg.f64 (-.f64 z x)))
(/.f64 (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (neg.f64 (fma.f64 z (-.f64 z x) (*.f64 x x))))
(/.f64 (neg.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x z) (*.f64 z z))))
(/.f64 (*.f64 (+.f64 x z) (-.f64 x z)) (-.f64 x z))
(/.f64 (*.f64 (+.f64 x z) (-.f64 z x)) (-.f64 z x))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(/.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) (fma.f64 x (-.f64 x z) (*.f64 z z)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x z)) (/.f64 (*.f64 z z) (-.f64 x z)))
(-.f64 (/.f64 (*.f64 z z) (-.f64 z x)) (/.f64 (*.f64 x x) (-.f64 z x)))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 z (-.f64 z x) (*.f64 x x))) (/.f64 (pow.f64 z #s(literal 3 binary64)) (fma.f64 z (-.f64 z x) (*.f64 x x))))
(+.f64 (/.f64 (pow.f64 z #s(literal 3 binary64)) (fma.f64 x (-.f64 x z) (*.f64 z z))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (-.f64 x z) (*.f64 z z))))
(+.f64 x z)
(+.f64 z x)
z
x
y
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (*.f64 y z))
(*.f64 y z)
(*.f64 z y)
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
(*.f64 (-.f64 y #s(literal -1 binary64)) x)
(*.f64 x (-.f64 y #s(literal -1 binary64)))
(/.f64 (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 y y))) (-.f64 #s(literal 1 binary64) y))
(/.f64 (*.f64 x (+.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64))) (fma.f64 y (-.f64 y #s(literal 1 binary64)) #s(literal 1 binary64)))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 x) y) #s(literal 3 binary64))) (fma.f64 x x (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x (*.f64 (neg.f64 x) y)))))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (*.f64 y x))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (-.f64 (*.f64 y x) x)))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) x) (*.f64 x x))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) x) (-.f64 #s(literal 1 binary64) y))
(/.f64 (*.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64)) x) (fma.f64 y (-.f64 y #s(literal 1 binary64)) #s(literal 1 binary64)))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 x (*.f64 y x)))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 y x) x))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) x) (*.f64 x x)))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (-.f64 x (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))
(fma.f64 y x x)
(fma.f64 x y x)
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (*.f64 y x))) (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 x (*.f64 y x))))
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) x)) (/.f64 (*.f64 x x) (-.f64 (*.f64 y x) x)))
(-.f64 x (*.f64 (neg.f64 x) y))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) x) (*.f64 x x))) (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) x) (*.f64 x x))))
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(+.f64 (*.f64 y x) x)
(+.f64 x (*.f64 y x))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 x z) y))
(*.f64 (+.f64 x z) y)
(*.f64 y (+.f64 x z))
(/.f64 (*.f64 y (*.f64 (+.f64 x z) (-.f64 x z))) (-.f64 x z))
(/.f64 (*.f64 y (*.f64 (+.f64 x z) (-.f64 z x))) (-.f64 z x))
(/.f64 (*.f64 y (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(/.f64 (*.f64 y (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (fma.f64 x (-.f64 x z) (*.f64 z z)))
(/.f64 (-.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (*.f64 y z) (*.f64 y x)))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 z) y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (+.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (*.f64 (*.f64 y x) (*.f64 (neg.f64 z) y)))))
(/.f64 (neg.f64 (*.f64 (*.f64 (+.f64 x z) y) (*.f64 y (-.f64 x z)))) (neg.f64 (*.f64 y (-.f64 x z))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 y z) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(/.f64 (*.f64 (*.f64 (+.f64 x z) (-.f64 x z)) y) (-.f64 x z))
(/.f64 (*.f64 (*.f64 (+.f64 x z) (-.f64 z x)) y) (-.f64 z x))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) y) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) y) (fma.f64 x (-.f64 x z) (*.f64 z z)))
(/.f64 (*.f64 (*.f64 (+.f64 x z) y) (*.f64 y (-.f64 x z))) (*.f64 y (-.f64 x z)))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 y z) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 (*.f64 x z) y) y))))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 y z) #s(literal 3 binary64))) (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))
(fma.f64 y x (*.f64 y z))
(fma.f64 y z (*.f64 y x))
(fma.f64 x y (*.f64 y z))
(fma.f64 z y (*.f64 y x))
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y (-.f64 x z))) (/.f64 (pow.f64 (*.f64 y z) #s(literal 2 binary64)) (*.f64 y (-.f64 x z))))
(-.f64 (*.f64 y x) (*.f64 (neg.f64 z) y))
(-.f64 (*.f64 y z) (*.f64 (neg.f64 x) y))
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 y z) #s(literal 3 binary64)) (fma.f64 (*.f64 y z) (-.f64 (*.f64 y z) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(+.f64 (*.f64 y x) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 y x))
#s(approx (+ x (* y (+ z x))) (*.f64 y z))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 x z) y x))
#s(approx (+ z x) z)
#s(approx (+ z x) (+.f64 x z))
#s(approx x x)
#s(approx (+ x (* y (+ z x))) (*.f64 y z))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 x z) y x))
#s(approx (+ (* y x) x) (fma.f64 y x x))
#s(approx (* (+ z x) y) (*.f64 y z))
#s(approx (* (+ z x) y) (*.f64 (+.f64 x z) y))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (fma.f64 (/.f64 z x) y y) x x))
#s(approx (+ z x) x)
#s(approx (+ z x) (fma.f64 (/.f64 z x) x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (fma.f64 (/.f64 z x) y y) x x))
#s(approx (* (+ z x) y) (*.f64 y x))
#s(approx (* (+ z x) y) (*.f64 (fma.f64 (/.f64 z x) y y) x))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (fma.f64 (/.f64 z x) y y) #s(literal -1 binary64))))
#s(approx (+ z x) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (/.f64 z x) #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (fma.f64 (/.f64 z x) y y) #s(literal -1 binary64))))
#s(approx (+ (* y x) x) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (* (+ z x) y) (*.f64 (fma.f64 (/.f64 z x) y y) x))
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 x z) y x))
#s(approx y y)
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 x z) y x))
#s(approx (* z y) (*.f64 y z))
#s(approx (+ (* y x) x) x)
#s(approx (+ (* y x) x) (fma.f64 y x x))
#s(approx (* (+ z x) y) (*.f64 (+.f64 x z) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 x z) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (+.f64 (/.f64 x y) z) x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 x z) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (+.f64 (/.f64 x y) z) x) y))
#s(approx (+ (* y x) x) (*.f64 y x))
#s(approx (+ (* y x) x) (*.f64 (+.f64 (/.f64 x y) x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 (+.f64 (+.f64 (/.f64 x y) z) x)) (neg.f64 y)))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 (+.f64 (+.f64 (/.f64 x y) z) x)) (neg.f64 y)))
#s(approx (+ (* y x) x) (*.f64 (-.f64 (/.f64 x (neg.f64 y)) x) (neg.f64 y)))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 x z) y x))
#s(approx z z)
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 x z) y x))
#s(approx (+ x (* y (+ z x))) (*.f64 (fma.f64 (-.f64 y #s(literal -1 binary64)) (/.f64 x z) y) z))
#s(approx (+ z x) (fma.f64 (/.f64 x z) z z))
#s(approx (+ x (* y (+ z x))) (*.f64 (fma.f64 (-.f64 y #s(literal -1 binary64)) (/.f64 x z) y) z))
#s(approx (* (+ z x) y) (*.f64 (fma.f64 y (/.f64 x z) y) z))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 z) (neg.f64 (fma.f64 (-.f64 y #s(literal -1 binary64)) (/.f64 x z) y))))
#s(approx (+ z x) (*.f64 (neg.f64 z) (fma.f64 (/.f64 x z) #s(literal -1 binary64) #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 z) (neg.f64 (fma.f64 (-.f64 y #s(literal -1 binary64)) (/.f64 x z) y))))
#s(approx (* (+ z x) y) (*.f64 (neg.f64 z) (neg.f64 (fma.f64 y (/.f64 x z) y))))

eval35.0ms (1.4%)

Memory
2.5MiB live, 46.8MiB allocated; 8ms collecting garbage
Compiler

Compiled 3 632 to 511 computations (85.9% saved)

prune12.0ms (0.5%)

Memory
-41.9MiB live, 19.6MiB allocated; 11ms collecting garbage
Pruning

6 alts after pruning (2 fresh and 4 done)

PrunedKeptTotal
New1932195
Fresh101
Picked145
Done000
Total1956201
Accuracy
100.0%
Counts
201 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
75.8%
(fma.f64 #s(approx (+ z x) z) y x)
64.5%
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
63.2%
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
29.0%
#s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))
40.3%
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
37.2%
#s(approx (+ x (* y (+ z x))) x)
Compiler

Compiled 68 to 47 computations (30.9% saved)

series4.0ms (0.2%)

Memory
7.9MiB live, 7.9MiB allocated; 0ms collecting garbage
Counts
8 → 48
Calls
Call 1
Inputs
#s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))
(*.f64 #s(approx (+ z x) x) y)
#s(approx (+ z x) x)
x
y
(fma.f64 #s(approx (+ z x) z) y x)
#s(approx (+ z x) z)
z
Outputs
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y z)))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y z)))
#s(approx (* (+ z x) y) #s(hole binary64 (+ (* x y) (* y z))))
#s(approx (+ z x) #s(hole binary64 z))
#s(approx (+ z x) #s(hole binary64 (+ x z)))
#s(approx x #s(hole binary64 x))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y z)))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* x y)))
#s(approx (* (+ z x) y) #s(hole binary64 (* x (+ y (/ (* y z) x)))))
#s(approx (+ z x) #s(hole binary64 x))
#s(approx (+ z x) #s(hole binary64 (* x (+ 1 (/ z x)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ (* y z) x)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* x (- (* -1 (/ z x)) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y (+ x z))))
#s(approx y #s(hole binary64 y))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 x))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* x y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx z #s(hole binary64 z))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* z (+ y (/ (* x y) z)))))
#s(approx (+ z x) #s(hole binary64 (* z (+ 1 (/ x z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (* x y) z)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* z (- (* -1 (/ x z)) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
Calls

9 calls:

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

rewrite196.0ms (8%)

Memory
25.4MiB live, 213.2MiB allocated; 32ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0126745
0129708
1650689
25531689
08238632
Stop Event
iter limit
node limit
iter limit
Counts
56 → 70
Calls
Call 1
Inputs
#s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))
(*.f64 #s(approx (+ z x) x) y)
#s(approx (+ z x) x)
x
y
(fma.f64 #s(approx (+ z x) z) y x)
#s(approx (+ z x) z)
z
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y z)))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y z)))
#s(approx (* (+ z x) y) #s(hole binary64 (+ (* x y) (* y z))))
#s(approx (+ z x) #s(hole binary64 z))
#s(approx (+ z x) #s(hole binary64 (+ x z)))
#s(approx x #s(hole binary64 x))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y z)))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ (* x (+ 1 y)) (* y z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* x y)))
#s(approx (* (+ z x) y) #s(hole binary64 (* x (+ y (/ (* y z) x)))))
#s(approx (+ z x) #s(hole binary64 x))
#s(approx (+ z x) #s(hole binary64 (* x (+ 1 (/ z x)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* x (+ 1 (+ y (/ (* y z) x))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ (* y z) x)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* x (- (* -1 (/ z x)) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ (* y z) x))) 1)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 x))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (* (+ z x) y) #s(hole binary64 (* y (+ x z))))
#s(approx y #s(hole binary64 y))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 x))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* y (+ x z)))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x z))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x z))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* y (+ x (+ z (/ x y))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* y (+ (* -1 (+ x z)) (* -1 (/ x y)))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (* x y))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (+ x (+ (* x y) (* y z)))))
#s(approx z #s(hole binary64 z))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* z (+ y (/ (* x y) z)))))
#s(approx (+ z x) #s(hole binary64 (* z (+ 1 (/ x z)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* z (+ y (+ (/ x z) (/ (* x y) z))))))
#s(approx (+ x (* y (+ z x))) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
#s(approx (* (+ z x) y) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (* x y) z)))))))
#s(approx (+ z x) #s(hole binary64 (* -1 (* z (- (* -1 (/ x z)) 1)))))
#s(approx (+ (* (+ z x) y) x) #s(hole binary64 (* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* x y)) z)))))))
Outputs
#s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))
(*.f64 #s(approx (+ z x) x) y)
(*.f64 y #s(approx (+ z x) x))
#s(approx (+ z x) x)
x
y
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64))) (-.f64 x (*.f64 #s(approx (+ z x) z) y)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (-.f64 (*.f64 #s(approx (+ z x) z) y) x)))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x (*.f64 #s(approx (+ z x) z) y)) (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 #s(approx (+ z x) z) y) x))
(/.f64 (+.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x x (-.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)) (*.f64 (*.f64 #s(approx (+ z x) z) y) x))))
(/.f64 (+.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (-.f64 x (*.f64 #s(approx (+ z x) z) y)) (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64))))
(fma.f64 #s(approx (+ z x) z) y x)
(fma.f64 y #s(approx (+ z x) z) x)
(-.f64 (/.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)) (-.f64 (*.f64 #s(approx (+ z x) z) y) x)) (/.f64 (*.f64 x x) (-.f64 (*.f64 #s(approx (+ z x) z) y) x)))
(-.f64 x (*.f64 (neg.f64 #s(approx (+ z x) z)) y))
(-.f64 x (*.f64 (neg.f64 y) #s(approx (+ z x) z)))
(+.f64 (/.f64 (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 #s(approx (+ z x) z) y)) (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 #s(approx (+ z x) z) y)) (pow.f64 (*.f64 #s(approx (+ z x) z) y) #s(literal 2 binary64)))))
(+.f64 (*.f64 #s(approx (+ z x) z) y) x)
(+.f64 x (*.f64 #s(approx (+ z x) z) y))
#s(approx (+ z x) z)
z
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx (* (+ z x) y) (*.f64 z y))
#s(approx (* (+ z x) y) (*.f64 (+.f64 z x) y))
#s(approx (+ z x) z)
#s(approx (+ z x) (+.f64 z x))
#s(approx x x)
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (fma.f64 (/.f64 z x) y y) x x))
#s(approx (* (+ z x) y) (*.f64 y x))
#s(approx (* (+ z x) y) (*.f64 (fma.f64 (/.f64 z x) y y) x))
#s(approx (+ z x) x)
#s(approx (+ z x) (fma.f64 (/.f64 z x) x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (fma.f64 (/.f64 z x) y y) x x))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (fma.f64 (/.f64 z x) y y) #s(literal -1 binary64))))
#s(approx (* (+ z x) y) (*.f64 (fma.f64 (/.f64 z x) y y) x))
#s(approx (+ z x) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (/.f64 z x) #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) (fma.f64 (/.f64 z x) y y) #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx (* (+ z x) y) (*.f64 (+.f64 z x) y))
#s(approx y y)
#s(approx (+ x (* y (+ z x))) x)
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (+.f64 (/.f64 x y) z) x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (+.f64 (/.f64 x y) z) x) y))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 (+.f64 (+.f64 (/.f64 x y) z) x)) (neg.f64 y)))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 (+.f64 (+.f64 (/.f64 x y) z) x)) (neg.f64 y)))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
#s(approx (+ x (* y (+ z x))) (fma.f64 (+.f64 z x) y x))
#s(approx z z)
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (/.f64 (fma.f64 y x x) z) y) z))
#s(approx (* (+ z x) y) (*.f64 (fma.f64 y (/.f64 x z) y) z))
#s(approx (+ z x) (fma.f64 (/.f64 x z) z z))
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 (/.f64 (fma.f64 y x x) z) y) z))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 z) (neg.f64 (+.f64 (/.f64 (fma.f64 y x x) z) y))))
#s(approx (* (+ z x) y) (*.f64 (neg.f64 z) (neg.f64 (fma.f64 y (/.f64 x z) y))))
#s(approx (+ z x) (*.f64 (neg.f64 z) (fma.f64 (/.f64 x z) #s(literal -1 binary64) #s(literal -1 binary64))))
#s(approx (+ x (* y (+ z x))) (*.f64 (neg.f64 z) (neg.f64 (+.f64 (/.f64 (fma.f64 y x x) z) y))))

eval10.0ms (0.4%)

Memory
-34.7MiB live, 10.9MiB allocated; 7ms collecting garbage
Compiler

Compiled 914 to 145 computations (84.1% saved)

prune4.0ms (0.2%)

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

6 alts after pruning (0 fresh and 6 done)

PrunedKeptTotal
New52052
Fresh000
Picked022
Done044
Total52658
Accuracy
100.0%
Counts
58 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
75.8%
(fma.f64 #s(approx (+ z x) z) y x)
64.5%
#s(approx (+ x (* y (+ z x))) (fma.f64 y x x))
63.2%
#s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))
29.0%
#s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))
40.3%
#s(approx (+ x (* y (+ z x))) (*.f64 z y))
37.2%
#s(approx (+ x (* y (+ z x))) x)
Compiler

Compiled 158 to 71 computations (55.1% saved)

regimes13.0ms (0.5%)

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

4 calls:

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

Compiled 10 to 15 computations (-50% saved)

regimes13.0ms (0.5%)

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

4 calls:

5.0ms
z
3.0ms
x
3.0ms
y
2.0ms
(+.f64 x (*.f64 y (+.f64 z x)))
Results
AccuracySegmentsBranch
85.9%3(+.f64 x (*.f64 y (+.f64 z x)))
89.1%3x
98.2%3y
89.3%3z
Compiler

Compiled 10 to 15 computations (-50% saved)

regimes5.0ms (0.2%)

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

2 calls:

2.0ms
z
2.0ms
y
Results
AccuracySegmentsBranch
89.3%3z
75.8%1y
Compiler

Compiled 2 to 6 computations (-200% saved)

regimes9.0ms (0.4%)

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

3 calls:

5.0ms
x
2.0ms
z
2.0ms
(+.f64 x (*.f64 y (+.f64 z x)))
Results
AccuracySegmentsBranch
67.3%2(+.f64 x (*.f64 y (+.f64 z x)))
77.8%3x
79.6%3z
Compiler

Compiled 9 to 12 computations (-33.3% saved)

regimes7.0ms (0.3%)

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

4 calls:

2.0ms
y
2.0ms
z
2.0ms
x
1.0ms
(+.f64 x (*.f64 y (+.f64 z x)))
Results
AccuracySegmentsBranch
52.9%3(+.f64 x (*.f64 y (+.f64 z x)))
58.1%4x
64.7%3y
61.8%5z
Compiler

Compiled 10 to 15 computations (-50% saved)

regimes2.0ms (0.1%)

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

1 calls:

1.0ms
y
Results
AccuracySegmentsBranch
64.4%3y
Compiler

Compiled 1 to 3 computations (-200% saved)

regimes20.0ms (0.8%)

Memory
-17.5MiB live, 31.2MiB allocated; 27ms collecting garbage
Accuracy

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

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

4 calls:

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

Compiled 10 to 15 computations (-50% saved)

bsearch35.0ms (1.4%)

Memory
-17.9MiB live, 74.4MiB allocated; 12ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
11.0ms
0.08181117501537162
139025.43705121195
20.0ms
-1.5747700096843789
-3.079460285362236e-9
Samples
20.0ms288×0valid
Compiler

Compiled 388 to 318 computations (18% saved)

Precisions
Click to see histograms. Total time spent on operations: 13.0ms
ival-mult: 10.0ms (76% of total)
ival-add: 3.0ms (22.8% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch27.0ms (1.1%)

Memory
26.7MiB live, 73.7MiB allocated; 3ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
13.0ms
1.1712681462518115e-31
2.700094013524514e-20
11.0ms
-3.3417050797667243e-53
-6.081019226445724e-61
Samples
13.0ms304×0valid
Compiler

Compiled 390 to 316 computations (19% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-add: 3.0ms (53.6% of total)
ival-mult: 2.0ms (35.7% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch31.0ms (1.3%)

Memory
0.2MiB live, 51.9MiB allocated; 13ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
8.0ms
3.272082983733402e+84
2.805596826654364e+85
21.0ms
-9.307861780969403e+63
-2.4148434209439982e+51
Samples
11.0ms256×0valid
Compiler

Compiled 378 to 300 computations (20.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 5.0ms
ival-add: 3.0ms (61.8% of total)
ival-mult: 2.0ms (41.2% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch25.0ms (1%)

Memory
-1.2MiB live, 46.3MiB allocated; 4ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
10.0ms
139025.43705121195
913654388.3390857
13.0ms
-1.0594225330290235e-36
-3.477800390635561e-43
Samples
13.0ms272×0valid
Compiler

Compiled 382 to 309 computations (19.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 5.0ms
ival-add: 3.0ms (60.9% of total)
ival-mult: 2.0ms (40.6% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch14.0ms (0.6%)

Memory
-24.8MiB live, 21.8MiB allocated; 3ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
12.0ms
2.9158269084724327e-21
2.8015632252028224e-15
1.0ms
-1.0594225330290235e-36
-3.477800390635561e-43
Samples
7.0ms144×0valid
Compiler

Compiled 370 to 318 computations (14.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 4.0ms
ival-add: 3.0ms (74.2% of total)
ival-mult: 1.0ms (24.7% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

simplify38.0ms (1.6%)

Memory
13.6MiB live, 60.1MiB allocated; 3ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
048178
174178
2109178
3181178
4274178
5550178
63088178
Stop Event
node limit
Calls
Call 1
Inputs
(fma.f64 (+.f64 z x) y x)
(if (<=.f64 y #s(literal -1 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y)) (if (<=.f64 y #s(literal 1 binary64)) (fma.f64 #s(approx (+ z x) z) y x) #s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))))
(if (<=.f64 z #s(literal -5521397077432451/441711766194596082395824375185729628956870974218904739530401550323154944 binary64)) (fma.f64 #s(approx (+ z x) z) y x) (if (<=.f64 z #s(literal 22118353849861/340282366920938463463374607431768211456 binary64)) #s(approx (+ x (* y (+ z x))) (fma.f64 y x x)) (fma.f64 #s(approx (+ z x) z) y x)))
(if (<=.f64 z #s(literal -7000000000000000587693424265451653567214254913760660524200099840 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) (if (<=.f64 z #s(literal 21000000000000000997419234523228712393846488972860301489961723747604379165526534914048 binary64)) #s(approx (+ x (* y (+ z x))) (fma.f64 y x x)) #s(approx (+ x (* y (+ z x))) (*.f64 z y))))
(if (<=.f64 y #s(literal -8888474137022155/6129982163463555433433388108601236734474956488734408704 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) (if (<=.f64 y #s(literal 140000 binary64)) #s(approx (+ x (* y (+ z x))) x) #s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))))
(if (<=.f64 y #s(literal -8888474137022155/6129982163463555433433388108601236734474956488734408704 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) (if (<=.f64 y #s(literal 571152654438831/5192296858534827628530496329220096 binary64)) #s(approx (+ x (* y (+ z x))) x) #s(approx (+ x (* y (+ z x))) (*.f64 z y))))
#s(approx (+ x (* y (+ z x))) x)
Outputs
(fma.f64 (+.f64 z x) y x)
(if (<=.f64 y #s(literal -1 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y)) (if (<=.f64 y #s(literal 1 binary64)) (fma.f64 #s(approx (+ z x) z) y x) #s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y))))
(if (or (<=.f64 y #s(literal -1 binary64)) (not (<=.f64 y #s(literal 1 binary64)))) #s(approx (+ x (* y (+ z x))) (*.f64 (+.f64 z x) y)) (fma.f64 #s(approx (+ z x) z) y x))
(if (<=.f64 z #s(literal -5521397077432451/441711766194596082395824375185729628956870974218904739530401550323154944 binary64)) (fma.f64 #s(approx (+ z x) z) y x) (if (<=.f64 z #s(literal 22118353849861/340282366920938463463374607431768211456 binary64)) #s(approx (+ x (* y (+ z x))) (fma.f64 y x x)) (fma.f64 #s(approx (+ z x) z) y x)))
(if (or (<=.f64 z #s(literal -5521397077432451/441711766194596082395824375185729628956870974218904739530401550323154944 binary64)) (not (<=.f64 z #s(literal 22118353849861/340282366920938463463374607431768211456 binary64)))) (fma.f64 #s(approx (+ z x) z) y x) #s(approx (+ x (* y (+ z x))) (fma.f64 y x x)))
(if (<=.f64 z #s(literal -7000000000000000587693424265451653567214254913760660524200099840 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) (if (<=.f64 z #s(literal 21000000000000000997419234523228712393846488972860301489961723747604379165526534914048 binary64)) #s(approx (+ x (* y (+ z x))) (fma.f64 y x x)) #s(approx (+ x (* y (+ z x))) (*.f64 z y))))
(if (or (<=.f64 z #s(literal -7000000000000000587693424265451653567214254913760660524200099840 binary64)) (not (<=.f64 z #s(literal 21000000000000000997419234523228712393846488972860301489961723747604379165526534914048 binary64)))) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) #s(approx (+ x (* y (+ z x))) (fma.f64 y x x)))
(if (<=.f64 y #s(literal -8888474137022155/6129982163463555433433388108601236734474956488734408704 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) (if (<=.f64 y #s(literal 140000 binary64)) #s(approx (+ x (* y (+ z x))) x) #s(approx (+ x (* y (+ z x))) (*.f64 #s(approx (+ z x) x) y))))
(if (<=.f64 y #s(literal -8888474137022155/6129982163463555433433388108601236734474956488734408704 binary64)) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) (if (<=.f64 y #s(literal 571152654438831/5192296858534827628530496329220096 binary64)) #s(approx (+ x (* y (+ z x))) x) #s(approx (+ x (* y (+ z x))) (*.f64 z y))))
(if (or (<=.f64 y #s(literal -8888474137022155/6129982163463555433433388108601236734474956488734408704 binary64)) (not (<=.f64 y #s(literal 571152654438831/5192296858534827628530496329220096 binary64)))) #s(approx (+ x (* y (+ z x))) (*.f64 z y)) #s(approx (+ x (* y (+ z x))) x))
#s(approx (+ x (* y (+ z x))) x)

derivations245.0ms (10%)

Memory
28.9MiB live, 207.9MiB allocated; 28ms collecting garbage
Stop Event
done
Compiler

Compiled 178 to 52 computations (70.8% saved)

preprocess48.0ms (2%)

Memory
4.3MiB live, 51.4MiB allocated; 24ms collecting garbage
Compiler

Compiled 370 to 116 computations (68.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...