Numeric.LinearAlgebra.Util:formatSparse from hmatrix-0.16.1.5

Time bar (total: 1.5s)

analyze11.0ms (0.7%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
50%50%50%0.1%0%0%0%3
50%50%50%0.1%0%0%0%4
75%74.9%25%0.1%0%0%0%5
75%74.9%25%0.1%0%0%0%6
87.5%87.4%12.5%0.1%0%0%0%7
87.5%87.4%12.5%0.1%0%0%0%8
93.8%93.7%6.2%0.1%0%0%0%9
93.8%93.7%6.2%0.1%0%0%0%10
96.9%96.8%3.1%0.1%0%0%0%11
96.9%96.8%3.1%0.1%0%0%0%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample746.0ms (51.3%)

Results
649.0ms7230×body256valid
85.0ms1026×body256infinite
Bogosity

preprocess54.0ms (3.7%)

Algorithm
egg-herbie
Rules
130×fma-def
48×times-frac
36×associate-/r*
34×sub-neg
32×associate-/l*
Problems
256×No Errors
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
025158
142150
283150
3174150
4253150
5316150
6363150
7371150
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 (neg.f64 x) y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 x (neg.f64 y))) (fabs.f64 (neg.f64 y)))
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 x))
Outputs
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 (neg.f64 x) y)) (fabs.f64 y))
(/.f64 (fabs.f64 (+.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 x (neg.f64 y))) (fabs.f64 (neg.f64 y)))
(/.f64 (fabs.f64 (-.f64 (neg.f64 x) y)) (fabs.f64 y))
(/.f64 (fabs.f64 (+.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 x))
Compiler

Compiled 30 to 13 computations (56.7% saved)

eval0.0ms (0%)

Compiler

Compiled 9 to 6 computations (33.3% saved)

prune1.0ms (0.1%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
100.0%
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
Compiler

Compiled 18 to 12 computations (33.3% saved)

localize25.0ms (1.7%)

Localize:

Found 1 expressions with local error:

NewAccuracyProgram
100.0%
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
Compiler

Compiled 21 to 7 computations (66.7% saved)

series4.0ms (0.3%)

Counts
1 → 8
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
1.0ms
y
@-inf
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
0.0ms
y
@inf
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
0.0ms
y
@0
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
0.0ms
x
@inf
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))

rewrite99.0ms (6.8%)

Algorithm
batch-egg-rewrite
Rules
1242×prod-diff
645×log1p-expm1-u
645×expm1-log1p-u
570×log-prod
472×fma-def
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01226
114922
2231522
Stop Event
node limit
Counts
1 → 51
Calls
Call 1
Inputs
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
Outputs
(+.f64 0 (/.f64 (-.f64 y x) y))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y))) (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))))
(-.f64 (exp.f64 (log1p.f64 (/.f64 (-.f64 y x) y))) 1)
(-.f64 (/.f64 y y) (/.f64 x y))
(*.f64 (-.f64 y x) (/.f64 1 y))
(*.f64 (/.f64 (-.f64 y x) y) 1)
(*.f64 (/.f64 (-.f64 y x) y) (log.f64 (exp.f64 1)))
(*.f64 1 (/.f64 (-.f64 y x) y))
(*.f64 (cbrt.f64 (/.f64 (-.f64 y x) y)) (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)))
(*.f64 (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)) (cbrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (*.f64 (cbrt.f64 (-.f64 y x)) (/.f64 1 y)))
(*.f64 (sqrt.f64 (/.f64 (-.f64 y x) y)) (sqrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (sqrt.f64 (-.f64 y x)) (*.f64 (sqrt.f64 (-.f64 y x)) (/.f64 1 y)))
(*.f64 (neg.f64 (-.f64 y x)) (/.f64 1 (neg.f64 y)))
(*.f64 (/.f64 1 y) (-.f64 y x))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (sqrt.f64 y)) (/.f64 (cbrt.f64 (-.f64 y x)) (sqrt.f64 y)))
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 y) 2)) (/.f64 (-.f64 y x) (cbrt.f64 y)))
(*.f64 (/.f64 1 (sqrt.f64 y)) (/.f64 (-.f64 y x) (sqrt.f64 y)))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) 1) (/.f64 (cbrt.f64 (-.f64 y x)) y))
(*.f64 (/.f64 (sqrt.f64 (-.f64 y x)) 1) (/.f64 (sqrt.f64 (-.f64 y x)) y))
(*.f64 (/.f64 (sqrt.f64 (-.f64 y x)) (pow.f64 (cbrt.f64 y) 2)) (/.f64 (sqrt.f64 (-.f64 y x)) (cbrt.f64 y)))
(pow.f64 (/.f64 (-.f64 y x) y) 1)
(pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) y)) 3)
(pow.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2) 1/2)
(pow.f64 (pow.f64 (/.f64 (-.f64 y x) y) 3) 1/3)
(pow.f64 (sqrt.f64 (/.f64 (-.f64 y x) y)) 2)
(pow.f64 (/.f64 y (-.f64 y x)) -1)
(pow.f64 (/.f64 (/.f64 y (-.f64 y x)) 1) -1)
(neg.f64 (/.f64 (-.f64 y x) (neg.f64 y)))
(sqrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2))
(fabs.f64 (/.f64 (-.f64 y x) y))
(fabs.f64 (neg.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (/.f64 (-.f64 y x) (neg.f64 y)))
(fabs.f64 (/.f64 (neg.f64 (-.f64 y x)) y))
(fabs.f64 (/.f64 (-.f64 x y) y))
(fabs.f64 (/.f64 (-.f64 x y) (neg.f64 y)))
(log.f64 (exp.f64 (/.f64 (-.f64 y x) y)))
(log.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) y))))
(cbrt.f64 (pow.f64 (/.f64 (-.f64 y x) y) 3))
(cbrt.f64 (/.f64 (pow.f64 (-.f64 y x) 3) (pow.f64 y 3)))
(expm1.f64 (log1p.f64 (/.f64 (-.f64 y x) y)))
(exp.f64 (log.f64 (/.f64 (-.f64 y x) y)))
(exp.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) y)) 1))
(exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) y)) 1) 1))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (-.f64 y x) y))) 3))
(exp.f64 (*.f64 (*.f64 3 (log.f64 (/.f64 (-.f64 y x) y))) 1/3))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 (-.f64 y x) y))) 2))
(exp.f64 (*.f64 (log.f64 (/.f64 y (-.f64 y x))) -1))
(log1p.f64 (expm1.f64 (/.f64 (-.f64 y x) y)))

simplify60.0ms (4.2%)

Algorithm
egg-herbie
Rules
876×log-prod
860×fma-def
670×log-div
664×distribute-lft-in
646×distribute-rgt-in
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01471754
13321496
210821460
361911434
Stop Event
node limit
Counts
59 → 73
Calls
Call 1
Inputs
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(+.f64 0 (/.f64 (-.f64 y x) y))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y))) (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))))
(-.f64 (exp.f64 (log1p.f64 (/.f64 (-.f64 y x) y))) 1)
(-.f64 (/.f64 y y) (/.f64 x y))
(*.f64 (-.f64 y x) (/.f64 1 y))
(*.f64 (/.f64 (-.f64 y x) y) 1)
(*.f64 (/.f64 (-.f64 y x) y) (log.f64 (exp.f64 1)))
(*.f64 1 (/.f64 (-.f64 y x) y))
(*.f64 (cbrt.f64 (/.f64 (-.f64 y x) y)) (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)))
(*.f64 (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)) (cbrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (*.f64 (cbrt.f64 (-.f64 y x)) (/.f64 1 y)))
(*.f64 (sqrt.f64 (/.f64 (-.f64 y x) y)) (sqrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (sqrt.f64 (-.f64 y x)) (*.f64 (sqrt.f64 (-.f64 y x)) (/.f64 1 y)))
(*.f64 (neg.f64 (-.f64 y x)) (/.f64 1 (neg.f64 y)))
(*.f64 (/.f64 1 y) (-.f64 y x))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (sqrt.f64 y)) (/.f64 (cbrt.f64 (-.f64 y x)) (sqrt.f64 y)))
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 y) 2)) (/.f64 (-.f64 y x) (cbrt.f64 y)))
(*.f64 (/.f64 1 (sqrt.f64 y)) (/.f64 (-.f64 y x) (sqrt.f64 y)))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) 1) (/.f64 (cbrt.f64 (-.f64 y x)) y))
(*.f64 (/.f64 (sqrt.f64 (-.f64 y x)) 1) (/.f64 (sqrt.f64 (-.f64 y x)) y))
(*.f64 (/.f64 (sqrt.f64 (-.f64 y x)) (pow.f64 (cbrt.f64 y) 2)) (/.f64 (sqrt.f64 (-.f64 y x)) (cbrt.f64 y)))
(pow.f64 (/.f64 (-.f64 y x) y) 1)
(pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) y)) 3)
(pow.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2) 1/2)
(pow.f64 (pow.f64 (/.f64 (-.f64 y x) y) 3) 1/3)
(pow.f64 (sqrt.f64 (/.f64 (-.f64 y x) y)) 2)
(pow.f64 (/.f64 y (-.f64 y x)) -1)
(pow.f64 (/.f64 (/.f64 y (-.f64 y x)) 1) -1)
(neg.f64 (/.f64 (-.f64 y x) (neg.f64 y)))
(sqrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2))
(fabs.f64 (/.f64 (-.f64 y x) y))
(fabs.f64 (neg.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (/.f64 (-.f64 y x) (neg.f64 y)))
(fabs.f64 (/.f64 (neg.f64 (-.f64 y x)) y))
(fabs.f64 (/.f64 (-.f64 x y) y))
(fabs.f64 (/.f64 (-.f64 x y) (neg.f64 y)))
(log.f64 (exp.f64 (/.f64 (-.f64 y x) y)))
(log.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) y))))
(cbrt.f64 (pow.f64 (/.f64 (-.f64 y x) y) 3))
(cbrt.f64 (/.f64 (pow.f64 (-.f64 y x) 3) (pow.f64 y 3)))
(expm1.f64 (log1p.f64 (/.f64 (-.f64 y x) y)))
(exp.f64 (log.f64 (/.f64 (-.f64 y x) y)))
(exp.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) y)) 1))
(exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) y)) 1) 1))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (-.f64 y x) y))) 3))
(exp.f64 (*.f64 (*.f64 3 (log.f64 (/.f64 (-.f64 y x) y))) 1/3))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 (-.f64 y x) y))) 2))
(exp.f64 (*.f64 (log.f64 (/.f64 y (-.f64 y x))) -1))
(log1p.f64 (expm1.f64 (/.f64 (-.f64 y x) y)))
Outputs
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (neg.f64 (+.f64 x (*.f64 -1 y)))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(/.f64 (fabs.f64 (+.f64 y (*.f64 -1 x))) (fabs.f64 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(+.f64 0 (/.f64 (-.f64 y x) y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y))) (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (-.f64 1 (/.f64 x y)))) (cbrt.f64 (exp.f64 (-.f64 1 (/.f64 x y)))))) (log.f64 (cbrt.f64 (exp.f64 (-.f64 1 (/.f64 x y))))))
(+.f64 (*.f64 2 (log.f64 (cbrt.f64 (exp.f64 (-.f64 1 (/.f64 x y)))))) (log.f64 (cbrt.f64 (exp.f64 (-.f64 1 (/.f64 x y))))))
(*.f64 3 (log.f64 (cbrt.f64 (exp.f64 (+.f64 -1 (/.f64 x y))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) y)))))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(-.f64 (exp.f64 (log1p.f64 (/.f64 (-.f64 y x) y))) 1)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(-.f64 (/.f64 y y) (/.f64 x y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (-.f64 y x) (/.f64 1 y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (/.f64 (-.f64 y x) y) 1)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (/.f64 (-.f64 y x) y) (log.f64 (exp.f64 1)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 1 (/.f64 (-.f64 y x) y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (cbrt.f64 (/.f64 (-.f64 y x) y)) (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)))
(*.f64 (cbrt.f64 (-.f64 1 (/.f64 x y))) (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)))
(*.f64 (cbrt.f64 (-.f64 1 (/.f64 x y))) (cbrt.f64 (pow.f64 (-.f64 1 (/.f64 x y)) 2)))
(*.f64 (cbrt.f64 (+.f64 -1 (/.f64 x y))) (cbrt.f64 (pow.f64 (+.f64 -1 (/.f64 x y)) 2)))
(*.f64 (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)) (cbrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (cbrt.f64 (-.f64 1 (/.f64 x y))) (cbrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2)))
(*.f64 (cbrt.f64 (-.f64 1 (/.f64 x y))) (cbrt.f64 (pow.f64 (-.f64 1 (/.f64 x y)) 2)))
(*.f64 (cbrt.f64 (+.f64 -1 (/.f64 x y))) (cbrt.f64 (pow.f64 (+.f64 -1 (/.f64 x y)) 2)))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (*.f64 (cbrt.f64 (-.f64 y x)) (/.f64 1 y)))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (*.f64 (/.f64 1 y) (cbrt.f64 (-.f64 y x))))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (/.f64 (cbrt.f64 (-.f64 y x)) y))
(/.f64 (cbrt.f64 (-.f64 x y)) (/.f64 y (cbrt.f64 (pow.f64 (-.f64 x y) 2))))
(*.f64 (sqrt.f64 (/.f64 (-.f64 y x) y)) (sqrt.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (sqrt.f64 (-.f64 y x)) (*.f64 (sqrt.f64 (-.f64 y x)) (/.f64 1 y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (neg.f64 (-.f64 y x)) (/.f64 1 (neg.f64 y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (/.f64 1 y) (-.f64 y x))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 (/.f64 (-.f64 y x) y)))
(*.f64 (cbrt.f64 (-.f64 1 (/.f64 x y))) (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (pow.f64 (cbrt.f64 y) 2)))
(/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (+.f64 -1 (/.f64 x y)))))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (sqrt.f64 y)) (/.f64 (cbrt.f64 (-.f64 y x)) (sqrt.f64 y)))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (sqrt.f64 y)) (/.f64 (cbrt.f64 (-.f64 x y)) (sqrt.f64 y)))
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 y) 2)) (/.f64 (-.f64 y x) (cbrt.f64 y)))
(/.f64 (/.f64 (-.f64 y x) (cbrt.f64 y)) (pow.f64 (cbrt.f64 y) 2))
(/.f64 (-.f64 x y) (*.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y)))
(/.f64 (-.f64 x y) (pow.f64 (cbrt.f64 y) 3))
(*.f64 (/.f64 1 (sqrt.f64 y)) (/.f64 (-.f64 y x) (sqrt.f64 y)))
(/.f64 (/.f64 (-.f64 y x) (sqrt.f64 y)) (sqrt.f64 y))
(/.f64 (-.f64 x y) (*.f64 (sqrt.f64 y) (sqrt.f64 y)))
(*.f64 (/.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) 1) (/.f64 (cbrt.f64 (-.f64 y x)) y))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (*.f64 (/.f64 1 y) (cbrt.f64 (-.f64 y x))))
(*.f64 (cbrt.f64 (pow.f64 (-.f64 x y) 2)) (/.f64 (cbrt.f64 (-.f64 y x)) y))
(/.f64 (cbrt.f64 (-.f64 x y)) (/.f64 y (cbrt.f64 (pow.f64 (-.f64 x y) 2))))
(*.f64 (/.f64 (sqrt.f64 (-.f64 y x)) 1) (/.f64 (sqrt.f64 (-.f64 y x)) y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(*.f64 (/.f64 (sqrt.f64 (-.f64 y x)) (pow.f64 (cbrt.f64 y) 2)) (/.f64 (sqrt.f64 (-.f64 y x)) (cbrt.f64 y)))
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 y) 2)) (/.f64 (-.f64 y x) (cbrt.f64 y)))
(/.f64 (/.f64 (-.f64 y x) (cbrt.f64 y)) (pow.f64 (cbrt.f64 y) 2))
(/.f64 (-.f64 x y) (*.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 y)))
(/.f64 (-.f64 x y) (pow.f64 (cbrt.f64 y) 3))
(pow.f64 (/.f64 (-.f64 y x) y) 1)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) y)) 3)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(pow.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2) 1/2)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(pow.f64 (pow.f64 (/.f64 (-.f64 y x) y) 3) 1/3)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(pow.f64 (sqrt.f64 (/.f64 (-.f64 y x) y)) 2)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(pow.f64 (/.f64 y (-.f64 y x)) -1)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(pow.f64 (/.f64 (/.f64 y (-.f64 y x)) 1) -1)
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(neg.f64 (/.f64 (-.f64 y x) (neg.f64 y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(sqrt.f64 (pow.f64 (/.f64 y (-.f64 y x)) -2))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(fabs.f64 (/.f64 (-.f64 y x) y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(fabs.f64 (neg.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(fabs.f64 (/.f64 (-.f64 y x) (neg.f64 y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(fabs.f64 (/.f64 (neg.f64 (-.f64 y x)) y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(fabs.f64 (/.f64 (-.f64 x y) y))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(fabs.f64 (/.f64 (-.f64 x y) (neg.f64 y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(log.f64 (exp.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(log.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) y))))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(cbrt.f64 (pow.f64 (/.f64 (-.f64 y x) y) 3))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(cbrt.f64 (/.f64 (pow.f64 (-.f64 y x) 3) (pow.f64 y 3)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(expm1.f64 (log1p.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (log.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) y)) 1))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) y)) 1) 1))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (-.f64 y x) y))) 3))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (*.f64 (*.f64 3 (log.f64 (/.f64 (-.f64 y x) y))) 1/3))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 (-.f64 y x) y))) 2))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(exp.f64 (*.f64 (log.f64 (/.f64 y (-.f64 y x))) -1))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(log1p.f64 (expm1.f64 (/.f64 (-.f64 y x) y)))
(fabs.f64 (-.f64 (/.f64 x y) 1))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))

eval13.0ms (0.9%)

Compiler

Compiled 791 to 322 computations (59.3% saved)

prune10.0ms (0.7%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New71273
Fresh000
Picked101
Done000
Total72274
Accuracy
100.0%
Counts
74 → 2
Alt Table
Click to see full alt table
StatusAccuracyProgram
68.6%
(-.f64 1 (/.f64 x y))
32.5%
(+.f64 -1 (/.f64 x y))
68.6%
(-.f64 1 (/.f64 x y))
32.5%
(+.f64 -1 (/.f64 x y))
Compiler

Compiled 28 to 20 computations (28.6% saved)

localize32.0ms (2.2%)

Compiler

Compiled 25 to 10 computations (60% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune2.0ms (0.1%)

Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New000
Fresh000
Picked022
Done000
Total022
Accuracy
100.0%
Counts
2 → 2
Alt Table
Click to see full alt table
StatusAccuracyProgram
68.6%
(-.f64 1 (/.f64 x y))
32.5%
(+.f64 -1 (/.f64 x y))
Compiler

Compiled 40 to 24 computations (40% saved)

regimes13.0ms (0.9%)

Counts
4 → 1
Calls
Call 1
Inputs
(+.f64 -1 (/.f64 x y))
(-.f64 1 (/.f64 x y))
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
Outputs
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
Calls

3 calls:

4.0ms
x
4.0ms
y
3.0ms
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
Results
AccuracySegmentsBranch
100.0%1x
100.0%1y
100.0%1(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
Compiler

Compiled 41 to 24 computations (41.5% saved)

regimes32.0ms (2.2%)

Counts
2 → 5
Calls
Call 1
Inputs
(+.f64 -1 (/.f64 x y))
(-.f64 1 (/.f64 x y))
Outputs
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(-.f64 1 (/.f64 x y))
(+.f64 -1 (/.f64 x y))
(-.f64 1 (/.f64 x y))
Calls

2 calls:

16.0ms
y
15.0ms
x
Results
AccuracySegmentsBranch
73.6%4x
76.0%5y
Compiler

Compiled 18 to 11 computations (38.9% saved)

regimes6.0ms (0.4%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
(+.f64 -1 (/.f64 x y))
Outputs
(+.f64 -1 (/.f64 x y))
Calls

2 calls:

3.0ms
x
3.0ms
y
Results
AccuracySegmentsBranch
32.5%1x
32.5%1y
Compiler

Compiled 13 to 9 computations (30.8% saved)

bsearch34.0ms (2.3%)

Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
narrow-enough
narrow-enough
Steps
TimeLeftRight
6.0ms
4.838085232598409e-139
7.459155383869937e-139
7.0ms
7.832397939907066e-173
1.1613101565307502e-172
14.0ms
5.939777447825279e-204
1.1612952709165632e-197
6.0ms
-7.291059225878803e-213
-4.6968524546498106e-213
Results
20.0ms228×body256valid
9.0ms108×body256infinite
Compiler

Compiled 350 to 262 computations (25.1% saved)

simplify8.0ms (0.5%)

Algorithm
egg-herbie
Rules
14×+-commutative
12×sub-neg
not-or
neg-mul-1
not-not
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
032180
146168
258156
371152
479152
584152
685152
786152
Stop Event
done
saturated
Calls
Call 1
Inputs
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(if (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (-.f64 1 (/.f64 x y)) (if (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144) (+.f64 -1 (/.f64 x y)) (if (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608) (-.f64 1 (/.f64 x y)) (if (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096) (+.f64 -1 (/.f64 x y)) (-.f64 1 (/.f64 x y))))))
(+.f64 -1 (/.f64 x y))
Outputs
(/.f64 (fabs.f64 (-.f64 x y)) (fabs.f64 y))
(/.f64 (fabs.f64 (-.f64 y x)) (fabs.f64 y))
(if (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (-.f64 1 (/.f64 x y)) (if (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144) (+.f64 -1 (/.f64 x y)) (if (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608) (-.f64 1 (/.f64 x y)) (if (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096) (+.f64 -1 (/.f64 x y)) (-.f64 1 (/.f64 x y))))))
(if (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (-.f64 1 (/.f64 x y)) (if (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144) (+.f64 (/.f64 x y) -1) (if (or (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608) (not (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096))) (-.f64 1 (/.f64 x y)) (+.f64 (/.f64 x y) -1))))
(if (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (-.f64 1 (/.f64 x y)) (if (or (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144) (not (or (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608) (not (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096))))) (+.f64 (/.f64 x y) -1) (-.f64 1 (/.f64 x y))))
(if (or (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (not (or (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144) (not (or (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608) (not (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096))))))) (-.f64 1 (/.f64 x y)) (+.f64 (/.f64 x y) -1))
(if (or (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (not (or (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144) (and (not (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608)) (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096))))) (-.f64 1 (/.f64 x y)) (+.f64 (/.f64 x y) -1))
(if (or (<=.f64 y -483266740157081/94758184344525691842589080106353915726128296943157752144717531617800961467674370503593652882607817257720198406807316479868870852301929589321550737002025216015896910157522577243058183937475491017166931103132108688408987234729984) (and (not (<=.f64 y 3033608744706093/1378913065775496824682182051857728448902028277271278088224317349054049721856053955032165000485952146958446223387833982704161766047792183079895777875237766653530662154044294980748355504146827894396365898183024673030144)) (or (<=.f64 y 3654909247210163/34808659497239648579720852704622583960672214563358764118798771041101647699040812580153753748454066465596331097210650690541753423472407821641942301328447068696990926165468330002463334596608) (not (<=.f64 y 6569825885671873/13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096))))) (-.f64 1 (/.f64 x y)) (+.f64 (/.f64 x y) -1))
(+.f64 -1 (/.f64 x y))
(+.f64 (/.f64 x y) -1)
Compiler

Compiled 46 to 32 computations (30.4% saved)

soundness264.0ms (18.2%)

Rules
876×log-prod
876×log-prod
860×fma-def
860×fma-def
670×log-div
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
025158
142150
283150
3174150
4253150
5316150
6363150
7371150
01471754
13321496
210821460
361911434
01471754
13321496
210821460
361911434
Stop Event
node limit
node limit
saturated
Compiler

Compiled 308 to 120 computations (61% saved)

end0.0ms (0%)

preprocess38.0ms (2.7%)

Compiler

Compiled 102 to 66 computations (35.3% saved)

Profiling

Loading profile data...