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

Time bar (total: 3.2s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
1.2MiB live, 1.2MiB 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)

sample1.1s (33.8%)

Memory
20.9MiB live, 1 219.0MiB allocated; 389ms collecting garbage
Samples
693.0ms8 253×0valid
0.0ms2valid
0.0ms1valid
Precisions
Click to see histograms. Total time spent on operations: 384.0ms
ival-add: 253.0ms (65.9% of total)
ival-mult: 125.0ms (32.6% of total)
ival-assert: 3.0ms (0.8% of total)
adjust: 2.0ms (0.5% of total)
Bogosity

explain527.0ms (16.7%)

Memory
115.0MiB live, 317.5MiB allocated; 281ms 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
481.0ms512×0valid
Compiler

Compiled 45 to 19 computations (57.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 12.0ms
ival-mult: 6.0ms (50% of total)
ival-add: 4.0ms (33.3% of total)
ival-true: 1.0ms (8.3% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess186.0ms (5.9%)

Memory
2.2MiB live, 280.2MiB allocated; 21ms 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.3MiB live, 0.2MiB allocated; 0ms collecting garbage
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.4MiB live, 1.4MiB 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
14.1MiB live, 14.1MiB 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)

rewrite386.0ms (12.2%)

Memory
-24.3MiB live, 272.2MiB allocated; 260ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
065285
1341283
23262281
09190252
Stop Event
iter limit
node limit
Counts
27 → 130
Calls
Call 1
Inputs
(+ (+ (* x y) x) y)
(+ (* x y) x)
(* 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 (*.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 (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 (-.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 (*.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 (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 (-.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 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 (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 (*.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 (*.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 (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 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 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 (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 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 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 (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 (*.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))

eval26.0ms (0.8%)

Memory
-0.9MiB live, 45.7MiB allocated; 2ms collecting garbage
Compiler

Compiled 2 285 to 373 computations (83.7% saved)

prune5.0ms (0.2%)

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

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New1265131
Fresh000
Picked101
Done000
Total1275132
Accuracy
100.0%
Counts
132 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
71.8%
(+.f64 #s(approx (+ (* x y) x) x) y)
63.0%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
65.5%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
34.8%
#s(approx (+ (+ (* x y) x) y) y)
38.6%
#s(approx (+ (+ (* x y) x) y) x)
Compiler

Compiled 102 to 64 computations (37.3% saved)

series8.0ms (0.2%)

Memory
-31.5MiB live, 12.9MiB allocated; 3ms collecting garbage
Counts
10 → 35
Calls
Call 1
Inputs
(+.f64 #s(approx (+ (* x y) x) x) y)
#s(approx (+ (* x y) x) x)
x
y
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
(fma.f64 y x x)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
(fma.f64 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 #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* y x) y) #s(hole binary64 y))
#s(approx (+ (* y x) y) #s(hole binary64 (+ y (* x y))))
#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 x) y) #s(hole binary64 (* x y)))
#s(approx (+ (* y x) y) #s(hole binary64 (* x (+ 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 (+ (* y x) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* y x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ y x)))))))
#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 (+ (* y x) x) #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* y x) y) #s(hole binary64 (* y (+ 1 x))))
#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 (+ (+ (* 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)))))))
#s(approx (+ (* y x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
Calls

6 calls:

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

rewrite202.0ms (6.4%)

Memory
24.7MiB live, 351.3MiB allocated; 78ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
088487
1443485
23754483
08769428
Stop Event
iter limit
node limit
Counts
45 → 122
Calls
Call 1
Inputs
(+ #s(approx (+ (* x y) x) #s(hole binary64 x)) y)
#s(approx (+ (* x y) x) #s(hole binary64 x))
x
y
#s(approx (+ (+ (* x y) x) y) #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) x)))
(+ (* y x) x)
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 (+ (* y x) y)))
(+ (* 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 #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (* x (+ 1 y))))
#s(approx (+ (* y x) y) #s(hole binary64 y))
#s(approx (+ (* y x) y) #s(hole binary64 (+ y (* x y))))
#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 x) y) #s(hole binary64 (* x y)))
#s(approx (+ (* y x) y) #s(hole binary64 (* x (+ 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 (+ (* y x) x) #s(hole binary64 (* -1 (* x (- (* -1 y) 1)))))
#s(approx (+ (* y x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ y x)))))))
#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 (+ (* y x) x) #s(hole binary64 x))
#s(approx (+ (* y x) x) #s(hole binary64 (+ x (* x y))))
#s(approx (+ (* y x) y) #s(hole binary64 (* y (+ 1 x))))
#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 (+ (+ (* 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)))))))
#s(approx (+ (* y x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
Outputs
(/.f64 (neg.f64 (-.f64 (*.f64 y y) (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 2 binary64)))) (neg.f64 (-.f64 y #s(approx (+ (* x y) x) x))))
(/.f64 (neg.f64 (neg.f64 (*.f64 (+.f64 #s(approx (+ (* x y) x) x) y) (-.f64 #s(approx (+ (* x y) x) x) y)))) (neg.f64 (neg.f64 (-.f64 #s(approx (+ (* x y) x) x) y))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64))))) (neg.f64 (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 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 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (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 (neg.f64 (+.f64 (pow.f64 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)) (pow.f64 y #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 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)) (pow.f64 y #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 #s(approx (+ (* x y) x) x) #s(literal 3 binary64)) (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 (/.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)
x
y
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) y)
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
(*.f64 (-.f64 y #s(literal -1 binary64)) x)
(*.f64 x (-.f64 y #s(literal -1 binary64)))
(/.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 (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 (*.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 (*.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))
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
(*.f64 (-.f64 x #s(literal -1 binary64)) y)
(*.f64 y (-.f64 x #s(literal -1 binary64)))
(/.f64 (neg.f64 (*.f64 y (-.f64 #s(literal 1 binary64) (*.f64 x x)))) (neg.f64 (-.f64 #s(literal 1 binary64) x)))
(/.f64 (neg.f64 (*.f64 y (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)))) (neg.f64 (fma.f64 x (-.f64 x #s(literal 1 binary64)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y)))) (neg.f64 (neg.f64 (-.f64 (*.f64 y x) y))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (*.f64 y y) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))) (neg.f64 (neg.f64 (-.f64 y (*.f64 y x)))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))))
(/.f64 (neg.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))))) (neg.f64 (neg.f64 (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) y) (*.f64 y y)))))
(/.f64 (neg.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) y)) (neg.f64 (-.f64 #s(literal 1 binary64) x)))
(/.f64 (neg.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)) y)) (neg.f64 (fma.f64 x (-.f64 x #s(literal 1 binary64)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 y y (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y (*.f64 (neg.f64 x) y))))))
(/.f64 (*.f64 y (-.f64 #s(literal 1 binary64) (*.f64 x x))) (-.f64 #s(literal 1 binary64) x))
(/.f64 (*.f64 y (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64))) (fma.f64 x (-.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)))
(/.f64 (-.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 y y (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y (*.f64 (neg.f64 x) y)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y))) (neg.f64 (-.f64 (*.f64 y x) y)))
(/.f64 (neg.f64 (-.f64 (*.f64 y y) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (neg.f64 (-.f64 y (*.f64 y x))))
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) y) (*.f64 y y))))
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 x x)) y) (-.f64 #s(literal 1 binary64) x))
(/.f64 (*.f64 (+.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)) y) (fma.f64 x (-.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y y)) (-.f64 (*.f64 y x) y))
(/.f64 (-.f64 (*.f64 y y) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 y (*.f64 y x)))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) y) (*.f64 y y)))
(fma.f64 y x y)
(fma.f64 x y y)
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) y)) (/.f64 (*.f64 y y) (-.f64 (*.f64 y x) y)))
(-.f64 (/.f64 (*.f64 y y) (-.f64 y (*.f64 y x))) (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 y (*.f64 y x))))
(-.f64 y (*.f64 (neg.f64 x) y))
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(+.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) y) (*.f64 y y))) (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 y x) (-.f64 (*.f64 y x) y) (*.f64 y y))))
(+.f64 (*.f64 y x) y)
(+.f64 y (*.f64 y x))
#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 x)
#s(approx (+ (* x y) x) (fma.f64 y x x))
#s(approx (+ (* y x) y) y)
#s(approx (+ (* y x) y) (fma.f64 y x y))
#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 (+ (* y x) y) (*.f64 y x))
#s(approx (+ (* y x) y) (*.f64 (+.f64 (/.f64 y x) y) 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) (*.f64 (neg.f64 x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
#s(approx (+ (* y x) y) (*.f64 (+.f64 (/.f64 y x) y) x))
#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) x)
#s(approx (+ (* x y) x) (fma.f64 y x x))
#s(approx (+ (* y x) y) (fma.f64 y x 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) (*.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))
#s(approx (+ (* x y) x) (*.f64 (+.f64 (/.f64 x y) x) y))
#s(approx (+ (* y x) y) (*.f64 (fma.f64 #s(literal -1 binary64) x #s(literal -1 binary64)) (neg.f64 y)))

eval25.0ms (0.8%)

Memory
13.2MiB live, 59.0MiB allocated; 6ms collecting garbage
Compiler

Compiled 2 635 to 360 computations (86.3% saved)

prune9.0ms (0.3%)

Memory
-24.6MiB live, 22.7MiB allocated; 3ms collecting garbage
Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New1201121
Fresh000
Picked055
Done000
Total1206126
Accuracy
100.0%
Counts
126 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
71.8%
(+.f64 #s(approx (+ (* x y) x) x) y)
63.0%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
65.5%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
29.8%
#s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))
34.8%
#s(approx (+ (+ (* x y) x) y) y)
38.6%
#s(approx (+ (+ (* x y) x) y) x)
Compiler

Compiled 68 to 42 computations (38.2% saved)

series5.0ms (0.2%)

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

6 calls:

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

rewrite316.0ms (10%)

Memory
9.7MiB live, 246.7MiB allocated; 93ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069299
1370297
23398295
08644265
Stop Event
iter limit
node limit
Counts
27 → 28
Calls
Call 1
Inputs
#s(approx (+ (+ (* x y) x) y) #s(hole binary64 #s(approx (+ (* y x) y) #s(hole binary64 (* y x)))))
#s(approx (+ (* y x) y) #s(hole binary64 (* y x)))
(* y x)
y
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 (+ (* y x) y) #s(hole binary64 y))
#s(approx (+ (* y x) y) #s(hole binary64 (+ y (* x y))))
#s(approx (* y x) #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 (+ (* y x) y) #s(hole binary64 (* x y)))
#s(approx (+ (* y x) y) #s(hole binary64 (* x (+ 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 (+ (* y x) y) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 (/ y x)))))))
#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 (+ (* y x) y) #s(hole binary64 (* y (+ 1 x))))
#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) 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 (+ (* y x) y) #s(hole binary64 (* -1 (* y (- (* -1 x) 1)))))
Outputs
#s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))
#s(approx (+ (* y x) y) (*.f64 y x))
(*.f64 y x)
(*.f64 x y)
y
x
#s(approx (+ (+ (* x y) x) y) y)
#s(approx (+ (+ (* x y) x) y) (fma.f64 (-.f64 x #s(literal -1 binary64)) y x))
#s(approx (+ (* y x) y) y)
#s(approx (+ (* y x) y) (fma.f64 y x y))
#s(approx (* y x) (*.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 (+ (* y x) y) (*.f64 y x))
#s(approx (+ (* y x) y) (*.f64 (+.f64 (/.f64 y x) y) 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 (+ (* y x) y) (*.f64 (+.f64 (/.f64 y x) y) x))
#s(approx (+ (+ (* x y) x) y) x)
#s(approx (+ (+ (* x y) x) y) (fma.f64 (-.f64 x #s(literal -1 binary64)) y x))
#s(approx (+ (* y x) y) (fma.f64 y x y))
#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) 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 (+ (* y x) y) (*.f64 (fma.f64 #s(literal -1 binary64) x #s(literal -1 binary64)) (neg.f64 y)))

eval5.0ms (0.1%)

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

Compiled 390 to 66 computations (83.1% saved)

prune5.0ms (0.2%)

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

6 alts after pruning (0 fresh and 6 done)

PrunedKeptTotal
New24024
Fresh000
Picked011
Done055
Total24630
Accuracy
100.0%
Counts
30 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
71.8%
(+.f64 #s(approx (+ (* x y) x) x) y)
63.0%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
65.5%
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
29.8%
#s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))
34.8%
#s(approx (+ (+ (* x y) x) y) y)
38.6%
#s(approx (+ (+ (* x y) x) y) x)
Compiler

Compiled 143 to 63 computations (55.9% saved)

regimes14.0ms (0.4%)

Memory
-28.9MiB live, 17.5MiB allocated; 8ms 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) #s(approx (+ (* y x) y) (*.f64 y x)))
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x y))
(+.f64 (+.f64 (*.f64 x y) x) y)
Outputs
(+.f64 (+.f64 (*.f64 x y) x) y)
Calls

3 calls:

3.0ms
y
3.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
2.0ms
x
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.2%)

Memory
12.4MiB live, 12.4MiB 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) #s(approx (+ (* y x) y) (*.f64 y x)))
#s(approx (+ (+ (* x y) x) y) (fma.f64 y x x))
#s(approx (+ (+ (* x y) x) y) (fma.f64 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.3%2(+.f64 (+.f64 (*.f64 x y) x) y)
99.5%3x
99.8%3y
Compiler

Compiled 9 to 9 computations (0% saved)

regimes6.0ms (0.2%)

Memory
11.6MiB live, 11.6MiB allocated; 0ms collecting garbage
Counts
5 → 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) #s(approx (+ (* y x) y) (*.f64 y x)))
#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) #s(approx (+ (* y x) y) (*.f64 y x)))
Calls

3 calls:

2.0ms
y
2.0ms
x
2.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
98.7%3x
83.5%4y
93.5%3(+.f64 (+.f64 (*.f64 x y) x) y)
Compiler

Compiled 9 to 9 computations (0% saved)

regimes7.0ms (0.2%)

Memory
-38.1MiB live, 7.3MiB allocated; 5ms 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) #s(approx (+ (* y x) y) (*.f64 y x)))
Outputs
#s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))
(+.f64 #s(approx (+ (* x y) x) x) y)
#s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))
Calls

2 calls:

2.0ms
x
2.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
85.4%3(+.f64 (+.f64 (*.f64 x y) x) y)
79.9%3x
Compiler

Compiled 8 to 7 computations (12.5% saved)

regimes5.0ms (0.2%)

Memory
12.6MiB live, 12.6MiB 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
(+.f64 (+.f64 (*.f64 x y) x) y)
2.0ms
y
2.0ms
x
Results
AccuracySegmentsBranch
71.8%1x
71.8%1y
71.8%1(+.f64 (+.f64 (*.f64 x y) x) y)
Compiler

Compiled 9 to 9 computations (0% saved)

regimes4.0ms (0.1%)

Memory
12.0MiB live, 12.0MiB allocated; 0ms 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:

1.0ms
x
1.0ms
y
1.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
63.8%2y
70.8%2(+.f64 (+.f64 (*.f64 x y) x) y)
62.6%2x
Compiler

Compiled 9 to 9 computations (0% saved)

regimes3.0ms (0.1%)

Memory
7.5MiB live, 7.5MiB 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
x
1.0ms
(+.f64 (+.f64 (*.f64 x y) x) y)
Results
AccuracySegmentsBranch
38.6%1x
38.6%1y
38.6%1(+.f64 (+.f64 (*.f64 x y) x) y)
Compiler

Compiled 9 to 9 computations (0% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.0987214462689953e-278
1.5021088702040752e-293
Compiler

Compiled 10 to 10 computations (0% saved)

bsearch38.0ms (1.2%)

Memory
-10.5MiB live, 34.9MiB allocated; 5ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
24.0ms
0.8942500123325275
62983.24247968523
12.0ms
-84553684361.93259
-0.9515924132076018
Samples
12.0ms304×0valid
Compiler

Compiled 454 to 322 computations (29.1% saved)

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

bsearch1.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
5.665166276219773e+292
+inf
0.0ms
-9.105058626283013e+287
-1.0414372803910859e+282
Compiler

Compiled 10 to 10 computations (0% saved)

bsearch0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.0987214462689953e-278
1.5021088702040752e-293
Compiler

Compiled 10 to 10 computations (0% saved)

simplify55.0ms (1.8%)

Memory
-7.8MiB live, 45.3MiB allocated; 13ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
037180
147180
265180
394180
4155180
5271180
61089180
76098180
Stop Event
node limit
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x y) x) y)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -6386688990511103/638668899051110339730039268171788341141584403339346413280815117579907805398068501051186548957643424348589582990141598478071180156285949971436534975451146054502401815344347416485612070862196155898449074158254055677865859345638678524444433685903374130402278690200241933325554718473710083176923136 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 62000 binary64)) (+.f64 #s(approx (+ (* x y) x) x) y) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))))
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -500000000000000003815236769787517830257389167755855375390043332219984755318247477305565774567919593256991727777697610447843930272404792499914862630297436635543699813243303073221275494420008458697313224768197604310133506389038893861697957032303559981034741662286988928916069412641477492736 binary64)) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x))) (if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal 99999999999999992462348437353960485060448933957923525202610654848990348279466077292501969423268405025328970231162545648343655275306678872441733790178059478330735395060467469727994972900530063978805843953102113868000379620369084502134308975505229555772913629423636305841602377586326247764393984 binary64)) (+.f64 #s(approx (+ (* x y) x) x) y) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))))
(+.f64 #s(approx (+ (* x y) x) x) y)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -6386688990511103/638668899051110339730039268171788341141584403339346413280815117579907805398068501051186548957643424348589582990141598478071180156285949971436534975451146054502401815344347416485612070862196155898449074158254055677865859345638678524444433685903374130402278690200241933325554718473710083176923136 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)
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -6386688990511103/638668899051110339730039268171788341141584403339346413280815117579907805398068501051186548957643424348589582990141598478071180156285949971436534975451146054502401815344347416485612070862196155898449074158254055677865859345638678524444433685903374130402278690200241933325554718473710083176923136 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 62000 binary64)) (+.f64 #s(approx (+ (* x y) x) x) y) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))))
(if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -500000000000000003815236769787517830257389167755855375390043332219984755318247477305565774567919593256991727777697610447843930272404792499914862630297436635543699813243303073221275494420008458697313224768197604310133506389038893861697957032303559981034741662286988928916069412641477492736 binary64)) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x))) (if (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal 99999999999999992462348437353960485060448933957923525202610654848990348279466077292501969423268405025328970231162545648343655275306678872441733790178059478330735395060467469727994972900530063978805843953102113868000379620369084502134308975505229555772913629423636305841602377586326247764393984 binary64)) (+.f64 #s(approx (+ (* x y) x) x) y) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y x)))))
(if (or (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal -500000000000000003815236769787517830257389167755855375390043332219984755318247477305565774567919593256991727777697610447843930272404792499914862630297436635543699813243303073221275494420008458697313224768197604310133506389038893861697957032303559981034741662286988928916069412641477492736 binary64)) (not (<=.f64 (+.f64 (+.f64 (*.f64 x y) x) y) #s(literal 99999999999999992462348437353960485060448933957923525202610654848990348279466077292501969423268405025328970231162545648343655275306678872441733790178059478330735395060467469727994972900530063978805843953102113868000379620369084502134308975505229555772913629423636305841602377586326247764393984 binary64)))) #s(approx (+ (+ (* x y) x) y) #s(approx (+ (* y x) y) (*.f64 y 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 -6386688990511103/638668899051110339730039268171788341141584403339346413280815117579907805398068501051186548957643424348589582990141598478071180156285949971436534975451146054502401815344347416485612070862196155898449074158254055677865859345638678524444433685903374130402278690200241933325554718473710083176923136 binary64)) #s(approx (+ (+ (* x y) x) y) x) #s(approx (+ (+ (* x y) x) y) y))
#s(approx (+ (+ (* x y) x) y) x)

derivations205.0ms (6.5%)

Memory
-6.6MiB live, 225.0MiB allocated; 42ms collecting garbage
Stop Event
done
Compiler

Compiled 180 to 38 computations (78.9% saved)

preprocess31.0ms (1%)

Memory
33.5MiB live, 80.0MiB allocated; 3ms collecting garbage
Remove

(sort x y)

Compiler

Compiled 402 to 106 computations (73.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...