Details

Time bar (total: 6.5s)

analyze54.0ms (0.8%)

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
43.7%43.7%12.6%7
53.1%34.3%12.6%8
57.8%23.4%18.8%9
63.2%18%18.8%10
66%12.1%22%11
68.9%9.2%22%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample1.5s (22.2%)

Results
1.4s8256×body256valid
55.0ms363×body256invalid

preprocess214.0ms (3.3%)

Algorithm
egg-herbie
Rules
303×fma-neg_binary64
296×fma-def_binary64
157×distribute-rgt-in_binary64
98×distribute-lft-in_binary64
95×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12320
26620
315020
434520
549720
679520
7129120
8160920
9177920
10185120
11185120
12185120
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(*.f64 (*.f64 x y) (-.f64 1 y))
(*.f64 (*.f64 y x) (-.f64 1 x))
Outputs
(*.f64 (*.f64 x y) (-.f64 1 y))
(*.f64 (-.f64 1 y) (*.f64 x y))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (*.f64 y x) (-.f64 1 x))
(*.f64 y (*.f64 x (-.f64 1 x)))
(*.f64 x (*.f64 y (-.f64 1 x)))
(*.f64 x (fma.f64 y (neg.f64 x) y))
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify31.0ms (0.5%)

Algorithm
egg-herbie
Rules
601×fma-def_binary64
148×fma-neg_binary64
79×distribute-rgt-in_binary64
52×cancel-sign-sub-inv_binary64
49×distribute-lft-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11510
23810
38510
419410
529210
645110
769410
8132710
9140510
10144110
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 (*.f64 x y) (-.f64 1 y))
Outputs
(*.f64 (*.f64 x y) (-.f64 1 y))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 x (fma.f64 y (neg.f64 y) y))

eval1.0ms (0%)

Compiler

Compiled 16 to 9 computations (43.8% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 18 to 11 computations (38.9% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
6.4b
(*.f64 x (fma.f64 y (neg.f64 y) y))
Compiler

Compiled 18 to 5 computations (72.2% saved)

series5.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite47.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
503×pow1_binary64
482×add-sqr-sqrt_binary64
462×add-log-exp_binary64
461×log1p-expm1-u_binary64
461×expm1-log1p-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify70.0ms (1.1%)

Algorithm
egg-herbie
Rules
396×unsub-neg_binary64
387×distribute-rgt-out--_binary64
358×fma-neg_binary64
357×sub-neg_binary64
317×distribute-rgt-neg-in_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013253
130232
264232
3153232
4469232
51733232
64121232
76658232
Stop Event
node limit
Counts
37 → 19
Calls
Call 1
Inputs
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (neg.f64 (*.f64 y x)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (neg.f64 (*.f64 y x)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (fma.f64 -1 (*.f64 y y) y) x)
(*.f64 (-.f64 y (*.f64 y y)) x)
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y (-.f64 1 y)) x)

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 18 to 9 computations (50% saved)

series4.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite77.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
747×pow1_binary64
692×add-log-exp_binary64
692×log1p-expm1-u_binary64
692×expm1-log1p-u_binary64
678×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify89.0ms (1.4%)

Algorithm
egg-herbie
Rules
367×fma-neg_binary64
349×associate-*l*_binary64
306×distribute-rgt-neg-in_binary64
295×distribute-rgt-out--_binary64
295×neg-sub0_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014232
134232
283232
3189232
4590232
51939232
63937232
76091232
87890232
Stop Event
node limit
Counts
43 → 25
Calls
Call 1
Inputs
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 x (neg.f64 (*.f64 y y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 x (neg.f64 (*.f64 y y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))

eval8.0ms (0.1%)

Compiler

Compiled 409 to 197 computations (51.8% saved)

prune66.0ms (1%)

Pruning

11 alts after pruning (10 fresh and 1 done)

PrunedKeptTotal
New341044
Fresh000
Picked011
Done101
Total351146
Error
0.0b
Counts
46 → 11
Alt Table
Click to see full alt table
StatusErrorProgram
30.7b
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
22.1b
(*.f64 y x)
6.8b
(*.f64 (*.f64 y (-.f64 1 y)) x)
26.2b
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
0.1b
(+.f64 (*.f64 x y) (*.f64 (*.f64 x y) (neg.f64 y)))
37.6b
(*.f64 x (neg.f64 (*.f64 y y)))
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
30.9b
(*.f64 y (*.f64 y (neg.f64 x)))
13.1b
(/.f64 (*.f64 (-.f64 1 (pow.f64 y 3)) (*.f64 x y)) (+.f64 1 (fma.f64 y y y)))
0.1b
(*.f64 y (*.f64 (-.f64 1 y) x))
1.1b
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
Compiler

Compiled 219 to 146 computations (33.3% saved)

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 25 to 6 computations (76% saved)

series9.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite64.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
730×pow1_binary64
678×add-log-exp_binary64
677×log1p-expm1-u_binary64
677×expm1-log1p-u_binary64
663×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify100.0ms (1.5%)

Algorithm
egg-herbie
Rules
642×fma-neg_binary64
434×unsub-neg_binary64
343×distribute-rgt-out--_binary64
341×distribute-rgt-neg-in_binary64
327×sub-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
017469
147448
2118448
3302448
41063448
52685448
64641448
77119448
Stop Event
node limit
Counts
109 → 68
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) y) x)
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 x (+.f64 (pow.f64 y 2) (*.f64 -1 y))))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))

localize3.0ms (0%)

Compiler

Compiled 7 to 3 computations (57.1% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 y (*.f64 y (neg.f64 x)))
Compiler

Compiled 16 to 5 computations (68.8% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite223.0ms (3.4%)

Algorithm
batch-egg-rewrite
Rules
505×pow1_binary64
482×add-sqr-sqrt_binary64
464×add-log-exp_binary64
463×log1p-expm1-u_binary64
463×expm1-log1p-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify106.0ms (1.6%)

Algorithm
egg-herbie
Rules
572×fma-neg_binary64
566×distribute-lft-neg-in_binary64
557×distribute-rgt-neg-in_binary64
507×fma-def_binary64
366×sub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
08216
118216
243216
3100216
4267216
5882216
61467216
72632216
83726216
94571216
105180216
115952216
127098216
Stop Event
node limit
Counts
36 → 14
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))

localize9.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series3.0ms (0%)

Counts
2 → 36
Calls

9 calls:

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

rewrite59.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
745×pow1_binary64
690×add-log-exp_binary64
690×log1p-expm1-u_binary64
690×expm1-log1p-u_binary64
676×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify69.0ms (1.1%)

Algorithm
egg-herbie
Rules
714×fma-neg_binary64
493×distribute-rgt-neg-in_binary64
380×unswap-sqr_binary64
380×unsub-neg_binary64
365×distribute-lft-neg-in_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
016380
139308
287308
3206308
4644308
51499308
62797308
75357308
Stop Event
node limit
Counts
68 → 43
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
y
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(*.f64 -1 (pow.f64 y 2))
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(*.f64 -1 (pow.f64 y 2))
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(*.f64 x (*.f64 y (neg.f64 y)))
(*.f64 y (*.f64 x (neg.f64 y)))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 y (neg.f64 (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(*.f64 x (*.f64 y (neg.f64 y)))
(*.f64 y (*.f64 x (neg.f64 y)))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 y (neg.f64 (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (*.f64 (neg.f64 (*.f64 y y)) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
y
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(*.f64 -1 (pow.f64 y 2))
(neg.f64 (*.f64 y y))
(*.f64 y (neg.f64 y))
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(*.f64 -1 (pow.f64 y 2))
(neg.f64 (*.f64 y y))
(*.f64 y (neg.f64 y))
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)
(+.f64 (*.f64 -1 (pow.f64 y 2)) y)
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(fma.f64 y (neg.f64 y) y)

localize147.0ms (2.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
0.6b
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
10.3b
(cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y)))
Compiler

Compiled 37 to 20 computations (45.9% saved)

series11.0ms (0.2%)

Counts
2 → 0
Calls

12 calls:

TimeVariablePointExpression
2.0ms
y
@-inf
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
1.0ms
x
@-inf
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
1.0ms
x
@0
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
1.0ms
x
@0
(cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y)))
1.0ms
y
@inf
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)

rewrite69.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
915×pow1_binary64
857×add-log-exp_binary64
856×log1p-expm1-u_binary64
856×expm1-log1p-u_binary64
838×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify7.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
000
Stop Event
saturated
Counts
68 → 68
Calls
Call 1
Inputs
Outputs

eval187.0ms (2.9%)

Compiler

Compiled 2742 to 1421 computations (48.2% saved)

prune75.0ms (1.1%)

Pruning

16 alts after pruning (11 fresh and 5 done)

PrunedKeptTotal
New2099218
Fresh325
Picked011
Done145
Total21316229
Error
0.0b
Counts
229 → 16
Alt Table
Click to see full alt table
StatusErrorProgram
30.9b
(*.f64 y (*.f64 y (neg.f64 x)))
41.4b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2) x)
6.8b
(-.f64 (*.f64 x y) (*.f64 x (*.f64 y y)))
1.1b
(*.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x (-.f64 1 y)))) 2) (cbrt.f64 (*.f64 x y))) (cbrt.f64 (-.f64 1 y)))
1.1b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
30.7b
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
22.1b
(*.f64 y x)
6.8b
(*.f64 (*.f64 y (-.f64 1 y)) x)
37.6b
(*.f64 (*.f64 y (neg.f64 y)) x)
26.2b
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
35.7b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y))))
30.4b
(*.f64 (*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y))) (sqrt.f64 (*.f64 x y)))
0.1b
(*.f64 (*.f64 (-.f64 1 y) x) y)
11.4b
(*.f64 (*.f64 (*.f64 x y) (sqrt.f64 (-.f64 1 y))) (sqrt.f64 (-.f64 1 y)))
1.1b
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
Compiler

Compiled 335 to 223 computations (33.4% saved)

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series51.0ms (0.8%)

Counts
1 → 24
Calls

6 calls:

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

rewrite48.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
746×pow1_binary64
691×add-log-exp_binary64
691×log1p-expm1-u_binary64
691×expm1-log1p-u_binary64
677×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify88.0ms (1.3%)

Algorithm
egg-herbie
Rules
367×fma-neg_binary64
354×associate-*l*_binary64
306×distribute-rgt-neg-in_binary64
298×distribute-rgt-out--_binary64
295×neg-sub0_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
014295
134274
283232
3189232
4591232
51954232
63959232
76114232
87932232
Stop Event
node limit
Counts
39 → 21
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (*.f64 x (neg.f64 y)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (*.f64 x (neg.f64 y)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (*.f64 y x) (-.f64 1 y))

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
11.2b
(*.f64 (*.f64 y (neg.f64 y)) x)
Compiler

Compiled 16 to 5 computations (68.8% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite44.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
477×pow1_binary64
456×add-sqr-sqrt_binary64
450×*-un-lft-identity_binary64
438×add-log-exp_binary64
437×log1p-expm1-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify103.0ms (1.6%)

Algorithm
egg-herbie
Rules
572×fma-neg_binary64
566×distribute-lft-neg-in_binary64
557×distribute-rgt-neg-in_binary64
507×fma-def_binary64
366×sub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
08216
118216
243216
3100216
4267216
5882216
61467216
72632216
83726216
94571216
105180216
115952216
127098216
Stop Event
node limit
Counts
36 → 14
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 (neg.f64 y) (*.f64 y x))
(*.f64 y (*.f64 y (neg.f64 x)))

localize16.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
0.3b
(pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3)
29.7b
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
Compiler

Compiled 38 to 21 computations (44.7% saved)

series13.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
4.0ms
y
@0
(pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3)
2.0ms
x
@-inf
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
2.0ms
x
@0
(pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3)
1.0ms
y
@-inf
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
1.0ms
x
@-inf
(pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3)

rewrite66.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
927×pow1_binary64
869×add-log-exp_binary64
868×log1p-expm1-u_binary64
868×expm1-log1p-u_binary64
848×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify84.0ms (1.3%)

Algorithm
egg-herbie
Rules
703×associate-*l*_binary64
629×fma-def_binary64
597×unswap-sqr_binary64
582×associate-*r*_binary64
415×distribute-rgt-neg-in_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
061882
1205869
2869805
34974785
Stop Event
node limit
Counts
117 → 97
Calls
Call 1
Inputs
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x))
(+.f64 (*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) x))) (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(+.f64 (*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) x))) (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(+.f64 (*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) x))) (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (pow.f64 x 3))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5))))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5)))))
(*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5)))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5))))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5)))))
(*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 5) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3))))) (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 5) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3))))) (+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3)))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 5) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3))))) (+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))))))
Outputs
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 (-.f64 1 y) x))))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x))
(*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1)))
(*.f64 y (*.f64 x (*.f64 y (cbrt.f64 -1))))
(*.f64 (cbrt.f64 -1) (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 y (*.f64 x (cbrt.f64 -1))))
(+.f64 (*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) x))) (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(+.f64 (*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) x))) (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(+.f64 (*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -1) x))) (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 y (*.f64 (*.f64 (-.f64 1 y) x) (cbrt.f64 -1))))
(neg.f64 (*.f64 (*.f64 x (*.f64 y (cbrt.f64 -1))) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (*.f64 (cbrt.f64 -1) (neg.f64 x))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (+.f64 -1 y))))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 y 3) (pow.f64 x 3))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(fma.f64 (pow.f64 y 3) (pow.f64 x 3) (*.f64 (pow.f64 x 3) (*.f64 -3 (pow.f64 y 4))))
(*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) (*.f64 (pow.f64 y 4) -3)))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 (pow.f64 y 3) (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 (pow.f64 y 3) (pow.f64 x 3) (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5)))))
(fma.f64 (pow.f64 y 3) (pow.f64 x 3) (*.f64 (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (pow.f64 y 5) (pow.f64 y 4))))
(fma.f64 (pow.f64 y 3) (pow.f64 x 3) (*.f64 (*.f64 (pow.f64 x 3) -3) (-.f64 (pow.f64 y 4) (pow.f64 y 5))))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5)))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 (pow.f64 y 3) (pow.f64 x 3) (fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5)))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (+.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) (neg.f64 (pow.f64 y 6))))))
(fma.f64 (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (pow.f64 y 5) (pow.f64 y 4)) (*.f64 (pow.f64 x 3) (-.f64 (pow.f64 y 3) (pow.f64 y 6))))
(fma.f64 (pow.f64 x 3) (-.f64 (pow.f64 y 3) (pow.f64 y 6)) (*.f64 (*.f64 (pow.f64 x 3) -3) (-.f64 (pow.f64 y 4) (pow.f64 y 5))))
(*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3)))
(neg.f64 (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (neg.f64 (pow.f64 y 6)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5)))
(fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5)))
(-.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (-.f64 (*.f64 3 (pow.f64 y 5)) (pow.f64 y 6)))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (-.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (pow.f64 y 6))))
(-.f64 (*.f64 (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (pow.f64 y 5) (pow.f64 y 4))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(-.f64 (*.f64 (*.f64 (pow.f64 x 3) -3) (-.f64 (pow.f64 y 4) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 5)))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 (pow.f64 y 3) (pow.f64 x 3) (fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5)))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (+.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) (neg.f64 (pow.f64 y 6))))))
(fma.f64 (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (pow.f64 y 5) (pow.f64 y 4)) (*.f64 (pow.f64 x 3) (-.f64 (pow.f64 y 3) (pow.f64 y 6))))
(fma.f64 (pow.f64 x 3) (-.f64 (pow.f64 y 3) (pow.f64 y 6)) (*.f64 (*.f64 (pow.f64 x 3) -3) (-.f64 (pow.f64 y 4) (pow.f64 y 5))))
(*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3)))
(neg.f64 (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (neg.f64 (pow.f64 y 6)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 5) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3))))) (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))))
(fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5)))
(-.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (-.f64 (*.f64 3 (pow.f64 y 5)) (pow.f64 y 6)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 5) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3))))) (+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3)))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (-.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (pow.f64 y 6))))
(-.f64 (*.f64 (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (pow.f64 y 5) (pow.f64 y 4))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(-.f64 (*.f64 (*.f64 (pow.f64 x 3) -3) (-.f64 (pow.f64 y 4) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y 5) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3))))) (+.f64 (*.f64 (pow.f64 y 4) (+.f64 (*.f64 -1 (pow.f64 x 3)) (*.f64 -2 (pow.f64 x 3)))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 -1 (*.f64 (pow.f64 y 6) (pow.f64 x 3))))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (fma.f64 (pow.f64 y 3) (pow.f64 x 3) (fma.f64 -1 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 5)))))
(fma.f64 (pow.f64 y 4) (*.f64 (pow.f64 x 3) -3) (+.f64 (*.f64 3 (*.f64 (pow.f64 x 3) (pow.f64 y 5))) (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 3) (neg.f64 (pow.f64 y 6))))))
(fma.f64 (*.f64 (pow.f64 x 3) -3) (fma.f64 -1 (pow.f64 y 5) (pow.f64 y 4)) (*.f64 (pow.f64 x 3) (-.f64 (pow.f64 y 3) (pow.f64 y 6))))
(fma.f64 (pow.f64 x 3) (-.f64 (pow.f64 y 3) (pow.f64 y 6)) (*.f64 (*.f64 (pow.f64 x 3) -3) (-.f64 (pow.f64 y 4) (pow.f64 y 5))))

localize16.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
0.2b
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
9.9b
(sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y)))
Compiler

Compiled 37 to 20 computations (45.9% saved)

series16.0ms (0.2%)

Counts
2 → 16
Calls

12 calls:

TimeVariablePointExpression
5.0ms
x
@-inf
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
1.0ms
x
@0
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
1.0ms
y
@0
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
1.0ms
x
@0
(sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y)))
1.0ms
x
@inf
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)

rewrite62.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
889×pow1_binary64
827×add-log-exp_binary64
826×log1p-expm1-u_binary64
826×expm1-log1p-u_binary64
809×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify78.0ms (1.2%)

Algorithm
egg-herbie
Rules
698×fma-def_binary64
692×fma-neg_binary64
436×associate-/l/_binary64
344×cancel-sign-sub-inv_binary64
286×distribute-rgt-out_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
088424
1277337
21086277
34537269
Stop Event
node limit
Counts
82 → 91
Calls
Call 1
Inputs
(*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))
(+.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (*.f64 1/2 (*.f64 (/.f64 1 (sqrt.f64 -1)) (sqrt.f64 x))))
(+.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (+.f64 (*.f64 -1/8 (*.f64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 3) y)) (sqrt.f64 x))) (*.f64 1/2 (*.f64 (/.f64 1 (sqrt.f64 -1)) (sqrt.f64 x)))))
(+.f64 (*.f64 1/16 (*.f64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 5) (pow.f64 y 2))) (sqrt.f64 x))) (+.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (+.f64 (*.f64 -1/8 (*.f64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 3) y)) (sqrt.f64 x))) (*.f64 1/2 (*.f64 (/.f64 1 (sqrt.f64 -1)) (sqrt.f64 x))))))
(*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x))) (*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x))) (+.f64 (*.f64 1/8 (*.f64 (/.f64 (sqrt.f64 -1) y) (sqrt.f64 x))) (*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)))))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x))) (+.f64 (*.f64 1/8 (*.f64 (/.f64 (sqrt.f64 -1) y) (sqrt.f64 x))) (+.f64 (*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))) (*.f64 1/16 (*.f64 (/.f64 (sqrt.f64 -1) (pow.f64 y 2)) (sqrt.f64 x))))))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (+.f64 (*.f64 -1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)) (*.f64 1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))))))
(+.f64 (*.f64 -1/8 (/.f64 x (*.f64 (pow.f64 (sqrt.f64 -1) 4) y))) (+.f64 (*.f64 y x) (+.f64 (*.f64 1/8 (/.f64 x (*.f64 (pow.f64 (sqrt.f64 -1) 4) y))) (+.f64 (*.f64 -1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)) (*.f64 1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))))))))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -1/8 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (*.f64 1/8 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x))) y)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))))))
Outputs
(*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 -1) (sqrt.f64 x)))
(+.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (*.f64 1/2 (*.f64 (/.f64 1 (sqrt.f64 -1)) (sqrt.f64 x))))
(fma.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x) (*.f64 1/2 (*.f64 (sqrt.f64 x) (/.f64 1 (sqrt.f64 -1)))))
(*.f64 (sqrt.f64 x) (+.f64 (/.f64 1/2 (sqrt.f64 -1)) (*.f64 (sqrt.f64 -1) y)))
(*.f64 (sqrt.f64 x) (fma.f64 (sqrt.f64 -1) y (/.f64 1/2 (sqrt.f64 -1))))
(+.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (+.f64 (*.f64 -1/8 (*.f64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 3) y)) (sqrt.f64 x))) (*.f64 1/2 (*.f64 (/.f64 1 (sqrt.f64 -1)) (sqrt.f64 x)))))
(fma.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x) (fma.f64 -1/8 (/.f64 (*.f64 1 (sqrt.f64 x)) (*.f64 y (pow.f64 (sqrt.f64 -1) 3))) (*.f64 1/2 (*.f64 (sqrt.f64 x) (/.f64 1 (sqrt.f64 -1))))))
(fma.f64 (sqrt.f64 -1) (*.f64 y (sqrt.f64 x)) (*.f64 (sqrt.f64 x) (+.f64 (/.f64 1/2 (sqrt.f64 -1)) (/.f64 -1/8 (neg.f64 (*.f64 (sqrt.f64 -1) y))))))
(*.f64 (sqrt.f64 x) (+.f64 (/.f64 1/2 (sqrt.f64 -1)) (fma.f64 (sqrt.f64 -1) y (/.f64 1/8 (*.f64 (sqrt.f64 -1) y)))))
(+.f64 (*.f64 1/16 (*.f64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 5) (pow.f64 y 2))) (sqrt.f64 x))) (+.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (+.f64 (*.f64 -1/8 (*.f64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 3) y)) (sqrt.f64 x))) (*.f64 1/2 (*.f64 (/.f64 1 (sqrt.f64 -1)) (sqrt.f64 x))))))
(fma.f64 1/16 (/.f64 (*.f64 1 (sqrt.f64 x)) (*.f64 (pow.f64 (sqrt.f64 -1) 5) (*.f64 y y))) (fma.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x) (fma.f64 -1/8 (/.f64 (*.f64 1 (sqrt.f64 x)) (*.f64 y (pow.f64 (sqrt.f64 -1) 3))) (*.f64 1/2 (*.f64 (sqrt.f64 x) (/.f64 1 (sqrt.f64 -1)))))))
(+.f64 (*.f64 (sqrt.f64 x) (+.f64 (/.f64 1/2 (sqrt.f64 -1)) (/.f64 -1/8 (neg.f64 (*.f64 (sqrt.f64 -1) y))))) (*.f64 (sqrt.f64 x) (+.f64 (/.f64 1/16 (*.f64 y (*.f64 y (pow.f64 (sqrt.f64 -1) 5)))) (*.f64 (sqrt.f64 -1) y))))
(*.f64 (sqrt.f64 x) (+.f64 (+.f64 (*.f64 (sqrt.f64 -1) y) (/.f64 (/.f64 1/16 y) (*.f64 y (pow.f64 (sqrt.f64 -1) 5)))) (+.f64 (/.f64 1/8 (*.f64 (sqrt.f64 -1) y)) (/.f64 1/2 (sqrt.f64 -1)))))
(+.f64 (*.f64 (sqrt.f64 x) (fma.f64 (sqrt.f64 -1) y (/.f64 1/2 (sqrt.f64 -1)))) (*.f64 (/.f64 (sqrt.f64 x) y) (+.f64 (/.f64 1/8 (sqrt.f64 -1)) (/.f64 1/16 (*.f64 y (pow.f64 (sqrt.f64 -1) 5))))))
(*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)))
(neg.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)))
(*.f64 (sqrt.f64 -1) (neg.f64 (*.f64 y (sqrt.f64 x))))
(*.f64 (sqrt.f64 -1) (*.f64 y (neg.f64 (sqrt.f64 x))))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x))) (*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))))
(fma.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))))
(*.f64 (sqrt.f64 x) (+.f64 (neg.f64 (*.f64 (sqrt.f64 -1) y)) (*.f64 (sqrt.f64 -1) 1/2)))
(*.f64 (*.f64 (sqrt.f64 -1) (sqrt.f64 x)) (-.f64 1/2 y))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x))) (+.f64 (*.f64 1/8 (*.f64 (/.f64 (sqrt.f64 -1) y) (sqrt.f64 x))) (*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)))))
(fma.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x)) (fma.f64 1/8 (*.f64 (sqrt.f64 x) (/.f64 (sqrt.f64 -1) y)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)))))
(-.f64 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (sqrt.f64 -1) 1/2) (*.f64 1/8 (/.f64 (sqrt.f64 -1) y)))) (*.f64 y (*.f64 (sqrt.f64 -1) (sqrt.f64 x))))
(*.f64 (sqrt.f64 x) (+.f64 (*.f64 (sqrt.f64 -1) (+.f64 1/2 (neg.f64 y))) (*.f64 1/8 (/.f64 (sqrt.f64 -1) y))))
(*.f64 (sqrt.f64 x) (+.f64 (*.f64 (sqrt.f64 -1) (-.f64 1/2 y)) (*.f64 1/8 (/.f64 (sqrt.f64 -1) y))))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x))) (+.f64 (*.f64 1/8 (*.f64 (/.f64 (sqrt.f64 -1) y) (sqrt.f64 x))) (+.f64 (*.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x))) (*.f64 1/16 (*.f64 (/.f64 (sqrt.f64 -1) (pow.f64 y 2)) (sqrt.f64 x))))))
(fma.f64 1/2 (*.f64 (sqrt.f64 -1) (sqrt.f64 x)) (fma.f64 1/8 (*.f64 (sqrt.f64 x) (/.f64 (sqrt.f64 -1) y)) (fma.f64 -1 (*.f64 (*.f64 (sqrt.f64 -1) y) (sqrt.f64 x)) (*.f64 (*.f64 1/16 (/.f64 (sqrt.f64 -1) (*.f64 y y))) (sqrt.f64 x)))))
(+.f64 (*.f64 (sqrt.f64 x) (+.f64 (neg.f64 (*.f64 (sqrt.f64 -1) y)) (*.f64 1/16 (/.f64 (/.f64 (sqrt.f64 -1) y) y)))) (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (sqrt.f64 -1) 1/2) (*.f64 1/8 (/.f64 (sqrt.f64 -1) y)))))
(*.f64 (sqrt.f64 x) (+.f64 (fma.f64 1/16 (/.f64 (sqrt.f64 -1) (*.f64 y y)) (*.f64 (sqrt.f64 -1) (neg.f64 y))) (fma.f64 (sqrt.f64 -1) 1/2 (*.f64 1/8 (/.f64 (sqrt.f64 -1) y)))))
(+.f64 (*.f64 (sqrt.f64 x) (*.f64 (/.f64 (sqrt.f64 -1) y) (+.f64 1/8 (/.f64 1/16 y)))) (*.f64 (*.f64 (sqrt.f64 -1) (sqrt.f64 x)) (-.f64 1/2 y)))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y)))
(*.f64 -1 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 -1 (*.f64 y y)) y))
(*.f64 x (fma.f64 (neg.f64 y) y y))
(*.f64 x (-.f64 y (*.f64 y y)))
(+.f64 (*.f64 y x) (+.f64 (*.f64 -1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)) (*.f64 1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))))))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 -1 (*.f64 y y)) y))
(*.f64 x (fma.f64 (neg.f64 y) y y))
(*.f64 x (-.f64 y (*.f64 y y)))
(+.f64 (*.f64 -1/8 (/.f64 x (*.f64 (pow.f64 (sqrt.f64 -1) 4) y))) (+.f64 (*.f64 y x) (+.f64 (*.f64 1/8 (/.f64 x (*.f64 (pow.f64 (sqrt.f64 -1) 4) y))) (+.f64 (*.f64 -1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)) (*.f64 1/4 (/.f64 x (pow.f64 (sqrt.f64 -1) 2))))))))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 -1 (*.f64 y y)) y))
(*.f64 x (fma.f64 (neg.f64 y) y y))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y)))
(*.f64 -1 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 -1 (*.f64 y y)) y))
(*.f64 x (fma.f64 (neg.f64 y) y y))
(*.f64 x (-.f64 y (*.f64 y y)))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 -1 (*.f64 y y)) y))
(*.f64 x (fma.f64 (neg.f64 y) y y))
(*.f64 x (-.f64 y (*.f64 y y)))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -1/8 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (*.f64 1/8 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x))) y)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 (sqrt.f64 -1) 2) x)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))))))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 -1 (*.f64 y y)) y))
(*.f64 x (fma.f64 (neg.f64 y) y y))
(*.f64 x (-.f64 y (*.f64 y y)))

localize43.0ms (0.7%)

Local error

Found 3 expressions with local error:

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

Compiled 36 to 21 computations (41.7% saved)

series13.0ms (0.2%)

Counts
3 → 44
Calls

15 calls:

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

rewrite186.0ms (2.8%)

Algorithm
batch-egg-rewrite
Rules
926×pow1_binary64
857×add-log-exp_binary64
857×log1p-expm1-u_binary64
857×expm1-log1p-u_binary64
838×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify109.0ms (1.7%)

Algorithm
egg-herbie
Rules
901×fma-def_binary64
714×distribute-rgt-out_binary64
702×fma-neg_binary64
589×associate-*l*_binary64
431×associate-*r*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
042493
1117488
2321475
3966459
43793459
55889459
67204459
Stop Event
node limit
Counts
97 → 74
Calls
Call 1
Inputs
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1/8 (*.f64 (pow.f64 y 3) x))))
(+.f64 (*.f64 y x) (+.f64 (*.f64 -1/16 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1/8 (*.f64 (pow.f64 y 3) x)))))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
1
(+.f64 (*.f64 -1/2 y) 1)
(+.f64 (*.f64 -1/2 y) (+.f64 1 (*.f64 -1/8 (pow.f64 y 2))))
(+.f64 (*.f64 -1/2 y) (+.f64 1 (+.f64 (*.f64 -1/16 (pow.f64 y 3)) (*.f64 -1/8 (pow.f64 y 2)))))
Outputs
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 (*.f64 y x) (sqrt.f64 (-.f64 1 y)))
(*.f64 y (*.f64 x (sqrt.f64 (-.f64 1 y))))
(*.f64 x (*.f64 y (sqrt.f64 (-.f64 1 y))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (*.f64 -1/2 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 y (*.f64 -1/2 (*.f64 y y))))
(*.f64 x (fma.f64 (*.f64 y -1/2) y y))
(*.f64 x (*.f64 y (fma.f64 y -1/2 1)))
(*.f64 x (fma.f64 y (*.f64 y -1/2) y))
(+.f64 (*.f64 y x) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1/8 (*.f64 (pow.f64 y 3) x))))
(fma.f64 y x (fma.f64 -1/2 (*.f64 x (*.f64 y y)) (*.f64 -1/8 (*.f64 x (pow.f64 y 3)))))
(fma.f64 y x (*.f64 x (+.f64 (*.f64 -1/2 (*.f64 y y)) (*.f64 -1/8 (pow.f64 y 3)))))
(*.f64 x (+.f64 y (*.f64 y (*.f64 y (+.f64 (*.f64 y -1/8) -1/2)))))
(*.f64 x (*.f64 y (fma.f64 y (fma.f64 y -1/8 -1/2) 1)))
(*.f64 (*.f64 y x) (fma.f64 y (fma.f64 y -1/8 -1/2) 1))
(+.f64 (*.f64 y x) (+.f64 (*.f64 -1/16 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1/8 (*.f64 (pow.f64 y 3) x)))))
(fma.f64 y x (fma.f64 -1/16 (*.f64 x (pow.f64 y 4)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) (*.f64 -1/8 (*.f64 x (pow.f64 y 3))))))
(fma.f64 y x (fma.f64 -1/16 (*.f64 x (pow.f64 y 4)) (*.f64 x (+.f64 (*.f64 -1/2 (*.f64 y y)) (*.f64 -1/8 (pow.f64 y 3))))))
(*.f64 x (+.f64 (*.f64 y (*.f64 y (+.f64 (*.f64 y -1/8) -1/2))) (+.f64 y (*.f64 -1/16 (pow.f64 y 4)))))
(*.f64 x (fma.f64 y (*.f64 y (fma.f64 y -1/8 -1/2)) (fma.f64 -1/16 (pow.f64 y 4) y)))
(*.f64 x (*.f64 y (fma.f64 (pow.f64 y 3) -1/16 (fma.f64 y (fma.f64 y -1/8 -1/2) 1))))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (*.f64 x (neg.f64 y)))
(*.f64 (*.f64 y x) (neg.f64 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (*.f64 x (neg.f64 y)))
(*.f64 (*.f64 y x) (neg.f64 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
1
(+.f64 (*.f64 -1/2 y) 1)
(fma.f64 -1/2 y 1)
(fma.f64 y -1/2 1)
(+.f64 (*.f64 -1/2 y) (+.f64 1 (*.f64 -1/8 (pow.f64 y 2))))
(fma.f64 -1/2 y (+.f64 1 (*.f64 (*.f64 y y) -1/8)))
(fma.f64 y -1/2 (fma.f64 (*.f64 y y) -1/8 1))
(fma.f64 y -1/2 (fma.f64 y (*.f64 y -1/8) 1))
(fma.f64 y (fma.f64 y -1/8 -1/2) 1)
(+.f64 (*.f64 -1/2 y) (+.f64 1 (+.f64 (*.f64 -1/16 (pow.f64 y 3)) (*.f64 -1/8 (pow.f64 y 2)))))
(+.f64 (fma.f64 -1/2 y 1) (fma.f64 -1/16 (pow.f64 y 3) (*.f64 (*.f64 y y) -1/8)))
(+.f64 (fma.f64 y -1/2 1) (fma.f64 (pow.f64 y 3) -1/16 (*.f64 y (*.f64 y -1/8))))
(fma.f64 y -1/2 (fma.f64 y (*.f64 y -1/8) (fma.f64 (pow.f64 y 3) -1/16 1)))
(fma.f64 y -1/2 (fma.f64 (*.f64 y y) (fma.f64 y -1/16 -1/8) 1))
(fma.f64 (pow.f64 y 3) -1/16 (fma.f64 y (fma.f64 y -1/8 -1/2) 1))

eval277.0ms (4.2%)

Compiler

Compiled 5568 to 3556 computations (36.1% saved)

prune93.0ms (1.4%)

Pruning

17 alts after pruning (7 fresh and 10 done)

PrunedKeptTotal
New3733376
Fresh246
Picked011
Done099
Total37517392
Error
0.0b
Counts
392 → 17
Alt Table
Click to see full alt table
StatusErrorProgram
30.9b
(*.f64 y (*.f64 y (neg.f64 x)))
41.4b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2) x)
6.8b
(-.f64 (*.f64 x y) (*.f64 x (*.f64 y y)))
12.1b
(*.f64 (*.f64 (*.f64 x y) (sqrt.f64 (-.f64 1 y))) (cbrt.f64 (pow.f64 (-.f64 1 y) 3/2)))
30.7b
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
22.1b
(*.f64 y x)
11.4b
(*.f64 (*.f64 (*.f64 x y) (pow.f64 (pow.f64 (-.f64 1 y) 1/4) 2)) (sqrt.f64 (-.f64 1 y)))
11.4b
(*.f64 (*.f64 (*.f64 x y) (sqrt.f64 (-.f64 1 y))) (sqrt.f64 (-.f64 1 y)))
6.8b
(*.f64 (*.f64 y (-.f64 1 y)) x)
37.6b
(*.f64 (*.f64 y (neg.f64 y)) x)
26.2b
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
35.7b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y))))
30.4b
(*.f64 (*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y))) (sqrt.f64 (*.f64 x y)))
1.1b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
0.1b
(*.f64 (*.f64 (-.f64 1 y) x) y)
1.1b
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
Compiler

Compiled 305 to 205 computations (32.8% saved)

localize17.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))
0.3b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
0.5b
(pow.f64 (cbrt.f64 (*.f64 x y)) 2)
10.3b
(cbrt.f64 (*.f64 x y))
Compiler

Compiled 45 to 19 computations (57.8% saved)

series15.0ms (0.2%)

Counts
4 → 24
Calls

24 calls:

TimeVariablePointExpression
2.0ms
x
@-inf
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
1.0ms
y
@-inf
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
1.0ms
y
@inf
(*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))
1.0ms
x
@-inf
(*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))
1.0ms
x
@-inf
(pow.f64 (cbrt.f64 (*.f64 x y)) 2)

rewrite89.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
514×log-prod_binary64
388×pow-prod-down_binary64
372×exp-prod_binary64
261×pow2_binary64
227×pow-unpow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01137
122737
2266837
Stop Event
node limit
Counts
4 → 185
Calls
Call 1
Inputs
(cbrt.f64 (*.f64 x y))
(pow.f64 (cbrt.f64 (*.f64 x y)) 2)
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
(*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cbrt.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cbrt.f64 (*.f64 x y)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cbrt.f64 (*.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 (*.f64 x y))))) (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 (*.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cbrt.f64 (*.f64 x y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 y) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) (cbrt.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x y) 1/6) (pow.f64 (*.f64 x y) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4)) (sqrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x y) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x y) 2) 1/6)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x y) 3) 1/9)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) 3/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x y) 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x y)) 2/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1/3) (log.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (cbrt.f64 (*.f64 x y)))) 2)) (cbrt.f64 (log.f64 (cbrt.f64 (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (cbrt.f64 (*.f64 x y))))) (sqrt.f64 (log.f64 (cbrt.f64 (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (cbrt.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cbrt.f64 (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x y)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2/3 (log.f64 (*.f64 x y))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (*.f64 x y) 1/6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x y)) 1) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x y)) 1/3) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x y))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (*.f64 2/3 (log.f64 (*.f64 x y))) 1) 1/2))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))) 2)) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x y)) (cbrt.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (*.f64 (cbrt.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (pow.f64 (cbrt.f64 y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x y) 1/6) (sqrt.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x y)) (pow.f64 (*.f64 x y) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 5) (cbrt.f64 (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (cbrt.f64 x)) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2/3 (log.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2/3 (log.f64 (*.f64 x y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x y)) 2/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (*.f64 x y))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/3 (*.f64 2/3 (log.f64 (*.f64 x y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x y)) 1) 2/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x y)) 1/3) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x y))) 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (*.f64 2/3 (log.f64 (*.f64 x y))) 1) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 y (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 y (-.f64 1 y)))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 y (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 y (-.f64 1 y))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 y (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (*.f64 y (-.f64 1 y))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x y) (-.f64 1 (pow.f64 y 3))) (+.f64 1 (fma.f64 y y y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x y) (-.f64 1 (*.f64 y y))) (+.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 y (-.f64 1 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (*.f64 x (*.f64 y (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 y (-.f64 1 y))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 y (-.f64 1 y))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 y (-.f64 1 y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (*.f64 y (-.f64 1 y)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (-.f64 1 y) 3) (pow.f64 (*.f64 x y) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 (-.f64 1 y)) (sqrt.f64 (*.f64 x y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y))))) 2)) (cbrt.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y)))))) (sqrt.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (*.f64 y (-.f64 1 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 y (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 y (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 y (-.f64 1 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 y (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 y (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (*.f64 x (*.f64 y (-.f64 1 y))) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x (*.f64 y (-.f64 1 y))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 x (*.f64 y (-.f64 1 y))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x (*.f64 y (-.f64 1 y)))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x y) 1 (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x y) 1 (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x y)) (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x y)) (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (cbrt.f64 (*.f64 x y)) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (cbrt.f64 (*.f64 x y)) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) x) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) x) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 5) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 5) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) x) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) x) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x y)) (sqrt.f64 (*.f64 x y)) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x y)) (sqrt.f64 (*.f64 x y)) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (sqrt.f64 y)) (sqrt.f64 y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (sqrt.f64 y)) (sqrt.f64 y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 x) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 x) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) 4) (cbrt.f64 (cbrt.f64 (*.f64 x y))) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) 4) (cbrt.f64 (cbrt.f64 (*.f64 x y))) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (cbrt.f64 x)) (cbrt.f64 y) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (cbrt.f64 x)) (cbrt.f64 y) (*.f64 (*.f64 x y) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 x y) 5/6) (pow.f64 (*.f64 x y) 1/6) (*.f64 (neg.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 x y) 5/6) (pow.f64 (*.f64 x y) 1/6) (*.f64 (*.f64 x y) (neg.f64 y)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (cbrt.f64 (*.f64 x y)) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cbrt.f64 (*.f64 x y)) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))) (log.f64 (sqrt.f64 (exp.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1 (pow.f64 y 3)) (cbrt.f64 (*.f64 x y))) (+.f64 1 (fma.f64 y y y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1 (*.f64 y y)) (cbrt.f64 (*.f64 x y))) (+.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 (pow.f64 y 3))) (+.f64 1 (fma.f64 y y y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 (*.f64 y y))) (+.f64 y 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x y) (pow.f64 (-.f64 1 y) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))) 2)) (cbrt.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))) (sqrt.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 x y) (pow.f64 (-.f64 1 y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (*.f64 x y) (pow.f64 (-.f64 1 y) 3))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x y)) 1 (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x y)) 1 (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (cbrt.f64 (*.f64 x y)) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (cbrt.f64 (*.f64 x y)) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 x) (cbrt.f64 y) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 x) (cbrt.f64 y) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 y) (cbrt.f64 x) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 y) (cbrt.f64 x) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) (cbrt.f64 (cbrt.f64 (*.f64 x y))) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2)) (cbrt.f64 (cbrt.f64 (*.f64 x y))) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 x y) 1/6) (pow.f64 (*.f64 x y) 1/6) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 x y) 1/6) (pow.f64 (*.f64 x y) 1/6) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4)) (sqrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))) (*.f64 (neg.f64 y) (cbrt.f64 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x y))) 4)) (sqrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2))) (*.f64 (cbrt.f64 (*.f64 x y)) (neg.f64 y)))))))

simplify91.0ms (1.4%)

Algorithm
egg-herbie
Rules
367×fma-neg_binary64
349×associate-*l*_binary64
306×distribute-rgt-neg-in_binary64
295×distribute-rgt-out--_binary64
295×neg-sub0_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014232
134232
283232
3189232
4590232
51939232
63937232
76091232
87890232
Stop Event
node limit
Counts
209 → 191
Calls
Call 1
Inputs
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 x (neg.f64 (*.f64 y y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 x (neg.f64 (*.f64 y y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (fma.f64 y (neg.f64 x) x))

localize9.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 24 to 6 computations (75% saved)

series4.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite61.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
886×pow1_binary64
824×add-log-exp_binary64
824×log1p-expm1-u_binary64
824×expm1-log1p-u_binary64
806×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify100.0ms (1.5%)

Algorithm
egg-herbie
Rules
677×fma-neg_binary64
397×unsub-neg_binary64
339×cancel-sign-sub-inv_binary64
311×distribute-rgt-neg-in_binary64
292×difference-of-squares_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
017400
148400
2116400
3346400
41030400
52504400
64295400
76489400
87644400
Stop Event
node limit
Counts
114 → 75
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 (-.f64 y (pow.f64 y 2)) x)
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 y) (*.f64 -1 (pow.f64 y 2))) x))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(*.f64 (neg.f64 (*.f64 y y)) x)
(neg.f64 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (-.f64 x (*.f64 y x)))

localize17.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(*.f64 y (-.f64 1 y))
0.0b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2) x)
0.2b
(pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2)
Compiler

Compiled 38 to 26 computations (31.6% saved)

series8.0ms (0.1%)

Counts
2 → 32
Calls

9 calls:

TimeVariablePointExpression
2.0ms
y
@inf
(pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2)
2.0ms
x
@-inf
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2) x)
1.0ms
y
@0
(pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2)
1.0ms
y
@-inf
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2) x)
1.0ms
y
@-inf
(pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2)

rewrite55.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
863×pow1_binary64
802×add-log-exp_binary64
801×log1p-expm1-u_binary64
801×expm1-log1p-u_binary64
785×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify53.0ms (0.8%)

Algorithm
egg-herbie
Rules
679×fma-def_binary64
521×associate-/r*_binary64
449×fma-neg_binary64
371×unsub-neg_binary64
252×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
064503
1178371
2611344
31785306
47066306
Stop Event
node limit
Counts
81 → 67
Calls
Call 1
Inputs
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2))
(+.f64 y (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))
(+.f64 y (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 (sqrt.f64 -1) 6))) (pow.f64 (/.f64 -1/8 (pow.f64 (sqrt.f64 -1) 3)) 2)) (pow.f64 y 2))) (+.f64 (*.f64 5/64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 6) (pow.f64 y 2)))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))))
(+.f64 y (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 (sqrt.f64 -1) 6))) (pow.f64 (/.f64 -1/8 (pow.f64 (sqrt.f64 -1) 3)) 2)) (pow.f64 y 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)) (*.f64 5/64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 6) (pow.f64 y 2)))))))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) y)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))
(+.f64 (*.f64 1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) y)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))))
(+.f64 (*.f64 1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) y)) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -1/8 (pow.f64 (sqrt.f64 -1) 2)) (*.f64 1/8 (pow.f64 (sqrt.f64 -1) 2))) y)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2))))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
Outputs
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y))
(*.f64 y (neg.f64 y))
(+.f64 y (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))
(+.f64 y (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y)))
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(+.f64 y (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 (sqrt.f64 -1) 6))) (pow.f64 (/.f64 -1/8 (pow.f64 (sqrt.f64 -1) 3)) 2)) (pow.f64 y 2))) (+.f64 (*.f64 5/64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 6) (pow.f64 y 2)))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))))
(+.f64 y (fma.f64 -1 (/.f64 (+.f64 (/.f64 1/16 (pow.f64 (sqrt.f64 -1) 6)) (pow.f64 (/.f64 -1/8 (pow.f64 (sqrt.f64 -1) 3)) 2)) (*.f64 y y)) (fma.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y) (/.f64 5/64 (*.f64 (*.f64 y y) (pow.f64 (sqrt.f64 -1) 6))))))
(+.f64 y (-.f64 (fma.f64 -1 (*.f64 y y) (/.f64 -5/64 (*.f64 y y))) (/.f64 (+.f64 -1/16 (pow.f64 (/.f64 1/8 (sqrt.f64 -1)) 2)) (*.f64 y y))))
(-.f64 (+.f64 y (-.f64 (/.f64 -5/64 (*.f64 y y)) (*.f64 y y))) (/.f64 (+.f64 -1/16 (pow.f64 (/.f64 1/8 (sqrt.f64 -1)) 2)) (*.f64 y y)))
(fma.f64 y (-.f64 1 y) (*.f64 (/.f64 -1 (*.f64 y y)) 0))
(+.f64 y (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 (sqrt.f64 -1) 6))) (pow.f64 (/.f64 -1/8 (pow.f64 (sqrt.f64 -1) 3)) 2)) (pow.f64 y 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)) (*.f64 5/64 (/.f64 1 (*.f64 (pow.f64 (sqrt.f64 -1) 6) (pow.f64 y 2)))))))
(+.f64 y (fma.f64 -1 (/.f64 (+.f64 (/.f64 1/16 (pow.f64 (sqrt.f64 -1) 6)) (pow.f64 (/.f64 -1/8 (pow.f64 (sqrt.f64 -1) 3)) 2)) (*.f64 y y)) (fma.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y) (/.f64 5/64 (*.f64 (*.f64 y y) (pow.f64 (sqrt.f64 -1) 6))))))
(+.f64 y (-.f64 (fma.f64 -1 (*.f64 y y) (/.f64 -5/64 (*.f64 y y))) (/.f64 (+.f64 -1/16 (pow.f64 (/.f64 1/8 (sqrt.f64 -1)) 2)) (*.f64 y y))))
(-.f64 (+.f64 y (-.f64 (/.f64 -5/64 (*.f64 y y)) (*.f64 y y))) (/.f64 (+.f64 -1/16 (pow.f64 (/.f64 1/8 (sqrt.f64 -1)) 2)) (*.f64 y y)))
(fma.f64 y (-.f64 1 y) (*.f64 (/.f64 -1 (*.f64 y y)) 0))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y))
(*.f64 y (neg.f64 y))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) y)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))
(+.f64 y (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y)))
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(+.f64 (*.f64 1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) y)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2)))))
(+.f64 y (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y)))
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(+.f64 (*.f64 1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1/4 (pow.f64 (sqrt.f64 -1) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) y)) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -1/8 (pow.f64 (sqrt.f64 -1) 2)) (*.f64 1/8 (pow.f64 (sqrt.f64 -1) 2))) y)) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 y 2))))))
(+.f64 y (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y y)))
(fma.f64 -1 (*.f64 y y) y)
(-.f64 y (*.f64 y y))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 (*.f64 y y) x))
(*.f64 (*.f64 y y) (neg.f64 x))
(*.f64 y (*.f64 y (neg.f64 x)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1 (*.f64 y y) y))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 x (-.f64 1 y)))

localize15.0ms (0.2%)

Local error

Found 3 expressions with local error:

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

Compiled 34 to 18 computations (47.1% saved)

series13.0ms (0.2%)

Counts
2 → 36
Calls

12 calls:

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

rewrite69.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
930×pow1_binary64
861×add-log-exp_binary64
861×log1p-expm1-u_binary64
861×expm1-log1p-u_binary64
842×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify64.0ms (1%)

Algorithm
egg-herbie
Rules
727×fma-neg_binary64
581×unswap-sqr_binary64
548×fma-def_binary64
404×distribute-rgt-neg-in_binary64
310×distribute-lft-neg-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
023413
160386
2194368
3566368
41486368
53855368
Stop Event
node limit
Counts
67 → 43
Calls
Call 1
Inputs
(*.f64 y (sqrt.f64 x))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 y (sqrt.f64 x))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 (neg.f64 y) y))
(*.f64 (sqrt.f64 x) (*.f64 y (neg.f64 y)))
(*.f64 y (*.f64 (sqrt.f64 x) (neg.f64 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 (neg.f64 y) y))
(*.f64 (sqrt.f64 x) (*.f64 y (neg.f64 y)))
(*.f64 y (*.f64 (sqrt.f64 x) (neg.f64 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(+.f64 (*.f64 y (sqrt.f64 x)) (*.f64 -1 (*.f64 (pow.f64 y 2) (sqrt.f64 x))))
(fma.f64 y (sqrt.f64 x) (neg.f64 (*.f64 (sqrt.f64 x) (*.f64 y y))))
(*.f64 (sqrt.f64 x) (+.f64 y (*.f64 (neg.f64 y) y)))
(*.f64 (sqrt.f64 x) (-.f64 y (*.f64 y y)))
(*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) (sqrt.f64 x)))
(*.f64 y (*.f64 (sqrt.f64 x) (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 x (*.f64 y (neg.f64 y)))
(*.f64 y (*.f64 x (neg.f64 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 x (*.f64 y (neg.f64 y)))
(*.f64 y (*.f64 x (neg.f64 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (-.f64 1 y) (*.f64 y x))
(*.f64 y (-.f64 x (*.f64 y x)))

localize12.0ms (0.2%)

Local error

Found 3 expressions with local error:

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

Compiled 36 to 14 computations (61.1% saved)

series17.0ms (0.3%)

Counts
3 → 24
Calls

18 calls:

TimeVariablePointExpression
5.0ms
x
@inf
(*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y)))
2.0ms
x
@inf
(sqrt.f64 (*.f64 x y))
1.0ms
x
@0
(sqrt.f64 (*.f64 x y))
1.0ms
x
@-inf
(*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y)))
1.0ms
y
@-inf
(*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y)))

rewrite89.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
912×pow1_binary64
844×add-log-exp_binary64
844×log1p-expm1-u_binary64
844×expm1-log1p-u_binary64
826×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify106.0ms (1.6%)

Algorithm
egg-herbie
Rules
843×fma-def_binary64
726×unswap-sqr_binary64
456×distribute-rgt-neg-in_binary64
369×distribute-lft-neg-in_binary64
350×difference-of-squares_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
022295
162274
2234232
3680232
41833232
54433232
67886232
Stop Event
node limit
Counts
81 → 66
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 (*.f64 y x) (neg.f64 y))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 y x) (*.f64 -1 (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x))
(neg.f64 (*.f64 x (*.f64 y y)))
(*.f64 x (*.f64 (neg.f64 y) y))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 (*.f64 y x) (neg.f64 y))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y x))) (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 y (*.f64 (-.f64 1 y) x))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 y (*.f64 (-.f64 1 y) x))))
(fma.f64 y x (neg.f64 (*.f64 x (*.f64 y y))))
(*.f64 x (+.f64 (*.f64 (neg.f64 y) y) y))
(*.f64 x (*.f64 y (-.f64 1 y)))
(*.f64 y (-.f64 x (*.f64 y x)))
(*.f64 x (-.f64 y (*.f64 y y)))
(*.f64 y (*.f64 x (-.f64 1 y)))

eval310.0ms (4.7%)

Compiler

Compiled 8811 to 3958 computations (55.1% saved)

prune147.0ms (2.2%)

Pruning

17 alts after pruning (3 fresh and 14 done)

PrunedKeptTotal
New5503553
Fresh202
Picked011
Done11314
Total55317570
Error
0b
Counts
570 → 17
Alt Table
Click to see full alt table
StatusErrorProgram
30.9b
(*.f64 y (*.f64 y (neg.f64 x)))
33.6b
(-.f64 (*.f64 x y) (pow.f64 (*.f64 y (sqrt.f64 x)) 2))
6.8b
(-.f64 (*.f64 x y) (*.f64 x (*.f64 y y)))
30.7b
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
22.1b
(*.f64 y x)
26.2b
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
6.8b
(fma.f64 y x (*.f64 (*.f64 y y) (neg.f64 x)))
6.8b
(*.f64 (*.f64 y (-.f64 1 y)) x)
37.6b
(*.f64 (*.f64 y (neg.f64 y)) x)
0.1b
(*.f64 (*.f64 x y) (-.f64 1 y))
1.1b
(*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (cbrt.f64 x)) (cbrt.f64 y)) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
35.7b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y))))
30.4b
(*.f64 (*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y))) (sqrt.f64 (*.f64 x y)))
1.1b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
0.1b
(*.f64 (*.f64 (-.f64 1 y) x) y)
11.4b
(*.f64 (*.f64 (*.f64 x y) (sqrt.f64 (-.f64 1 y))) (sqrt.f64 (-.f64 1 y)))
1.1b
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
Compiler

Compiled 199 to 127 computations (36.2% saved)

regimes76.0ms (1.2%)

Counts
27 → 1
Calls
Call 1
Inputs
(*.f64 y x)
(*.f64 (*.f64 y (neg.f64 y)) x)
(*.f64 x (neg.f64 (*.f64 y y)))
(*.f64 y (*.f64 y (neg.f64 x)))
(*.f64 (*.f64 (-.f64 1 y) x) y)
(*.f64 (*.f64 y (-.f64 1 y)) x)
(*.f64 y (*.f64 (-.f64 1 y) x))
(*.f64 (*.f64 x y) (-.f64 1 y))
(-.f64 (*.f64 x y) (*.f64 x (*.f64 y y)))
(+.f64 (*.f64 x y) (*.f64 (*.f64 x y) (neg.f64 y)))
(*.f64 x (fma.f64 y (neg.f64 y) y))
(fma.f64 y x (*.f64 (*.f64 y y) (neg.f64 x)))
(-.f64 (*.f64 x y) (pow.f64 (*.f64 y (sqrt.f64 x)) 2))
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y (-.f64 1 y))) 2) x)
(cbrt.f64 (pow.f64 (*.f64 (*.f64 x y) (-.f64 1 y)) 3))
(pow.f64 (sqrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 2)
(pow.f64 (cbrt.f64 (*.f64 (*.f64 x y) (-.f64 1 y))) 3)
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (*.f64 y (-.f64 1 y))))
(*.f64 (*.f64 (-.f64 1 y) (sqrt.f64 (*.f64 x y))) (sqrt.f64 (*.f64 x y)))
(*.f64 (*.f64 (*.f64 x y) (sqrt.f64 (-.f64 1 y))) (sqrt.f64 (-.f64 1 y)))
(/.f64 (*.f64 (-.f64 1 (pow.f64 y 3)) (*.f64 x y)) (+.f64 1 (fma.f64 y y y)))
(*.f64 (*.f64 (*.f64 x y) (sqrt.f64 (-.f64 1 y))) (cbrt.f64 (pow.f64 (-.f64 1 y) 3/2)))
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
(*.f64 (*.f64 (*.f64 x y) (pow.f64 (pow.f64 (-.f64 1 y) 1/4) 2)) (sqrt.f64 (-.f64 1 y)))
(*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 x y)) (cbrt.f64 x)) (cbrt.f64 y)) (*.f64 (cbrt.f64 (*.f64 x y)) (-.f64 1 y)))
(*.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x (-.f64 1 y)))) 2) (cbrt.f64 (*.f64 x y))) (cbrt.f64 (-.f64 1 y)))
Outputs
(*.f64 (*.f64 x y) (-.f64 1 y))
Calls

3 calls:

33.0ms
y
22.0ms
x
13.0ms
(*.f64 (*.f64 x y) (-.f64 1 y))
Results
ErrorSegmentsBranch
0.1b1x
0.1b1y
0.1b1(*.f64 (*.f64 x y) (-.f64 1 y))
Compiler

Compiled 304 to 157 computations (48.4% saved)

regimes25.0ms (0.4%)

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

2 calls:

11.0ms
y
11.0ms
x
Results
ErrorSegmentsBranch
0.1b1x
0.1b1y
Compiler

Compiled 50 to 28 computations (44% saved)

regimes57.0ms (0.9%)

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

2 calls:

31.0ms
x
23.0ms
y
Results
ErrorSegmentsBranch
12.4b3x
2.2b3y
Compiler

Compiled 29 to 16 computations (44.8% saved)

bsearch86.0ms (1.3%)

Algorithm
binary-search
Steps
TimeLeftRight
31.0ms
0.07914621420229247
2911.864194550937
55.0ms
-287.87126243190335
-0.000935231411574878
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes109.0ms (1.7%)

Accuracy

Total -42.1b remaining (-471.8%)

Threshold costs -42.1b (-471.8%)

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

2 calls:

85.0ms
y
22.0ms
x
Results
ErrorSegmentsBranch
18.0b3x
8.9b3y
Compiler

Compiled 23 to 13 computations (43.5% saved)

bsearch66.0ms (1%)

Algorithm
binary-search
Steps
TimeLeftRight
15.0ms
0.07914621420229247
2911.864194550937
50.0ms
-287.87126243190335
-0.000935231411574878
Compiler

Compiled 14 to 10 computations (28.6% saved)

simplify7.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
02592
14492
26392
38192
48792
58992
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 (*.f64 x y) (-.f64 1 y))
(*.f64 (*.f64 (-.f64 1 y) x) y)
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 y (*.f64 y (neg.f64 x))) (if (<=.f64 y 1459989957792685312/18446744073709551616) (*.f64 y x) (*.f64 y (*.f64 y (neg.f64 x)))))
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 (*.f64 y (neg.f64 y)) x) (if (<=.f64 y 1459989957792685312/18446744073709551616) (*.f64 y x) (*.f64 (*.f64 y (neg.f64 y)) x)))
(*.f64 y x)
Outputs
(*.f64 (*.f64 x y) (-.f64 1 y))
(*.f64 (-.f64 1 y) (*.f64 x y))
(*.f64 (*.f64 (-.f64 1 y) x) y)
(*.f64 y (*.f64 x (-.f64 1 y)))
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 y (*.f64 y (neg.f64 x))) (if (<=.f64 y 1459989957792685312/18446744073709551616) (*.f64 y x) (*.f64 y (*.f64 y (neg.f64 x)))))
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 y (*.f64 y (neg.f64 x))) (if (<=.f64 y 5703085772627677/72057594037927936) (*.f64 x y) (*.f64 y (*.f64 y (neg.f64 x)))))
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 (*.f64 y (neg.f64 y)) x) (if (<=.f64 y 1459989957792685312/18446744073709551616) (*.f64 y x) (*.f64 (*.f64 y (neg.f64 y)) x)))
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 x (*.f64 y (neg.f64 y))) (if (<=.f64 y 5703085772627677/72057594037927936) (*.f64 x y) (*.f64 x (*.f64 y (neg.f64 y)))))
(if (<=.f64 y -2532142402771473/8796093022208) (*.f64 (neg.f64 x) (*.f64 y y)) (if (<=.f64 y 5703085772627677/72057594037927936) (*.f64 x y) (*.f64 (neg.f64 x) (*.f64 y y))))
(*.f64 y x)
(*.f64 x y)
Compiler

Compiled 73 to 39 computations (46.6% saved)

soundness0.0ms (0%)

end45.0ms (0.7%)

Compiler

Compiled 65 to 27 computations (58.5% saved)

Profiling

Loading profile data...