Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, B

Time bar (total: 1.5s)

start0.0ms (0%)

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

analyze11.0ms (0.7%)

Memory
24.9MiB live, 24.9MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
50%50%50%0.1%0%0%0%3
50%50%50%0.1%0%0%0%4
75%74.9%25%0.1%0%0%0%5
75%74.9%25%0.1%0%0%0%6
87.5%87.4%12.5%0.1%0%0%0%7
87.5%87.4%12.5%0.1%0%0%0%8
93.8%93.7%6.2%0.1%0%0%0%9
93.8%93.7%6.2%0.1%0%0%0%10
96.9%96.8%3.1%0.1%0%0%0%11
96.9%96.8%3.1%0.1%0%0%0%12
Compiler

Compiled 9 to 8 computations (11.1% saved)

sample697.0ms (45.4%)

Memory
20.4MiB live, 914.6MiB allocated; 228ms collecting garbage
Samples
456.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 140.0ms
ival-mult!: 53.0ms (37.8% of total)
ival-div!: 48.0ms (34.3% of total)
ival-add!: 37.0ms (26.4% of total)
adjust: 2.0ms (1.4% of total)
Bogosity

explain117.0ms (7.6%)

Memory
-26.5MiB live, 121.9MiB allocated; 13ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
320-0-(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
00-0-(+.f64 y #s(literal 1 binary64))
00-0-y
00-0-#s(literal 1 binary64)
00-0-(*.f64 x y)
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
/.f64(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))o/n320
(*.f64 x y)overflow32
Confusion
Predicted +Predicted -
+320
-0224
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+3200
-00224
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
0224
132
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
48.0ms512×0valid
Compiler

Compiled 43 to 22 computations (48.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 7.0ms
ival-mult!: 3.0ms (44.7% of total)
ival-add!: 2.0ms (29.8% of total)
ival-div!: 2.0ms (29.8% of total)
adjust: 0.0ms (0% of total)

preprocess69.0ms (4.5%)

Memory
-0.7MiB live, 39.4MiB allocated; 9ms collecting garbage
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01848
14346
210944
323444
433344
591942
6708242
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.2%
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
Symmetry

(negabs x)

Compiler

Compiled 14 to 12 computations (14.3% saved)

series7.0ms (0.5%)

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

6 calls:

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

rewrite171.0ms (11.1%)

Memory
-4.2MiB live, 177.9MiB allocated; 76ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069266
070251
1377238
03433234
Stop Event
iter-limit
iter-limit
node-limit
iter-limit
Counts
24 → 65
Calls
Call 1
Inputs
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
(*.f64 x y)
x
y
(+.f64 y #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (/ (* x y) (+ 1 y))))
#s(approx (* x y) #s(hole binary64 (* x y)))
#s(approx x #s(hole binary64 x))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* x y)))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* -1 (* x y))))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* y (- (* x y) x))))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* y (- (* y (- (* -1 (* x y)) (* -1 x))) x))))))
#s(approx y #s(hole binary64 y))
#s(approx (+ y 1) #s(hole binary64 1))
#s(approx (+ y 1) #s(hole binary64 (+ 1 y)))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 x))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (- (+ x (/ x (pow y 2))) (/ x y))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (- (+ x (* -1 (/ x (pow y 3)))) (+ (* -1 (/ x (pow y 2))) (/ 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) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ x y))) y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ (+ x (* -1 (/ x y))) y))) y)))))
Outputs
(*.f64 (/.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) (*.f64 y y))) (-.f64 #s(literal 1 binary64) y))
(*.f64 (/.f64 (*.f64 y x) (fma.f64 y y #s(literal -1 binary64))) (-.f64 y #s(literal 1 binary64)))
(*.f64 (/.f64 (*.f64 y 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 (*.f64 y 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 y (-.f64 y #s(literal -1 binary64))) x)
(*.f64 (neg.f64 x) (/.f64 y (+.f64 (neg.f64 y) #s(literal -1 binary64))))
(*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y x) (+.f64 (neg.f64 y) #s(literal -1 binary64))))
(*.f64 (*.f64 y x) (/.f64 #s(literal -1 binary64) (+.f64 (neg.f64 y) #s(literal -1 binary64))))
(*.f64 y (/.f64 x (-.f64 y #s(literal -1 binary64))))
(*.f64 x (/.f64 y (-.f64 y #s(literal -1 binary64))))
(/.f64 (*.f64 (neg.f64 y) x) (+.f64 (neg.f64 y) #s(literal -1 binary64)))
(/.f64 (*.f64 y x) (neg.f64 (+.f64 (neg.f64 y) #s(literal -1 binary64))))
(/.f64 (*.f64 y x) (-.f64 y #s(literal -1 binary64)))
(neg.f64 (/.f64 (*.f64 (neg.f64 y) x) (-.f64 y #s(literal -1 binary64))))
(neg.f64 (/.f64 (*.f64 y x) (+.f64 (neg.f64 y) #s(literal -1 binary64))))
(*.f64 (*.f64 y x) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (*.f64 y x))
(*.f64 y x)
(*.f64 x y)
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 y x)) #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 y) x))
x
y
(*.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 (fma.f64 y y #s(literal -1 binary64))) (neg.f64 (-.f64 y #s(literal 1 binary64))))
(/.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 (-.f64 #s(literal 1 binary64) (*.f64 y y)) (-.f64 #s(literal 1 binary64) y))
(/.f64 (fma.f64 y y #s(literal -1 binary64)) (-.f64 y #s(literal 1 binary64)))
(/.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 (pow.f64 y #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 y y (-.f64 #s(literal 1 binary64) y)))
(-.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 y (*.f64 (neg.f64 (pow.f64 y #s(literal -1 binary64))) y))
(-.f64 y (*.f64 (neg.f64 y) (pow.f64 y #s(literal -1 binary64))))
(-.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 (/.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 #s(literal 1 binary64) y)
(+.f64 y #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (/ (* x y) (+ y 1)) (*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x))
#s(approx (* x y) (*.f64 y x))
#s(approx x x)
#s(approx (/ (* x y) (+ y 1)) (*.f64 y x))
#s(approx (/ (* x y) (+ y 1)) (*.f64 (fma.f64 (neg.f64 x) y x) y))
#s(approx (/ (* x y) (+ y 1)) (*.f64 (fma.f64 (-.f64 (*.f64 y x) x) y x) y))
#s(approx (/ (* x y) (+ y 1)) (*.f64 (fma.f64 (-.f64 (*.f64 (fma.f64 (neg.f64 x) y x) y) x) y x) y))
#s(approx y y)
#s(approx (+ y 1) #s(literal 1 binary64))
#s(approx (+ y 1) (-.f64 y #s(literal -1 binary64)))
#s(approx (/ (* x y) (+ y 1)) x)
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 x y)))
#s(approx (/ (* x y) (+ y 1)) (fma.f64 x (pow.f64 y #s(literal -2 binary64)) (-.f64 x (/.f64 x y))))
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (fma.f64 x (pow.f64 y #s(literal -3 binary64)) (/.f64 (-.f64 x (/.f64 x y)) y))))
#s(approx (+ y 1) y)
#s(approx (+ y 1) (-.f64 y #s(literal -1 binary64)))
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 (-.f64 x (/.f64 x y)) y)))
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 (-.f64 x (/.f64 (-.f64 x (/.f64 x y)) y)) y)))

eval5.0ms (0.4%)

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

Compiled 781 to 182 computations (76.7% saved)

prune3.0ms (0.2%)

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

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New56460
Fresh000
Picked011
Done000
Total56561
Accuracy
100.0%
Counts
61 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.2%
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
100.0%
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
50.6%
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 x y)))
50.6%
#s(approx (/ (* x y) (+ y 1)) (*.f64 y x))
51.3%
#s(approx (/ (* x y) (+ y 1)) x)
Compiler

Compiled 47 to 36 computations (23.4% saved)

series9.0ms (0.6%)

Memory
-34.7MiB live, 12.3MiB allocated; 2ms collecting garbage
Counts
12 → 46
Calls
Call 1
Inputs
#s(approx (/ (* x y) (+ y 1)) x)
x
#s(approx (/ (* x y) (+ y 1)) (*.f64 y x))
(*.f64 y x)
y
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 x y)))
(-.f64 x (/.f64 x y))
(/.f64 x y)
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
(/.f64 y (-.f64 y #s(literal -1 binary64)))
(-.f64 y #s(literal -1 binary64))
#s(literal -1 binary64)
Outputs
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (/ (* x y) (+ 1 y))))
#s(approx x #s(hole binary64 x))
#s(approx (* y x) #s(hole binary64 (* x y)))
#s(approx (- x (/ x y)) #s(hole binary64 (* x (- 1 (/ 1 y)))))
#s(approx (/ x y) #s(hole binary64 (/ x y)))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (/ (* x y) (+ 1 y))))
#s(approx (- x (/ x y)) #s(hole binary64 (* -1 (* x (- (/ 1 y) 1)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* x y)))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* -1 (* x y))))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* y (- (* x y) x))))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* y (- (* y (- (* -1 (* x y)) (* -1 x))) x))))))
#s(approx y #s(hole binary64 y))
#s(approx (- x (/ x y)) #s(hole binary64 (* -1 (/ x y))))
#s(approx (- x (/ x y)) #s(hole binary64 (/ (- (* x y) x) y)))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* x y)))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* y (+ x (* -1 (* x y))))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* y (+ x (* y (- (* x y) x))))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* y (+ x (* y (- (* y (- (* -1 (* x y)) (* -1 x))) x))))))
#s(approx (/ y (- y -1)) #s(hole binary64 y))
#s(approx (/ y (- y -1)) #s(hole binary64 (* y (+ 1 (* -1 y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 (* y (+ 1 (* y (- y 1))))))
#s(approx (/ y (- y -1)) #s(hole binary64 (* y (+ 1 (* y (- (* y (+ 1 (* -1 y))) 1))))))
#s(approx (- y -1) #s(hole binary64 1))
#s(approx (- y -1) #s(hole binary64 (+ 1 y)))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 x))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (- (+ x (/ x (pow y 2))) (/ x y))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (- (+ x (* -1 (/ x (pow y 3)))) (+ (* -1 (/ x (pow y 2))) (/ x y)))))
#s(approx (- x (/ x y)) #s(hole binary64 x))
#s(approx (- x (/ x y)) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 x))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (- (+ x (/ x (pow y 2))) (/ x y))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (- (+ x (* -1 (/ x (pow y 3)))) (+ (* -1 (/ x (pow y 2))) (/ x y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 1))
#s(approx (/ y (- y -1)) #s(hole binary64 (- 1 (/ 1 y))))
#s(approx (/ y (- y -1)) #s(hole binary64 (- (+ 1 (/ 1 (pow y 2))) (/ 1 y))))
#s(approx (/ y (- y -1)) #s(hole binary64 (- (+ 1 (/ 1 (pow y 2))) (+ (/ 1 y) (/ 1 (pow y 3))))))
#s(approx (- y -1) #s(hole binary64 y))
#s(approx (- y -1) #s(hole binary64 (* y (+ 1 (/ 1 y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ x y))) y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ (+ x (* -1 (/ x y))) y))) y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ x y))) y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ (+ x (* -1 (/ x y))) y))) y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 (+ 1 (* -1 (/ (- 1 (/ 1 y)) y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 (+ 1 (* -1 (/ (+ 1 (* -1 (/ (- 1 (/ 1 y)) y))) y)))))
Calls

6 calls:

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

rewrite260.0ms (16.9%)

Memory
21.1MiB live, 187.6MiB allocated; 142ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0136754
0143713
1674680
06412669
Stop Event
iter-limit
iter-limit
node-limit
iter-limit
Counts
58 → 153
Calls
Call 1
Inputs
#s(approx (/ (* x y) (+ y 1)) x)
x
#s(approx (/ (* x y) (+ y 1)) (*.f64 y x))
(*.f64 y x)
y
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 x y)))
(-.f64 x (/.f64 x y))
(/.f64 x y)
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
(/.f64 y (-.f64 y #s(literal -1 binary64)))
(-.f64 y #s(literal -1 binary64))
#s(literal -1 binary64)
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (/ (* x y) (+ 1 y))))
#s(approx x #s(hole binary64 x))
#s(approx (* y x) #s(hole binary64 (* x y)))
#s(approx (- x (/ x y)) #s(hole binary64 (* x (- 1 (/ 1 y)))))
#s(approx (/ x y) #s(hole binary64 (/ x y)))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (/ (* x y) (+ 1 y))))
#s(approx (- x (/ x y)) #s(hole binary64 (* -1 (* x (- (/ 1 y) 1)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* x y)))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* -1 (* x y))))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* y (- (* x y) x))))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (* y (+ x (* y (- (* y (- (* -1 (* x y)) (* -1 x))) x))))))
#s(approx y #s(hole binary64 y))
#s(approx (- x (/ x y)) #s(hole binary64 (* -1 (/ x y))))
#s(approx (- x (/ x y)) #s(hole binary64 (/ (- (* x y) x) y)))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* x y)))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* y (+ x (* -1 (* x y))))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* y (+ x (* y (- (* x y) x))))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (* y (+ x (* y (- (* y (- (* -1 (* x y)) (* -1 x))) x))))))
#s(approx (/ y (- y -1)) #s(hole binary64 y))
#s(approx (/ y (- y -1)) #s(hole binary64 (* y (+ 1 (* -1 y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 (* y (+ 1 (* y (- y 1))))))
#s(approx (/ y (- y -1)) #s(hole binary64 (* y (+ 1 (* y (- (* y (+ 1 (* -1 y))) 1))))))
#s(approx (- y -1) #s(hole binary64 1))
#s(approx (- y -1) #s(hole binary64 (+ 1 y)))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 x))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (- (+ x (/ x (pow y 2))) (/ x y))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (- (+ x (* -1 (/ x (pow y 3)))) (+ (* -1 (/ x (pow y 2))) (/ x y)))))
#s(approx (- x (/ x y)) #s(hole binary64 x))
#s(approx (- x (/ x y)) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 x))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (+ x (* -1 (/ x y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (- (+ x (/ x (pow y 2))) (/ x y))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (- (+ x (* -1 (/ x (pow y 3)))) (+ (* -1 (/ x (pow y 2))) (/ x y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 1))
#s(approx (/ y (- y -1)) #s(hole binary64 (- 1 (/ 1 y))))
#s(approx (/ y (- y -1)) #s(hole binary64 (- (+ 1 (/ 1 (pow y 2))) (/ 1 y))))
#s(approx (/ y (- y -1)) #s(hole binary64 (- (+ 1 (/ 1 (pow y 2))) (+ (/ 1 y) (/ 1 (pow y 3))))))
#s(approx (- y -1) #s(hole binary64 y))
#s(approx (- y -1) #s(hole binary64 (* y (+ 1 (/ 1 y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ x y))) y)))))
#s(approx (/ (* x y) (+ y 1)) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ (+ x (* -1 (/ x y))) y))) y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ x y))) y)))))
#s(approx (* (/ y (- y -1)) x) #s(hole binary64 (+ x (* -1 (/ (+ x (* -1 (/ (+ x (* -1 (/ x y))) y))) y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 (+ 1 (* -1 (/ (- 1 (/ 1 y)) y)))))
#s(approx (/ y (- y -1)) #s(hole binary64 (+ 1 (* -1 (/ (+ 1 (* -1 (/ (- 1 (/ 1 y)) y))) y)))))
Outputs
#s(approx (* (/ y (- y -1)) x) x)
x
#s(approx (* (/ y (- y -1)) x) (*.f64 y x))
(*.f64 #s(literal -1 binary64) (*.f64 (neg.f64 y) x))
(*.f64 #s(literal 1 binary64) (*.f64 y x))
(*.f64 (*.f64 y x) #s(literal 1 binary64))
(*.f64 y x)
(*.f64 x y)
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 y x)) #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 y) x))
y
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 x y)))
(/.f64 (/.f64 (fma.f64 (neg.f64 x) y x) #s(literal -1 binary64)) y)
(/.f64 (/.f64 (fma.f64 (neg.f64 x) y x) y) #s(literal -1 binary64))
(/.f64 (-.f64 (pow.f64 (/.f64 x y) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 (/.f64 (neg.f64 x) y) x))
(/.f64 (neg.f64 (fma.f64 (neg.f64 x) y x)) y)
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 x y) #s(literal 2 binary64)))) (neg.f64 (+.f64 (/.f64 x y) x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (/.f64 x y) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (/.f64 x y) (+.f64 (/.f64 x y) x) (*.f64 x x))))
(/.f64 (-.f64 (*.f64 (neg.f64 y) (*.f64 y x)) (*.f64 (neg.f64 y) x)) (*.f64 (neg.f64 y) y))
(/.f64 (-.f64 (*.f64 (*.f64 y x) y) (*.f64 y x)) (*.f64 y y))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 x x)) (*.f64 (fma.f64 y x x) y))
(/.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 x y) #s(literal 2 binary64))) (+.f64 (/.f64 x y) x))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (*.f64 (fma.f64 x (fma.f64 y x x) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) y))
(/.f64 (-.f64 (pow.f64 x #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 x x) (*.f64 (/.f64 (neg.f64 x) y) x))))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 (/.f64 x y) #s(literal 3 binary64))) (fma.f64 (/.f64 x y) (+.f64 (/.f64 x y) x) (*.f64 x x)))
(/.f64 (fma.f64 (neg.f64 x) y x) (neg.f64 y))
(/.f64 (-.f64 (*.f64 y x) x) y)
(neg.f64 (/.f64 (fma.f64 (neg.f64 x) y x) y))
(neg.f64 (/.f64 (-.f64 (*.f64 y x) x) (neg.f64 y)))
(fma.f64 (/.f64 x y) #s(literal -1 binary64) x)
(fma.f64 #s(literal -1 binary64) (/.f64 x y) x)
(fma.f64 x (/.f64 #s(literal -1 binary64) y) x)
(-.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 (*.f64 x x) (+.f64 (/.f64 x y) x)) (/.f64 (pow.f64 (/.f64 x y) #s(literal 2 binary64)) (+.f64 (/.f64 x y) x)))
(-.f64 x (*.f64 (/.f64 (neg.f64 x) y) #s(literal -1 binary64)))
(-.f64 x (/.f64 x y))
(+.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 (neg.f64 x) y) #s(literal 3 binary64)) (fma.f64 (/.f64 x y) (+.f64 (/.f64 x y) x) (*.f64 x x))))
(+.f64 (/.f64 (neg.f64 x) y) x)
(+.f64 x (/.f64 (neg.f64 x) y))
(*.f64 (/.f64 x #s(literal -1 binary64)) (/.f64 #s(literal -1 binary64) y))
(*.f64 (/.f64 #s(literal -1 binary64) y) (/.f64 x #s(literal -1 binary64)))
(*.f64 (/.f64 x y) #s(literal 1 binary64))
(*.f64 #s(literal -1 binary64) (/.f64 (neg.f64 x) y))
(*.f64 #s(literal 1 binary64) (/.f64 x y))
(*.f64 x (pow.f64 y #s(literal -1 binary64)))
(/.f64 (/.f64 (neg.f64 x) #s(literal -1 binary64)) y)
(/.f64 (*.f64 #s(literal 2 binary64) (/.f64 x y)) #s(literal 2 binary64))
(/.f64 (*.f64 #s(literal 1 binary64) (neg.f64 x)) (neg.f64 y))
(/.f64 (*.f64 #s(literal 2 binary64) (neg.f64 x)) (*.f64 #s(literal 2 binary64) (neg.f64 y)))
(/.f64 (*.f64 #s(literal 2 binary64) x) (*.f64 #s(literal 2 binary64) y))
(/.f64 (/.f64 (neg.f64 x) y) #s(literal -1 binary64))
(/.f64 (neg.f64 x) (neg.f64 y))
(/.f64 x y)
(neg.f64 (/.f64 (neg.f64 x) y))
(*.f64 (/.f64 (*.f64 y x) (-.f64 #s(literal 1 binary64) (*.f64 y y))) (-.f64 #s(literal 1 binary64) y))
(*.f64 (/.f64 (*.f64 y x) (fma.f64 y y #s(literal -1 binary64))) (-.f64 y #s(literal 1 binary64)))
(*.f64 (/.f64 (*.f64 y x) (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64)))
(*.f64 (neg.f64 x) (/.f64 y (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
(*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(*.f64 (*.f64 y x) (/.f64 #s(literal -1 binary64) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(*.f64 y (/.f64 x (-.f64 y #s(literal -1 binary64))))
(*.f64 x (/.f64 y (-.f64 y #s(literal -1 binary64))))
(/.f64 (*.f64 (neg.f64 y) x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64)))
(/.f64 (*.f64 y x) (neg.f64 (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(/.f64 (*.f64 y x) (-.f64 y #s(literal -1 binary64)))
(neg.f64 (/.f64 (*.f64 (neg.f64 y) x) (-.f64 y #s(literal -1 binary64))))
(neg.f64 (/.f64 (*.f64 y x) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(*.f64 (/.f64 y (fma.f64 y y #s(literal -1 binary64))) (-.f64 y #s(literal 1 binary64)))
(*.f64 (/.f64 y (-.f64 #s(literal 1 binary64) (*.f64 y y))) (-.f64 #s(literal 1 binary64) y))
(*.f64 (/.f64 y (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64)))
(*.f64 #s(literal -1 binary64) (/.f64 y (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(*.f64 y (/.f64 #s(literal -1 binary64) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(/.f64 (neg.f64 y) (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64)))
(/.f64 y (neg.f64 (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(/.f64 y (-.f64 y #s(literal -1 binary64)))
(neg.f64 (/.f64 (neg.f64 y) (-.f64 y #s(literal -1 binary64))))
(neg.f64 (/.f64 y (fma.f64 #s(literal -1 binary64) y #s(literal -1 binary64))))
(*.f64 (/.f64 (fma.f64 y y #s(literal -1 binary64)) (-.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal 1 binary64))) (fma.f64 y y (-.f64 y #s(literal -1 binary64))))
(*.f64 (/.f64 (fma.f64 y y #s(literal -1 binary64)) (fma.f64 y y #s(literal -1 binary64))) (-.f64 y #s(literal -1 binary64)))
(*.f64 (-.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal -1 binary64)) y)
(*.f64 (-.f64 y #s(literal -1 binary64)) #s(literal 1 binary64))
(*.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) y))
(*.f64 #s(literal 1 binary64) (-.f64 y #s(literal -1 binary64)))
(*.f64 y (-.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal -1 binary64)))
(/.f64 (*.f64 (+.f64 (pow.f64 y #s(literal -3 binary64)) #s(literal 1 binary64)) y) (-.f64 (-.f64 (pow.f64 y #s(literal -2 binary64)) #s(literal -1 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 (pow.f64 y #s(literal -2 binary64)) #s(literal -1 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 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))))
(/.f64 (neg.f64 (fma.f64 y y #s(literal -1 binary64))) (-.f64 #s(literal 1 binary64) y))
(/.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 (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 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64)))
(-.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))) (/.f64 #s(literal -1 binary64) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))))
(-.f64 (/.f64 (*.f64 y y) (-.f64 y #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 y #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 #s(literal 1 binary64) (neg.f64 y))
(-.f64 y (*.f64 (neg.f64 (pow.f64 y #s(literal -1 binary64))) y))
(-.f64 y (*.f64 (neg.f64 y) (pow.f64 y #s(literal -1 binary64))))
(-.f64 y #s(literal -1 binary64))
(+.f64 (/.f64 #s(literal 1 binary64) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))))
(+.f64 (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 (-.f64 y #s(literal 1 binary64)) y #s(literal 1 binary64))))
(+.f64 #s(literal 1 binary64) y)
(+.f64 y #s(literal 1 binary64))
#s(literal -1 binary64)
#s(approx (* (/ y (- y -1)) x) (*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x))
#s(approx x x)
#s(approx (* y x) (*.f64 y x))
#s(approx (- x (/ x y)) (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -1 binary64))) x))
#s(approx (/ x y) (/.f64 x y))
#s(approx (* (/ y (- y -1)) x) (*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x))
#s(approx (- x (/ x y)) (*.f64 (neg.f64 x) (-.f64 (pow.f64 y #s(literal -1 binary64)) #s(literal 1 binary64))))
#s(approx (* (/ y (- y -1)) x) (*.f64 y x))
#s(approx (* (/ y (- y -1)) x) (*.f64 (fma.f64 (neg.f64 x) y x) y))
#s(approx (* (/ y (- y -1)) x) (*.f64 (fma.f64 (-.f64 (*.f64 y x) x) y x) y))
#s(approx (* (/ y (- y -1)) x) (*.f64 (fma.f64 (-.f64 (*.f64 (fma.f64 (neg.f64 x) y x) y) x) y x) y))
#s(approx y y)
#s(approx (- x (/ x y)) (/.f64 (neg.f64 x) y))
#s(approx (- x (/ x y)) (-.f64 x (/.f64 x y)))
#s(approx (* (/ y (- y -1)) x) (*.f64 y x))
#s(approx (* (/ y (- y -1)) x) (*.f64 (fma.f64 (neg.f64 x) y x) y))
#s(approx (* (/ y (- y -1)) x) (*.f64 (fma.f64 (-.f64 (*.f64 y x) x) y x) y))
#s(approx (* (/ y (- y -1)) x) (*.f64 (fma.f64 (-.f64 (*.f64 (fma.f64 (neg.f64 x) y x) y) x) y x) y))
#s(approx (/ y (- y -1)) y)
#s(approx (/ y (- y -1)) (*.f64 (-.f64 #s(literal 1 binary64) y) y))
#s(approx (/ y (- y -1)) (fma.f64 (*.f64 (-.f64 y #s(literal 1 binary64)) y) y y))
#s(approx (/ y (- y -1)) (*.f64 (fma.f64 (fma.f64 (-.f64 #s(literal 1 binary64) y) y #s(literal -1 binary64)) y #s(literal 1 binary64)) y))
#s(approx (- y -1) #s(literal 1 binary64))
#s(approx (- y -1) (-.f64 y #s(literal -1 binary64)))
#s(approx (* (/ y (- y -1)) x) x)
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 x y)))
#s(approx (* (/ y (- y -1)) x) (fma.f64 x (pow.f64 y #s(literal -2 binary64)) (-.f64 x (/.f64 x y))))
#s(approx (* (/ y (- y -1)) x) (-.f64 x (fma.f64 x (pow.f64 y #s(literal -3 binary64)) (/.f64 (-.f64 x (/.f64 x y)) y))))
#s(approx (- x (/ x y)) x)
#s(approx (- x (/ x y)) (-.f64 x (/.f64 x y)))
#s(approx (* (/ y (- y -1)) x) x)
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 x y)))
#s(approx (* (/ y (- y -1)) x) (fma.f64 x (pow.f64 y #s(literal -2 binary64)) (-.f64 x (/.f64 x y))))
#s(approx (* (/ y (- y -1)) x) (-.f64 x (fma.f64 x (pow.f64 y #s(literal -3 binary64)) (/.f64 (-.f64 x (/.f64 x y)) y))))
#s(approx (/ y (- y -1)) #s(literal 1 binary64))
#s(approx (/ y (- y -1)) (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -1 binary64))))
#s(approx (/ y (- y -1)) (-.f64 (-.f64 (pow.f64 y #s(literal -2 binary64)) #s(literal -1 binary64)) (pow.f64 y #s(literal -1 binary64))))
#s(approx (/ y (- y -1)) (-.f64 (-.f64 (-.f64 (pow.f64 y #s(literal -2 binary64)) #s(literal -1 binary64)) (pow.f64 y #s(literal -1 binary64))) (pow.f64 y #s(literal -3 binary64))))
#s(approx (- y -1) y)
#s(approx (- y -1) (-.f64 y #s(literal -1 binary64)))
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 (-.f64 x (/.f64 x y)) y)))
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 (-.f64 x (/.f64 (-.f64 x (/.f64 x y)) y)) y)))
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 (-.f64 x (/.f64 x y)) y)))
#s(approx (* (/ y (- y -1)) x) (-.f64 x (/.f64 (-.f64 x (/.f64 (-.f64 x (/.f64 x y)) y)) y)))
#s(approx (/ y (- y -1)) (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -1 binary64))) y)))
#s(approx (/ y (- y -1)) (-.f64 (/.f64 (+.f64 (/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 y #s(literal -1 binary64))) y) #s(literal -1 binary64)) y) #s(literal -1 binary64)))

eval14.0ms (0.9%)

Memory
-15.6MiB live, 30.4MiB allocated; 3ms collecting garbage
Compiler

Compiled 2 114 to 459 computations (78.3% saved)

prune6.0ms (0.4%)

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

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New1350135
Fresh000
Picked044
Done011
Total1355140
Accuracy
100.0%
Counts
140 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.2%
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
100.0%
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
50.6%
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 x y)))
50.6%
#s(approx (/ (* x y) (+ y 1)) (*.f64 y x))
51.3%
#s(approx (/ (* x y) (+ y 1)) x)
Compiler

Compiled 94 to 56 computations (40.4% saved)

regimes14.0ms (0.9%)

Memory
-34.0MiB live, 13.0MiB allocated; 2ms collecting garbage
Counts
5 → 1
Calls
Call 1
Inputs
#s(approx (/ (* x y) (+ y 1)) x)
#s(approx (/ (* x y) (+ y 1)) (*.f64 y x))
#s(approx (/ (* x y) (+ y 1)) (-.f64 x (/.f64 x y)))
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
Outputs
(*.f64 (/.f64 y (-.f64 y #s(literal -1 binary64))) x)
Calls

3 calls:

10.0ms
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
2.0ms
x
2.0ms
y
Results
AccuracySegmentsBranch
100.0%1(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
100.0%1x
100.0%1y
Compiler

Compiled 9 to 10 computations (-11.1% saved)

regimes5.0ms (0.3%)

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

3 calls:

2.0ms
y
1.0ms
x
1.0ms
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
Results
AccuracySegmentsBranch
79.6%2(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
59.2%3x
98.2%3y
Compiler

Compiled 9 to 10 computations (-11.1% saved)

regimes1.0ms (0.1%)

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

1 calls:

1.0ms
y
Results
AccuracySegmentsBranch
97.7%3y
Compiler

Compiled 1 to 2 computations (-100% saved)

regimes3.0ms (0.2%)

Memory
6.8MiB live, 6.8MiB 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) (+ y 1)) x)
Outputs
#s(approx (/ (* x y) (+ y 1)) x)
Calls

3 calls:

1.0ms
x
1.0ms
(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
1.0ms
y
Results
AccuracySegmentsBranch
51.3%1x
51.3%1(/.f64 (*.f64 x y) (+.f64 y #s(literal 1 binary64)))
51.3%1y
Compiler

Compiled 9 to 10 computations (-11.1% saved)

bsearch40.0ms (2.6%)

Memory
-19.2MiB live, 32.4MiB allocated; 5ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
29.0ms
1.5532301487969538e-22
3.142817507631918
9.0ms
-128.5276100297378
-0.09309839367702698
Samples
25.0ms304×0valid
Compiler

Compiled 466 to 372 computations (20.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 19.0ms
ival-add!: 16.0ms (83.9% of total)
ival-mult!: 2.0ms (10.5% of total)
ival-div!: 1.0ms (5.2% of total)
adjust: 0.0ms (0% of total)

bsearch5.0ms (0.3%)

Memory
6.6MiB live, 6.6MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
4.0ms
1.5532301487969538e-22
3.142817507631918
0.0ms
-128.5276100297378
-0.09309839367702698
Samples
2.0ms48×0valid
Compiler

Compiled 390 to 334 computations (14.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 1.0ms
adjust: 0.0ms (0% of total)
ival-add!: 0.0ms (0% of total)
ival-mult!: 0.0ms (0% of total)
ival-div!: 0.0ms (0% of total)

derivations61.0ms (4%)

Memory
4.8MiB live, 52.1MiB allocated; 2ms collecting garbage
Stop Event
done
Compiler

Compiled 98 to 25 computations (74.5% saved)

preprocess39.0ms (2.5%)

Memory
-8.2MiB live, 80.9MiB allocated; 9ms collecting garbage
Remove

(negabs x)

Compiler

Compiled 406 to 152 computations (62.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...