Details

Time bar (total: 2.2s)

analyze56.0ms (2.5%)

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
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
25%25%74.9%0.1%0%0%0%5
37.5%37.5%62.4%0.1%0%0%0%6
51.6%50%46.8%0.1%3.1%0%0%7
62.3%59.3%35.9%0.1%4.7%0%0%8
72.3%67.1%25.8%0.1%7%0%0%9
79.1%72.6%19.1%0.1%8.2%0%0%10
85.1%76.9%13.5%0.1%9.6%0%0%11
89%79.8%9.9%0.1%10.2%0%0%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample825.0ms (37.4%)

Results
797.0ms8253×body256valid
17.0ms222×body256infinite
0.0msbody1024valid
0.0msbody512valid
Bogosity

preprocess65.0ms (2.9%)

Algorithm
egg-herbie
Rules
928×fma-def
606×associate--r+
570×associate-+r+
476×associate-+l-
430×associate--l+
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01138
12538
24830
311030
424830
557330
6140030
7278130
8307630
9309430
10309430
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(-.f64 (*.f64 (+.f64 x 1) y) x)
(-.f64 (*.f64 (+.f64 y 1) x) y)
Outputs
(-.f64 (*.f64 (+.f64 x 1) y) x)
(-.f64 (fma.f64 x y y) x)
(-.f64 (*.f64 (+.f64 y 1) x) y)
(fma.f64 (+.f64 1 y) x (neg.f64 y))
(fma.f64 x (+.f64 1 y) (neg.f64 y))
(-.f64 (fma.f64 x y x) y)
(fma.f64 y (+.f64 x -1) x)
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify42.0ms (1.9%)

Algorithm
egg-herbie
Rules
520×fma-def
306×associate-+l+
298×associate--r+
272×associate-+l-
232×associate-+r+
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0819
11719
23015
36815
413615
530015
660315
7130415
8183915
9189015
10189915
Stop Event
saturated
Counts
1 → 3
Calls
Call 1
Inputs
(-.f64 (*.f64 (+.f64 x 1) y) x)
Outputs
(-.f64 (*.f64 (+.f64 x 1) y) x)
(-.f64 (fma.f64 x y y) x)
(fma.f64 x y (-.f64 y x))

eval1.0ms (0%)

Compiler

Compiled 21 to 10 computations (52.4% saved)

prune1.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New123
Fresh011
Picked000
Done000
Total134
Error
0b
Counts
4 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0b
(fma.f64 x y (-.f64 y x))
0.0b
(-.f64 (*.f64 (+.f64 x 1) y) x)
Compiler

Compiled 17 to 10 computations (41.2% saved)

localize8.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 (+.f64 x 1) y) x)
Compiler

Compiled 20 to 12 computations (40% saved)

series2.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
y
@-inf
(-.f64 (*.f64 (+.f64 x 1) y) x)
0.0ms
x
@inf
(-.f64 (*.f64 (+.f64 x 1) y) x)
0.0ms
y
@inf
(-.f64 (*.f64 (+.f64 x 1) y) x)
0.0ms
y
@0
(-.f64 (*.f64 (+.f64 x 1) y) x)
0.0ms
x
@-inf
(-.f64 (*.f64 (+.f64 x 1) y) x)

rewrite101.0ms (4.6%)

Algorithm
batch-egg-rewrite
Rules
1912×add-sqr-sqrt
1896×*-un-lft-identity
1768×add-cube-cbrt
1752×add-cbrt-cube
180×pow1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0819
117419
2233219
Stop Event
node limit
Counts
1 → 39
Calls
Call 1
Inputs
(-.f64 (*.f64 (+.f64 x 1) y) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 y (*.f64 x y)) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 y (*.f64 x y)) (*.f64 (neg.f64 x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 x) 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 (sqrt.f64 x)) (sqrt.f64 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (neg.f64 x) (+.f64 y (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (+.f64 y (*.f64 x y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) (pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2) (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 x 1) y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 x)) (-.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (+.f64 x 1) y x) (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x))) (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x)) (fma.f64 (+.f64 x 1) y x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (+.f64 y (*.f64 x y)) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 (neg.f64 x) 3)) (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (+.f64 y (*.f64 x y)) (neg.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x))) (neg.f64 (fma.f64 (+.f64 x 1) y x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3))) (neg.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (-.f64 (+.f64 y (*.f64 x y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 y (*.f64 x y)) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 x 1) y (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (+.f64 x 1) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 (+.f64 y (*.f64 x y))) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 y (*.f64 x y))) 2) (cbrt.f64 (+.f64 y (*.f64 x y))) (neg.f64 x))))))

simplify65.0ms (2.9%)

Algorithm
egg-herbie
Rules
1532×associate--r+
854×distribute-lft-in
826×fma-def
806×associate-+r-
766×distribute-rgt-in
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01171527
13041371
213401371
361131371
Stop Event
node limit
Counts
63 → 61
Calls
Call 1
Inputs
y
(+.f64 (*.f64 (-.f64 y 1) x) y)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(*.f64 (-.f64 y 1) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(*.f64 -1 x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(*.f64 (+.f64 1 x) y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(*.f64 (+.f64 1 x) y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(+.f64 (+.f64 y (*.f64 x y)) (neg.f64 x))
(+.f64 (+.f64 y (*.f64 x y)) (*.f64 (neg.f64 x) 1))
(+.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 x) 1 x))
(+.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 (sqrt.f64 x)) (sqrt.f64 x) x))
(+.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) x))
(+.f64 (neg.f64 x) (+.f64 y (*.f64 x y)))
(*.f64 1 (-.f64 (+.f64 y (*.f64 x y)) x))
(*.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)
(*.f64 (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(*.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) (pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2))
(*.f64 (pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2) (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 x 1) y x)))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x)))))
(*.f64 (+.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 x)) (-.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 x)))
(/.f64 1 (/.f64 (fma.f64 (+.f64 x 1) y x) (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x))))
(/.f64 1 (/.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x))) (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3))))
(/.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x)) (fma.f64 (+.f64 x 1) y x))
(/.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x))))
(/.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (+.f64 y (*.f64 x y)) (neg.f64 x)))
(/.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 (neg.f64 x) 3)) (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (+.f64 y (*.f64 x y)) (neg.f64 x)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x))) (neg.f64 (fma.f64 (+.f64 x 1) y x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3))) (neg.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x)))))
(pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)
(pow.f64 (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2)
(pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 3)
(pow.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 3) 1/3)
(sqrt.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 2))
(log.f64 (exp.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(log.f64 (+.f64 1 (expm1.f64 (-.f64 (+.f64 y (*.f64 x y)) x))))
(cbrt.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 3))
(expm1.f64 (log1p.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(exp.f64 (log.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(exp.f64 (*.f64 (log.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 1))
(log1p.f64 (expm1.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 1 (+.f64 y (*.f64 x y)) (neg.f64 x))
(fma.f64 (+.f64 x 1) y (neg.f64 x))
(fma.f64 y (+.f64 x 1) (neg.f64 x))
(fma.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 (+.f64 y (*.f64 x y))) (neg.f64 x))
(fma.f64 (pow.f64 (cbrt.f64 (+.f64 y (*.f64 x y))) 2) (cbrt.f64 (+.f64 y (*.f64 x y))) (neg.f64 x))
Outputs
y
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (+.f64 y -1) x)
(-.f64 (*.f64 y x) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 (+.f64 y -1) x)
(-.f64 (*.f64 y x) x)
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (+.f64 1 x) y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (+.f64 1 x) y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (+.f64 y (*.f64 x y)) (neg.f64 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (+.f64 y (*.f64 x y)) (*.f64 (neg.f64 x) 1))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 x) 1 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 (sqrt.f64 x)) (sqrt.f64 x) x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (-.f64 (+.f64 y (*.f64 x y)) x) (fma.f64 (neg.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(+.f64 (neg.f64 x) (+.f64 y (*.f64 x y)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 1 (-.f64 (+.f64 y (*.f64 x y)) x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) (pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2) (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 x 1) y x)))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 1 x) y x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 2) (*.f64 x x)) (+.f64 y (fma.f64 y x x)))
(/.f64 (fma.f64 x (neg.f64 x) (pow.f64 (fma.f64 y x y) 2)) (+.f64 y (fma.f64 y x x)))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x)))))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x (fma.f64 (+.f64 1 x) y x)))))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 3) (pow.f64 x 3)) (fma.f64 x (+.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x y) 2)))
(*.f64 (+.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 x)) (-.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 x)))
(*.f64 (+.f64 (sqrt.f64 x) (sqrt.f64 (+.f64 y (*.f64 y x)))) (-.f64 (sqrt.f64 (+.f64 y (*.f64 y x))) (sqrt.f64 x)))
(*.f64 (+.f64 (sqrt.f64 x) (sqrt.f64 (fma.f64 y x y))) (-.f64 (sqrt.f64 (fma.f64 y x y)) (sqrt.f64 x)))
(/.f64 1 (/.f64 (fma.f64 (+.f64 x 1) y x) (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x))))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 1 x) y x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 2) (*.f64 x x)) (+.f64 y (fma.f64 y x x)))
(/.f64 (fma.f64 x (neg.f64 x) (pow.f64 (fma.f64 y x y) 2)) (+.f64 y (fma.f64 y x x)))
(/.f64 1 (/.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x))) (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3))))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x (fma.f64 (+.f64 1 x) y x)))))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 3) (pow.f64 x 3)) (fma.f64 x (+.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x y) 2)))
(/.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x)) (fma.f64 (+.f64 x 1) y x))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 1 x) y x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 2) (*.f64 x x)) (+.f64 y (fma.f64 y x x)))
(/.f64 (fma.f64 x (neg.f64 x) (pow.f64 (fma.f64 y x y) 2)) (+.f64 y (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x))))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x (fma.f64 (+.f64 1 x) y x)))))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 3) (pow.f64 x 3)) (fma.f64 x (+.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x y) 2)))
(/.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (+.f64 y (*.f64 x y)) (neg.f64 x)))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 1 x) y x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 2) (*.f64 x x)) (+.f64 y (fma.f64 y x x)))
(/.f64 (fma.f64 x (neg.f64 x) (pow.f64 (fma.f64 y x y) 2)) (+.f64 y (fma.f64 y x x)))
(/.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 (neg.f64 x) 3)) (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (+.f64 y (*.f64 x y)) (neg.f64 x)))))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x (fma.f64 (+.f64 1 x) y x)))))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 3) (pow.f64 x 3)) (fma.f64 x (+.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x y) 2)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x x))) (neg.f64 (fma.f64 (+.f64 x 1) y x)))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x x)) (/.f64 1 (fma.f64 (+.f64 1 x) y x)))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 2) (*.f64 x x)) (+.f64 y (fma.f64 y x x)))
(/.f64 (fma.f64 x (neg.f64 x) (pow.f64 (fma.f64 y x y) 2)) (+.f64 y (fma.f64 y x x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) (pow.f64 x 3))) (neg.f64 (+.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2) (*.f64 x (fma.f64 (+.f64 x 1) y x)))))
(*.f64 (-.f64 (pow.f64 (+.f64 y (*.f64 y x)) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (+.f64 y (*.f64 y x)) 2) (*.f64 x (fma.f64 (+.f64 1 x) y x)))))
(/.f64 (-.f64 (pow.f64 (fma.f64 y x y) 3) (pow.f64 x 3)) (fma.f64 x (+.f64 y (fma.f64 y x x)) (pow.f64 (fma.f64 y x y) 2)))
(pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(pow.f64 (sqrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 2)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 3)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(pow.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 3) 1/3)
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(sqrt.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 2))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(log.f64 (exp.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(log.f64 (+.f64 1 (expm1.f64 (-.f64 (+.f64 y (*.f64 x y)) x))))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(cbrt.f64 (pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 3))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(expm1.f64 (log1p.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(exp.f64 (log.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(exp.f64 (*.f64 (log.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 1))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(log1p.f64 (expm1.f64 (-.f64 (+.f64 y (*.f64 x y)) x)))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 1 (+.f64 y (*.f64 x y)) (neg.f64 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 (+.f64 x 1) y (neg.f64 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y (+.f64 x 1) (neg.f64 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) (sqrt.f64 (+.f64 y (*.f64 x y))) (neg.f64 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 (pow.f64 (cbrt.f64 (+.f64 y (*.f64 x y))) 2) (cbrt.f64 (+.f64 y (*.f64 x y))) (neg.f64 x))
(fma.f64 (+.f64 y -1) x y)
(-.f64 (fma.f64 y x y) x)

localize5.0ms (0.2%)

Compiler

Compiled 13 to 4 computations (69.2% saved)

eval12.0ms (0.5%)

Compiler

Compiled 819 to 289 computations (64.7% saved)

prune13.0ms (0.6%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New56561
Fresh000
Picked101
Done011
Total57663
Error
0b
Counts
63 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(-.f64 (*.f64 (+.f64 x 1) y) x)
24.9b
(-.f64 (*.f64 y x) x)
24.9b
(*.f64 (-.f64 y 1) x)
28.9b
(*.f64 (+.f64 1 x) y)
34.5b
(neg.f64 x)
38.9b
y
Compiler

Compiled 37 to 25 computations (32.4% saved)

localize2.0ms (0.1%)

Compiler

Compiled 5 to 3 computations (40% saved)

localize5.0ms (0.2%)

Compiler

Compiled 13 to 8 computations (38.5% saved)

localize5.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (-.f64 y 1) x)
Compiler

Compiled 13 to 8 computations (38.5% saved)

series2.0ms (0.1%)

Counts
1 → 12
Calls

6 calls:

TimeVariablePointExpression
0.0ms
x
@inf
(*.f64 (-.f64 y 1) x)
0.0ms
x
@0
(*.f64 (-.f64 y 1) x)
0.0ms
x
@-inf
(*.f64 (-.f64 y 1) x)
0.0ms
y
@-inf
(*.f64 (-.f64 y 1) x)
0.0ms
y
@0
(*.f64 (-.f64 y 1) x)

rewrite53.0ms (2.4%)

Algorithm
batch-egg-rewrite
Rules
1412×add-sqr-sqrt
1396×*-un-lft-identity
1302×add-cube-cbrt
1286×add-cbrt-cube
1274×add-exp-log
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
114413
2178513
Stop Event
node limit
Counts
1 → 18
Calls
Call 1
Inputs
(*.f64 (-.f64 y 1) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x y) (*.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y x) (*.f64 -1 x))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (+.f64 y -1) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (fma.f64 y y -1)) (+.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (pow.f64 y 3) -1)) (fma.f64 y y (+.f64 y 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 y y -1) x) (+.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 y 3) -1) x) (fma.f64 y y (+.f64 y 1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 y -1) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (+.f64 y -1) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (+.f64 y -1) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (+.f64 y -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (+.f64 y -1) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (+.f64 y -1) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 y -1) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (+.f64 y -1) x)))))))

simplify53.0ms (2.4%)

Algorithm
egg-herbie
Rules
1034×*-commutative
874×fma-def
688×associate-*r*
606×associate-*l*
604×distribute-lft-out
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
055422
1130422
2404422
32396422
44947422
Stop Event
node limit
Counts
30 → 28
Calls
Call 1
Inputs
(*.f64 -1 x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 x y) (*.f64 x -1))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (+.f64 1 (*.f64 (+.f64 y -1) x)) 1)
(/.f64 (*.f64 x (fma.f64 y y -1)) (+.f64 y 1))
(/.f64 (*.f64 x (+.f64 (pow.f64 y 3) -1)) (fma.f64 y y (+.f64 y 1)))
(/.f64 (*.f64 (fma.f64 y y -1) x) (+.f64 y 1))
(/.f64 (*.f64 (+.f64 (pow.f64 y 3) -1) x) (fma.f64 y y (+.f64 y 1)))
(pow.f64 (*.f64 (+.f64 y -1) x) 1)
(pow.f64 (sqrt.f64 (*.f64 (+.f64 y -1) x)) 2)
(pow.f64 (cbrt.f64 (*.f64 (+.f64 y -1) x)) 3)
(pow.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 3) 1/3)
(sqrt.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 2))
(log.f64 (pow.f64 (exp.f64 x) (+.f64 y -1)))
(cbrt.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 3))
(expm1.f64 (log1p.f64 (*.f64 (+.f64 y -1) x)))
(exp.f64 (log.f64 (*.f64 (+.f64 y -1) x)))
(exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 y -1) x)) 1))
(log1p.f64 (expm1.f64 (*.f64 (+.f64 y -1) x)))
Outputs
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(*.f64 y x)
(*.f64 x y)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(*.f64 y x)
(*.f64 x y)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 x y) (*.f64 x -1))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(-.f64 (+.f64 1 (*.f64 (+.f64 y -1) x)) 1)
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(/.f64 (*.f64 x (fma.f64 y y -1)) (+.f64 y 1))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(/.f64 (*.f64 x (+.f64 (pow.f64 y 3) -1)) (fma.f64 y y (+.f64 y 1)))
(/.f64 x (/.f64 (fma.f64 y y (+.f64 y 1)) (+.f64 -1 (pow.f64 y 3))))
(*.f64 (/.f64 x (fma.f64 y y (+.f64 y 1))) (+.f64 -1 (pow.f64 y 3)))
(*.f64 x (/.f64 (+.f64 -1 (pow.f64 y 3)) (+.f64 y (fma.f64 y y 1))))
(*.f64 (+.f64 -1 (pow.f64 y 3)) (/.f64 x (+.f64 y (fma.f64 y y 1))))
(/.f64 (*.f64 (fma.f64 y y -1) x) (+.f64 y 1))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(/.f64 (*.f64 (+.f64 (pow.f64 y 3) -1) x) (fma.f64 y y (+.f64 y 1)))
(/.f64 x (/.f64 (fma.f64 y y (+.f64 y 1)) (+.f64 -1 (pow.f64 y 3))))
(*.f64 (/.f64 x (fma.f64 y y (+.f64 y 1))) (+.f64 -1 (pow.f64 y 3)))
(*.f64 x (/.f64 (+.f64 -1 (pow.f64 y 3)) (+.f64 y (fma.f64 y y 1))))
(*.f64 (+.f64 -1 (pow.f64 y 3)) (/.f64 x (+.f64 y (fma.f64 y y 1))))
(pow.f64 (*.f64 (+.f64 y -1) x) 1)
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(pow.f64 (sqrt.f64 (*.f64 (+.f64 y -1) x)) 2)
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(pow.f64 (cbrt.f64 (*.f64 (+.f64 y -1) x)) 3)
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(pow.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 3) 1/3)
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(sqrt.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 2))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(log.f64 (pow.f64 (exp.f64 x) (+.f64 y -1)))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(cbrt.f64 (pow.f64 (*.f64 (+.f64 y -1) x) 3))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(expm1.f64 (log1p.f64 (*.f64 (+.f64 y -1) x)))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(exp.f64 (log.f64 (*.f64 (+.f64 y -1) x)))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 y -1) x)) 1))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)
(log1p.f64 (expm1.f64 (*.f64 (+.f64 y -1) x)))
(*.f64 x (+.f64 -1 y))
(-.f64 (*.f64 x y) x)

localize4.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 y x) x)
Compiler

Compiled 12 to 4 computations (66.7% saved)

series2.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite55.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
1486×add-sqr-sqrt
1470×*-un-lft-identity
1372×add-cube-cbrt
1358×add-cbrt-cube
1346×add-exp-log
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0613
113213
2180213
Stop Event
node limit
Counts
1 → 39
Calls
Call 1
Inputs
(-.f64 (*.f64 y x) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y x) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y x) (*.f64 (neg.f64 x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 x) 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 (sqrt.f64 x)) (sqrt.f64 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (neg.f64 x) (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (-.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 y x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (*.f64 y x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) (sqrt.f64 (-.f64 (*.f64 y x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) (pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 2) (cbrt.f64 (-.f64 (*.f64 y x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 x)) (-.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 y x x) (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x))) (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x)) (fma.f64 y x x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (*.f64 y x) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 (neg.f64 x) 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y x) (neg.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x))) (neg.f64 (fma.f64 y x x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (*.f64 y x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 (*.f64 y x) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 (*.f64 y x) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 (*.f64 y x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 (*.f64 y x) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 (*.f64 y x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 (*.f64 y x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (-.f64 (*.f64 y x) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 (*.f64 y x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 y x) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) (neg.f64 x))))))

simplify58.0ms (2.6%)

Algorithm
egg-herbie
Rules
1248×associate-+l+
776×associate-/l/
740×associate-*r/
702×fma-def
610×associate-/r/
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01101273
12821193
211861193
344841193
Stop Event
node limit
Counts
63 → 55
Calls
Call 1
Inputs
(*.f64 -1 x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 (-.f64 y 1) x)
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(+.f64 (*.f64 y x) (neg.f64 x))
(+.f64 (*.f64 y x) (*.f64 (neg.f64 x) 1))
(+.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 x) 1 x))
(+.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 (sqrt.f64 x)) (sqrt.f64 x) x))
(+.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) x))
(+.f64 (neg.f64 x) (*.f64 y x))
(*.f64 x (-.f64 y 1))
(*.f64 (-.f64 (*.f64 y x) x) 1)
(*.f64 1 (-.f64 (*.f64 y x) x))
(*.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) (sqrt.f64 (-.f64 (*.f64 y x) x)))
(*.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) (pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 2))
(*.f64 (pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 2) (cbrt.f64 (-.f64 (*.f64 y x) x)))
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x)))))
(*.f64 (+.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 x)) (-.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 x)))
(/.f64 1 (/.f64 (fma.f64 y x x) (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x))))
(/.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x))) (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3))))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x)) (fma.f64 y x x))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x))))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (*.f64 y x) (neg.f64 x)))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 (neg.f64 x) 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y x) (neg.f64 x)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x))) (neg.f64 (fma.f64 y x x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x)))))
(pow.f64 (-.f64 (*.f64 y x) x) 1)
(pow.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) 2)
(pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 3)
(pow.f64 (pow.f64 (-.f64 (*.f64 y x) x) 3) 1/3)
(sqrt.f64 (pow.f64 (-.f64 (*.f64 y x) x) 2))
(log.f64 (exp.f64 (-.f64 (*.f64 y x) x)))
(cbrt.f64 (pow.f64 (-.f64 (*.f64 y x) x) 3))
(expm1.f64 (log1p.f64 (-.f64 (*.f64 y x) x)))
(exp.f64 (log.f64 (-.f64 (*.f64 y x) x)))
(exp.f64 (*.f64 (log.f64 (-.f64 (*.f64 y x) x)) 1))
(log1p.f64 (expm1.f64 (-.f64 (*.f64 y x) x)))
(fma.f64 y x (neg.f64 x))
(fma.f64 x y (neg.f64 x))
(fma.f64 1 (*.f64 y x) (neg.f64 x))
(fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) (neg.f64 x))
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) (neg.f64 x))
Outputs
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 y x)
(*.f64 x y)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 y x)
(*.f64 x y)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (neg.f64 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 (neg.f64 x) 1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 x) 1 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 (sqrt.f64 x)) (sqrt.f64 x) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (-.f64 (*.f64 y x) x) (fma.f64 (neg.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (neg.f64 x) (*.f64 y x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 x (-.f64 y 1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 (*.f64 y x) x) 1)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 1 (-.f64 (*.f64 y x) x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) (sqrt.f64 (-.f64 (*.f64 y x) x)))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) (pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 2))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 2) (cbrt.f64 (-.f64 (*.f64 y x) x)))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (fma.f64 x y x))
(*.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x)))))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (fma.f64 y x x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (fma.f64 x (fma.f64 x y x) (pow.f64 (*.f64 x y) 2)))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) -1)) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 -1 (pow.f64 y 3))) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(*.f64 (+.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 x)) (-.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 x)))
(*.f64 (+.f64 (sqrt.f64 x) (sqrt.f64 (*.f64 x y))) (-.f64 (sqrt.f64 (*.f64 x y)) (sqrt.f64 x)))
(/.f64 1 (/.f64 (fma.f64 y x x) (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x))))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (fma.f64 x y x))
(/.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x))) (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3))))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (fma.f64 y x x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (fma.f64 x (fma.f64 x y x) (pow.f64 (*.f64 x y) 2)))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) -1)) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 -1 (pow.f64 y 3))) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x)) (fma.f64 y x x))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (fma.f64 x y x))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x))))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (fma.f64 y x x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (fma.f64 x (fma.f64 x y x) (pow.f64 (*.f64 x y) 2)))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) -1)) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 -1 (pow.f64 y 3))) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 (neg.f64 x) (neg.f64 x))) (-.f64 (*.f64 y x) (neg.f64 x)))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (fma.f64 x y x))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 (neg.f64 x) 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y x) (neg.f64 x)))))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (fma.f64 y x x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (fma.f64 x (fma.f64 x y x) (pow.f64 (*.f64 x y) 2)))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) -1)) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 -1 (pow.f64 y 3))) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x x))) (neg.f64 (fma.f64 y x x)))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (/.f64 1 (fma.f64 y x x)))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x x)) (fma.f64 x y x))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 x 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 x (fma.f64 y x x)))))
(*.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (fma.f64 y x x)))))
(/.f64 (-.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 x 3)) (fma.f64 x (fma.f64 x y x) (pow.f64 (*.f64 x y) 2)))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) -1)) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(/.f64 (*.f64 (pow.f64 x 3) (+.f64 -1 (pow.f64 y 3))) (fma.f64 x x (*.f64 y (*.f64 x (fma.f64 x y x)))))
(pow.f64 (-.f64 (*.f64 y x) x) 1)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(pow.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) 2)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 3)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(pow.f64 (pow.f64 (-.f64 (*.f64 y x) x) 3) 1/3)
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(sqrt.f64 (pow.f64 (-.f64 (*.f64 y x) x) 2))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(log.f64 (exp.f64 (-.f64 (*.f64 y x) x)))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(cbrt.f64 (pow.f64 (-.f64 (*.f64 y x) x) 3))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(expm1.f64 (log1p.f64 (-.f64 (*.f64 y x) x)))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(exp.f64 (log.f64 (-.f64 (*.f64 y x) x)))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(exp.f64 (*.f64 (log.f64 (-.f64 (*.f64 y x) x)) 1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(log1p.f64 (expm1.f64 (-.f64 (*.f64 y x) x)))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(fma.f64 y x (neg.f64 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(fma.f64 x y (neg.f64 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(fma.f64 1 (*.f64 y x) (neg.f64 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) (neg.f64 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) (neg.f64 x))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))

eval13.0ms (0.6%)

Compiler

Compiled 874 to 384 computations (56.1% saved)

prune23.0ms (1%)

Pruning

7 alts after pruning (2 fresh and 5 done)

PrunedKeptTotal
New82183
Fresh011
Picked011
Done044
Total82789
Error
0b
Counts
89 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(-.f64 (*.f64 (+.f64 x 1) y) x)
24.9b
(-.f64 (*.f64 y x) x)
24.9b
(*.f64 (-.f64 y 1) x)
28.9b
(*.f64 (+.f64 1 x) y)
52.8b
(*.f64 y x)
34.5b
(neg.f64 x)
38.9b
y
Compiler

Compiled 42 to 28 computations (33.3% saved)

localize3.0ms (0.1%)

Compiler

Compiled 7 to 3 computations (57.1% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune2.0ms (0.1%)

Pruning

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New000
Fresh011
Picked011
Done055
Total077
Error
0b
Counts
7 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(-.f64 (*.f64 (+.f64 x 1) y) x)
24.9b
(-.f64 (*.f64 y x) x)
24.9b
(*.f64 (-.f64 y 1) x)
28.9b
(*.f64 (+.f64 1 x) y)
52.8b
(*.f64 y x)
34.5b
(neg.f64 x)
38.9b
y
Compiler

Compiled 42 to 28 computations (33.3% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune4.0ms (0.2%)

Pruning

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done066
Total077
Error
0b
Counts
7 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(-.f64 (*.f64 (+.f64 x 1) y) x)
24.9b
(-.f64 (*.f64 y x) x)
24.9b
(*.f64 (-.f64 y 1) x)
28.9b
(*.f64 (+.f64 1 x) y)
52.8b
(*.f64 y x)
34.5b
(neg.f64 x)
38.9b
y
Compiler

Compiled 42 to 28 computations (33.3% saved)

regimes17.0ms (0.8%)

Counts
8 → 1
Calls
Call 1
Inputs
y
(neg.f64 x)
(*.f64 y x)
(*.f64 (+.f64 1 x) y)
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 y x) x)
(-.f64 (*.f64 (+.f64 x 1) y) x)
(fma.f64 x y (-.f64 y x))
Outputs
(fma.f64 x y (-.f64 y x))
Calls

3 calls:

6.0ms
x
5.0ms
y
5.0ms
(-.f64 (*.f64 (+.f64 x 1) y) x)
Results
ErrorSegmentsBranch
0b1x
0b1y
0b1(-.f64 (*.f64 (+.f64 x 1) y) x)
Compiler

Compiled 51 to 27 computations (47.1% saved)

regimes16.0ms (0.7%)

Counts
7 → 1
Calls
Call 1
Inputs
y
(neg.f64 x)
(*.f64 y x)
(*.f64 (+.f64 1 x) y)
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 y x) x)
(-.f64 (*.f64 (+.f64 x 1) y) x)
Outputs
(-.f64 (*.f64 (+.f64 x 1) y) x)
Calls

3 calls:

5.0ms
x
5.0ms
(-.f64 (*.f64 (+.f64 x 1) y) x)
5.0ms
y
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1(-.f64 (*.f64 (+.f64 x 1) y) x)
Compiler

Compiled 45 to 25 computations (44.4% saved)

regimes40.0ms (1.8%)

Counts
6 → 3
Calls
Call 1
Inputs
y
(neg.f64 x)
(*.f64 y x)
(*.f64 (+.f64 1 x) y)
(*.f64 (-.f64 y 1) x)
(-.f64 (*.f64 y x) x)
Outputs
(*.f64 (+.f64 1 x) y)
(neg.f64 x)
(*.f64 (+.f64 1 x) y)
Calls

2 calls:

22.0ms
x
17.0ms
y
Results
ErrorSegmentsBranch
8.5b5x
8.2b3y
Compiler

Compiled 29 to 15 computations (48.3% saved)

bsearch51.0ms (2.3%)

Algorithm
binary-search
Steps
TimeLeftRight
15.0ms
5.6550388756738124e-42
2.689050511619898e-31
36.0ms
-2.5936960726322135e-35
-9.931993369813188e-47
Results
47.0ms320×body256valid
Compiler

Compiled 274 to 210 computations (23.4% saved)

regimes111.0ms (5%)

Counts
3 → 11
Calls
Call 1
Inputs
y
(neg.f64 x)
(*.f64 y x)
Outputs
(neg.f64 x)
(*.f64 y x)
(neg.f64 x)
(*.f64 y x)
(neg.f64 x)
y
(neg.f64 x)
y
(neg.f64 x)
(*.f64 y x)
(neg.f64 x)
Calls

2 calls:

66.0ms
x
44.0ms
y
Results
ErrorSegmentsBranch
14.3b11x
16.4b5y
Compiler

Compiled 14 to 8 computations (42.9% saved)

bsearch138.0ms (6.3%)

Algorithm
10×binary-search
Steps
TimeLeftRight
11.0ms
8.05826855490559e+89
9.914559356580725e+91
11.0ms
5.2250945584540805e+20
1.2838141069730987e+23
18.0ms
1.9958919243919797e-43
1.9630429299707828e-39
7.0ms
3.4413578247350237e-81
1.0963758825739425e-80
12.0ms
1.377678345857592e-141
1.2559327827451914e-137
7.0ms
-2.8865303101785604e-69
-1.0299462976098421e-69
33.0ms
-5.431594855404919e+43
-6.1329563934501155e+41
18.0ms
-6.254027567400718e+85
-1.88082540978811e+63
9.0ms
-8.666707214187892e+185
-3.4866306531335e+185
11.0ms
-5.690080118400626e+206
-3.865770615440326e+205
Results
119.0ms1104×body256valid
7.0ms83×body256infinite
Compiler

Compiled 721 to 536 computations (25.7% saved)

regimes52.0ms (2.4%)

Accuracy

Total -43.9b remaining (-244.4%)

Threshold costs -43.9b (-244.4%)

Counts
2 → 5
Calls
Call 1
Inputs
y
(neg.f64 x)
Outputs
(neg.f64 x)
y
(neg.f64 x)
y
(neg.f64 x)
Calls

2 calls:

38.0ms
y
14.0ms
x
Results
ErrorSegmentsBranch
18.0b5x
18.1b3y
Compiler

Compiled 11 to 7 computations (36.4% saved)

bsearch72.0ms (3.2%)

Algorithm
binary-search
Steps
TimeLeftRight
12.0ms
1.9958919243919797e-43
1.9630429299707828e-39
7.0ms
3.4413578247350237e-81
1.0963758825739425e-80
44.0ms
1.377678345857592e-141
1.2559327827451914e-137
7.0ms
-2.8865303101785604e-69
-1.0299462976098421e-69
Results
35.0ms416×body256valid
Compiler

Compiled 248 to 192 computations (22.6% saved)

simplify14.0ms (0.6%)

Algorithm
egg-herbie
Rules
10×if-if-or-not
not-or
+-commutative
sub-neg
not-not
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
067274
189274
296274
3103274
4107274
5111274
6112274
7113274
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(fma.f64 x y (-.f64 y x))
(-.f64 (*.f64 (+.f64 x 1) y) x)
(if (<=.f64 y -221493496140773/11972621413014756705924586149611790497021399392059392) (*.f64 (+.f64 1 x) y) (if (<=.f64 y 8418249431026001/374144419156711147060143317175368453031918731001856) (neg.f64 x) (*.f64 (+.f64 1 x) y)))
(if (<=.f64 x -38999999999999998308883465226841135713913741967111447384826634823855903584365370589673334643471016154087374064130307714269862619516113008717071655999190044216826998212738756867697162355424525998514757435392) (neg.f64 x) (if (<=.f64 x -850000000000000012866186942012988713373496681992966531592857064445354613577377345495739028331027404005825936104155276632797983541036682420455737602330408260305136538162248991225405243392) (*.f64 y x) (if (<=.f64 x -370000000000000010984497586449062645819856882726414928189500277660063891456) (neg.f64 x) (if (<=.f64 x -29000000000000001765913182396219189868101632) (*.f64 y x) (if (<=.f64 x -6605074233567479/3885337784451458141838923813647037813284813678104279042503624819477808570410416996352) (neg.f64 x) (if (<=.f64 x 5237424972633827/418993997810706159361688281193932691483730181893512293053861295116305125939798343025058571817715732115313495568327689089179808837873330310826051531440128) y (if (<=.f64 x 2269486225665967/266998379490113760299377713271194014325338065294581596243380200977777465722580068752870260867072) (neg.f64 x) (if (<=.f64 x 6129982163463555/12259964326927110866866776217202473468949912977468817408) y (if (<=.f64 x 31000000000000002097152) (neg.f64 x) (if (<=.f64 x 1499999999999999893187063000287551528072259115156795747990027195943962973264670404665933824) (*.f64 y x) (neg.f64 x)))))))))))
(if (<=.f64 x -8353476236570635/3885337784451458141838923813647037813284813678104279042503624819477808570410416996352) (neg.f64 x) (if (<=.f64 x 6703903964971299/1675975991242824637446753124775730765934920727574049172215445180465220503759193372100234287270862928461253982273310756356719235351493321243304206125760512) y (if (<=.f64 x 4485572775433911/1067993517960455041197510853084776057301352261178326384973520803911109862890320275011481043468288) (neg.f64 x) (if (<=.f64 x 7846377169233351/1569275433846670190958947355801916604025588861116008628224) y (neg.f64 x)))))
y
Outputs
(fma.f64 x y (-.f64 y x))
(-.f64 (*.f64 (+.f64 x 1) y) x)
(-.f64 (*.f64 y (+.f64 x 1)) x)
(if (<=.f64 y -221493496140773/11972621413014756705924586149611790497021399392059392) (*.f64 (+.f64 1 x) y) (if (<=.f64 y 8418249431026001/374144419156711147060143317175368453031918731001856) (neg.f64 x) (*.f64 (+.f64 1 x) y)))
(if (or (<=.f64 y -221493496140773/11972621413014756705924586149611790497021399392059392) (not (<=.f64 y 8418249431026001/374144419156711147060143317175368453031918731001856))) (*.f64 y (+.f64 x 1)) (neg.f64 x))
(if (<=.f64 x -38999999999999998308883465226841135713913741967111447384826634823855903584365370589673334643471016154087374064130307714269862619516113008717071655999190044216826998212738756867697162355424525998514757435392) (neg.f64 x) (if (<=.f64 x -850000000000000012866186942012988713373496681992966531592857064445354613577377345495739028331027404005825936104155276632797983541036682420455737602330408260305136538162248991225405243392) (*.f64 y x) (if (<=.f64 x -370000000000000010984497586449062645819856882726414928189500277660063891456) (neg.f64 x) (if (<=.f64 x -29000000000000001765913182396219189868101632) (*.f64 y x) (if (<=.f64 x -6605074233567479/3885337784451458141838923813647037813284813678104279042503624819477808570410416996352) (neg.f64 x) (if (<=.f64 x 5237424972633827/418993997810706159361688281193932691483730181893512293053861295116305125939798343025058571817715732115313495568327689089179808837873330310826051531440128) y (if (<=.f64 x 2269486225665967/266998379490113760299377713271194014325338065294581596243380200977777465722580068752870260867072) (neg.f64 x) (if (<=.f64 x 6129982163463555/12259964326927110866866776217202473468949912977468817408) y (if (<=.f64 x 31000000000000002097152) (neg.f64 x) (if (<=.f64 x 1499999999999999893187063000287551528072259115156795747990027195943962973264670404665933824) (*.f64 y x) (neg.f64 x)))))))))))
(if (<=.f64 x -38999999999999998308883465226841135713913741967111447384826634823855903584365370589673334643471016154087374064130307714269862619516113008717071655999190044216826998212738756867697162355424525998514757435392) (neg.f64 x) (if (<=.f64 x -850000000000000012866186942012988713373496681992966531592857064445354613577377345495739028331027404005825936104155276632797983541036682420455737602330408260305136538162248991225405243392) (*.f64 x y) (if (<=.f64 x -370000000000000010984497586449062645819856882726414928189500277660063891456) (neg.f64 x) (if (<=.f64 x -29000000000000001765913182396219189868101632) (*.f64 x y) (if (<=.f64 x -6605074233567479/3885337784451458141838923813647037813284813678104279042503624819477808570410416996352) (neg.f64 x) (if (<=.f64 x 5237424972633827/418993997810706159361688281193932691483730181893512293053861295116305125939798343025058571817715732115313495568327689089179808837873330310826051531440128) y (if (<=.f64 x 2269486225665967/266998379490113760299377713271194014325338065294581596243380200977777465722580068752870260867072) (neg.f64 x) (if (<=.f64 x 6129982163463555/12259964326927110866866776217202473468949912977468817408) y (if (<=.f64 x 31000000000000002097152) (neg.f64 x) (if (<=.f64 x 1499999999999999893187063000287551528072259115156795747990027195943962973264670404665933824) (*.f64 x y) (neg.f64 x)))))))))))
(if (<=.f64 x -8353476236570635/3885337784451458141838923813647037813284813678104279042503624819477808570410416996352) (neg.f64 x) (if (<=.f64 x 6703903964971299/1675975991242824637446753124775730765934920727574049172215445180465220503759193372100234287270862928461253982273310756356719235351493321243304206125760512) y (if (<=.f64 x 4485572775433911/1067993517960455041197510853084776057301352261178326384973520803911109862890320275011481043468288) (neg.f64 x) (if (<=.f64 x 7846377169233351/1569275433846670190958947355801916604025588861116008628224) y (neg.f64 x)))))
y
Compiler

Compiled 129 to 74 computations (42.6% saved)

soundness144.0ms (6.5%)

Algorithm
egg-herbie
Rules
520×fma-def
306×associate-+l+
298×associate--r+
272×associate-+l-
232×associate-+r+
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0819
11719
23015
36815
413615
530015
660315
7130415
8183915
9189015
10189915
Stop Event
saturated
Compiler

Compiled 132 to 69 computations (47.7% saved)

end72.0ms (3.3%)

Compiler

Compiled 119 to 62 computations (47.9% saved)

Profiling

Loading profile data...