Graphics.Rendering.Chart.Drawing:drawTextsR from Chart-1.5.3

Time bar (total: 4.2s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.9MiB live, 0.9MiB 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 11 to 10 computations (9.1% saved)

sample1.1s (25.4%)

Memory
10.6MiB live, 1 206.0MiB allocated; 453ms collecting garbage
Samples
752.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 410.0ms
ival-mult: 262.0ms (63.9% of total)
ival-add: 80.0ms (19.5% of total)
ival-sub: 58.0ms (14.1% of total)
exact: 6.0ms (1.5% of total)
ival-assert: 3.0ms (0.7% of total)
adjust: 2.0ms (0.5% of total)
Bogosity

explain80.0ms (1.9%)

Memory
27.4MiB live, 132.5MiB allocated; 11ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
50-0-(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
00-0-(*.f64 (-.f64 x #s(literal 1 binary64)) z)
00-0-y
00-0-(-.f64 x #s(literal 1 binary64))
00-0-#s(literal 1 binary64)
00-0-z
00-0-(*.f64 x y)
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
+.f64(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))nan-rescue50
(*.f64 x y)overflow39
(*.f64 (-.f64 x #s(literal 1 binary64)) z)overflow36
Confusion
Predicted +Predicted -
+50
-0251
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+500
-00251
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
0251
15
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
29.0ms512×0valid
Compiler

Compiled 61 to 28 computations (54.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 13.0ms
ival-mult: 7.0ms (53.7% of total)
ival-sub: 3.0ms (23% of total)
ival-add: 2.0ms (15.3% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess289.0ms (6.9%)

Memory
-21.5MiB live, 254.9MiB allocated; 42ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
03399
18393
216792
331692
438692
568292
6424491
7742791
089
0129
1209
2379
3669
41179
52949
620189
754499
086168
Stop Event
iter limit
node limit
iter limit
node limit
Calls
Call 1
Inputs
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Outputs
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(fma.f64 z (-.f64 x #s(literal 1 binary64)) (*.f64 y x))
Compiler

Compiled 9 to 8 computations (11.1% saved)

eval0.0ms (0%)

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

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.0MiB live, 1.0MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
98.0%
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Compiler

Compiled 9 to 8 computations (11.1% saved)

simplify282.0ms (6.7%)

Memory
12.5MiB live, 225.1MiB allocated; 152ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(-.f64 x #s(literal 1 binary64))
cost-diff0
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
cost-diff0
(*.f64 x y)
cost-diff1
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0824
01224
12024
23724
36624
411724
529424
6201824
7544924
0861623
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 x y)
x
y
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(-.f64 x #s(literal 1 binary64))
#s(literal 1 binary64)
z
Outputs
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(fma.f64 z (-.f64 x #s(literal 1 binary64)) (*.f64 y x))
(*.f64 x y)
(*.f64 y x)
x
y
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(*.f64 z (-.f64 x #s(literal 1 binary64)))
(-.f64 x #s(literal 1 binary64))
#s(literal 1 binary64)
z

localize22.0ms (0.5%)

Memory
-2.3MiB live, 43.3MiB allocated; 3ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(-.f64 x #s(literal 1 binary64))
accuracy0.0
(*.f64 x y)
accuracy0.00390625
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
accuracy1.046872935830206
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Samples
16.0ms256×0valid
Compiler

Compiled 26 to 10 computations (61.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 9.0ms
ival-mult: 6.0ms (68.8% of total)
ival-sub: 1.0ms (11.5% of total)
ival-add: 1.0ms (11.5% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series18.0ms (0.4%)

Memory
-19.6MiB live, 31.9MiB allocated; 8ms collecting garbage
Counts
4 → 25
Calls
Call 1
Inputs
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 x y)
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(-.f64 x #s(literal 1 binary64))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (* x y) #s(hole binary64 (* x y)))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
Calls

9 calls:

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

simplify227.0ms (5.4%)

Memory
-11.2MiB live, 223.0MiB allocated; 28ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
081313
1227305
2647279
31922279
45747279
08086279
Stop Event
iter limit
node limit
Counts
25 → 25
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (* x y) #s(hole binary64 (* x y)))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* x y) #s(hole binary64 (* x y)))
#s(approx (* x y) (*.f64 y x))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) (neg.f64 z))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (* (- x 1) z) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(literal -1 binary64))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (- x 1) (-.f64 x #s(literal 1 binary64)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) (*.f64 z x))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (* (- x 1) z) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) x)
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (- x 1) (-.f64 x #s(literal 1 binary64)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (* (- x 1) z) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (- x 1) (-.f64 x #s(literal 1 binary64)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (* (- x 1) z) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))

rewrite51.0ms (1.2%)

Memory
49.9MiB live, 138.8MiB allocated; 12ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0820
01220
14620
034819
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
4 → 38
Calls
Call 1
Inputs
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 x y)
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(-.f64 x #s(literal 1 binary64))
Outputs
(/.f64 (-.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 2 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 y x)))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (neg.f64 (*.f64 z (-.f64 x #s(literal 1 binary64)))) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (+.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 2 binary64)) (*.f64 (*.f64 y x) (neg.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))))))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 2 binary64)))) (neg.f64 (-.f64 (*.f64 y x) (*.f64 z (-.f64 x #s(literal 1 binary64))))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 2 binary64))) (-.f64 (*.f64 y x) (*.f64 z (-.f64 x #s(literal 1 binary64)))))
(/.f64 (+.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 (*.f64 y x) z) (-.f64 x #s(literal 1 binary64))))))
(/.f64 (+.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 3 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))
(fma.f64 z (-.f64 x #s(literal 1 binary64)) (*.f64 y x))
(fma.f64 (-.f64 x #s(literal 1 binary64)) z (*.f64 y x))
(fma.f64 y x (*.f64 (neg.f64 (neg.f64 (-.f64 x #s(literal 1 binary64)))) z))
(fma.f64 y x (*.f64 z (-.f64 x #s(literal 1 binary64))))
(fma.f64 x y (*.f64 (neg.f64 (neg.f64 (-.f64 x #s(literal 1 binary64)))) z))
(fma.f64 x y (*.f64 z (-.f64 x #s(literal 1 binary64))))
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 y x) (*.f64 z (-.f64 x #s(literal 1 binary64))))) (/.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 2 binary64)) (-.f64 (*.f64 y x) (*.f64 z (-.f64 x #s(literal 1 binary64))))))
(-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 (neg.f64 y) x))
(-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 (neg.f64 x) y))
(-.f64 (*.f64 y x) (*.f64 (neg.f64 z) (-.f64 x #s(literal 1 binary64))))
(-.f64 (*.f64 y x) (neg.f64 (*.f64 z (-.f64 x #s(literal 1 binary64)))))
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) #s(literal 3 binary64)) (fma.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (-.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(+.f64 (*.f64 z (-.f64 x #s(literal 1 binary64))) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (neg.f64 (neg.f64 (-.f64 x #s(literal 1 binary64)))) z))
(+.f64 (*.f64 y x) (*.f64 z (-.f64 x #s(literal 1 binary64))))
(*.f64 y x)
(*.f64 x y)
(*.f64 z (-.f64 x #s(literal 1 binary64)))
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(/.f64 (*.f64 (fma.f64 x x #s(literal -1 binary64)) z) (-.f64 x #s(literal -1 binary64)))
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)) z) (fma.f64 x x (-.f64 x #s(literal -1 binary64))))
(/.f64 (*.f64 z (fma.f64 x x #s(literal -1 binary64))) (-.f64 x #s(literal -1 binary64)))
(/.f64 (*.f64 z (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64))) (fma.f64 x x (-.f64 x #s(literal -1 binary64))))
(/.f64 (neg.f64 (fma.f64 x x #s(literal -1 binary64))) (neg.f64 (-.f64 x #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 x x (-.f64 x #s(literal -1 binary64)))))
(/.f64 (fma.f64 x x #s(literal -1 binary64)) (-.f64 x #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)) (fma.f64 x x (-.f64 x #s(literal -1 binary64))))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 x #s(literal -1 binary64))))
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (-.f64 x #s(literal -1 binary64)))) (/.f64 #s(literal 1 binary64) (fma.f64 x x (-.f64 x #s(literal -1 binary64)))))
(-.f64 x #s(literal 1 binary64))
(+.f64 x #s(literal -1 binary64))

eval11.0ms (0.3%)

Memory
-25.0MiB live, 33.5MiB allocated; 4ms collecting garbage
Compiler

Compiled 816 to 152 computations (81.4% saved)

prune4.0ms (0.1%)

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

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New44650
Fresh000
Picked101
Done000
Total45651
Accuracy
100.0%
Counts
51 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
76.3%
(+.f64 (*.f64 x y) #s(approx (* (- x 1) z) (neg.f64 z)))
100.0%
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
63.9%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
64.3%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
40.8%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
38.0%
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
Compiler

Compiled 168 to 130 computations (22.6% saved)

simplify284.0ms (6.8%)

Memory
-32.2MiB live, 253.4MiB allocated; 25ms collecting garbage
Localize:

Found 14 expressions of interest:

NewMetricScoreProgram
cost-diff0
(-.f64 x #s(literal 1 binary64))
cost-diff0
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
cost-diff0
(+.f64 z y)
cost-diff0
(*.f64 (+.f64 z y) x)
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
cost-diff0
(*.f64 y x)
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
cost-diff0
(neg.f64 z)
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
cost-diff0
(neg.f64 z)
cost-diff0
(+.f64 z y)
cost-diff0
(fma.f64 (+.f64 z y) x (neg.f64 z))
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
020117
027117
138117
265117
3133117
4250117
5464117
62329107
76046107
08057107
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(fma.f64 (+.f64 z y) x (neg.f64 z))
(+.f64 z y)
z
y
x
(neg.f64 z)
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
(neg.f64 z)
z
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
(*.f64 y x)
y
x
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
(*.f64 (+.f64 z y) x)
(+.f64 z y)
z
y
x
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(-.f64 x #s(literal 1 binary64))
x
#s(literal 1 binary64)
z
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(fma.f64 (+.f64 z y) x (neg.f64 z))
(+.f64 z y)
z
y
x
(neg.f64 z)
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
(neg.f64 z)
z
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
(*.f64 y x)
y
x
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
(*.f64 (+.f64 z y) x)
(+.f64 z y)
z
y
x
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(-.f64 x #s(literal 1 binary64))
x
#s(literal 1 binary64)
z

localize98.0ms (2.3%)

Memory
-1.9MiB live, 96.3MiB allocated; 11ms collecting garbage
Localize:

Found 14 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(-.f64 x #s(literal 1 binary64))
accuracy0.00390625
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
accuracy23.124726249438023
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
accuracy0.0
(+.f64 z y)
accuracy0.00390625
(*.f64 (+.f64 z y) x)
accuracy22.879419403225064
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
accuracy0.0
(*.f64 y x)
accuracy37.88801255447851
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
accuracy0.0
(neg.f64 z)
accuracy39.69411000980315
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
accuracy0.0
(fma.f64 (+.f64 z y) x (neg.f64 z))
accuracy0.0
(+.f64 z y)
accuracy0.0
(neg.f64 z)
accuracy0.0
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
Samples
88.0ms256×0valid
Compiler

Compiled 93 to 15 computations (83.9% saved)

Precisions
Click to see histograms. Total time spent on operations: 13.0ms
ival-mult: 7.0ms (52.2% of total)
ival-add: 3.0ms (22.4% of total)
ival-sub: 1.0ms (7.5% of total)
ival-neg: 1.0ms (7.5% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series11.0ms (0.3%)

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

9 calls:

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

simplify168.0ms (4%)

Memory
-7.9MiB live, 129.9MiB allocated; 9ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0163702
1443685
21242629
33526629
45946629
08334627
Stop Event
iter limit
node limit
Counts
56 → 56
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x (+ y z)) z)))
#s(approx (* y x) #s(hole binary64 (* x y)))
#s(approx (* (+ z y) x) #s(hole binary64 (* x (+ y z))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* x (+ (* -1 (+ y z)) (/ z x))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x z) z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (+ (* x y) (* x z)) z)))
#s(approx (+ z y) #s(hole binary64 z))
#s(approx (+ z y) #s(hole binary64 (+ y z)))
#s(approx (* (+ z y) x) #s(hole binary64 (* x z)))
#s(approx (* (+ z y) x) #s(hole binary64 (+ (* x y) (* x z))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x y)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* y (- (+ x (/ (* x z) y)) (/ z y)))))
#s(approx (+ z y) #s(hole binary64 y))
#s(approx (+ z y) #s(hole binary64 (* y (+ 1 (/ z y)))))
#s(approx (* (+ z y) x) #s(hole binary64 (* x y)))
#s(approx (* (+ z y) x) #s(hole binary64 (* y (+ x (/ (* x z) y)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (- (* x z) z) y)))))))
#s(approx (+ z y) #s(hole binary64 (* -1 (* y (- (* -1 (/ z y)) 1)))))
#s(approx (* (+ z y) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* x z) y)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (neg z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ z y) #s(hole binary64 (* z (+ 1 (/ y z)))))
#s(approx (* (+ z y) x) #s(hole binary64 (* z (+ x (/ (* x y) z)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (* -1 x))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (+ (* -1 x) (* -1 (/ (* x y) z))))))))
#s(approx (+ z y) #s(hole binary64 (* -1 (* z (- (* -1 (/ y z)) 1)))))
#s(approx (* (+ z y) x) #s(hole binary64 (* -1 (* z (+ (* -1 x) (* -1 (/ (* x y) z)))))))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x (+ y z)) z)))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* y x) #s(hole binary64 (* x y)))
#s(approx (* y x) (*.f64 y x))
#s(approx (* (+ z y) x) #s(hole binary64 (* x (+ y z))))
#s(approx (* (+ z y) x) (*.f64 (+.f64 z y) x))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) (neg.f64 z))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(literal -1 binary64))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (- x 1) (-.f64 x #s(literal 1 binary64)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) (*.f64 z x))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) x)
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (- x 1) (fma.f64 (/.f64 #s(literal -1 binary64) x) x x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* x (+ (* -1 (+ y z)) (/ z x))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (- x 1) (fma.f64 (/.f64 #s(literal -1 binary64) x) x x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x z) z)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (+ (* x y) (* x z)) z)))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 z))
#s(approx (+ z y) z)
#s(approx (+ z y) #s(hole binary64 (+ y z)))
#s(approx (+ z y) (+.f64 z y))
#s(approx (* (+ z y) x) #s(hole binary64 (* x z)))
#s(approx (* (+ z y) x) (*.f64 z x))
#s(approx (* (+ z y) x) #s(hole binary64 (+ (* x y) (* x z))))
#s(approx (* (+ z y) x) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* y (- (+ x (/ (* x z) y)) (/ z y)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 y))
#s(approx (+ z y) y)
#s(approx (+ z y) #s(hole binary64 (* y (+ 1 (/ z y)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (* (+ z y) x) #s(hole binary64 (* x y)))
#s(approx (* (+ z y) x) (*.f64 y x))
#s(approx (* (+ z y) x) #s(hole binary64 (* y (+ x (/ (* x z) y)))))
#s(approx (* (+ z y) x) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (- (* x z) z) y)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 (* -1 (* y (- (* -1 (/ z y)) 1)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (* (+ z y) x) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* x z) y)))))))
#s(approx (* (+ z y) x) (*.f64 (+.f64 z y) x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (neg z) #s(hole binary64 (* -1 z)))
#s(approx (neg z) (neg.f64 z))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 (* z (+ 1 (/ y z)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (* (+ z y) x) #s(hole binary64 (* z (+ x (/ (* x y) z)))))
#s(approx (* (+ z y) x) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (* -1 x))))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (+ (* -1 x) (* -1 (/ (* x y) z))))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 (* -1 (* z (- (* -1 (/ y z)) 1)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (* (+ z y) x) #s(hole binary64 (* -1 (* z (+ (* -1 x) (* -1 (/ (* x y) z)))))))
#s(approx (* (+ z y) x) (*.f64 (+.f64 z y) x))

rewrite46.0ms (1.1%)

Memory
12.3MiB live, 63.6MiB allocated; 9ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
020100
027100
188100
063795
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
12 → 62
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(fma.f64 (+.f64 z y) x (neg.f64 z))
(+.f64 z y)
(neg.f64 z)
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
(*.f64 y x)
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
(*.f64 (+.f64 z y) x)
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(-.f64 x #s(literal 1 binary64))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(/.f64 (-.f64 (*.f64 z z) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64))) (-.f64 (neg.f64 z) (*.f64 (+.f64 z y) x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)) (*.f64 z z))) (neg.f64 (-.f64 (*.f64 (+.f64 z y) x) (neg.f64 z))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 (+.f64 z y) x)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)) (*.f64 z z)) (-.f64 (*.f64 (+.f64 z y) x) (neg.f64 z)))
(/.f64 (+.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 3 binary64))) (fma.f64 z z (-.f64 (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)) (*.f64 (*.f64 (+.f64 z y) x) (neg.f64 z)))))
(/.f64 (+.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 3 binary64))) (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 (+.f64 z y) x)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64))))
(fma.f64 (+.f64 z y) x (neg.f64 z))
(fma.f64 x (+.f64 z y) (neg.f64 z))
(-.f64 (/.f64 (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)) (-.f64 (*.f64 (+.f64 z y) x) (neg.f64 z))) (/.f64 (*.f64 z z) (-.f64 (*.f64 (+.f64 z y) x) (neg.f64 z))))
(-.f64 (neg.f64 z) (*.f64 (neg.f64 (+.f64 z y)) x))
(-.f64 (neg.f64 z) (*.f64 (neg.f64 x) (+.f64 z y)))
(+.f64 (/.f64 (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 3 binary64)) (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 (+.f64 z y) x)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 (+.f64 z y) x)) (pow.f64 (*.f64 (+.f64 z y) x) #s(literal 2 binary64)))))
(+.f64 (*.f64 (+.f64 z y) x) (neg.f64 z))
(+.f64 (neg.f64 z) (*.f64 (+.f64 z y) x))
(/.f64 (-.f64 (*.f64 y y) (*.f64 z z)) (-.f64 y z))
(/.f64 (neg.f64 (*.f64 (+.f64 z y) (-.f64 z y))) (neg.f64 (-.f64 z y)))
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (neg.f64 (fma.f64 y (-.f64 y z) (*.f64 z z))))
(/.f64 (*.f64 (+.f64 z y) (-.f64 z y)) (-.f64 z y))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) (fma.f64 y y (-.f64 (*.f64 z z) (*.f64 z y))))
(/.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) (fma.f64 y (-.f64 y z) (*.f64 z z)))
(-.f64 (/.f64 (*.f64 z z) (-.f64 z y)) (/.f64 (*.f64 y y) (-.f64 z y)))
(+.f64 (/.f64 (pow.f64 z #s(literal 3 binary64)) (fma.f64 y (-.f64 y z) (*.f64 z z))) (/.f64 (pow.f64 y #s(literal 3 binary64)) (fma.f64 y (-.f64 y z) (*.f64 z z))))
(+.f64 z y)
(+.f64 y z)
(neg.f64 z)
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
(*.f64 y x)
(*.f64 x y)
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
(*.f64 (+.f64 z y) x)
(*.f64 x (+.f64 z y))
(/.f64 (*.f64 (*.f64 (+.f64 z y) (-.f64 z y)) x) (-.f64 z y))
(/.f64 (*.f64 (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) x) (fma.f64 y (-.f64 y z) (*.f64 z z)))
(/.f64 (*.f64 x (*.f64 (+.f64 z y) (-.f64 z y))) (-.f64 z y))
(/.f64 (*.f64 x (+.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (fma.f64 y (-.f64 y z) (*.f64 z z)))
(fma.f64 z x (*.f64 y x))
(fma.f64 y x (*.f64 z x))
(fma.f64 y x (*.f64 x z))
(fma.f64 x z (*.f64 y x))
(fma.f64 x y (*.f64 z x))
(fma.f64 x y (*.f64 x z))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 x z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 z x))
(+.f64 (*.f64 y x) (*.f64 x z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
(*.f64 (-.f64 x #s(literal 1 binary64)) z)
(*.f64 z (-.f64 x #s(literal 1 binary64)))
(/.f64 (*.f64 (fma.f64 x x #s(literal -1 binary64)) z) (-.f64 x #s(literal -1 binary64)))
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)) z) (fma.f64 x x (-.f64 x #s(literal -1 binary64))))
(/.f64 (*.f64 z (fma.f64 x x #s(literal -1 binary64))) (-.f64 x #s(literal -1 binary64)))
(/.f64 (*.f64 z (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64))) (fma.f64 x x (-.f64 x #s(literal -1 binary64))))
(/.f64 (neg.f64 (fma.f64 x x #s(literal -1 binary64))) (neg.f64 (-.f64 x #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 x x (-.f64 x #s(literal -1 binary64)))))
(/.f64 (fma.f64 x x #s(literal -1 binary64)) (-.f64 x #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal 1 binary64)) (fma.f64 x x (-.f64 x #s(literal -1 binary64))))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 x #s(literal -1 binary64))))
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 x x (-.f64 x #s(literal -1 binary64)))) (/.f64 #s(literal 1 binary64) (fma.f64 x x (-.f64 x #s(literal -1 binary64)))))
(-.f64 x #s(literal 1 binary64))
(+.f64 x #s(literal -1 binary64))

eval28.0ms (0.7%)

Memory
-16.9MiB live, 26.4MiB allocated; 5ms collecting garbage
Compiler

Compiled 2 041 to 278 computations (86.4% saved)

prune5.0ms (0.1%)

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

7 alts after pruning (2 fresh and 5 done)

PrunedKeptTotal
New91293
Fresh101
Picked055
Done000
Total92799
Accuracy
100.0%
Counts
99 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
76.3%
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
63.9%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
64.3%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
28.8%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
40.8%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
38.0%
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
Compiler

Compiled 108 to 79 computations (26.9% saved)

simplify215.0ms (5.1%)

Memory
-25.2MiB live, 211.4MiB allocated; 28ms collecting garbage
Localize:

Found 7 expressions of interest:

NewMetricScoreProgram
cost-diff0
(neg.f64 z)
cost-diff0
#s(approx (+ z y) y)
cost-diff0
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
cost-diff0
#s(approx (- x 1) x)
cost-diff0
(*.f64 #s(approx (- x 1) x) z)
cost-diff0
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01669
02069
13269
25369
39069
415269
534169
6210769
7567269
0803567
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
(*.f64 #s(approx (- x 1) x) z)
#s(approx (- x 1) x)
x
z
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
#s(approx (+ z y) y)
y
x
(neg.f64 z)
z
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
(*.f64 #s(approx (- x 1) x) z)
#s(approx (- x 1) x)
x
z
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
#s(approx (+ z y) y)
y
x
(neg.f64 z)
z

localize31.0ms (0.7%)

Memory
31.7MiB live, 77.0MiB allocated; 5ms collecting garbage
Localize:

Found 7 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
accuracy0.0
(neg.f64 z)
accuracy0.0
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
accuracy31.507316716961103
#s(approx (+ z y) y)
accuracy0.00390625
(*.f64 #s(approx (- x 1) x) z)
accuracy23.124726249438023
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
accuracy30.690859042833484
#s(approx (- x 1) x)
Samples
23.0ms256×0valid
Compiler

Compiled 46 to 14 computations (69.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 12.0ms
ival-mult: 5.0ms (42.9% of total)
ival-add: 4.0ms (34.3% of total)
ival-sub: 1.0ms (8.6% of total)
ival-neg: 1.0ms (8.6% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series39.0ms (0.9%)

Memory
-23.2MiB live, 37.5MiB allocated; 11ms collecting garbage
Counts
7 → 47
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
(*.f64 #s(approx (- x 1) x) z)
#s(approx (- x 1) x)
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
#s(approx (+ z y) y)
(neg.f64 z)
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x (+ y z)) z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* x (+ (* -1 (+ y z)) (/ z x))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x z) z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (+ (* x y) (* x z)) z)))
#s(approx (+ z y) #s(hole binary64 z))
#s(approx (+ z y) #s(hole binary64 (+ y z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x y)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* y (- (+ x (/ (* x z) y)) (/ z y)))))
#s(approx (+ z y) #s(hole binary64 y))
#s(approx (+ z y) #s(hole binary64 (* y (+ 1 (/ z y)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (- (* x z) z) y)))))))
#s(approx (+ z y) #s(hole binary64 (* -1 (* y (- (* -1 (/ z y)) 1)))))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (neg z) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ z y) #s(hole binary64 (* z (+ 1 (/ y z)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (* -1 x))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (+ (* -1 x) (* -1 (/ (* x y) z))))))))
#s(approx (+ z y) #s(hole binary64 (* -1 (* z (- (* -1 (/ y z)) 1)))))
Calls

9 calls:

TimeVariablePointExpression
18.0ms
z
@-inf
((+ (* x y) (* (- x 1) z)) (* (- x 1) z) (- x 1) (+ (* x y) (* (- x 1) z)) (+ (* (+ z y) x) (neg z)) (+ z y) (neg z))
17.0ms
z
@inf
((+ (* x y) (* (- x 1) z)) (* (- x 1) z) (- x 1) (+ (* x y) (* (- x 1) z)) (+ (* (+ z y) x) (neg z)) (+ z y) (neg z))
1.0ms
x
@-inf
((+ (* x y) (* (- x 1) z)) (* (- x 1) z) (- x 1) (+ (* x y) (* (- x 1) z)) (+ (* (+ z y) x) (neg z)) (+ z y) (neg z))
1.0ms
x
@inf
((+ (* x y) (* (- x 1) z)) (* (- x 1) z) (- x 1) (+ (* x y) (* (- x 1) z)) (+ (* (+ z y) x) (neg z)) (+ z y) (neg z))
1.0ms
y
@-inf
((+ (* x y) (* (- x 1) z)) (* (- x 1) z) (- x 1) (+ (* x y) (* (- x 1) z)) (+ (* (+ z y) x) (neg z)) (+ z y) (neg z))

simplify159.0ms (3.8%)

Memory
-4.4MiB live, 185.1MiB allocated; 18ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0145611
1387594
21089538
33143538
46169538
08154538
Stop Event
iter limit
node limit
Counts
47 → 47
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x (+ y z)) z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* x (+ (* -1 (+ y z)) (/ z x))))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x z) z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (+ (* x y) (* x z)) z)))
#s(approx (+ z y) #s(hole binary64 z))
#s(approx (+ z y) #s(hole binary64 (+ y z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x y)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* y (- (+ x (/ (* x z) y)) (/ z y)))))
#s(approx (+ z y) #s(hole binary64 y))
#s(approx (+ z y) #s(hole binary64 (* y (+ 1 (/ z y)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (- (* x z) z) y)))))))
#s(approx (+ z y) #s(hole binary64 (* -1 (* y (- (* -1 (/ z y)) 1)))))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (neg z) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ z y) #s(hole binary64 (* z (+ 1 (/ y z)))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (* -1 x))))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (+ (* -1 x) (* -1 (/ (* x y) z))))))))
#s(approx (+ z y) #s(hole binary64 (* -1 (* z (- (* -1 (/ y z)) 1)))))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* -1 z) (* x (+ y z)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 z)))
#s(approx (* (- x 1) z) (neg.f64 z))
#s(approx (* (- x 1) z) #s(hole binary64 (+ (* -1 z) (* x z))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (- x 1) #s(hole binary64 -1))
#s(approx (- x 1) #s(literal -1 binary64))
#s(approx (- x 1) #s(hole binary64 (- x 1)))
#s(approx (- x 1) (-.f64 x #s(literal 1 binary64)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x (+ y z)) z)))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* x z)))
#s(approx (* (- x 1) z) (*.f64 z x))
#s(approx (* (- x 1) z) #s(hole binary64 (* x (+ z (* -1 (/ z x))))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (- x 1) #s(hole binary64 x))
#s(approx (- x 1) x)
#s(approx (- x 1) #s(hole binary64 (* x (- 1 (/ 1 x)))))
#s(approx (- x 1) (*.f64 (/.f64 (-.f64 x #s(literal 1 binary64)) x) x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y z))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x (+ y (+ z (* -1 (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (* -1 z))))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* x (+ (* -1 y) (+ (* -1 z) (/ z x)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (* (- x 1) z) #s(hole binary64 (* -1 (* x (+ (* -1 z) (/ z x))))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (- x 1) #s(hole binary64 (* -1 (* x (- (/ 1 x) 1)))))
#s(approx (- x 1) (*.f64 (/.f64 (-.f64 x #s(literal 1 binary64)) x) x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* x (+ (* -1 (+ y z)) (/ z x))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (* x z) z)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (- (+ (* x y) (* x z)) z)))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 z))
#s(approx (+ z y) z)
#s(approx (+ z y) #s(hole binary64 (+ y z)))
#s(approx (+ z y) (+.f64 z y))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* y (+ x (/ (* z (- x 1)) y)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* x y)))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* y (- (+ x (/ (* x z) y)) (/ z y)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 y))
#s(approx (+ z y) y)
#s(approx (+ z y) #s(hole binary64 (* y (+ 1 (/ z y)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (* z (- x 1)) y)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* y (+ (* -1 x) (* -1 (/ (- (* x z) z) y)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 (* -1 (* y (- (* -1 (/ z y)) 1)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (* (- x 1) z) #s(hole binary64 (* z (- x 1))))
#s(approx (* (- x 1) z) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (+ (* x y) (* z (- x 1)))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (neg z) #s(hole binary64 (* -1 z)))
#s(approx (neg z) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- x 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* z (- (+ x (/ (* x y) z)) 1))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 (* z (+ 1 (/ y z)))))
#s(approx (+ z y) (+.f64 z y))
#s(approx (+ (* x y) (* (- x 1) z)) #s(hole binary64 (* -1 (* z (+ (* -1 (- x 1)) (* -1 (/ (* x y) z)))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (* -1 x))))))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 z (-.f64 x #s(literal 1 binary64))))
#s(approx (+ (* (+ z y) x) (neg z)) #s(hole binary64 (* -1 (* z (+ 1 (+ (* -1 x) (* -1 (/ (* x y) z))))))))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
#s(approx (+ z y) #s(hole binary64 (* -1 (* z (- (* -1 (/ y z)) 1)))))
#s(approx (+ z y) (+.f64 z y))

rewrite38.0ms (0.9%)

Memory
23.6MiB live, 69.5MiB allocated; 4ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01664
02064
18264
061762
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
7 → 21
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
(*.f64 #s(approx (- x 1) x) z)
#s(approx (- x 1) x)
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
#s(approx (+ z y) y)
(neg.f64 z)
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
(*.f64 #s(approx (- x 1) x) z)
(*.f64 z #s(approx (- x 1) x))
#s(approx (- x 1) x)
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
(/.f64 (-.f64 (*.f64 z z) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64))) (-.f64 (neg.f64 z) (*.f64 #s(approx (+ z y) y) x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)) (*.f64 z z))) (neg.f64 (-.f64 (*.f64 #s(approx (+ z y) y) x) (neg.f64 z))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 #s(approx (+ z y) y) x)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)) (*.f64 z z)) (-.f64 (*.f64 #s(approx (+ z y) y) x) (neg.f64 z)))
(/.f64 (+.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 3 binary64))) (fma.f64 z z (-.f64 (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)) (*.f64 (*.f64 #s(approx (+ z y) y) x) (neg.f64 z)))))
(/.f64 (+.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 3 binary64))) (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 #s(approx (+ z y) y) x)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64))))
(fma.f64 #s(approx (+ z y) y) x (neg.f64 z))
(fma.f64 x #s(approx (+ z y) y) (neg.f64 z))
(-.f64 (/.f64 (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)) (-.f64 (*.f64 #s(approx (+ z y) y) x) (neg.f64 z))) (/.f64 (*.f64 z z) (-.f64 (*.f64 #s(approx (+ z y) y) x) (neg.f64 z))))
(-.f64 (neg.f64 z) (*.f64 (neg.f64 #s(approx (+ z y) y)) x))
(-.f64 (neg.f64 z) (*.f64 (neg.f64 x) #s(approx (+ z y) y)))
(+.f64 (/.f64 (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 3 binary64)) (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 #s(approx (+ z y) y) x)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)))) (/.f64 (pow.f64 (neg.f64 z) #s(literal 3 binary64)) (fma.f64 (neg.f64 z) (-.f64 (neg.f64 z) (*.f64 #s(approx (+ z y) y) x)) (pow.f64 (*.f64 #s(approx (+ z y) y) x) #s(literal 2 binary64)))))
(+.f64 (*.f64 #s(approx (+ z y) y) x) (neg.f64 z))
(+.f64 (neg.f64 z) (*.f64 #s(approx (+ z y) y) x))
#s(approx (+ z y) y)
(neg.f64 z)

eval7.0ms (0.2%)

Memory
-33.1MiB live, 13.2MiB allocated; 4ms collecting garbage
Compiler

Compiled 859 to 113 computations (86.8% saved)

prune4.0ms (0.1%)

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

7 alts after pruning (0 fresh and 7 done)

PrunedKeptTotal
New35035
Fresh000
Picked022
Done055
Total35742
Accuracy
100.0%
Counts
42 → 7
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
76.3%
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
63.9%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
64.3%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
28.8%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
40.8%
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
38.0%
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
Compiler

Compiled 237 to 111 computations (53.2% saved)

regimes57.0ms (1.3%)

Memory
-12.0MiB live, 35.5MiB allocated; 1ms collecting garbage
Counts
9 → 1
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z)))
(+.f64 (*.f64 x y) #s(approx (* (- x 1) z) (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
Calls

4 calls:

46.0ms
x
3.0ms
z
3.0ms
y
3.0ms
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Results
AccuracySegmentsBranch
100.0%1(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
100.0%1x
100.0%1y
100.0%1z
Compiler

Compiled 12 to 17 computations (-41.7% saved)

regimes11.0ms (0.3%)

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

4 calls:

3.0ms
z
3.0ms
x
3.0ms
y
3.0ms
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Results
AccuracySegmentsBranch
87.6%3(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
99.0%3x
89.5%3y
90.5%4z
Compiler

Compiled 12 to 17 computations (-41.7% saved)

regimes12.0ms (0.3%)

Memory
-32.0MiB live, 21.2MiB allocated; 5ms collecting garbage
Counts
5 → 3
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
#s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))
Calls

2 calls:

10.0ms
y
2.0ms
x
Results
AccuracySegmentsBranch
82.7%3y
89.2%3x
Compiler

Compiled 2 to 6 computations (-200% saved)

regimes4.0ms (0.1%)

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

2 calls:

2.0ms
x
2.0ms
z
Results
AccuracySegmentsBranch
68.6%3z
88.8%3x
Compiler

Compiled 2 to 6 computations (-200% saved)

regimes5.0ms (0.1%)

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

3 calls:

2.0ms
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
2.0ms
x
2.0ms
y
Results
AccuracySegmentsBranch
63.3%5y
54.3%3(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
70.3%3x
Compiler

Compiled 11 to 14 computations (-27.3% saved)

regimes6.0ms (0.1%)

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

2 calls:

4.0ms
z
1.0ms
x
Results
AccuracySegmentsBranch
55.3%3z
65.6%3x
Compiler

Compiled 2 to 6 computations (-200% saved)

regimes5.0ms (0.1%)

Memory
16.3MiB live, 16.3MiB 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 1) z)) (neg.f64 z))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
Calls

4 calls:

1.0ms
y
1.0ms
x
1.0ms
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
1.0ms
z
Results
AccuracySegmentsBranch
38.0%1(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
38.0%1z
38.0%1y
38.0%1x
Compiler

Compiled 12 to 17 computations (-41.7% saved)

bsearch34.0ms (0.8%)

Memory
-15.2MiB live, 76.8MiB allocated; 6ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
12.0ms
0.001182390368042008
923857.2400295866
17.0ms
-8191.509523022472
-1.6438336824939404e-25
Samples
17.0ms320×0valid
Compiler

Compiled 692 to 534 computations (22.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 9.0ms
ival-mult: 6.0ms (65.5% of total)
ival-sub: 1.0ms (10.9% of total)
ival-add: 1.0ms (10.9% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch23.0ms (0.6%)

Memory
44.0MiB live, 44.0MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
8.0ms
4.7982142466851164e-39
7.46807825277474e-38
12.0ms
-3666563498646.615
-194251.57476272885
Samples
12.0ms240×0valid
Compiler

Compiled 462 to 389 computations (15.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-mult: 3.0ms (50.4% of total)
ival-sub: 1.0ms (16.8% of total)
ival-add: 1.0ms (16.8% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch36.0ms (0.9%)

Memory
-24.3MiB live, 26.4MiB allocated; 10ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
0.0ms
4.7982142466851164e-39
7.46807825277474e-38
33.0ms
-8191.509523022472
-1.6438336824939404e-25
Samples
27.0ms160×0valid
Compiler

Compiled 471 to 405 computations (14% saved)

Precisions
Click to see histograms. Total time spent on operations: 4.0ms
ival-mult: 2.0ms (47.9% of total)
ival-sub: 1.0ms (23.9% of total)
ival-add: 1.0ms (23.9% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch2.0ms (0%)

Memory
3.3MiB live, 3.3MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
0.0ms
4.7982142466851164e-39
7.46807825277474e-38
1.0ms
-8191.509523022472
-1.6438336824939404e-25
Compiler

Compiled 481 to 399 computations (17% saved)

bsearch1.0ms (0%)

Memory
3.2MiB live, 3.2MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
0.0ms
4.7982142466851164e-39
7.46807825277474e-38
1.0ms
-3666563498646.615
-194251.57476272885
Compiler

Compiled 387 to 344 computations (11.1% saved)

simplify99.0ms (2.4%)

Memory
-9.6MiB live, 79.3MiB allocated; 19ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
045231
168231
288231
3124231
4182231
5434231
63294231
77396231
Stop Event
node limit
Calls
Call 1
Inputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) (if (<=.f64 x #s(literal 1 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z))) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))))
(if (<=.f64 x #s(literal -200000 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))))
(if (<=.f64 x #s(literal -735237348132373/1267650600228229401496703205376 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))))
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))))
(if (<=.f64 x #s(literal -200000 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))
Outputs
#s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 (+.f64 z y) x (neg.f64 z)))
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) (if (<=.f64 x #s(literal 1 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z))) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))))
(if (or (<=.f64 x #s(literal -1 binary64)) (not (<=.f64 x #s(literal 1 binary64)))) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) #s(approx (+ (* x y) (* (- x 1) z)) (fma.f64 #s(approx (+ z y) y) x (neg.f64 z))))
(if (<=.f64 x #s(literal -200000 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))))
(if (or (<=.f64 x #s(literal -200000 binary64)) (not (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)))) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (-.f64 x #s(literal 1 binary64)) z)))
(if (<=.f64 x #s(literal -735237348132373/1267650600228229401496703205376 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x))))
(if (or (<=.f64 x #s(literal -735237348132373/1267650600228229401496703205376 binary64)) (not (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)))) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 (+.f64 z y) x)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)))
(if (<=.f64 x #s(literal -1 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 #s(approx (- x 1) x) z)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))))
(if (<=.f64 x #s(literal -200000 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x)) (if (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x))))
(if (or (<=.f64 x #s(literal -200000 binary64)) (not (<=.f64 x #s(literal 4980610507814139/383123885216472214589586756787577295904684780545900544 binary64)))) #s(approx (+ (* x y) (* (- x 1) z)) (*.f64 y x)) #s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z)))
#s(approx (+ (* x y) (* (- x 1) z)) (neg.f64 z))

derivations683.0ms (16.2%)

Memory
-11.8MiB live, 325.2MiB allocated; 55ms collecting garbage
Stop Event
done
Compiler

Compiled 231 to 48 computations (79.2% saved)

preprocess40.0ms (0.9%)

Memory
40.5MiB live, 86.6MiB allocated; 5ms collecting garbage
Compiler

Compiled 480 to 112 computations (76.7% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...