Diagrams.Solve.Polynomial:quadForm from diagrams-solve-0.1, A

Time bar (total: 2.7s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated

analyze0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
100%99.9%0%0.1%0%0%0%1
Compiler

Compiled 9 to 9 computations (0% saved)

sample823.0ms (30%)

Memory
20.5MiB live, 685.1MiB allocated
Samples
513.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 186.0ms
ival-mult: 129.0ms (69.4% of total)
ival-sub: 43.0ms (23.1% of total)
ival-true: 6.0ms (3.2% of total)
exact: 5.0ms (2.7% of total)
ival-assert: 3.0ms (1.6% of total)
Bogosity

explain76.0ms (2.8%)

Memory
13.8MiB live, 136.9MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-y
00-0-(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
00-0-(*.f64 y #s(literal 4 binary64))
00-0-#s(literal 4 binary64)
00-0-z
00-0-(*.f64 (*.f64 y #s(literal 4 binary64)) z)
00-0-x
Confusion
Predicted +Predicted -
+00
-0256
Precision
0/0
Recall
0/0
Confusion?
Predicted +Predicted MaybePredicted -
+000
-00256
Precision?
0/0
Recall?
0/0
Freqs
test
numberfreq
0256
Total Confusion?
Predicted +Predicted MaybePredicted -
+000
-001
Precision?
0/0
Recall?
0/0
Samples
33.0ms512×0valid
Compiler

Compiled 68 to 32 computations (52.9% saved)

Precisions
Click to see histograms. Total time spent on operations: 10.0ms
ival-mult: 7.0ms (68.7% of total)
ival-sub: 3.0ms (29.5% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess45.0ms (1.6%)

Memory
10.6MiB live, 49.8MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02669
19266
224163
355963
490463
599863
6101263
7101263
8101263
077
0107
1197
2497
3997
41317
51707
62217
72637
83487
94007
104307
04306
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Outputs
(fma.f64 (*.f64 z y) #s(literal -4 binary64) x)
Symmetry

(sort y z)

Compiler

Compiled 7 to 7 computations (0% saved)

eval0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated
Compiler

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.2MiB live, 1.2MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Compiler

Compiled 7 to 7 computations (0% saved)

simplify15.0ms (0.6%)

Memory
-25.1MiB live, 13.7MiB allocated
Algorithm
egg-herbie
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 y #s(literal 4 binary64))
cost-diff0
(*.f64 (*.f64 y #s(literal 4 binary64)) z)
cost-diff128
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0719
01019
11919
24919
39919
413119
517019
622119
726319
834819
940019
1043019
043018
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
x
(*.f64 (*.f64 y #s(literal 4 binary64)) z)
(*.f64 y #s(literal 4 binary64))
y
#s(literal 4 binary64)
z
Outputs
(fma.f64 (*.f64 z y) #s(literal -4 binary64) x)
x
(*.f64 z (*.f64 #s(literal 4 binary64) y))
(*.f64 #s(literal 4 binary64) y)
y
#s(literal 4 binary64)
z

localize19.0ms (0.7%)

Memory
5.8MiB live, 45.0MiB allocated
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
accuracy0
(*.f64 (*.f64 y #s(literal 4 binary64)) z)
accuracy0
(*.f64 y #s(literal 4 binary64))
accuracy0.00390625
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Samples
14.0ms256×0valid
Compiler

Compiled 40 to 16 computations (60% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-mult: 4.0ms (71.9% of total)
ival-sub: 1.0ms (18% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series8.0ms (0.3%)

Memory
16.6MiB live, 16.6MiB allocated
Counts
3 → 72
Calls
Call 1
Inputs
#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())
#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())
#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())
Outputs
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 y #s(literal 4 binary64)) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 y #s(literal 4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z)) #<representation binary64>) () ())) ())
Calls

9 calls:

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

simplify277.0ms (10.1%)

Memory
-26.1MiB live, 212.3MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
038374
1105374
2262374
3894374
42564374
54472374
65485374
75862374
86076374
96188374
106230374
08292347
Stop Event
iter limit
node limit
Counts
72 → 68
Calls
Call 1
Inputs
x
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* -4 (* y z))
(* z (- (/ x z) (* 4 y)))
(* z (- (/ x z) (* 4 y)))
(* z (- (/ x z) (* 4 y)))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* -4 (* y z))
(* -1 (* z (- (* -1 (/ x z)) (* -4 y))))
(* -1 (* z (- (* -1 (/ x z)) (* -4 y))))
(* -1 (* z (- (* -1 (/ x z)) (* -4 y))))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
x
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 y)
(* 4 y)
(* 4 y)
(* 4 y)
(* -4 (* y z))
(* y (- (/ x y) (* 4 z)))
(* y (- (/ x y) (* 4 z)))
(* y (- (/ x y) (* 4 z)))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 y)
(* 4 y)
(* 4 y)
(* 4 y)
(* -4 (* y z))
(* -1 (* y (- (* -1 (/ x y)) (* -4 z))))
(* -1 (* y (- (* -1 (/ x y)) (* -4 z))))
(* -1 (* y (- (* -1 (/ x y)) (* -4 z))))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 (* y z))
(* 4 y)
(* 4 y)
(* 4 y)
(* 4 y)
(* -4 (* y z))
(- x (* 4 (* y z)))
(- x (* 4 (* y z)))
(- x (* 4 (* y z)))
x
(* x (+ 1 (* -4 (/ (* y z) x))))
(* x (+ 1 (* -4 (/ (* y z) x))))
(* x (+ 1 (* -4 (/ (* y z) x))))
x
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
Outputs
x
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
x
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) (*.f64 z y))
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 #s(literal 4 binary64) y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
x
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
x
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)

rewrite210.0ms (7.7%)

Memory
32.3MiB live, 266.5MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0715
01015
13215
221915
3211815
0834014
Stop Event
iter limit
node limit
iter limit
Counts
3 → 207
Calls
Call 1
Inputs
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(*.f64 (*.f64 y #s(literal 4 binary64)) z)
(*.f64 y #s(literal 4 binary64))
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval36.0ms (1.3%)

Memory
-7.6MiB live, 73.9MiB allocated
Compiler

Compiled 9 026 to 642 computations (92.9% saved)

prune7.0ms (0.3%)

Memory
-13.6MiB live, 25.0MiB allocated
Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New2732275
Fresh000
Picked101
Done000
Total2742276
Accuracy
100.0%
Counts
276 → 2
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
54.9%
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
Compiler

Compiled 19 to 17 computations (10.5% saved)

simplify17.0ms (0.6%)

Memory
-1.2MiB live, 37.7MiB allocated
Algorithm
egg-herbie
Localize:

Found 5 expressions of interest:

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

Useful iterations: 1 (0.0ms)

IterNodesCost
01337
01837
13536
26236
310136
413436
517336
622436
726836
835336
940536
1043536
043536
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
z
y
#s(literal -4 binary64)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal -4 binary64) z)
#s(literal -4 binary64)
z
y
x
Outputs
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 #s(literal -4 binary64) z) y))
(*.f64 (*.f64 #s(literal -4 binary64) z) y)
(*.f64 z y)
z
y
#s(literal -4 binary64)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 #s(literal -4 binary64) z)
#s(literal -4 binary64)
z
y
x

localize36.0ms (1.3%)

Memory
-5.3MiB live, 76.4MiB allocated
Localize:

Found 5 expressions of interest:

NewMetricScoreProgram
accuracy0
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
accuracy0
(*.f64 #s(literal -4 binary64) z)
accuracy0
(*.f64 z y)
accuracy0.00390625
(*.f64 (*.f64 z y) #s(literal -4 binary64))
accuracy28.890184312576558
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
Samples
26.0ms256×0valid
Compiler

Compiled 71 to 28 computations (60.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 16.0ms
ival-mult: 13.0ms (81.6% of total)
ival-sub: 1.0ms (6.3% of total)
ival-add: 1.0ms (6.3% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series9.0ms (0.3%)

Memory
34.0MiB live, 34.0MiB allocated
Counts
5 → 132
Calls
Call 1
Inputs
#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())
#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())
#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())
#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())
#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())
Outputs
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf z) (#s(alt #<batchref> (patch (*.f64 #s(literal -4 binary64) z) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 (*.f64 z y) #s(literal -4 binary64)) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (*.f64 z y) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf y) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor 0 x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch #s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64))) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
#s(alt #<batchref> (taylor -inf x) (#s(alt #<batchref> (patch (fma.f64 (*.f64 #s(literal -4 binary64) z) y x) #<representation binary64>) () ())) ())
Calls

9 calls:

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

simplify216.0ms (7.9%)

Memory
-15.7MiB live, 107.1MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
048664
1143664
2369664
31010664
42675664
55453664
67558664
08080610
Stop Event
iter limit
node limit
Counts
132 → 124
Calls
Call 1
Inputs
x
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* y z)
(* y z)
(* y z)
(* y z)
x
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(* -4 z)
(* -4 z)
(* -4 z)
(* -4 z)
(* -4 (* y z))
(* z (- (/ x z) (* 4 y)))
(* z (- (/ x z) (* 4 y)))
(* z (- (/ x z) (* 4 y)))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* y z)
(* y z)
(* y z)
(* y z)
(* -4 (* y z))
(* z (+ (* -4 y) (/ x z)))
(* z (+ (* -4 y) (/ x z)))
(* z (+ (* -4 y) (/ x z)))
(* -4 z)
(* -4 z)
(* -4 z)
(* -4 z)
(* -4 (* y z))
(* -1 (* z (- (* -1 (/ x z)) (* -4 y))))
(* -1 (* z (- (* -1 (/ x z)) (* -4 y))))
(* -1 (* z (- (* -1 (/ x z)) (* -4 y))))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* y z)
(* y z)
(* y z)
(* y z)
(* -4 (* y z))
(* -1 (* z (+ (* -1 (/ x z)) (* 4 y))))
(* -1 (* z (+ (* -1 (/ x z)) (* 4 y))))
(* -1 (* z (+ (* -1 (/ x z)) (* 4 y))))
(* -4 z)
(* -4 z)
(* -4 z)
(* -4 z)
x
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* y z)
(* y z)
(* y z)
(* y z)
x
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(* -4 (* y z))
(* y (- (/ x y) (* 4 z)))
(* y (- (/ x y) (* 4 z)))
(* y (- (/ x y) (* 4 z)))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* y z)
(* y z)
(* y z)
(* y z)
(* -4 (* y z))
(* y (+ (* -4 z) (/ x y)))
(* y (+ (* -4 z) (/ x y)))
(* y (+ (* -4 z) (/ x y)))
(* -4 (* y z))
(* -1 (* y (- (* -1 (/ x y)) (* -4 z))))
(* -1 (* y (- (* -1 (/ x y)) (* -4 z))))
(* -1 (* y (- (* -1 (/ x y)) (* -4 z))))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* -4 (* y z))
(* y z)
(* y z)
(* y z)
(* y z)
(* -4 (* y z))
(* -1 (* y (+ (* -1 (/ x y)) (* 4 z))))
(* -1 (* y (+ (* -1 (/ x y)) (* 4 z))))
(* -1 (* y (+ (* -1 (/ x y)) (* 4 z))))
(* -4 (* y z))
(- x (* 4 (* y z)))
(- x (* 4 (* y z)))
(- x (* 4 (* y z)))
(* -4 (* y z))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
(+ x (* -4 (* y z)))
x
(* x (+ 1 (* -4 (/ (* y z) x))))
(* x (+ 1 (* -4 (/ (* y z) x))))
(* x (+ 1 (* -4 (/ (* y z) x))))
x
(* x (+ 1 (* -4 (/ (* y z) x))))
(* x (+ 1 (* -4 (/ (* y z) x))))
(* x (+ 1 (* -4 (/ (* y z) x))))
x
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
x
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
(* -1 (* x (- (* 4 (/ (* y z) x)) 1)))
Outputs
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
(*.f64 #s(literal -4 binary64) z)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 z y)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
x
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)
(fma.f64 (*.f64 #s(literal -4 binary64) y) z x)

rewrite179.0ms (6.5%)

Memory
20.9MiB live, 216.2MiB allocated
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01330
01830
15829
239229
3446429
0822129
Stop Event
iter limit
node limit
iter limit
Counts
5 → 195
Calls
Call 1
Inputs
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
(*.f64 (*.f64 z y) #s(literal -4 binary64))
(*.f64 z y)
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(*.f64 #s(literal -4 binary64) z)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval36.0ms (1.3%)

Memory
-0.2MiB live, 75.4MiB allocated
Compiler

Compiled 6 772 to 546 computations (91.9% saved)

prune22.0ms (0.8%)

Memory
1.3MiB live, 45.5MiB allocated
Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New3190319
Fresh000
Picked022
Done000
Total3192321
Accuracy
100.0%
Counts
321 → 2
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
54.9%
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
Compiler

Compiled 45 to 34 computations (24.4% saved)

regimes13.0ms (0.5%)

Memory
-14.3MiB live, 24.9MiB allocated
Counts
3 → 1
Calls
Call 1
Inputs
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
(-.f64 x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Outputs
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
Calls

6 calls:

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

Compiled 18 to 27 computations (-50% saved)

regimes9.0ms (0.3%)

Memory
-19.2MiB live, 20.2MiB allocated
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
Outputs
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
Calls

6 calls:

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

Compiled 18 to 27 computations (-50% saved)

simplify25.0ms (0.9%)

Memory
8.8MiB live, 47.3MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01319
11619
Stop Event
saturated
Calls
Call 1
Inputs
(fma.f64 (*.f64 #s(literal -4 binary64) z) y x)
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 z y) #s(literal -4 binary64)))
Outputs
(fma.f64 (*.f64 z #s(literal -4 binary64)) y x)
#s(approx (- x (* (* y 4) z)) (*.f64 (*.f64 y z) #s(literal -4 binary64)))

soundness621.0ms (22.6%)

Memory
29.8MiB live, 220.0MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
038374
1105374
2262374
3894374
42564374
54472374
65485374
75862374
86076374
96188374
106230374
08292347
0715
01015
13215
221915
3211815
0834014
Stop Event
done
iter limit
node limit
iter limit
iter limit
node limit
Compiler

Compiled 37 to 29 computations (21.6% saved)

preprocess46.0ms (1.7%)

Memory
8.1MiB live, 45.0MiB allocated
Remove

(sort y z)

Compiler

Compiled 88 to 76 computations (13.6% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...