_multiplyComplex, real part

Time bar (total: 1.3s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
1.3MiB live, 1.3MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.8%0.2%0%0%0%0
100%99.8%0%0.2%0%0%0%1
Compiler

Compiled 9 to 9 computations (0% saved)

sample693.0ms (54.9%)

Memory
13.9MiB live, 862.0MiB allocated; 114ms collecting garbage
Samples
375.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 152.0ms
ival-mult!: 134.0ms (88.1% of total)
ival-sub!: 17.0ms (11.2% of total)
adjust: 1.0ms (0.7% of total)
Bogosity

preprocess9.0ms (0.7%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
037109
166109
2123109
3190109
4214109
5217109
Stop Event
saturated
Alt Table
Click to see full alt table
StatusAccuracyProgram
98.0%
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
Symmetry

(sort x.re y.re)

(sort x.im y.im)

Compiler

Compiled 14 to 14 computations (0% saved)

series9.0ms (0.7%)

Memory
14.8MiB live, 14.8MiB allocated; 0ms collecting garbage
Counts
7 → 18
Calls
Call 1
Inputs
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
(*.f64 x.re y.re)
x.re
y.re
(*.f64 x.im y.im)
x.im
y.im
Outputs
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (- (* x.re y.re) (* x.im y.im))))
#s(approx (* x.re y.re) #s(hole binary64 (* x.re y.re)))
#s(approx x.re #s(hole binary64 x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re y.re)))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re (+ y.re (* -1 (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.re (+ (* -1 y.re) (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (+ (* -1 (* x.im y.im)) (* x.re y.re))))
#s(approx (* x.im y.im) #s(hole binary64 (* x.im y.im)))
#s(approx x.im #s(hole binary64 x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.im (- (/ (* x.re y.re) x.im) y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im (- (* -1 (/ (* x.re y.re) x.im)) (* -1 y.im))))))
#s(approx y.re #s(hole binary64 y.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.re (+ x.re (* -1 (/ (* x.im y.im) y.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.re (+ (* -1 x.re) (/ (* x.im y.im) y.re))))))
#s(approx y.im #s(hole binary64 y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.im (- (/ (* x.re y.re) y.im) x.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.im (- (* -1 (/ (* x.re y.re) y.im)) (* -1 x.im))))))
Calls

12 calls:

TimeVariablePointExpression
1.0ms
y.re
@-inf
((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im)
1.0ms
x.re
@-inf
((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im)
1.0ms
x.re
@inf
((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im)
1.0ms
y.im
@-inf
((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im)
1.0ms
x.im
@-inf
((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im)

rewrite216.0ms (17.1%)

Memory
-44.8MiB live, 338.9MiB allocated; 47ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
063259
064244
1290240
22295238
09078236
Stop Event
iter-limit
node-limit
iter-limit
Counts
25 → 84
Calls
Call 1
Inputs
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
(*.f64 x.re y.re)
x.re
y.re
(*.f64 x.im y.im)
x.im
y.im
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (- (* x.re y.re) (* x.im y.im))))
#s(approx (* x.re y.re) #s(hole binary64 (* x.re y.re)))
#s(approx x.re #s(hole binary64 x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re y.re)))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re (+ y.re (* -1 (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.re (+ (* -1 y.re) (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (+ (* -1 (* x.im y.im)) (* x.re y.re))))
#s(approx (* x.im y.im) #s(hole binary64 (* x.im y.im)))
#s(approx x.im #s(hole binary64 x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.im (- (/ (* x.re y.re) x.im) y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im (- (* -1 (/ (* x.re y.re) x.im)) (* -1 y.im))))))
#s(approx y.re #s(hole binary64 y.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.re (+ x.re (* -1 (/ (* x.im y.im) y.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.re (+ (* -1 x.re) (/ (* x.im y.im) y.re))))))
#s(approx y.im #s(hole binary64 y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.im (- (/ (* x.re y.re) y.im) x.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.im (- (* -1 (/ (* x.re y.re) y.im)) (* -1 x.im))))))
Outputs
(/.f64 (-.f64 (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) #s(literal 3 binary64)) (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))) #s(literal 3 binary64))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))) (*.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (fma.f64 y.im x.im (*.f64 y.re x.re)))))))
(/.f64 (-.f64 (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) #s(literal 3 binary64)) (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) #s(literal 3 binary64))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (*.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re)))))))
(/.f64 (-.f64 (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) #s(literal 3 binary64)) (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) #s(literal 3 binary64))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (*.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re)))))))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (pow.f64 (*.f64 #s(literal 1 binary64) (*.f64 y.im x.im)) #s(literal 3 binary64))) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (fma.f64 (*.f64 #s(literal 1 binary64) (*.f64 y.im x.im)) (*.f64 #s(literal 1 binary64) (*.f64 y.im x.im)) (*.f64 (*.f64 y.re x.re) (*.f64 #s(literal 1 binary64) (*.f64 y.im x.im))))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (pow.f64 (*.f64 (*.f64 (neg.f64 x.im) y.im) #s(literal -1 binary64)) #s(literal 3 binary64))) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (fma.f64 (*.f64 (*.f64 (neg.f64 x.im) y.im) #s(literal -1 binary64)) (*.f64 (*.f64 (neg.f64 x.im) y.im) #s(literal -1 binary64)) (*.f64 (*.f64 y.re x.re) (*.f64 (*.f64 (neg.f64 x.im) y.im) #s(literal -1 binary64))))))
(/.f64 (+.f64 (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) #s(literal 3 binary64)) (pow.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) #s(literal 3 binary64))) (fma.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (-.f64 (*.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))))) (*.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))))))))
(/.f64 (fma.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im) (pow.f64 (*.f64 (neg.f64 (neg.f64 x.re)) y.re) #s(literal 3 binary64))) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (-.f64 (*.f64 (*.f64 (neg.f64 (neg.f64 x.re)) y.re) (*.f64 (neg.f64 (neg.f64 x.re)) y.re)) (*.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 (neg.f64 x.re)) y.re)))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)))) (neg.f64 (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 x.re) y.re))))))
(/.f64 (neg.f64 (neg.f64 (*.f64 (fma.f64 y.im x.im (*.f64 y.re x.re)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im))))) (neg.f64 (neg.f64 (fma.f64 y.im x.im (*.f64 y.re x.re)))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re)))) (neg.f64 (neg.f64 (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re)))))
(/.f64 (neg.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im))))) (neg.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re)))))))
(/.f64 (neg.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re))))) (neg.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) (*.f64 (fma.f64 y.im x.im (*.f64 y.re x.re)) (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im))) (*.f64 (fma.f64 y.im x.im (*.f64 y.re x.re)) (fma.f64 y.im x.im (*.f64 y.re x.re))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (*.f64 (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re)) (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re))) (*.f64 (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re)) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (*.f64 (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re)))) (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)))) (*.f64 (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re)))) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(/.f64 (fma.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))) (*.f64 (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)))) (*.f64 (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re))) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 x.re) y.re)))))
(/.f64 (fma.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re))) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (neg.f64 x.im) (*.f64 y.im (*.f64 y.re x.re))))))
(/.f64 (fma.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re))) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re)))))
(/.f64 (neg.f64 (*.f64 (fma.f64 y.im x.im (*.f64 y.re x.re)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im)))) (neg.f64 (fma.f64 y.im x.im (*.f64 y.re x.re))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re))) (neg.f64 (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)))) (neg.f64 (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(/.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)))) (neg.f64 (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (neg.f64 x.im) (*.f64 y.im (*.f64 y.re x.re)))))))
(/.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im) (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)))) (neg.f64 (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(/.f64 (*.f64 (fma.f64 y.im x.im (*.f64 y.re x.re)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im))) (fma.f64 y.im x.im (*.f64 y.re x.re)))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re)) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re)))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im))) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re)))))
(fma.f64 (neg.f64 x.im) y.im (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(fma.f64 (neg.f64 x.im) y.im (*.f64 y.re x.re))
(fma.f64 (neg.f64 y.im) x.im (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(fma.f64 (neg.f64 y.im) x.im (*.f64 y.re x.re))
(fma.f64 #s(literal -1 binary64) (*.f64 y.im x.im) (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(fma.f64 #s(literal -1 binary64) (*.f64 y.im x.im) (*.f64 y.re x.re))
(fma.f64 (*.f64 y.im x.im) #s(literal -1 binary64) (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(fma.f64 (*.f64 y.im x.im) #s(literal -1 binary64) (*.f64 y.re x.re))
(fma.f64 y.im (neg.f64 x.im) (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(fma.f64 y.im (neg.f64 x.im) (*.f64 y.re x.re))
(fma.f64 x.im (neg.f64 y.im) (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(fma.f64 x.im (neg.f64 y.im) (*.f64 y.re x.re))
(fma.f64 y.re x.re (*.f64 (neg.f64 x.im) y.im))
(fma.f64 x.re y.re (*.f64 (neg.f64 x.im) y.im))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 x.re) y.re))))) (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 x.re) y.re))))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (*.f64 (*.f64 y.im x.im) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 x.re) y.re))
(-.f64 (*.f64 y.re x.re) (*.f64 #s(literal 1 binary64) (*.f64 y.im x.im)))
(-.f64 (*.f64 y.re x.re) (*.f64 (*.f64 (neg.f64 x.im) y.im) #s(literal -1 binary64)))
(-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im))
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (neg.f64 x.im) (*.f64 y.im (*.f64 y.re x.re)))))) (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (neg.f64 x.im) (*.f64 y.im (*.f64 y.re x.re)))))))
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (neg.f64 x.im) (*.f64 y.im (*.f64 y.re x.re)))))) (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re (-.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (*.f64 (neg.f64 x.im) (*.f64 y.im (*.f64 y.re x.re)))))))
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 x.im x.im) x.im) (*.f64 (*.f64 y.im y.im) y.im)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))) (/.f64 (*.f64 (*.f64 (*.f64 y.re y.re) y.re) (*.f64 (*.f64 x.re x.re) x.re)) (fma.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im (*.f64 (*.f64 y.re x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))))))
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.re x.re) y.re) x.re) (fma.f64 y.im x.im (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.im x.im)) (fma.f64 y.im x.im (*.f64 y.re x.re))))
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 y.im x.im) y.im) x.im) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))) (/.f64 (*.f64 (*.f64 (neg.f64 x.re) y.re) (*.f64 y.re x.re)) (-.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))))
(+.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 (neg.f64 (neg.f64 x.re)) y.re))
(+.f64 (*.f64 (neg.f64 x.im) y.im) (*.f64 y.re x.re))
(+.f64 (*.f64 y.re x.re) (*.f64 (neg.f64 x.im) y.im))
(*.f64 y.re x.re)
(*.f64 x.re y.re)
x.re
y.re
(*.f64 y.im x.im)
(*.f64 x.im y.im)
x.im
y.im
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im)))
#s(approx (* x.re y.re) (*.f64 y.re x.re))
#s(approx x.re x.re)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 y.re (/.f64 (*.f64 y.im x.im) x.re)) x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.re) (-.f64 y.re (/.f64 (*.f64 y.im x.im) x.re))))
#s(approx (- (* x.re y.re) (* x.im y.im)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im)))
#s(approx (* x.im y.im) (*.f64 y.im x.im))
#s(approx x.im x.im)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 (/.f64 (*.f64 y.re x.re) x.im) y.im) x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) (fma.f64 (neg.f64 x.re) (/.f64 y.re x.im) y.im)))
#s(approx y.re y.re)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 x.re (/.f64 (*.f64 y.im x.im) y.re)) y.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 x.re (/.f64 (*.f64 y.im x.im) y.re)) (neg.f64 y.re)))
#s(approx y.im y.im)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 (/.f64 (*.f64 y.re x.re) y.im) x.im) y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (fma.f64 (neg.f64 x.re) (/.f64 y.re y.im) x.im) (neg.f64 y.im)))

eval7.0ms (0.5%)

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

Compiled 1 299 to 254 computations (80.4% saved)

prune3.0ms (0.2%)

Memory
7.4MiB live, 7.5MiB allocated; 0ms collecting garbage
Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New75277
Fresh000
Picked011
Done000
Total75378
Accuracy
100.0%
Counts
78 → 3
Alt Table
Click to see full alt table
StatusAccuracyProgram
98.0%
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
60.3%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
44.0%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
Compiler

Compiled 26 to 26 computations (0% saved)

series7.0ms (0.6%)

Memory
19.8MiB live, 19.8MiB allocated; 0ms collecting garbage
Counts
9 → 19
Calls
Call 1
Inputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
(*.f64 y.re x.re)
y.re
x.re
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
(*.f64 (neg.f64 x.im) y.im)
(neg.f64 x.im)
x.im
y.im
Outputs
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (- (* x.re y.re) (* x.im y.im))))
#s(approx (* y.re x.re) #s(hole binary64 (* x.re y.re)))
#s(approx x.re #s(hole binary64 x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re y.re)))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re (+ y.re (* -1 (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.re (+ (* -1 y.re) (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (+ (* -1 (* x.im y.im)) (* x.re y.re))))
#s(approx (* (neg x.im) y.im) #s(hole binary64 (* -1 (* x.im y.im))))
#s(approx (neg x.im) #s(hole binary64 (* -1 x.im)))
#s(approx x.im #s(hole binary64 x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.im (- (/ (* x.re y.re) x.im) y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im (- (* -1 (/ (* x.re y.re) x.im)) (* -1 y.im))))))
#s(approx y.re #s(hole binary64 y.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.re (+ x.re (* -1 (/ (* x.im y.im) y.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.re (+ (* -1 x.re) (/ (* x.im y.im) y.re))))))
#s(approx y.im #s(hole binary64 y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.im (- (/ (* x.re y.re) y.im) x.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.im (- (* -1 (/ (* x.re y.re) y.im)) (* -1 x.im))))))
Calls

12 calls:

TimeVariablePointExpression
1.0ms
y.re
@-inf
((- (* x.re y.re) (* x.im y.im)) (* y.re x.re) y.re x.re (- (* x.re y.re) (* x.im y.im)) (* (neg x.im) y.im) (neg x.im) x.im y.im)
1.0ms
x.im
@-inf
((- (* x.re y.re) (* x.im y.im)) (* y.re x.re) y.re x.re (- (* x.re y.re) (* x.im y.im)) (* (neg x.im) y.im) (neg x.im) x.im y.im)
1.0ms
x.im
@inf
((- (* x.re y.re) (* x.im y.im)) (* y.re x.re) y.re x.re (- (* x.re y.re) (* x.im y.im)) (* (neg x.im) y.im) (neg x.im) x.im y.im)
1.0ms
x.im
@0
((- (* x.re y.re) (* x.im y.im)) (* y.re x.re) y.re x.re (- (* x.re y.re) (* x.im y.im)) (* (neg x.im) y.im) (neg x.im) x.im y.im)
1.0ms
y.im
@inf
((- (* x.re y.re) (* x.im y.im)) (* y.re x.re) y.re x.re (- (* x.re y.re) (* x.im y.im)) (* (neg x.im) y.im) (neg x.im) x.im y.im)

rewrite145.0ms (11.5%)

Memory
-32.3MiB live, 257.1MiB allocated; 24ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069287
073270
1301266
22324264
08396262
Stop Event
iter-limit
node-limit
iter-limit
Counts
28 → 37
Calls
Call 1
Inputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
(*.f64 y.re x.re)
y.re
x.re
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
(*.f64 (neg.f64 x.im) y.im)
(neg.f64 x.im)
x.im
y.im
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (- (* x.re y.re) (* x.im y.im))))
#s(approx (* y.re x.re) #s(hole binary64 (* x.re y.re)))
#s(approx x.re #s(hole binary64 x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re y.re)))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.re (+ y.re (* -1 (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.re (+ (* -1 y.re) (/ (* x.im y.im) x.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (+ (* -1 (* x.im y.im)) (* x.re y.re))))
#s(approx (* (neg x.im) y.im) #s(hole binary64 (* -1 (* x.im y.im))))
#s(approx (neg x.im) #s(hole binary64 (* -1 x.im)))
#s(approx x.im #s(hole binary64 x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* x.im (- (/ (* x.re y.re) x.im) y.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* x.im (- (* -1 (/ (* x.re y.re) x.im)) (* -1 y.im))))))
#s(approx y.re #s(hole binary64 y.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.re (+ x.re (* -1 (/ (* x.im y.im) y.re))))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.re (+ (* -1 x.re) (/ (* x.im y.im) y.re))))))
#s(approx y.im #s(hole binary64 y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* y.im (- (/ (* x.re y.re) y.im) x.im))))
#s(approx (- (* x.re y.re) (* x.im y.im)) #s(hole binary64 (* -1 (* y.im (- (* -1 (/ (* x.re y.re) y.im)) (* -1 x.im))))))
Outputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
(*.f64 y.re x.re)
(*.f64 x.re y.re)
y.re
x.re
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 y.im) x.im))
(*.f64 (neg.f64 y.im) x.im)
(*.f64 (neg.f64 x.im) y.im)
(*.f64 #s(literal -1 binary64) (*.f64 y.im x.im))
(*.f64 (*.f64 y.im x.im) #s(literal -1 binary64))
(*.f64 y.im (neg.f64 x.im))
(*.f64 x.im (neg.f64 y.im))
(neg.f64 (*.f64 y.im x.im))
(*.f64 #s(literal -1 binary64) x.im)
(*.f64 x.im #s(literal -1 binary64))
(neg.f64 x.im)
x.im
y.im
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 y.im) x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im)))
#s(approx (* y.re x.re) (*.f64 y.re x.re))
#s(approx x.re x.re)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 y.re (/.f64 (*.f64 y.im x.im) x.re)) x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.re) (-.f64 y.re (/.f64 (*.f64 y.im x.im) x.re))))
#s(approx (- (* x.re y.re) (* x.im y.im)) (-.f64 (*.f64 y.re x.re) (*.f64 y.im x.im)))
#s(approx (* (neg x.im) y.im) (*.f64 (neg.f64 y.im) x.im))
#s(approx (neg x.im) (neg.f64 x.im))
#s(approx x.im x.im)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 (/.f64 (*.f64 y.re x.re) x.im) y.im) x.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (fma.f64 (neg.f64 x.re) (/.f64 y.re x.im) y.im) (neg.f64 x.im)))
#s(approx y.re y.re)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 x.re (/.f64 (*.f64 y.im x.im) y.re)) y.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 x.re (/.f64 (*.f64 y.im x.im) y.re)) (neg.f64 y.re)))
#s(approx y.im y.im)
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (-.f64 (/.f64 (*.f64 y.re x.re) y.im) x.im) y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (fma.f64 (neg.f64 x.re) (/.f64 y.re y.im) x.im) (neg.f64 y.im)))

eval2.0ms (0.2%)

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

Compiled 147 to 87 computations (40.8% saved)

prune2.0ms (0.2%)

Memory
5.0MiB live, 5.0MiB allocated; 0ms collecting garbage
Pruning

3 alts after pruning (0 fresh and 3 done)

PrunedKeptTotal
New26026
Fresh000
Picked022
Done011
Total26329
Accuracy
100.0%
Counts
29 → 3
Alt Table
Click to see full alt table
StatusAccuracyProgram
98.0%
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
60.3%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
44.0%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
Compiler

Compiled 44 to 41 computations (6.8% saved)

regimes25.0ms (2%)

Memory
-21.5MiB live, 25.7MiB allocated; 2ms collecting garbage
Counts
3 → 1
Calls
Call 1
Inputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
Outputs
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
Calls

7 calls:

15.0ms
(*.f64 x.im y.im)
2.0ms
x.im
2.0ms
y.re
2.0ms
x.re
2.0ms
y.im
Results
AccuracySegmentsBranch
98.0%1(*.f64 x.im y.im)
98.0%1(*.f64 x.re y.re)
98.0%1(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
98.0%1x.re
98.0%1x.im
98.0%1y.re
98.0%1y.im
Compiler

Compiled 17 to 33 computations (-94.1% saved)

regimes9.0ms (0.7%)

Memory
23.5MiB live, 23.5MiB allocated; 0ms collecting garbage
Counts
2 → 3
Calls
Call 1
Inputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
Outputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
Calls

7 calls:

1.0ms
x.im
1.0ms
y.im
1.0ms
x.re
1.0ms
y.re
1.0ms
(*.f64 x.re y.re)
Results
AccuracySegmentsBranch
80.3%3(*.f64 x.im y.im)
77.6%3(*.f64 x.re y.re)
60.3%1(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
74.0%3x.re
77.9%3x.im
73.0%3y.re
74.5%3y.im
Compiler

Compiled 17 to 33 computations (-94.1% saved)

regimes7.0ms (0.6%)

Memory
21.1MiB live, 21.1MiB allocated; 0ms collecting garbage
Accuracy

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
Outputs
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
Calls

7 calls:

1.0ms
y.re
1.0ms
(*.f64 x.re y.re)
1.0ms
x.im
1.0ms
x.re
1.0ms
y.im
Results
AccuracySegmentsBranch
44.0%1(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
44.0%1y.re
44.0%1x.re
44.0%1y.im
44.0%1(*.f64 x.re y.re)
44.0%1x.im
44.0%1(*.f64 x.im y.im)
Compiler

Compiled 17 to 33 computations (-94.1% saved)

bsearch27.0ms (2.2%)

Memory
-46.8MiB live, 0.8MiB allocated; 1ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.4328644983237936e-123
1.3033953638665287e-98
27.0ms
-2.0628057740368766e+27
-210504969934406430.0
Compiler

Compiled 10 to 14 computations (-40% saved)

derivations75.0ms (5.9%)

Memory
-0.6MiB live, 97.0MiB allocated; 10ms collecting garbage
Stop Event
done
Compiler

Compiled 24 to 21 computations (12.5% saved)

preprocess26.0ms (2.1%)

Memory
9.4MiB live, 54.5MiB allocated; 3ms collecting garbage
Remove

(sort x.im y.im)

(sort x.re y.re)

Compiler

Compiled 183 to 168 computations (8.2% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...