_multiplyComplex, real part

Time bar (total: 1.4s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.7MiB live, 0.7MiB 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)

sample721.0ms (49.9%)

Memory
6.4MiB live, 900.3MiB allocated; 230ms collecting garbage
Samples
409.0ms8 255×0valid
0.0ms1valid
Precisions
Click to see histograms. Total time spent on operations: 179.0ms
ival-mult!: 159.0ms (88.8% of total)
ival-sub!: 18.0ms (10.1% of total)
adjust: 2.0ms (1.1% of total)
Bogosity

preprocess17.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
037109
166109
2126109
3196109
4228109
5231109
Stop Event
saturated
Alt Table
Click to see full alt table
StatusAccuracyProgram
98.4%
(-.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)

series12.0ms (0.9%)

Memory
-28.4MiB live, 16.9MiB allocated; 5ms 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
4.0ms
x.im
@0
((- (* 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.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)

rewrite183.0ms (12.7%)

Memory
-2.6MiB live, 237.7MiB allocated; 46ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
063259
064244
1290240
22259238
08942236
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 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 (-.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 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.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 (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 (*.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 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.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 (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 (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 (fma.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.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 (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 (-.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 (fma.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 (*.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 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.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 (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 (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 (fma.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 (*.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 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.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 (*.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 (-.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 (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.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.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 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.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 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.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 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 (*.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.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 (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
16.0MiB live, 16.0MiB allocated; 0ms collecting garbage
Compiler

Compiled 1 299 to 254 computations (80.4% saved)

prune3.0ms (0.2%)

Memory
6.2MiB live, 6.2MiB 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.4%
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
57.0%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
47.1%
#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.5%)

Memory
14.6MiB live, 14.6MiB 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
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
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)
1.0ms
x.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
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)

rewrite329.0ms (22.8%)

Memory
-49.4MiB live, 200.7MiB allocated; 187ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069287
073270
1301266
22292264
09039262
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
6.2MiB live, 6.2MiB 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.4%
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
57.0%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 (neg.f64 x.im) y.im))
47.1%
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re x.re))
Compiler

Compiled 44 to 41 computations (6.8% saved)

regimes13.0ms (0.9%)

Memory
-8.9MiB live, 35.7MiB allocated; 4ms 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:

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

Compiled 17 to 33 computations (-94.1% saved)

regimes9.0ms (0.6%)

Memory
28.3MiB live, 28.3MiB 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 y.re x.re))
#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))
Calls

7 calls:

1.0ms
y.re
1.0ms
x.re
1.0ms
y.im
1.0ms
x.im
1.0ms
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
Results
AccuracySegmentsBranch
78.5%3(*.f64 x.im y.im)
82.9%3(*.f64 x.re y.re)
60.3%2(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))
78.3%3x.re
73.0%3x.im
73.8%3y.re
75.1%3y.im
Compiler

Compiled 17 to 33 computations (-94.1% saved)

regimes9.0ms (0.6%)

Memory
-23.8MiB live, 22.2MiB allocated; 3ms 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:

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

Compiled 17 to 33 computations (-94.1% saved)

bsearch0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
1.478868475019411e+120
1.3740971440840015e+124
0.0ms
-8.750454581391093e+65
-2.3542660832668017e+61
Compiler

Compiled 10 to 14 computations (-40% saved)

derivations73.0ms (5%)

Memory
23.0MiB live, 85.0MiB allocated; 11ms collecting garbage
Stop Event
done
Compiler

Compiled 24 to 21 computations (12.5% saved)

preprocess57.0ms (4%)

Memory
-39.6MiB live, 51.7MiB allocated; 8ms 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...