Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, C

Time bar (total: 929.0ms)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

analyze9.0ms (1%)

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

Compiled 7 to 7 computations (0% saved)

sample511.0ms (55%)

Memory
-7.5MiB live, 709.8MiB allocated
Samples
302.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 145.0ms
ival-mult: 73.0ms (50.3% of total)
ival-div: 59.0ms (40.7% of total)
ival-true: 6.0ms (4.1% of total)
exact: 4.0ms (2.8% of total)
ival-assert: 3.0ms (2.1% of total)
Bogosity

explain50.0ms (5.4%)

Memory
-0.5MiB live, 74.7MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(*.f64 y #s(literal 3 binary64))
00-0-y
00-0-#s(literal 3 binary64)
00-0-(/.f64 x (*.f64 y #s(literal 3 binary64)))
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
25.0ms512×0valid
Compiler

Compiled 42 to 24 computations (42.9% saved)

Precisions
Click to see histograms. Total time spent on operations: 8.0ms
ival-div: 4.0ms (49.8% of total)
ival-mult: 4.0ms (49.8% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess16.0ms (1.8%)

Memory
27.4MiB live, 27.4MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01331
13025
25525
38225
410325
511525
055
075
1105
2125
0125
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
Outputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(/.f64 x (*.f64 #s(literal 3 binary64) y))
Symmetry

(negabs y)

(negabs x)

Compiler

Compiled 5 to 5 computations (0% saved)

eval0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(/.f64 x (*.f64 y #s(literal 3 binary64)))
Compiler

Compiled 5 to 5 computations (0% saved)

simplify3.0ms (0.3%)

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

Found 2 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 y #s(literal 3 binary64))
cost-diff0
(/.f64 x (*.f64 y #s(literal 3 binary64)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0511
0711
11011
21211
01211
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
x
(*.f64 y #s(literal 3 binary64))
y
#s(literal 3 binary64)
Outputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(/.f64 x (*.f64 #s(literal 3 binary64) y))
x
(*.f64 y #s(literal 3 binary64))
(*.f64 #s(literal 3 binary64) y)
y
#s(literal 3 binary64)

localize20.0ms (2.1%)

Memory
-13.5MiB live, 23.5MiB allocated
Localize:

Found 2 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 y #s(literal 3 binary64))
accuracy0.203125
(/.f64 x (*.f64 y #s(literal 3 binary64)))
Samples
16.0ms256×0valid
Compiler

Compiled 24 to 12 computations (50% saved)

Precisions
Click to see histograms. Total time spent on operations: 9.0ms
ival-div: 7.0ms (75.1% of total)
ival-mult: 2.0ms (21.5% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series5.0ms (0.5%)

Memory
7.9MiB live, 7.9MiB allocated
Counts
2 → 2
Calls
Call 1
Inputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(*.f64 y #s(literal 3 binary64))
Outputs
(* 1/3 (/ x y))
(* 3 y)
Calls

6 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((/ x (* y 3)) (* y 3))
1.0ms
y
@0
((/ x (* y 3)) (* y 3))
1.0ms
x
@inf
((/ x (* y 3)) (* y 3))
1.0ms
y
@inf
((/ x (* y 3)) (* y 3))
1.0ms
x
@0
((/ x (* y 3)) (* y 3))

simplify3.0ms (0.3%)

Memory
4.0MiB live, 4.0MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
078
1118
2138
3158
4168
0168
Stop Event
iter limit
saturated
Counts
2 → 2
Calls
Call 1
Inputs
(* 1/3 (/ x y))
(* 3 y)
Outputs
(* 1/3 (/ x y))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(* 3 y)
(*.f64 #s(literal 3 binary64) y)

rewrite21.0ms (2.3%)

Memory
-21.1MiB live, 24.3MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
058
078
1138
2328
3688
4868
0868
Stop Event
iter limit
saturated
iter limit
Counts
2 → 12
Calls
Call 1
Inputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(*.f64 y #s(literal 3 binary64))
Outputs
(/.f64 (/.f64 x #s(literal -3 binary64)) (neg.f64 y))
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 (/.f64 (neg.f64 x) y) #s(literal -3 binary64))
(/.f64 (/.f64 x y) #s(literal 3 binary64))
(/.f64 (neg.f64 x) (*.f64 y #s(literal -3 binary64)))
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(neg.f64 (/.f64 (/.f64 x y) #s(literal -3 binary64)))
(*.f64 y #s(literal 3 binary64))
(*.f64 (neg.f64 y) #s(literal -3 binary64))
(*.f64 #s(literal -3 binary64) (neg.f64 y))
(*.f64 #s(literal 3 binary64) y)
(neg.f64 (*.f64 y #s(literal -3 binary64)))

eval1.0ms (0.2%)

Memory
3.0MiB live, 3.0MiB allocated
Compiler

Compiled 87 to 36 computations (58.6% saved)

prune1.0ms (0.1%)

Memory
3.1MiB live, 3.1MiB allocated
Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New11314
Fresh000
Picked011
Done000
Total11415
Accuracy
100.0%
Counts
15 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.4%
(/.f64 (/.f64 x y) #s(literal 3 binary64))
99.7%
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
99.7%
(/.f64 x (*.f64 y #s(literal 3 binary64)))
99.3%
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
Compiler

Compiled 26 to 24 computations (7.7% saved)

simplify3.0ms (0.4%)

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

Found 7 expressions of interest:

NewMetricScoreProgram
cost-diff0
(/.f64 x y)
cost-diff0
(/.f64 (/.f64 x y) #s(literal 3 binary64))
cost-diff0
(/.f64 x #s(literal 3 binary64))
cost-diff0
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
cost-diff0
(/.f64 x y)
cost-diff0
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
cost-diff0
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01244
01744
12244
22644
32744
02744
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(/.f64 x y)
x
y
#s(literal 1/3 binary64)
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 x #s(literal 3 binary64))
x
#s(literal 3 binary64)
y
(/.f64 (/.f64 x y) #s(literal 3 binary64))
(/.f64 x y)
x
y
#s(literal 3 binary64)
Outputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
#s(approx (/ x (* y 3)) (*.f64 #s(literal 1/3 binary64) (/.f64 x y)))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(*.f64 #s(literal 1/3 binary64) (/.f64 x y))
(/.f64 x y)
x
y
#s(literal 1/3 binary64)
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 x (*.f64 #s(literal 3 binary64) y))
(/.f64 x #s(literal 3 binary64))
x
#s(literal 3 binary64)
y
(/.f64 (/.f64 x y) #s(literal 3 binary64))
(/.f64 x (*.f64 #s(literal 3 binary64) y))
(/.f64 x y)
x
y
#s(literal 3 binary64)

localize46.0ms (4.9%)

Memory
-14.9MiB live, 58.5MiB allocated
Localize:

Found 7 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(/.f64 x y)
accuracy0.40907771145115346
(/.f64 (/.f64 x y) #s(literal 3 binary64))
accuracy0.0
(/.f64 x #s(literal 3 binary64))
accuracy0.1640625
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
accuracy0.0
(/.f64 x y)
accuracy0.0
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
accuracy0.46767146145115346
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
Samples
29.0ms256×0valid
Compiler

Compiled 84 to 26 computations (69% saved)

Precisions
Click to see histograms. Total time spent on operations: 19.0ms
ival-div: 12.0ms (64.7% of total)
ival-mult: 3.0ms (16.2% of total)
const: 3.0ms (16.2% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series4.0ms (0.4%)

Memory
8.4MiB live, 8.4MiB allocated
Counts
6 → 3
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(/.f64 x y)
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 x #s(literal 3 binary64))
(/.f64 (/.f64 x y) #s(literal 3 binary64))
Outputs
(* 1/3 (/ x y))
(/ x y)
(* 1/3 x)
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
((/ x (* y 3)) (* (/ x y) 1/3) (/ x y) (/ (/ x 3) y) (/ x 3) (/ (/ x y) 3))
1.0ms
x
@inf
((/ x (* y 3)) (* (/ x y) 1/3) (/ x y) (/ (/ x 3) y) (/ x 3) (/ (/ x y) 3))
1.0ms
x
@0
((/ x (* y 3)) (* (/ x y) 1/3) (/ x y) (/ (/ x 3) y) (/ x 3) (/ (/ x y) 3))
1.0ms
y
@-inf
((/ x (* y 3)) (* (/ x y) 1/3) (/ x y) (/ (/ x 3) y) (/ x 3) (/ (/ x y) 3))
0.0ms
y
@0
((/ x (* y 3)) (* (/ x y) 1/3) (/ x y) (/ (/ x 3) y) (/ x 3) (/ (/ x y) 3))

simplify3.0ms (0.3%)

Memory
5.0MiB live, 5.0MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0611
1911
21111
31211
01211
Stop Event
iter limit
saturated
Counts
3 → 3
Calls
Call 1
Inputs
(* 1/3 (/ x y))
(/ x y)
(* 1/3 x)
Outputs
(* 1/3 (/ x y))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(/ x y)
(/.f64 x y)
(* 1/3 x)
(*.f64 #s(literal 1/3 binary64) x)

rewrite9.0ms (1%)

Memory
14.8MiB live, 14.8MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01232
01732
13432
28032
313332
415332
515532
015532
Stop Event
iter limit
saturated
iter limit
Counts
6 → 32
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(/.f64 x y)
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 x #s(literal 3 binary64))
(/.f64 (/.f64 x y) #s(literal 3 binary64))
Outputs
#s(approx (/ x (* y 3)) (*.f64 #s(literal 1/3 binary64) (/.f64 x y)))
(*.f64 (/.f64 #s(literal -1/3 binary64) y) (neg.f64 x))
(*.f64 #s(literal -1/3 binary64) (/.f64 (neg.f64 x) y))
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
(*.f64 (/.f64 (neg.f64 x) y) #s(literal -1/3 binary64))
(*.f64 (neg.f64 x) (/.f64 #s(literal -1/3 binary64) y))
(*.f64 #s(literal 1/3 binary64) (/.f64 x y))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(*.f64 x (/.f64 #s(literal 1/3 binary64) y))
(/.f64 (*.f64 #s(literal 1/3 binary64) x) y)
(/.f64 (*.f64 #s(literal -1/3 binary64) x) (neg.f64 y))
(neg.f64 (*.f64 #s(literal -1/3 binary64) (/.f64 x y)))
(/.f64 (neg.f64 x) (neg.f64 y))
(/.f64 x y)
(neg.f64 (/.f64 (neg.f64 x) y))
(/.f64 (/.f64 (neg.f64 x) y) #s(literal -3 binary64))
(/.f64 (/.f64 x #s(literal -3 binary64)) (neg.f64 y))
(/.f64 (neg.f64 x) (*.f64 #s(literal -3 binary64) y))
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 (/.f64 x y) #s(literal 3 binary64))
(/.f64 x (*.f64 #s(literal 3 binary64) y))
(neg.f64 (/.f64 (/.f64 x #s(literal -3 binary64)) y))
(/.f64 (neg.f64 x) #s(literal -3 binary64))
(/.f64 x #s(literal 3 binary64))
(neg.f64 (/.f64 x #s(literal -3 binary64)))
(/.f64 (/.f64 (neg.f64 x) y) #s(literal -3 binary64))
(/.f64 (/.f64 x #s(literal -3 binary64)) (neg.f64 y))
(/.f64 (neg.f64 x) (*.f64 #s(literal -3 binary64) y))
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 (/.f64 x y) #s(literal 3 binary64))
(/.f64 x (*.f64 #s(literal 3 binary64) y))
(neg.f64 (/.f64 (/.f64 x #s(literal -3 binary64)) y))

eval12.0ms (1.3%)

Memory
-28.9MiB live, 8.6MiB allocated
Compiler

Compiled 294 to 72 computations (75.5% saved)

prune3.0ms (0.3%)

Memory
6.6MiB live, 6.6MiB allocated
Pruning

5 alts after pruning (2 fresh and 3 done)

PrunedKeptTotal
New30232
Fresh000
Picked123
Done011
Total31536
Accuracy
100.0%
Counts
36 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
99.6%
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
99.7%
(/.f64 x (*.f64 y #s(literal 3 binary64)))
99.3%
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
99.5%
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
Compiler

Compiled 41 to 36 computations (12.2% saved)

simplify4.0ms (0.4%)

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

Found 6 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 #s(literal 1/3 binary64) x)
cost-diff0
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
cost-diff0
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
cost-diff0
(/.f64 #s(literal 1/3 binary64) y)
cost-diff0
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
cost-diff0
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01344
01744
12344
22544
32644
02644
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
(/.f64 #s(literal 1/3 binary64) y)
#s(literal 1/3 binary64)
y
x
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
(*.f64 #s(literal 1/3 binary64) x)
#s(literal 1/3 binary64)
x
y
Outputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
(/.f64 #s(literal 1/3 binary64) y)
#s(literal 1/3 binary64)
y
x
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
(*.f64 #s(literal 1/3 binary64) x)
#s(literal 1/3 binary64)
x
y

localize34.0ms (3.6%)

Memory
10.5MiB live, 58.0MiB allocated
Localize:

Found 6 expressions of interest:

NewMetricScoreProgram
accuracy0.0
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
accuracy0.1640625
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
accuracy0.3046875
(*.f64 #s(literal 1/3 binary64) x)
accuracy0.0
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
accuracy0.18359375
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
accuracy0.3671875
(/.f64 #s(literal 1/3 binary64) y)
Samples
26.0ms256×0valid
Compiler

Compiled 76 to 26 computations (65.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 18.0ms
ival-div: 10.0ms (56.3% of total)
ival-mult: 4.0ms (22.5% of total)
const: 3.0ms (16.9% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series4.0ms (0.5%)

Memory
-32.1MiB live, 7.1MiB allocated
Counts
6 → 3
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
(/.f64 #s(literal 1/3 binary64) y)
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
(*.f64 #s(literal 1/3 binary64) x)
Outputs
(* 1/3 (/ x y))
(* 1/3 x)
(/ 1/3 y)
Calls

6 calls:

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

simplify3.0ms (0.3%)

Memory
4.5MiB live, 4.5MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0711
11011
21111
31211
01211
Stop Event
iter limit
saturated
Counts
3 → 3
Calls
Call 1
Inputs
(* 1/3 (/ x y))
(* 1/3 x)
(/ 1/3 y)
Outputs
(* 1/3 (/ x y))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(* 1/3 x)
(*.f64 #s(literal 1/3 binary64) x)
(/ 1/3 y)
(/.f64 #s(literal 1/3 binary64) y)

rewrite9.0ms (1%)

Memory
15.9MiB live, 15.9MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01338
01738
13538
27238
313938
416338
516438
016438
Stop Event
iter limit
saturated
iter limit
Counts
6 → 25
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
(/.f64 #s(literal 1/3 binary64) y)
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
(*.f64 #s(literal 1/3 binary64) x)
Outputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
(*.f64 (/.f64 #s(literal -1/3 binary64) y) (neg.f64 x))
(*.f64 (/.f64 (neg.f64 x) y) #s(literal -1/3 binary64))
(*.f64 (/.f64 x y) #s(literal 1/3 binary64))
(*.f64 #s(literal -1/3 binary64) (/.f64 (neg.f64 x) y))
(*.f64 (neg.f64 x) (/.f64 #s(literal -1/3 binary64) y))
(*.f64 (/.f64 #s(literal 1/3 binary64) y) x)
(*.f64 #s(literal 1/3 binary64) (/.f64 x y))
(*.f64 x (/.f64 #s(literal 1/3 binary64) y))
(/.f64 (*.f64 #s(literal 1/3 binary64) x) y)
(/.f64 (*.f64 #s(literal -1/3 binary64) x) (neg.f64 y))
(neg.f64 (*.f64 (/.f64 #s(literal -1/3 binary64) y) x))
(/.f64 #s(literal -1/3 binary64) (neg.f64 y))
(/.f64 #s(literal 1/3 binary64) y)
(neg.f64 (/.f64 #s(literal -1/3 binary64) y))
(/.f64 (neg.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))) (neg.f64 y))
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
(neg.f64 (/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) (neg.f64 y)))
#s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))
(neg.f64 (neg.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x))))
(*.f64 #s(literal -1/3 binary64) (neg.f64 x))
(*.f64 (neg.f64 x) #s(literal -1/3 binary64))
(*.f64 #s(literal 1/3 binary64) x)
(*.f64 x #s(literal 1/3 binary64))
(neg.f64 (*.f64 #s(literal -1/3 binary64) x))

eval3.0ms (0.3%)

Memory
6.0MiB live, 6.0MiB allocated
Compiler

Compiled 298 to 70 computations (76.5% saved)

prune4.0ms (0.4%)

Memory
7.6MiB live, 7.6MiB allocated
Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New27027
Fresh000
Picked022
Done033
Total27532
Accuracy
100.0%
Counts
32 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
99.6%
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
99.7%
(/.f64 x (*.f64 y #s(literal 3 binary64)))
99.3%
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
99.5%
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
Compiler

Compiled 87 to 58 computations (33.3% saved)

regimes12.0ms (1.3%)

Memory
-15.7MiB live, 23.3MiB allocated
Counts
6 → 1
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 (/.f64 x y) #s(literal 3 binary64))
Outputs
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
Calls

4 calls:

4.0ms
(*.f64 y #s(literal 3 binary64))
3.0ms
x
2.0ms
(/.f64 x (*.f64 y #s(literal 3 binary64)))
2.0ms
y
Results
AccuracySegmentsBranch
99.7%1x
99.7%1y
99.7%1(/.f64 x (*.f64 y #s(literal 3 binary64)))
99.7%1(*.f64 y #s(literal 3 binary64))
Compiler

Compiled 10 to 13 computations (-30% saved)

regimes9.0ms (1%)

Memory
-19.2MiB live, 19.9MiB allocated
Counts
4 → 1
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
(/.f64 x (*.f64 y #s(literal 3 binary64)))
(/.f64 #s(approx (/ x 3) (*.f64 #s(literal 1/3 binary64) x)) y)
Outputs
(/.f64 x (*.f64 y #s(literal 3 binary64)))
Calls

4 calls:

2.0ms
(*.f64 y #s(literal 3 binary64))
2.0ms
x
2.0ms
(/.f64 x (*.f64 y #s(literal 3 binary64)))
2.0ms
y
Results
AccuracySegmentsBranch
99.7%1x
99.7%1y
99.7%1(/.f64 x (*.f64 y #s(literal 3 binary64)))
99.7%1(*.f64 y #s(literal 3 binary64))
Compiler

Compiled 10 to 13 computations (-30% saved)

regimes6.0ms (0.6%)

Memory
13.7MiB live, 13.7MiB allocated
Accuracy

Total -0.3b remaining (-101.4%)

Threshold costs -0.3b (-101.4%)

Counts
2 → 1
Calls
Call 1
Inputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
#s(approx (/ x (* y 3)) (*.f64 (/.f64 x y) #s(literal 1/3 binary64)))
Outputs
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
Calls

4 calls:

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

Compiled 10 to 13 computations (-30% saved)

simplify9.0ms (0.9%)

Memory
16.3MiB live, 16.3MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01321
11621
21821
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 x (*.f64 y #s(literal 3 binary64)))
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))
Outputs
(/.f64 (/.f64 x #s(literal 3 binary64)) y)
(/.f64 x (*.f64 y #s(literal 3 binary64)))
#s(approx (/ x (* y 3)) (*.f64 (/.f64 #s(literal 1/3 binary64) y) x))

soundness26.0ms (2.8%)

Memory
-24.5MiB live, 28.8MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01232
01732
13432
28032
313332
415332
515532
015532
078
1118
2138
3158
4168
0168
058
078
1138
2328
3688
4868
0868
Stop Event
done
iter limit
saturated
iter limit
iter limit
saturated
iter limit
saturated
iter limit
Compiler

Compiled 47 to 35 computations (25.5% saved)

preprocess85.0ms (9.1%)

Memory
-8.4MiB live, 67.8MiB allocated
Remove

(negabs x)

(negabs y)

Compiler

Compiled 102 to 88 computations (13.7% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...