Details

Time bar (total: 4.4s)

analyze84.0ms (1.9%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
25%74.9%0.1%5
37.5%62.4%0.1%6
50%46.8%3.2%7
59.3%35.9%4.8%8
67.1%25.8%7.1%9
72.6%19.1%8.3%10
76.9%13.5%9.7%11
79.8%9.9%10.3%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample1.4s (32.6%)

Results
1.4s8256×body256valid
33.0ms228×body256invalid

preprocess115.0ms (2.6%)

Algorithm
egg-herbie
Rules
650×fma-def_binary64
317×fma-neg_binary64
120×cancel-sign-sub-inv_binary64
74×distribute-rgt-in_binary64
62×associate--r+_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12220
24516
312316
426516
554616
6109316
7180816
8198016
9199816
10199816
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)
(-.f64 (*.f64 x (+.f64 1 y)) 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)

simplify115.0ms (2.6%)

Algorithm
egg-herbie
Rules
406×fma-def_binary64
257×fma-neg_binary64
73×cancel-sign-sub-inv_binary64
42×distribute-rgt-in_binary64
37×associate--r+_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0710
11410
2278
3668
41328
52618
64908
79218
812508
912998
1013088
Stop Event
saturated
Counts
1 → 2
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)

eval1.0ms (0%)

Compiler

Compiled 15 to 8 computations (46.7% saved)

prune2.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 17 to 10 computations (41.2% saved)

localize20.0ms (0.4%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series10.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

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

rewrite102.0ms (2.3%)

Algorithm
batch-egg-rewrite
Rules
840×pow1_binary64
781×log1p-expm1-u_binary64
781×expm1-log1p-u_binary64
780×add-log-exp_binary64
765×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0717
115317
2211217
Stop Event
node limit
Counts
2 → 56
Calls
Call 1
Inputs
(*.f64 (+.f64 x 1) y)
(-.f64 (*.f64 (+.f64 x 1) y) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 y (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 y (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x y) y)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y x) y)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (+.f64 y (*.f64 x y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 x 3)) y) (fma.f64 x x (-.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 x x -1) y) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (+.f64 1 (pow.f64 x 3))) (fma.f64 x x (-.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (fma.f64 x x -1)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 y (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 y (*.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 y (*.f64 x y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 y (*.f64 x y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 y (*.f64 x y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 y (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 y (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log1p.f64 x) (log.f64 y)))))))
((#(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 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) 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 (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 (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 (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 (-.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 (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 (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 (+.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 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 (-.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 x x)) (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 /.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 (+.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 (-.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 pow.f64 (-.f64 (+.f64 y (*.f64 x y)) x) 1)))) (#(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 pow.f64 (cbrt.f64 (-.f64 (+.f64 y (*.f64 x y)) x)) 3)))) (#(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 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 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 log1p.f64 (expm1.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 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 (pow.f64 (cbrt.f64 (+.f64 y (*.f64 x y))) 2) (cbrt.f64 (+.f64 y (*.f64 x y))) (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))))))

simplify53.0ms (1.2%)

Algorithm
egg-herbie
Rules
290×fma-def_binary64
221×fma-neg_binary64
69×cancel-sign-sub-inv_binary64
37×distribute-rgt-in_binary64
35×unsub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
020286
144286
290286
3193286
4422286
5841286
61116286
71145286
81148286
Stop Event
saturated
Counts
104 → 69
Calls
Call 1
Inputs
y
(+.f64 (*.f64 y x) y)
(+.f64 (*.f64 y x) y)
(+.f64 (*.f64 y x) y)
(*.f64 y x)
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(*.f64 y x)
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
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))
Outputs
y
(+.f64 (*.f64 y x) y)
(fma.f64 y x y)
(+.f64 (*.f64 y x) y)
(fma.f64 y x y)
(+.f64 (*.f64 y x) y)
(fma.f64 y x y)
(*.f64 y x)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(*.f64 y x)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
y
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 y x) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 y x) x)
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 y x y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 x (+.f64 y -1) y)
(-.f64 (fma.f64 y x y) x)
(fma.f64 y x (-.f64 y x))

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 14 to 4 computations (71.4% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite68.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
651×pow1_binary64
606×add-log-exp_binary64
606×log1p-expm1-u_binary64
606×expm1-log1p-u_binary64
592×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify34.0ms (0.8%)

Algorithm
egg-herbie
Rules
185×fma-neg_binary64
182×fma-def_binary64
44×unsub-neg_binary64
43×distribute-rgt-in_binary64
40×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
021176
154176
2132172
3350172
4668172
5931172
61004172
71008172
Stop Event
saturated
Counts
61 → 51
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 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(+.f64 (*.f64 -1 x) (*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y)))
(+.f64 (*.f64 -1 x) (*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y)))
(+.f64 (*.f64 -1 x) (*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y)))
Outputs
y
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(*.f64 (-.f64 y 1) x)
(*.f64 (+.f64 y -1) x)
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (-.f64 y 1) x) y)
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 (+.f64 y -1) x)
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 y (*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(*.f64 (+.f64 1 x) y)
(*.f64 y (+.f64 1 x))
(fma.f64 y x y)
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 (+.f64 1 x) y) (*.f64 -1 x))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 y (+.f64 1 x))
(fma.f64 y x y)
(+.f64 (*.f64 -1 x) (*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 -1 x) (*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))
(+.f64 (*.f64 -1 x) (*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y)))
(fma.f64 (+.f64 y -1) x y)
(fma.f64 y x (-.f64 y x))

eval54.0ms (1.2%)

Compiler

Compiled 1446 to 513 computations (64.5% saved)

prune51.0ms (1.1%)

Pruning

7 alts after pruning (7 fresh and 0 done)

PrunedKeptTotal
New1137120
Fresh000
Picked101
Done101
Total1157122
Error
0b
Counts
122 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
27.5b
(*.f64 (+.f64 1 x) y)
11.6b
(-.f64 y x)
0b
(fma.f64 y x (-.f64 y x))
38.8b
y
24.5b
(-.f64 (*.f64 y x) x)
0.0b
(-.f64 (+.f64 (*.f64 y x) y) x)
35.2b
(neg.f64 x)
Compiler

Compiled 83 to 50 computations (39.8% saved)

localize5.0ms (0.1%)

Compiler

Compiled 13 to 4 computations (69.2% saved)

localize3.0ms (0.1%)

Compiler

Compiled 5 to 3 computations (40% saved)

localize3.0ms (0.1%)

Compiler

Compiled 7 to 3 computations (57.1% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 13 to 8 computations (38.5% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

6 calls:

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

rewrite99.0ms (2.3%)

Algorithm
batch-egg-rewrite
Rules
604×pow1_binary64
560×add-log-exp_binary64
560×log1p-expm1-u_binary64
560×expm1-log1p-u_binary64
549×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify10.0ms (0.2%)

Algorithm
egg-herbie
Rules
14×fma-def_binary64
associate-*r*_binary64
associate-*l*_binary64
*-lft-identity_binary64
*-rgt-identity_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0654
1854
21254
31654
42254
52854
64154
74554
84754
Stop Event
saturated
Counts
31 → 22
Calls
Call 1
Inputs
y
(+.f64 (*.f64 y x) y)
(+.f64 (*.f64 y x) y)
(+.f64 (*.f64 y x) y)
(*.f64 y x)
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(*.f64 y x)
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
Outputs
y
(+.f64 (*.f64 y x) y)
(fma.f64 y x y)
(+.f64 (*.f64 y x) y)
(fma.f64 y x y)
(+.f64 (*.f64 y x) y)
(fma.f64 y x y)
(*.f64 y x)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(*.f64 y x)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)
(+.f64 y (*.f64 y x))
(fma.f64 y x y)

localize5.0ms (0.1%)

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)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite110.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
628×pow1_binary64
584×add-log-exp_binary64
584×log1p-expm1-u_binary64
584×expm1-log1p-u_binary64
571×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
11117
215727
Stop Event
node limit
Counts
1 → 38
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 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) 2) 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 (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 (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 (sqrt.f64 (-.f64 (*.f64 y x) x)) (sqrt.f64 (-.f64 (*.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 (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 (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 (+.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 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 (-.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 x x)) (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 /.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 (+.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 (-.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 pow.f64 (-.f64 (*.f64 y x) x) 1)))) (#(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 pow.f64 (cbrt.f64 (-.f64 (*.f64 y x) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 (*.f64 y x) x)) 2)))) (#(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 log1p.f64 (expm1.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 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 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.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))))))

simplify24.0ms (0.5%)

Algorithm
egg-herbie
Rules
85×fma-def_binary64
53×fma-neg_binary64
21×associate-*l*_binary64
17×cancel-sign-sub-inv_binary64
17×unsub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014158
132158
266158
3136158
4278158
5390158
6448158
7452158
Stop Event
saturated
Counts
62 → 46
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))
Outputs
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 y x)
(*.f64 x y)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 y x)
(*.f64 x y)
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(+.f64 (*.f64 y x) (*.f64 -1 x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 (-.f64 y 1) x)
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 y)) x))
(*.f64 x (+.f64 y -1))
(-.f64 (*.f64 x y) x)
(*.f64 x (+.f64 -1 y))

eval14.0ms (0.3%)

Compiler

Compiled 659 to 248 computations (62.4% saved)

prune20.0ms (0.5%)

Pruning

8 alts after pruning (4 fresh and 4 done)

PrunedKeptTotal
New64468
Fresh202
Picked011
Done134
Total67875
Error
0b
Counts
75 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
27.5b
(*.f64 (+.f64 1 x) y)
11.6b
(-.f64 y x)
51.6b
(*.f64 y x)
27.5b
(+.f64 (*.f64 y x) y)
24.5b
(-.f64 (*.f64 y x) x)
38.8b
y
24.5b
(fma.f64 y x (neg.f64 x))
35.2b
(neg.f64 x)
Compiler

Compiled 45 to 28 computations (37.8% saved)

localize4.0ms (0.1%)

Compiler

Compiled 7 to 3 computations (57.1% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 12 to 4 computations (66.7% saved)

series2.0ms (0.1%)

Counts
1 → 21
Calls

6 calls:

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

rewrite57.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
618×pow1_binary64
575×add-log-exp_binary64
575×log1p-expm1-u_binary64
575×expm1-log1p-u_binary64
562×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify24.0ms (0.5%)

Algorithm
egg-herbie
Rules
68×fma-def_binary64
53×fma-neg_binary64
20×unsub-neg_binary64
16×distribute-lft-in_binary64
16×distribute-rgt-in_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013135
12999
26299
313999
423899
533699
639699
Stop Event
saturated
Counts
59 → 44
Calls
Call 1
Inputs
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 (+.f64 1 x) y)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
y
(*.f64 y x)
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(*.f64 y x)
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
(+.f64 y (*.f64 y x))
Outputs
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 x) 1) y))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
y
(*.f64 y x)
(*.f64 x y)
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(*.f64 y x)
(*.f64 x y)
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)
(+.f64 y (*.f64 y x))
(*.f64 (+.f64 1 x) y)
(fma.f64 x y y)

localize6.0ms (0.1%)

Compiler

Compiled 11 to 4 computations (63.6% saved)

eval9.0ms (0.2%)

Compiler

Compiled 451 to 171 computations (62.1% saved)

prune10.0ms (0.2%)

Pruning

8 alts after pruning (1 fresh and 7 done)

PrunedKeptTotal
New43144
Fresh101
Picked011
Done066
Total44852
Error
0b
Counts
52 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
27.5b
(*.f64 (+.f64 1 x) y)
11.6b
(-.f64 y x)
51.6b
(*.f64 y x)
38.8b
y
27.5b
(+.f64 (*.f64 y x) y)
24.5b
(-.f64 (*.f64 y x) x)
24.5b
(fma.f64 y x (neg.f64 x))
35.2b
(neg.f64 x)
Compiler

Compiled 45 to 28 computations (37.8% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune3.0ms (0.1%)

Pruning

8 alts after pruning (1 fresh and 7 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done077
Total088
Error
0b
Counts
8 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
27.5b
(*.f64 (+.f64 1 x) y)
11.6b
(-.f64 y x)
51.6b
(*.f64 y x)
38.8b
y
27.5b
(+.f64 (*.f64 y x) y)
24.5b
(-.f64 (*.f64 y x) x)
24.5b
(fma.f64 y x (neg.f64 x))
35.2b
(neg.f64 x)
Compiler

Compiled 45 to 28 computations (37.8% saved)

regimes32.0ms (0.7%)

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

3 calls:

11.0ms
(-.f64 (*.f64 (+.f64 x 1) y) x)
10.0ms
y
8.0ms
x
Results
ErrorSegmentsBranch
0b1x
0b1y
0b1(-.f64 (*.f64 (+.f64 x 1) y) x)
Compiler

Compiled 74 to 29 computations (60.8% saved)

regimes46.0ms (1%)

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

3 calls:

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

Compiled 62 to 26 computations (58.1% saved)

regimes63.0ms (1.4%)

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

2 calls:

44.0ms
y
17.0ms
x
Results
ErrorSegmentsBranch
1.0b3x
0.7b3y
Compiler

Compiled 34 to 14 computations (58.8% saved)

bsearch41.0ms (0.9%)

Algorithm
binary-search
Steps
TimeLeftRight
25.0ms
0.18327023206112672
0.847000604379472
16.0ms
-3579.0988771741213
-2814.2471217956813
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes57.0ms (1.3%)

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

2 calls:

29.0ms
x
27.0ms
y
Results
ErrorSegmentsBranch
10.2b3x
9.2b5y
Compiler

Compiled 19 to 9 computations (52.6% saved)

bsearch326.0ms (7.4%)

Algorithm
binary-search
Steps
TimeLeftRight
235.0ms
3.8120113252603477e+83
3.9131818116214745e+85
56.0ms
2.342093802916112e+36
3.1207936163784135e+39
18.0ms
-9034363349901394.0
-1803258792196531.0
17.0ms
-1.1065249413986918e+21
-4.884498761776704e+19
Compiler

Compiled 84 to 59 computations (29.8% saved)

regimes145.0ms (3.3%)

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

2 calls:

110.0ms
y
29.0ms
x
Results
ErrorSegmentsBranch
19.7b3x
13.5b7y
Compiler

Compiled 16 to 8 computations (50% saved)

bsearch679.0ms (15.4%)

Algorithm
binary-search
Steps
TimeLeftRight
269.0ms
3.8120113252603477e+83
3.9131818116214745e+85
31.0ms
2.342093802916112e+36
3.1207936163784135e+39
53.0ms
2.6843551990494734e-28
3.77527973267057e-22
31.0ms
-1.0119576914670136e-13
-3.488665238929869e-14
29.0ms
-9034363349901394.0
-1803258792196531.0
266.0ms
-1.0284373605386679e+83
-1.0021122752828545e+79
Compiler

Compiled 164 to 115 computations (29.9% saved)

regimes58.0ms (1.3%)

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

2 calls:

30.0ms
y
26.0ms
x
Results
ErrorSegmentsBranch
19.7b3x
16.0b3y
Compiler

Compiled 13 to 7 computations (46.2% saved)

bsearch64.0ms (1.5%)

Algorithm
binary-search
Steps
TimeLeftRight
28.0ms
2.6843551990494734e-28
3.77527973267057e-22
33.0ms
-1.0119576914670136e-13
-3.488665238929869e-14
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes19.0ms (0.4%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0.0b (-0%)

Counts
3 → 1
Calls
Call 1
Inputs
y
y
y
Outputs
y
Calls

2 calls:

9.0ms
y
8.0ms
x
Results
ErrorSegmentsBranch
38.8b1x
38.8b1y
Compiler

Compiled 11 to 6 computations (45.5% saved)

simplify19.0ms (0.4%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
sub-neg_binary64
*-commutative_binary64
neg-sub0_binary64
neg-mul-1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
041158
149158
253158
354158
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(fma.f64 y x (-.f64 y x))
(-.f64 (+.f64 (*.f64 y x) y) x)
(if (<=.f64 y -983815208103243/274877906944) (+.f64 (*.f64 y x) y) (if (<=.f64 y 3380739067160963584/18446744073709551616) (-.f64 y x) (+.f64 (*.f64 y x) y)))
(if (<=.f64 y -1106524941398691807232) (-.f64 y x) (if (<=.f64 y -9034363349901394) (*.f64 y x) (if (<=.f64 y 2342093802916111953539648837545623552) (-.f64 y x) (if (<=.f64 y 390000000000000016058590660149046163230450558682753651795321665251800414801734139904) (*.f64 y x) y))))
(if (<=.f64 y -10200000000000000621423919753026934057083457562046272401518147178481984028540928) y (if (<=.f64 y -9034363349901394) (*.f64 y x) (if (<=.f64 y -8017554843710832/79228162514264337593543950336) y (if (<=.f64 y 2993156065817663/11150372599265311570767859136324180752990208) (neg.f64 x) (if (<=.f64 y 2342093802916111953539648837545623552) y (if (<=.f64 y 390000000000000016058590660149046163230450558682753651795321665251800414801734139904) (*.f64 y x) y))))))
(if (<=.f64 y -8017554843710832/79228162514264337593543950336) y (if (<=.f64 y 2993156065817663/11150372599265311570767859136324180752990208) (neg.f64 x) y))
y
Outputs
(fma.f64 y x (-.f64 y x))
(-.f64 (+.f64 (*.f64 y x) y) x)
(-.f64 (+.f64 y (*.f64 y x)) x)
(if (<=.f64 y -983815208103243/274877906944) (+.f64 (*.f64 y x) y) (if (<=.f64 y 3380739067160963584/18446744073709551616) (-.f64 y x) (+.f64 (*.f64 y x) y)))
(if (<=.f64 y -983815208103243/274877906944) (+.f64 y (*.f64 y x)) (if (<=.f64 y 6603005990548757/36028797018963968) (-.f64 y x) (+.f64 y (*.f64 y x))))
(if (<=.f64 y -1106524941398691807232) (-.f64 y x) (if (<=.f64 y -9034363349901394) (*.f64 y x) (if (<=.f64 y 2342093802916111953539648837545623552) (-.f64 y x) (if (<=.f64 y 390000000000000016058590660149046163230450558682753651795321665251800414801734139904) (*.f64 y x) y))))
(if (<=.f64 y -10200000000000000621423919753026934057083457562046272401518147178481984028540928) y (if (<=.f64 y -9034363349901394) (*.f64 y x) (if (<=.f64 y -8017554843710832/79228162514264337593543950336) y (if (<=.f64 y 2993156065817663/11150372599265311570767859136324180752990208) (neg.f64 x) (if (<=.f64 y 2342093802916111953539648837545623552) y (if (<=.f64 y 390000000000000016058590660149046163230450558682753651795321665251800414801734139904) (*.f64 y x) y))))))
(if (<=.f64 y -10200000000000000621423919753026934057083457562046272401518147178481984028540928) y (if (<=.f64 y -9034363349901394) (*.f64 y x) (if (<=.f64 y -501097177731927/4951760157141521099596496896) y (if (<=.f64 y 2993156065817663/11150372599265311570767859136324180752990208) (neg.f64 x) (if (<=.f64 y 2342093802916111953539648837545623552) y (if (<=.f64 y 390000000000000016058590660149046163230450558682753651795321665251800414801734139904) (*.f64 y x) y))))))
(if (<=.f64 y -8017554843710832/79228162514264337593543950336) y (if (<=.f64 y 2993156065817663/11150372599265311570767859136324180752990208) (neg.f64 x) y))
(if (<=.f64 y -501097177731927/4951760157141521099596496896) y (if (<=.f64 y 2993156065817663/11150372599265311570767859136324180752990208) (neg.f64 x) y))
y
Compiler

Compiled 126 to 69 computations (45.2% saved)

soundness175.0ms (4%)

Algorithm
egg-herbie
Rules
406×fma-def_binary64
257×fma-neg_binary64
185×fma-neg_binary64
182×fma-def_binary64
73×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0710
11410
2278
3668
41328
52618
64908
79218
812508
912998
1013088
021176
154176
2132172
3350172
4668172
5931172
61004172
71008172
Stop Event
saturated
saturated
Compiler

Compiled 123 to 76 computations (38.2% saved)

end105.0ms (2.4%)

Compiler

Compiled 114 to 50 computations (56.1% saved)

Profiling

Loading profile data...