Details

Time bar (total: 11.8s)

analyze232.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
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
25%25%74.9%0.1%0%0%0%7
37.5%37.4%62.4%0.1%0%0%0%8
37.5%37.4%62.4%0.1%0%0%0%9
56.3%56.2%43.7%0.1%0%0%0%10
65.6%65.5%34.3%0.1%0%0%0%11
65.6%65.5%34.3%0.1%0%0%0%12
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample2.5s (21.5%)

Results
1.1s2067×body1024valid
1.1s5169×body256valid
318.0ms1018×body512valid
1.0msbody2048valid
Bogosity

preprocess20.0ms (0.2%)

Algorithm
egg-herbie
Rules
16×fma-def_binary64
*-commutative_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02248
13848
25048
033
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 y (cos.f64 x)) (*.f64 z (sin.f64 x)))
(+.f64 (*.f64 z (cos.f64 y)) (*.f64 x (sin.f64 y)))
(+.f64 (*.f64 x (cos.f64 z)) (*.f64 y (sin.f64 z)))
Outputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 y (cos.f64 x)) (*.f64 z (sin.f64 x)))
(fma.f64 y (cos.f64 x) (*.f64 z (sin.f64 x)))
(+.f64 (*.f64 z (cos.f64 y)) (*.f64 x (sin.f64 y)))
(fma.f64 z (cos.f64 y) (*.f64 x (sin.f64 y)))
(fma.f64 x (sin.f64 y) (*.f64 (cos.f64 y) z))
(+.f64 (*.f64 x (cos.f64 z)) (*.f64 y (sin.f64 z)))
(fma.f64 x (cos.f64 z) (*.f64 y (sin.f64 z)))
Compiler

Compiled 15 to 11 computations (26.7% saved)

simplify44.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0912
11312
21612
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
Outputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))

eval1.0ms (0%)

Compiler

Compiled 20 to 9 computations (55% saved)

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
0.2b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
Compiler

Compiled 12 to 8 computations (33.3% saved)

localize14.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(cos.f64 y)
0.0b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.2b
(*.f64 z (sin.f64 y))
0.2b
(*.f64 x (cos.f64 y))
Compiler

Compiled 27 to 8 computations (70.4% saved)

series15.0ms (0.1%)

Counts
4 → 68
Calls

24 calls:

TimeVariablePointExpression
1.0ms
x
@0
(*.f64 x (cos.f64 y))
1.0ms
z
@-inf
(*.f64 z (sin.f64 y))
1.0ms
z
@0
(*.f64 z (sin.f64 y))
1.0ms
y
@0
(*.f64 x (cos.f64 y))
1.0ms
y
@0
(*.f64 z (sin.f64 y))

rewrite79.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
484×log-prod_binary64
382×prod-exp_binary64
361×exp-prod_binary64
332×pow-prod-down_binary64
325×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0927
118727
2249727
Stop Event
node limit
Counts
4 → 167
Calls
Call 1
Inputs
(*.f64 x (cos.f64 y))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(cos.f64 y)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (cos.f64 y))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (cos.f64 y)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (cos.f64 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (cos.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (cos.f64 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (*.f64 x (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 x (cos.f64 y)))) 2)) (cbrt.f64 (log.f64 (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 x (cos.f64 y))))) (sqrt.f64 (log.f64 (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (cos.f64 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x (cos.f64 y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 x (cos.f64 y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 x (cos.f64 y)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x (cos.f64 y))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x (cos.f64 y))) 3) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 x) 1) (log.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 x) (*.f64 (log.f64 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 x) 1) (*.f64 (log.f64 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (cos.f64 y)) 1) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 (cos.f64 y)) (*.f64 (log.f64 x) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (cos.f64 y)) 1) (*.f64 (log.f64 x) 1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 z) (sin.f64 y))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 z) (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 z) (sin.f64 y)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 z) (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 z (sin.f64 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 z (sin.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 z (sin.f64 y)))) 2)) (cbrt.f64 (log.f64 (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 z (sin.f64 y))))) (sqrt.f64 (log.f64 (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 z) (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 z (sin.f64 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 z (sin.f64 y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 z (sin.f64 y))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 z (sin.f64 y))) 3) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 z) 1) (log.f64 (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 z) (*.f64 (log.f64 (sin.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 z) 1) (*.f64 (log.f64 (sin.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (sin.f64 y)) 1) (log.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 (sin.f64 y)) (*.f64 (log.f64 z) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (sin.f64 y)) 1) (*.f64 (log.f64 z) 1)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y)))) (/.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) (pow.f64 (cbrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) 2) (cbrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) (sqrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3)) (/.f64 1 (fma.f64 (*.f64 z (sin.f64 y)) (-.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) (pow.f64 (*.f64 x (cos.f64 y)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (pow.f64 (*.f64 z (sin.f64 y)) 2)) (/.f64 1 (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (*.f64 z (sin.f64 y)) (-.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) (pow.f64 (*.f64 x (cos.f64 y)) 2)) (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y))) (-.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (pow.f64 (*.f64 z (sin.f64 y)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3)) (fma.f64 (*.f64 z (sin.f64 y)) (-.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) (pow.f64 (*.f64 x (cos.f64 y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3)) (+.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (-.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (*.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (pow.f64 (*.f64 z (sin.f64 y)) 2)) (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3))) (neg.f64 (fma.f64 (*.f64 z (sin.f64 y)) (-.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) (pow.f64 (*.f64 x (cos.f64 y)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (pow.f64 (*.f64 z (sin.f64 y)) 2))) (neg.f64 (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (pow.f64 (*.f64 x (cos.f64 y)) 2)) (-.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (*.f64 z (sin.f64 y)) (-.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) (pow.f64 (*.f64 x (cos.f64 y)) 2)) (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (cos.f64 y) (*.f64 (neg.f64 z) (sin.f64 y))) (-.f64 (pow.f64 (*.f64 x (cos.f64 y)) 2) (pow.f64 (*.f64 z (sin.f64 y)) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))) 2)) (cbrt.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))) (sqrt.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x (cos.f64 y)))) (pow.f64 (exp.f64 z) (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 x) (cos.f64 y)) (+.f64 1 (expm1.f64 (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x (cos.f64 y)))) (+.f64 1 (expm1.f64 (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 z (sin.f64 y)))) (pow.f64 (exp.f64 x) (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 z) (sin.f64 y)) (+.f64 1 (expm1.f64 (*.f64 x (cos.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 z (sin.f64 y)))) (+.f64 1 (expm1.f64 (*.f64 x (cos.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (cos.f64 y)) 1 (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sin.f64 y) z (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 z (sin.f64 y)) 1 (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2) (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x (cos.f64 y))) (pow.f64 (cbrt.f64 (*.f64 x (cos.f64 y))) 2) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x (cos.f64 y))) 2) (cbrt.f64 (*.f64 x (cos.f64 y))) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (cos.f64 y)) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 z) 2) (*.f64 (cbrt.f64 z) (sin.f64 y)) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (sin.f64 y) 2)) (*.f64 (cbrt.f64 (sin.f64 y)) z) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (cos.f64 y) 2)) (*.f64 (cbrt.f64 (cos.f64 y)) x) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (sqrt.f64 (*.f64 z (sin.f64 y))) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x (cos.f64 y))) (sqrt.f64 (*.f64 x (cos.f64 y))) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (sin.f64 y)) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (sin.f64 y)) (*.f64 (sqrt.f64 (sin.f64 y)) z) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (cos.f64 y)) (*.f64 (sqrt.f64 (cos.f64 y)) x) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 z (cbrt.f64 (pow.f64 (sin.f64 y) 2))) (cbrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sin.f64 y) (pow.f64 (cbrt.f64 z) 2)) (cbrt.f64 z) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 2))) (cbrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) (sqrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cos.f64 y) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cos.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 y))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 y))) (sin.f64 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cos.f64 y))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 y)))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 y)) (cbrt.f64 (pow.f64 (cos.f64 y) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cos.f64 y) 2)) (cbrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 y)) (sqrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 y) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 y) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 y)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (cos.f64 y))) 2)) (cbrt.f64 (log.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (cos.f64 y)))) (sqrt.f64 (log.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cos.f64 y)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (cos.f64 y) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (cos.f64 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (cos.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (cos.f64 y)) 1) 1))))))

simplify284.0ms (2.4%)

Algorithm
egg-herbie
Rules
682×sqr-pow_binary64
626×cube-prod_binary64
460×*-commutative_binary64
443×pow-sqr_binary64
408×distribute-lft-out_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
062706
1165699
2449676
31471674
42337674
53446674
63584674
73801674
84016674
94298674
104713674
115214674
125790674
136480674
146990674
157384674
167770674
Stop Event
node limit
Counts
235 → 198
Calls
Call 1
Inputs
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 y z)
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (*.f64 y z))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (*.f64 1/120 (*.f64 (pow.f64 y 5) z))))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (+.f64 (*.f64 -1/5040 (*.f64 (pow.f64 y 7) z)) (*.f64 1/120 (*.f64 (pow.f64 y 5) z)))))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
x
(+.f64 (*.f64 y z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
Outputs
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(fma.f64 -1/2 (*.f64 x (*.f64 y y)) x)
(*.f64 (fma.f64 -1/2 (*.f64 y y) 1) x)
(*.f64 x (fma.f64 y (*.f64 y -1/2) 1))
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 1/24 (*.f64 x (pow.f64 y 4)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x))
(+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(*.f64 x (fma.f64 y (*.f64 y -1/2) (fma.f64 1/24 (pow.f64 y 4) 1)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 -1/720 (*.f64 x (pow.f64 y 6)) (fma.f64 1/24 (*.f64 x (pow.f64 y 4)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x)))
(fma.f64 -1/720 (*.f64 x (pow.f64 y 6)) (+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(+.f64 x (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 y (*.f64 y -1/2) (*.f64 1/24 (pow.f64 y 4))))))
(*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 y (*.f64 y -1/2) (fma.f64 1/24 (pow.f64 y 4) 1))))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 y z)
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (*.f64 y z))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 y z))
(*.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))))
(*.f64 z (fma.f64 -1/6 (pow.f64 y 3) y))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (*.f64 1/120 (*.f64 (pow.f64 y 5) z))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (*.f64 1/120 (*.f64 z (pow.f64 y 5)))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 z (+.f64 (*.f64 1/120 (pow.f64 y 5)) y)))
(*.f64 z (+.f64 (fma.f64 -1/6 (pow.f64 y 3) y) (*.f64 1/120 (pow.f64 y 5))))
(*.f64 z (+.f64 (*.f64 -1/6 (pow.f64 y 3)) (fma.f64 1/120 (pow.f64 y 5) y)))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (+.f64 (*.f64 -1/5040 (*.f64 (pow.f64 y 7) z)) (*.f64 1/120 (*.f64 (pow.f64 y 5) z)))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (fma.f64 -1/5040 (*.f64 z (pow.f64 y 7)) (*.f64 1/120 (*.f64 z (pow.f64 y 5))))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (*.f64 z (+.f64 (*.f64 1/120 (pow.f64 y 5)) (*.f64 -1/5040 (pow.f64 y 7))))))
(*.f64 z (+.f64 (fma.f64 -1/6 (pow.f64 y 3) y) (fma.f64 1/120 (pow.f64 y 5) (*.f64 -1/5040 (pow.f64 y 7)))))
(*.f64 z (+.f64 (fma.f64 1/120 (pow.f64 y 5) (*.f64 -1/5040 (pow.f64 y 7))) (fma.f64 -1/6 (pow.f64 y 3) y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
x
(+.f64 (*.f64 y z) x)
(fma.f64 y z x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 y z (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x))
(fma.f64 y z (*.f64 (fma.f64 -1/2 (*.f64 y y) 1) x))
(fma.f64 x (*.f64 y (*.f64 y -1/2)) (fma.f64 y z x))
(fma.f64 y z (*.f64 x (fma.f64 y (*.f64 y -1/2) 1)))
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x)))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 (fma.f64 -1/2 (*.f64 y y) 1) x)))
(fma.f64 z (fma.f64 -1/6 (pow.f64 y 3) y) (*.f64 x (fma.f64 y (*.f64 y -1/2) 1)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (*.f64 -1/2 (*.f64 y y)))
(fma.f64 -1/2 (*.f64 y y) 1)
(fma.f64 y (*.f64 y -1/2) 1)
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) 1) (*.f64 1/24 (pow.f64 y 4)))
(fma.f64 y (*.f64 y -1/2) (fma.f64 1/24 (pow.f64 y 4) 1))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 (fma.f64 -1/2 (*.f64 y y) 1) (*.f64 1/24 (pow.f64 y 4))))
(fma.f64 -1/720 (pow.f64 y 6) (fma.f64 y (*.f64 y -1/2) (fma.f64 1/24 (pow.f64 y 4) 1)))

eval124.0ms (1.1%)

Compiler

Compiled 2987 to 1031 computations (65.5% saved)

prune65.0ms (0.5%)

Pruning

23 alts after pruning (22 fresh and 1 done)

PrunedKeptTotal
New17622198
Fresh000
Picked011
Done000
Total17623199
Error
0.0b
Counts
199 → 23
Alt Table
Click to see full alt table
StatusErrorProgram
24.5b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 y z))
31.0b
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
32.4b
(+.f64 (pow.f64 (sqrt.f64 (*.f64 x (cos.f64 y))) 2) (*.f64 z (sin.f64 y)))
16.6b
(+.f64 (*.f64 x (pow.f64 (sqrt.f64 (cos.f64 y)) 2)) (*.f64 z (sin.f64 y)))
0.8b
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.4b
(+.f64 (*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (*.f64 z (sin.f64 y)))
16.6b
(fma.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) (sqrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
26.4b
(+.f64 (*.f64 x (cos.f64 y)) (pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2))
0.3b
(fma.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 2))) (cbrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.7b
(+.f64 (*.f64 x (cos.f64 y)) (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3))
32.2b
(fma.f64 y z x)
34.4b
(fma.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z) (*.f64 x (cos.f64 y)))
14.5b
(+.f64 x (*.f64 z (sin.f64 y)))
3.7b
(fma.f64 (*.f64 z (cbrt.f64 (pow.f64 (sin.f64 y) 2))) (cbrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
0.3b
(+.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (*.f64 z (sin.f64 y)))
21.3b
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))
0.2b
(+.f64 (*.f64 x (log.f64 (exp.f64 (cos.f64 y)))) (*.f64 z (sin.f64 y)))
0.3b
(+.f64 (*.f64 x (+.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 y)))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 y)))))) (*.f64 z (sin.f64 y)))
0.2b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
32.2b
(+.f64 (*.f64 y z) x)
36.1b
(fma.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
35.0b
(*.f64 z (sin.f64 y))
0.2b
(+.f64 (*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)) (*.f64 z (sin.f64 y)))
Compiler

Compiled 638 to 426 computations (33.2% saved)

localize28.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1))
0.2b
(exp.f64 (log1p.f64 (cos.f64 y)))
0.3b
(log1p.f64 (cos.f64 y))
0.3b
(-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)
Compiler

Compiled 49 to 18 computations (63.3% saved)

series145.0ms (1.2%)

Counts
4 → 60
Calls

15 calls:

TimeVariablePointExpression
62.0ms
x
@-inf
(*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1))
28.0ms
y
@inf
(-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)
27.0ms
y
@-inf
(-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)
23.0ms
x
@0
(*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1))
1.0ms
y
@0
(-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)

rewrite157.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
758×pow1_binary64
700×add-log-exp_binary64
699×expm1-log1p-u_binary64
698×log1p-expm1-u_binary64
685×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0921
118020
2194420
Stop Event
node limit
Counts
4 → 94
Calls
Call 1
Inputs
(-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)
(log1p.f64 (cos.f64 y))
(exp.f64 (log1p.f64 (cos.f64 y)))
(*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (cos.f64 y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (+.f64 1 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 y)) (pow.f64 (cbrt.f64 (cos.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 y)) 2) (cbrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 y)) (sqrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1) (/.f64 1 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (+.f64 (+.f64 1 (cos.f64 y)) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1) (/.f64 1 (+.f64 (+.f64 1 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 1) (-.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (+.f64 (+.f64 1 (cos.f64 y)) 1)) (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1) (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (+.f64 (+.f64 1 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1) (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (-.f64 1 (*.f64 (+.f64 1 (cos.f64 y)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1) (+.f64 (+.f64 1 (cos.f64 y)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1) (-.f64 (+.f64 1 (cos.f64 y)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1)) (neg.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (+.f64 (+.f64 1 (cos.f64 y)) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1)) (neg.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 y) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 y)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 y)))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (cos.f64 y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 2) (cbrt.f64 (+.f64 1 (cos.f64 y))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) (sqrt.f64 (+.f64 1 (cos.f64 y))) -1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log1p.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 2)) (log.f64 (cbrt.f64 (+.f64 1 (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (+.f64 1 (cos.f64 y)))) (log.f64 (sqrt.f64 (+.f64 1 (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (log1p.f64 (cos.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log1p.f64 (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log1p.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log1p.f64 (cos.f64 y))) (pow.f64 (cbrt.f64 (log1p.f64 (cos.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log1p.f64 (cos.f64 y))) 2) (cbrt.f64 (log1p.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log1p.f64 (cos.f64 y))) (sqrt.f64 (log1p.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log1p.f64 (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log1p.f64 (cos.f64 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (log1p.f64 (cos.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log1p.f64 (cos.f64 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (log1p.f64 (cos.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log1p.f64 (cos.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (log1p.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (log1p.f64 (cos.f64 y))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (cos.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 y) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1 (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 1 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) (pow.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 2) (cbrt.f64 (+.f64 1 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 2) (*.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) (sqrt.f64 (+.f64 1 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) (*.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 (cos.f64 y) 3)) (+.f64 1 (-.f64 (pow.f64 (cos.f64 y) 2) (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 (cos.f64 y) 2)) (-.f64 1 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 1 (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log1p.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 1 (cos.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log1p.f64 (cos.f64 y)))) (sqrt.f64 (log1p.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log1p.f64 (cos.f64 y))) 2)) (cbrt.f64 (log1p.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 1 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 1 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 1 (cos.f64 y))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (+.f64 1 (cos.f64 y))) (*.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (cos.f64 y) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1) x) (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (+.f64 (+.f64 1 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1) x) (+.f64 (+.f64 1 (cos.f64 y)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 3) -1)) (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) (+.f64 (+.f64 1 (cos.f64 y)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (pow.f64 (+.f64 1 (cos.f64 y)) 2) -1)) (+.f64 (+.f64 1 (cos.f64 y)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cos.f64 y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (cos.f64 y) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cos.f64 y) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cos.f64 y) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (cos.f64 y) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (cos.f64 y) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (cos.f64 y) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (cos.f64 y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cos.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (cos.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cos.f64 y) x)))))))

simplify160.0ms (1.4%)

Algorithm
egg-herbie
Rules
886×fma-def_binary64
640×distribute-rgt-in_binary64
629×distribute-rgt-out_binary64
574×associate-*l*_binary64
566×distribute-lft-out_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
049458
1119450
2307435
3951433
43651433
56064433
66406433
76636433
86853433
97126433
107463433
Stop Event
node limit
Counts
154 → 124
Calls
Call 1
Inputs
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(log.f64 2)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (log.f64 2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (log.f64 2) (*.f64 -1/96 (pow.f64 y 4))))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (log.f64 2) (+.f64 (*.f64 -1/1440 (pow.f64 y 6)) (*.f64 -1/96 (pow.f64 y 4)))))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
(log.f64 (+.f64 1 (cos.f64 y)))
2
(+.f64 2 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
Outputs
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (*.f64 -1/2 (*.f64 y y)))
(fma.f64 -1/2 (*.f64 y y) 1)
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) 1) (*.f64 1/24 (pow.f64 y 4)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) (fma.f64 -1/720 (pow.f64 y 6) 1))
(fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)))
(fma.f64 (*.f64 y y) (fma.f64 (*.f64 y y) 1/24 -1/2) (fma.f64 -1/720 (pow.f64 y 6) 1))
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(log.f64 2)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (log.f64 2))
(fma.f64 -1/4 (*.f64 y y) (log.f64 2))
(fma.f64 (*.f64 y y) -1/4 (log.f64 2))
(fma.f64 y (*.f64 y -1/4) (log.f64 2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (log.f64 2) (*.f64 -1/96 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/4 (*.f64 y y) (log.f64 2)) (*.f64 (pow.f64 y 4) -1/96))
(fma.f64 (*.f64 y y) -1/4 (fma.f64 (pow.f64 y 4) -1/96 (log.f64 2)))
(fma.f64 y (*.f64 y -1/4) (fma.f64 (pow.f64 y 4) -1/96 (log.f64 2)))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (log.f64 2) (+.f64 (*.f64 -1/1440 (pow.f64 y 6)) (*.f64 -1/96 (pow.f64 y 4)))))
(+.f64 (fma.f64 -1/4 (*.f64 y y) (log.f64 2)) (fma.f64 -1/1440 (pow.f64 y 6) (*.f64 (pow.f64 y 4) -1/96)))
(+.f64 (fma.f64 (*.f64 y y) -1/4 (log.f64 2)) (fma.f64 (pow.f64 y 4) -1/96 (*.f64 (pow.f64 y 6) -1/1440)))
(fma.f64 y (*.f64 y -1/4) (fma.f64 (pow.f64 y 4) -1/96 (fma.f64 (pow.f64 y 6) -1/1440 (log.f64 2))))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
(log.f64 (+.f64 1 (cos.f64 y)))
(log1p.f64 (cos.f64 y))
2
(+.f64 2 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 2 (*.f64 -1/2 (*.f64 y y)))
(fma.f64 -1/2 (*.f64 y y) 2)
(+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 2 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 1/24 (pow.f64 y 4)) (fma.f64 -1/2 (*.f64 y y) 2))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 2 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) (fma.f64 -1/720 (pow.f64 y 6) 2))
(fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2)))
(fma.f64 (*.f64 y y) (fma.f64 (*.f64 y y) 1/24 -1/2) (fma.f64 -1/720 (pow.f64 y 6) 2))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 1/24 (pow.f64 y 4) 2)))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(+.f64 1 (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)
(*.f64 (fma.f64 -1/2 (*.f64 y y) 1) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x))
(+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(*.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)))
(fma.f64 (*.f64 (*.f64 y y) (fma.f64 (*.f64 y y) 1/24 -1/2)) x x)
(*.f64 (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)) x)
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(+.f64 x (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(*.f64 x (fma.f64 (*.f64 y y) (fma.f64 (*.f64 y y) 1/24 -1/2) (fma.f64 -1/720 (pow.f64 y 6) 1)))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)

localize5.0ms (0%)

Local error

Found 1 expressions with local error:

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

Compiled 14 to 5 computations (64.3% saved)

series4.0ms (0%)

Counts
1 → 9
Calls

9 calls:

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

rewrite54.0ms (0.5%)

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

Useful iterations: 0 (0.0ms)

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

simplify8.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0524
1624
Stop Event
saturated
Counts
44 → 37
Calls
Call 1
Inputs
x
(*.f64 y z)
(*.f64 y z)
x
(*.f64 y z)
(*.f64 y z)
(*.f64 y z)
x
x
Outputs
x
(*.f64 y z)
(*.f64 y z)
x
(*.f64 y z)
(*.f64 y z)
(*.f64 y z)
x
x

localize20.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(exp.f64 (cos.f64 y))
0.2b
(*.f64 z (sin.f64 y))
0.2b
(*.f64 x (log.f64 (exp.f64 (cos.f64 y))))
0.4b
(log.f64 (exp.f64 (cos.f64 y)))
Compiler

Compiled 38 to 10 computations (73.7% saved)

series4.0ms (0%)

Counts
3 → 40
Calls

12 calls:

TimeVariablePointExpression
1.0ms
y
@0
(exp.f64 (cos.f64 y))
0.0ms
y
@0
(log.f64 (exp.f64 (cos.f64 y)))
0.0ms
y
@inf
(exp.f64 (cos.f64 y))
0.0ms
y
@-inf
(log.f64 (exp.f64 (cos.f64 y)))
0.0ms
y
@-inf
(exp.f64 (cos.f64 y))

rewrite53.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
531×pow1_binary64
504×add-sqr-sqrt_binary64
484×log1p-expm1-u_binary64
484×expm1-log1p-u_binary64
483×add-log-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify151.0ms (1.3%)

Algorithm
egg-herbie
Rules
1604×fma-def_binary64
820×unswap-sqr_binary64
612×sqr-pow_binary64
454×cube-prod_binary64
356×pow-sqr_binary64
Iterations

Useful iterations: 8 (0.0ms)

IterNodesCost
046334
1119328
2324311
31061307
41622307
52083307
62216307
72342307
82476304
93991304
104233304
115933304
126496304
137149304
147882304
Stop Event
node limit
Counts
89 → 72
Calls
Call 1
Inputs
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(exp.f64 1)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (exp.f64 1))) (exp.f64 1))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (exp.f64 1))) (+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 4) (exp.f64 1))) (exp.f64 1)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (exp.f64 1))) (+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 4) (exp.f64 1))) (+.f64 (*.f64 -31/720 (*.f64 (pow.f64 y 6) (exp.f64 1))) (exp.f64 1))))
Outputs
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (*.f64 -1/2 (*.f64 y y)))
(fma.f64 -1/2 (*.f64 y y) 1)
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) 1) (*.f64 1/24 (pow.f64 y 4)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) (fma.f64 -1/720 (pow.f64 y 6) 1))
(fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 1/24 (pow.f64 y 4) 1)))
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)
(*.f64 (fma.f64 -1/2 (*.f64 y y) 1) x)
(fma.f64 (*.f64 y y) (*.f64 -1/2 x) x)
(fma.f64 y (*.f64 y (*.f64 -1/2 x)) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x))
(+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(*.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)))
(*.f64 (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)) x)
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(+.f64 x (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1))))
(fma.f64 x (fma.f64 -1/720 (pow.f64 y 6) (*.f64 (*.f64 y y) (fma.f64 y (*.f64 y 1/24) -1/2))) x)
(*.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 1/24 (pow.f64 y 4) 1))))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(exp.f64 1)
(E.f64)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (exp.f64 1))) (exp.f64 1))
(fma.f64 -1/2 (*.f64 (*.f64 y y) (E.f64)) (E.f64))
(*.f64 (fma.f64 -1/2 (*.f64 y y) 1) (E.f64))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (exp.f64 1))) (+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 4) (exp.f64 1))) (exp.f64 1)))
(fma.f64 -1/2 (*.f64 (*.f64 y y) (E.f64)) (fma.f64 1/6 (*.f64 (pow.f64 y 4) (E.f64)) (E.f64)))
(fma.f64 -1/2 (*.f64 y (*.f64 y (E.f64))) (fma.f64 (*.f64 (pow.f64 y 4) 1/6) (E.f64) (E.f64)))
(fma.f64 (E.f64) (fma.f64 -1/2 (*.f64 y y) (*.f64 (pow.f64 y 4) 1/6)) (E.f64))
(*.f64 (E.f64) (fma.f64 y (fma.f64 1/6 (pow.f64 y 3) (*.f64 -1/2 y)) 1))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (exp.f64 1))) (+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 4) (exp.f64 1))) (+.f64 (*.f64 -31/720 (*.f64 (pow.f64 y 6) (exp.f64 1))) (exp.f64 1))))
(fma.f64 -1/2 (*.f64 (*.f64 y y) (E.f64)) (fma.f64 1/6 (*.f64 (pow.f64 y 4) (E.f64)) (fma.f64 -31/720 (*.f64 (pow.f64 y 6) (E.f64)) (E.f64))))
(+.f64 (*.f64 (E.f64) (+.f64 (*.f64 (pow.f64 y 4) 1/6) (*.f64 (pow.f64 y 6) -31/720))) (*.f64 (fma.f64 -1/2 (*.f64 y y) 1) (E.f64)))
(fma.f64 (E.f64) (fma.f64 (pow.f64 y 4) 1/6 (*.f64 (pow.f64 y 6) -31/720)) (*.f64 (fma.f64 -1/2 (*.f64 y y) 1) (E.f64)))
(*.f64 (E.f64) (+.f64 (fma.f64 (pow.f64 y 6) -31/720 1) (fma.f64 -1/2 (*.f64 y y) (*.f64 (pow.f64 y 4) 1/6))))
(*.f64 (E.f64) (fma.f64 -1/2 (*.f64 y y) (fma.f64 (pow.f64 y 4) 1/6 (fma.f64 (pow.f64 y 6) -31/720 1))))
(*.f64 (E.f64) (fma.f64 y (fma.f64 1/6 (pow.f64 y 3) (*.f64 -1/2 y)) (fma.f64 (pow.f64 y 6) -31/720 1)))

localize20.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 z (sin.f64 y))
0.2b
(*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3))
0.3b
(cbrt.f64 (cos.f64 y))
0.3b
(pow.f64 (cbrt.f64 (cos.f64 y)) 3)
Compiler

Compiled 42 to 17 computations (59.5% saved)

series9.0ms (0.1%)

Counts
3 → 48
Calls

12 calls:

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

rewrite63.0ms (0.5%)

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

Useful iterations: 0 (0.0ms)

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

simplify151.0ms (1.3%)

Algorithm
egg-herbie
Rules
768×fma-def_binary64
636×distribute-rgt-in_binary64
628×distribute-rgt-out_binary64
581×associate-*l*_binary64
578×distribute-lft-out_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
044376
1110342
2282333
3885331
43468331
55936331
66294331
76547331
86794331
97104331
107489331
Stop Event
node limit
Counts
98 → 73
Calls
Call 1
Inputs
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
1
(+.f64 1 (*.f64 -1/6 (pow.f64 y 2)))
(+.f64 (*.f64 -1/72 (pow.f64 y 4)) (+.f64 1 (*.f64 -1/6 (pow.f64 y 2))))
(+.f64 (*.f64 -23/6480 (pow.f64 y 6)) (+.f64 (*.f64 -1/72 (pow.f64 y 4)) (+.f64 1 (*.f64 -1/6 (pow.f64 y 2)))))
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(pow.f64 (cos.f64 y) 1/3)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
Outputs
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (*.f64 -1/2 (*.f64 y y)))
(fma.f64 -1/2 (*.f64 y y) 1)
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) 1) (*.f64 1/24 (pow.f64 y 4)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1))
(fma.f64 (*.f64 y y) (fma.f64 (*.f64 y y) 1/24 -1/2) 1)
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) (fma.f64 -1/720 (pow.f64 y 6) 1))
(fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) (fma.f64 -1/720 (pow.f64 y 6) 1)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 1/24 (pow.f64 y 4) 1)))
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
(*.f64 (pow.f64 1 1/3) (cos.f64 y))
(*.f64 1 (cos.f64 y))
(cos.f64 y)
1
(+.f64 1 (*.f64 -1/6 (pow.f64 y 2)))
(+.f64 1 (*.f64 (*.f64 y y) -1/6))
(fma.f64 (*.f64 y y) -1/6 1)
(fma.f64 y (*.f64 y -1/6) 1)
(+.f64 (*.f64 -1/72 (pow.f64 y 4)) (+.f64 1 (*.f64 -1/6 (pow.f64 y 2))))
(fma.f64 -1/72 (pow.f64 y 4) (+.f64 1 (*.f64 (*.f64 y y) -1/6)))
(fma.f64 (pow.f64 y 4) -1/72 (fma.f64 (*.f64 y y) -1/6 1))
(fma.f64 y (*.f64 y -1/6) (fma.f64 (pow.f64 y 4) -1/72 1))
(fma.f64 (*.f64 y y) (fma.f64 y (*.f64 y -1/72) -1/6) 1)
(+.f64 (*.f64 -23/6480 (pow.f64 y 6)) (+.f64 (*.f64 -1/72 (pow.f64 y 4)) (+.f64 1 (*.f64 -1/6 (pow.f64 y 2)))))
(fma.f64 -23/6480 (pow.f64 y 6) (fma.f64 -1/72 (pow.f64 y 4) (+.f64 1 (*.f64 (*.f64 y y) -1/6))))
(fma.f64 (pow.f64 y 6) -23/6480 (fma.f64 (pow.f64 y 4) -1/72 (fma.f64 (*.f64 y y) -1/6 1)))
(fma.f64 (pow.f64 y 4) -1/72 (fma.f64 (pow.f64 y 6) -23/6480 (fma.f64 y (*.f64 y -1/6) 1)))
(fma.f64 y (*.f64 y -1/6) (fma.f64 (pow.f64 y 4) -1/72 (fma.f64 (pow.f64 y 6) -23/6480 1)))
(fma.f64 (pow.f64 y 4) -1/72 (fma.f64 y (*.f64 y -1/6) (fma.f64 (pow.f64 y 6) -23/6480 1)))
(fma.f64 (*.f64 y y) (fma.f64 y (*.f64 y -1/72) -1/6) (fma.f64 (pow.f64 y 6) -23/6480 1))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(pow.f64 (cos.f64 y) 1/3)
(cbrt.f64 (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)
(*.f64 (fma.f64 -1/2 (*.f64 y y) 1) x)
(fma.f64 -1/2 (*.f64 y (*.f64 y x)) x)
(fma.f64 y (*.f64 y (*.f64 -1/2 x)) x)
(fma.f64 (*.f64 y x) (*.f64 -1/2 y) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x))
(+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) x)
(*.f64 (fma.f64 (*.f64 y y) (fma.f64 (*.f64 y y) 1/24 -1/2) 1) x)
(fma.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) x x)
(*.f64 (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)) x)
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (+.f64 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(+.f64 x (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(*.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) (fma.f64 -1/720 (pow.f64 y 6) 1))))
(fma.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) (*.f64 -1/720 (pow.f64 y 6)))) x)
(*.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 1/24 (pow.f64 y 4) 1))))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)

localize16.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(sqrt.f64 (cos.f64 y))
0.0b
(fma.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) (sqrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.1b
(*.f64 x (sqrt.f64 (cos.f64 y)))
0.2b
(*.f64 z (sin.f64 y))
Compiler

Compiled 35 to 9 computations (74.3% saved)

series28.0ms (0.2%)

Counts
3 → 64
Calls

18 calls:

TimeVariablePointExpression
19.0ms
y
@0
(*.f64 x (sqrt.f64 (cos.f64 y)))
1.0ms
x
@0
(*.f64 x (sqrt.f64 (cos.f64 y)))
1.0ms
y
@inf
(fma.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) (sqrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
1.0ms
y
@inf
(*.f64 x (sqrt.f64 (cos.f64 y)))
1.0ms
y
@-inf
(*.f64 x (sqrt.f64 (cos.f64 y)))

rewrite69.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
931×pow1_binary64
850×add-log-exp_binary64
850×log1p-expm1-u_binary64
850×expm1-log1p-u_binary64
828×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01034
119627
2232927
Stop Event
node limit
Counts
3 → 54
Calls
Call 1
Inputs
(*.f64 x (sqrt.f64 (cos.f64 y)))
(fma.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) (sqrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
(sqrt.f64 (cos.f64 y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (sqrt.f64 (cos.f64 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (sqrt.f64 (cos.f64 y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (sqrt.f64 (cos.f64 y)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (cos.f64 y) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (sqrt.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (cos.f64 y) 3/2)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (cos.f64 y) 3/2) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (sqrt.f64 (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (sqrt.f64 (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (sqrt.f64 (cos.f64 y)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x (cos.f64 y)) 1) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) (pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 2) (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x (cos.f64 y)) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3)) (+.f64 (*.f64 (*.f64 x (cos.f64 y)) (*.f64 x (cos.f64 y))) (-.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (*.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x (cos.f64 y)) (*.f64 x (cos.f64 y))) (pow.f64 (*.f64 z (sin.f64 y)) 2)) (-.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (sqrt.f64 (cos.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (cos.f64 y))) (cbrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 y)) (cbrt.f64 (sqrt.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 y) 1/4) (pow.f64 (cos.f64 y) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (cos.f64 y)) 2)) (sqrt.f64 (cbrt.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cos.f64 y)) 2) 1/2) (pow.f64 (cbrt.f64 (cos.f64 y)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 y) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 y) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (cos.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 y) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (cos.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 y) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (cos.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (cos.f64 y))))))))

simplify199.0ms (1.7%)

Algorithm
egg-herbie
Rules
1908×fma-def_binary64
679×sqr-pow_binary64
416×cube-prod_binary64
394×*-commutative_binary64
358×pow-sqr_binary64
Iterations

Useful iterations: 8 (0.0ms)

IterNodesCost
053668
1134665
2345656
31110654
41761654
52759654
62862654
73026654
83196649
95013649
105336649
115735649
126243649
136808649
147588649
157993649
Stop Event
node limit
Counts
118 → 80
Calls
Call 1
Inputs
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
x
(+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 2) x)) x)
(+.f64 (*.f64 -1/96 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 -19/5760 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 -1/96 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
x
(+.f64 (*.f64 y z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
1
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) 1)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 1 (*.f64 -1/96 (pow.f64 y 4))))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 1 (+.f64 (*.f64 -1/96 (pow.f64 y 4)) (*.f64 -19/5760 (pow.f64 y 6)))))
Outputs
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
x
(+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 2) x)) x)
(fma.f64 -1/4 (*.f64 x (*.f64 y y)) x)
(*.f64 (fma.f64 -1/4 (*.f64 y y) 1) x)
(*.f64 x (fma.f64 y (*.f64 y -1/4) 1))
(+.f64 (*.f64 -1/96 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 -1/96 (*.f64 x (pow.f64 y 4)) (fma.f64 -1/4 (*.f64 x (*.f64 y y)) x))
(fma.f64 -1/96 (*.f64 x (pow.f64 y 4)) (*.f64 (fma.f64 -1/4 (*.f64 y y) 1) x))
(fma.f64 x (fma.f64 y (*.f64 y -1/4) (*.f64 -1/96 (pow.f64 y 4))) x)
(fma.f64 x (*.f64 y (*.f64 y (fma.f64 y (*.f64 y -1/96) -1/4))) x)
(fma.f64 x (*.f64 (*.f64 y y) (fma.f64 y (*.f64 y -1/96) -1/4)) x)
(+.f64 (*.f64 -19/5760 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 -1/96 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 -19/5760 (*.f64 x (pow.f64 y 6)) (fma.f64 -1/96 (*.f64 x (pow.f64 y 4)) (fma.f64 -1/4 (*.f64 x (*.f64 y y)) x)))
(+.f64 (*.f64 (fma.f64 -1/4 (*.f64 y y) 1) x) (*.f64 x (fma.f64 -1/96 (pow.f64 y 4) (*.f64 -19/5760 (pow.f64 y 6)))))
(+.f64 x (*.f64 x (fma.f64 y (*.f64 y -1/4) (fma.f64 -1/96 (pow.f64 y 4) (*.f64 -19/5760 (pow.f64 y 6))))))
(*.f64 x (fma.f64 y (*.f64 y -1/4) (fma.f64 -1/96 (pow.f64 y 4) (fma.f64 -19/5760 (pow.f64 y 6) 1))))
(*.f64 x (fma.f64 y (fma.f64 -19/5760 (pow.f64 y 5) (*.f64 y -1/4)) (fma.f64 -1/96 (pow.f64 y 4) 1)))
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 (sqrt.f64 (cos.f64 y)) x)
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
x
(+.f64 (*.f64 y z) x)
(fma.f64 y z x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 y z (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x))
(fma.f64 y z (fma.f64 (*.f64 x (*.f64 y y)) -1/2 x))
(fma.f64 x (*.f64 y (*.f64 y -1/2)) (fma.f64 y z x))
(fma.f64 y (fma.f64 x (*.f64 y -1/2) z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x)))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 (*.f64 x (*.f64 y y)) -1/2 x)))
(fma.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))) (fma.f64 (*.f64 x (*.f64 y y)) -1/2 x))
(fma.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))) (*.f64 x (fma.f64 (*.f64 y y) -1/2 1)))
(fma.f64 y z (fma.f64 (*.f64 y y) (fma.f64 z (*.f64 y -1/6) (*.f64 x -1/2)) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 (cos.f64 y) x (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 (cos.f64 y) x))
1
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) 1)
(fma.f64 -1/4 (*.f64 y y) 1)
(fma.f64 y (*.f64 y -1/4) 1)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 1 (*.f64 -1/96 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/4 (*.f64 y y) 1) (*.f64 -1/96 (pow.f64 y 4)))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/96 (pow.f64 y 4) 1))
(fma.f64 y (*.f64 y -1/4) (fma.f64 -1/96 (pow.f64 y 4) 1))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 1 (+.f64 (*.f64 -1/96 (pow.f64 y 4)) (*.f64 -19/5760 (pow.f64 y 6)))))
(+.f64 (fma.f64 -1/4 (*.f64 y y) 1) (fma.f64 -1/96 (pow.f64 y 4) (*.f64 -19/5760 (pow.f64 y 6))))
(fma.f64 y (*.f64 y -1/4) (fma.f64 -1/96 (pow.f64 y 4) (fma.f64 -19/5760 (pow.f64 y 6) 1)))
(fma.f64 y (fma.f64 -19/5760 (pow.f64 y 5) (*.f64 y -1/4)) (fma.f64 -1/96 (pow.f64 y 4) 1))

eval147.0ms (1.2%)

Compiler

Compiled 8583 to 3453 computations (59.8% saved)

prune171.0ms (1.5%)

Pruning

24 alts after pruning (20 fresh and 4 done)

PrunedKeptTotal
New51710527
Fresh71017
Picked101
Done145
Total52624550
Error
0.0b
Counts
550 → 24
Alt Table
Click to see full alt table
StatusErrorProgram
0.9b
(+.f64 (*.f64 x (-.f64 (pow.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 2) 1)) (*.f64 z (sin.f64 y)))
0.8b
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (cos.f64 y)) (*.f64 z (sin.f64 y)))
24.7b
(+.f64 (*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (*.f64 y z))
52.1b
(*.f64 y z)
34.4b
(fma.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z) (*.f64 x (cos.f64 y)))
32.2b
(+.f64 (*.f64 y z) x)
41.6b
x
32.2b
(fma.f64 z y x)
14.5b
(+.f64 x (*.f64 z (sin.f64 y)))
3.7b
(fma.f64 (*.f64 z (cbrt.f64 (pow.f64 (sin.f64 y) 2))) (cbrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
31.3b
(pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 2)
28.0b
(*.f64 (cos.f64 y) x)
0.3b
(+.f64 (+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x)) (*.f64 z (sin.f64 y)))
1.3b
(pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 3)
0.3b
(+.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (*.f64 z (sin.f64 y)))
21.3b
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))
0.3b
(+.f64 (*.f64 x (-.f64 (-.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) 1) 1)) (*.f64 z (sin.f64 y)))
0.2b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
31.0b
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
0.3b
(fma.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 2))) (cbrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
36.1b
(fma.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
35.0b
(*.f64 z (sin.f64 y))
0.2b
(+.f64 (*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)) (*.f64 z (sin.f64 y)))
0.2b
(+.f64 (*.f64 x (log.f64 (exp.f64 (cos.f64 y)))) (*.f64 z (sin.f64 y)))
Compiler

Compiled 586 to 406 computations (30.7% saved)

localize37.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 z (sin.f64 y))
0.2b
(*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3)))
0.3b
(cbrt.f64 (pow.f64 (cos.f64 y) 3))
0.4b
(pow.f64 (cos.f64 y) 3)
Compiler

Compiled 43 to 21 computations (51.2% saved)

series11.0ms (0.1%)

Counts
3 → 40
Calls

12 calls:

TimeVariablePointExpression
7.0ms
y
@inf
(*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3)))
1.0ms
y
@-inf
(pow.f64 (cos.f64 y) 3)
1.0ms
y
@inf
(pow.f64 (cos.f64 y) 3)
1.0ms
y
@0
(pow.f64 (cos.f64 y) 3)
0.0ms
y
@0
(*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3)))

rewrite70.0ms (0.6%)

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

Useful iterations: 0 (0.0ms)

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

simplify153.0ms (1.3%)

Algorithm
egg-herbie
Rules
788×fma-def_binary64
640×distribute-rgt-in_binary64
629×distribute-rgt-out_binary64
566×distribute-lft-out_binary64
565×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
042312
1102306
2268293
3856291
43412291
55825291
66166291
76396291
86613291
96886291
107223291
Stop Event
node limit
Counts
90 → 71
Calls
Call 1
Inputs
1
(+.f64 1 (*.f64 -3/2 (pow.f64 y 2)))
(+.f64 1 (+.f64 (*.f64 7/8 (pow.f64 y 4)) (*.f64 -3/2 (pow.f64 y 2))))
(+.f64 1 (+.f64 (*.f64 -61/240 (pow.f64 y 6)) (+.f64 (*.f64 7/8 (pow.f64 y 4)) (*.f64 -3/2 (pow.f64 y 2)))))
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
Outputs
1
(+.f64 1 (*.f64 -3/2 (pow.f64 y 2)))
(+.f64 1 (*.f64 -3/2 (*.f64 y y)))
(fma.f64 -3/2 (*.f64 y y) 1)
(+.f64 1 (+.f64 (*.f64 7/8 (pow.f64 y 4)) (*.f64 -3/2 (pow.f64 y 2))))
(+.f64 1 (fma.f64 7/8 (pow.f64 y 4) (*.f64 -3/2 (*.f64 y y))))
(+.f64 1 (fma.f64 -3/2 (*.f64 y y) (*.f64 7/8 (pow.f64 y 4))))
(fma.f64 -3/2 (*.f64 y y) (fma.f64 7/8 (pow.f64 y 4) 1))
(fma.f64 (*.f64 y y) (fma.f64 y (*.f64 y 7/8) -3/2) 1)
(+.f64 1 (+.f64 (*.f64 -61/240 (pow.f64 y 6)) (+.f64 (*.f64 7/8 (pow.f64 y 4)) (*.f64 -3/2 (pow.f64 y 2)))))
(+.f64 1 (fma.f64 -61/240 (pow.f64 y 6) (fma.f64 7/8 (pow.f64 y 4) (*.f64 -3/2 (*.f64 y y)))))
(+.f64 1 (fma.f64 -61/240 (pow.f64 y 6) (fma.f64 -3/2 (*.f64 y y) (*.f64 7/8 (pow.f64 y 4)))))
(fma.f64 -61/240 (pow.f64 y 6) (fma.f64 -3/2 (*.f64 y y) (fma.f64 7/8 (pow.f64 y 4) 1)))
(fma.f64 -3/2 (*.f64 y y) (fma.f64 -61/240 (pow.f64 y 6) (fma.f64 7/8 (pow.f64 y 4) 1)))
(fma.f64 (*.f64 y y) (fma.f64 y (*.f64 y 7/8) -3/2) (fma.f64 -61/240 (pow.f64 y 6) 1))
1
(+.f64 1 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 1 (*.f64 (*.f64 y y) -1/2))
(fma.f64 (*.f64 y y) -1/2 1)
(fma.f64 y (*.f64 y -1/2) 1)
(+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 (pow.f64 y 4) 1/24)))
(+.f64 1 (fma.f64 (*.f64 y y) -1/2 (*.f64 (pow.f64 y 4) 1/24)))
(fma.f64 (*.f64 y y) -1/2 (fma.f64 (pow.f64 y 4) 1/24 1))
(fma.f64 y (*.f64 y -1/2) (fma.f64 (pow.f64 y 4) 1/24 1))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 1 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 1 (fma.f64 -1/2 (*.f64 y y) (*.f64 (pow.f64 y 4) 1/24))))
(+.f64 (fma.f64 (*.f64 y y) -1/2 (*.f64 (pow.f64 y 4) 1/24)) (fma.f64 (pow.f64 y 6) -1/720 1))
(fma.f64 (pow.f64 y 6) -1/720 (fma.f64 (*.f64 y y) -1/2 (fma.f64 (pow.f64 y 4) 1/24 1)))
(fma.f64 (*.f64 y y) (fma.f64 y (*.f64 y 1/24) -1/2) (fma.f64 (pow.f64 y 6) -1/720 1))
(fma.f64 y (*.f64 y -1/2) (fma.f64 (pow.f64 y 4) 1/24 (fma.f64 (pow.f64 y 6) -1/720 1)))
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(cos.f64 y)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
x
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)
(fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)
(*.f64 (fma.f64 (*.f64 y y) -1/2 1) x)
(fma.f64 (*.f64 y y) (*.f64 -1/2 x) x)
(fma.f64 y (*.f64 -1/2 (*.f64 y x)) x)
(*.f64 (fma.f64 y (*.f64 y -1/2) 1) x)
(+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x))
(+.f64 x (*.f64 x (fma.f64 (*.f64 y y) -1/2 (*.f64 (pow.f64 y 4) 1/24))))
(*.f64 x (fma.f64 (*.f64 y y) -1/2 (fma.f64 (pow.f64 y 4) 1/24 1)))
(*.f64 (fma.f64 (*.f64 y y) -1/2 (fma.f64 (pow.f64 y 4) 1/24 1)) x)
(fma.f64 (*.f64 (*.f64 y y) (fma.f64 y (*.f64 y 1/24) -1/2)) x x)
(*.f64 (fma.f64 y (*.f64 y -1/2) (fma.f64 (pow.f64 y 4) 1/24 1)) x)
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (+.f64 x (*.f64 x (fma.f64 (*.f64 y y) -1/2 (*.f64 (pow.f64 y 4) 1/24)))))
(+.f64 x (*.f64 x (fma.f64 (pow.f64 y 6) -1/720 (fma.f64 y (*.f64 y -1/2) (*.f64 (pow.f64 y 4) 1/24)))))
(*.f64 x (fma.f64 (*.f64 y y) (fma.f64 y (*.f64 y 1/24) -1/2) (fma.f64 (pow.f64 y 6) -1/720 1)))
(*.f64 x (fma.f64 y (*.f64 y -1/2) (fma.f64 (pow.f64 y 4) 1/24 (fma.f64 (pow.f64 y 6) -1/720 1))))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)

localize4.0ms (0%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize12.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 18 to 6 computations (66.7% saved)

series3.0ms (0%)

Counts
1 → 27
Calls

9 calls:

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

rewrite56.0ms (0.5%)

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

Useful iterations: 1 (0.0ms)

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

simplify137.0ms (1.2%)

Algorithm
egg-herbie
Rules
1295×fma-def_binary64
788×sqr-pow_binary64
544×associate-*l*_binary64
487×*-commutative_binary64
448×cube-prod_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
024186
165186
2152182
3380179
4995177
52360177
62811177
73453177
83569177
93741177
103960177
114946177
125406177
136006177
146759177
157693177
Stop Event
node limit
Counts
62 → 44
Calls
Call 1
Inputs
(*.f64 z (sin.f64 y))
x
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
x
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
x
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
x
(+.f64 (*.f64 y z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) x))
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 1/120 (*.f64 (pow.f64 y 5) z)) x)))
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
Outputs
(*.f64 z (sin.f64 y))
x
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
x
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
x
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
x
(+.f64 (*.f64 y z) x)
(fma.f64 y z x)
(fma.f64 z y x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) x))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) x))
(fma.f64 z y (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) x))
(fma.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))) x)
(fma.f64 z (fma.f64 -1/6 (pow.f64 y 3) y) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 1/120 (*.f64 (pow.f64 y 5) z)) x)))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 1/120 (*.f64 z (pow.f64 y 5)) x)))
(fma.f64 z y (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 1/120 (*.f64 z (pow.f64 y 5)) x)))
(fma.f64 z (fma.f64 -1/6 (pow.f64 y 3) (*.f64 1/120 (pow.f64 y 5))) (fma.f64 z y x))
(fma.f64 z (+.f64 (*.f64 1/120 (pow.f64 y 5)) (fma.f64 -1/6 (pow.f64 y 3) y)) x)
(fma.f64 z (fma.f64 -1/6 (pow.f64 y 3) (fma.f64 1/120 (pow.f64 y 5) y)) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)

localize22.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 z (sin.f64 y))
0.2b
(*.f64 x (cos.f64 y))
0.2b
(pow.f64 (*.f64 z (sin.f64 y)) 3)
35.6b
(cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3))
Compiler

Compiled 44 to 17 computations (61.4% saved)

series9.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite62.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
645×pow1_binary64
603×add-log-exp_binary64
603×log1p-expm1-u_binary64
603×expm1-log1p-u_binary64
586×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0815
116815
2172815
Stop Event
node limit
Counts
2 → 54
Calls
Call 1
Inputs
(cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3))
(pow.f64 (*.f64 z (sin.f64 y)) 3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 z (sin.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 z (sin.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 y) z)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 z (sin.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2) (cbrt.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 z) 2) (*.f64 (cbrt.f64 z) (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 y)) 2) (*.f64 (cbrt.f64 (sin.f64 y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (sqrt.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 y)) (*.f64 (sqrt.f64 (sin.f64 y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) 1/3) (cbrt.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3/2) 1/3) (pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3/2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 z (pow.f64 (cbrt.f64 (sin.f64 y)) 2)) (cbrt.f64 (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sin.f64 y) (pow.f64 (cbrt.f64 z) 2)) (cbrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 z (sin.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 z) (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 z (sin.f64 y))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (*.f64 z (sin.f64 y)) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 z (*.f64 (sin.f64 y) (pow.f64 (*.f64 z (sin.f64 y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 y) (*.f64 z (pow.f64 (*.f64 z (sin.f64 y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 z (sin.f64 y)) (pow.f64 (*.f64 z (sin.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (*.f64 z (sin.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2) (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (pow.f64 (*.f64 z (sin.f64 y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (pow.f64 (*.f64 z (sin.f64 y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3/2) (pow.f64 (*.f64 z (sin.f64 y)) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2) 3) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 3) (pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) z) (sin.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (sin.f64 y)) z)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) 1) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 2)) (cbrt.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (sqrt.f64 (*.f64 z (sin.f64 y)))) (sqrt.f64 (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 6))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 3 (log.f64 (*.f64 z (sin.f64 y)))))))))

simplify157.0ms (1.3%)

Algorithm
egg-herbie
Rules
707×fma-def_binary64
488×distribute-rgt-in_binary64
482×distribute-lft-in_binary64
476×associate-*l*_binary64
434×distribute-rgt-out_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
074625
1235610
2866565
34542565
47126562
57250562
67387562
77541562
87729562
97919562
Stop Event
node limit
Counts
102 → 72
Calls
Call 1
Inputs
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 y z)
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (*.f64 y z))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (*.f64 1/120 (*.f64 (pow.f64 y 5) z))))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (+.f64 (*.f64 -1/5040 (*.f64 (pow.f64 y 7) z)) (*.f64 1/120 (*.f64 (pow.f64 y 5) z)))))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 y 3) (pow.f64 z 3))
(+.f64 (*.f64 (+.f64 (*.f64 -1/3 (pow.f64 z 3)) (*.f64 -1/6 (pow.f64 z 3))) (pow.f64 y 5)) (*.f64 (pow.f64 y 3) (pow.f64 z 3)))
(+.f64 (*.f64 (+.f64 (*.f64 -1/3 (pow.f64 z 3)) (*.f64 -1/6 (pow.f64 z 3))) (pow.f64 y 5)) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 (pow.f64 y 7) (+.f64 (*.f64 (+.f64 (*.f64 1/36 (pow.f64 z 2)) (*.f64 1/60 (pow.f64 z 2))) z) (+.f64 (*.f64 1/18 (pow.f64 z 3)) (*.f64 1/120 (pow.f64 z 3)))))))
(+.f64 (*.f64 (+.f64 (*.f64 -1/3 (pow.f64 z 3)) (*.f64 -1/6 (pow.f64 z 3))) (pow.f64 y 5)) (+.f64 (*.f64 (pow.f64 y 9) (+.f64 (*.f64 -1/6 (*.f64 (+.f64 (*.f64 1/36 (pow.f64 z 2)) (*.f64 1/60 (pow.f64 z 2))) z)) (+.f64 (*.f64 z (+.f64 (*.f64 -1/360 (pow.f64 z 2)) (*.f64 -1/2520 (pow.f64 z 2)))) (+.f64 (*.f64 -1/5040 (pow.f64 z 3)) (*.f64 -1/360 (pow.f64 z 3)))))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 (pow.f64 y 7) (+.f64 (*.f64 (+.f64 (*.f64 1/36 (pow.f64 z 2)) (*.f64 1/60 (pow.f64 z 2))) z) (+.f64 (*.f64 1/18 (pow.f64 z 3)) (*.f64 1/120 (pow.f64 z 3))))))))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
Outputs
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(neg.f64 (*.f64 z (*.f64 (sin.f64 y) (cbrt.f64 -1))))
(*.f64 (*.f64 (sin.f64 y) (cbrt.f64 -1)) (neg.f64 z))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(neg.f64 (*.f64 z (*.f64 (sin.f64 y) (cbrt.f64 -1))))
(*.f64 (*.f64 (sin.f64 y) (cbrt.f64 -1)) (neg.f64 z))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(neg.f64 (*.f64 z (*.f64 (sin.f64 y) (cbrt.f64 -1))))
(*.f64 (*.f64 (sin.f64 y) (cbrt.f64 -1)) (neg.f64 z))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(neg.f64 (*.f64 z (*.f64 (sin.f64 y) (cbrt.f64 -1))))
(*.f64 (*.f64 (sin.f64 y) (cbrt.f64 -1)) (neg.f64 z))
(*.f64 y z)
(*.f64 z y)
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (*.f64 y z))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 z y))
(*.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))))
(*.f64 z (fma.f64 -1/6 (pow.f64 y 3) y))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (*.f64 1/120 (*.f64 (pow.f64 y 5) z))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (*.f64 1/120 (*.f64 z (pow.f64 y 5)))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 z (+.f64 y (*.f64 1/120 (pow.f64 y 5)))))
(*.f64 z (+.f64 (*.f64 -1/6 (pow.f64 y 3)) (fma.f64 1/120 (pow.f64 y 5) y)))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (+.f64 (*.f64 -1/5040 (*.f64 (pow.f64 y 7) z)) (*.f64 1/120 (*.f64 (pow.f64 y 5) z)))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (fma.f64 -1/5040 (*.f64 z (pow.f64 y 7)) (*.f64 1/120 (*.f64 z (pow.f64 y 5))))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 z y (*.f64 z (+.f64 (*.f64 1/120 (pow.f64 y 5)) (*.f64 -1/5040 (pow.f64 y 7))))))
(*.f64 z (+.f64 (fma.f64 -1/6 (pow.f64 y 3) y) (fma.f64 1/120 (pow.f64 y 5) (*.f64 -1/5040 (pow.f64 y 7)))))
(*.f64 z (+.f64 (fma.f64 -1/5040 (pow.f64 y 7) (*.f64 1/120 (pow.f64 y 5))) (fma.f64 -1/6 (pow.f64 y 3) y)))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 y 3) (pow.f64 z 3))
(pow.f64 (*.f64 z y) 3)
(+.f64 (*.f64 (+.f64 (*.f64 -1/3 (pow.f64 z 3)) (*.f64 -1/6 (pow.f64 z 3))) (pow.f64 y 5)) (*.f64 (pow.f64 y 3) (pow.f64 z 3)))
(fma.f64 (*.f64 (pow.f64 z 3) -1/2) (pow.f64 y 5) (*.f64 (pow.f64 y 3) (pow.f64 z 3)))
(fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 (pow.f64 y 5) (*.f64 (pow.f64 z 3) -1/2)))
(*.f64 (pow.f64 z 3) (+.f64 (pow.f64 y 3) (*.f64 (pow.f64 y 5) -1/2)))
(+.f64 (*.f64 (+.f64 (*.f64 -1/3 (pow.f64 z 3)) (*.f64 -1/6 (pow.f64 z 3))) (pow.f64 y 5)) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 (pow.f64 y 7) (+.f64 (*.f64 (+.f64 (*.f64 1/36 (pow.f64 z 2)) (*.f64 1/60 (pow.f64 z 2))) z) (+.f64 (*.f64 1/18 (pow.f64 z 3)) (*.f64 1/120 (pow.f64 z 3)))))))
(fma.f64 (*.f64 (pow.f64 z 3) -1/2) (pow.f64 y 5) (fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 (pow.f64 y 7) (fma.f64 (*.f64 (*.f64 z z) 2/45) z (*.f64 (pow.f64 z 3) 23/360)))))
(fma.f64 (pow.f64 y 5) (*.f64 (pow.f64 z 3) -1/2) (fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 (pow.f64 y 7) (fma.f64 (pow.f64 z 3) 23/360 (*.f64 (pow.f64 z 3) 2/45)))))
(fma.f64 (pow.f64 y 7) (*.f64 (pow.f64 z 3) 13/120) (*.f64 (pow.f64 z 3) (+.f64 (pow.f64 y 3) (*.f64 (pow.f64 y 5) -1/2))))
(+.f64 (*.f64 (+.f64 (*.f64 -1/3 (pow.f64 z 3)) (*.f64 -1/6 (pow.f64 z 3))) (pow.f64 y 5)) (+.f64 (*.f64 (pow.f64 y 9) (+.f64 (*.f64 -1/6 (*.f64 (+.f64 (*.f64 1/36 (pow.f64 z 2)) (*.f64 1/60 (pow.f64 z 2))) z)) (+.f64 (*.f64 z (+.f64 (*.f64 -1/360 (pow.f64 z 2)) (*.f64 -1/2520 (pow.f64 z 2)))) (+.f64 (*.f64 -1/5040 (pow.f64 z 3)) (*.f64 -1/360 (pow.f64 z 3)))))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 (pow.f64 y 7) (+.f64 (*.f64 (+.f64 (*.f64 1/36 (pow.f64 z 2)) (*.f64 1/60 (pow.f64 z 2))) z) (+.f64 (*.f64 1/18 (pow.f64 z 3)) (*.f64 1/120 (pow.f64 z 3))))))))
(fma.f64 (*.f64 (pow.f64 z 3) -1/2) (pow.f64 y 5) (fma.f64 (pow.f64 y 9) (fma.f64 -1/6 (*.f64 z (*.f64 (*.f64 z z) 2/45)) (fma.f64 z (*.f64 (*.f64 z z) -1/315) (*.f64 (pow.f64 z 3) -1/336))) (fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 (pow.f64 y 7) (fma.f64 (*.f64 (*.f64 z z) 2/45) z (*.f64 (pow.f64 z 3) 23/360))))))
(fma.f64 (pow.f64 y 5) (*.f64 (pow.f64 z 3) -1/2) (fma.f64 (pow.f64 y 9) (fma.f64 -1/6 (*.f64 (pow.f64 z 3) 2/45) (fma.f64 (pow.f64 z 3) -1/336 (*.f64 (pow.f64 z 3) -1/315))) (fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 (pow.f64 y 7) (fma.f64 (pow.f64 z 3) 23/360 (*.f64 (pow.f64 z 3) 2/45))))))
(fma.f64 (pow.f64 y 9) (+.f64 (*.f64 (pow.f64 z 3) -1/135) (*.f64 (pow.f64 z 3) -31/5040)) (fma.f64 (pow.f64 y 7) (*.f64 (pow.f64 z 3) 13/120) (*.f64 (pow.f64 z 3) (+.f64 (pow.f64 y 3) (*.f64 (pow.f64 y 5) -1/2)))))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))

localize19.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(cos.f64 y)
0.1b
(*.f64 (cos.f64 y) (sqrt.f64 x))
0.1b
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
0.2b
(*.f64 z (sin.f64 y))
Compiler

Compiled 33 to 9 computations (72.7% saved)

series11.0ms (0.1%)

Counts
2 → 29
Calls

15 calls:

TimeVariablePointExpression
2.0ms
x
@-inf
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
1.0ms
x
@inf
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
1.0ms
x
@0
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
1.0ms
x
@0
(*.f64 (cos.f64 y) (sqrt.f64 x))
1.0ms
y
@inf
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))

rewrite60.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
931×pow1_binary64
850×add-log-exp_binary64
850×log1p-expm1-u_binary64
850×expm1-log1p-u_binary64
828×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01027
119622
2232922
Stop Event
node limit
Counts
2 → 34
Calls
Call 1
Inputs
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) (sqrt.f64 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (cos.f64 y) x) 1) (*.f64 z (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) (pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 2) (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (cos.f64 y) x) 3) (pow.f64 (*.f64 z (sin.f64 y)) 3)) (+.f64 (*.f64 (*.f64 (cos.f64 y) x) (*.f64 (cos.f64 y) x)) (-.f64 (pow.f64 (*.f64 z (sin.f64 y)) 2) (*.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 (cos.f64 y) x) (*.f64 (cos.f64 y) x)) (pow.f64 (*.f64 z (sin.f64 y)) 2)) (-.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (cos.f64 y) (sqrt.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cos.f64 y) (sqrt.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cos.f64 y) (sqrt.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 x (pow.f64 (cos.f64 y) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (cos.f64 y)) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (cos.f64 y) 3) (pow.f64 x 3/2)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3/2) (pow.f64 (cos.f64 y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cos.f64 y) (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (cos.f64 y) (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cos.f64 y) (sqrt.f64 x))))))))

simplify153.0ms (1.3%)

Algorithm
egg-herbie
Rules
1924×fma-def_binary64
662×sqr-pow_binary64
422×*-commutative_binary64
416×cube-prod_binary64
351×pow-sqr_binary64
Iterations

Useful iterations: 9 (0.0ms)

IterNodesCost
043358
1111356
2293343
3934336
42473336
53480336
63679336
73842336
84006336
94225331
105531331
115897331
126354331
136909331
147658331
Stop Event
node limit
Counts
63 → 52
Calls
Call 1
Inputs
x
(+.f64 (*.f64 y z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(sqrt.f64 x)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (sqrt.f64 x))) (sqrt.f64 x))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (sqrt.f64 x))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) (sqrt.f64 x))) (sqrt.f64 x)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) (sqrt.f64 x))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (sqrt.f64 x))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) (sqrt.f64 x))) (sqrt.f64 x))))
Outputs
x
(+.f64 (*.f64 y z) x)
(fma.f64 y z x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 y z (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x))
(fma.f64 (*.f64 y y) (*.f64 x -1/2) (fma.f64 y z x))
(fma.f64 y z (fma.f64 -1/2 (*.f64 y (*.f64 x y)) x))
(fma.f64 y (fma.f64 -1/2 (*.f64 x y) z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 y z (fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x)))
(fma.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))) (*.f64 x (fma.f64 -1/2 (*.f64 y y) 1)))
(fma.f64 z (fma.f64 -1/6 (pow.f64 y 3) y) (fma.f64 -1/2 (*.f64 y (*.f64 x y)) x))
(fma.f64 -1/2 (*.f64 y (*.f64 x y)) (fma.f64 z (fma.f64 -1/6 (pow.f64 y 3) y) x))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y)))
(fma.f64 z (sin.f64 y) (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 z (sin.f64 y)))
(sqrt.f64 x)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (sqrt.f64 x))) (sqrt.f64 x))
(fma.f64 -1/2 (*.f64 (*.f64 y y) (sqrt.f64 x)) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 -1/2 (*.f64 y y) 1))
(*.f64 (sqrt.f64 x) (fma.f64 y (*.f64 y -1/2) 1))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (sqrt.f64 x))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) (sqrt.f64 x))) (sqrt.f64 x)))
(fma.f64 -1/2 (*.f64 (*.f64 y y) (sqrt.f64 x)) (fma.f64 1/24 (*.f64 (sqrt.f64 x) (pow.f64 y 4)) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (+.f64 (*.f64 -1/2 (*.f64 y y)) (*.f64 1/24 (pow.f64 y 4)))))
(*.f64 (sqrt.f64 x) (+.f64 (*.f64 1/24 (pow.f64 y 4)) (fma.f64 -1/2 (*.f64 y y) 1)))
(*.f64 (sqrt.f64 x) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)))
(*.f64 (sqrt.f64 x) (fma.f64 1/24 (pow.f64 y 4) (fma.f64 y (*.f64 y -1/2) 1)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) (sqrt.f64 x))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) (sqrt.f64 x))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) (sqrt.f64 x))) (sqrt.f64 x))))
(fma.f64 -1/720 (*.f64 (sqrt.f64 x) (pow.f64 y 6)) (fma.f64 -1/2 (*.f64 (*.f64 y y) (sqrt.f64 x)) (fma.f64 1/24 (*.f64 (sqrt.f64 x) (pow.f64 y 4)) (sqrt.f64 x))))
(+.f64 (*.f64 (+.f64 (*.f64 1/24 (pow.f64 y 4)) 1) (sqrt.f64 x)) (*.f64 (sqrt.f64 x) (+.f64 (*.f64 -1/720 (pow.f64 y 6)) (*.f64 -1/2 (*.f64 y y)))))
(fma.f64 (sqrt.f64 x) (fma.f64 -1/720 (pow.f64 y 6) (*.f64 y (*.f64 y -1/2))) (*.f64 (sqrt.f64 x) (fma.f64 1/24 (pow.f64 y 4) 1)))
(*.f64 (sqrt.f64 x) (+.f64 (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1)) (*.f64 -1/720 (pow.f64 y 6))))
(*.f64 (sqrt.f64 x) (+.f64 (*.f64 -1/720 (pow.f64 y 6)) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 1))))
(*.f64 (sqrt.f64 x) (fma.f64 y (fma.f64 y -1/2 (*.f64 (pow.f64 y 3) 1/24)) (fma.f64 -1/720 (pow.f64 y 6) 1)))
(*.f64 (sqrt.f64 x) (fma.f64 y (*.f64 y (fma.f64 y (*.f64 y 1/24) -1/2)) (fma.f64 -1/720 (pow.f64 y 6) 1)))

eval143.0ms (1.2%)

Compiler

Compiled 7529 to 3094 computations (58.9% saved)

prune190.0ms (1.6%)

Pruning

30 alts after pruning (23 fresh and 7 done)

PrunedKeptTotal
New45215467
Fresh7815
Picked101
Done178
Total46130491
Error
0.0b
Counts
491 → 30
Alt Table
Click to see full alt table
StatusErrorProgram
21.4b
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3) 3)))
0.2b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.9b
(+.f64 (*.f64 x (-.f64 (pow.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 2) 1)) (*.f64 z (sin.f64 y)))
31.3b
(pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 2)
41.6b
x
0.8b
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (cos.f64 y)) (*.f64 z (sin.f64 y)))
1.3b
(pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 3)
36.1b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y))))
32.2b
(fma.f64 z y x)
0.3b
(fma.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 2))) (cbrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
24.7b
(+.f64 (*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (*.f64 y z))
52.1b
(*.f64 y z)
15.0b
(+.f64 x (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3))
36.9b
(/.f64 1 (/.f64 (-.f64 x (*.f64 z (sin.f64 y))) (-.f64 (*.f64 x x) (pow.f64 (*.f64 z (sin.f64 y)) 2))))
32.4b
(+.f64 x (pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2))
32.2b
(+.f64 (*.f64 y z) x)
14.5b
(+.f64 x (*.f64 z (sin.f64 y)))
3.7b
(fma.f64 (*.f64 z (cbrt.f64 (pow.f64 (sin.f64 y) 2))) (cbrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
45.0b
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
28.0b
(*.f64 (cos.f64 y) x)
0.3b
(+.f64 (+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x)) (*.f64 z (sin.f64 y)))
35.0b
(*.f64 z (sin.f64 y))
0.3b
(+.f64 (*.f64 x (-.f64 (-.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) 1) 1)) (*.f64 z (sin.f64 y)))
34.4b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z)))
36.9b
(*.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 z (sin.f64 y)) 2)) (/.f64 1 (-.f64 x (*.f64 z (sin.f64 y)))))
34.4b
(+.f64 x (cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))
0.3b
(+.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (*.f64 z (sin.f64 y)))
0.2b
(+.f64 (*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)) (*.f64 z (sin.f64 y)))
0.2b
(+.f64 (*.f64 x (log.f64 (exp.f64 (cos.f64 y)))) (*.f64 z (sin.f64 y)))
29.3b
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))))
Compiler

Compiled 758 to 525 computations (30.7% saved)

localize70.0ms (0.6%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (+.f64 1 (cos.f64 y)) x)
0.2b
(*.f64 z (sin.f64 y))
0.4b
(+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x))
0.4b
(+.f64 1 (cos.f64 y))
Compiler

Compiled 54 to 28 computations (48.1% saved)

series11.0ms (0.1%)

Counts
3 → 24
Calls

15 calls:

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

rewrite125.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
989×pow1_binary64
917×add-log-exp_binary64
916×log1p-expm1-u_binary64
916×expm1-log1p-u_binary64
106×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify116.0ms (1%)

Algorithm
egg-herbie
Rules
521×associate-+l+_binary64
493×distribute-rgt-in_binary64
450×distribute-lft-in_binary64
437×sub-neg_binary64
392×distribute-neg-in_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
046286
1129262
2352236
31462235
45927235
Stop Event
node limit
Counts
122 → 123
Calls
Call 1
Inputs
2
(+.f64 2 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 (*.f64 2 x) (*.f64 -1 x))
(+.f64 (*.f64 2 x) (+.f64 (*.f64 -1 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))))
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 (cos.f64 y) x)
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
Outputs
2
(+.f64 2 (*.f64 -1/2 (pow.f64 y 2)))
(+.f64 2 (*.f64 -1/2 (*.f64 y y)))
(fma.f64 -1/2 (*.f64 y y) 2)
(+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 2 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) 2) (*.f64 1/24 (pow.f64 y 4)))
(fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2))
(+.f64 (*.f64 -1/720 (pow.f64 y 6)) (+.f64 2 (+.f64 (*.f64 -1/2 (pow.f64 y 2)) (*.f64 1/24 (pow.f64 y 4)))))
(fma.f64 -1/720 (pow.f64 y 6) (+.f64 2 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(+.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) (fma.f64 -1/720 (pow.f64 y 6) 2))
(fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2)))
(+.f64 (*.f64 2 x) (*.f64 -1 x))
(*.f64 x 1)
x
(+.f64 (*.f64 2 x) (+.f64 (*.f64 -1 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(+.f64 (*.f64 x 1) (*.f64 -1/2 (*.f64 (*.f64 y y) x)))
(+.f64 x (*.f64 -1/2 (*.f64 y (*.f64 y x))))
(fma.f64 (*.f64 y y) (*.f64 -1/2 x) x)
(fma.f64 -1/2 (*.f64 (*.f64 y y) x) x)
(+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(fma.f64 2 x (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1 x (*.f64 -1/2 (*.f64 (*.f64 y y) x)))))
(+.f64 (*.f64 (pow.f64 y 4) (*.f64 1/24 x)) (+.f64 x (*.f64 -1/2 (*.f64 y (*.f64 y x)))))
(+.f64 x (*.f64 (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))) x))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (fma.f64 2 x (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (fma.f64 -1 x (*.f64 -1/2 (*.f64 (*.f64 y y) x))))))
(+.f64 (+.f64 (neg.f64 x) (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))) (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) 2)))
(-.f64 (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2)))) x)
(+.f64 x (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4))))))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 x (cos.f64 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 x (cos.f64 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 x (cos.f64 y))
(*.f64 -1 (*.f64 (+.f64 1 (*.f64 -1 (+.f64 1 (cos.f64 y)))) x))
(*.f64 x (cos.f64 y))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(fma.f64 2 x (*.f64 -1/2 (*.f64 (*.f64 y y) x)))
(*.f64 x (fma.f64 -1/2 (*.f64 y y) 2))
(*.f64 (fma.f64 -1/2 (*.f64 y y) 2) x)
(+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(fma.f64 2 x (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (*.f64 -1/2 (*.f64 (*.f64 y y) x))))
(fma.f64 2 x (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))))
(*.f64 x (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2)))
(*.f64 (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2)) x)
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 y 6) x)) (+.f64 (*.f64 2 x) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(fma.f64 -1/720 (*.f64 (pow.f64 y 6) x) (fma.f64 2 x (fma.f64 1/24 (*.f64 (pow.f64 y 4) x) (*.f64 -1/2 (*.f64 (*.f64 y y) x)))))
(+.f64 (*.f64 x (fma.f64 -1/2 (*.f64 y y) (*.f64 1/24 (pow.f64 y 4)))) (*.f64 x (fma.f64 -1/720 (pow.f64 y 6) 2)))
(*.f64 x (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2))))
(*.f64 (fma.f64 -1/720 (pow.f64 y 6) (fma.f64 -1/2 (*.f64 y y) (fma.f64 1/24 (pow.f64 y 4) 2))) x)

localize14.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 z (sin.f64 y))
Compiler

Compiled 11 to 5 computations (54.5% saved)

localize53.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3))
0.2b
(*.f64 z (sin.f64 y))
0.5b
(pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)
7.4b
(cbrt.f64 (*.f64 z (sin.f64 y)))
Compiler

Compiled 34 to 12 computations (64.7% saved)

series30.0ms (0.3%)

Counts
3 → 40
Calls

21 calls:

TimeVariablePointExpression
3.0ms
y
@inf
(cbrt.f64 (*.f64 z (sin.f64 y)))
3.0ms
y
@-inf
(cbrt.f64 (*.f64 z (sin.f64 y)))
2.0ms
x
@-inf
(+.f64 x (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3))
2.0ms
z
@-inf
(pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)
2.0ms
z
@0
(pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)

rewrite79.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
979×pow1_binary64
914×add-log-exp_binary64
914×log1p-expm1-u_binary64
914×expm1-log1p-u_binary64
99×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify192.0ms (1.6%)

Algorithm
egg-herbie
Rules
1290×sqr-pow_binary64
666×pow-sqr_binary64
625×cube-prod_binary64
561×fabs-mul_binary64
373×unpow3_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
012321
131243
250243
364243
488243
5177243
6560243
71226243
81318243
91456243
101619243
111857243
122184243
132610243
143117243
153723243
164448243
174771243
185055243
195277243
205459243
215543243
226486243
237463243
247929243
Stop Event
node limit
Counts
131 → 95
Calls
Call 1
Inputs
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
x
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
x
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
x
x
x
x
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
Outputs
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(pow.f64 (*.f64 z (sin.f64 y)) 1/3)
(cbrt.f64 (*.f64 z (sin.f64 y)))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y)))
(*.f64 (*.f64 z (sin.f64 y)) 1)
(*.f64 z (sin.f64 y))
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
x
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
x
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
x
x
x
x
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)
(+.f64 (*.f64 (pow.f64 1 1/3) (*.f64 z (sin.f64 y))) x)
(fma.f64 1 (*.f64 z (sin.f64 y)) x)
(fma.f64 z (sin.f64 y) x)

localize13.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(cos.f64 y)
0.1b
(*.f64 (cos.f64 y) (sqrt.f64 x))
0.1b
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
Compiler

Compiled 29 to 8 computations (72.4% saved)

series25.0ms (0.2%)

Counts
1 → 25
Calls

9 calls:

TimeVariablePointExpression
21.0ms
x
@inf
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
1.0ms
x
@-inf
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
0.0ms
y
@0
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
0.0ms
x
@0
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
0.0ms
y
@-inf
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))

rewrite92.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
843×pow1_binary64
771×add-log-exp_binary64
771×log1p-expm1-u_binary64
771×expm1-log1p-u_binary64
751×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify178.0ms (1.5%)

Algorithm
egg-herbie
Rules
909×fma-def_binary64
671×sqr-pow_binary64
478×distribute-lft-out_binary64
444×cube-prod_binary64
428×*-commutative_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
023222
158222
2139219
3375219
41274216
52750216
63908216
73989216
84112216
94267216
104531216
114788216
125144216
135518216
146005216
156592216
167312216
177638216
187900216
Stop Event
node limit
Counts
46 → 32
Calls
Call 1
Inputs
x
(+.f64 (*.f64 y z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(+.f64 (*.f64 y z) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(*.f64 y z)
(*.f64 (cos.f64 y) x)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
Outputs
x
(+.f64 (*.f64 y z) x)
(fma.f64 y z x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x))
(fma.f64 y z (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x))
(fma.f64 (*.f64 y y) (*.f64 x -1/2) (fma.f64 y z x))
(fma.f64 y z (fma.f64 y (*.f64 -1/2 (*.f64 x y)) x))
(fma.f64 y (fma.f64 x (*.f64 y -1/2) z) x)
(+.f64 (*.f64 y z) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 y 4) x)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)) x)))
(fma.f64 y z (fma.f64 1/24 (*.f64 x (pow.f64 y 4)) (fma.f64 -1/2 (*.f64 x (*.f64 y y)) x)))
(fma.f64 x (fma.f64 1/24 (pow.f64 y 4) (*.f64 y (*.f64 y -1/2))) (fma.f64 y z x))
(fma.f64 x (*.f64 y (*.f64 y (fma.f64 (*.f64 y y) 1/24 -1/2))) (fma.f64 y z x))
(fma.f64 x (*.f64 1/24 (pow.f64 y 4)) (fma.f64 y (fma.f64 x (*.f64 y -1/2) z) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(*.f64 y z)
(*.f64 (cos.f64 y) x)
(*.f64 x (cos.f64 y))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))
(+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))
(fma.f64 y z (*.f64 x (cos.f64 y)))
(fma.f64 x (cos.f64 y) (*.f64 y z))

localize29.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (cos.f64 y))
0.4b
(pow.f64 (sin.f64 y) 3)
9.4b
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))
35.6b
(cbrt.f64 (*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3)))
Compiler

Compiled 53 to 29 computations (45.3% saved)

series8.0ms (0.1%)

Counts
3 → 52
Calls

15 calls:

TimeVariablePointExpression
1.0ms
y
@inf
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))
1.0ms
z
@0
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))
1.0ms
y
@-inf
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))
1.0ms
y
@0
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))
1.0ms
z
@inf
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))

rewrite71.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
776×pow1_binary64
722×add-log-exp_binary64
722×log1p-expm1-u_binary64
722×expm1-log1p-u_binary64
700×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0921
119421
2204521
Stop Event
node limit
Counts
3 → 56
Calls
Call 1
Inputs
(cbrt.f64 (*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3)))
(*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))
(pow.f64 (sin.f64 y) 3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (sin.f64 y) z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 y) z)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 z (sin.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sin.f64 y) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (sin.f64 y) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (sin.f64 y) z)) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 y) z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (sin.f64 y) z)) 2) (cbrt.f64 (*.f64 (sin.f64 y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 y)) 2) (*.f64 (cbrt.f64 (sin.f64 y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 (sin.f64 y) z)) (sqrt.f64 (*.f64 (sin.f64 y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 y)) (*.f64 (sqrt.f64 (sin.f64 y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (*.f64 (sin.f64 y) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 2) 1/3) (cbrt.f64 (*.f64 (sin.f64 y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3/2) 1/3) (pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3/2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sin.f64 y) (pow.f64 (cbrt.f64 z) 2)) (cbrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sin.f64 y) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (sin.f64 y) z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (sin.f64 y) z)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (sin.f64 y) z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sin.f64 y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (sin.f64 y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (sin.f64 y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (sin.f64 y) z)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (*.f64 (sin.f64 y) z) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sin.f64 y) z) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3/2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (sin.f64 y) z) 6))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (pow.f64 (sin.f64 y) 3) 3) (pow.f64 (pow.f64 z 3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (pow.f64 z 3) 3) (pow.f64 (pow.f64 (sin.f64 y) 3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (*.f64 (sin.f64 y) z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 3 (log.f64 (*.f64 (sin.f64 y) z))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (sin.f64 y) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 y) (pow.f64 (sin.f64 y) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sin.f64 y) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (sin.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sin.f64 y) 2) (sin.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 y)) 2) (*.f64 (cbrt.f64 (sin.f64 y)) (pow.f64 (sin.f64 y) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 y)) (*.f64 (sqrt.f64 (sin.f64 y)) (pow.f64 (sin.f64 y) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sin.f64 y) 3/2) (pow.f64 (sin.f64 y) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (sin.f64 y)) 2) 3) (sin.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (sin.f64 y)) 3) (pow.f64 (sqrt.f64 (sin.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (sin.f64 y) 2) 1) (sin.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (sin.f64 y) 2) (pow.f64 (cbrt.f64 (sin.f64 y)) 2)) (cbrt.f64 (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (sin.f64 y) 2) (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (sin.f64 y) 6))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (sin.f64 y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (sin.f64 y) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (sin.f64 y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (sin.f64 y) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 3 (log.f64 (sin.f64 y))))))))

simplify163.0ms (1.4%)

Algorithm
egg-herbie
Rules
736×distribute-lft-out_binary64
679×distribute-rgt-in_binary64
676×unswap-sqr_binary64
419×fma-def_binary64
386×distribute-lft-in_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
059646
1164623
2568594
32197594
43216591
54648591
65054591
75314591
85686591
96475591
107713591
Stop Event
node limit
Counts
108 → 81
Calls
Call 1
Inputs
(*.f64 y z)
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (*.f64 y z))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (*.f64 1/120 (*.f64 (pow.f64 y 5) z))))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (+.f64 (*.f64 -1/5040 (*.f64 (pow.f64 y 7) z)) (*.f64 1/120 (*.f64 (pow.f64 y 5) z)))))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(*.f64 (pow.f64 y 3) (pow.f64 z 3))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3))) (*.f64 (pow.f64 y 3) (pow.f64 z 3)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 13/120 (*.f64 (pow.f64 y 7) (pow.f64 z 3)))))
(+.f64 (*.f64 -41/3024 (*.f64 (pow.f64 y 9) (pow.f64 z 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 13/120 (*.f64 (pow.f64 y 7) (pow.f64 z 3))))))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(pow.f64 y 3)
(+.f64 (pow.f64 y 3) (*.f64 -1/2 (pow.f64 y 5)))
(+.f64 (pow.f64 y 3) (+.f64 (*.f64 -1/2 (pow.f64 y 5)) (*.f64 13/120 (pow.f64 y 7))))
(+.f64 (pow.f64 y 3) (+.f64 (*.f64 -1/2 (pow.f64 y 5)) (+.f64 (*.f64 -41/3024 (pow.f64 y 9)) (*.f64 13/120 (pow.f64 y 7)))))
Outputs
(*.f64 y z)
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (*.f64 y z))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 y z))
(*.f64 z (+.f64 y (*.f64 -1/6 (pow.f64 y 3))))
(*.f64 z (fma.f64 -1/6 (pow.f64 y 3) y))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (*.f64 1/120 (*.f64 (pow.f64 y 5) z))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (*.f64 1/120 (*.f64 z (pow.f64 y 5)))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (*.f64 z (+.f64 y (*.f64 1/120 (pow.f64 y 5)))))
(*.f64 z (+.f64 (*.f64 -1/6 (pow.f64 y 3)) (fma.f64 1/120 (pow.f64 y 5) y)))
(*.f64 z (+.f64 (*.f64 1/120 (pow.f64 y 5)) (fma.f64 -1/6 (pow.f64 y 3) y)))
(+.f64 (*.f64 -1/6 (*.f64 (pow.f64 y 3) z)) (+.f64 (*.f64 y z) (+.f64 (*.f64 -1/5040 (*.f64 (pow.f64 y 7) z)) (*.f64 1/120 (*.f64 (pow.f64 y 5) z)))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (fma.f64 -1/5040 (*.f64 z (pow.f64 y 7)) (*.f64 1/120 (*.f64 z (pow.f64 y 5))))))
(fma.f64 -1/6 (*.f64 z (pow.f64 y 3)) (fma.f64 y z (*.f64 z (+.f64 (*.f64 1/120 (pow.f64 y 5)) (*.f64 -1/5040 (pow.f64 y 7))))))
(*.f64 z (+.f64 (fma.f64 -1/6 (pow.f64 y 3) y) (fma.f64 -1/5040 (pow.f64 y 7) (*.f64 1/120 (pow.f64 y 5)))))
(*.f64 z (+.f64 (fma.f64 1/120 (pow.f64 y 5) (*.f64 -1/5040 (pow.f64 y 7))) (fma.f64 -1/6 (pow.f64 y 3) y)))
(*.f64 z (+.f64 (fma.f64 -1/5040 (pow.f64 y 7) (*.f64 1/120 (pow.f64 y 5))) (fma.f64 -1/6 (pow.f64 y 3) y)))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 z (sin.f64 y))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(*.f64 (*.f64 z (sin.f64 y)) (neg.f64 (cbrt.f64 -1)))
(*.f64 z (*.f64 (sin.f64 y) (neg.f64 (cbrt.f64 -1))))
(*.f64 (cbrt.f64 -1) (*.f64 (sin.f64 y) (neg.f64 z)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(*.f64 (*.f64 z (sin.f64 y)) (neg.f64 (cbrt.f64 -1)))
(*.f64 z (*.f64 (sin.f64 y) (neg.f64 (cbrt.f64 -1))))
(*.f64 (cbrt.f64 -1) (*.f64 (sin.f64 y) (neg.f64 z)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(*.f64 (*.f64 z (sin.f64 y)) (neg.f64 (cbrt.f64 -1)))
(*.f64 z (*.f64 (sin.f64 y) (neg.f64 (cbrt.f64 -1))))
(*.f64 (cbrt.f64 -1) (*.f64 (sin.f64 y) (neg.f64 z)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 z (sin.f64 y))))
(neg.f64 (*.f64 (*.f64 z (sin.f64 y)) (cbrt.f64 -1)))
(*.f64 (*.f64 z (sin.f64 y)) (neg.f64 (cbrt.f64 -1)))
(*.f64 z (*.f64 (sin.f64 y) (neg.f64 (cbrt.f64 -1))))
(*.f64 (cbrt.f64 -1) (*.f64 (sin.f64 y) (neg.f64 z)))
(*.f64 (pow.f64 y 3) (pow.f64 z 3))
(pow.f64 (*.f64 y z) 3)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3))) (*.f64 (pow.f64 y 3) (pow.f64 z 3)))
(fma.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3)) (*.f64 (pow.f64 y 3) (pow.f64 z 3)))
(*.f64 (pow.f64 z 3) (fma.f64 (pow.f64 y 5) -1/2 (pow.f64 y 3)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 13/120 (*.f64 (pow.f64 y 7) (pow.f64 z 3)))))
(fma.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3)) (fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 13/120 (*.f64 (pow.f64 y 7) (pow.f64 z 3)))))
(+.f64 (*.f64 (pow.f64 z 3) (fma.f64 (pow.f64 y 5) -1/2 (pow.f64 y 3))) (*.f64 (pow.f64 y 7) (*.f64 (pow.f64 z 3) 13/120)))
(*.f64 (pow.f64 z 3) (fma.f64 (pow.f64 y 5) -1/2 (fma.f64 (pow.f64 y 7) 13/120 (pow.f64 y 3))))
(+.f64 (*.f64 -41/3024 (*.f64 (pow.f64 y 9) (pow.f64 z 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3))) (+.f64 (*.f64 (pow.f64 y 3) (pow.f64 z 3)) (*.f64 13/120 (*.f64 (pow.f64 y 7) (pow.f64 z 3))))))
(fma.f64 -41/3024 (*.f64 (pow.f64 z 3) (pow.f64 y 9)) (fma.f64 -1/2 (*.f64 (pow.f64 y 5) (pow.f64 z 3)) (fma.f64 (pow.f64 y 3) (pow.f64 z 3) (*.f64 13/120 (*.f64 (pow.f64 y 7) (pow.f64 z 3))))))
(+.f64 (*.f64 (pow.f64 z 3) (+.f64 (*.f64 (pow.f64 y 7) 13/120) (pow.f64 y 3))) (*.f64 (pow.f64 z 3) (fma.f64 (pow.f64 y 5) -1/2 (*.f64 -41/3024 (pow.f64 y 9)))))
(*.f64 (pow.f64 z 3) (+.f64 (fma.f64 (pow.f64 y 5) -1/2 (pow.f64 y 3)) (fma.f64 (pow.f64 y 7) 13/120 (*.f64 -41/3024 (pow.f64 y 9)))))
(*.f64 (pow.f64 z 3) (+.f64 (fma.f64 -41/3024 (pow.f64 y 9) (*.f64 (pow.f64 y 5) -1/2)) (fma.f64 (pow.f64 y 7) 13/120 (pow.f64 y 3))))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(*.f64 (pow.f64 z 3) (pow.f64 (sin.f64 y) 3))
(pow.f64 y 3)
(+.f64 (pow.f64 y 3) (*.f64 -1/2 (pow.f64 y 5)))
(+.f64 (pow.f64 y 3) (*.f64 (pow.f64 y 5) -1/2))
(fma.f64 (pow.f64 y 5) -1/2 (pow.f64 y 3))
(+.f64 (pow.f64 y 3) (+.f64 (*.f64 -1/2 (pow.f64 y 5)) (*.f64 13/120 (pow.f64 y 7))))
(+.f64 (pow.f64 y 3) (fma.f64 -1/2 (pow.f64 y 5) (*.f64 (pow.f64 y 7) 13/120)))
(+.f64 (pow.f64 y 3) (fma.f64 (pow.f64 y 5) -1/2 (*.f64 (pow.f64 y 7) 13/120)))
(fma.f64 (pow.f64 y 5) -1/2 (fma.f64 (pow.f64 y 7) 13/120 (pow.f64 y 3)))
(+.f64 (pow.f64 y 3) (+.f64 (*.f64 -1/2 (pow.f64 y 5)) (+.f64 (*.f64 -41/3024 (pow.f64 y 9)) (*.f64 13/120 (pow.f64 y 7)))))
(+.f64 (pow.f64 y 3) (fma.f64 -1/2 (pow.f64 y 5) (fma.f64 -41/3024 (pow.f64 y 9) (*.f64 (pow.f64 y 7) 13/120))))
(+.f64 (pow.f64 y 3) (fma.f64 (pow.f64 y 5) -1/2 (fma.f64 (pow.f64 y 7) 13/120 (*.f64 -41/3024 (pow.f64 y 9)))))
(+.f64 (fma.f64 (pow.f64 y 5) -1/2 (pow.f64 y 3)) (fma.f64 (pow.f64 y 7) 13/120 (*.f64 -41/3024 (pow.f64 y 9))))
(+.f64 (fma.f64 -41/3024 (pow.f64 y 9) (*.f64 (pow.f64 y 5) -1/2)) (fma.f64 (pow.f64 y 7) 13/120 (pow.f64 y 3)))

eval152.0ms (1.3%)

Compiler

Compiled 8872 to 4062 computations (54.2% saved)

prune121.0ms (1%)

Pruning

32 alts after pruning (23 fresh and 9 done)

PrunedKeptTotal
New52615541
Fresh10818
Picked101
Done2911
Total53932571
Error
0.0b
Counts
571 → 32
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(+.f64 (*.f64 x (-.f64 (-.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) 1) 1)) (*.f64 z (sin.f64 y)))
53.7b
(cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3))
0.9b
(+.f64 (*.f64 x (-.f64 (pow.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 2) 1)) (*.f64 z (sin.f64 y)))
31.3b
(pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 2)
42.4b
(+.f64 x (cbrt.f64 (*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))))
1.3b
(pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 3)
17.4b
(+.f64 (/.f64 1 (/.f64 (*.f64 x (+.f64 (cos.f64 y) 0)) (pow.f64 (*.f64 x (+.f64 (cos.f64 y) 0)) 2))) (*.f64 z (sin.f64 y)))
28.0b
(*.f64 (cos.f64 y) x)
15.4b
(+.f64 x (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))) 3) 3))
32.2b
(fma.f64 z y x)
0.3b
(fma.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 2))) (cbrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
24.7b
(+.f64 (*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (*.f64 y z))
52.1b
(*.f64 y z)
14.5b
(+.f64 x (*.f64 z (sin.f64 y)))
3.7b
(fma.f64 (*.f64 z (cbrt.f64 (pow.f64 (sin.f64 y) 2))) (cbrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
42.7b
(+.f64 x (*.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y))))
45.0b
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
35.0b
(*.f64 z (sin.f64 y))
24.6b
(+.f64 (+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x)) (*.f64 y z))
0.3b
(+.f64 (-.f64 (+.f64 x (*.f64 (cos.f64 y) x)) x) (*.f64 z (sin.f64 y)))
15.1b
(+.f64 x (pow.f64 (*.f64 (cbrt.f64 (sin.f64 y)) (cbrt.f64 z)) 3))
35.5b
(pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)
40.8b
(+.f64 x (*.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z)))
41.6b
x
0.3b
(+.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (*.f64 z (sin.f64 y)))
46.8b
(pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2)
0.2b
(+.f64 (*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)) (*.f64 z (sin.f64 y)))
44.5b
(pow.f64 (sqrt.f64 (+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))) 2)
34.8b
(+.f64 x (*.f64 (cbrt.f64 (*.f64 z z)) (*.f64 (cbrt.f64 z) (sin.f64 y))))
0.2b
(+.f64 (*.f64 x (log.f64 (exp.f64 (cos.f64 y)))) (*.f64 z (sin.f64 y)))
0.2b
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
32.2b
(+.f64 (*.f64 y z) x)
Compiler

Compiled 424 to 301 computations (29% saved)

regimes245.0ms (2.1%)

Counts
63 → 1
Calls
Call 1
Inputs
x
x
x
(*.f64 y z)
(+.f64 (*.f64 y z) x)
(*.f64 (cos.f64 y) x)
(fma.f64 z y x)
(*.f64 z (sin.f64 y))
(fma.f64 z y x)
(*.f64 (cos.f64 y) x)
(fma.f64 y z x)
(*.f64 z (sin.f64 y))
(+.f64 x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 y z))
(+.f64 (+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x)) (*.f64 y z))
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(+.f64 (-.f64 (+.f64 x (*.f64 (cos.f64 y) x)) x) (*.f64 z (sin.f64 y)))
(+.f64 (+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (-.f64 (-.f64 (+.f64 (+.f64 1 (cos.f64 y)) 1) 1) 1)) (*.f64 z (sin.f64 y)))
(cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3))
(pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3)
(pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2)
(+.f64 x (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3))
(+.f64 x (pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2))
(+.f64 x (cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))
(+.f64 x (*.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z)))
(pow.f64 (sqrt.f64 (+.f64 (*.f64 y z) (*.f64 (cos.f64 y) x))) 2)
(+.f64 (*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (*.f64 y z))
(+.f64 x (*.f64 (cbrt.f64 (*.f64 z z)) (*.f64 (cbrt.f64 z) (sin.f64 y))))
(/.f64 1 (/.f64 (-.f64 x (*.f64 z (sin.f64 y))) (-.f64 (*.f64 x x) (pow.f64 (*.f64 z (sin.f64 y)) 2))))
(*.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 z (sin.f64 y)) 2)) (/.f64 1 (-.f64 x (*.f64 z (sin.f64 y)))))
(+.f64 x (pow.f64 (*.f64 (cbrt.f64 (sin.f64 y)) (cbrt.f64 z)) 3))
(+.f64 x (cbrt.f64 (*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))))
(+.f64 x (*.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y))))
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 y z))
(+.f64 (*.f64 x (log.f64 (exp.f64 (cos.f64 y)))) (*.f64 z (sin.f64 y)))
(pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 2)
(pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 (cos.f64 y) x))) 3)
(pow.f64 (sqrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 2)
(pow.f64 (cbrt.f64 (+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))) 3)
(+.f64 (pow.f64 (sqrt.f64 (*.f64 x (cos.f64 y))) 2) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (pow.f64 (sqrt.f64 (cos.f64 y)) 2)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (cos.f64 y)) (pow.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) 2))
(+.f64 (*.f64 x (cos.f64 y)) (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3))
(+.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (pow.f64 (*.f64 z (sin.f64 y)) 3)))
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z)))
(+.f64 (*.f64 x (-.f64 (exp.f64 (log1p.f64 (cos.f64 y))) 1)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (-.f64 (pow.f64 (sqrt.f64 (+.f64 1 (cos.f64 y))) 2) 1)) (*.f64 z (sin.f64 y)))
(+.f64 (/.f64 1 (/.f64 (*.f64 x (+.f64 (cos.f64 y) 0)) (pow.f64 (*.f64 x (+.f64 (cos.f64 y) 0)) 2))) (*.f64 z (sin.f64 y)))
(+.f64 x (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))) 3) 3))
(fma.f64 (*.f64 (cos.f64 y) (sqrt.f64 x)) (sqrt.f64 x) (*.f64 z (sin.f64 y)))
(fma.f64 (*.f64 (sin.f64 y) (sqrt.f64 z)) (sqrt.f64 z) (*.f64 x (cos.f64 y)))
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y))))
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (*.f64 (pow.f64 (sin.f64 y) 3) (pow.f64 z 3))))
(fma.f64 (*.f64 x (sqrt.f64 (cos.f64 y))) (sqrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
(fma.f64 (*.f64 z (sqrt.f64 (sin.f64 y))) (sqrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
(fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (cos.f64 y)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (cos.f64 y)) (cbrt.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) 3) 3)))
(fma.f64 (*.f64 x (cbrt.f64 (pow.f64 (cos.f64 y) 2))) (cbrt.f64 (cos.f64 y)) (*.f64 z (sin.f64 y)))
(fma.f64 (*.f64 z (cbrt.f64 (pow.f64 (sin.f64 y) 2))) (cbrt.f64 (sin.f64 y)) (*.f64 x (cos.f64 y)))
(+.f64 (*.f64 x (+.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 y)))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 y)))))) (*.f64 z (sin.f64 y)))
Outputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
Calls

4 calls:

69.0ms
z
54.0ms
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
53.0ms
y
37.0ms
x
Results
ErrorSegmentsBranch
0.2b1x
0.2b1y
0.2b1z
0.2b1(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
Compiler

Compiled 695 to 249 computations (64.2% saved)

regimes294.0ms (2.5%)

Counts
15 → 7
Calls
Call 1
Inputs
x
x
x
(*.f64 y z)
(+.f64 (*.f64 y z) x)
(*.f64 (cos.f64 y) x)
(fma.f64 z y x)
(*.f64 z (sin.f64 y))
(fma.f64 z y x)
(*.f64 (cos.f64 y) x)
(fma.f64 y z x)
(*.f64 z (sin.f64 y))
(+.f64 x (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 y z))
(+.f64 (+.f64 (*.f64 (+.f64 1 (cos.f64 y)) x) (*.f64 -1 x)) (*.f64 y z))
Outputs
(+.f64 x (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(+.f64 x (*.f64 z (sin.f64 y)))
(*.f64 (cos.f64 y) x)
(*.f64 z (sin.f64 y))
(*.f64 (cos.f64 y) x)
(+.f64 x (*.f64 z (sin.f64 y)))
Calls

3 calls:

119.0ms
z
110.0ms
y
60.0ms
x
Results
ErrorSegmentsBranch
9.0b3x
11.9b5y
3.9b7z
Compiler

Compiled 82 to 30 computations (63.4% saved)

bsearch931.0ms (7.9%)

Algorithm
binary-search
Steps
TimeLeftRight
228.0ms
6.346609771289541e-75
2.0034994127818026e-70
257.0ms
1.3431943441470405e-118
3.300257962750949e-115
123.0ms
5.6296287302526506e-145
5.6881035784240744e-129
107.0ms
-5.07117478959281e-89
-1.508523340639381e-102
75.0ms
-0.0006250749902912553
-6.582803330243139e-15
140.0ms
-1.0534156578752266e+85
-4.329251279680388e+84
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes253.0ms (2.2%)

Counts
12 → 7
Calls
Call 1
Inputs
x
x
x
(*.f64 y z)
(+.f64 (*.f64 y z) x)
(*.f64 (cos.f64 y) x)
(fma.f64 z y x)
(*.f64 z (sin.f64 y))
(fma.f64 z y x)
(*.f64 (cos.f64 y) x)
(fma.f64 y z x)
(*.f64 z (sin.f64 y))
Outputs
(*.f64 z (sin.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 z (sin.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 z (sin.f64 y))
(*.f64 (cos.f64 y) x)
(*.f64 z (sin.f64 y))
Calls

3 calls:

133.0ms
z
66.0ms
x
50.0ms
y
Results
ErrorSegmentsBranch
13.5b3x
14.7b5y
10.6b7z
Compiler

Compiled 54 to 20 computations (63% saved)

bsearch785.0ms (6.7%)

Algorithm
binary-search
Steps
TimeLeftRight
179.0ms
1.127550276082568e-66
1.4738264609525582e-55
86.0ms
1.3431943441470405e-118
3.300257962750949e-115
174.0ms
5.6296287302526506e-145
5.6881035784240744e-129
124.0ms
-6.260393229177624e-38
-2.5922424577211068e-49
166.0ms
-0.0006250749902912553
-6.582803330243139e-15
55.0ms
-1.0534156578752266e+85
-4.329251279680388e+84
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes62.0ms (0.5%)

Counts
7 → 3
Calls
Call 1
Inputs
x
x
x
(*.f64 y z)
(+.f64 (*.f64 y z) x)
(*.f64 (cos.f64 y) x)
(fma.f64 z y x)
Outputs
(*.f64 (cos.f64 y) x)
(fma.f64 z y x)
(*.f64 (cos.f64 y) x)
Calls

3 calls:

31.0ms
y
15.0ms
x
14.0ms
z
Results
ErrorSegmentsBranch
22.0b3x
17.9b3y
20.6b3z
Compiler

Compiled 34 to 17 computations (50% saved)

bsearch223.0ms (1.9%)

Algorithm
binary-search
Steps
TimeLeftRight
166.0ms
1.9709589350215084e-6
4.061146230053281
56.0ms
-4.773562577435384e-7
-3.7524582276412786e-20
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes136.0ms (1.2%)

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

3 calls:

106.0ms
x
15.0ms
y
13.0ms
z
Results
ErrorSegmentsBranch
22.0b3x
17.9b3y
20.6b3z
Compiler

Compiled 30 to 16 computations (46.7% saved)

bsearch74.0ms (0.6%)

Algorithm
binary-search
Steps
TimeLeftRight
35.0ms
1.9709589350215084e-6
4.061146230053281
39.0ms
-4.773562577435384e-7
-3.7524582276412786e-20
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes36.0ms (0.3%)

Counts
5 → 1
Calls
Call 1
Inputs
x
x
x
(*.f64 y z)
(+.f64 (*.f64 y z) x)
Outputs
(+.f64 (*.f64 y z) x)
Calls

3 calls:

20.0ms
z
9.0ms
x
5.0ms
y
Results
ErrorSegmentsBranch
32.2b1x
32.2b1y
32.2b1z
Compiler

Compiled 26 to 14 computations (46.2% saved)

regimes182.0ms (1.5%)

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

3 calls:

131.0ms
z
24.0ms
x
24.0ms
y
Results
ErrorSegmentsBranch
36.5b3x
39.9b3y
38.2b2z
Compiler

Compiled 21 to 13 computations (38.1% saved)

bsearch252.0ms (2.1%)

Algorithm
binary-search
Steps
TimeLeftRight
138.0ms
1.954327378733383e-108
9.40598540089577e-104
114.0ms
-1.2296590947315732e-76
-3.499000822520246e-79
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes92.0ms (0.8%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0.0b (-0%)

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

3 calls:

72.0ms
y
10.0ms
x
8.0ms
z
Results
ErrorSegmentsBranch
41.6b1x
41.6b1y
41.6b1z
Compiler

Compiled 18 to 12 computations (33.3% saved)

simplify17.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
057265
163265
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(if (<=.f64 z -10534156578752265976675101202204290385762507306394592203912830865647131065580527812608) (+.f64 x (*.f64 z (sin.f64 y))) (if (<=.f64 z -5765299186389635/9223372036854775808) (*.f64 (cos.f64 y) x) (if (<=.f64 z -3634603862929641/71671831749689734737838152978190216899892655911508785116799651230841339877765150252188079784691427704832) (+.f64 x (*.f64 z (sin.f64 y))) (if (<=.f64 z 3957377242607867/7029552803973744348141466418259346654483901747346744739219930582205996219799199797373501072037329464296751422864876398630012915711709843264075804970101818523648) (*.f64 (cos.f64 y) x) (if (<=.f64 z 6101785397380683/45427420268475430659332737993000283397102585042957378767593137448789955507087370207886940669610222847547657600391636120845912601788416) (*.f64 z (sin.f64 y)) (if (<=.f64 z 3232068107968195/509258994083621521567111422102344540262867098416484062659035112338595324940834176545849344) (*.f64 (cos.f64 y) x) (+.f64 x (*.f64 z (sin.f64 y)))))))))
(if (<=.f64 z -10534156578752265976675101202204290385762507306394592203912830865647131065580527812608) (*.f64 z (sin.f64 y)) (if (<=.f64 z -5765299186389635/9223372036854775808) (*.f64 (cos.f64 y) x) (if (<=.f64 z -2998132721181785/47890485652059026823698344598447161988085597568237568) (*.f64 z (sin.f64 y)) (if (<=.f64 z 3957377242607867/7029552803973744348141466418259346654483901747346744739219930582205996219799199797373501072037329464296751422864876398630012915711709843264075804970101818523648) (*.f64 (cos.f64 y) x) (if (<=.f64 z 6101785397380683/45427420268475430659332737993000283397102585042957378767593137448789955507087370207886940669610222847547657600391636120845912601788416) (*.f64 z (sin.f64 y)) (if (<=.f64 z 4278236026886987/3794275180128377091639574036764685364535950857523710002444946112771297432041422848) (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y))))))))
(if (<=.f64 y -4508502383912339/9444732965739290427392) (*.f64 (cos.f64 y) x) (if (<=.f64 y 4653795206929011/2361183241434822606848) (fma.f64 z y x) (*.f64 (cos.f64 y) x)))
(if (<=.f64 y -4508502383912339/9444732965739290427392) (*.f64 (cos.f64 y) x) (if (<=.f64 y 4653795206929011/2361183241434822606848) (+.f64 (*.f64 y z) x) (*.f64 (cos.f64 y) x)))
(+.f64 (*.f64 y z) x)
(if (<=.f64 x -4007775703352177/32592575621351777380295131014550050576823494298654980010178247189670100796213387298934358016) x (if (<=.f64 x 2583839557363807/1322111937580497197903830616065542079656809365928562438569297590548811582472622691650378420879430569695182424050046716608512) (*.f64 y z) x))
x
Outputs
(+.f64 (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
(+.f64 (*.f64 z (sin.f64 y)) (*.f64 x (cos.f64 y)))
(if (<=.f64 z -10534156578752265976675101202204290385762507306394592203912830865647131065580527812608) (+.f64 x (*.f64 z (sin.f64 y))) (if (<=.f64 z -5765299186389635/9223372036854775808) (*.f64 (cos.f64 y) x) (if (<=.f64 z -3634603862929641/71671831749689734737838152978190216899892655911508785116799651230841339877765150252188079784691427704832) (+.f64 x (*.f64 z (sin.f64 y))) (if (<=.f64 z 3957377242607867/7029552803973744348141466418259346654483901747346744739219930582205996219799199797373501072037329464296751422864876398630012915711709843264075804970101818523648) (*.f64 (cos.f64 y) x) (if (<=.f64 z 6101785397380683/45427420268475430659332737993000283397102585042957378767593137448789955507087370207886940669610222847547657600391636120845912601788416) (*.f64 z (sin.f64 y)) (if (<=.f64 z 3232068107968195/509258994083621521567111422102344540262867098416484062659035112338595324940834176545849344) (*.f64 (cos.f64 y) x) (+.f64 x (*.f64 z (sin.f64 y)))))))))
(if (<=.f64 z -10534156578752265976675101202204290385762507306394592203912830865647131065580527812608) (+.f64 x (*.f64 z (sin.f64 y))) (if (<=.f64 z -5765299186389635/9223372036854775808) (*.f64 x (cos.f64 y)) (if (<=.f64 z -3634603862929641/71671831749689734737838152978190216899892655911508785116799651230841339877765150252188079784691427704832) (+.f64 x (*.f64 z (sin.f64 y))) (if (<=.f64 z 3957377242607867/7029552803973744348141466418259346654483901747346744739219930582205996219799199797373501072037329464296751422864876398630012915711709843264075804970101818523648) (*.f64 x (cos.f64 y)) (if (<=.f64 z 6101785397380683/45427420268475430659332737993000283397102585042957378767593137448789955507087370207886940669610222847547657600391636120845912601788416) (*.f64 z (sin.f64 y)) (if (<=.f64 z 3232068107968195/509258994083621521567111422102344540262867098416484062659035112338595324940834176545849344) (*.f64 x (cos.f64 y)) (+.f64 x (*.f64 z (sin.f64 y)))))))))
(if (<=.f64 z -10534156578752265976675101202204290385762507306394592203912830865647131065580527812608) (*.f64 z (sin.f64 y)) (if (<=.f64 z -5765299186389635/9223372036854775808) (*.f64 (cos.f64 y) x) (if (<=.f64 z -2998132721181785/47890485652059026823698344598447161988085597568237568) (*.f64 z (sin.f64 y)) (if (<=.f64 z 3957377242607867/7029552803973744348141466418259346654483901747346744739219930582205996219799199797373501072037329464296751422864876398630012915711709843264075804970101818523648) (*.f64 (cos.f64 y) x) (if (<=.f64 z 6101785397380683/45427420268475430659332737993000283397102585042957378767593137448789955507087370207886940669610222847547657600391636120845912601788416) (*.f64 z (sin.f64 y)) (if (<=.f64 z 4278236026886987/3794275180128377091639574036764685364535950857523710002444946112771297432041422848) (*.f64 (cos.f64 y) x) (*.f64 z (sin.f64 y))))))))
(if (<=.f64 z -10534156578752265976675101202204290385762507306394592203912830865647131065580527812608) (*.f64 z (sin.f64 y)) (if (<=.f64 z -5765299186389635/9223372036854775808) (*.f64 x (cos.f64 y)) (if (<=.f64 z -2998132721181785/47890485652059026823698344598447161988085597568237568) (*.f64 z (sin.f64 y)) (if (<=.f64 z 3957377242607867/7029552803973744348141466418259346654483901747346744739219930582205996219799199797373501072037329464296751422864876398630012915711709843264075804970101818523648) (*.f64 x (cos.f64 y)) (if (<=.f64 z 6101785397380683/45427420268475430659332737993000283397102585042957378767593137448789955507087370207886940669610222847547657600391636120845912601788416) (*.f64 z (sin.f64 y)) (if (<=.f64 z 4278236026886987/3794275180128377091639574036764685364535950857523710002444946112771297432041422848) (*.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y))))))))
(if (<=.f64 y -4508502383912339/9444732965739290427392) (*.f64 (cos.f64 y) x) (if (<=.f64 y 4653795206929011/2361183241434822606848) (fma.f64 z y x) (*.f64 (cos.f64 y) x)))
(if (<=.f64 y -4508502383912339/9444732965739290427392) (*.f64 x (cos.f64 y)) (if (<=.f64 y 4653795206929011/2361183241434822606848) (fma.f64 z y x) (*.f64 x (cos.f64 y))))
(if (<=.f64 y -4508502383912339/9444732965739290427392) (*.f64 (cos.f64 y) x) (if (<=.f64 y 4653795206929011/2361183241434822606848) (+.f64 (*.f64 y z) x) (*.f64 (cos.f64 y) x)))
(if (<=.f64 y -4508502383912339/9444732965739290427392) (*.f64 x (cos.f64 y)) (if (<=.f64 y 4653795206929011/2361183241434822606848) (+.f64 x (*.f64 y z)) (*.f64 x (cos.f64 y))))
(+.f64 (*.f64 y z) x)
(+.f64 x (*.f64 y z))
(if (<=.f64 x -4007775703352177/32592575621351777380295131014550050576823494298654980010178247189670100796213387298934358016) x (if (<=.f64 x 2583839557363807/1322111937580497197903830616065542079656809365928562438569297590548811582472622691650378420879430569695182424050046716608512) (*.f64 y z) x))
x
Compiler

Compiled 203 to 102 computations (49.8% saved)

soundness0.0ms (0%)

end260.0ms (2.2%)

Compiler

Compiled 182 to 66 computations (63.7% saved)

Profiling

Loading profile data...