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

Time bar (total: 7.6s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.3MiB live, 0.3MiB 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.2s (16.5%)

Memory
25.3MiB live, 1 115.6MiB allocated; 462ms collecting garbage
Samples
672.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 376.0ms
ival-mult: 261.0ms (69.5% of total)
ival-add: 55.0ms (14.6% of total)
ival-sub: 42.0ms (11.2% of total)
ival-true: 6.0ms (1.6% of total)
exact: 6.0ms (1.6% of total)
ival-assert: 3.0ms (0.8% of total)
adjust: 2.0ms (0.5% of total)
Bogosity

explain103.0ms (1.4%)

Memory
-3.6MiB live, 147.8MiB allocated; 30ms 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
32.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 (51.9% of total)
ival-sub: 3.0ms (22.2% of total)
ival-add: 2.0ms (14.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)

preprocess246.0ms (3.3%)

Memory
27.1MiB live, 207.4MiB allocated; 45ms 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
0.7MiB live, 0.7MiB 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)

simplify206.0ms (2.7%)

Memory
2.5MiB live, 151.0MiB allocated; 31ms 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

localize24.0ms (0.3%)

Memory
-5.8MiB live, 38.9MiB allocated; 8ms 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
15.0ms256×0valid
Compiler

Compiled 26 to 10 computations (61.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 7.0ms
ival-mult: 4.0ms (58% of total)
ival-sub: 1.0ms (14.5% of total)
ival-add: 1.0ms (14.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)

series10.0ms (0.1%)

Memory
-24.9MiB live, 19.6MiB allocated; 7ms 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
4.0ms
z
@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
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
@0
((+ (* x y) (* (- x 1) z)) (* x y) (* (- x 1) z) (- x 1))

simplify162.0ms (2.1%)

Memory
38.5MiB live, 232.4MiB allocated; 50ms 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)))

rewrite81.0ms (1.1%)

Memory
-20.5MiB live, 81.5MiB allocated; 14ms 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))

eval5.0ms (0.1%)

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

Compiled 816 to 152 computations (81.4% saved)

prune9.0ms (0.1%)

Memory
-31.0MiB live, 13.3MiB allocated; 6ms 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)

simplify152.0ms (2%)

Memory
22.9MiB live, 164.2MiB allocated; 24ms 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

localize39.0ms (0.5%)

Memory
18.6MiB live, 64.0MiB allocated; 8ms 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
26.0ms256×0valid
Compiler

Compiled 93 to 15 computations (83.9% saved)

Precisions
Click to see histograms. Total time spent on operations: 14.0ms
ival-mult: 7.0ms (51.8% of total)
ival-add: 3.0ms (22.2% of total)
ival-sub: 1.0ms (7.4% of total)
ival-neg: 1.0ms (7.4% 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)

series16.0ms (0.2%)

Memory
-19.3MiB live, 25.5MiB allocated; 14ms 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
7.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))
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
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))
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))

simplify214.0ms (2.8%)

Memory
-9.0MiB live, 183.7MiB allocated; 20ms 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))

rewrite130.0ms (1.7%)

Memory
-8.4MiB live, 86.0MiB allocated; 33ms 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))

eval10.0ms (0.1%)

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

Compiled 2 041 to 278 computations (86.4% saved)

prune35.0ms (0.5%)

Memory
-27.5MiB live, 19.3MiB allocated; 4ms 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)

simplify223.0ms (2.9%)

Memory
11.2MiB live, 202.8MiB allocated; 18ms 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

localize39.0ms (0.5%)

Memory
7.6MiB live, 54.6MiB allocated; 3ms 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
31.0ms256×0valid
Compiler

Compiled 46 to 14 computations (69.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 11.0ms
ival-mult: 5.0ms (44.8% of total)
ival-add: 3.0ms (26.9% of total)
ival-sub: 1.0ms (9% of total)
ival-neg: 1.0ms (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)

series6.0ms (0.1%)

Memory
11.0MiB live, 11.0MiB allocated; 0ms 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
1.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
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
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))

simplify177.0ms (2.3%)

Memory
10.3MiB live, 253.8MiB allocated; 29ms 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))

rewrite81.0ms (1.1%)

Memory
-31.3MiB live, 103.7MiB allocated; 12ms 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)

eval3.0ms (0%)

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

Compiled 859 to 113 computations (86.8% saved)

prune4.0ms (0.1%)

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

regimes30.0ms (0.4%)

Memory
-20.5MiB live, 82.6MiB allocated; 18ms 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:

19.0ms
z
3.0ms
x
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)

regimes13.0ms (0.2%)

Memory
-3.4MiB live, 43.0MiB allocated; 2ms 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:

4.0ms
y
3.0ms
z
3.0ms
x
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)

regimes5.0ms (0.1%)

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

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

Compiled 2 to 6 computations (-200% saved)

regimes7.0ms (0.1%)

Memory
-23.9MiB live, 21.2MiB allocated; 5ms 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:

5.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
23.8MiB live, 23.8MiB 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
y
2.0ms
x
1.0ms
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
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)

regimes5.0ms (0.1%)

Memory
-46.2MiB live, 13.4MiB allocated; 3ms 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:

3.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
19.8MiB live, 19.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) (* (- 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
(+.f64 (*.f64 x y) (*.f64 (-.f64 x #s(literal 1 binary64)) z))
1.0ms
z
1.0ms
x
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)

bsearch61.0ms (0.8%)

Memory
-8.7MiB live, 84.8MiB allocated; 5ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
41.0ms
0.001182390368042008
923857.2400295866
16.0ms
-8191.509523022472
-1.6438336824939404e-25
Samples
46.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: 4.0ms (44.4% of total)
ival-sub: 3.0ms (33.3% of total)
ival-add: 1.0ms (11.1% 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)

bsearch47.0ms (0.6%)

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

Compiled 462 to 389 computations (15.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 30.0ms
ival-add: 25.0ms (84.1% of total)
ival-mult: 3.0ms (10.1% of total)
ival-sub: 1.0ms (3.4% 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)

bsearch38.0ms (0.5%)

Memory
-9.5MiB live, 38.3MiB allocated; 8ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
0.0ms
4.7982142466851164e-39
7.46807825277474e-38
14.0ms
-8191.509523022472
-1.6438336824939404e-25
Samples
8.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 (50.2% of total)
ival-sub: 1.0ms (25.1% of total)
ival-add: 1.0ms (25.1% 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
4.1MiB live, 4.1MiB 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.4MiB live, 3.4MiB 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)

simplify62.0ms (0.8%)

Memory
14.0MiB live, 58.7MiB allocated; 7ms 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))

derivations4.0s (53.2%)

Memory
-288.8MiB live, 977.7MiB allocated; 3.2s collecting garbage
Stop Event
done
Compiler

Compiled 231 to 48 computations (79.2% saved)

preprocess36.0ms (0.5%)

Memory
-0.5MiB live, 89.0MiB allocated; 12ms 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...