Linear.Projection:inverseInfinitePerspective from linear-1.19.1.3

Time bar (total: 4.1s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.3MiB live, 0.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 11 to 10 computations (9.1% saved)

sample1.4s (33.8%)

Memory
-2.2MiB live, 584.5MiB allocated; 422ms collecting garbage
Samples
859.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 465.0ms
ival-mult!: 402.0ms (86.5% of total)
ival-sub!: 60.0ms (12.9% of total)
adjust: 2.0ms (0.4% of total)
Bogosity

preprocess59.0ms (1.5%)

Memory
-7.6MiB live, 38.8MiB allocated; 7ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
046109
1249109
21776105
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
55.9%
(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
Symmetry

(abs y)

(abs t)

(negabs y)

(negabs t)

(sort x z)

(sort y t)

Compiler

Compiled 18 to 16 computations (11.1% saved)

series181.0ms (4.4%)

Memory
30.2MiB live, 75.7MiB allocated; 9ms collecting garbage
Counts
8 → 25
Calls
Call 1
Inputs
(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
(-.f64 (*.f64 x y) (*.f64 z y))
(*.f64 x y)
x
y
(*.f64 z y)
z
t
Outputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z))))
#s(approx (* (- (* x y) (* z y)) t) (fma.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z)) (*.f64 t (*.f64 x y))))
#s(approx (- (* x y) (* z y)) (*.f64 #s(literal -1 binary64) (*.f64 y z)))
#s(approx (- (* x y) (* z y)) (-.f64 (*.f64 x y) (*.f64 y z)))
#s(approx (* x y) (*.f64 x y))
#s(approx x x)
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 y z)) x) (*.f64 t y))))
#s(approx (- (* x y) (* z y)) (*.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 y z)) x)))))
#s(approx (- (* x y) (* z y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 y z) x)))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 y (-.f64 x z))))
#s(approx (- (* x y) (* z y)) (*.f64 y (-.f64 x z)))
#s(approx y y)
#s(approx (* z y) (*.f64 y z))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 #s(literal -1 binary64) z))))))
#s(approx (- (* x y) (* z y)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 #s(literal -1 binary64) z)))))
#s(approx (- (* x y) (* z y)) (fma.f64 #s(literal -1 binary64) (*.f64 y z) (*.f64 x y)))
#s(approx z z)
#s(approx (* (- (* x y) (* z y)) t) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 x y)) z))))
#s(approx (- (* x y) (* z y)) (*.f64 z (-.f64 (/.f64 (*.f64 x y) z) y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 x y)) z) (*.f64 t y)))))
#s(approx (- (* x y) (* z y)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)) (*.f64 #s(literal -1 binary64) y)))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (-.f64 (*.f64 x y) (*.f64 y z))))
#s(approx t t)
Calls

12 calls:

TimeVariablePoint
2.0ms
y
inf
1.0ms
y
-inf
1.0ms
x
inf
1.0ms
x
-inf
1.0ms
z
-inf

rewrite217.0ms (5.3%)

Memory
-19.9MiB live, 78.0MiB allocated; 21ms collecting garbage
Counts
8 → 20
Calls
Call 1
Inputs
(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
(-.f64 (*.f64 x y) (*.f64 z y))
(*.f64 x y)
x
y
(*.f64 z y)
z
t
Outputs
(*.f64 (*.f64 t y) (-.f64 x z))
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 y (*.f64 (-.f64 x z) t))
(*.f64 (-.f64 x z) y)
(*.f64 y (-.f64 x z))
(*.f64 (+.f64 (neg.f64 z) x) y)
(*.f64 y (+.f64 (neg.f64 z) x))
(*.f64 (/.f64 (*.f64 (+.f64 z x) y) y) (/.f64 (*.f64 (-.f64 x z) y) (+.f64 z x)))
(*.f64 x y)
(*.f64 y x)
x
y
(*.f64 z y)
(*.f64 y z)
(neg.f64 (neg.f64 (*.f64 z y)))
z
(neg.f64 (neg.f64 z))
t

eval13.0ms (0.3%)

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

Compiled 582 to 140 computations (75.9% saved)

prune5.0ms (0.1%)

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

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New35439
Fresh000
Picked101
Done000
Total36440
Accuracy
100.0%
Counts
40 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
52.2%
(*.f64 (-.f64 x z) (*.f64 t y))
56.3%
(*.f64 (*.f64 (-.f64 x z) y) t)
51.1%
(*.f64 (*.f64 (-.f64 x z) t) y)
37.8%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
Compiler

Compiled 36 to 32 computations (11.1% saved)

series254.0ms (6.2%)

Memory
19.1MiB live, 105.0MiB allocated; 26ms collecting garbage
Counts
14 → 38
Calls
Call 1
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
(*.f64 t (*.f64 x y))
t
(*.f64 x y)
x
y
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (-.f64 x z) t)
(-.f64 x z)
z
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (-.f64 x z) y)
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 t y)
Outputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z))))
#s(approx (* (- (* x y) (* z y)) t) (fma.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z)) (*.f64 t (*.f64 x y))))
#s(approx (* t (* x y)) (*.f64 t (*.f64 x y)))
#s(approx (* x y) (*.f64 x y))
#s(approx x x)
#s(approx (* (- x z) t) (*.f64 #s(literal -1 binary64) (*.f64 t z)))
#s(approx (* (- x z) t) (fma.f64 #s(literal -1 binary64) (*.f64 t z) (*.f64 t x)))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) z))
#s(approx (- x z) (-.f64 x z))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 y z)))
#s(approx (* (- x z) y) (fma.f64 #s(literal -1 binary64) (*.f64 y z) (*.f64 x y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 y z)) x) (*.f64 t y))))
#s(approx (* (- x z) t) (*.f64 t x))
#s(approx (* (- x z) t) (*.f64 x (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x)))))
#s(approx (- x z) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 z x)))))
#s(approx (* (- x z) y) (*.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 y z)) x)))))
#s(approx (* (- x z) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t z) x)))))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 y z) x)))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 y (-.f64 x z))))
#s(approx y y)
#s(approx (* (- x z) y) (*.f64 y (-.f64 x z)))
#s(approx (* t y) (*.f64 t y))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 #s(literal -1 binary64) z))))))
#s(approx (- x z) (+.f64 x (*.f64 #s(literal -1 binary64) z)))
#s(approx z z)
#s(approx (* (- (* x y) (* z y)) t) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 x y)) z))))
#s(approx (* (- x z) t) (*.f64 z (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t x) z))))
#s(approx (- x z) (*.f64 z (-.f64 (/.f64 x z) #s(literal 1 binary64))))
#s(approx (* (- x z) y) (*.f64 z (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 x y) z))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 x y)) z) (*.f64 t y)))))
#s(approx (* (- x z) t) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) z))))))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x z))))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z))))))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (-.f64 (*.f64 x y) (*.f64 y z))))
#s(approx t t)
#s(approx (* (- x z) t) (*.f64 t (-.f64 x z)))
Calls

12 calls:

TimeVariablePoint
20.0ms
y
0
7.0ms
y
-inf
6.0ms
z
-inf
6.0ms
y
inf
4.0ms
x
0

rewrite241.0ms (5.9%)

Memory
-15.5MiB live, 142.9MiB allocated; 66ms collecting garbage
Counts
14 → 45
Calls
Call 1
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
(*.f64 t (*.f64 x y))
t
(*.f64 x y)
x
y
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (-.f64 x z) t)
(-.f64 x z)
z
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (-.f64 x z) y)
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 t y)
Outputs
#s(approx (* (- x z) (* t y)) (*.f64 t (*.f64 x y)))
(*.f64 t (*.f64 x y))
(*.f64 (*.f64 x y) t)
(*.f64 (*.f64 t x) y)
(*.f64 (*.f64 t y) x)
(*.f64 x (*.f64 t y))
t
(*.f64 x y)
(*.f64 y x)
x
y
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (*.f64 t y) (-.f64 x z))
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 (*.f64 t y) (+.f64 z x)))
(*.f64 (-.f64 x z) t)
(*.f64 t (-.f64 x z))
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x)))
(*.f64 (-.f64 (*.f64 (*.f64 x x) x) (*.f64 (*.f64 z z) z)) (/.f64 t (fma.f64 (+.f64 z x) z (*.f64 x x))))
(*.f64 (/.f64 (*.f64 (-.f64 (*.f64 (*.f64 x x) x) (*.f64 (*.f64 z z) z)) t) (fma.f64 (*.f64 (*.f64 (*.f64 x x) x) (*.f64 x x)) x (pow.f64 (*.f64 (+.f64 z x) z) #s(literal 3 binary64)))) (fma.f64 (*.f64 (+.f64 z x) z) (-.f64 (*.f64 (+.f64 z x) z) (*.f64 x x)) (*.f64 (*.f64 x x) (*.f64 x x))))
(*.f64 (+.f64 z x) (/.f64 (-.f64 x z) (+.f64 z x)))
(*.f64 (/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (*.f64 (+.f64 z x) (-.f64 x z))) (-.f64 x z))
(*.f64 (/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (fma.f64 (*.f64 x x) x (*.f64 (*.f64 z z) z))) (fma.f64 z (-.f64 z x) (*.f64 x x)))
(*.f64 (fma.f64 (+.f64 z x) z (*.f64 x x)) (/.f64 (-.f64 x z) (fma.f64 (+.f64 z x) z (*.f64 x x))))
(*.f64 (/.f64 (-.f64 (*.f64 (*.f64 x x) x) (*.f64 (*.f64 z z) z)) (fma.f64 (*.f64 (*.f64 (*.f64 x x) x) (*.f64 x x)) x (pow.f64 (*.f64 (+.f64 z x) z) #s(literal 3 binary64)))) (fma.f64 (*.f64 (+.f64 z x) z) (-.f64 (*.f64 (+.f64 z x) z) (*.f64 x x)) (*.f64 (*.f64 x x) (*.f64 x x))))
z
(neg.f64 (neg.f64 z))
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (*.f64 t y) (-.f64 x z))
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 (*.f64 t y) (+.f64 z x)))
(*.f64 (-.f64 x z) y)
(*.f64 y (-.f64 x z))
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 y (+.f64 z x)))
(*.f64 (+.f64 (neg.f64 z) x) y)
(*.f64 y (+.f64 (neg.f64 z) x))
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (*.f64 t y) (-.f64 x z))
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 (*.f64 t y) (+.f64 z x)))
(*.f64 t y)
(*.f64 y t)

eval17.0ms (0.4%)

Memory
-28.9MiB live, 16.2MiB allocated; 11ms collecting garbage
Compiler

Compiled 1 706 to 319 computations (81.3% saved)

prune7.0ms (0.2%)

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

8 alts after pruning (4 fresh and 4 done)

PrunedKeptTotal
New94498
Fresh000
Picked044
Done000
Total948102
Accuracy
100.0%
Counts
102 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
52.2%
(*.f64 (-.f64 x z) (*.f64 t y))
56.3%
(*.f64 (*.f64 (-.f64 x z) y) t)
51.1%
(*.f64 (*.f64 (-.f64 x z) t) y)
37.4%
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x))) y)
53.6%
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))) y) t)
35.6%
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
35.3%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
37.8%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
Compiler

Compiled 94 to 76 computations (19.1% saved)

series317.0ms (7.8%)

Memory
6.8MiB live, 103.5MiB allocated; 32ms collecting garbage
Counts
25 → 89
Calls
Call 1
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
(*.f64 (*.f64 t y) x)
(*.f64 t y)
t
y
x
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
#s(approx (* (- x z) t) (*.f64 t x))
(*.f64 t x)
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))) y) t)
(*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))) y)
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))))
(*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))
#s(literal -1 binary64)
(*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(-.f64 (/.f64 z x) #s(literal 1 binary64))
(/.f64 z x)
z
#s(literal 1 binary64)
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x))) y)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x)))
(*.f64 (+.f64 z x) (-.f64 x z))
(+.f64 z x)
(-.f64 x z)
(/.f64 t (+.f64 z x))
Outputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z))))
#s(approx (* (- (* x y) (* z y)) t) (fma.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z)) (*.f64 t (*.f64 x y))))
#s(approx (* (* t y) x) (*.f64 t (*.f64 x y)))
#s(approx x x)
#s(approx (* (- x z) t) (*.f64 #s(literal -1 binary64) (*.f64 t z)))
#s(approx (* (- x z) t) (fma.f64 #s(literal -1 binary64) (*.f64 t z) (*.f64 t x)))
#s(approx (* t x) (*.f64 t x))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 y z)))
#s(approx (* (- x z) y) (fma.f64 #s(literal -1 binary64) (*.f64 y z) (*.f64 x y)))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) z))
#s(approx (- x z) (-.f64 x z))
#s(approx (* -1 (* x (- (/ z x) 1))) (+.f64 x (*.f64 #s(literal -1 binary64) z)))
#s(approx (* x (- (/ z x) 1)) z)
#s(approx (* x (- (/ z x) 1)) (+.f64 z (*.f64 #s(literal -1 binary64) x)))
#s(approx (- (/ z x) 1) (/.f64 z x))
#s(approx (- (/ z x) 1) (/.f64 (+.f64 z (*.f64 #s(literal -1 binary64) x)) x))
#s(approx (* (+ z x) (- x z)) (*.f64 #s(literal -1 binary64) (pow.f64 z #s(literal 2 binary64))))
#s(approx (* (+ z x) (- x z)) (fma.f64 #s(literal -1 binary64) (pow.f64 z #s(literal 2 binary64)) (*.f64 x (+.f64 z (*.f64 #s(literal -1 binary64) z)))))
#s(approx (* (+ z x) (- x z)) (fma.f64 #s(literal -1 binary64) (pow.f64 z #s(literal 2 binary64)) (*.f64 x (+.f64 x (+.f64 z (*.f64 #s(literal -1 binary64) z))))))
#s(approx (+ z x) (+.f64 x z))
#s(approx (/ t (+ z x)) (/.f64 t z))
#s(approx (/ t (+ z x)) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) (pow.f64 z #s(literal 2 binary64))) (/.f64 t z)))
#s(approx (/ t (+ z x)) (fma.f64 x (-.f64 (/.f64 (*.f64 t x) (pow.f64 z #s(literal 3 binary64))) (/.f64 t (pow.f64 z #s(literal 2 binary64)))) (/.f64 t z)))
#s(approx (/ t (+ z x)) (fma.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) (pow.f64 z #s(literal 4 binary64)))) (*.f64 #s(literal -1 binary64) (/.f64 t (pow.f64 z #s(literal 3 binary64)))))) (/.f64 t (pow.f64 z #s(literal 2 binary64)))) (/.f64 t z)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 y z)) x) (*.f64 t y))))
#s(approx (* (- x z) t) (*.f64 x (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x)))))
#s(approx (* (- x z) y) (*.f64 x y))
#s(approx (* (- x z) y) (*.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (- x z) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 z x)))))
#s(approx (* x (- (/ z x) 1)) (*.f64 #s(literal -1 binary64) x))
#s(approx (* x (- (/ z x) 1)) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))
#s(approx (- (/ z x) 1) #s(literal -1 binary64))
#s(approx (- (/ z x) 1) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
#s(approx (* (+ z x) (- x z)) (pow.f64 x #s(literal 2 binary64)))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 z x) (/.f64 z x)))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 z x) (fma.f64 #s(literal -1 binary64) (/.f64 (pow.f64 z #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) (/.f64 z x))))))
#s(approx (+ z x) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 z x))))
#s(approx (/ t (+ z x)) (/.f64 t x))
#s(approx (/ t (+ z x)) (/.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x))) x))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (/.f64 (*.f64 t (pow.f64 z #s(literal 2 binary64))) (pow.f64 x #s(literal 2 binary64)))) (/.f64 (*.f64 t z) x)) x))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 z #s(literal 3 binary64))) (pow.f64 x #s(literal 3 binary64))))) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 z #s(literal 2 binary64))) (pow.f64 x #s(literal 2 binary64))) (/.f64 (*.f64 t z) x))) x))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 y z)) x)))))
#s(approx (* (- x z) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t z) x)))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 y z) x)))))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))))
#s(approx (* x (- (/ z x) 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 z x))))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (+.f64 z (*.f64 #s(literal -1 binary64) z)) (/.f64 (pow.f64 z #s(literal 2 binary64)) x)) x)))))
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 1 binary64)))))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t z) x)) x)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 z #s(literal 2 binary64))) x) (*.f64 t z)) x))) x)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 z #s(literal 3 binary64))) x) (*.f64 t (pow.f64 z #s(literal 2 binary64)))) x)) (*.f64 t z)) x))) x)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 y (-.f64 x z))))
#s(approx (* t y) (*.f64 t y))
#s(approx y y)
#s(approx (* (- x z) y) (*.f64 y (-.f64 x z)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) x) (*.f64 #s(literal -1 binary64) z))))))
#s(approx (* (+ z x) (- x z)) (fma.f64 z (+.f64 x (*.f64 #s(literal -1 binary64) x)) (pow.f64 x #s(literal 2 binary64))))
#s(approx (* (+ z x) (- x z)) (fma.f64 z (+.f64 x (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) z))) (pow.f64 x #s(literal 2 binary64))))
#s(approx (/ t (+ z x)) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) (pow.f64 x #s(literal 2 binary64))) (/.f64 t x)))
#s(approx (/ t (+ z x)) (fma.f64 z (-.f64 (/.f64 (*.f64 t z) (pow.f64 x #s(literal 3 binary64))) (/.f64 t (pow.f64 x #s(literal 2 binary64)))) (/.f64 t x)))
#s(approx (/ t (+ z x)) (fma.f64 z (-.f64 (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) (pow.f64 x #s(literal 4 binary64)))) (*.f64 #s(literal -1 binary64) (/.f64 t (pow.f64 x #s(literal 3 binary64)))))) (/.f64 t (pow.f64 x #s(literal 2 binary64)))) (/.f64 t x)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 x y)) z))))
#s(approx (* (- x z) t) (*.f64 z (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t x) z))))
#s(approx (* (- x z) y) (*.f64 z (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 x y) z))))
#s(approx (- x z) (*.f64 z (-.f64 (/.f64 x z) #s(literal 1 binary64))))
#s(approx (* x (- (/ z x) 1)) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x z)))))
#s(approx (- (/ z x) 1) (*.f64 z (-.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) z))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 x z) (/.f64 x z)) #s(literal 1 binary64))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 x z) (+.f64 (/.f64 x z) (/.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 z #s(literal 2 binary64))))) #s(literal 1 binary64))))
#s(approx (+ z x) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 x z))))
#s(approx (/ t (+ z x)) (/.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) z))) z))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (/.f64 (*.f64 t (pow.f64 x #s(literal 2 binary64))) (pow.f64 z #s(literal 2 binary64)))) (/.f64 (*.f64 t x) z)) z))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 x #s(literal 3 binary64))) (pow.f64 z #s(literal 3 binary64))))) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 x #s(literal 2 binary64))) (pow.f64 z #s(literal 2 binary64))) (/.f64 (*.f64 t x) z))) z))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 x y)) z) (*.f64 t y)))))
#s(approx (* (- x z) t) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) z))))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z))))))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x z))))))
#s(approx (* x (- (/ z x) 1)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (/.f64 x z) #s(literal 1 binary64)))))
#s(approx (- (/ z x) 1) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (/.f64 #s(literal 1 binary64) z) (/.f64 #s(literal 1 binary64) x)))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) x)) z)) #s(literal 1 binary64))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (pow.f64 x #s(literal 2 binary64)) z)))) z)) #s(literal 1 binary64))))
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x z)) #s(literal 1 binary64)))))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t x) z)) z)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 x #s(literal 2 binary64))) z) (*.f64 t x)) z))) z)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 x #s(literal 3 binary64))) z) (*.f64 t (pow.f64 x #s(literal 2 binary64)))) z)) (*.f64 t x)) z))) z)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (-.f64 (*.f64 x y) (*.f64 y z))))
#s(approx t t)
#s(approx (* (- x z) t) (*.f64 t (-.f64 x z)))
#s(approx (/ t (+ z x)) (/.f64 t (+.f64 x z)))
Calls

12 calls:

TimeVariablePoint
45.0ms
x
inf
13.0ms
x
-inf
8.0ms
t
0
6.0ms
t
-inf
6.0ms
y
inf

rewrite366.0ms (9%)

Memory
-14.3MiB live, 122.0MiB allocated; 31ms collecting garbage
Counts
25 → 84
Calls
Call 1
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
(*.f64 (*.f64 t y) x)
(*.f64 t y)
t
y
x
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
#s(approx (* (- x z) t) (*.f64 t x))
(*.f64 t x)
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))) y) t)
(*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))) y)
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))))
(*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))
#s(literal -1 binary64)
(*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(-.f64 (/.f64 z x) #s(literal 1 binary64))
(/.f64 z x)
z
#s(literal 1 binary64)
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x))) y)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x)))
(*.f64 (+.f64 z x) (-.f64 x z))
(+.f64 z x)
(-.f64 x z)
(/.f64 t (+.f64 z x))
Outputs
#s(approx (* (- x z) (* y t)) (*.f64 (*.f64 t y) x))
(*.f64 (*.f64 t y) x)
(*.f64 (*.f64 y x) t)
(*.f64 (*.f64 t x) y)
(*.f64 x (*.f64 t y))
(*.f64 y (*.f64 t x))
(*.f64 t y)
(*.f64 y t)
t
(neg.f64 (neg.f64 t))
y
x
(*.f64 (neg.f64 x) #s(literal -1 binary64))
(*.f64 (neg.f64 #s(literal -1 binary64)) x)
(*.f64 #s(literal -1 binary64) (neg.f64 x))
(*.f64 x (neg.f64 #s(literal -1 binary64)))
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
#s(approx (* (- x z) t) (*.f64 t x))
(*.f64 t x)
(*.f64 x t)
(*.f64 (*.f64 #s(approx (- x z) (*.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) (neg.f64 x))) y) t)
(*.f64 #s(approx (- x z) (*.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) (neg.f64 x))) y)
#s(approx (- x z) (*.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) (neg.f64 x)))
(*.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) (neg.f64 x))
(*.f64 (/.f64 (neg.f64 x) #s(literal 1 binary64)) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(*.f64 (neg.f64 x) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))
(*.f64 (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))) #s(literal -1 binary64))
#s(literal -1 binary64)
(*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(*.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) x)
(*.f64 (/.f64 x #s(literal 1 binary64)) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(*.f64 (/.f64 (fma.f64 z (/.f64 z (*.f64 x x)) #s(literal -1 binary64)) #s(literal 1 binary64)) (/.f64 x (+.f64 (/.f64 z x) #s(literal 1 binary64))))
(*.f64 (fma.f64 z (/.f64 z (*.f64 x x)) #s(literal -1 binary64)) (/.f64 x (+.f64 (/.f64 z x) #s(literal 1 binary64))))
(*.f64 #s(literal 1 binary64) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(*.f64 (/.f64 (fma.f64 z (/.f64 z (*.f64 x x)) #s(literal -1 binary64)) (fma.f64 z (/.f64 z (*.f64 x x)) #s(literal -1 binary64))) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
(*.f64 (/.f64 (+.f64 (/.f64 z x) #s(literal 1 binary64)) #s(literal 1 binary64)) (/.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) (+.f64 (/.f64 z x) #s(literal 1 binary64))))
(*.f64 (+.f64 (/.f64 z x) #s(literal 1 binary64)) (/.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) (+.f64 (/.f64 z x) #s(literal 1 binary64))))
(*.f64 (/.f64 (fma.f64 z (/.f64 z (*.f64 x x)) #s(literal -1 binary64)) (fma.f64 z (/.f64 (*.f64 z z) (*.f64 (*.f64 x x) x)) #s(literal 1 binary64))) (fma.f64 (/.f64 z x) (-.f64 (/.f64 z x) #s(literal 1 binary64)) #s(literal 1 binary64)))
(*.f64 (/.f64 z x) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (/.f64 z x))
(*.f64 z (/.f64 #s(literal 1 binary64) x))
(*.f64 (neg.f64 (/.f64 z x)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (neg.f64 (/.f64 z x)) (/.f64 #s(literal 1 binary64) #s(literal -1 binary64)))
z
(*.f64 z #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) z)
(*.f64 (*.f64 z (neg.f64 #s(literal 1 binary64))) (neg.f64 #s(literal 1 binary64)))
(+.f64 z (*.f64 z #s(literal 0 binary64)))
#s(literal 1 binary64)
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64))
(*.f64 (neg.f64 #s(literal 1 binary64)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (pow.f64 (neg.f64 #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 2 binary64))) (pow.f64 (neg.f64 #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 2 binary64))))
(*.f64 (pow.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))))
(*.f64 (*.f64 t y) (-.f64 x z))
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 (*.f64 t y) (+.f64 z x)))
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (-.f64 x z) t)
(*.f64 (neg.f64 t) (-.f64 z x))
(*.f64 t (-.f64 x z))
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x)))
(*.f64 (/.f64 (-.f64 x z) (-.f64 z x)) (*.f64 (-.f64 z x) t))
(*.f64 (+.f64 z x) (-.f64 x z))
(*.f64 (-.f64 x z) (+.f64 z x))
(*.f64 (*.f64 (+.f64 z x) (-.f64 z x)) (/.f64 (-.f64 x z) (-.f64 z x)))
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 (+.f64 z x) (+.f64 z x)))
(*.f64 (+.f64 (neg.f64 x) (fabs.f64 z)) (-.f64 (neg.f64 x) (fabs.f64 z)))
(*.f64 (/.f64 (-.f64 x z) (-.f64 z x)) (-.f64 (neg.f64 z) x))
(*.f64 (+.f64 z x) (/.f64 (-.f64 z x) (-.f64 z x)))
(*.f64 (+.f64 z x) (/.f64 (-.f64 x z) (-.f64 x z)))
(*.f64 (-.f64 x z) (/.f64 (+.f64 z x) (-.f64 x z)))
(*.f64 (/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (*.f64 (+.f64 z x) (-.f64 x z))) (+.f64 z x))
(*.f64 (/.f64 (-.f64 x z) (-.f64 z x)) (-.f64 z x))
(*.f64 (+.f64 z x) (/.f64 (-.f64 x z) (+.f64 z x)))
(*.f64 (-.f64 z x) (/.f64 (-.f64 x z) (-.f64 z x)))
(*.f64 (-.f64 x z) (/.f64 (+.f64 z x) (+.f64 z x)))
(*.f64 (/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (fma.f64 (*.f64 x x) x (*.f64 (*.f64 z z) z))) (fma.f64 (-.f64 x z) x (*.f64 z z)))
(*.f64 (/.f64 t (fma.f64 (*.f64 x x) x (*.f64 (*.f64 z z) z))) (fma.f64 (-.f64 x z) x (*.f64 z z)))
(*.f64 (/.f64 t (*.f64 (+.f64 z x) (-.f64 z x))) (-.f64 z x))
(*.f64 (/.f64 t (*.f64 (+.f64 z x) (-.f64 x z))) (-.f64 x z))
(*.f64 (/.f64 (neg.f64 t) (fma.f64 (*.f64 x x) x (*.f64 (*.f64 z z) z))) (neg.f64 (fma.f64 (-.f64 x z) x (*.f64 z z))))
(*.f64 (/.f64 (neg.f64 t) (*.f64 (+.f64 z x) (-.f64 z x))) (-.f64 x z))

eval24.0ms (0.6%)

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

Compiled 4 196 to 1 012 computations (75.9% saved)

prune12.0ms (0.3%)

Memory
-35.9MiB live, 14.0MiB allocated; 12ms collecting garbage
Pruning

8 alts after pruning (2 fresh and 6 done)

PrunedKeptTotal
New1792181
Fresh000
Picked224
Done044
Total1818189
Accuracy
100.0%
Counts
189 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
52.2%
(*.f64 (-.f64 x z) (*.f64 t y))
56.3%
(*.f64 (*.f64 (-.f64 x z) y) t)
51.1%
(*.f64 (*.f64 (-.f64 x z) t) y)
29.6%
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
32.8%
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
35.6%
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
35.3%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
37.8%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
Compiler

Compiled 102 to 81 computations (20.6% saved)

series190.0ms (4.7%)

Memory
7.5MiB live, 146.2MiB allocated; 26ms collecting garbage
Counts
19 → 86
Calls
Call 1
Inputs
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
(*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y)
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x)))))
(*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))
#s(literal -1 binary64)
(*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x)))
x
#s(approx (- (/ z x) 1) (/.f64 z x))
(/.f64 z x)
z
y
t
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z)))
(*.f64 (+.f64 z x) (-.f64 x z))
(+.f64 z x)
(-.f64 x z)
#s(approx (/ t (+ z x)) (/.f64 t z))
(/.f64 t z)
Outputs
#s(approx (* (* (- x z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z))))
#s(approx (* (* (- x z) y) t) (fma.f64 #s(literal -1 binary64) (*.f64 t (*.f64 y z)) (*.f64 t (*.f64 x y))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 y z)))
#s(approx (* (- x z) y) (fma.f64 #s(literal -1 binary64) (*.f64 y z) (*.f64 x y)))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) z))
#s(approx (- x z) (-.f64 x z))
#s(approx (* -1 (* x (- (/ z x) 1))) (+.f64 x (*.f64 #s(literal -1 binary64) z)))
#s(approx (* x (- (/ z x) 1)) z)
#s(approx (* x (- (/ z x) 1)) (+.f64 z (*.f64 #s(literal -1 binary64) x)))
#s(approx x x)
#s(approx (- (/ z x) 1) (/.f64 z x))
#s(approx (- (/ z x) 1) (/.f64 (+.f64 z (*.f64 #s(literal -1 binary64) x)) x))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 t z)))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (fma.f64 #s(literal -1 binary64) (*.f64 t z) (*.f64 t x)))
#s(approx (* (+ z x) (- x z)) (*.f64 #s(literal -1 binary64) (pow.f64 z #s(literal 2 binary64))))
#s(approx (* (+ z x) (- x z)) (fma.f64 #s(literal -1 binary64) (pow.f64 z #s(literal 2 binary64)) (*.f64 x (+.f64 z (*.f64 #s(literal -1 binary64) z)))))
#s(approx (* (+ z x) (- x z)) (fma.f64 #s(literal -1 binary64) (pow.f64 z #s(literal 2 binary64)) (*.f64 x (+.f64 x (+.f64 z (*.f64 #s(literal -1 binary64) z))))))
#s(approx (+ z x) (+.f64 x z))
#s(approx (/ t (+ z x)) (/.f64 t z))
#s(approx (/ t (+ z x)) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) (pow.f64 z #s(literal 2 binary64))) (/.f64 t z)))
#s(approx (/ t (+ z x)) (fma.f64 x (-.f64 (/.f64 (*.f64 t x) (pow.f64 z #s(literal 3 binary64))) (/.f64 t (pow.f64 z #s(literal 2 binary64)))) (/.f64 t z)))
#s(approx (/ t (+ z x)) (fma.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) (pow.f64 z #s(literal 4 binary64)))) (*.f64 #s(literal -1 binary64) (/.f64 t (pow.f64 z #s(literal 3 binary64)))))) (/.f64 t (pow.f64 z #s(literal 2 binary64)))) (/.f64 t z)))
#s(approx (* (* (- x z) y) t) (*.f64 t (*.f64 x y)))
#s(approx (* (* (- x z) y) t) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 y z)) x) (*.f64 t y))))
#s(approx (* (- x z) y) (*.f64 x y))
#s(approx (* (- x z) y) (*.f64 x (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x)))))
#s(approx (- x z) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 z x)))))
#s(approx (* x (- (/ z x) 1)) (*.f64 #s(literal -1 binary64) x))
#s(approx (* x (- (/ z x) 1)) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))
#s(approx (- (/ z x) 1) #s(literal -1 binary64))
#s(approx (- (/ z x) 1) (-.f64 (/.f64 z x) #s(literal 1 binary64)))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 t x))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 x (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x)))))
#s(approx (* (+ z x) (- x z)) (pow.f64 x #s(literal 2 binary64)))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 z x) (/.f64 z x)))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 z x) (fma.f64 #s(literal -1 binary64) (/.f64 (pow.f64 z #s(literal 2 binary64)) (pow.f64 x #s(literal 2 binary64))) (/.f64 z x))))))
#s(approx (+ z x) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 z x))))
#s(approx (/ t (+ z x)) (/.f64 t x))
#s(approx (/ t (+ z x)) (/.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x))) x))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (/.f64 (*.f64 t (pow.f64 z #s(literal 2 binary64))) (pow.f64 x #s(literal 2 binary64)))) (/.f64 (*.f64 t z) x)) x))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 z #s(literal 3 binary64))) (pow.f64 x #s(literal 3 binary64))))) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 z #s(literal 2 binary64))) (pow.f64 x #s(literal 2 binary64))) (/.f64 (*.f64 t z) x))) x))
#s(approx (* (* (- x z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 y z)) x)))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 y z) x)))))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64)))))
#s(approx (* x (- (/ z x) 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 z x))))))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t z) x)))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (+.f64 z (*.f64 #s(literal -1 binary64) z)) (/.f64 (pow.f64 z #s(literal 2 binary64)) x)) x)))))
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 1 binary64)))))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t z) x)) x)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 z #s(literal 2 binary64))) x) (*.f64 t z)) x))) x)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 z #s(literal 3 binary64))) x) (*.f64 t (pow.f64 z #s(literal 2 binary64)))) x)) (*.f64 t z)) x))) x)))
#s(approx (* (* (- x z) y) t) (*.f64 t (*.f64 y (-.f64 x z))))
#s(approx (* (- x z) y) (*.f64 y (-.f64 x z)))
#s(approx y y)
#s(approx (* (+ z x) (- x z)) (fma.f64 z (+.f64 x (*.f64 #s(literal -1 binary64) x)) (pow.f64 x #s(literal 2 binary64))))
#s(approx (* (+ z x) (- x z)) (fma.f64 z (+.f64 x (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) z))) (pow.f64 x #s(literal 2 binary64))))
#s(approx (/ t (+ z x)) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) (pow.f64 x #s(literal 2 binary64))) (/.f64 t x)))
#s(approx (/ t (+ z x)) (fma.f64 z (-.f64 (/.f64 (*.f64 t z) (pow.f64 x #s(literal 3 binary64))) (/.f64 t (pow.f64 x #s(literal 2 binary64)))) (/.f64 t x)))
#s(approx (/ t (+ z x)) (fma.f64 z (-.f64 (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) (pow.f64 x #s(literal 4 binary64)))) (*.f64 #s(literal -1 binary64) (/.f64 t (pow.f64 x #s(literal 3 binary64)))))) (/.f64 t (pow.f64 x #s(literal 2 binary64)))) (/.f64 t x)))
#s(approx (* (* (- x z) y) t) (*.f64 z (fma.f64 #s(literal -1 binary64) (*.f64 t y) (/.f64 (*.f64 t (*.f64 x y)) z))))
#s(approx (* (- x z) y) (*.f64 z (fma.f64 #s(literal -1 binary64) y (/.f64 (*.f64 x y) z))))
#s(approx (- x z) (*.f64 z (-.f64 (/.f64 x z) #s(literal 1 binary64))))
#s(approx (* x (- (/ z x) 1)) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x z)))))
#s(approx (- (/ z x) 1) (*.f64 z (-.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) z))))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 z (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t x) z))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 x z) (/.f64 x z)) #s(literal 1 binary64))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 x z) (+.f64 (/.f64 x z) (/.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 z #s(literal 2 binary64))))) #s(literal 1 binary64))))
#s(approx (+ z x) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 x z))))
#s(approx (/ t (+ z x)) (/.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) z))) z))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (/.f64 (*.f64 t (pow.f64 x #s(literal 2 binary64))) (pow.f64 z #s(literal 2 binary64)))) (/.f64 (*.f64 t x) z)) z))
#s(approx (/ t (+ z x)) (/.f64 (-.f64 (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 x #s(literal 3 binary64))) (pow.f64 z #s(literal 3 binary64))))) (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (pow.f64 x #s(literal 2 binary64))) (pow.f64 z #s(literal 2 binary64))) (/.f64 (*.f64 t x) z))) z))
#s(approx (* (* (- x z) y) t) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) (/.f64 (*.f64 t (*.f64 x y)) z) (*.f64 t y)))))
#s(approx (* (- x z) y) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z))))))
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x z))))))
#s(approx (* x (- (/ z x) 1)) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (/.f64 x z) #s(literal 1 binary64)))))
#s(approx (- (/ z x) 1) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (/.f64 #s(literal 1 binary64) z) (/.f64 #s(literal 1 binary64) x)))))
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 z (+.f64 t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t x) z))))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 #s(literal -1 binary64) x)) z)) #s(literal 1 binary64))))
#s(approx (* (+ z x) (- x z)) (*.f64 (pow.f64 z #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (pow.f64 x #s(literal 2 binary64)) z)))) z)) #s(literal 1 binary64))))
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x z)) #s(literal 1 binary64)))))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (/.f64 (*.f64 t x) z)) z)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 x #s(literal 2 binary64))) z) (*.f64 t x)) z))) z)))
#s(approx (/ t (+ z x)) (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 (*.f64 t (pow.f64 x #s(literal 3 binary64))) z) (*.f64 t (pow.f64 x #s(literal 2 binary64)))) z)) (*.f64 t x)) z))) z)))
#s(approx t t)
#s(approx (* (* (+ z x) (- x z)) (/ t (+ z x))) (*.f64 t (-.f64 x z)))
#s(approx (/ t (+ z x)) (/.f64 t (+.f64 x z)))
Calls

12 calls:

TimeVariablePoint
2.0ms
t
-inf
2.0ms
z
-inf
1.0ms
x
-inf
1.0ms
t
inf
1.0ms
z
inf

rewrite257.0ms (6.3%)

Memory
-16.4MiB live, 281.7MiB allocated; 75ms collecting garbage
Counts
19 → 46
Calls
Call 1
Inputs
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
(*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y)
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x)))))
(*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))
#s(literal -1 binary64)
(*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x)))
x
#s(approx (- (/ z x) 1) (/.f64 z x))
(/.f64 z x)
z
y
t
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z)))
(*.f64 (+.f64 z x) (-.f64 x z))
(+.f64 z x)
(-.f64 x z)
#s(approx (/ t (+ z x)) (/.f64 t z))
(/.f64 t z)
Outputs
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
(*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y)
#s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x)))))
(*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))
#s(literal -1 binary64)
(*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x)))
x
(*.f64 (neg.f64 x) #s(literal -1 binary64))
(*.f64 (neg.f64 #s(literal -1 binary64)) x)
(*.f64 #s(literal -1 binary64) (neg.f64 x))
(*.f64 x (neg.f64 #s(literal -1 binary64)))
#s(approx (- (/ z x) 1) (/.f64 z x))
(*.f64 (/.f64 z x) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (/.f64 z x))
(*.f64 z (/.f64 #s(literal 1 binary64) x))
(*.f64 (neg.f64 (/.f64 z x)) (neg.f64 #s(literal 1 binary64)))
(*.f64 (neg.f64 (/.f64 z x)) (/.f64 #s(literal 1 binary64) #s(literal -1 binary64)))
z
(*.f64 z #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) z)
(*.f64 (*.f64 z (neg.f64 #s(literal 1 binary64))) (neg.f64 #s(literal 1 binary64)))
(+.f64 z (*.f64 z #s(literal 0 binary64)))
y
t
(neg.f64 (neg.f64 t))
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z)))
(*.f64 (+.f64 z x) (-.f64 x z))
(*.f64 (-.f64 x z) (+.f64 z x))
(*.f64 (*.f64 (+.f64 z x) (-.f64 z x)) (/.f64 (-.f64 x z) (-.f64 z x)))
(*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 (+.f64 z x) (+.f64 z x)))
(*.f64 (+.f64 (neg.f64 x) (fabs.f64 z)) (-.f64 (neg.f64 x) (fabs.f64 z)))
(*.f64 (/.f64 (-.f64 x z) (-.f64 z x)) (-.f64 (neg.f64 z) x))
(*.f64 (+.f64 z x) (/.f64 (-.f64 z x) (-.f64 z x)))
(*.f64 (+.f64 z x) (/.f64 (-.f64 x z) (-.f64 x z)))
(*.f64 (-.f64 x z) (/.f64 (+.f64 z x) (-.f64 x z)))
(*.f64 (/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (*.f64 (+.f64 z x) (-.f64 x z))) (+.f64 z x))
(*.f64 (/.f64 (-.f64 x z) (-.f64 z x)) (-.f64 z x))
(*.f64 (+.f64 z x) (/.f64 (-.f64 x z) (+.f64 z x)))
(*.f64 (-.f64 z x) (/.f64 (-.f64 x z) (-.f64 z x)))
(*.f64 (-.f64 x z) (/.f64 (+.f64 z x) (+.f64 z x)))
(*.f64 (/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (fma.f64 (*.f64 x x) x (*.f64 (*.f64 z z) z))) (fma.f64 (-.f64 x z) x (*.f64 z z)))
#s(approx (/ t (+ z x)) (/.f64 t z))
(/.f64 t z)
(/.f64 (neg.f64 t) (neg.f64 z))
(neg.f64 (neg.f64 (/.f64 t z)))

eval29.0ms (0.7%)

Memory
-1.7MiB live, 43.8MiB allocated; 5ms collecting garbage
Compiler

Compiled 3 337 to 786 computations (76.4% saved)

prune7.0ms (0.2%)

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

8 alts after pruning (0 fresh and 8 done)

PrunedKeptTotal
New1260126
Fresh000
Picked022
Done066
Total1268134
Accuracy
100.0%
Counts
134 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
52.2%
(*.f64 (-.f64 x z) (*.f64 t y))
56.3%
(*.f64 (*.f64 (-.f64 x z) y) t)
51.1%
(*.f64 (*.f64 (-.f64 x z) t) y)
29.6%
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
32.8%
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
35.6%
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
35.3%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
37.8%
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
Compiler

Compiled 102 to 81 computations (20.6% saved)

regimes117.0ms (2.9%)

Memory
-10.4MiB live, 133.0MiB allocated; 28ms collecting garbage
Accuracy

Total -4.1b remaining (-3.3%)

Threshold costs -4.1b (-3.3%)

Counts
3 → 1
4 → 2
8 → 1
11 → 2
Calls
Call 1
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
Outputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
Call 2
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
(*.f64 (*.f64 (-.f64 x z) t) y)
Outputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
(*.f64 (*.f64 (-.f64 x z) t) y)
Call 3
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
Outputs
(*.f64 (*.f64 (-.f64 x z) y) t)
Call 4
Inputs
#s(approx (* (- (* x y) (* z y)) t) (*.f64 t (*.f64 x y)))
#s(approx (* (- (* x y) (* z y)) t) (*.f64 (*.f64 t y) x))
(*.f64 #s(approx (* (- x z) t) (*.f64 t x)) y)
(*.f64 (*.f64 (-.f64 x z) t) y)
(*.f64 (*.f64 (-.f64 x z) y) t)
(*.f64 (-.f64 x z) (*.f64 t y))
(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x #s(approx (- (/ z x) 1) (/.f64 z x))))) y) t)
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
(*.f64 (*.f64 #s(approx (- x z) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 z x) #s(literal 1 binary64))))) y) t)
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (/.f64 t (+.f64 z x))) y)
Outputs
(*.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) #s(approx (/ t (+ z x)) (/.f64 t z))) y)
(*.f64 (*.f64 (-.f64 x z) y) t)
Calls

20 calls:

42.0ms
z
16.0ms
x
7.0ms
y
6.0ms
t
6.0ms
z
Results
AccuracySegmentsBranch
37.8%1(-.f64 (*.f64 x y) (*.f64 z y))
37.8%1(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
37.8%1y
37.8%1t
37.8%1z
37.8%1x
51.1%1(-.f64 (*.f64 x y) (*.f64 z y))
51.1%1(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
52.7%2z
51.1%1y
53.3%2x
51.1%1t
56.3%1t
56.3%1(-.f64 (*.f64 x y) (*.f64 z y))
58.3%2(-.f64 (*.f64 x y) (*.f64 z y))
56.3%1(*.f64 (-.f64 (*.f64 x y) (*.f64 z y)) t)
56.3%1x
56.3%1y
56.3%1z
56.3%1t
Compiler

Compiled 211 to 161 computations (23.7% saved)

bsearch1.0ms (0%)

Memory
1.6MiB live, 1.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-4.15483553584986e+272
-7.24802504570839e+271
Compiler

Compiled 12 to 15 computations (-25% saved)

bsearch12.0ms (0.3%)

Memory
32.7MiB live, 32.7MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
Steps
TimeLeftRight
11.0ms
-1.8357440223533302e+123
-1.090834802540375e+114
Samples
6.0ms144×0valid
Compiler

Compiled 210 to 195 computations (7.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 2.0ms
ival-mult!: 2.0ms (88.7% of total)
ival-sub!: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)

derivations1.0ms (0%)

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

Compiled 84 to 32 computations (61.9% saved)

preprocess367.0ms (9%)

Memory
25.7MiB live, 624.5MiB allocated; 175ms collecting garbage
Remove

(negabs t)

(abs y)

Compiler

Compiled 1 687 to 1 104 computations (34.6% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...