Details

Time bar (total: 3.8s)

analyze75.0ms (2%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
18.8%18.7%81.2%0.1%0%0%0%5
46.9%46.8%53.1%0.1%0%0%0%6
56.3%56.2%43.7%0.1%0%0%0%7
71.1%71%28.9%0.1%0%0%0%8
76.6%76.5%23.4%0.1%0%0%0%9
85%84.9%15%0.1%0%0%0%10
87.9%87.8%12.1%0.1%0%0%0%11
92.3%92.2%7.7%0.1%0%0%0%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample1.0s (26.9%)

Results
989.0ms8256×body256valid
Bogosity

preprocess135.0ms (3.6%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-/r/_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
11820
22620
33120
43320
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(/.f64 (*.f64 x 100) (+.f64 x y))
(/.f64 (*.f64 y 100) (+.f64 y x))
Outputs
(/.f64 (*.f64 x 100) (+.f64 x y))
(/.f64 x (/.f64 (+.f64 x y) 100))
(*.f64 (/.f64 x (+.f64 x y)) 100)
(*.f64 100 (/.f64 x (+.f64 x y)))
(*.f64 x (/.f64 100 (+.f64 x y)))
(/.f64 (*.f64 y 100) (+.f64 y x))
(/.f64 y (/.f64 (+.f64 x y) 100))
(*.f64 (/.f64 y (+.f64 x y)) 100)
(*.f64 100 (/.f64 y (+.f64 x y)))
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify128.0ms (3.4%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-/r/_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11110
21510
31810
41910
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(/.f64 (*.f64 x 100) (+.f64 x y))
Outputs
(/.f64 (*.f64 x 100) (+.f64 x y))
(/.f64 x (/.f64 (+.f64 x y) 100))
(*.f64 (/.f64 x (+.f64 x y)) 100)
(*.f64 100 (/.f64 x (+.f64 x y)))
(*.f64 x (/.f64 100 (+.f64 x y)))

eval1.0ms (0%)

Compiler

Compiled 16 to 9 computations (43.8% saved)

prune3.0ms (0.1%)

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.2b
(*.f64 x (/.f64 100 (+.f64 x y)))
0.4b
(/.f64 (*.f64 x 100) (+.f64 x y))
Compiler

Compiled 18 to 12 computations (33.3% saved)

localize100.0ms (2.7%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (/.f64 100 (+.f64 x y)))
Compiler

Compiled 20 to 9 computations (55% saved)

series7.0ms (0.2%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
2.0ms
x
@0
(*.f64 x (/.f64 100 (+.f64 x y)))
1.0ms
y
@inf
(*.f64 x (/.f64 100 (+.f64 x y)))
1.0ms
x
@inf
(*.f64 x (/.f64 100 (+.f64 x y)))
1.0ms
y
@-inf
(*.f64 x (/.f64 100 (+.f64 x y)))
1.0ms
y
@0
(*.f64 x (/.f64 100 (+.f64 x y)))

rewrite211.0ms (5.6%)

Algorithm
batch-egg-rewrite
Rules
874×pow1_binary64
821×add-log-exp_binary64
821×log1p-expm1-u_binary64
821×expm1-log1p-u_binary64
805×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify82.0ms (2.2%)

Algorithm
egg-herbie
Rules
880×fma-def_binary64
708×associate-/r*_binary64
650×associate-*l/_binary64
530×associate-*r*_binary64
472×associate-*l*_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
040522
1117516
2351474
31390426
47821378
Stop Event
node limit
Counts
46 → 37
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
Outputs
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 x (/.f64 y 100))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (/.f64 x y) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) (+.f64 (/.f64 x (/.f64 y 100)) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 (fma.f64 (/.f64 x y) (/.f64 x y) 1) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) (*.f64 100 (fma.f64 (/.f64 y x) (/.f64 y x) 1)))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) (fma.f64 -100 (/.f64 y x) 100))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) (*.f64 100 (fma.f64 (/.f64 y x) (/.f64 y x) 1)))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) (fma.f64 -100 (/.f64 y x) 100))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) (*.f64 100 (fma.f64 (/.f64 y x) (/.f64 y x) 1)))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) (fma.f64 -100 (/.f64 y x) 100))
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 x (/.f64 y 100))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (/.f64 x y) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) (+.f64 (/.f64 x (/.f64 y 100)) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 (fma.f64 (/.f64 x y) (/.f64 x y) 1) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 x (/.f64 y 100))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (/.f64 x y) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) (+.f64 (/.f64 x (/.f64 y 100)) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 (fma.f64 (/.f64 x y) (/.f64 x y) 1) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))

localize15.0ms (0.4%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.4b
(/.f64 (*.f64 x 100) (+.f64 x y))
Compiler

Compiled 18 to 9 computations (50% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite90.0ms (2.4%)

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

Useful iterations: 0 (0.0ms)

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

simplify67.0ms (1.8%)

Algorithm
egg-herbie
Rules
880×fma-def_binary64
708×associate-/r*_binary64
650×associate-*l/_binary64
530×associate-*r*_binary64
472×associate-*l*_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
040522
1117516
2351474
31390426
47821378
Stop Event
node limit
Counts
67 → 58
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
Outputs
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 x (/.f64 y 100))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (/.f64 x y) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) (+.f64 (/.f64 x (/.f64 y 100)) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 (fma.f64 (/.f64 x y) (/.f64 x y) 1) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) (*.f64 100 (fma.f64 (/.f64 y x) (/.f64 y x) 1)))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) (fma.f64 -100 (/.f64 y x) 100))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) (*.f64 100 (fma.f64 (/.f64 y x) (/.f64 y x) 1)))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) (fma.f64 -100 (/.f64 y x) 100))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) (*.f64 100 (fma.f64 (/.f64 y x) (/.f64 y x) 1)))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) (fma.f64 -100 (/.f64 y x) 100))
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 x (/.f64 y 100))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (/.f64 x y) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) (+.f64 (/.f64 x (/.f64 y 100)) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 (fma.f64 (/.f64 x y) (/.f64 x y) 1) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 x (/.f64 y 100))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (/.f64 x y) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 x y) (*.f64 (/.f64 x y) -100)))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) (+.f64 (/.f64 x (/.f64 y 100)) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 (fma.f64 (/.f64 x y) (/.f64 x y) 1) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))

eval26.0ms (0.7%)

Compiler

Compiled 1195 to 679 computations (43.2% saved)

prune20.0ms (0.5%)

Pruning

8 alts after pruning (6 fresh and 2 done)

PrunedKeptTotal
New89695
Fresh000
Picked011
Done011
Total89897
Error
0b
Counts
97 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 x (/.f64 100 (+.f64 x y)))
36.2b
(+.f64 100 (*.f64 -100 (/.f64 y x)))
0.5b
(pow.f64 (*.f64 1/100 (/.f64 (+.f64 x y) x)) -1)
0.4b
(/.f64 (*.f64 x 100) (+.f64 x y))
27.3b
(/.f64 x (/.f64 y 100))
27.4b
(*.f64 100 (/.f64 x y))
35.5b
100
1.4b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) (pow.f64 (cbrt.f64 (+.f64 x y)) 2)) (cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100))))
Compiler

Compiled 137 to 99 computations (27.7% saved)

localize45.0ms (1.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (+.f64 x y) x)
0.1b
(*.f64 1/100 (/.f64 (+.f64 x y) x))
0.5b
(pow.f64 (*.f64 1/100 (/.f64 (+.f64 x y) x)) -1)
Compiler

Compiled 30 to 12 computations (60% saved)

series9.0ms (0.2%)

Counts
3 → 72
Calls

18 calls:

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

rewrite80.0ms (2.1%)

Algorithm
batch-egg-rewrite
Rules
476×log-prod_binary64
473×prod-diff_binary64
284×pow-prod-down_binary64
261×pow2_binary64
185×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0930
120527
2278727
Stop Event
node limit
Counts
3 → 111
Calls
Call 1
Inputs
(pow.f64 (*.f64 1/100 (/.f64 (+.f64 x y) x)) -1)
(*.f64 1/100 (/.f64 (+.f64 x y) x))
(/.f64 (+.f64 x y) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 100 (/.f64 x (+.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 100) (/.f64 x (+.f64 x y)))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 100) (/.f64 x (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 100) (/.f64 x (+.f64 x y))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 100) (/.f64 x (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 100 (/.f64 x (+.f64 x y))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 100 (/.f64 x (+.f64 x y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 100 (/.f64 x (+.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 100 (/.f64 x (+.f64 x y)))) (pow.f64 (cbrt.f64 (*.f64 100 (/.f64 x (+.f64 x y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 100 (/.f64 x (+.f64 x y)))) 2) (cbrt.f64 (*.f64 100 (/.f64 x (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 100 (/.f64 x (+.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (+.f64 x y)) 100)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 10 (sqrt.f64 (/.f64 x (+.f64 x y)))) (*.f64 10 (sqrt.f64 (/.f64 x (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (*.f64 1/100 (+.f64 x y))) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) -2) (cbrt.f64 (*.f64 100 (/.f64 x (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (neg.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 1/100 (+.f64 x y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 100 (/.f64 (+.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 x (+.f64 x y)) 1/100)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 10 (sqrt.f64 (/.f64 x (+.f64 x y)))) (sqrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (cbrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) -2) (cbrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 10000 (pow.f64 (/.f64 x (+.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 100) (/.f64 x (+.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 100 (/.f64 x (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) -3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 100 (/.f64 x (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 100 (/.f64 x (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 100 (/.f64 x (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 100 (/.f64 x (+.f64 x y)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 100 (/.f64 x (+.f64 x y))))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x))) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 100 (/.f64 x (+.f64 x y))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 10 (sqrt.f64 (/.f64 x (+.f64 x y))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) 1) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 100 (/.f64 x (+.f64 x y)))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) -1/2) 2))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (*.f64 1/100 (+.f64 x y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 1/100) (/.f64 (+.f64 x y) x))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 1/100) (/.f64 (+.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 1/100) (/.f64 (+.f64 x y) x)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 1/100) (/.f64 (+.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1/100 (/.f64 x (+.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 x (*.f64 1/100 (+.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 1/100 (+.f64 x y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 1/100 (+.f64 x y))) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) 1) x)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (+.f64 x y)) 1/100) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 1/100 (neg.f64 (+.f64 x y))) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (*.f64 1/100 (+.f64 x y))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/100) (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (*.f64 1/100 (+.f64 x y)) x)) 1) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (+.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (+.f64 x y) x))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (+.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (+.f64 x y) x)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (+.f64 x y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (+.f64 x y) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x y) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (+.f64 x y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (+.f64 x y) x)) (pow.f64 (cbrt.f64 (/.f64 (+.f64 x y) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (+.f64 x y) x)) 2) (cbrt.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 x y)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (+.f64 x y) x)) (sqrt.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (+.f64 x y)) (/.f64 1 (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 x) (+.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 1) (/.f64 (cbrt.f64 (+.f64 x y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 1) (/.f64 (sqrt.f64 (+.f64 x y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) -2) (/.f64 (+.f64 x y) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (+.f64 x y)) (pow.f64 (cbrt.f64 x) 2)) (/.f64 (sqrt.f64 (+.f64 x y)) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x -1/2) (/.f64 (+.f64 x y) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (sqrt.f64 x)) (/.f64 (cbrt.f64 (+.f64 x y)) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 x y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x y) x) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (+.f64 x y) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (+.f64 x y) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (+.f64 x y) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 x (+.f64 x y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (+.f64 x y) 3) (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 x (+.f64 x y)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (+.f64 x y) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (+.f64 x y) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (+.f64 x y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (+.f64 x y) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (+.f64 x y) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (+.f64 x y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (+.f64 x y) x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (/.f64 (+.f64 x y) x) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (+.f64 x y) x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 (+.f64 x y) x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 x (+.f64 x y))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (+.f64 x y) x)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (+.f64 x y) x)) -1) -1))))))

simplify76.0ms (2%)

Algorithm
egg-herbie
Rules
886×fma-def_binary64
715×associate-/r*_binary64
656×associate-*l/_binary64
535×associate-*r*_binary64
478×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
046867
1128825
2366783
31418735
47930735
Stop Event
node limit
Counts
183 → 135
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(*.f64 100 (/.f64 x y))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(*.f64 1/100 (/.f64 y x))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
1/100
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
1/100
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
1/100
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(*.f64 1/100 (/.f64 y x))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(*.f64 1/100 (/.f64 y x))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(/.f64 y x)
(+.f64 1 (/.f64 y x))
(+.f64 1 (/.f64 y x))
(+.f64 1 (/.f64 y x))
1
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
1
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
1
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(/.f64 y x)
(+.f64 1 (/.f64 y x))
(+.f64 1 (/.f64 y x))
(+.f64 1 (/.f64 y x))
(/.f64 y x)
(+.f64 1 (/.f64 y x))
(+.f64 1 (/.f64 y x))
(+.f64 1 (/.f64 y x))
Outputs
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 (*.f64 100 x) y)
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 (/.f64 -100 y) (/.f64 x (/.f64 y x)) (/.f64 100 (/.f64 y x)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 -100 y) (/.f64 x (/.f64 y x))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 100 (*.f64 (/.f64 y x) (/.f64 y x)) (fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) 100))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 100 (*.f64 (/.f64 y x) (/.f64 y x)) (fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) 100))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
100
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(fma.f64 -100 (/.f64 y x) 100)
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (*.f64 -100 (/.f64 y x))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (/.f64 y x))))
(+.f64 (fma.f64 -100 (/.f64 y x) 100) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x)))
(fma.f64 (fma.f64 (/.f64 y x) (/.f64 y x) 1) 100 (*.f64 -100 (/.f64 y x)))
(+.f64 100 (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x)))))
(+.f64 100 (+.f64 (*.f64 100 (/.f64 (pow.f64 y 2) (pow.f64 x 2))) (+.f64 (*.f64 -100 (/.f64 y x)) (*.f64 -100 (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 100 (/.f64 (*.f64 y y) (*.f64 x x)) (*.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))))))
(+.f64 100 (fma.f64 -100 (+.f64 (/.f64 y x) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (*.f64 (/.f64 100 x) (/.f64 (*.f64 y y) x))))
(fma.f64 100 (*.f64 (/.f64 y x) (/.f64 y x)) (fma.f64 -100 (+.f64 (/.f64 y x) (pow.f64 (/.f64 y x) 3)) 100))
(+.f64 100 (fma.f64 -100 (pow.f64 (/.f64 y x) 3) (*.f64 (/.f64 y x) (+.f64 -100 (*.f64 100 (/.f64 y x))))))
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 (*.f64 100 x) y)
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 (/.f64 -100 y) (/.f64 x (/.f64 y x)) (/.f64 100 (/.f64 y x)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 -100 y) (/.f64 x (/.f64 y x))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 100 (/.f64 x y))
(/.f64 100 (/.f64 y x))
(/.f64 (*.f64 100 x) y)
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (*.f64 100 (/.f64 x y)))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (/.f64 x y)))
(fma.f64 100 (/.f64 x y) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 (/.f64 -100 y) (/.f64 x (/.f64 y x)) (/.f64 100 (/.f64 y x)))
(*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (*.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3)))))
(fma.f64 100 (+.f64 (/.f64 x y) (/.f64 (pow.f64 x 3) (pow.f64 y 3))) (/.f64 (*.f64 -100 (*.f64 x x)) (*.f64 y y)))
(fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 (/.f64 -100 y) (/.f64 x (/.f64 y x))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100))))
(+.f64 (*.f64 -100 (/.f64 (pow.f64 x 2) (pow.f64 y 2))) (+.f64 (*.f64 100 (/.f64 x y)) (+.f64 (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (/.f64 (*.f64 x x) (*.f64 y y)) (fma.f64 100 (/.f64 x y) (fma.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)) (*.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (/.f64 x y) (fma.f64 100 (/.f64 (pow.f64 x 3) (pow.f64 y 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4))))))
(fma.f64 -100 (*.f64 (/.f64 x y) (/.f64 x y)) (fma.f64 100 (+.f64 (/.f64 x y) (pow.f64 (/.f64 x y) 3)) (*.f64 -100 (/.f64 (pow.f64 x 4) (pow.f64 y 4)))))
(fma.f64 100 (pow.f64 (/.f64 x y) 3) (fma.f64 -100 (pow.f64 (/.f64 x y) 4) (*.f64 (/.f64 x y) (+.f64 100 (*.f64 (/.f64 x y) -100)))))
(*.f64 1/100 (/.f64 y x))
(*.f64 (/.f64 y x) 1/100)
(*.f64 y (/.f64 1/100 x))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
1/100
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
1/100
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
1/100
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(*.f64 1/100 (/.f64 y x))
(*.f64 (/.f64 y x) 1/100)
(*.f64 y (/.f64 1/100 x))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(*.f64 1/100 (/.f64 y x))
(*.f64 (/.f64 y x) 1/100)
(*.f64 y (/.f64 1/100 x))
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(+.f64 1/100 (*.f64 1/100 (/.f64 y x)))
(+.f64 1/100 (*.f64 (/.f64 y x) 1/100))
(fma.f64 (/.f64 y x) 1/100 1/100)
(/.f64 y x)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
1
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
1
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
1
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(+.f64 (/.f64 y x) 1)
(/.f64 y x)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(/.f64 y x)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)
(+.f64 1 (/.f64 y x))
(+.f64 (/.f64 y x) 1)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.3b
(*.f64 100 (/.f64 x y))
Compiler

Compiled 13 to 6 computations (53.8% saved)

series5.0ms (0.1%)

Counts
1 → 0
Calls

6 calls:

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

rewrite62.0ms (1.6%)

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

Useful iterations: 0 (0.0ms)

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

simplify8.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize7.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(/.f64 x (/.f64 y 100))
Compiler

Compiled 13 to 8 computations (38.5% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite56.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
712×pow1_binary64
673×add-log-exp_binary64
673×log1p-expm1-u_binary64
673×expm1-log1p-u_binary64
660×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify12.0ms (0.3%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-*r/_binary64
associate-*l/_binary64
associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
19168
213168
317168
418168
Stop Event
saturated
Counts
62 → 38
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
Outputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))

localize9.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 -100 (/.f64 y x))
Compiler

Compiled 21 to 11 computations (47.6% saved)

series4.0ms (0.1%)

Counts
1 → 0
Calls

6 calls:

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

rewrite50.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
653×pow1_binary64
608×add-log-exp_binary64
608×log1p-expm1-u_binary64
608×expm1-log1p-u_binary64
596×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify8.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize38.0ms (1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.6b
(cbrt.f64 (+.f64 x y))
0.6b
(pow.f64 (cbrt.f64 (*.f64 x 100)) 2)
0.8b
(cbrt.f64 (*.f64 x 100))
9.9b
(cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100)))
Compiler

Compiled 88 to 49 computations (44.3% saved)

series23.0ms (0.6%)

Counts
4 → 20
Calls

18 calls:

TimeVariablePointExpression
3.0ms
x
@inf
(cbrt.f64 (*.f64 x 100))
3.0ms
x
@0
(pow.f64 (cbrt.f64 (*.f64 x 100)) 2)
2.0ms
x
@-inf
(cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100)))
2.0ms
x
@0
(cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100)))
2.0ms
x
@inf
(cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100)))

rewrite82.0ms (2.2%)

Algorithm
batch-egg-rewrite
Rules
649×log-prod_binary64
482×prod-diff_binary64
344×pow2_binary64
240×expm1-udef_binary64
240×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01433
129933
2368333
Stop Event
node limit
Counts
4 → 107
Calls
Call 1
Inputs
(cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100)))
(cbrt.f64 (*.f64 x 100))
(pow.f64 (cbrt.f64 (*.f64 x 100)) 2)
(cbrt.f64 (+.f64 x y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))) (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))) (cbrt.f64 (cbrt.f64 (/.f64 (pow.f64 (/.f64 x (+.f64 x y)) 2) 1/10000))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (/.f64 (pow.f64 (/.f64 x (+.f64 x y)) 2) 1/10000))) (cbrt.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (cbrt.f64 (/.f64 100 (+.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (/.f64 1 (cbrt.f64 (*.f64 (+.f64 x y) 1/100))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (/.f64 100 (+.f64 x y))) 1/6) (pow.f64 (*.f64 x (/.f64 100 (+.f64 x y))) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (cbrt.f64 (*.f64 1/100 (/.f64 (+.f64 x y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cbrt.f64 (*.f64 (+.f64 x y) 1/100)) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 x) (cbrt.f64 (*.f64 (+.f64 x y) 1/100)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (neg.f64 x)) (cbrt.f64 (*.f64 (+.f64 x y) -1/100)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (/.f64 x (+.f64 x y))) (cbrt.f64 1/100))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (cbrt.f64 x)) (neg.f64 (cbrt.f64 (*.f64 (+.f64 x y) 1/100))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (/.f64 100 (+.f64 x y))) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (/.f64 100 (+.f64 x y))) 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 1/100 (/.f64 (+.f64 x y) x))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cbrt.f64 (*.f64 (+.f64 x y) 1/100)) (cbrt.f64 x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (cbrt.f64 (/.f64 (pow.f64 (/.f64 x (+.f64 x y)) 2) 1/10000)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y)))))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (/.f64 100 (+.f64 x y)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x (/.f64 100 (+.f64 x y))))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cbrt.f64 (*.f64 x 100)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cbrt.f64 (*.f64 x 100)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cbrt.f64 (*.f64 x 100))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 (*.f64 x 100))))) (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 (*.f64 x 100))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cbrt.f64 (*.f64 x 100)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 100)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 (*.f64 x 100)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (cbrt.f64 100))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 100) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2) (cbrt.f64 (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x 100) 1/6) (pow.f64 (*.f64 x 100) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 4))) (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (cbrt.f64 (*.f64 x 100)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 100) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 100)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x 100) 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (cbrt.f64 (*.f64 x 100)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cbrt.f64 (*.f64 x 100)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x 100)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x 100))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2))) 2)) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 100)) (cbrt.f64 (*.f64 x 100)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (*.f64 (cbrt.f64 100) (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 10000))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2) (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 4)) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x 100) 1/6) (*.f64 (pow.f64 (*.f64 x 100) 1/6) (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 x) 10) (pow.f64 (*.f64 x 100) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 x 100)) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 100))) 2)) (cbrt.f64 (cbrt.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 x 100)) (cbrt.f64 x)) (cbrt.f64 100))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 x x) 10000))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2/3 (log.f64 (*.f64 x 100))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2/3 (log.f64 (*.f64 x 100))) 1))))))
((#(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 (cbrt.f64 (pow.f64 (+.f64 x y) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (pow.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 (pow.f64 1 1/3) (cbrt.f64 (+.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (-.f64 (*.f64 x x) (*.f64 y y))) (cbrt.f64 (-.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (+.f64 (pow.f64 x 3) (pow.f64 y 3))) (cbrt.f64 (fma.f64 y (-.f64 y x) (*.f64 x x))))))) (#(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 (cbrt.f64 (cbrt.f64 (+.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 x y) 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (cbrt.f64 (pow.f64 (+.f64 x y) 2)))))) (#(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))))))

simplify83.0ms (2.2%)

Algorithm
egg-herbie
Rules
778×fma-def_binary64
709×associate-/r/_binary64
520×times-frac_binary64
396×*-commutative_binary64
359×associate-/l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0153940
1474886
21759855
36437821
Stop Event
node limit
Counts
127 → 141
Calls
Call 1
Inputs
(cbrt.f64 100)
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (cbrt.f64 100))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2))) (cbrt.f64 100)) (pow.f64 x 2))) (cbrt.f64 100)))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2))) (cbrt.f64 100)) (pow.f64 x 2))) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 -1/27 (pow.f64 y 3)) (+.f64 (pow.f64 y 3) (+.f64 (*.f64 1/3 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2))) y)) (*.f64 1/3 (*.f64 y (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2)))))))) (cbrt.f64 100)) (pow.f64 x 3))) (cbrt.f64 100))))
(*.f64 (cbrt.f64 -1) (cbrt.f64 -100))
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)) 1/3) (/.f64 (*.f64 y (cbrt.f64 -100)) x))) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)))
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)) 1/3) (/.f64 (*.f64 y (cbrt.f64 -100)) x))) (+.f64 (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)) (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (cbrt.f64 -1)) 1/3) (pow.f64 y 2))) (pow.f64 y 2)) (cbrt.f64 -100)) (*.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 x 2))))))
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)) 1/3) (/.f64 (*.f64 y (cbrt.f64 -100)) x))) (+.f64 (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (cbrt.f64 -1)) 1/3) (pow.f64 y 2))) (pow.f64 y 2)) (cbrt.f64 -100)) (*.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 x 2)))) (*.f64 1/3 (/.f64 (*.f64 (cbrt.f64 -100) (+.f64 (pow.f64 y 3) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 5)) 1/3) (*.f64 y (+.f64 (pow.f64 y 2) (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (cbrt.f64 -1)) 1/3) (pow.f64 y 2))))))) (*.f64 -1/27 (/.f64 (pow.f64 y 3) (pow.f64 (cbrt.f64 -1) 2)))))) (*.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 x 3)))))))
(cbrt.f64 100)
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (cbrt.f64 100))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (cbrt.f64 100) (*.f64 2/9 (/.f64 (*.f64 (pow.f64 y 2) (cbrt.f64 100)) (pow.f64 x 2)))))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (*.f64 -14/81 (/.f64 (*.f64 (pow.f64 y 3) (cbrt.f64 100)) (pow.f64 x 3))) (+.f64 (cbrt.f64 100) (*.f64 2/9 (/.f64 (*.f64 (pow.f64 y 2) (cbrt.f64 100)) (pow.f64 x 2))))))
(pow.f64 y 1/3)
(+.f64 (pow.f64 y 1/3) (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/9) x)))
(+.f64 (pow.f64 y 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/9) x)) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/9) (pow.f64 x 2)))))
(+.f64 (pow.f64 y 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/9) x)) (+.f64 (*.f64 -1/3 (*.f64 (*.f64 (+.f64 (*.f64 1/27 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/3)) (*.f64 -2/9 (*.f64 (pow.f64 (pow.f64 1 4) 1/9) (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/3)))) (pow.f64 x 3)) (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/3))) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/9) (pow.f64 x 2))))))
(pow.f64 x 1/3)
(+.f64 (pow.f64 x 1/3) (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/9) y)))
(+.f64 (pow.f64 x 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/9) y)) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/9) (pow.f64 y 2)))))
(+.f64 (pow.f64 x 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/9) y)) (+.f64 (*.f64 -1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/3) (*.f64 (pow.f64 y 3) (+.f64 (*.f64 1/27 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/3)) (*.f64 -2/9 (*.f64 (pow.f64 (pow.f64 1 4) 1/9) (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/3))))))) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/9) (pow.f64 y 2))))))
Outputs
(cbrt.f64 100)
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (cbrt.f64 100))
(fma.f64 -1/3 (/.f64 y (/.f64 x (cbrt.f64 100))) (cbrt.f64 100))
(fma.f64 -1/3 (*.f64 (/.f64 y x) (cbrt.f64 100)) (cbrt.f64 100))
(fma.f64 -1/3 (*.f64 (cbrt.f64 100) (/.f64 y x)) (cbrt.f64 100))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2))) (cbrt.f64 100)) (pow.f64 x 2))) (cbrt.f64 100)))
(fma.f64 -1/3 (/.f64 y (/.f64 x (cbrt.f64 100))) (fma.f64 -1/3 (/.f64 (*.f64 (cbrt.f64 100) (*.f64 (*.f64 y y) -2/3)) (*.f64 x x)) (cbrt.f64 100)))
(fma.f64 -1/3 (*.f64 (/.f64 y x) (cbrt.f64 100)) (fma.f64 -1/3 (*.f64 (/.f64 (cbrt.f64 100) x) (/.f64 (*.f64 (*.f64 y y) -2/3) x)) (cbrt.f64 100)))
(fma.f64 -1/3 (*.f64 (cbrt.f64 100) (+.f64 (/.f64 y x) (*.f64 (/.f64 y (/.f64 x y)) (/.f64 -2/3 x)))) (cbrt.f64 100))
(fma.f64 -1/3 (*.f64 (/.f64 (cbrt.f64 100) x) (+.f64 y (*.f64 (/.f64 y (/.f64 x y)) -2/3))) (cbrt.f64 100))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2))) (cbrt.f64 100)) (pow.f64 x 2))) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 -1/27 (pow.f64 y 3)) (+.f64 (pow.f64 y 3) (+.f64 (*.f64 1/3 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2))) y)) (*.f64 1/3 (*.f64 y (+.f64 (*.f64 -1 (pow.f64 y 2)) (*.f64 1/3 (pow.f64 y 2)))))))) (cbrt.f64 100)) (pow.f64 x 3))) (cbrt.f64 100))))
(fma.f64 -1/3 (/.f64 y (/.f64 x (cbrt.f64 100))) (fma.f64 -1/3 (/.f64 (*.f64 (cbrt.f64 100) (*.f64 (*.f64 y y) -2/3)) (*.f64 x x)) (fma.f64 -1/3 (/.f64 (fma.f64 -1/27 (pow.f64 y 3) (+.f64 (pow.f64 y 3) (*.f64 1/3 (+.f64 (*.f64 y (*.f64 (*.f64 y y) -2/3)) (*.f64 y (*.f64 (*.f64 y y) -2/3)))))) (/.f64 (pow.f64 x 3) (cbrt.f64 100))) (cbrt.f64 100))))
(fma.f64 -1/3 (*.f64 (/.f64 y x) (cbrt.f64 100)) (fma.f64 -1/3 (*.f64 (/.f64 (cbrt.f64 100) x) (/.f64 (*.f64 (*.f64 y y) -2/3) x)) (fma.f64 -1/3 (*.f64 (/.f64 (+.f64 (*.f64 (*.f64 (pow.f64 y 3) -2/3) 2/3) (*.f64 26/27 (pow.f64 y 3))) (pow.f64 x 3)) (cbrt.f64 100)) (cbrt.f64 100))))
(fma.f64 -1/3 (*.f64 (cbrt.f64 100) (+.f64 (*.f64 (/.f64 y (/.f64 x y)) (/.f64 -2/3 x)) (/.f64 (fma.f64 1/3 (*.f64 (pow.f64 y 3) -4/3) (*.f64 (pow.f64 y 3) 26/27)) (pow.f64 x 3)))) (fma.f64 -1/3 (*.f64 (cbrt.f64 100) (/.f64 y x)) (cbrt.f64 100)))
(+.f64 (cbrt.f64 100) (*.f64 -1/3 (*.f64 (/.f64 (cbrt.f64 100) x) (+.f64 y (+.f64 (*.f64 (/.f64 y (/.f64 x y)) -2/3) (/.f64 (fma.f64 1/3 (*.f64 (pow.f64 y 3) -4/3) (*.f64 (pow.f64 y 3) 26/27)) (*.f64 x x)))))))
(*.f64 (cbrt.f64 -1) (cbrt.f64 -100))
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)) 1/3) (/.f64 (*.f64 y (cbrt.f64 -100)) x))) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)))
(fma.f64 1/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (/.f64 y (/.f64 x (cbrt.f64 -100)))) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)))
(fma.f64 (*.f64 1/3 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)))) (*.f64 (/.f64 y x) (cbrt.f64 -100)) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)))
(fma.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (*.f64 1/3 (*.f64 (cbrt.f64 -100) (/.f64 y x))) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)))
(*.f64 (cbrt.f64 -100) (+.f64 (cbrt.f64 -1) (/.f64 (*.f64 y (*.f64 1/3 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))))) x)))
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)) 1/3) (/.f64 (*.f64 y (cbrt.f64 -100)) x))) (+.f64 (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)) (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (cbrt.f64 -1)) 1/3) (pow.f64 y 2))) (pow.f64 y 2)) (cbrt.f64 -100)) (*.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 x 2))))))
(fma.f64 1/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (/.f64 y (/.f64 x (cbrt.f64 -100)))) (fma.f64 (cbrt.f64 -1) (cbrt.f64 -100) (*.f64 -1/3 (*.f64 (/.f64 (fma.f64 1/3 (*.f64 (*.f64 y y) (cbrt.f64 (/.f64 1 (cbrt.f64 -1)))) (*.f64 y y)) (pow.f64 (cbrt.f64 -1) 2)) (/.f64 (cbrt.f64 -100) (*.f64 x x))))))
(fma.f64 1/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (*.f64 (/.f64 y x) (cbrt.f64 -100))) (fma.f64 -1/3 (*.f64 (/.f64 (*.f64 (+.f64 (*.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1)))) 1) (*.f64 y y)) (pow.f64 (cbrt.f64 -1) 2)) (/.f64 (/.f64 (cbrt.f64 -100) x) x)) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100))))
(fma.f64 (/.f64 (fma.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1))) 1) (/.f64 (pow.f64 (cbrt.f64 -1) 2) (*.f64 y y))) (/.f64 (*.f64 -1/3 (cbrt.f64 -100)) (*.f64 x x)) (fma.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (*.f64 1/3 (*.f64 (cbrt.f64 -100) (/.f64 y x))) (*.f64 (cbrt.f64 -1) (cbrt.f64 -100))))
(fma.f64 -1/3 (*.f64 (cbrt.f64 -100) (*.f64 (/.f64 (fma.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1))) 1) (pow.f64 (cbrt.f64 -1) 2)) (*.f64 (/.f64 y x) (/.f64 y x)))) (*.f64 (cbrt.f64 -100) (+.f64 (cbrt.f64 -1) (/.f64 (*.f64 y (*.f64 1/3 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))))) x))))
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2)) 1/3) (/.f64 (*.f64 y (cbrt.f64 -100)) x))) (+.f64 (*.f64 (cbrt.f64 -1) (cbrt.f64 -100)) (+.f64 (*.f64 -1/3 (/.f64 (*.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (cbrt.f64 -1)) 1/3) (pow.f64 y 2))) (pow.f64 y 2)) (cbrt.f64 -100)) (*.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 x 2)))) (*.f64 1/3 (/.f64 (*.f64 (cbrt.f64 -100) (+.f64 (pow.f64 y 3) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 5)) 1/3) (*.f64 y (+.f64 (pow.f64 y 2) (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (cbrt.f64 -1)) 1/3) (pow.f64 y 2))))))) (*.f64 -1/27 (/.f64 (pow.f64 y 3) (pow.f64 (cbrt.f64 -1) 2)))))) (*.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 x 3)))))))
(fma.f64 1/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (/.f64 y (/.f64 x (cbrt.f64 -100)))) (fma.f64 (cbrt.f64 -1) (cbrt.f64 -100) (fma.f64 -1/3 (*.f64 (/.f64 (fma.f64 1/3 (*.f64 (*.f64 y y) (cbrt.f64 (/.f64 1 (cbrt.f64 -1)))) (*.f64 y y)) (pow.f64 (cbrt.f64 -1) 2)) (/.f64 (cbrt.f64 -100) (*.f64 x x))) (*.f64 1/3 (*.f64 (/.f64 (cbrt.f64 -100) (pow.f64 (cbrt.f64 -1) 2)) (/.f64 (+.f64 (pow.f64 y 3) (fma.f64 2/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 5))) (*.f64 y (fma.f64 1/3 (*.f64 (*.f64 y y) (cbrt.f64 (/.f64 1 (cbrt.f64 -1)))) (*.f64 y y)))) (*.f64 -1/27 (/.f64 (pow.f64 y 3) (pow.f64 (cbrt.f64 -1) 2))))) (pow.f64 x 3)))))))
(fma.f64 1/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (*.f64 (/.f64 y x) (cbrt.f64 -100))) (fma.f64 (cbrt.f64 -1) (cbrt.f64 -100) (fma.f64 -1/3 (*.f64 (/.f64 (*.f64 (+.f64 (*.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1)))) 1) (*.f64 y y)) (pow.f64 (cbrt.f64 -1) 2)) (/.f64 (/.f64 (cbrt.f64 -100) x) x)) (/.f64 (*.f64 (*.f64 1/3 (cbrt.f64 -100)) (+.f64 (pow.f64 y 3) (fma.f64 (*.f64 2/3 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 5)))) (+.f64 (pow.f64 y 3) (*.f64 (*.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1)))) (pow.f64 y 3))) (/.f64 -1/27 (/.f64 (pow.f64 (cbrt.f64 -1) 2) (pow.f64 y 3)))))) (*.f64 (pow.f64 x 3) (pow.f64 (cbrt.f64 -1) 2))))))
(fma.f64 1/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))) (*.f64 (cbrt.f64 -100) (/.f64 y x))) (fma.f64 -1/3 (*.f64 (cbrt.f64 -100) (*.f64 (/.f64 (fma.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1))) 1) (pow.f64 (cbrt.f64 -1) 2)) (*.f64 (/.f64 y x) (/.f64 y x)))) (fma.f64 (cbrt.f64 -1) (cbrt.f64 -100) (*.f64 (*.f64 (fma.f64 -1/27 (/.f64 (pow.f64 y 3) (pow.f64 (cbrt.f64 -1) 2)) (fma.f64 2/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 5))) (*.f64 (fma.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1))) 1) (pow.f64 y 3))) (pow.f64 y 3))) (/.f64 (cbrt.f64 -100) (pow.f64 (cbrt.f64 -1) 2))) (/.f64 1/3 (pow.f64 x 3))))))
(+.f64 (*.f64 (cbrt.f64 -100) (+.f64 (cbrt.f64 -1) (/.f64 (*.f64 y (*.f64 1/3 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 2))))) x))) (*.f64 (/.f64 (cbrt.f64 -100) (pow.f64 (cbrt.f64 -1) 2)) (+.f64 (/.f64 (*.f64 -1/3 (*.f64 y (*.f64 (fma.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1))) 1) y))) (*.f64 x x)) (*.f64 1/3 (/.f64 (fma.f64 2/3 (*.f64 (cbrt.f64 (/.f64 1 (pow.f64 (cbrt.f64 -1) 5))) (*.f64 (fma.f64 1/3 (cbrt.f64 (/.f64 1 (cbrt.f64 -1))) 1) (pow.f64 y 3))) (*.f64 (+.f64 (/.f64 -1/27 (pow.f64 (cbrt.f64 -1) 2)) 1) (pow.f64 y 3))) (pow.f64 x 3))))))
(cbrt.f64 100)
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (cbrt.f64 100))
(fma.f64 -1/3 (/.f64 y (/.f64 x (cbrt.f64 100))) (cbrt.f64 100))
(fma.f64 -1/3 (*.f64 (/.f64 y x) (cbrt.f64 100)) (cbrt.f64 100))
(fma.f64 -1/3 (*.f64 (cbrt.f64 100) (/.f64 y x)) (cbrt.f64 100))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (cbrt.f64 100) (*.f64 2/9 (/.f64 (*.f64 (pow.f64 y 2) (cbrt.f64 100)) (pow.f64 x 2)))))
(fma.f64 -1/3 (/.f64 y (/.f64 x (cbrt.f64 100))) (+.f64 (cbrt.f64 100) (*.f64 2/9 (/.f64 (*.f64 (cbrt.f64 100) (*.f64 y y)) (*.f64 x x)))))
(fma.f64 -1/3 (*.f64 (/.f64 y x) (cbrt.f64 100)) (fma.f64 2/9 (*.f64 (/.f64 (cbrt.f64 100) x) (/.f64 (*.f64 y y) x)) (cbrt.f64 100)))
(fma.f64 -1/3 (*.f64 (cbrt.f64 100) (/.f64 y x)) (fma.f64 2/9 (*.f64 (/.f64 (cbrt.f64 100) x) (/.f64 y (/.f64 x y))) (cbrt.f64 100)))
(+.f64 (cbrt.f64 100) (*.f64 (cbrt.f64 100) (+.f64 (/.f64 (*.f64 -1/3 y) x) (/.f64 (*.f64 (*.f64 y y) 2/9) (*.f64 x x)))))
(+.f64 (*.f64 -1/3 (/.f64 (*.f64 y (cbrt.f64 100)) x)) (+.f64 (*.f64 -14/81 (/.f64 (*.f64 (pow.f64 y 3) (cbrt.f64 100)) (pow.f64 x 3))) (+.f64 (cbrt.f64 100) (*.f64 2/9 (/.f64 (*.f64 (pow.f64 y 2) (cbrt.f64 100)) (pow.f64 x 2))))))
(fma.f64 -1/3 (/.f64 y (/.f64 x (cbrt.f64 100))) (fma.f64 -14/81 (/.f64 (pow.f64 y 3) (/.f64 (pow.f64 x 3) (cbrt.f64 100))) (+.f64 (cbrt.f64 100) (*.f64 2/9 (/.f64 (*.f64 (cbrt.f64 100) (*.f64 y y)) (*.f64 x x))))))
(fma.f64 -1/3 (*.f64 (/.f64 y x) (cbrt.f64 100)) (fma.f64 -14/81 (*.f64 (/.f64 (pow.f64 y 3) (pow.f64 x 3)) (cbrt.f64 100)) (fma.f64 2/9 (*.f64 (/.f64 (cbrt.f64 100) x) (/.f64 (*.f64 y y) x)) (cbrt.f64 100))))
(fma.f64 -1/3 (*.f64 (cbrt.f64 100) (/.f64 y x)) (fma.f64 -14/81 (*.f64 (cbrt.f64 100) (/.f64 (pow.f64 y 3) (pow.f64 x 3))) (fma.f64 2/9 (*.f64 (/.f64 (cbrt.f64 100) x) (/.f64 y (/.f64 x y))) (cbrt.f64 100))))
(+.f64 (fma.f64 -14/81 (*.f64 (cbrt.f64 100) (pow.f64 (/.f64 y x) 3)) (cbrt.f64 100)) (*.f64 (cbrt.f64 100) (+.f64 (/.f64 (*.f64 -1/3 y) x) (/.f64 (*.f64 (*.f64 y y) 2/9) (*.f64 x x)))))
(pow.f64 y 1/3)
(cbrt.f64 y)
(+.f64 (pow.f64 y 1/3) (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/9) x)))
(+.f64 (cbrt.f64 y) (*.f64 1/3 (*.f64 x (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18)))))
(fma.f64 1/3 (*.f64 x (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (cbrt.f64 y))
(fma.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (*.f64 x (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (cbrt.f64 y))
(+.f64 (pow.f64 y 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/9) x)) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/9) (pow.f64 x 2)))))
(+.f64 (cbrt.f64 y) (fma.f64 1/3 (*.f64 x (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (*.f64 -1/9 (*.f64 (*.f64 x x) (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18))))))
(+.f64 (cbrt.f64 y) (fma.f64 1/3 (*.f64 x (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (*.f64 (*.f64 x x) (*.f64 (*.f64 -1/9 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18)) (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18)))))
(fma.f64 x (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (fma.f64 (*.f64 x x) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18))) (cbrt.f64 y)))
(+.f64 (pow.f64 y 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/9) x)) (+.f64 (*.f64 -1/3 (*.f64 (*.f64 (+.f64 (*.f64 1/27 (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/3)) (*.f64 -2/9 (*.f64 (pow.f64 (pow.f64 1 4) 1/9) (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/3)))) (pow.f64 x 3)) (pow.f64 (/.f64 1 (pow.f64 y 2)) 1/3))) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/9) (pow.f64 x 2))))))
(+.f64 (cbrt.f64 y) (fma.f64 1/3 (*.f64 x (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (fma.f64 -1/3 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 y y))) (*.f64 (pow.f64 x 3) (fma.f64 1/27 (cbrt.f64 (/.f64 1 (*.f64 y y))) (*.f64 -2/9 (cbrt.f64 (/.f64 1 (*.f64 y y))))))) (*.f64 -1/9 (*.f64 (*.f64 x x) (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18)))))))
(+.f64 (fma.f64 1/3 (*.f64 x (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (cbrt.f64 y)) (fma.f64 -1/3 (*.f64 (pow.f64 x 3) (*.f64 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 y y))) -5/27) (cbrt.f64 (/.f64 1 (*.f64 y y))))) (*.f64 (*.f64 x x) (*.f64 (*.f64 -1/9 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18)) (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18)))))
(+.f64 (cbrt.f64 y) (fma.f64 -1/3 (*.f64 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 y y))) -5/27) (*.f64 (pow.f64 x 3) (cbrt.f64 (/.f64 1 (*.f64 y y))))) (*.f64 x (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (*.f64 y y)) 1/18) (pow.f64 (/.f64 1 (*.f64 y y)) 1/18))) (*.f64 x (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 y 7)) 1/18))))))))
(pow.f64 x 1/3)
(cbrt.f64 x)
(+.f64 (pow.f64 x 1/3) (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/9) y)))
(+.f64 (cbrt.f64 x) (*.f64 1/3 (*.f64 y (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)))))
(fma.f64 1/3 (*.f64 (*.f64 y (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)) (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)) (cbrt.f64 x))
(fma.f64 y (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (*.f64 1/3 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18))) (cbrt.f64 x))
(+.f64 (pow.f64 x 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/9) y)) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/9) (pow.f64 y 2)))))
(+.f64 (cbrt.f64 x) (fma.f64 1/3 (*.f64 y (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (pow.f64 (/.f64 1 (*.f64 x x)) 1/18))) (*.f64 -1/9 (*.f64 (*.f64 y y) (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18))))))
(+.f64 (cbrt.f64 x) (fma.f64 1/3 (*.f64 (*.f64 y (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)) (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)) (*.f64 (*.f64 y y) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18))))))
(fma.f64 y (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (*.f64 1/3 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18))) (fma.f64 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18)) (*.f64 (*.f64 y y) -1/9) (cbrt.f64 x)))
(+.f64 (pow.f64 x 1/3) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/9) y)) (+.f64 (*.f64 -1/3 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/3) (*.f64 (pow.f64 y 3) (+.f64 (*.f64 1/27 (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/3)) (*.f64 -2/9 (*.f64 (pow.f64 (pow.f64 1 4) 1/9) (pow.f64 (/.f64 1 (pow.f64 x 2)) 1/3))))))) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/9) (pow.f64 y 2))))))
(+.f64 (cbrt.f64 x) (fma.f64 1/3 (*.f64 y (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (pow.f64 (/.f64 1 (*.f64 x x)) 1/18))) (fma.f64 -1/3 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 x x))) (*.f64 (pow.f64 y 3) (fma.f64 1/27 (cbrt.f64 (/.f64 1 (*.f64 x x))) (*.f64 -2/9 (cbrt.f64 (/.f64 1 (*.f64 x x))))))) (*.f64 -1/9 (*.f64 (*.f64 y y) (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18)))))))
(+.f64 (fma.f64 1/3 (*.f64 (*.f64 y (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)) (pow.f64 (/.f64 1 (*.f64 x x)) 1/18)) (cbrt.f64 x)) (fma.f64 -1/3 (*.f64 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 x x))) -5/27) (*.f64 (pow.f64 y 3) (cbrt.f64 (/.f64 1 (*.f64 x x))))) (*.f64 (*.f64 y y) (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18))))))
(+.f64 (cbrt.f64 x) (fma.f64 -1/3 (*.f64 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 x x))) -5/27) (*.f64 (pow.f64 y 3) (cbrt.f64 (/.f64 1 (*.f64 x x))))) (*.f64 y (+.f64 (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (*.f64 1/3 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18))) (*.f64 y (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18))))))))
(+.f64 (cbrt.f64 x) (fma.f64 -1/3 (*.f64 (cbrt.f64 (/.f64 1 (*.f64 x x))) (*.f64 (cbrt.f64 (/.f64 1 (*.f64 x x))) (*.f64 (pow.f64 y 3) -5/27))) (*.f64 y (+.f64 (*.f64 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18) (*.f64 1/3 (pow.f64 (/.f64 1 (*.f64 x x)) 1/18))) (*.f64 y (*.f64 -1/9 (*.f64 (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18) (pow.f64 (/.f64 1 (pow.f64 x 7)) 1/18))))))))

eval252.0ms (6.7%)

Compiler

Compiled 6986 to 4523 computations (35.3% saved)

prune101.0ms (2.7%)

Pruning

8 alts after pruning (4 fresh and 4 done)

PrunedKeptTotal
New3513354
Fresh011
Picked011
Done336
Total3548362
Error
0b
Counts
362 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 x (/.f64 100 (+.f64 x y)))
36.2b
(+.f64 100 (*.f64 -100 (/.f64 y x)))
1.4b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) (pow.f64 (cbrt.f64 (+.f64 x y)) 2)) (cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100))))
27.4b
(*.f64 (/.f64 100 y) x)
27.8b
(/.f64 100 (/.f64 y x))
27.4b
(*.f64 100 (/.f64 x y))
27.3b
(/.f64 (*.f64 100 x) y)
35.5b
100
Compiler

Compiled 73 to 53 computations (27.4% saved)

localize11.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.4b
(*.f64 (/.f64 100 y) x)
Compiler

Compiled 13 to 8 computations (38.5% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite55.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
614×pow1_binary64
574×add-log-exp_binary64
574×log1p-expm1-u_binary64
574×expm1-log1p-u_binary64
563×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify13.0ms (0.3%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-*r/_binary64
associate-*l/_binary64
associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
19168
213168
317168
418168
Stop Event
saturated
Counts
45 → 22
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
Outputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.6b
(/.f64 100 (/.f64 y x))
Compiler

Compiled 13 to 6 computations (53.8% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite54.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
696×pow1_binary64
653×add-log-exp_binary64
653×log1p-expm1-u_binary64
653×expm1-log1p-u_binary64
640×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify11.0ms (0.3%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-*r/_binary64
associate-*l/_binary64
associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
19168
213168
317168
418168
Stop Event
saturated
Counts
50 → 26
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
Outputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (*.f64 100 x) y)
Compiler

Compiled 13 to 8 computations (38.5% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite53.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
682×pow1_binary64
640×add-log-exp_binary64
640×log1p-expm1-u_binary64
640×expm1-log1p-u_binary64
627×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify12.0ms (0.3%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-*r/_binary64
associate-*l/_binary64
associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
19168
213168
317168
418168
Stop Event
saturated
Counts
65 → 41
Calls
Call 1
Inputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
Outputs
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))
(*.f64 100 (/.f64 x y))

eval18.0ms (0.5%)

Compiler

Compiled 769 to 476 computations (38.1% saved)

prune15.0ms (0.4%)

Pruning

8 alts after pruning (1 fresh and 7 done)

PrunedKeptTotal
New89089
Fresh011
Picked011
Done066
Total89897
Error
0b
Counts
97 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 x (/.f64 100 (+.f64 x y)))
36.2b
(+.f64 100 (*.f64 -100 (/.f64 y x)))
1.4b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) (pow.f64 (cbrt.f64 (+.f64 x y)) 2)) (cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100))))
27.4b
(*.f64 (/.f64 100 y) x)
27.8b
(/.f64 100 (/.f64 y x))
27.4b
(*.f64 100 (/.f64 x y))
27.3b
(/.f64 (*.f64 100 x) y)
35.5b
100
Compiler

Compiled 73 to 53 computations (27.4% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune4.0ms (0.1%)

Pruning

8 alts after pruning (1 fresh and 7 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done077
Total088
Error
0b
Counts
8 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 x (/.f64 100 (+.f64 x y)))
36.2b
(+.f64 100 (*.f64 -100 (/.f64 y x)))
1.4b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) (pow.f64 (cbrt.f64 (+.f64 x y)) 2)) (cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100))))
27.4b
(*.f64 (/.f64 100 y) x)
27.8b
(/.f64 100 (/.f64 y x))
27.4b
(*.f64 100 (/.f64 x y))
27.3b
(/.f64 (*.f64 100 x) y)
35.5b
100
Compiler

Compiled 73 to 53 computations (27.4% saved)

regimes27.0ms (0.7%)

Counts
11 → 1
Calls
Call 1
Inputs
100
(*.f64 (/.f64 100 y) x)
(/.f64 100 (/.f64 y x))
(/.f64 (*.f64 100 x) y)
(/.f64 x (/.f64 y 100))
(*.f64 100 (/.f64 x y))
(+.f64 100 (*.f64 -100 (/.f64 y x)))
(*.f64 x (/.f64 100 (+.f64 x y)))
(/.f64 (*.f64 x 100) (+.f64 x y))
(pow.f64 (*.f64 1/100 (/.f64 (+.f64 x y) x)) -1)
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x 100)) 2) (pow.f64 (cbrt.f64 (+.f64 x y)) 2)) (cbrt.f64 (/.f64 x (*.f64 (+.f64 x y) 1/100))))
Outputs
(*.f64 x (/.f64 100 (+.f64 x y)))
Calls

4 calls:

8.0ms
y
6.0ms
x
5.0ms
(/.f64 (*.f64 x 100) (+.f64 x y))
5.0ms
(/.f64 (*.f64 x 100) (+.f64 x y))
Results
ErrorSegmentsBranch
0.2b1x
0.2b1y
0.2b1(/.f64 (*.f64 x 100) (+.f64 x y))
0.2b1(/.f64 (*.f64 x 100) (+.f64 x y))
Compiler

Compiled 104 to 64 computations (38.5% saved)

regimes37.0ms (1%)

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

2 calls:

21.0ms
x
13.0ms
y
Results
ErrorSegmentsBranch
12.1b5x
12.8b3y
Compiler

Compiled 41 to 26 computations (36.6% saved)

bsearch64.0ms (1.7%)

Algorithm
binary-search
Steps
TimeLeftRight
16.0ms
2.613042532516956e+170
1.2969310268724833e+172
16.0ms
3.572295006533607e+111
4.661884352685314e+115
16.0ms
8.284860875722656e+91
1.5773933714110625e+92
16.0ms
-1.0946692789448324e+55
-8.243845342461022e+44
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes38.0ms (1%)

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

2 calls:

21.0ms
x
15.0ms
y
Results
ErrorSegmentsBranch
12.2b5x
12.8b3y
Compiler

Compiled 34 to 22 computations (35.3% saved)

bsearch66.0ms (1.7%)

Algorithm
binary-search
Steps
TimeLeftRight
17.0ms
2.613042532516956e+170
1.2969310268724833e+172
16.0ms
3.572295006533607e+111
4.661884352685314e+115
16.0ms
8.284860875722656e+91
1.5773933714110625e+92
17.0ms
-1.0946692789448324e+55
-8.243845342461022e+44
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes28.0ms (0.7%)

Counts
3 → 5
Calls
Call 1
Inputs
100
(*.f64 (/.f64 100 y) x)
(/.f64 100 (/.f64 y x))
Outputs
100
(*.f64 (/.f64 100 y) x)
100
(/.f64 100 (/.f64 y x))
100
Calls

2 calls:

17.0ms
x
10.0ms
y
Results
ErrorSegmentsBranch
12.2b5x
12.8b3y
Compiler

Compiled 19 to 13 computations (31.6% saved)

bsearch66.0ms (1.8%)

Algorithm
binary-search
Steps
TimeLeftRight
17.0ms
2.613042532516956e+170
1.2969310268724833e+172
16.0ms
3.572295006533607e+111
4.661884352685314e+115
16.0ms
8.284860875722656e+91
1.5773933714110625e+92
17.0ms
-1.0946692789448324e+55
-8.243845342461022e+44
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes24.0ms (0.7%)

Accuracy

Total -49.8b remaining (-407.7%)

Threshold costs -49.8b (-407.7%)

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

2 calls:

15.0ms
x
9.0ms
y
Results
ErrorSegmentsBranch
12.2b5x
12.8b3y
Compiler

Compiled 14 to 10 computations (28.6% saved)

bsearch66.0ms (1.8%)

Algorithm
binary-search
Steps
TimeLeftRight
17.0ms
2.613042532516956e+170
1.2969310268724833e+172
16.0ms
3.572295006533607e+111
4.661884352685314e+115
16.0ms
8.284860875722656e+91
1.5773933714110625e+92
18.0ms
-1.0946692789448324e+55
-8.243845342461022e+44
Compiler

Compiled 14 to 10 computations (28.6% saved)

simplify8.0ms (0.2%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
038184
144184
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 x (/.f64 100 (+.f64 x y)))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (/.f64 (*.f64 100 x) y) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) (+.f64 100 (*.f64 -100 (/.f64 y x))) (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (/.f64 (*.f64 100 x) y) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (*.f64 (/.f64 100 y) x) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (*.f64 (/.f64 100 y) x) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (*.f64 (/.f64 100 y) x) 100))))
100
Outputs
(*.f64 x (/.f64 100 (+.f64 x y)))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (/.f64 (*.f64 100 x) y) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) (+.f64 100 (*.f64 -100 (/.f64 y x))) (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (/.f64 (*.f64 x 100) y) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) (+.f64 100 (*.f64 -100 (/.f64 y x))) (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (/.f64 (*.f64 100 x) y) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (/.f64 (*.f64 x 100) y) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (*.f64 (/.f64 100 y) x) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (*.f64 x (/.f64 100 y)) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (/.f64 100 (/.f64 y x)) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (*.f64 (/.f64 100 y) x) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (*.f64 (/.f64 100 y) x) 100))))
(if (<=.f64 x -10946692789448323648399671827382577349669014542579924992) 100 (if (<=.f64 x 82848608757226559733599746444752443095543349538398778622153248515235276236980424194062811136) (*.f64 x (/.f64 100 y)) (if (<=.f64 x 3572295006533606994476629104945010313534551518146544420612239201583255195888142776715826971429515813862600867840) 100 (if (<=.f64 x 261304253251695578300122099176571545550743579161340469986363603175611239234026597104624440474246698924167246825246196033829782160489993563172913061315542444351556463624192) (*.f64 x (/.f64 100 y)) 100))))
100
Compiler

Compiled 142 to 104 computations (26.8% saved)

soundness8.0ms (0.2%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-/r/_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11110
21510
31810
41910
Stop Event
saturated
Compiler

Compiled 18 to 12 computations (33.3% saved)

end68.0ms (1.8%)

Compiler

Compiled 132 to 92 computations (30.3% saved)

Profiling

Loading profile data...