bug329 (missed optimization)

Time bar (total: 2.0s)

start0.0ms (0%)

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

analyze7.0ms (0.4%)

Memory
4.9MiB live, 4.9MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%50%50%0%0%0%0
0%0%50%50%0%0%0%1
50%25%25%50%0%0%0%2
50%25%25%50%0%0%0%3
75%37.5%12.5%50%0%0%0%4
75%37.5%12.5%50%0%0%0%5
87.5%43.7%6.2%50%0%0%0%6
87.5%43.7%6.2%50%0%0%0%7
93.8%46.8%3.1%50%0%0%0%8
93.8%46.8%3.1%50%0%0%0%9
96.9%48.4%1.6%50%0%0%0%10
96.9%48.4%1.6%50%0%0%0%11
98.4%49.2%0.8%50%0%0%0%12
Compiler

Compiled 8 to 7 computations (12.5% saved)

sample496.0ms (24.9%)

Memory
4.2MiB live, 289.9MiB allocated; 149ms collecting garbage
Samples
257.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 103.0ms
ival-div!: 53.0ms (51.6% of total)
ival-atan: 48.0ms (46.7% of total)
adjust: 2.0ms (1.9% of total)
Bogosity

preprocess80.0ms (4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01426
13326
28626
316226
442726
5249226
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(atan.f64 (/.f64 y x))
Symmetry

(negabs x)

(negabs y)

Compiler

Compiled 8 to 8 computations (0% saved)

series73.0ms (3.7%)

Memory
-33.7MiB live, 11.0MiB allocated; 27ms collecting garbage
Counts
4 → 4
Calls
Call 1
Inputs
(atan.f64 (/.f64 y x))
(/.f64 y x)
y
x
Outputs
#s(approx (atan (/ y x)) (atan.f64 (/.f64 y x)))
#s(approx (/ y x) (/.f64 y x))
#s(approx x x)
#s(approx y y)
Calls

6 calls:

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

rewrite1.2s (61.8%)

Memory
6.9MiB live, 296.6MiB allocated; 35ms collecting garbage
Counts
4 → 192
Calls
Call 1
Inputs
(atan.f64 (/.f64 y x))
(/.f64 y x)
y
x
Outputs
(atan.f64 (/.f64 y x))
(neg.f64 (neg.f64 (atan.f64 (/.f64 y x))))
(*.f64 (/.f64 #s(literal 1 binary64) x) y)
(*.f64 (/.f64 y x) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (/.f64 y x))
(*.f64 y (/.f64 #s(literal 1 binary64) x))
(*.f64 (neg.f64 (/.f64 #s(literal 1 binary64) x)) (neg.f64 y))
(*.f64 (neg.f64 (/.f64 y x)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (/.f64 (+.f64 y y) x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)))
(*.f64 (+.f64 y y) (/.f64 #s(literal 1 binary64) (+.f64 x x)))
(*.f64 (neg.f64 y) (neg.f64 (/.f64 #s(literal 1 binary64) x)))
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 (/.f64 y x)))
(*.f64 #s(literal 2 binary64) (/.f64 (/.f64 y x) #s(literal 2 binary64)))
(*.f64 #s(literal 2 binary64) (/.f64 y (+.f64 x x)))
(*.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)))
(*.f64 (neg.f64 (+.f64 y y)) (/.f64 #s(literal 1 binary64) (neg.f64 (+.f64 x x))))
(*.f64 #s(literal 2 binary64) (/.f64 (neg.f64 y) (neg.f64 (+.f64 x x))))
(+.f64 (/.f64 y x) #s(literal 0 binary64))
(+.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)))
(+.f64 (*.f64 #s(literal 0 binary64) (/.f64 y x)) (/.f64 y x))
(+.f64 (*.f64 (/.f64 y x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64))) (*.f64 (/.f64 y x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64))))
(+.f64 (*.f64 (/.f64 y x) #s(literal 0 binary64)) (/.f64 y x))
(+.f64 (/.f64 y x) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(+.f64 (/.f64 y x) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(/.f64 y x)
(/.f64 (+.f64 y y) (+.f64 x x))
(/.f64 (neg.f64 y) (neg.f64 x))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (/.f64 y x)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (neg.f64 y)) (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (neg.f64 x)))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) y) (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) x))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (+.f64 y y)) (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (+.f64 x x)))
(/.f64 (*.f64 (+.f64 y y) (/.f64 #s(literal 2 binary64) x)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (/.f64 (+.f64 y y) x) #s(literal 2 binary64))
(/.f64 (*.f64 (+.f64 y y) (neg.f64 #s(literal 2 binary64))) (*.f64 (+.f64 x x) (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (+.f64 y y) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 (+.f64 x x) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(/.f64 (*.f64 (+.f64 y y) #s(literal 2 binary64)) (*.f64 (+.f64 x x) #s(literal 2 binary64)))
(/.f64 (*.f64 (+.f64 y y) #s(literal 2 binary64)) (*.f64 #s(literal 2 binary64) (+.f64 x x)))
(/.f64 (neg.f64 (+.f64 y y)) (neg.f64 (+.f64 x x)))
(/.f64 (neg.f64 (+.f64 y y)) (*.f64 (neg.f64 #s(literal 2 binary64)) x))
(/.f64 (neg.f64 (+.f64 y y)) (*.f64 x (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (/.f64 #s(literal 2 binary64) x) (+.f64 y y)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (/.f64 #s(literal 1 binary64) x) (+.f64 y y)) #s(literal 2 binary64))
(/.f64 (*.f64 (/.f64 y x) (neg.f64 #s(literal 2 binary64))) (neg.f64 #s(literal 2 binary64)))
(/.f64 (*.f64 (/.f64 y x) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 y)) (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 x)))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 y)) (+.f64 x x))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (+.f64 y y)) (*.f64 (neg.f64 #s(literal 2 binary64)) (+.f64 x x)))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (/.f64 y x)) (neg.f64 #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 y) (neg.f64 #s(literal 2 binary64))) (*.f64 (neg.f64 x) (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (neg.f64 y) (neg.f64 #s(literal 2 binary64))) (+.f64 x x))
(/.f64 (*.f64 (neg.f64 y) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 (neg.f64 x) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(/.f64 (*.f64 #s(literal 2 binary64) (+.f64 y y)) (*.f64 #s(literal 2 binary64) (+.f64 x x)))
(/.f64 (*.f64 #s(literal 2 binary64) (+.f64 y y)) (*.f64 (+.f64 x x) #s(literal 2 binary64)))
(/.f64 (*.f64 y (/.f64 #s(literal 2 binary64) x)) #s(literal 2 binary64))
(/.f64 (*.f64 y (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 x (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(/.f64 (+.f64 y y) (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 x)))
(/.f64 (*.f64 (neg.f64 (/.f64 #s(literal 1 binary64) x)) (neg.f64 (+.f64 y y))) #s(literal 2 binary64))
(/.f64 (*.f64 (neg.f64 (/.f64 #s(literal 2 binary64) x)) (neg.f64 (+.f64 y y))) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (/.f64 (+.f64 y y) x) (neg.f64 #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (/.f64 (+.f64 y y) x) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(/.f64 (*.f64 (/.f64 (+.f64 y y) x) #s(literal 2 binary64)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 (neg.f64 (+.f64 x x)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (neg.f64 #s(literal 1 binary64))) (+.f64 x x))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (neg.f64 (/.f64 #s(literal 2 binary64) x))) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (neg.f64 #s(literal 2 binary64))) (*.f64 (neg.f64 (+.f64 x x)) (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (neg.f64 #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (+.f64 x x)))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) #s(literal 2 binary64)) (*.f64 (neg.f64 (+.f64 x x)) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) #s(literal 2 binary64)) (*.f64 #s(literal 2 binary64) (neg.f64 (+.f64 x x))))
(/.f64 (*.f64 (neg.f64 y) (neg.f64 (/.f64 #s(literal 2 binary64) x))) #s(literal 2 binary64))
(/.f64 (*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 (+.f64 y y))) (+.f64 x x))
(/.f64 (*.f64 #s(literal 1 binary64) (/.f64 (+.f64 y y) x)) #s(literal 2 binary64))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (neg.f64 (+.f64 y y))) (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (neg.f64 (+.f64 x x))))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (/.f64 (+.f64 y y) x)) (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 (+.f64 y y))) (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 (+.f64 x x))))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 (+.f64 y y))) (*.f64 (+.f64 x x) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (/.f64 (+.f64 y y) x)) (*.f64 (neg.f64 #s(literal 2 binary64)) #s(literal 2 binary64)))
(/.f64 (*.f64 #s(literal 2 binary64) (neg.f64 (/.f64 y x))) (neg.f64 #s(literal 2 binary64)))
(/.f64 (*.f64 #s(literal 2 binary64) (neg.f64 (+.f64 y y))) (*.f64 #s(literal 2 binary64) (neg.f64 (+.f64 x x))))
(/.f64 (*.f64 #s(literal 2 binary64) (neg.f64 (+.f64 y y))) (*.f64 (neg.f64 (+.f64 x x)) #s(literal 2 binary64)))
(/.f64 (*.f64 #s(literal 2 binary64) (/.f64 (+.f64 y y) x)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (neg.f64 (/.f64 (+.f64 y y) x)) (neg.f64 #s(literal 2 binary64)))
(/.f64 (*.f64 (+.f64 y y) (neg.f64 #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (neg.f64 (+.f64 x x))))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (+.f64 y y)) (*.f64 (neg.f64 (+.f64 x x)) #s(literal 2 binary64)))
(fma.f64 (/.f64 #s(literal 1 binary64) x) y #s(literal 0 binary64))
(fma.f64 (/.f64 y x) #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 (/.f64 y x) #s(literal 0 binary64) (/.f64 y x))
(fma.f64 #s(literal 1 binary64) (/.f64 y x) #s(literal 0 binary64))
(fma.f64 #s(literal 0 binary64) (/.f64 y x) (/.f64 y x))
(fma.f64 y (/.f64 #s(literal 1 binary64) x) #s(literal 0 binary64))
(fma.f64 (neg.f64 (/.f64 #s(literal 1 binary64) x)) (neg.f64 y) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (neg.f64 (/.f64 #s(literal 1 binary64) x)) (neg.f64 y) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (/.f64 #s(literal 1 binary64) x)) (neg.f64 y) #s(literal 0 binary64))
(fma.f64 (neg.f64 (/.f64 y x)) (neg.f64 #s(literal 1 binary64)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (neg.f64 (/.f64 y x)) (neg.f64 #s(literal 1 binary64)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (/.f64 y x)) (neg.f64 #s(literal 1 binary64)) #s(literal 0 binary64))
(fma.f64 (/.f64 (+.f64 y y) x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (/.f64 (+.f64 y y) x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (/.f64 (+.f64 y y) x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 (+.f64 y y) (/.f64 #s(literal 1 binary64) (+.f64 x x)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (+.f64 y y) (/.f64 #s(literal 1 binary64) (+.f64 x x)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (+.f64 y y) (/.f64 #s(literal 1 binary64) (+.f64 x x)) #s(literal 0 binary64))
(fma.f64 (neg.f64 y) (neg.f64 (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (neg.f64 y) (neg.f64 (/.f64 #s(literal 1 binary64) x)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (neg.f64 y) (neg.f64 (/.f64 #s(literal 1 binary64) x)) #s(literal 0 binary64))
(fma.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 (/.f64 y x)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 (/.f64 y x)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 (/.f64 y x)) #s(literal 0 binary64))
(fma.f64 #s(literal 2 binary64) (/.f64 (/.f64 y x) #s(literal 2 binary64)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 #s(literal 2 binary64) (/.f64 (/.f64 y x) #s(literal 2 binary64)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) (/.f64 (/.f64 y x) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 #s(literal 2 binary64) (/.f64 y (+.f64 x x)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 #s(literal 2 binary64) (/.f64 y (+.f64 x x)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) (/.f64 y (+.f64 x x)) #s(literal 0 binary64))
(fma.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)) #s(literal 0 binary64))
(fma.f64 (/.f64 y x) #s(literal 1 binary64) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (/.f64 y x) #s(literal 1 binary64) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (/.f64 #s(literal 1 binary64) x) y (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (/.f64 #s(literal 1 binary64) x) y (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (/.f64 y x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (*.f64 (/.f64 y x) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64))))
(fma.f64 y (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 y (/.f64 #s(literal 1 binary64) x) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 #s(literal 1 binary64) (/.f64 y x) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 #s(literal 1 binary64) (/.f64 y x) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (/.f64 y x)))
(fma.f64 (neg.f64 (+.f64 y y)) (/.f64 #s(literal 1 binary64) (neg.f64 (+.f64 x x))) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 (neg.f64 (+.f64 y y)) (/.f64 #s(literal 1 binary64) (neg.f64 (+.f64 x x))) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (+.f64 y y)) (/.f64 #s(literal 1 binary64) (neg.f64 (+.f64 x x))) #s(literal 0 binary64))
(fma.f64 #s(literal 2 binary64) (/.f64 (neg.f64 y) (neg.f64 (+.f64 x x))) (*.f64 #s(literal 0 binary64) (/.f64 y x)))
(fma.f64 #s(literal 2 binary64) (/.f64 (neg.f64 y) (neg.f64 (+.f64 x x))) (*.f64 (/.f64 y x) #s(literal 0 binary64)))
(fma.f64 #s(literal 2 binary64) (/.f64 (neg.f64 y) (neg.f64 (+.f64 x x))) #s(literal 0 binary64))
(neg.f64 (neg.f64 (/.f64 y x)))
y
(*.f64 y #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) y)
(*.f64 (+.f64 y y) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)))
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 y))
(*.f64 (neg.f64 y) (neg.f64 #s(literal 1 binary64)))
(*.f64 #s(literal 2 binary64) (/.f64 y #s(literal 2 binary64)))
(*.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y))
(+.f64 y #s(literal 0 binary64))
(+.f64 #s(literal 0 binary64) y)
(+.f64 (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y))
(+.f64 (*.f64 y (/.f64 #s(literal 1 binary64) #s(literal 2 binary64))) (*.f64 y (/.f64 #s(literal 1 binary64) #s(literal 2 binary64))))
(-.f64 y #s(literal 0 binary64))
(/.f64 (+.f64 y y) #s(literal 2 binary64))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) y) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (+.f64 y y)) (*.f64 (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)) #s(literal 2 binary64)))
(/.f64 (*.f64 (+.f64 y y) (neg.f64 #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (+.f64 y y) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(/.f64 (*.f64 (+.f64 y y) #s(literal 2 binary64)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (neg.f64 (+.f64 y y)) (neg.f64 #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 y)) #s(literal 2 binary64))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (+.f64 y y)) (*.f64 (neg.f64 #s(literal 2 binary64)) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 y) (neg.f64 #s(literal 2 binary64))) #s(literal 2 binary64))
(/.f64 (*.f64 #s(literal 2 binary64) (+.f64 y y)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 y (+.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (neg.f64 #s(literal 1 binary64))) #s(literal 2 binary64))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) (neg.f64 #s(literal 2 binary64))) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 (neg.f64 (+.f64 y y)) #s(literal 2 binary64)) (*.f64 #s(literal 2 binary64) (neg.f64 #s(literal 2 binary64))))
(/.f64 (*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 (+.f64 y y))) #s(literal 2 binary64))
(/.f64 (*.f64 (neg.f64 #s(literal 2 binary64)) (neg.f64 (+.f64 y y))) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))
(/.f64 (*.f64 #s(literal 2 binary64) (neg.f64 (+.f64 y y))) (*.f64 (neg.f64 #s(literal 2 binary64)) #s(literal 2 binary64)))
(fma.f64 #s(literal 0 binary64) #s(literal 2 binary64) y)
(fma.f64 #s(literal 0 binary64) #s(literal 1 binary64) y)
(fma.f64 y #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 #s(literal 2 binary64) #s(literal 0 binary64) y)
(fma.f64 #s(literal 1 binary64) #s(literal 0 binary64) y)
(fma.f64 y #s(literal 0 binary64) y)
(fma.f64 #s(literal 1 binary64) y #s(literal 0 binary64))
(fma.f64 #s(literal 0 binary64) y y)
(fma.f64 (+.f64 y y) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 y) #s(literal 0 binary64))
(fma.f64 (neg.f64 #s(literal 1 binary64)) #s(literal 0 binary64) y)
(fma.f64 (/.f64 #s(literal 1 binary64) x) #s(literal 0 binary64) y)
(fma.f64 (neg.f64 y) (neg.f64 #s(literal 1 binary64)) #s(literal 0 binary64))
(fma.f64 (neg.f64 y) #s(literal 0 binary64) y)
(fma.f64 #s(literal 2 binary64) (/.f64 y #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) x) y)
(fma.f64 #s(literal 0 binary64) (neg.f64 y) y)
(fma.f64 #s(literal 0 binary64) (neg.f64 #s(literal 1 binary64)) y)
(fma.f64 #s(literal 0 binary64) (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y)
(fma.f64 (neg.f64 (/.f64 #s(literal 1 binary64) x)) #s(literal 0 binary64) y)
(fma.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y) #s(literal 0 binary64))
(fma.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) #s(literal 0 binary64)) y)
(fma.f64 #s(literal 0 binary64) (neg.f64 (/.f64 #s(literal 1 binary64) x)) y)
(fma.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y (*.f64 (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) y))
(fma.f64 y (/.f64 #s(literal 1 binary64) #s(literal 2 binary64)) (*.f64 y (/.f64 #s(literal 1 binary64) #s(literal 2 binary64))))
(neg.f64 (neg.f64 y))
x
(neg.f64 (neg.f64 x))

eval51.0ms (2.6%)

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

Compiled 1 110 to 545 computations (50.9% saved)

prune12.0ms (0.6%)

Memory
-39.7MiB live, 5.5MiB allocated; 15ms collecting garbage
Pruning

1 alts after pruning (0 fresh and 1 done)

PrunedKeptTotal
New1920192
Fresh000
Picked011
Done000
Total1921193
Accuracy
100.0%
Counts
193 → 1
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(atan.f64 (/.f64 y x))
Compiler

Compiled 8 to 8 computations (0% saved)

derivations0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage
Stop Event
done
Compiler

Compiled 4 to 4 computations (0% saved)

preprocess42.0ms (2.1%)

Memory
10.2MiB live, 10.2MiB allocated; 0ms collecting garbage
Remove

(negabs y)

(negabs x)

Compiler

Compiled 24 to 24 computations (0% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...