Numeric.Log:$cexpm1 from log-domain-0.10.2.1, B

Time bar (total: 2.0s)

start0.0ms (0%)

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

analyze0.0ms (0%)

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

Compiled 9 to 7 computations (22.2% saved)

sample723.0ms (35.8%)

Memory
35.5MiB live, 970.5MiB allocated; 271ms collecting garbage
Samples
390.0ms8 255×0valid
0.0ms2valid
Precisions
Click to see histograms. Total time spent on operations: 176.0ms
ival-mult: 94.0ms (53.3% of total)
ival-add: 77.0ms (43.7% of total)
ival-assert: 3.0ms (1.7% of total)
adjust: 2.0ms (1.1% of total)
Bogosity

explain86.0ms (4.3%)

Memory
26.5MiB live, 123.2MiB allocated; 9ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(+.f64 (*.f64 x y) x)
00-0-y
00-0-(+.f64 (+.f64 (*.f64 x y) x) y)
00-0-(*.f64 x y)
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
21.0ms512×0valid
Compiler

Compiled 45 to 19 computations (57.8% saved)

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

preprocess201.0ms (10%)

Memory
-12.0MiB live, 221.1MiB allocated; 35ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01852
14747
210245
322443
433842
554142
6149142
7410642
057
087
1137
2297
3547
41057
51937
65857
724867
868957
082166
Stop Event
iter limit
node limit
iter limit
node limit
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x y) x) y)
Outputs
(+.f64 (+.f64 (*.f64 x y) x) y)
(fma.f64 (-.f64 x #s(literal -1 binary64)) y x)
Symmetry

(sort x y)

Compiler

Compiled 7 to 5 computations (28.6% saved)

eval0.0ms (0%)

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

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

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

Compiled 7 to 5 computations (28.6% saved)

series5.0ms (0.2%)

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

6 calls:

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

rewrite248.0ms (12.3%)

Memory
12.1MiB live, 201.5MiB allocated; 23ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
068303
072285
1348283
23269281
09209252
Stop Event
iter limit
node limit
iter limit
Counts
27 → 130
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x y) x) y)
(+.f64 (*.f64 x y) x)
(*.f64 x y)
x
y
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 y))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ y (* x (+ 1 y)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (* x y) #s(hole binary64 (* x y)))
#s(approx x #s(hole binary64 x))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* x (+ 1 (+ y (/ y x))))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ y x))) 1)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 x))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ x (* y (+ 1 x)))))
#s(approx (+ (* x y) x) #s(hole binary64 x))
#s(approx (+ (* x y) x) #s(hole binary64 (+ x (* x y))))
#s(approx y #s(hole binary64 y))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* y (+ 1 x))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* y (+ 1 (+ x (/ x y))))))
#s(approx (+ (* x y) x) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) x) #s(hole binary64 (* y (+ x (/ x y)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* y (- (+ (* -1 x) (* -1 (/ x y))) 1)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
Outputs
(/.f64 (neg.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y (neg.f64 (fma.f64 y x x)))))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (-.f64 (fma.f64 y x y) x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 (+.f64 y x) #s(literal 2 binary64)))) (neg.f64 (-.f64 (*.f64 y x) (+.f64 y x))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (+.f64 y x) #s(literal 3 binary64)))) (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (pow.f64 (+.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 y x) (+.f64 y x))))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (*.f64 y y) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))))) (neg.f64 (neg.f64 (-.f64 y (fma.f64 y x x)))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y y)))) (neg.f64 (neg.f64 (-.f64 (fma.f64 y x x) y))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 (fma.f64 y x x) (-.f64 (fma.f64 y x x) y) (*.f64 y y)))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 y (-.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (fma.f64 y x y) #s(literal 2 binary64))))) (neg.f64 (neg.f64 (-.f64 x (fma.f64 y x y)))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 (fma.f64 y x y) (-.f64 (fma.f64 y x y) x) (*.f64 x x)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)))) (neg.f64 (fma.f64 x x (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (*.f64 x (neg.f64 (fma.f64 y x y)))))))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (fma.f64 y x y) x))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 (+.f64 y x) #s(literal 2 binary64))) (-.f64 (*.f64 y x) (+.f64 y x)))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (fma.f64 y x y) #s(literal 3 binary64))) (fma.f64 x x (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (*.f64 x (neg.f64 (fma.f64 y x y))))))
(/.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (fma.f64 y x x) #s(literal 3 binary64))) (fma.f64 y y (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y (neg.f64 (fma.f64 y x x))))))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (+.f64 y x) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (pow.f64 (+.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 y x) (+.f64 y x)))))
(/.f64 (neg.f64 (-.f64 (*.f64 y y) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))) (neg.f64 (-.f64 y (fma.f64 y x x))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y y))) (neg.f64 (-.f64 (fma.f64 y x x) y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 (fma.f64 y x x) (-.f64 (fma.f64 y x x) y) (*.f64 y y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (fma.f64 y x y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (-.f64 (*.f64 x x) (*.f64 (fma.f64 y x y) x)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (fma.f64 y x y) (-.f64 (fma.f64 y x y) x) (*.f64 x x))))
(/.f64 (-.f64 (*.f64 y y) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))) (-.f64 y (fma.f64 y x x)))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (fma.f64 y x y) #s(literal 2 binary64))) (-.f64 x (fma.f64 y x y)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y y)) (-.f64 (fma.f64 y x x) y))
(/.f64 (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (-.f64 (*.f64 x x) (*.f64 (fma.f64 y x y) x))))
(/.f64 (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (fma.f64 y x y) (-.f64 (fma.f64 y x y) x) (*.f64 x x)))
(/.f64 (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 (fma.f64 y x x) (-.f64 (fma.f64 y x x) y) (*.f64 y y)))
(/.f64 (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (-.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64))))
(fma.f64 (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) #s(literal 1 binary64)) (/.f64 x (-.f64 #s(literal 1 binary64) y)) y)
(fma.f64 (/.f64 x (-.f64 #s(literal 1 binary64) y)) (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) #s(literal 1 binary64)) y)
(fma.f64 (/.f64 y (-.f64 #s(literal 1 binary64) x)) (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64)) x)
(fma.f64 (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) #s(literal 1 binary64)) (/.f64 y (-.f64 #s(literal 1 binary64) x)) x)
(fma.f64 (/.f64 y #s(literal 1 binary64)) (-.f64 x #s(literal -1 binary64)) x)
(fma.f64 (/.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal -1 binary64)) y)
(fma.f64 (-.f64 x #s(literal -1 binary64)) (/.f64 y #s(literal 1 binary64)) x)
(fma.f64 (-.f64 x #s(literal -1 binary64)) y x)
(fma.f64 (-.f64 y #s(literal -1 binary64)) (/.f64 x #s(literal 1 binary64)) y)
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
(fma.f64 y (-.f64 x #s(literal -1 binary64)) x)
(fma.f64 y x (+.f64 y x))
(fma.f64 x (-.f64 y #s(literal -1 binary64)) y)
(fma.f64 x y (+.f64 y x))
(-.f64 (/.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (-.f64 (fma.f64 y x y) x)) (/.f64 (*.f64 x x) (-.f64 (fma.f64 y x y) x)))
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) (+.f64 y x))) (/.f64 (pow.f64 (+.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) (+.f64 y x))))
(-.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y y (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y (neg.f64 (fma.f64 y x x)))))) (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (fma.f64 y y (+.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (*.f64 y (neg.f64 (fma.f64 y x x)))))))
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (*.f64 x (neg.f64 (fma.f64 y x y)))))) (/.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (fma.f64 x x (+.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (*.f64 x (neg.f64 (fma.f64 y x y)))))))
(-.f64 (/.f64 (*.f64 y y) (-.f64 y (fma.f64 y x x))) (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (-.f64 y (fma.f64 y x x))))
(-.f64 (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)) (-.f64 (fma.f64 y x x) y)) (/.f64 (*.f64 y y) (-.f64 (fma.f64 y x x) y)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (fma.f64 y x y))) (/.f64 (pow.f64 (fma.f64 y x y) #s(literal 2 binary64)) (-.f64 x (fma.f64 y x y))))
(-.f64 (+.f64 y x) (*.f64 (neg.f64 x) y))
(-.f64 y (*.f64 (neg.f64 (-.f64 y #s(literal -1 binary64))) x))
(-.f64 y (neg.f64 (fma.f64 y x x)))
(-.f64 x (-.f64 (*.f64 (neg.f64 x) y) y))
(-.f64 x (*.f64 (neg.f64 (-.f64 x #s(literal -1 binary64))) y))
(-.f64 x (neg.f64 (fma.f64 y x y)))
(+.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (fma.f64 y x x) (-.f64 (fma.f64 y x x) y) (*.f64 y y))) (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (fma.f64 (fma.f64 y x x) (-.f64 (fma.f64 y x x) y) (*.f64 y y))))
(+.f64 (/.f64 (pow.f64 (fma.f64 y x x) #s(literal 3 binary64)) (fma.f64 y (-.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x x) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y (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 (fma.f64 y x y) (-.f64 (fma.f64 y x y) x) (*.f64 x x))) (/.f64 (pow.f64 (fma.f64 y x y) #s(literal 3 binary64)) (fma.f64 (fma.f64 y x y) (-.f64 (fma.f64 y x y) x) (*.f64 x x))))
(+.f64 (+.f64 y x) (*.f64 y x))
(+.f64 (fma.f64 y x y) x)
(+.f64 (fma.f64 y x x) y)
(+.f64 (*.f64 y x) (+.f64 y x))
(+.f64 y (fma.f64 y x x))
(+.f64 x (fma.f64 y x y))
(*.f64 (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) #s(literal 1 binary64)) (/.f64 x (-.f64 #s(literal 1 binary64) y)))
(*.f64 (/.f64 x (-.f64 #s(literal 1 binary64) y)) (/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) #s(literal 1 binary64)))
(*.f64 (/.f64 x #s(literal 1 binary64)) (-.f64 y #s(literal -1 binary64)))
(*.f64 (-.f64 y #s(literal -1 binary64)) (/.f64 x #s(literal 1 binary64)))
(*.f64 (-.f64 y #s(literal -1 binary64)) x)
(*.f64 x (-.f64 y #s(literal -1 binary64)))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (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 x (-.f64 #s(literal 1 binary64) (*.f64 y y)))) (neg.f64 (-.f64 #s(literal 1 binary64) y)))
(/.f64 (neg.f64 (*.f64 x (+.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64)))) (neg.f64 (fma.f64 y (-.f64 y #s(literal 1 binary64)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x x)))) (neg.f64 (neg.f64 (-.f64 (*.f64 y x) x))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) (neg.f64 (neg.f64 (-.f64 x (*.f64 y x)))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 x (-.f64 x (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) x) (*.f64 x x)))))
(/.f64 (neg.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) x)) (neg.f64 (-.f64 #s(literal 1 binary64) y)))
(/.f64 (neg.f64 (*.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64)) x)) (neg.f64 (fma.f64 y (-.f64 y #s(literal 1 binary64)) #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 y x) #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 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (-.f64 (*.f64 y x) x)))
(/.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 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 (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 (*.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 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 y x) x))
(/.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 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))))
(/.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)))
(fma.f64 y x x)
(fma.f64 x y x)
(-.f64 (/.f64 (pow.f64 x #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 (pow.f64 (*.f64 y x) #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 (/.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 (/.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 x (*.f64 (neg.f64 x) y))
(+.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 (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 y x) x)
(+.f64 x (*.f64 y x))
(*.f64 y x)
(*.f64 x y)
x
y
#s(approx (+ (+ (* x y) x) y) y)
#s(approx (+ (+ (* x y) x) y) (+.f64 (fma.f64 y x x) y))
#s(approx (+ (* x y) x) (fma.f64 y x x))
#s(approx (* x y) (*.f64 y x))
#s(approx x x)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (+ (* x y) x) y) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ (+ (* x y) x) y) (*.f64 (neg.f64 x) (-.f64 (+.f64 (/.f64 y x) y) #s(literal 1 binary64))))
#s(approx (+ (* x y) x) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) (+.f64 (fma.f64 y x x) y))
#s(approx (+ (* x y) x) x)
#s(approx (+ (* x y) x) (fma.f64 y x x))
#s(approx y y)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 x y) x) y y))
#s(approx (+ (* x y) x) (*.f64 y x))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))
#s(approx (+ (+ (* x y) x) y) (*.f64 (fma.f64 #s(literal -1 binary64) x #s(literal -1 binary64)) (neg.f64 y)))
#s(approx (+ (+ (* x y) x) y) (*.f64 (-.f64 (+.f64 (/.f64 x y) x) #s(literal 1 binary64)) (neg.f64 y)))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))

eval29.0ms (1.4%)

Memory
-22.7MiB live, 22.4MiB allocated; 3ms collecting garbage
Compiler

Compiled 2 285 to 373 computations (83.7% saved)

prune5.0ms (0.3%)

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

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New1256131
Fresh000
Picked101
Done000
Total1266132
Accuracy
100.0%
Counts
132 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
70.5%
(+.f64 #s(approx (+ (* x y) x) x) y)
63.8%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
65.8%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
35.3%
#s(approx (+ (+ (* x y) x) y) y)
37.5%
#s(approx (+ (+ (* x y) x) y) x)
Compiler

Compiled 114 to 74 computations (35.1% saved)

series6.0ms (0.3%)

Memory
6.7MiB live, 6.7MiB allocated; 0ms collecting garbage
Counts
11 → 43
Calls
Call 1
Inputs
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
(-.f64 y #s(literal -1 binary64))
y
#s(literal -1 binary64)
x
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
(+.f64 #s(approx (+ (* x y) x) x) y)
#s(approx (+ (* x y) x) x)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
(fma.f64 y x x)
Outputs
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 y))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (+ y (* x (+ 1 y)))))
#s(approx x #s(hole binary64 x))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 y))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ y (* x (+ 1 y)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* y x) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* x (+ 1 (+ y (/ y x))))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* x (+ 1 (+ y (/ y x))))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* x (+ (* -1 (+ 1 y)) (* -1 (/ y x)))))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ y x))) 1)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 x))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (+ x (* y (+ 1 x)))))
#s(approx (- y -1) #s(hole binary64 1))
#s(approx (- y -1) #s(hole binary64 (+ 1 y)))
#s(approx y #s(hole binary64 y))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 x))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ x (* y (+ 1 x)))))
#s(approx (+ (* x y) x) #s(hole binary64 x))
#s(approx (+ (* x y) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* y x) x) #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* y (+ 1 x))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* y (+ 1 (+ x (/ x y))))))
#s(approx (- y -1) #s(hole binary64 y))
#s(approx (- y -1) #s(hole binary64 (* y (+ 1 (/ 1 y)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* y (+ 1 x))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* y (+ 1 (+ x (/ x y))))))
#s(approx (+ (* x y) x) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) x) #s(hole binary64 (* y (+ x (/ 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 (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* y (- (+ (* -1 x) (* -1 (/ x y))) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* y (- (+ (* -1 x) (* -1 (/ x y))) 1)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
Calls

6 calls:

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

rewrite194.0ms (9.6%)

Memory
-15.3MiB live, 183.7MiB allocated; 27ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0103607
0106529
1488524
04216514
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
54 → 152
Calls
Call 1
Inputs
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
(-.f64 y #s(literal -1 binary64))
y
#s(literal -1 binary64)
x
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
(+.f64 #s(approx (+ (* x y) x) x) y)
#s(approx (+ (* x y) x) x)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
(fma.f64 y x x)
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 y))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (+ y (* x (+ 1 y)))))
#s(approx x #s(hole binary64 x))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 y))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ y (* x (+ 1 y)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* y x) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* x (+ 1 (+ y (/ y x))))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* x (+ 1 (+ y (/ y x))))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* x (+ (* -1 (+ 1 y)) (* -1 (/ y x)))))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* x (- (+ (* -1 y) (* -1 (/ y x))) 1)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 x))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (+ x (* y (+ 1 x)))))
#s(approx (- y -1) #s(hole binary64 1))
#s(approx (- y -1) #s(hole binary64 (+ 1 y)))
#s(approx y #s(hole binary64 y))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 x))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ x (* y (+ 1 x)))))
#s(approx (+ (* x y) x) #s(hole binary64 x))
#s(approx (+ (* x y) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* y x) x) #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* y (+ 1 x))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* y (+ 1 (+ x (/ x y))))))
#s(approx (- y -1) #s(hole binary64 y))
#s(approx (- y -1) #s(hole binary64 (* y (+ 1 (/ 1 y)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* y (+ 1 x))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* y (+ 1 (+ x (/ x y))))))
#s(approx (+ (* x y) x) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) x) #s(hole binary64 (* y (+ x (/ 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 (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* y (- (+ (* -1 x) (* -1 (/ x y))) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (* -1 (* y (- (+ (* -1 x) (* -1 (/ x y))) 1)))))
#s(approx (+ (* x y) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
#s(approx (+ (* y x) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ x y)))))))
Outputs
(/.f64 (-.f64 (pow.f64 (fma.f64 x y y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (fma.f64 x y y) x))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) #s(literal 2 binary64)) (*.f64 (+.f64 x y) (+.f64 x y))) (-.f64 (*.f64 x y) (+.f64 x y)))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (neg.f64 (fma.f64 x y y)) #s(literal 3 binary64))) (fma.f64 x x (+.f64 (pow.f64 (fma.f64 x y y) #s(literal 2 binary64)) (*.f64 x (neg.f64 (fma.f64 x y y))))))
(/.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 (-.f64 #s(literal -1 binary64) y) x) #s(literal 3 binary64))) (fma.f64 y y (+.f64 (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)) (*.f64 y (*.f64 (-.f64 #s(literal -1 binary64) y) x)))))
(/.f64 (+.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (pow.f64 (+.f64 x y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 x y) #s(literal 2 binary64)) (-.f64 (*.f64 (+.f64 x y) (+.f64 x y)) (*.f64 (*.f64 x y) (+.f64 x y)))))
(/.f64 (neg.f64 (-.f64 (*.f64 y y) (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)))) (neg.f64 (-.f64 y (fma.f64 x y x))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)) (*.f64 y y))) (neg.f64 (-.f64 (fma.f64 x y x) y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 x y x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 (fma.f64 x y x) (-.f64 (fma.f64 x y x) y) (*.f64 y y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 x y x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y (fma.f64 x y x)) (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (fma.f64 x y y) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (fma.f64 x y y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 x y y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (fma.f64 x y y) (-.f64 (fma.f64 x y y) x) (*.f64 x x))))
(/.f64 (-.f64 (*.f64 y y) (pow.f64 (fma.f64 x y x) #s(literal 2 binary64))) (-.f64 y (fma.f64 x y x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)) (*.f64 y y)) (-.f64 (fma.f64 x y x) y))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (fma.f64 x y y) #s(literal 2 binary64))) (-.f64 x (fma.f64 x y y)))
(/.f64 (+.f64 (pow.f64 (fma.f64 x y x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 (fma.f64 x y x) (-.f64 (fma.f64 x y x) y) (*.f64 y y)))
(/.f64 (+.f64 (pow.f64 (fma.f64 x y x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (-.f64 y (fma.f64 x y x)) (pow.f64 (fma.f64 x y x) #s(literal 2 binary64))))
(/.f64 (+.f64 (pow.f64 (fma.f64 x y y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 (pow.f64 (fma.f64 x y y) #s(literal 2 binary64)) (-.f64 (*.f64 x x) (*.f64 (fma.f64 x y y) x))))
(/.f64 (+.f64 (pow.f64 (fma.f64 x y y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (fma.f64 x y y) (-.f64 (fma.f64 x y y) x) (*.f64 x x)))
(fma.f64 (-.f64 x #s(literal -1 binary64)) y x)
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
(fma.f64 x (-.f64 y #s(literal -1 binary64)) y)
(fma.f64 x y (+.f64 x y))
(fma.f64 y (-.f64 x #s(literal -1 binary64)) x)
(fma.f64 y x (+.f64 x y))
(-.f64 (/.f64 (*.f64 y y) (-.f64 y (fma.f64 x y x))) (/.f64 (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)) (-.f64 y (fma.f64 x y x))))
(-.f64 (/.f64 (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)) (-.f64 (fma.f64 x y x) y)) (/.f64 (*.f64 y y) (-.f64 (fma.f64 x y x) y)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (fma.f64 x y y))) (/.f64 (pow.f64 (fma.f64 x y y) #s(literal 2 binary64)) (-.f64 x (fma.f64 x y y))))
(-.f64 (+.f64 x y) (*.f64 (neg.f64 x) y))
(-.f64 x (-.f64 (*.f64 (neg.f64 x) y) y))
(-.f64 x (*.f64 (neg.f64 (-.f64 x #s(literal -1 binary64))) y))
(-.f64 x (neg.f64 (fma.f64 x y y)))
(-.f64 y (*.f64 (-.f64 #s(literal -1 binary64) y) x))
(+.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (fma.f64 x y x) (-.f64 (fma.f64 x y x) y) (*.f64 y y))) (/.f64 (pow.f64 (fma.f64 x y x) #s(literal 3 binary64)) (fma.f64 (fma.f64 x y x) (-.f64 (fma.f64 x y x) y) (*.f64 y y))))
(+.f64 (/.f64 (pow.f64 (fma.f64 x y x) #s(literal 3 binary64)) (fma.f64 y (-.f64 y (fma.f64 x y x)) (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y (fma.f64 x y x)) (pow.f64 (fma.f64 x y x) #s(literal 2 binary64)))))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (fma.f64 x y y) (-.f64 (fma.f64 x y y) x) (*.f64 x x))) (/.f64 (pow.f64 (fma.f64 x y y) #s(literal 3 binary64)) (fma.f64 (fma.f64 x y y) (-.f64 (fma.f64 x y y) x) (*.f64 x x))))
(+.f64 (+.f64 x y) (*.f64 x y))
(+.f64 (fma.f64 x y y) x)
(+.f64 (fma.f64 x y x) y)
(+.f64 (*.f64 x y) (+.f64 x y))
(+.f64 x (fma.f64 x y y))
(+.f64 y (fma.f64 x y x))
(*.f64 (-.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal -1 binary64)) y)
(*.f64 y (-.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal -1 binary64)))
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -2 binary64))) y) (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -1 binary64))))
(/.f64 (*.f64 (+.f64 (pow.f64 y #s(literal -3 binary64)) #s(literal 1 binary64)) y) (-.f64 (+.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -2 binary64))) (pow.f64 y #s(literal -1 binary64))))
(/.f64 (*.f64 y (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -2 binary64)))) (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -1 binary64))))
(/.f64 (*.f64 y (+.f64 (pow.f64 y #s(literal -3 binary64)) #s(literal 1 binary64))) (-.f64 (+.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -2 binary64))) (pow.f64 y #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y))) (neg.f64 (-.f64 #s(literal 1 binary64) y)))
(/.f64 (neg.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 y (-.f64 y #s(literal 1 binary64)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 y y (-.f64 #s(literal 1 binary64) y))))
(/.f64 (neg.f64 (fma.f64 y y #s(literal -1 binary64))) (-.f64 #s(literal 1 binary64) y))
(/.f64 (fma.f64 y y #s(literal -1 binary64)) (-.f64 y #s(literal 1 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (-.f64 #s(literal 1 binary64) y))
(/.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 y y (-.f64 #s(literal 1 binary64) y)))
(/.f64 (-.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 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) y)) (/.f64 (*.f64 y y) (-.f64 #s(literal 1 binary64) y)))
(-.f64 (/.f64 (*.f64 y y) (-.f64 y #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 y #s(literal 1 binary64))))
(-.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y y (-.f64 #s(literal 1 binary64) y))) (/.f64 #s(literal -1 binary64) (fma.f64 y y (-.f64 #s(literal 1 binary64) y))))
(-.f64 y (*.f64 (neg.f64 y) (pow.f64 y #s(literal -1 binary64))))
(-.f64 y (*.f64 (neg.f64 (pow.f64 y #s(literal -1 binary64))) y))
(-.f64 y #s(literal -1 binary64))
(+.f64 (/.f64 #s(literal 1 binary64) (fma.f64 y (-.f64 y #s(literal 1 binary64)) #s(literal 1 binary64))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y #s(literal 1 binary64)) #s(literal 1 binary64))))
(+.f64 #s(literal 1 binary64) y)
(+.f64 y #s(literal 1 binary64))
y
#s(literal -1 binary64)
x
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
(/.f64 (-.f64 (*.f64 y y) (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 2 binary64))) (-.f64 y #s(approx (+ (* x y) x) x)))
(/.f64 (neg.f64 (*.f64 (+.f64 #s(approx (+ (* x y) x) x) y) (-.f64 #s(approx (+ (* x y) x) x) y))) (neg.f64 (-.f64 #s(approx (+ (* x y) x) x) y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 #s(approx (+ (* x y) x) x) #s(approx (+ (* x y) x) x) (*.f64 y (-.f64 y #s(approx (+ (* x y) x) x))))))
(/.f64 (*.f64 (+.f64 #s(approx (+ (* x y) x) x) y) (-.f64 #s(approx (+ (* x y) x) x) y)) (-.f64 #s(approx (+ (* x y) x) x) y))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 3 binary64))) (fma.f64 y y (-.f64 (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 2 binary64)) (*.f64 #s(approx (+ (* x y) x) x) y))))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 3 binary64))) (fma.f64 #s(approx (+ (* x y) x) x) #s(approx (+ (* x y) x) x) (*.f64 y (-.f64 y #s(approx (+ (* x y) x) x)))))
(-.f64 (/.f64 (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 2 binary64)) (-.f64 #s(approx (+ (* x y) x) x) y)) (/.f64 (*.f64 y y) (-.f64 #s(approx (+ (* x y) x) x) y)))
(+.f64 (/.f64 (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)) (fma.f64 #s(approx (+ (* x y) x) x) #s(approx (+ (* x y) x) x) (*.f64 y (-.f64 y #s(approx (+ (* x y) x) x))))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 #s(approx (+ (* x y) x) x) #s(approx (+ (* x y) x) x) (*.f64 y (-.f64 y #s(approx (+ (* x y) x) x))))))
(+.f64 #s(approx (+ (* x y) x) x) y)
(+.f64 y #s(approx (+ (* x y) x) x))
#s(approx (+ (* x y) x) x)
#s(approx (+ (+ (* x y) x) y) (fma.f64 x y x))
(*.f64 (-.f64 y #s(literal -1 binary64)) x)
(*.f64 x (-.f64 y #s(literal -1 binary64)))
(/.f64 (*.f64 (fma.f64 y y #s(literal -1 binary64)) 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 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 x (fma.f64 y y #s(literal -1 binary64))) (-.f64 y #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 x y) #s(literal 2 binary64)) (*.f64 x (*.f64 (neg.f64 x) y)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 x y) #s(literal 2 binary64)) (*.f64 x x))) (neg.f64 (-.f64 (*.f64 x y) x)))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 x y) #s(literal 2 binary64)))) (neg.f64 (-.f64 x (*.f64 x y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 x (-.f64 x (*.f64 x y)) (pow.f64 (*.f64 x y) #s(literal 2 binary64)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 x y) (-.f64 (*.f64 x y) x) (*.f64 x x))))
(/.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 y (-.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 (pow.f64 (*.f64 x y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (*.f64 x y) x))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 x y) #s(literal 2 binary64))) (-.f64 x (*.f64 x y)))
(/.f64 (+.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 x (-.f64 x (*.f64 x y)) (pow.f64 (*.f64 x y) #s(literal 2 binary64))))
(/.f64 (+.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (*.f64 x y) (-.f64 (*.f64 x y) x) (*.f64 x x)))
(fma.f64 x y x)
(fma.f64 y x x)
(-.f64 (/.f64 (pow.f64 (*.f64 x y) #s(literal 2 binary64)) (-.f64 (*.f64 x y) x)) (/.f64 (*.f64 x x) (-.f64 (*.f64 x y) x)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (*.f64 x y))) (/.f64 (pow.f64 (*.f64 x y) #s(literal 2 binary64)) (-.f64 x (*.f64 x y))))
(-.f64 x (*.f64 (neg.f64 x) y))
(+.f64 (/.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 x y)) (pow.f64 (*.f64 x y) #s(literal 2 binary64)))) (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x (-.f64 x (*.f64 x y)) (pow.f64 (*.f64 x y) #s(literal 2 binary64)))))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (*.f64 x y) (-.f64 (*.f64 x y) x) (*.f64 x x))) (/.f64 (pow.f64 (*.f64 x y) #s(literal 3 binary64)) (fma.f64 (*.f64 x y) (-.f64 (*.f64 x y) x) (*.f64 x x))))
(+.f64 (*.f64 x y) x)
(+.f64 x (*.f64 x y))
#s(approx (+ (+ (* x y) x) y) y)
#s(approx (+ (+ (* x y) x) y) (+.f64 (fma.f64 x y x) y))
#s(approx x x)
#s(approx (+ (+ (* x y) x) y) y)
#s(approx (+ (+ (* x y) x) y) (+.f64 (fma.f64 x y x) y))
#s(approx (+ (* x y) x) (fma.f64 x y x))
#s(approx (+ (* x y) x) (fma.f64 x y x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 x y x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 x y x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (+ (* x y) x) y) (*.f64 (neg.f64 x) (-.f64 #s(literal -1 binary64) y)))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (* x y) x) (*.f64 (neg.f64 x) (-.f64 #s(literal -1 binary64) y)))
#s(approx (+ (* x y) x) (*.f64 (neg.f64 x) (-.f64 #s(literal -1 binary64) y)))
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) (+.f64 (fma.f64 x y x) y))
#s(approx (- y -1) #s(literal 1 binary64))
#s(approx (- y -1) (-.f64 y #s(literal -1 binary64)))
#s(approx y y)
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) (+.f64 (fma.f64 x y x) y))
#s(approx (+ (* x y) x) x)
#s(approx (+ (* x y) x) (fma.f64 x y x))
#s(approx (+ (* x y) x) x)
#s(approx (+ (* x y) x) (fma.f64 x y x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 x y y))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 x y) x) y y))
#s(approx (- y -1) y)
#s(approx (- y -1) (-.f64 y #s(literal -1 binary64)))
#s(approx (+ (+ (* x y) x) y) (fma.f64 x y y))
#s(approx (+ (+ (* x y) x) y) (fma.f64 (+.f64 (/.f64 x y) x) y y))
#s(approx (+ (* x y) x) (*.f64 x y))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))
#s(approx (+ (* x y) x) (*.f64 x y))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))
#s(approx (+ (+ (* x y) x) y) (neg.f64 (neg.f64 (fma.f64 x y y))))
#s(approx (+ (+ (* x y) x) y) (*.f64 (fma.f64 (+.f64 (/.f64 x y) x) #s(literal -1 binary64) #s(literal -1 binary64)) (neg.f64 y)))
#s(approx (+ (+ (* x y) x) y) (neg.f64 (neg.f64 (fma.f64 x y y))))
#s(approx (+ (+ (* x y) x) y) (*.f64 (fma.f64 (+.f64 (/.f64 x y) x) #s(literal -1 binary64) #s(literal -1 binary64)) (neg.f64 y)))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))

eval13.0ms (0.7%)

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

Compiled 2 443 to 387 computations (84.2% saved)

prune7.0ms (0.4%)

Memory
-33.0MiB live, 12.8MiB allocated; 5ms collecting garbage
Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New1401141
Fresh101
Picked055
Done000
Total1416147
Accuracy
100.0%
Counts
147 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
63.8%
(fma.f64 #s(approx (- y -1) y) x y)
70.5%
(+.f64 #s(approx (+ (* x y) x) x) y)
65.8%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
35.3%
#s(approx (+ (+ (* x y) x) y) y)
37.5%
#s(approx (+ (+ (* x y) x) y) x)
Compiler

Compiled 53 to 36 computations (32.1% saved)

series2.0ms (0.1%)

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

6 calls:

TimeVariablePointExpression
0.0ms
x
@-inf
((+ (* (- y -1) x) y) (- y -1) y x)
0.0ms
y
@-inf
((+ (* (- y -1) x) y) (- y -1) y x)
0.0ms
x
@inf
((+ (* (- y -1) x) y) (- y -1) y x)
0.0ms
y
@inf
((+ (* (- y -1) x) y) (- y -1) y x)
0.0ms
x
@0
((+ (* (- y -1) x) y) (- y -1) y x)

rewrite92.0ms (4.5%)

Memory
23.2MiB live, 119.8MiB allocated; 12ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
056220
058205
1324204
03234186
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
21 → 34
Calls
Call 1
Inputs
(fma.f64 #s(approx (- y -1) y) x y)
#s(approx (- y -1) y)
y
x
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 y))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (+ y (* x (+ 1 y)))))
#s(approx x #s(hole binary64 x))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* x (+ 1 (+ y (/ y x))))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* x (+ (* -1 (+ 1 y)) (* -1 (/ y x)))))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 x))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (+ x (* y (+ 1 x)))))
#s(approx (- y -1) #s(hole binary64 1))
#s(approx (- y -1) #s(hole binary64 (+ 1 y)))
#s(approx y #s(hole binary64 y))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* y (+ 1 x))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* y (+ 1 (+ x (/ x y))))))
#s(approx (- y -1) #s(hole binary64 y))
#s(approx (- y -1) #s(hole binary64 (* y (+ 1 (/ 1 y)))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
#s(approx (+ (* (- y -1) x) y) #s(hole binary64 (* -1 (* y (- (+ (* -1 x) (* -1 (/ x y))) 1)))))
Outputs
(/.f64 (-.f64 (*.f64 y y) (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64))) (-.f64 y (*.f64 x #s(approx (- y -1) y))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)) (*.f64 y y))) (neg.f64 (-.f64 (*.f64 x #s(approx (- y -1) y)) y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y (*.f64 x #s(approx (- y -1) y))) (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)) (*.f64 y y)) (-.f64 (*.f64 x #s(approx (- y -1) y)) y))
(/.f64 (+.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y y (-.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)) (*.f64 (*.f64 x #s(approx (- y -1) y)) y))))
(/.f64 (+.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))) (fma.f64 y (-.f64 y (*.f64 x #s(approx (- y -1) y))) (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64))))
(fma.f64 x #s(approx (- y -1) y) y)
(fma.f64 #s(approx (- y -1) y) x y)
(-.f64 (/.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)) (-.f64 (*.f64 x #s(approx (- y -1) y)) y)) (/.f64 (*.f64 y y) (-.f64 (*.f64 x #s(approx (- y -1) y)) y)))
(-.f64 y (*.f64 (neg.f64 x) #s(approx (- y -1) y)))
(-.f64 y (*.f64 (neg.f64 #s(approx (- y -1) y)) x))
(+.f64 (/.f64 (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 3 binary64)) (fma.f64 y (-.f64 y (*.f64 x #s(approx (- y -1) y))) (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y (*.f64 x #s(approx (- y -1) y))) (pow.f64 (*.f64 x #s(approx (- y -1) y)) #s(literal 2 binary64)))))
(+.f64 (*.f64 x #s(approx (- y -1) y)) y)
(+.f64 y (*.f64 x #s(approx (- y -1) y)))
#s(approx (- y -1) y)
y
x
#s(approx (+ (* (- y -1) x) y) y)
#s(approx (+ (* (- y -1) x) y) (fma.f64 (-.f64 x #s(literal -1 binary64)) y x))
#s(approx x x)
#s(approx (+ (* (- y -1) x) y) (fma.f64 x y x))
#s(approx (+ (* (- y -1) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (* (- y -1) x) y) (fma.f64 (+.f64 (/.f64 y x) y) x x))
#s(approx (+ (* (- y -1) x) y) x)
#s(approx (+ (* (- y -1) x) y) (fma.f64 (-.f64 x #s(literal -1 binary64)) y x))
#s(approx (- y -1) #s(literal 1 binary64))
#s(approx (- y -1) (-.f64 y #s(literal -1 binary64)))
#s(approx y y)
#s(approx (+ (* (- y -1) x) y) (fma.f64 x y y))
#s(approx (+ (* (- y -1) x) y) (fma.f64 (+.f64 (/.f64 x y) x) y y))
#s(approx (- y -1) y)
#s(approx (- y -1) (-.f64 y #s(literal -1 binary64)))
#s(approx (+ (* (- y -1) x) y) (*.f64 (neg.f64 y) (fma.f64 x #s(literal -1 binary64) #s(literal -1 binary64))))
#s(approx (+ (* (- y -1) x) y) (*.f64 (neg.f64 y) (fma.f64 (+.f64 (/.f64 x y) x) #s(literal -1 binary64) #s(literal -1 binary64))))

eval3.0ms (0.2%)

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

Compiled 521 to 86 computations (83.5% saved)

prune8.0ms (0.4%)

Memory
-40.3MiB live, 5.0MiB allocated; 5ms collecting garbage
Pruning

6 alts after pruning (0 fresh and 6 done)

PrunedKeptTotal
New32032
Fresh000
Picked011
Done055
Total32638
Accuracy
100.0%
Counts
38 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
63.8%
(fma.f64 #s(approx (- y -1) y) x y)
70.5%
(+.f64 #s(approx (+ (* x y) x) x) y)
65.8%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
35.3%
#s(approx (+ (+ (* x y) x) y) y)
37.5%
#s(approx (+ (+ (* x y) x) y) x)
Compiler

Compiled 125 to 59 computations (52.8% saved)

regimes9.0ms (0.4%)

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

3 calls:

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

Compiled 9 to 9 computations (0% saved)

regimes8.0ms (0.4%)

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

3 calls:

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

Compiled 9 to 9 computations (0% saved)

regimes7.0ms (0.4%)

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

3 calls:

2.0ms
y
2.0ms
x
2.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
98.7%2(+.f64 (+.f64 (*.f64 x y) x) y)
99.3%3x
98.3%3y
Compiler

Compiled 9 to 9 computations (0% saved)

regimes4.0ms (0.2%)

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

2 calls:

2.0ms
x
2.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
98.6%3x
92.3%3(+.f64 (+.f64 (*.f64 x y) x) y)
Compiler

Compiled 8 to 7 computations (12.5% saved)

regimes5.0ms (0.2%)

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

3 calls:

2.0ms
y
2.0ms
x
1.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
70.5%1(+.f64 (+.f64 (*.f64 x y) x) y)
70.5%1y
70.5%1x
Compiler

Compiled 9 to 9 computations (0% saved)

regimes5.0ms (0.3%)

Memory
-33.7MiB live, 13.7MiB allocated; 2ms collecting garbage
Counts
2 → 2
Calls
Call 1
Inputs
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
Outputs
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
Calls

3 calls:

2.0ms
x
1.0ms
y
1.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
70.1%2(+.f64 (+.f64 (*.f64 x y) x) y)
63.0%2y
60.3%2x
Compiler

Compiled 9 to 9 computations (0% saved)

regimes3.0ms (0.2%)

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

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

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

3 calls:

1.0ms
y
1.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
1.0ms
x
Results
AccuracySegmentsBranch
37.5%1x
37.5%1y
37.5%1(+.f64 (+.f64 (*.f64 x y) x) y)
Compiler

Compiled 9 to 9 computations (0% saved)

bsearch0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.8639768631506942e-260
6.952033316386801e-246
Compiler

Compiled 10 to 10 computations (0% saved)

bsearch66.0ms (3.3%)

Memory
-10.7MiB live, 38.8MiB allocated; 17ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
48.0ms
5.572617017549625e-7
120549098.67140278
11.0ms
-32.13547460106622
-3.2571170336293135e-9
Samples
12.0ms320×0valid
Compiler

Compiled 430 to 310 computations (27.9% saved)

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

bsearch0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.8639768631506942e-260
6.952033316386801e-246
Compiler

Compiled 10 to 10 computations (0% saved)

simplify40.0ms (2%)

Memory
-7.3MiB live, 38.7MiB allocated; 4ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
028123
140123
261123
395123
4185123
5595123
64858123
Stop Event
node limit
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x y) x) y)
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -5539569662801113/553956966280111321359151042308621317197106853745652161186848528428353614047320326248246548509656023453846098404449586961587736474553087989908021159880755329796288475560940755137311819879076531853615938045960455092067922915100261601864210866521544040371494407003426519343169536 binary64)) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x)) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x y)))
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x)) (if (<=.f64 x #s(literal 1 binary64)) (+.f64 #s(approx (+ (* x y) x) x) y) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))))
(+.f64 #s(approx (+ (* x y) x) x) y)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -5539569662801113/553956966280111321359151042308621317197106853745652161186848528428353614047320326248246548509656023453846098404449586961587736474553087989908021159880755329796288475560940755137311819879076531853615938045960455092067922915100261601864210866521544040371494407003426519343169536 binary64)) #s(approx (+ (+ (* x y) x) y) x) #s(approx (+ (+ (* x y) x) y) y))
#s(approx (+ (+ (* x y) x) y) x)
Outputs
(+.f64 (+.f64 (*.f64 x y) x) y)
(fma.f64 (-.f64 y #s(literal -1 binary64)) x y)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -5539569662801113/553956966280111321359151042308621317197106853745652161186848528428353614047320326248246548509656023453846098404449586961587736474553087989908021159880755329796288475560940755137311819879076531853615938045960455092067922915100261601864210866521544040371494407003426519343169536 binary64)) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x)) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x y)))
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x)) (if (<=.f64 x #s(literal 1 binary64)) (+.f64 #s(approx (+ (* x y) x) x) y) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))))
(if (or (<=.f64 x #s(literal -1 binary64)) (not (<=.f64 x #s(literal 1 binary64)))) #s(approx (+ (+ (* x y) x) y) (fma.f64 y x x)) (+.f64 #s(approx (+ (* x y) x) x) y))
(+.f64 #s(approx (+ (* x y) x) x) y)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -5539569662801113/553956966280111321359151042308621317197106853745652161186848528428353614047320326248246548509656023453846098404449586961587736474553087989908021159880755329796288475560940755137311819879076531853615938045960455092067922915100261601864210866521544040371494407003426519343169536 binary64)) #s(approx (+ (+ (* x y) x) y) x) #s(approx (+ (+ (* x y) x) y) y))
#s(approx (+ (+ (* x y) x) y) x)

derivations216.0ms (10.7%)

Memory
-0.7MiB live, 141.0MiB allocated; 14ms collecting garbage
Stop Event
done
Compiler

Compiled 123 to 29 computations (76.4% saved)

preprocess31.0ms (1.5%)

Memory
20.6MiB live, 65.8MiB allocated; 6ms collecting garbage
Remove

(sort x y)

Compiler

Compiled 288 to 88 computations (69.4% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...