math.square on complex, imaginary part

Time bar (total: 998.0ms)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

analyze0.0ms (0%)

Memory
0.4MiB live, 0.4MiB 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 7 computations (22.2% saved)

sample688.0ms (68.9%)

Memory
-0.0MiB live, 781.4MiB allocated
Samples
487.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 204.0ms
ival-mult: 160.0ms (78.4% of total)
ival-add: 35.0ms (17.2% of total)
ival-true: 6.0ms (2.9% of total)
ival-assert: 3.0ms (1.5% of total)
Bogosity

explain88.0ms (8.8%)

Memory
-4.5MiB live, 93.4MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(*.f64 im re)
00-0-(+.f64 (*.f64 re im) (*.f64 im re))
00-0-(*.f64 re im)
00-0-re
00-0-im
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
48.0ms512×0valid
Compiler

Compiled 41 to 19 computations (53.7% saved)

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

preprocess21.0ms (2.1%)

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

Useful iterations: 1 (0.0ms)

IterNodesCost
01543
13627
28125
315425
420625
523025
057
087
1145
2305
3535
4895
51435
61775
71975
82125
02125
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(+.f64 (*.f64 re im) (*.f64 im re))
Outputs
(+.f64 (*.f64 re im) (*.f64 im re))
(*.f64 #s(literal 2 binary64) (*.f64 im re))
Symmetry

(negabs im)

(negabs re)

(sort re im)

Compiler

Compiled 7 to 5 computations (28.6% saved)

eval0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(+.f64 (*.f64 re im) (*.f64 im re))
Compiler

Compiled 7 to 5 computations (28.6% saved)

simplify14.0ms (1.4%)

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

Found 3 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 im re)
cost-diff0
(*.f64 re im)
cost-diff2
(+.f64 (*.f64 re im) (*.f64 im re))
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0515
0815
11413
23013
35313
48913
514313
617713
719713
821213
021213
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(+.f64 (*.f64 re im) (*.f64 im re))
(*.f64 re im)
re
im
(*.f64 im re)
Outputs
(+.f64 (*.f64 re im) (*.f64 im re))
(*.f64 #s(literal 2 binary64) (*.f64 im re))
(*.f64 re im)
(*.f64 im re)
re
im
(*.f64 im re)

localize14.0ms (1.4%)

Memory
28.8MiB live, 28.8MiB allocated
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 re im)
accuracy0.0
(*.f64 im re)
accuracy0.01171875
(+.f64 (*.f64 re im) (*.f64 im re))
Samples
10.0ms256×0valid
Compiler

Compiled 17 to 7 computations (58.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 5.0ms
ival-mult: 3.0ms (66.5% of total)
ival-add: 1.0ms (22.2% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series4.0ms (0.4%)

Memory
8.4MiB live, 8.4MiB allocated
Counts
3 → 2
Calls
Call 1
Inputs
(+.f64 (*.f64 re im) (*.f64 im re))
(*.f64 re im)
(*.f64 im re)
Outputs
(* 2 (* im re))
(* im re)
Calls

6 calls:

TimeVariablePointExpression
1.0ms
im
@0
((+ (* re im) (* im re)) (* re im) (* im re))
1.0ms
re
@inf
((+ (* re im) (* im re)) (* re im) (* im re))
1.0ms
im
@-inf
((+ (* re im) (* im re)) (* re im) (* im re))
1.0ms
re
@-inf
((+ (* re im) (* im re)) (* re im) (* im re))
1.0ms
re
@0
((+ (* re im) (* im re)) (* re im) (* im re))

simplify10.0ms (1%)

Memory
-34.6MiB live, 10.0MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
058
1128
2318
3468
4648
5988
61688
71938
82138
92238
02238
Stop Event
iter limit
saturated
Counts
2 → 2
Calls
Call 1
Inputs
(* 2 (* im re))
(* im re)
Outputs
(* 2 (* im re))
(*.f64 (*.f64 im re) #s(literal 2 binary64))
(* im re)
(*.f64 im re)

rewrite26.0ms (2.6%)

Memory
41.6MiB live, 41.6MiB allocated
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0513
0813
1329
01539
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
3 → 22
Calls
Call 1
Inputs
(+.f64 (*.f64 re im) (*.f64 im re))
(*.f64 re im)
(*.f64 im re)
Outputs
(*.f64 #s(literal 2 binary64) (*.f64 im re))
(*.f64 im (+.f64 re re))
(*.f64 re (-.f64 im (neg.f64 im)))
(*.f64 re (+.f64 im im))
(/.f64 (-.f64 (pow.f64 (*.f64 im re) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 im) re) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 im re) #s(literal 2 binary64)) (+.f64 (pow.f64 (*.f64 im re) #s(literal 2 binary64)) (*.f64 (*.f64 im re) (*.f64 (neg.f64 im) re)))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 (*.f64 im re) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 0 binary64) (pow.f64 (*.f64 im re) #s(literal 2 binary64)))))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 (*.f64 im re) #s(literal 3 binary64))) (+.f64 #s(literal 0 binary64) (pow.f64 (*.f64 im re) #s(literal 2 binary64))))
(fma.f64 im re (*.f64 (neg.f64 (neg.f64 im)) re))
(fma.f64 im re (*.f64 im re))
(fma.f64 re im (*.f64 (neg.f64 (neg.f64 im)) re))
(fma.f64 re im (*.f64 im re))
(-.f64 (/.f64 (pow.f64 (*.f64 im re) #s(literal 2 binary64)) #s(literal 0 binary64)) (/.f64 (pow.f64 (*.f64 im re) #s(literal 2 binary64)) #s(literal 0 binary64)))
(-.f64 (*.f64 im re) (*.f64 (neg.f64 re) im))
(-.f64 (*.f64 im re) (*.f64 (neg.f64 im) re))
(+.f64 (/.f64 (pow.f64 (*.f64 im re) #s(literal 3 binary64)) (+.f64 #s(literal 0 binary64) (pow.f64 (*.f64 im re) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 im re) #s(literal 3 binary64)) (+.f64 #s(literal 0 binary64) (pow.f64 (*.f64 im re) #s(literal 2 binary64)))))
(+.f64 (*.f64 im re) (*.f64 (neg.f64 (neg.f64 im)) re))
(+.f64 (*.f64 im re) (*.f64 im re))
(*.f64 im re)
(*.f64 re im)
(*.f64 im re)
(*.f64 re im)

eval8.0ms (0.8%)

Memory
-43.7MiB live, 6.7MiB allocated
Compiler

Compiled 229 to 55 computations (76% saved)

prune1.0ms (0.1%)

Memory
1.9MiB live, 1.9MiB allocated
Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New21122
Fresh000
Picked101
Done000
Total22123
Accuracy
100.0%
Counts
23 → 1
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 re (+.f64 im im))
Compiler

Compiled 5 to 4 computations (20% saved)

simplify7.0ms (0.7%)

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

Found 2 expressions of interest:

NewMetricScoreProgram
cost-diff0
(+.f64 im im)
cost-diff0
(*.f64 re (+.f64 im im))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0410
0610
11310
22910
34810
46610
510010
616410
718910
820910
921910
021910
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(*.f64 re (+.f64 im im))
re
(+.f64 im im)
im
Outputs
(*.f64 re (+.f64 im im))
(*.f64 (*.f64 #s(literal 2 binary64) im) re)
re
(+.f64 im im)
(*.f64 #s(literal 2 binary64) im)
im

localize12.0ms (1.2%)

Memory
14.8MiB live, 14.8MiB allocated
Localize:

Found 2 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(+.f64 im im)
accuracy0.0
(*.f64 re (+.f64 im im))
Samples
8.0ms256×0valid
Compiler

Compiled 12 to 6 computations (50% saved)

Precisions
Click to see histograms. Total time spent on operations: 3.0ms
ival-mult: 2.0ms (65.4% of total)
ival-add: 1.0ms (32.7% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series3.0ms (0.3%)

Memory
7.6MiB live, 7.6MiB allocated
Counts
2 → 2
Calls
Call 1
Inputs
(*.f64 re (+.f64 im im))
(+.f64 im im)
Outputs
(* 2 (* im re))
(* 2 im)
Calls

6 calls:

TimeVariablePointExpression
1.0ms
im
@inf
((* re (+ im im)) (+ im im))
1.0ms
im
@-inf
((* re (+ im im)) (+ im im))
0.0ms
im
@0
((* re (+ im im)) (+ im im))
0.0ms
re
@-inf
((* re (+ im im)) (+ im im))
0.0ms
re
@0
((* re (+ im im)) (+ im im))

simplify6.0ms (0.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
068
1148
2308
3448
4628
5968
61668
71918
82118
92218
02218
Stop Event
iter limit
saturated
Counts
2 → 2
Calls
Call 1
Inputs
(* 2 (* im re))
(* 2 im)
Outputs
(* 2 (* im re))
(*.f64 (*.f64 im re) #s(literal 2 binary64))
(* 2 im)
(*.f64 #s(literal 2 binary64) im)

rewrite32.0ms (3.2%)

Memory
-34.2MiB live, 12.3MiB allocated
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
048
068
1228
01378
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
2 → 24
Calls
Call 1
Inputs
(*.f64 re (+.f64 im im))
(+.f64 im im)
Outputs
(*.f64 (*.f64 re #s(literal 2 binary64)) im)
(*.f64 #s(literal 2 binary64) (*.f64 im re))
(*.f64 (*.f64 #s(literal 2 binary64) im) re)
(*.f64 im (+.f64 re re))
(*.f64 re (*.f64 #s(literal 2 binary64) im))
(/.f64 (*.f64 #s(literal 0 binary64) re) #s(literal 0 binary64))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (pow.f64 im #s(literal 3 binary64))) re) (fma.f64 im im #s(literal 0 binary64)))
(/.f64 (*.f64 re #s(literal 0 binary64)) #s(literal 0 binary64))
(/.f64 (*.f64 re (*.f64 #s(literal 2 binary64) (pow.f64 im #s(literal 3 binary64)))) (fma.f64 im im #s(literal 0 binary64)))
(/.f64 (-.f64 (*.f64 (*.f64 im re) (*.f64 im re)) (*.f64 (*.f64 im re) (*.f64 im re))) (-.f64 (*.f64 im re) (*.f64 im re)))
(/.f64 (+.f64 (pow.f64 (*.f64 im re) #s(literal 3 binary64)) (pow.f64 (*.f64 im re) #s(literal 3 binary64))) (fma.f64 (*.f64 im re) (*.f64 im re) (-.f64 (*.f64 (*.f64 im re) (*.f64 im re)) (*.f64 (*.f64 im re) (*.f64 im re)))))
(fma.f64 im re (*.f64 im re))
(fma.f64 re im (*.f64 im re))
(-.f64 (*.f64 im re) (*.f64 (neg.f64 im) re))
(-.f64 (*.f64 im re) (*.f64 (neg.f64 re) im))
(+.f64 (*.f64 im re) (*.f64 im re))
(*.f64 #s(literal 2 binary64) im)
(*.f64 im #s(literal 2 binary64))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (pow.f64 im #s(literal 3 binary64)))) (neg.f64 (fma.f64 im im #s(literal 0 binary64))))
(/.f64 #s(literal 0 binary64) #s(literal 0 binary64))
(/.f64 (*.f64 #s(literal 2 binary64) (pow.f64 im #s(literal 3 binary64))) (fma.f64 im im #s(literal 0 binary64)))
(-.f64 (/.f64 (*.f64 im im) #s(literal 0 binary64)) (/.f64 (*.f64 im im) #s(literal 0 binary64)))
(+.f64 (/.f64 (pow.f64 im #s(literal 3 binary64)) (fma.f64 im im #s(literal 0 binary64))) (/.f64 (pow.f64 im #s(literal 3 binary64)) (fma.f64 im im #s(literal 0 binary64))))
(+.f64 im im)

eval2.0ms (0.2%)

Memory
3.0MiB live, 3.0MiB allocated
Compiler

Compiled 249 to 67 computations (73.1% saved)

prune1.0ms (0.1%)

Memory
2.2MiB live, 2.2MiB allocated
Pruning

1 alts after pruning (0 fresh and 1 done)

PrunedKeptTotal
New26026
Fresh000
Picked011
Done000
Total26127
Accuracy
100.0%
Counts
27 → 1
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 re (+.f64 im im))
Compiler

Compiled 17 to 11 computations (35.3% saved)

regimes4.0ms (0.4%)

Memory
8.2MiB live, 8.2MiB allocated
Accuracy

Total -0.0b remaining (-∞%)

Threshold costs -0b (-∞%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 re (+.f64 im im))
(+.f64 (*.f64 re im) (*.f64 im re))
Outputs
(*.f64 re (+.f64 im im))
Calls

3 calls:

1.0ms
im
1.0ms
re
1.0ms
(+.f64 (*.f64 re im) (*.f64 im re))
Results
AccuracySegmentsBranch
100.0%1re
100.0%1im
100.0%1(+.f64 (*.f64 re im) (*.f64 im re))
Compiler

Compiled 9 to 9 computations (0% saved)

simplify9.0ms (0.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
045
Stop Event
saturated
Calls
Call 1
Inputs
(*.f64 re (+.f64 im im))
Outputs
(*.f64 re (+.f64 im im))

soundness21.0ms (2.1%)

Memory
-20.5MiB live, 25.9MiB allocated
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0513
0813
1329
01539
Stop Event
done
iter limit
iter limit
iter limit
unsound
iter limit
Compiler

Compiled 17 to 11 computations (35.3% saved)

preprocess26.0ms (2.6%)

Memory
6.7MiB live, 51.5MiB allocated
Remove

(sort re im)

(negabs re)

(negabs im)

Compiler

Compiled 54 to 42 computations (22.2% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...