Optimisation.CirclePacking:place from circle-packing-0.1.0.4, I

Time bar (total: 2.2s)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

analyze0.0ms (0%)

Memory
0.5MiB live, 0.5MiB 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 7 to 7 computations (0% saved)

sample661.0ms (29.8%)

Memory
-141.0MiB live, 1 148.9MiB allocated
Samples
446.0ms8 250×0valid
0.0ms1valid
0.0ms3valid
Precisions
Click to see histograms. Total time spent on operations: 115.0ms
ival-add: 105.0ms (91.6% of total)
ival-true: 6.0ms (5.2% of total)
ival-assert: 3.0ms (2.6% of total)
adjust: 0.0ms (0% of total)
Bogosity

explain52.0ms (2.3%)

Memory
-24.7MiB live, 100.3MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(+.f64 (+.f64 x y) z)
00-0-y
00-0-(+.f64 x y)
00-0-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
18.0ms512×0valid
Compiler

Compiled 31 to 19 computations (38.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-add: 5.0ms (88% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess30.0ms (1.3%)

Memory
12.4MiB live, 50.7MiB allocated
Algorithm
egg-herbie
Rules
132×associate--r+
126×sub-neg
120×associate-+l-
112×distribute-rgt-in
106×unsub-neg
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02150
16245
219145
349045
478045
584345
685945
055
075
1115
2185
3205
0205
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(+.f64 (+.f64 x y) z)
Outputs
(+.f64 (+.f64 x y) z)
(+.f64 z (+.f64 y x))
Symmetry

(sort x y z)

Compiler

Compiled 5 to 5 computations (0% saved)

eval0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated
Compiler

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(+.f64 (+.f64 x y) z)
Compiler

Compiled 5 to 5 computations (0% saved)

simplify3.0ms (0.1%)

Memory
5.4MiB live, 5.4MiB allocated
Algorithm
egg-herbie
Localize:

Found 2 expressions of interest:

NewMetricScoreProgram
cost-diff0
(+.f64 x y)
cost-diff0
(+.f64 (+.f64 x y) z)
Rules
24×lower-+.f32
20×lower-+.f64
10×+-commutative
associate-+l+
associate-+r+
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0511
0711
11111
21811
32011
02011
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(+.f64 (+.f64 x y) z)
(+.f64 x y)
x
y
z
Outputs
(+.f64 (+.f64 x y) z)
(+.f64 z (+.f64 y x))
(+.f64 x y)
(+.f64 y x)
x
y
z

localize17.0ms (0.8%)

Memory
-13.1MiB live, 28.8MiB allocated
Localize:

Found 2 expressions of interest:

NewMetricScoreProgram
accuracy0
(+.f64 (+.f64 x y) z)
accuracy0
(+.f64 x y)
Samples
14.0ms256×0valid
Compiler

Compiled 13 to 7 computations (46.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-add: 6.0ms (100.5% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series3.0ms (0.1%)

Memory
6.9MiB live, 6.9MiB allocated
Counts
2 → 60
Calls
Call 1
Inputs
#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())
#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())
Outputs
#s(alt (+ x y) (taylor 0 z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt z (taylor inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt z (taylor -inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ x y))) (taylor inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ x y))) (taylor inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ x y))) (taylor inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) 1))) (taylor -inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) 1))) (taylor -inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) 1))) (taylor -inf y) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ y x))) (taylor inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ y x))) (taylor inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ y x))) (taylor inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt (+.f64 (+.f64 x y) z) (patch (+.f64 (+.f64 x y) z) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ y x)) 1))) (taylor -inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ y x)) 1))) (taylor -inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ y x)) 1))) (taylor -inf x) (#s(alt (+.f64 x y) (patch (+.f64 x y) #<representation binary64>) () ())) ())
Calls

9 calls:

TimeVariablePointExpression
0.0ms
y
@-inf
((+ (+ x y) z) (+ x y))
0.0ms
x
@-inf
((+ (+ x y) z) (+ x y))
0.0ms
z
@inf
((+ (+ x y) z) (+ x y))
0.0ms
y
@inf
((+ (+ x y) z) (+ x y))
0.0ms
x
@inf
((+ (+ x y) z) (+ x y))

simplify122.0ms (5.5%)

Memory
15.4MiB live, 129.6MiB allocated
Algorithm
egg-herbie
Rules
4 768×lower-/.f32
4 768×lower-/.f64
2 864×lower-fma.f64
2 864×lower-fma.f32
2 160×lower-*.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
051210
1148210
2381210
31186210
42945210
54910210
65892210
76011210
86105210
96119210
08863210
Stop Event
iter limit
node limit
Counts
60 → 48
Calls
Call 1
Inputs
(+ x y)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+ x z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
x
(+ x y)
(+ x y)
(+ x y)
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
y
(* y (+ 1 (/ x y)))
(* y (+ 1 (/ x y)))
(* y (+ 1 (/ x y)))
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
y
(* -1 (* y (- (* -1 (/ x y)) 1)))
(* -1 (* y (- (* -1 (/ x y)) 1)))
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+ y z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
y
(+ x y)
(+ x y)
(+ x y)
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
x
(* x (+ 1 (/ y x)))
(* x (+ 1 (/ y x)))
(* x (+ 1 (/ y x)))
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
x
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* -1 (* x (- (* -1 (/ y x)) 1)))
Outputs
(+ x y)
(+.f64 y x)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z x) y)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z x) y)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z x) y)
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z x) y)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z x) y)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z x) y)
(+ x z)
(+.f64 z x)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
x
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z x) y)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z x) y)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z x) y)
y
(* y (+ 1 (/ x y)))
(+.f64 y x)
(* y (+ 1 (/ x y)))
(+.f64 y x)
(* y (+ 1 (/ x y)))
(+.f64 y x)
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z x) y)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z x) y)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z x) y)
y
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)
(+ y z)
(+.f64 z y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
(+ x (+ y z))
(+.f64 (+.f64 z x) y)
y
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z x) y)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z x) y)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z x) y)
x
(* x (+ 1 (/ y x)))
(+.f64 y x)
(* x (+ 1 (/ y x)))
(+.f64 y x)
(* x (+ 1 (/ y x)))
(+.f64 y x)
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z x) y)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z x) y)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z x) y)
x
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)

rewrite165.0ms (7.4%)

Memory
11.7MiB live, 289.7MiB allocated
Rules
5 946×lower-fma.f64
5 946×lower-fma.f32
4 786×lower-*.f64
4 786×lower-*.f32
2 372×lower-/.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
058
078
1368
23188
350398
080748
Stop Event
iter limit
node limit
iter limit
Counts
2 → 212
Calls
Call 1
Inputs
(+.f64 (+.f64 x y) z)
(+.f64 x y)
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>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval44.0ms (2%)

Memory
-32.2MiB live, 95.5MiB allocated
Compiler

Compiled 4 983 to 628 computations (87.4% saved)

prune5.0ms (0.2%)

Memory
20.6MiB live, 20.6MiB allocated
Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New2573260
Fresh000
Picked011
Done000
Total2574261
Accuracy
100.0%
Counts
261 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(+.f64 (+.f64 x y) z)
48.7%
#s(approx (+ (+ x y) z) (+.f64 z y))
98.5%
#s(approx (+ (+ x y) z) (+.f64 z x))
53.8%
#s(approx (+ (+ x y) z) (+.f64 y x))
Compiler

Compiled 17 to 20 computations (-17.6% saved)

simplify4.0ms (0.2%)

Memory
-32.3MiB live, 7.1MiB allocated
Algorithm
egg-herbie
Localize:

Found 6 expressions of interest:

NewMetricScoreProgram
cost-diff0
(+.f64 z y)
cost-diff0
#s(approx (+ (+ x y) z) (+.f64 z y))
cost-diff0
(+.f64 z x)
cost-diff0
#s(approx (+ (+ x y) z) (+.f64 z x))
cost-diff0
(+.f64 y x)
cost-diff0
#s(approx (+ (+ x y) z) (+.f64 y x))
Rules
24×lower-+.f32
18×lower-+.f64
+-commutative
lift-+.f64
associate-+l+
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01142
01442
12042
22342
02342
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (+ (+ x y) z) (+.f64 y x))
(+.f64 y x)
y
x
#s(approx (+ (+ x y) z) (+.f64 z x))
(+.f64 z x)
z
x
#s(approx (+ (+ x y) z) (+.f64 z y))
(+.f64 z y)
z
y
Outputs
#s(approx (+ (+ x y) z) (+.f64 y x))
(+.f64 y x)
y
x
#s(approx (+ (+ x y) z) (+.f64 z x))
(+.f64 z x)
z
x
#s(approx (+ (+ x y) z) (+.f64 z y))
(+.f64 z y)
z
y

localize21.0ms (0.9%)

Memory
6.3MiB live, 45.2MiB allocated
Localize:

Found 6 expressions of interest:

NewMetricScoreProgram
accuracy0
(+.f64 z y)
accuracy32.80832526939771
#s(approx (+ (+ x y) z) (+.f64 z y))
accuracy0
(+.f64 z x)
accuracy0.9454983397777825
#s(approx (+ (+ x y) z) (+.f64 z x))
accuracy0
(+.f64 y x)
accuracy29.551284745603663
#s(approx (+ (+ x y) z) (+.f64 y x))
Samples
15.0ms256×0valid
Compiler

Compiled 32 to 10 computations (68.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 7.0ms
ival-add: 7.0ms (99.7% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series5.0ms (0.2%)

Memory
12.3MiB live, 12.3MiB allocated
Counts
6 → 180
Calls
Call 1
Inputs
#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())
#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())
#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())
#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())
#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())
#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())
Outputs
#s(alt (+ x y) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt z (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt z (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt z (taylor inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (/ x z))) (taylor inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (/ x z))) (taylor inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (/ x z))) (taylor inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt z (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (+ (/ x z) (/ y z)))) (taylor inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt z (taylor inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (/ y z))) (taylor inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (/ y z))) (taylor inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* z (+ 1 (/ y z))) (taylor inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt z (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt z (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt z (taylor -inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ x z)) 1))) (taylor -inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ x z)) 1))) (taylor -inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ x z)) 1))) (taylor -inf z) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt z (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ (+ x y) z)) 1))) (taylor -inf z) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt z (taylor -inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ y z)) 1))) (taylor -inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ y z)) 1))) (taylor -inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* z (- (* -1 (/ y z)) 1))) (taylor -inf z) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt z (taylor 0 y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ x y))) (taylor inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ x y))) (taylor inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ x y))) (taylor inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (+ (/ x y) (/ z y)))) (taylor inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ z y))) (taylor inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ z y))) (taylor inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ z y))) (taylor inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) 1))) (taylor -inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) 1))) (taylor -inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) 1))) (taylor -inf y) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (+ x z) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ z y)) 1))) (taylor -inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ z y)) 1))) (taylor -inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ z y)) 1))) (taylor -inf y) (#s(alt (+.f64 z y) (patch (+.f64 z y) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ x y) (taylor 0 x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt z (taylor 0 x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ x z) (taylor 0 x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (+ y z) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (+ x (+ y z)) (taylor 0 x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ y x))) (taylor inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ y x))) (taylor inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ y x))) (taylor inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ z x))) (taylor inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ z x))) (taylor inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (/ z x))) (taylor inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (/ y x) (/ z x)))) (taylor inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 y x)) (patch #s(approx (+ (+ x y) z) (+.f64 y x)) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ y x)) 1))) (taylor -inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ y x)) 1))) (taylor -inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ y x)) 1))) (taylor -inf x) (#s(alt (+.f64 y x) (patch (+.f64 y x) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z x)) (patch #s(approx (+ (+ x y) z) (+.f64 z x)) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ z x)) 1))) (taylor -inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ z x)) 1))) (taylor -inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ z x)) 1))) (taylor -inf x) (#s(alt (+.f64 z x) (patch (+.f64 z x) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1 (/ (+ y z) x)) 1))) (taylor -inf x) (#s(alt #s(approx (+ (+ x y) z) (+.f64 z y)) (patch #s(approx (+ (+ x y) z) (+.f64 z y)) #<representation binary64>) () ())) ())
Calls

9 calls:

TimeVariablePointExpression
0.0ms
x
@-inf
((+ (+ x y) z) (+ y x) (+ (+ x y) z) (+ z x) (+ (+ x y) z) (+ z y))
0.0ms
z
@inf
((+ (+ x y) z) (+ y x) (+ (+ x y) z) (+ z x) (+ (+ x y) z) (+ z y))
0.0ms
z
@-inf
((+ (+ x y) z) (+ y x) (+ (+ x y) z) (+ z x) (+ (+ x y) z) (+ z y))
0.0ms
y
@-inf
((+ (+ x y) z) (+ y x) (+ (+ x y) z) (+ z x) (+ (+ x y) z) (+ z y))
0.0ms
y
@inf
((+ (+ x y) z) (+ y x) (+ (+ x y) z) (+ z x) (+ (+ x y) z) (+ z y))

simplify220.0ms (9.9%)

Memory
8.2MiB live, 243.3MiB allocated
Algorithm
egg-herbie
Rules
20 800×lower-fma.f64
20 800×lower-fma.f32
5 768×lower-/.f32
5 768×lower-/.f64
2 872×associate-/r*
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
075630
1227630
2564630
31699630
44043630
54666630
65033630
75171630
85195630
95195630
09415630
Stop Event
iter limit
node limit
Counts
180 → 144
Calls
Call 1
Inputs
(+ x y)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
(+ x y)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
x
(+ x z)
(+ x z)
(+ x z)
(+ x y)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
y
(+ y z)
(+ y z)
(+ y z)
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
z
(* z (+ 1 (/ x z)))
(* z (+ 1 (/ x z)))
(* z (+ 1 (/ x z)))
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
(* z (+ 1 (+ (/ x z) (/ y z))))
z
(* z (+ 1 (/ y z)))
(* z (+ 1 (/ y z)))
(* z (+ 1 (/ y z)))
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
z
(* -1 (* z (- (* -1 (/ x z)) 1)))
(* -1 (* z (- (* -1 (/ x z)) 1)))
(* -1 (* z (- (* -1 (/ x z)) 1)))
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
z
(* -1 (* z (- (* -1 (/ y z)) 1)))
(* -1 (* z (- (* -1 (/ y z)) 1)))
(* -1 (* z (- (* -1 (/ y z)) 1)))
(+ x z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
x
(+ x y)
(+ x y)
(+ x y)
(+ x z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
(+ x z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
z
(+ y z)
(+ y z)
(+ y z)
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
y
(* y (+ 1 (/ x y)))
(* y (+ 1 (/ x y)))
(* y (+ 1 (/ x y)))
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
(* y (+ 1 (+ (/ x y) (/ z y))))
y
(* y (+ 1 (/ z y)))
(* y (+ 1 (/ z y)))
(* y (+ 1 (/ z y)))
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
y
(* -1 (* y (- (* -1 (/ x y)) 1)))
(* -1 (* y (- (* -1 (/ x y)) 1)))
(* -1 (* y (- (* -1 (/ x y)) 1)))
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
y
(* -1 (* y (- (* -1 (/ z y)) 1)))
(* -1 (* y (- (* -1 (/ z y)) 1)))
(* -1 (* y (- (* -1 (/ z y)) 1)))
(+ y z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
y
(+ x y)
(+ x y)
(+ x y)
(+ y z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
z
(+ x z)
(+ x z)
(+ x z)
(+ y z)
(+ x (+ y z))
(+ x (+ y z))
(+ x (+ y z))
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
x
(* x (+ 1 (/ y x)))
(* x (+ 1 (/ y x)))
(* x (+ 1 (/ y x)))
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
x
(* x (+ 1 (/ z x)))
(* x (+ 1 (/ z x)))
(* x (+ 1 (/ z x)))
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
(* x (+ 1 (+ (/ y x) (/ z x))))
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
x
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* -1 (* x (- (* -1 (/ y x)) 1)))
(* -1 (* x (- (* -1 (/ y x)) 1)))
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
x
(* -1 (* x (- (* -1 (/ z x)) 1)))
(* -1 (* x (- (* -1 (/ z x)) 1)))
(* -1 (* x (- (* -1 (/ z x)) 1)))
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
Outputs
(+ x y)
(+.f64 y x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x y)
(+.f64 y x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
x
(+ x z)
(+.f64 z x)
(+ x z)
(+.f64 z x)
(+ x z)
(+.f64 z x)
(+ x y)
(+.f64 y x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
y
(+ y z)
(+.f64 z y)
(+ y z)
(+.f64 z y)
(+ y z)
(+.f64 z y)
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
z
(* z (+ 1 (/ x z)))
(+.f64 z x)
(* z (+ 1 (/ x z)))
(+.f64 z x)
(* z (+ 1 (/ x z)))
(+.f64 z x)
z
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
(* z (+ 1 (+ (/ x z) (/ y z))))
(+.f64 (+.f64 z y) x)
z
(* z (+ 1 (/ y z)))
(+.f64 z y)
(* z (+ 1 (/ y z)))
(+.f64 z y)
(* z (+ 1 (/ y z)))
(+.f64 z y)
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
z
(* -1 (* z (- (* -1 (/ x z)) 1)))
(+.f64 z x)
(* -1 (* z (- (* -1 (/ x z)) 1)))
(+.f64 z x)
(* -1 (* z (- (* -1 (/ x z)) 1)))
(+.f64 z x)
z
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* z (- (* -1 (/ (+ x y) z)) 1)))
(+.f64 (+.f64 z y) x)
z
(* -1 (* z (- (* -1 (/ y z)) 1)))
(+.f64 z y)
(* -1 (* z (- (* -1 (/ y z)) 1)))
(+.f64 z y)
(* -1 (* z (- (* -1 (/ y z)) 1)))
(+.f64 z y)
(+ x z)
(+.f64 z x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
x
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
(+ x z)
(+.f64 z x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x z)
(+.f64 z x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
z
(+ y z)
(+.f64 z y)
(+ y z)
(+.f64 z y)
(+ y z)
(+.f64 z y)
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
y
(* y (+ 1 (/ x y)))
(+.f64 y x)
(* y (+ 1 (/ x y)))
(+.f64 y x)
(* y (+ 1 (/ x y)))
(+.f64 y x)
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
y
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
(* y (+ 1 (+ (/ x y) (/ z y))))
(+.f64 (+.f64 z y) x)
y
(* y (+ 1 (/ z y)))
(+.f64 z y)
(* y (+ 1 (/ z y)))
(+.f64 z y)
(* y (+ 1 (/ z y)))
(+.f64 z y)
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
y
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)
(* -1 (* y (- (* -1 (/ x y)) 1)))
(+.f64 y x)
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
y
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* y (- (* -1 (/ (+ x z) y)) 1)))
(+.f64 (+.f64 z y) x)
y
(* -1 (* y (- (* -1 (/ z y)) 1)))
(+.f64 z y)
(* -1 (* y (- (* -1 (/ z y)) 1)))
(+.f64 z y)
(* -1 (* y (- (* -1 (/ z y)) 1)))
(+.f64 z y)
(+ y z)
(+.f64 z y)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
y
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
(+ x y)
(+.f64 y x)
(+ y z)
(+.f64 z y)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
z
(+ x z)
(+.f64 z x)
(+ x z)
(+.f64 z x)
(+ x z)
(+.f64 z x)
(+ y z)
(+.f64 z y)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
(+ x (+ y z))
(+.f64 (+.f64 z y) x)
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
x
(* x (+ 1 (/ y x)))
(+.f64 y x)
(* x (+ 1 (/ y x)))
(+.f64 y x)
(* x (+ 1 (/ y x)))
(+.f64 y x)
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
x
(* x (+ 1 (/ z x)))
(+.f64 z x)
(* x (+ 1 (/ z x)))
(+.f64 z x)
(* x (+ 1 (/ z x)))
(+.f64 z x)
x
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
(* x (+ 1 (+ (/ y x) (/ z x))))
(+.f64 (+.f64 z y) x)
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
x
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
(* -1 (* x (- (* -1 (/ y x)) 1)))
(+.f64 y x)
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
x
(* -1 (* x (- (* -1 (/ z x)) 1)))
(+.f64 z x)
(* -1 (* x (- (* -1 (/ z x)) 1)))
(+.f64 z x)
(* -1 (* x (- (* -1 (/ z x)) 1)))
(+.f64 z x)
x
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)
(* -1 (* x (- (* -1 (/ (+ y z) x)) 1)))
(+.f64 (+.f64 z y) x)

rewrite132.0ms (6%)

Memory
12.5MiB live, 207.6MiB allocated
Rules
5 702×lower-fma.f64
5 702×lower-fma.f32
4 358×lower-*.f64
4 358×lower-*.f32
3 718×lower-/.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01136
01436
16936
263136
0846036
Stop Event
iter limit
node limit
iter limit
Counts
6 → 190
Calls
Call 1
Inputs
#s(approx (+ (+ x y) z) (+.f64 y x))
(+.f64 y x)
#s(approx (+ (+ x y) z) (+.f64 z x))
(+.f64 z x)
#s(approx (+ (+ x y) z) (+.f64 z y))
(+.f64 z y)
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>

eval121.0ms (5.5%)

Memory
-21.3MiB live, 109.6MiB allocated
Compiler

Compiled 4 596 to 724 computations (84.2% saved)

prune26.0ms (1.2%)

Memory
-10.1MiB live, 29.1MiB allocated
Pruning

4 alts after pruning (0 fresh and 4 done)

PrunedKeptTotal
New3340334
Fresh000
Picked033
Done011
Total3344338
Accuracy
100.0%
Counts
338 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(+.f64 (+.f64 x y) z)
48.7%
#s(approx (+ (+ x y) z) (+.f64 z y))
98.5%
#s(approx (+ (+ x y) z) (+.f64 z x))
53.8%
#s(approx (+ (+ x y) z) (+.f64 y x))
Compiler

Compiled 34 to 31 computations (8.8% saved)

regimes11.0ms (0.5%)

Memory
24.0MiB live, 24.0MiB allocated
Counts
4 → 1
Calls
Call 1
Inputs
#s(approx (+ (+ x y) z) (+.f64 y x))
#s(approx (+ (+ x y) z) (+.f64 z x))
#s(approx (+ (+ x y) z) (+.f64 z y))
(+.f64 (+.f64 x y) z)
Outputs
(+.f64 (+.f64 x y) z)
Calls

5 calls:

2.0ms
y
2.0ms
(+.f64 x y)
2.0ms
z
2.0ms
x
2.0ms
(+.f64 (+.f64 x y) z)
Results
AccuracySegmentsBranch
100.0%1x
100.0%1y
100.0%1z
100.0%1(+.f64 (+.f64 x y) z)
100.0%1(+.f64 x y)
Compiler

Compiled 11 to 18 computations (-63.6% saved)

regimes23.0ms (1%)

Memory
-13.4MiB live, 25.9MiB allocated
Counts
3 → 1
Calls
Call 1
Inputs
#s(approx (+ (+ x y) z) (+.f64 y x))
#s(approx (+ (+ x y) z) (+.f64 z x))
#s(approx (+ (+ x y) z) (+.f64 z y))
Outputs
#s(approx (+ (+ x y) z) (+.f64 z x))
Calls

5 calls:

15.0ms
(+.f64 (+.f64 x y) z)
2.0ms
(+.f64 x y)
2.0ms
x
2.0ms
z
2.0ms
y
Results
AccuracySegmentsBranch
98.5%1x
98.5%1y
98.5%1z
98.5%1(+.f64 (+.f64 x y) z)
98.5%1(+.f64 x y)
Compiler

Compiled 11 to 18 computations (-63.6% saved)

regimes7.0ms (0.3%)

Memory
16.0MiB live, 16.0MiB allocated
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (+ (+ x y) z) (+.f64 y x))
Outputs
#s(approx (+ (+ x y) z) (+.f64 y x))
Calls

5 calls:

1.0ms
z
1.0ms
(+.f64 (+.f64 x y) z)
1.0ms
y
1.0ms
x
1.0ms
(+.f64 x y)
Results
AccuracySegmentsBranch
53.8%1x
53.8%1y
53.8%1z
53.8%1(+.f64 (+.f64 x y) z)
53.8%1(+.f64 x y)
Compiler

Compiled 11 to 18 computations (-63.6% saved)

simplify32.0ms (1.5%)

Memory
2.4MiB live, 44.3MiB allocated
Algorithm
egg-herbie
Rules
+-commutative-binary64-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01123
11423
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 (+.f64 x y) z)
#s(approx (+ (+ x y) z) (+.f64 z x))
#s(approx (+ (+ x y) z) (+.f64 y x))
Outputs
(+.f64 (+.f64 x y) z)
(+.f64 z (+.f64 y x))
#s(approx (+ (+ x y) z) (+.f64 z x))
#s(approx (+ (+ x y) z) (+.f64 y x))

soundness400.0ms (18%)

Memory
-32.9MiB live, 84.3MiB allocated
Rules
4 768×lower-/.f32
4 768×lower-/.f64
2 864×lower-fma.f64
2 864×lower-fma.f32
2 160×lower-*.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
051210
1148210
2381210
31186210
42945210
54910210
65892210
76011210
86105210
96119210
08863210
Stop Event
done
iter limit
node limit
Compiler

Compiled 19 to 16 computations (15.8% saved)

preprocess113.0ms (5.1%)

Memory
3.6MiB live, 81.4MiB allocated
Remove

(sort x y z)

Compiler

Compiled 56 to 46 computations (17.9% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...