Details

Time bar (total: 6.8s)

analyze3.0ms (0%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
25%50%25%3
37.5%25%37.5%4
43.7%12.5%43.8%5
46.9%6.2%46.9%6
48.4%3.1%48.5%7
49.2%1.6%49.2%8
49.6%0.8%49.6%9
49.6%0.4%50%10
49.7%0.2%50.1%11
49.7%0.1%50.2%12
Compiler

Compiled 6 to 4 computations (33.3% saved)

sample1.7s (25%)

Results
1.7s8256×body256valid
1.0ms13×body256invalid

preprocess30.0ms (0.4%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
046
156
011
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(*.f64 x (log.f64 x))
Outputs
(*.f64 x (log.f64 x))
Compiler

Compiled 6 to 4 computations (33.3% saved)

simplify12.0ms (0.2%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
046
156
Stop Event
saturated
Counts
1 → 1
Calls
Call 1
Inputs
(*.f64 x (log.f64 x))
Outputs
(*.f64 x (log.f64 x))

eval1.0ms (0%)

Compiler

Compiled 5 to 3 computations (40% saved)

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.3b
Counts
2 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(*.f64 x (log.f64 x))
Compiler

Compiled 5 to 3 computations (40% saved)

localize22.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.3b
(*.f64 x (log.f64 x))
Compiler

Compiled 8 to 3 computations (62.5% saved)

series110.0ms (1.6%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
55.0ms
x
@0
(*.f64 x (log.f64 x))
36.0ms
x
@-inf
(*.f64 x (log.f64 x))
18.0ms
x
@inf
(*.f64 x (log.f64 x))

rewrite75.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
348×pow1_binary64
332×add-sqr-sqrt_binary64
327×*-un-lft-identity_binary64
319×add-log-exp_binary64
319×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
046
1766
28876
Stop Event
node limit
Counts
1 → 23
Calls
Call 1
Inputs
(*.f64 x (log.f64 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (cbrt.f64 (pow.f64 x (+.f64 x x)))) (log.f64 (cbrt.f64 (pow.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 x x))) (log.f64 (sqrt.f64 (pow.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (*.f64 x (log.f64 x))) 3) 1) (+.f64 (*.f64 (+.f64 1 (*.f64 x (log.f64 x))) (+.f64 1 (*.f64 x (log.f64 x)))) (+.f64 1 (*.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 x (log.f64 x))))) (sqrt.f64 (log.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (cbrt.f64 (pow.f64 (log.f64 (*.f64 x (log.f64 x))) 2))) (cbrt.f64 (log.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 x x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 x (log.f64 x)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x (log.f64 x)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) 2))))))

simplify168.0ms (2.5%)

Algorithm
egg-herbie
Rules
1961×fma-def_binary64
961×fma-neg_binary64
610×distribute-rgt-in_binary64
511×distribute-lft-in_binary64
249×unsub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01672
13372
26072
313472
427572
570472
6198572
7303972
8340772
9357372
10358372
11358572
12484672
13550872
14564072
15567672
16569072
17569472
18569472
19571872
Stop Event
node limit
Counts
35 → 27
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))

eval11.0ms (0.2%)

Compiler

Compiled 243 to 110 computations (54.7% saved)

prune15.0ms (0.2%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New22527
Fresh000
Picked011
Done000
Total22628
Error
0.2b
Counts
28 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
1.4b
(pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)
34.5b
(exp.f64 (log.f64 (*.f64 x (log.f64 x))))
40.4b
(cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))
0.3b
(*.f64 x (log.f64 x))
0.3b
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
Compiler

Compiled 85 to 63 computations (25.9% saved)

localize22.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(log.f64 (/.f64 1 x))
0.3b
(*.f64 (log.f64 (/.f64 1 x)) x)
Compiler

Compiled 25 to 18 computations (28% saved)

series14.0ms (0.2%)

Counts
2 → 16
Calls

6 calls:

TimeVariablePointExpression
9.0ms
x
@-inf
(*.f64 (log.f64 (/.f64 1 x)) x)
3.0ms
x
@0
(*.f64 (log.f64 (/.f64 1 x)) x)
1.0ms
x
@inf
(*.f64 (log.f64 (/.f64 1 x)) x)
0.0ms
x
@0
(log.f64 (/.f64 1 x))
0.0ms
x
@inf
(log.f64 (/.f64 1 x))

rewrite57.0ms (0.8%)

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

Useful iterations: 0 (0.0ms)

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

simplify163.0ms (2.4%)

Algorithm
egg-herbie
Rules
1419×fma-neg_binary64
1009×fma-def_binary64
496×unsub-neg_binary64
411×associate--r-_binary64
391×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
012104
122104
244104
366104
4110104
5227104
6449104
7870104
81473104
91814104
101912104
112326104
123075104
133380104
143521104
153555104
163567104
173571104
187137104
197647104
207933104
Stop Event
node limit
Counts
54 → 42
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
Outputs
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(neg.f64 (log.f64 x))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(neg.f64 (log.f64 x))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(neg.f64 (log.f64 x))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(neg.f64 (log.f64 x))

localize18.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 x (log.f64 x))
2.8b
(exp.f64 (log.f64 (*.f64 x (log.f64 x))))
Compiler

Compiled 19 to 5 computations (73.7% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

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

rewrite66.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
432×pow1_binary64
411×add-sqr-sqrt_binary64
406×*-un-lft-identity_binary64
396×add-log-exp_binary64
396×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify163.0ms (2.4%)

Algorithm
egg-herbie
Rules
1961×fma-def_binary64
961×fma-neg_binary64
610×distribute-rgt-in_binary64
511×distribute-lft-in_binary64
249×unsub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01672
13372
26072
313472
427572
570472
6198572
7303972
8340772
9357372
10358372
11358572
12484672
13550872
14564072
15567672
16569072
17569472
18569472
19571872
Stop Event
node limit
Counts
44 → 34
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))

localize11.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(pow.f64 (*.f64 x (log.f64 x)) 3)
0.3b
(*.f64 x (log.f64 x))
39.1b
(cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))
Compiler

Compiled 22 to 9 computations (59.1% saved)

series6.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

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

rewrite80.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
531×pow1_binary64
517×add-sqr-sqrt_binary64
500×add-log-exp_binary64
500×log1p-expm1-u_binary64
500×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify45.0ms (0.7%)

Algorithm
egg-herbie
Rules
449×distribute-rgt-neg-in_binary64
413×distribute-rgt-in_binary64
406×associate-+l+_binary64
390×distribute-lft-in_binary64
355×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
028280
182276
2291276
31460244
44439244
Stop Event
node limit
Counts
78 → 59
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(neg.f64 (*.f64 (cbrt.f64 -1) (*.f64 x (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))))
(*.f64 (*.f64 x (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x)))) (neg.f64 (cbrt.f64 -1)))
(*.f64 x (*.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))) (neg.f64 (cbrt.f64 -1))))
(*.f64 x (*.f64 (neg.f64 (log.f64 x)) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(neg.f64 (*.f64 (cbrt.f64 -1) (*.f64 x (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))))
(*.f64 (*.f64 x (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x)))) (neg.f64 (cbrt.f64 -1)))
(*.f64 x (*.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))) (neg.f64 (cbrt.f64 -1))))
(*.f64 x (*.f64 (neg.f64 (log.f64 x)) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(neg.f64 (*.f64 (cbrt.f64 -1) (*.f64 x (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))))
(*.f64 (*.f64 x (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x)))) (neg.f64 (cbrt.f64 -1)))
(*.f64 x (*.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))) (neg.f64 (cbrt.f64 -1))))
(*.f64 x (*.f64 (neg.f64 (log.f64 x)) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(neg.f64 (*.f64 (cbrt.f64 -1) (*.f64 x (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))))
(*.f64 (*.f64 x (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x)))) (neg.f64 (cbrt.f64 -1)))
(*.f64 x (*.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))) (neg.f64 (cbrt.f64 -1))))
(*.f64 x (*.f64 (neg.f64 (log.f64 x)) (cbrt.f64 -1)))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 -1 (*.f64 (pow.f64 (log.f64 (/.f64 1 x)) 3) (pow.f64 x 3)))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3))

localize10.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.3b
(*.f64 x (log.f64 x))
0.6b
(cbrt.f64 (*.f64 x (log.f64 x)))
0.7b
(pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)
Compiler

Compiled 21 to 7 computations (66.7% saved)

series11.0ms (0.2%)

Counts
2 → 0
Calls

6 calls:

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

rewrite134.0ms (2%)

Algorithm
batch-egg-rewrite
Rules
524×pow1_binary64
510×add-sqr-sqrt_binary64
493×add-log-exp_binary64
493×log1p-expm1-u_binary64
493×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify12.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize21.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (*.f64 x (log.f64 x)))
0.3b
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
0.3b
(*.f64 x (log.f64 x))
Compiler

Compiled 21 to 7 computations (66.7% saved)

series14.0ms (0.2%)

Counts
2 → 0
Calls

6 calls:

TimeVariablePointExpression
5.0ms
x
@-inf
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
3.0ms
x
@0
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
2.0ms
x
@inf
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
2.0ms
x
@-inf
(sqrt.f64 (*.f64 x (log.f64 x)))
1.0ms
x
@inf
(sqrt.f64 (*.f64 x (log.f64 x)))

rewrite67.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
499×pow1_binary64
480×add-sqr-sqrt_binary64
462×add-log-exp_binary64
462×log1p-expm1-u_binary64
462×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0714
114214
2133214
Stop Event
node limit
Counts
2 → 50
Calls
Call 1
Inputs
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
(sqrt.f64 (*.f64 x (log.f64 x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (log.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 x) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (log.f64 x))) (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (log.f64 x))) (*.f64 (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 x)) (*.f64 (sqrt.f64 (log.f64 x)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) (*.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (pow.f64 (*.f64 x (log.f64 x)) 1/4)) (pow.f64 (*.f64 x (log.f64 x)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (pow.f64 (cbrt.f64 (log.f64 x)) 2)) (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (log.f64 x) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (cbrt.f64 (*.f64 x (log.f64 x)))) (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (sqrt.f64 x)) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 x x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (sqrt.f64 (*.f64 x (log.f64 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) (cbrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (log.f64 x))) (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) (pow.f64 (*.f64 x (log.f64 x)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2)) (sqrt.f64 (cbrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) 1/2) (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))))

simplify12.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

eval331.0ms (4.9%)

Compiler

Compiled 3711 to 1585 computations (57.3% saved)

prune158.0ms (2.3%)

Pruning

23 alts after pruning (17 fresh and 6 done)

PrunedKeptTotal
New32817345
Fresh000
Picked011
Done055
Total32823351
Error
0.0b
Counts
351 → 23
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
40.8b
(cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))
0.6b
(*.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))
32.6b
(*.f64 -1 (pow.f64 (sqrt.f64 (*.f64 x (neg.f64 (log.f64 x)))) 2))
32.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))
1.4b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 (*.f64 x (log.f64 x))))
1.4b
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
1.3b
(*.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))
32.8b
(*.f64 -1 (*.f64 (expm1.f64 (log1p.f64 (neg.f64 (log.f64 x)))) x))
34.5b
(exp.f64 (log.f64 (*.f64 x (log.f64 x))))
0.6b
(*.f64 -1 (*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x))
32.0b
(*.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))
30.9b
(*.f64 -1 (*.f64 (+.f64 (log.f64 (cbrt.f64 (pow.f64 x -2))) (log.f64 (/.f64 1 (cbrt.f64 x)))) x))
32.1b
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
40.4b
(cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))
1.3b
(*.f64 -1 (*.f64 (pow.f64 (cbrt.f64 (neg.f64 (log.f64 x))) 3) x))
1.2b
(*.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 x)) (cbrt.f64 (log.f64 x)))
0.3b
(*.f64 x (log.f64 x))
1.4b
(*.f64 (*.f64 (log.f64 x) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
1.7b
(pow.f64 (*.f64 (cbrt.f64 (log.f64 x)) (cbrt.f64 x)) 3)
1.4b
(pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)
32.8b
(*.f64 -1 (*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x))
0.3b
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
Compiler

Compiled 429 to 301 computations (29.8% saved)

localize19.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (log.f64 x) (sqrt.f64 x))
0.4b
(*.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))
Compiler

Compiled 19 to 5 computations (73.7% saved)

series9.0ms (0.1%)

Counts
2 → 12
Calls

6 calls:

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

rewrite73.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
527×pow1_binary64
500×add-sqr-sqrt_binary64
485×add-log-exp_binary64
485×log1p-expm1-u_binary64
485×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify153.0ms (2.2%)

Algorithm
egg-herbie
Rules
595×fma-neg_binary64
504×unsub-neg_binary64
401×fma-def_binary64
372×distribute-rgt-neg-in_binary64
297×distribute-lft-neg-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02172
14972
213572
343972
4148872
5339772
6621072
7752772
Stop Event
node limit
Counts
34 → 26
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))

localize27.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(log.f64 (neg.f64 (log.f64 x)))
0.2b
(*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x)
0.5b
(exp.f64 (log.f64 (neg.f64 (log.f64 x))))
Compiler

Compiled 33 to 9 computations (72.7% saved)

series157.0ms (2.3%)

Counts
3 → 32
Calls

9 calls:

TimeVariablePointExpression
93.0ms
x
@inf
(log.f64 (neg.f64 (log.f64 x)))
41.0ms
x
@0
(log.f64 (neg.f64 (log.f64 x)))
19.0ms
x
@-inf
(log.f64 (neg.f64 (log.f64 x)))
1.0ms
x
@0
(*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x)
1.0ms
x
@inf
(*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x)

rewrite51.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
453×pow1_binary64
432×add-sqr-sqrt_binary64
426×*-un-lft-identity_binary64
416×add-log-exp_binary64
415×log1p-expm1-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify272.0ms (4%)

Algorithm
egg-herbie
Rules
1226×associate--r-_binary64
819×fma-def_binary64
757×fma-neg_binary64
635×distribute-rgt-in_binary64
521×distribute-neg-in_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
024236
162212
2118212
3295212
4557212
51047212
62565212
74067212
85011212
95289212
105355212
115377212
125389212
135389212
146004212
156506212
166668212
176758212
186818212
196818212
Stop Event
node limit
Counts
97 → 74
Calls
Call 1
Inputs
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(log.f64 (/.f64 1 x))
(log.f64 (/.f64 1 x))
(log.f64 (/.f64 1 x))
(log.f64 (/.f64 1 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
Outputs
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))
(log.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (*.f64 1 (neg.f64 (log.f64 x))))
(log.f64 (neg.f64 (log.f64 x)))

localize14.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (*.f64 x (neg.f64 (log.f64 x))))
0.3b
(pow.f64 (sqrt.f64 (*.f64 x (neg.f64 (log.f64 x)))) 2)
0.3b
(*.f64 x (neg.f64 (log.f64 x)))
Compiler

Compiled 38 to 13 computations (65.8% saved)

series9.0ms (0.1%)

Counts
3 → 12
Calls

9 calls:

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

rewrite123.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
536×pow1_binary64
498×add-log-exp_binary64
497×log1p-expm1-u_binary64
497×expm1-log1p-u_binary64
487×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0826
116920
2175220
Stop Event
node limit
Counts
3 → 69
Calls
Call 1
Inputs
(*.f64 x (neg.f64 (log.f64 x)))
(pow.f64 (sqrt.f64 (*.f64 x (neg.f64 (log.f64 x)))) 2)
(sqrt.f64 (*.f64 x (neg.f64 (log.f64 x))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 x x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (log.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 x) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (log.f64 x))) (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (log.f64 x))) (*.f64 (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) (*.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 x)) (*.f64 (sqrt.f64 (log.f64 x)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (pow.f64 (*.f64 x (log.f64 x)) 1/4)) (pow.f64 (*.f64 x (log.f64 x)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 x) (log.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (pow.f64 (cbrt.f64 (log.f64 x)) 2)) (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x -1) (log.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (log.f64 x) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (cbrt.f64 (*.f64 x (log.f64 x)))) (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 x (log.f64 x))) (sqrt.f64 x)) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 x (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 x x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (sqrt.f64 (*.f64 x (log.f64 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (log.f64 x))) (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) (cbrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) (pow.f64 (*.f64 x (log.f64 x)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2)) (sqrt.f64 (cbrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) 1/2) (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (*.f64 x (log.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (*.f64 x (log.f64 x)))))))))

simplify159.0ms (2.3%)

Algorithm
egg-herbie
Rules
2025×fma-def_binary64
1087×fma-neg_binary64
603×distribute-rgt-in_binary64
255×unsub-neg_binary64
250×associate--r-_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01796
13896
27596
319596
438896
583996
6231896
7340596
8381396
9390096
10390696
11390896
12510196
13575096
14588796
15592396
16593796
17594196
18594196
19596596
Stop Event
node limit
Counts
81 → 63
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
Outputs
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))

localize9.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(sqrt.f64 (log.f64 x))
0.1b
(*.f64 x (sqrt.f64 (log.f64 x)))
0.2b
(*.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))
Compiler

Compiled 21 to 5 computations (76.2% saved)

series4.0ms (0.1%)

Counts
3 → 32
Calls

9 calls:

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

rewrite53.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
527×pow1_binary64
500×add-sqr-sqrt_binary64
485×add-log-exp_binary64
485×log1p-expm1-u_binary64
485×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0619
111719
2138119
Stop Event
node limit
Counts
3 → 42
Calls
Call 1
Inputs
(*.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))
(*.f64 x (sqrt.f64 (log.f64 x)))
(sqrt.f64 (log.f64 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (sqrt.f64 (log.f64 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (sqrt.f64 (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (sqrt.f64 (log.f64 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (sqrt.f64 (log.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (sqrt.f64 (log.f64 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (log.f64 x) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (sqrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (sqrt.f64 (log.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (sqrt.f64 (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (sqrt.f64 (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (sqrt.f64 (log.f64 x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (sqrt.f64 (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log.f64 x)) (cbrt.f64 (sqrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (log.f64 x))) (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (log.f64 x) 1/4) (pow.f64 (log.f64 x) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2)) (sqrt.f64 (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) 1/2) (pow.f64 (cbrt.f64 (log.f64 x)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log.f64 x) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 x) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 x) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log.f64 x) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (log.f64 x))))))))

simplify182.0ms (2.7%)

Algorithm
egg-herbie
Rules
2081×fma-def_binary64
937×fma-neg_binary64
695×distribute-rgt-in_binary64
313×unsub-neg_binary64
262×associate--r+_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
025300
149296
281296
3157264
4299264
5731264
62090264
73308264
83756264
93928264
103946264
113952264
125465264
136128264
146285264
156340264
166358264
176362264
186362264
196362264
Stop Event
node limit
Counts
74 → 55
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 (log.f64 x)) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 x (sqrt.f64 -1)) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 x (*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 x (sqrt.f64 -1)) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 x (*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 x (sqrt.f64 -1)) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 x (*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (*.f64 (sqrt.f64 -1) x) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (*.f64 x (sqrt.f64 -1)) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 x (*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) x)
(*.f64 x (sqrt.f64 (log.f64 x)))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 (/.f64 1 x))))
(*.f64 (sqrt.f64 -1) (sqrt.f64 (neg.f64 (log.f64 x))))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))
(sqrt.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))))
(sqrt.f64 (log.f64 x))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))
(sqrt.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))))
(sqrt.f64 (log.f64 x))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))
(sqrt.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))))
(sqrt.f64 (log.f64 x))
(sqrt.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(sqrt.f64 (fma.f64 -1 (log.f64 (/.f64 -1 x)) (log.f64 -1)))
(sqrt.f64 (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 x))))
(sqrt.f64 (log.f64 x))

localize13.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (*.f64 x (log.f64 x)))
0.2b
(*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x))))
0.2b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))
0.3b
(*.f64 x (log.f64 x))
Compiler

Compiled 39 to 8 computations (79.5% saved)

series2.0ms (0%)

Counts
2 → 12
Calls

6 calls:

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

rewrite67.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
684×pow1_binary64
630×add-log-exp_binary64
630×log1p-expm1-u_binary64
630×expm1-log1p-u_binary64
611×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify76.0ms (1.1%)

Algorithm
egg-herbie
Rules
595×fma-neg_binary64
504×unsub-neg_binary64
401×fma-def_binary64
372×distribute-rgt-neg-in_binary64
297×distribute-lft-neg-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02172
14972
213572
343972
4148872
5339772
6621072
7752772
Stop Event
node limit
Counts
42 → 34
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)))
(*.f64 x (log.f64 x))

eval154.0ms (2.3%)

Compiler

Compiled 3801 to 1666 computations (56.2% saved)

prune142.0ms (2.1%)

Pruning

24 alts after pruning (13 fresh and 11 done)

PrunedKeptTotal
New3223325
Fresh21012
Picked011
Done01010
Total32424348
Error
0.0b
Counts
348 → 24
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
0.6b
(*.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))
32.6b
(*.f64 -1 (pow.f64 (sqrt.f64 (*.f64 x (neg.f64 (log.f64 x)))) 2))
20.6b
(*.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 x) (log.f64 x)) 3)))
32.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))
32.1b
(*.f64 (*.f64 x (cbrt.f64 (pow.f64 (log.f64 x) 3/2))) (sqrt.f64 (log.f64 x)))
1.3b
(*.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))
32.8b
(*.f64 -1 (*.f64 (expm1.f64 (log1p.f64 (neg.f64 (log.f64 x)))) x))
34.5b
(exp.f64 (log.f64 (*.f64 x (log.f64 x))))
0.6b
(*.f64 -1 (*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x))
32.0b
(*.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))
30.9b
(*.f64 -1 (*.f64 (+.f64 (log.f64 (cbrt.f64 (pow.f64 x -2))) (log.f64 (/.f64 1 (cbrt.f64 x)))) x))
32.1b
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
40.4b
(cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))
1.3b
(*.f64 -1 (*.f64 (pow.f64 (cbrt.f64 (neg.f64 (log.f64 x))) 3) x))
1.2b
(*.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 x)) (cbrt.f64 (log.f64 x)))
0.3b
(*.f64 x (log.f64 x))
1.4b
(*.f64 (*.f64 (log.f64 x) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
1.7b
(pow.f64 (*.f64 (cbrt.f64 (log.f64 x)) (cbrt.f64 x)) 3)
40.8b
(cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))
1.4b
(pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)
32.8b
(*.f64 -1 (*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x))
1.4b
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
0.3b
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
Compiler

Compiled 396 to 284 computations (28.3% saved)

localize18.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x)
0.5b
(cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3))
0.8b
(pow.f64 (neg.f64 (log.f64 x)) 3)
Compiler

Compiled 38 to 20 computations (47.4% saved)

series6.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
x
@0
(pow.f64 (neg.f64 (log.f64 x)) 3)
1.0ms
x
@-inf
(pow.f64 (neg.f64 (log.f64 x)) 3)
1.0ms
x
@inf
(pow.f64 (neg.f64 (log.f64 x)) 3)
1.0ms
x
@0
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x)
1.0ms
x
@inf
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x)

rewrite83.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
555×pow1_binary64
523×add-log-exp_binary64
522×log1p-expm1-u_binary64
522×expm1-log1p-u_binary64
511×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify57.0ms (0.8%)

Algorithm
egg-herbie
Rules
823×fma-def_binary64
743×unsub-neg_binary64
328×associate-+r+_binary64
316×distribute-neg-in_binary64
275×associate-+l+_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
030324
187324
2235324
3749324
42352324
55985324
Stop Event
node limit
Counts
105 → 80
Calls
Call 1
Inputs
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
Outputs
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (log.f64 x) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(pow.f64 (log.f64 (/.f64 1 x)) 3)
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 -1 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 3))
(neg.f64 (pow.f64 (log.f64 x) 3))
(pow.f64 (neg.f64 (log.f64 x)) 3)
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (log.f64 x))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (cbrt.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (log.f64 x) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))
(*.f64 (cbrt.f64 -1) (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 (cbrt.f64 -1) (*.f64 x (log.f64 x)))
(*.f64 x (*.f64 (log.f64 x) (cbrt.f64 -1)))

localize14.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(log1p.f64 (neg.f64 (log.f64 x)))
0.2b
(*.f64 (expm1.f64 (log1p.f64 (neg.f64 (log.f64 x)))) x)
0.6b
(expm1.f64 (log1p.f64 (neg.f64 (log.f64 x))))
Compiler

Compiled 33 to 9 computations (72.7% saved)

series151.0ms (2.2%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
119.0ms
x
@-inf
(log1p.f64 (neg.f64 (log.f64 x)))
16.0ms
x
@0
(log1p.f64 (neg.f64 (log.f64 x)))
14.0ms
x
@inf
(log1p.f64 (neg.f64 (log.f64 x)))
0.0ms
x
@0
(expm1.f64 (log1p.f64 (neg.f64 (log.f64 x))))
0.0ms
x
@inf
(expm1.f64 (log1p.f64 (neg.f64 (log.f64 x))))

rewrite45.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
464×pow1_binary64
444×add-sqr-sqrt_binary64
438×*-un-lft-identity_binary64
427×add-log-exp_binary64
427×expm1-log1p-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify129.0ms (1.9%)

Algorithm
egg-herbie
Rules
1863×fma-neg_binary64
817×distribute-rgt-in_binary64
548×fma-def_binary64
547×distribute-lft-in_binary64
430×unsub-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
026252
166240
2127240
3335240
4638240
51507240
63681240
74615240
85101240
95210240
105246240
115258240
126668240
136836240
Stop Event
node limit
Counts
96 → 70
Calls
Call 1
Inputs
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(*.f64 -1 (log.f64 x))
(log.f64 (/.f64 1 x))
(log.f64 (/.f64 1 x))
(log.f64 (/.f64 1 x))
(log.f64 (/.f64 1 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 (log.f64 (/.f64 1 x)) x)
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(log.f64 (-.f64 1 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
Outputs
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (log.f64 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(log.f64 (/.f64 1 x))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(neg.f64 (log.f64 x))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 x (log.f64 x)))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 (log.f64 (/.f64 1 x)) x)
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x))
(neg.f64 (*.f64 x (log.f64 x)))
(*.f64 (log.f64 x) (neg.f64 x))
(*.f64 x (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (*.f64 -1 (log.f64 (/.f64 1 x)))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))
(log.f64 (-.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(log.f64 (-.f64 1 (log.f64 x)))
(log1p.f64 (neg.f64 (log.f64 x)))

localize10.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(sqrt.f64 (log.f64 x))
0.1b
(*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x))
0.3b
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
Compiler

Compiled 24 to 8 computations (66.7% saved)

series3.0ms (0%)

Counts
2 → 0
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
1.0ms
x
@0
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
0.0ms
x
@inf
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
0.0ms
x
@-inf
(*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x))
0.0ms
x
@0
(*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x))

rewrite72.0ms (1.1%)

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

Useful iterations: 1 (0.0ms)

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

simplify6.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize74.0ms (1.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (cbrt.f64 x) (log.f64 x))
0.4b
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
0.4b
(pow.f64 (cbrt.f64 x) 2)
0.6b
(cbrt.f64 x)
Compiler

Compiled 26 to 10 computations (61.5% saved)

series8.0ms (0.1%)

Counts
4 → 12
Calls

12 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
1.0ms
x
@-inf
(*.f64 (cbrt.f64 x) (log.f64 x))
1.0ms
x
@-inf
(pow.f64 (cbrt.f64 x) 2)
1.0ms
x
@inf
(*.f64 (cbrt.f64 x) (log.f64 x))
1.0ms
x
@inf
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))

rewrite59.0ms (0.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0823
116023
2175523
Stop Event
node limit
Counts
4 → 63
Calls
Call 1
Inputs
(cbrt.f64 x)
(pow.f64 (cbrt.f64 x) 2)
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
(*.f64 (cbrt.f64 x) (log.f64 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (cbrt.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2) (cbrt.f64 (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 x)) (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x 1/6) (pow.f64 x 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (*.f64 x (cbrt.f64 x)))) (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 x) 1/3) (pow.f64 (sqrt.f64 x) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 x 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 x) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 x 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 x)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (cbrt.f64 x) 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (cbrt.f64 x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2) (cbrt.f64 (*.f64 x (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2) (*.f64 (cbrt.f64 (cbrt.f64 x)) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (cbrt.f64 x))) (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (pow.f64 x 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x 1/6) (*.f64 (pow.f64 x 1/6) (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 x) (pow.f64 (cbrt.f64 (cbrt.f64 x)) 2)) (cbrt.f64 (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 x (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (cbrt.f64 x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (cbrt.f64 x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (cbrt.f64 x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (log.f64 (cbrt.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (log.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 x x) (pow.f64 (*.f64 (cbrt.f64 x) (log.f64 x)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 (cbrt.f64 x) (log.f64 x)) 3) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (cbrt.f64 x) (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cbrt.f64 x) (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (cbrt.f64 x) (log.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cbrt.f64 x) (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cbrt.f64 x) (log.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (cbrt.f64 x) (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 x (cbrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (cbrt.f64 x) (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 x (pow.f64 (log.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) x))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cbrt.f64 x) (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 x (cbrt.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cbrt.f64 x) (log.f64 x))))))))

simplify155.0ms (2.3%)

Algorithm
egg-herbie
Rules
1961×fma-def_binary64
961×fma-neg_binary64
610×distribute-rgt-in_binary64
511×distribute-lft-in_binary64
249×unsub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01672
13372
26072
313472
427572
570472
6198572
7303972
8340772
9357372
10358372
11358572
12484672
13550872
14564072
15567672
16569072
17569472
18569472
19571872
Stop Event
node limit
Counts
75 → 67
Calls
Call 1
Inputs
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
Outputs
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))

localize12.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (cbrt.f64 (log.f64 x)) x)
0.4b
(*.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))
0.5b
(cbrt.f64 (log.f64 x))
0.6b
(pow.f64 (cbrt.f64 (log.f64 x)) 2)
Compiler

Compiled 29 to 10 computations (65.5% saved)

series20.0ms (0.3%)

Counts
4 → 48
Calls

12 calls:

TimeVariablePointExpression
8.0ms
x
@0
(pow.f64 (cbrt.f64 (log.f64 x)) 2)
2.0ms
x
@inf
(pow.f64 (cbrt.f64 (log.f64 x)) 2)
2.0ms
x
@-inf
(pow.f64 (cbrt.f64 (log.f64 x)) 2)
2.0ms
x
@0
(*.f64 (cbrt.f64 (log.f64 x)) x)
2.0ms
x
@-inf
(*.f64 (cbrt.f64 (log.f64 x)) x)

rewrite67.0ms (1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0827
116027
2175327
Stop Event
node limit
Counts
4 → 63
Calls
Call 1
Inputs
(pow.f64 (cbrt.f64 (log.f64 x)) 2)
(cbrt.f64 (log.f64 x))
(*.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))
(*.f64 (cbrt.f64 (log.f64 x)) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (cbrt.f64 (log.f64 x)) 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log.f64 x)) (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (cbrt.f64 (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2) (cbrt.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2) (*.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 4)) (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 x)) (pow.f64 (log.f64 x) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (log.f64 x) 1/6) (*.f64 (pow.f64 (log.f64 x) 1/6) (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (log.f64 x)) (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2)) (cbrt.f64 (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log.f64 x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (log.f64 (cbrt.f64 (log.f64 x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (cbrt.f64 (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2) (cbrt.f64 (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (log.f64 x) 1/6) (pow.f64 (log.f64 x) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 4))) (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (log.f64 x)) 1/3) (pow.f64 (sqrt.f64 (log.f64 x)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log.f64 x) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 x) 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (cbrt.f64 (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (log.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 2) (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 3) (pow.f64 (log.f64 x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 x x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (log.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (cbrt.f64 (log.f64 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (cbrt.f64 (log.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (cbrt.f64 (log.f64 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (cbrt.f64 (log.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (log.f64 x) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (cbrt.f64 (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (cbrt.f64 (log.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (cbrt.f64 (log.f64 x)))))))))

simplify65.0ms (1%)

Algorithm
egg-herbie
Rules
616×fma-def_binary64
496×associate-*l*_binary64
492×unswap-sqr_binary64
491×unsub-neg_binary64
423×fma-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
041420
1113412
2242412
3681412
42657412
55724412
Stop Event
node limit
Counts
111 → 80
Calls
Call 1
Inputs
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(pow.f64 (log.f64 x) 1/3)
(pow.f64 (log.f64 x) 1/3)
(pow.f64 (log.f64 x) 1/3)
(pow.f64 (log.f64 x) 1/3)
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 (log.f64 x) x)
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
Outputs
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (pow.f64 (log.f64 x) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (log.f64 x) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (log.f64 x) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (log.f64 x) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 (log.f64 (/.f64 1 x)) 2)) 1/3) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 2)) (pow.f64 (cbrt.f64 -1) 2))
(*.f64 (cbrt.f64 (pow.f64 (log.f64 x) 2)) (pow.f64 (cbrt.f64 -1) 2))
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 2) 1/3)
(cbrt.f64 (pow.f64 (log.f64 x) 2))
(pow.f64 (log.f64 x) 1/3)
(cbrt.f64 (log.f64 x))
(pow.f64 (log.f64 x) 1/3)
(cbrt.f64 (log.f64 x))
(pow.f64 (log.f64 x) 1/3)
(cbrt.f64 (log.f64 x))
(pow.f64 (log.f64 x) 1/3)
(cbrt.f64 (log.f64 x))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x))))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x))))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x))))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (cbrt.f64 -1))
(*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x))))
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(cbrt.f64 (log.f64 x))
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(cbrt.f64 (log.f64 x))
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(cbrt.f64 (log.f64 x))
(pow.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) 1/3)
(cbrt.f64 (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 (log.f64 x) x)
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)) x)
(*.f64 x (log.f64 x))
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (log.f64 x)) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (cbrt.f64 (neg.f64 (log.f64 x))) (*.f64 x (cbrt.f64 -1)))
(*.f64 x (*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (cbrt.f64 (neg.f64 (log.f64 x))) (*.f64 x (cbrt.f64 -1)))
(*.f64 x (*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (cbrt.f64 (neg.f64 (log.f64 x))) (*.f64 x (cbrt.f64 -1)))
(*.f64 x (*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (pow.f64 (*.f64 1 (log.f64 (/.f64 1 x))) 1/3) (*.f64 (cbrt.f64 -1) x))
(*.f64 (cbrt.f64 (neg.f64 (log.f64 x))) (*.f64 x (cbrt.f64 -1)))
(*.f64 x (*.f64 (cbrt.f64 -1) (cbrt.f64 (neg.f64 (log.f64 x)))))
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (*.f64 1 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) 1/3) x)
(*.f64 x (cbrt.f64 (log.f64 x)))

eval131.0ms (1.9%)

Compiler

Compiled 4817 to 2351 computations (51.2% saved)

prune149.0ms (2.2%)

Pruning

24 alts after pruning (8 fresh and 16 done)

PrunedKeptTotal
New4004404
Fresh448
Picked011
Done01515
Total40424428
Error
0b
Counts
428 → 24
Alt Table
Click to see full alt table
StatusErrorProgram
29.6b
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (log.f64 x)))
40.8b
(cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))
32.1b
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
0.6b
(*.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))
32.6b
(*.f64 -1 (pow.f64 (sqrt.f64 (*.f64 x (neg.f64 (log.f64 x)))) 2))
20.6b
(*.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 x) (log.f64 x)) 3)))
32.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))
1.3b
(*.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))
32.8b
(*.f64 -1 (*.f64 (expm1.f64 (log1p.f64 (neg.f64 (log.f64 x)))) x))
34.5b
(exp.f64 (log.f64 (*.f64 x (log.f64 x))))
0.6b
(*.f64 -1 (*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x))
32.0b
(*.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))
30.9b
(*.f64 -1 (*.f64 (+.f64 (log.f64 (cbrt.f64 (pow.f64 x -2))) (log.f64 (/.f64 1 (cbrt.f64 x)))) x))
32.1b
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
40.4b
(cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))
1.3b
(*.f64 -1 (*.f64 (pow.f64 (cbrt.f64 (neg.f64 (log.f64 x))) 3) x))
0.3b
(*.f64 x (log.f64 x))
1.4b
(*.f64 (*.f64 (log.f64 x) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
0.8b
(*.f64 (cbrt.f64 (pow.f64 (log.f64 x) 2)) (*.f64 (cbrt.f64 (log.f64 x)) x))
40.7b
(cbrt.f64 (*.f64 (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 3) (pow.f64 (log.f64 x) 2)))
1.4b
(pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)
32.8b
(*.f64 -1 (*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x))
1.4b
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
0.3b
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
Compiler

Compiled 248 to 176 computations (29% saved)

regimes119.0ms (1.7%)

Accuracy

Total -63.7b remaining (-22655.6%)

Threshold costs -63.7b (-22655.6%)

Counts
30 → 1
Calls
Call 1
Inputs
(*.f64 x (log.f64 x))
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(exp.f64 (log.f64 (*.f64 x (log.f64 x))))
(pow.f64 (sqrt.f64 (*.f64 x (log.f64 x))) 2)
(pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 3)
(cbrt.f64 (pow.f64 (*.f64 x (log.f64 x)) 3))
(*.f64 (*.f64 (log.f64 x) (sqrt.f64 x)) (sqrt.f64 x))
(*.f64 -1 (*.f64 (expm1.f64 (log1p.f64 (neg.f64 (log.f64 x)))) x))
(*.f64 -1 (*.f64 (exp.f64 (log.f64 (neg.f64 (log.f64 x)))) x))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (log.f64 x)))
(*.f64 -1 (pow.f64 (sqrt.f64 (*.f64 x (neg.f64 (log.f64 x)))) 2))
(*.f64 -1 (*.f64 (cbrt.f64 (pow.f64 (neg.f64 (log.f64 x)) 3)) x))
(*.f64 -1 (*.f64 (pow.f64 (cbrt.f64 (neg.f64 (log.f64 x))) 3) x))
(pow.f64 (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 x)) 2)
(pow.f64 (*.f64 (cbrt.f64 (log.f64 x)) (cbrt.f64 x)) 3)
(cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))
(cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))
(cbrt.f64 (*.f64 (pow.f64 (log.f64 x) 3) (pow.f64 x 3)))
(*.f64 (*.f64 x (sqrt.f64 (log.f64 x))) (sqrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (log.f64 x)))
(*.f64 (*.f64 (log.f64 x) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
(*.f64 (cbrt.f64 (pow.f64 (log.f64 x) 2)) (*.f64 (cbrt.f64 (log.f64 x)) x))
(*.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 x) (log.f64 x)) 3)))
(*.f64 (*.f64 x (cbrt.f64 (pow.f64 (log.f64 x) 3/2))) (sqrt.f64 (log.f64 x)))
(*.f64 (pow.f64 (cbrt.f64 (log.f64 x)) 2) (*.f64 (cbrt.f64 (log.f64 x)) x))
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (log.f64 x)) (sqrt.f64 (*.f64 x (log.f64 x)))))
(*.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 (*.f64 x (log.f64 x))))
(*.f64 -1 (*.f64 (+.f64 (log.f64 (cbrt.f64 (pow.f64 x -2))) (log.f64 (/.f64 1 (cbrt.f64 x)))) x))
(cbrt.f64 (*.f64 (pow.f64 (*.f64 x (cbrt.f64 (log.f64 x))) 3) (pow.f64 (log.f64 x) 2)))
(*.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (log.f64 x))) 2) (cbrt.f64 x)) (cbrt.f64 (log.f64 x)))
Outputs
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
Calls

3 calls:

78.0ms
(*.f64 x (log.f64 x))
16.0ms
x
16.0ms
(*.f64 x (log.f64 x))
Results
ErrorSegmentsBranch
0.3b1x
0.3b1(*.f64 x (log.f64 x))
0.3b1(*.f64 x (log.f64 x))
Compiler

Compiled 301 to 144 computations (52.2% saved)

simplify3.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
+-commutative_binary64
sub-neg_binary64
neg-sub0_binary64
distribute-lft-neg-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01017
11617
22317
32817
43317
53517
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(*.f64 x (log.f64 x))
Outputs
(*.f64 -1 (*.f64 (log.f64 (/.f64 1 x)) x))
(neg.f64 (*.f64 x (log.f64 (/.f64 1 x))))
(*.f64 x (neg.f64 (log.f64 (/.f64 1 x))))
(*.f64 x (log.f64 x))
Compiler

Compiled 13 to 9 computations (30.8% saved)

soundness0.0ms (0%)

end20.0ms (0.3%)

Compiler

Compiled 12 to 8 computations (33.3% saved)

Profiling

Loading profile data...