Details

Time bar (total: 1.7s)

analyze0.0ms (0%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%25%75%0%0%0%0
100%25%0%75%0%0%0%1
Compiler

Compiled 6 to 4 computations (33.3% saved)

sample680.0ms (40.2%)

Results
662.0ms8256×body256valid
Bogosity

preprocess2.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
045
011
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(acosh.f64 x)
Outputs
(acosh.f64 x)
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify6.0ms (0.3%)

Algorithm
egg-herbie
Rules
62×rational.json-simplify-31
36×rational.json-simplify-2
18×rational.json-simplify-27
18×rational.json-simplify-9
12×rational.json-simplify-41
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01027
11727
22127
32927
43927
54927
66327
77527
88827
910527
1011127
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
Outputs
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))))

eval0.0ms (0%)

Compiler

Compiled 19 to 12 computations (36.8% saved)

prune1.0ms (0.1%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
30.0b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
30.0b
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
Compiler

Compiled 10 to 7 computations (30% saved)

localize15.0ms (0.9%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1)))
0.2b
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
27.9b
(sqrt.f64 (-.f64 (*.f64 x x) 1))
Compiler

Compiled 34 to 17 computations (50% saved)

series3.0ms (0.2%)

Counts
3 → 36
Calls

9 calls:

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

rewrite8.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
44×rational.json-simplify-2
42×bool.json-1
36×rational.json-1
36×rational.json-2
34×rational.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01067
15067
28867
311367
413767
515367
616267
716967
Stop Event
saturated
Counts
3 → 10
Calls
Call 1
Inputs
(sqrt.f64 (-.f64 (*.f64 x x) 1))
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
(+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (sqrt.f64 (+.f64 (*.f64 x x) -1)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (sqrt.f64 (+.f64 (*.f64 x x) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (+.f64 (*.f64 x x) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (*.f64 x x) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (sqrt.f64 (+.f64 (*.f64 x x) -1)) (sqrt.f64 (+.f64 (*.f64 x x) -1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))))))
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))) (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))))))))

simplify166.0ms (9.8%)

Algorithm
egg-herbie
Rules
1484×rational.json-simplify-27
1128×rational.json-simplify-1
1126×rational.json-simplify-29
924×rational.json-simplify-33
874×rational.json-simplify-34
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01291910
12501910
24841890
39981890
420941890
540661890
644811890
746341890
847721890
948101890
1049521890
1154031890
1256581890
1357641890
1459961890
1560091890
1660091890
Stop Event
saturated
Counts
46 → 128
Calls
Call 1
Inputs
(sqrt.f64 -1)
(+.f64 (sqrt.f64 -1) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1)))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5))))))
x
(-.f64 x (*.f64 1/2 (/.f64 1 x)))
(-.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(*.f64 -1 x)
(+.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x)))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x))))
(log.f64 (sqrt.f64 -1))
(+.f64 (/.f64 x (sqrt.f64 -1)) (log.f64 (sqrt.f64 -1)))
(+.f64 (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (/.f64 x (sqrt.f64 -1)) (log.f64 (sqrt.f64 -1))))
(+.f64 (*.f64 3/40 (/.f64 (pow.f64 x 5) (pow.f64 (sqrt.f64 -1) 5))) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (/.f64 x (sqrt.f64 -1)) (log.f64 (sqrt.f64 -1)))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 5/96 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(+.f64 (log.f64 -1/2) (log.f64 (/.f64 -1 x)))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (log.f64 -1/2) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 5/96 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))))
(sqrt.f64 -1)
(+.f64 (sqrt.f64 -1) x)
(+.f64 (sqrt.f64 -1) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) x))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) x)))
(*.f64 2 x)
(-.f64 (*.f64 2 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 2 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (*.f64 2 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(/.f64 1/2 x)
(+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 5/128 (/.f64 1 (pow.f64 x 7))))))
(+.f64 (sqrt.f64 (+.f64 (*.f64 x x) -1)) 0)
(+.f64 0 (sqrt.f64 (+.f64 (*.f64 x x) -1)))
(*.f64 1 (sqrt.f64 (+.f64 (*.f64 x x) -1)))
(*.f64 (sqrt.f64 (+.f64 (*.f64 x x) -1)) 1)
(+.f64 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) 0)
(+.f64 0 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))
(*.f64 1 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))
(*.f64 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) 1)
(*.f64 1 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))))
(*.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))) 1)
Outputs
(sqrt.f64 -1)
(+.f64 (sqrt.f64 -1) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1)))))
(+.f64 (+.f64 (sqrt.f64 -1) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1)))) (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (+.f64 (sqrt.f64 -1) (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3)))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5))))))
(+.f64 (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (sqrt.f64 -1)) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5)))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (+.f64 (sqrt.f64 -1) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5)))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1)))))
(+.f64 (sqrt.f64 -1) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5))))))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5))))))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (+.f64 (sqrt.f64 -1) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (*.f64 1/16 (/.f64 (pow.f64 x 6) (pow.f64 (sqrt.f64 -1) 5))))))
x
(-.f64 x (*.f64 1/2 (/.f64 1 x)))
(+.f64 x (*.f64 (/.f64 1 x) -1/2))
(-.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (-.f64 x (*.f64 1/2 (/.f64 1 x))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (+.f64 x (*.f64 (/.f64 1 x) -1/2)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(+.f64 (+.f64 x (*.f64 (/.f64 1 x) -1/2)) (*.f64 (/.f64 1 (pow.f64 x 3)) -1/8))
(+.f64 (+.f64 x (*.f64 (/.f64 1 x) -1/2)) (*.f64 -1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(-.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5))))))
(-.f64 (-.f64 x (*.f64 1/2 (/.f64 1 x))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))))
(+.f64 (-.f64 (-.f64 x (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 (/.f64 1 x) -1/2))
(-.f64 (+.f64 x (*.f64 (/.f64 1 x) -1/2)) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 (/.f64 1 (pow.f64 x 5)) -1/16)))
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 -1 x))
(-.f64 (*.f64 1/2 (/.f64 1 x)) x)
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x)))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) x))
(-.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 x (*.f64 (/.f64 1 (pow.f64 x 3)) -1/8)))
(-.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 x (*.f64 -1/8 (/.f64 1 (pow.f64 x 3)))))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x))))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (-.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (-.f64 x (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) x)))
(log.f64 (sqrt.f64 -1))
(+.f64 (/.f64 x (sqrt.f64 -1)) (log.f64 (sqrt.f64 -1)))
(+.f64 (log.f64 (sqrt.f64 -1)) (/.f64 x (sqrt.f64 -1)))
(+.f64 (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (/.f64 x (sqrt.f64 -1)) (log.f64 (sqrt.f64 -1))))
(+.f64 (+.f64 (log.f64 (sqrt.f64 -1)) (/.f64 x (sqrt.f64 -1))) (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))))
(+.f64 (log.f64 (sqrt.f64 -1)) (+.f64 (/.f64 x (sqrt.f64 -1)) (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3)))))
(+.f64 (/.f64 x (sqrt.f64 -1)) (+.f64 (log.f64 (sqrt.f64 -1)) (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3)))))
(+.f64 (*.f64 3/40 (/.f64 (pow.f64 x 5) (pow.f64 (sqrt.f64 -1) 5))) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (/.f64 x (sqrt.f64 -1)) (log.f64 (sqrt.f64 -1)))))
(+.f64 (+.f64 (+.f64 (log.f64 (sqrt.f64 -1)) (/.f64 x (sqrt.f64 -1))) (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3)))) (*.f64 3/40 (/.f64 (pow.f64 x 5) (pow.f64 (sqrt.f64 -1) 5))))
(+.f64 (+.f64 (log.f64 (sqrt.f64 -1)) (/.f64 x (sqrt.f64 -1))) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))) (*.f64 3/40 (/.f64 (pow.f64 x 5) (pow.f64 (sqrt.f64 -1) 5)))))
(+.f64 (log.f64 (sqrt.f64 -1)) (+.f64 (+.f64 (*.f64 3/40 (/.f64 (pow.f64 x 5) (pow.f64 (sqrt.f64 -1) 5))) (/.f64 x (sqrt.f64 -1))) (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3)))))
(+.f64 (log.f64 (sqrt.f64 -1)) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (/.f64 x (sqrt.f64 -1)) (*.f64 3/40 (/.f64 (pow.f64 x 5) (pow.f64 (sqrt.f64 -1) 5))))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 3/32 (/.f64 1 (pow.f64 x 4)))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (*.f64 3/32 (/.f64 1 (pow.f64 x 4))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (*.f64 (/.f64 1 (pow.f64 x 4)) -3/32))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 5/96 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 5/96 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (*.f64 5/96 (/.f64 1 (pow.f64 x 6))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (*.f64 5/96 (/.f64 1 (pow.f64 x 6)))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -3/32) (*.f64 5/96 (/.f64 1 (pow.f64 x 6)))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -3/32) (*.f64 (/.f64 1 (pow.f64 x 6)) -5/96)))))
(+.f64 (log.f64 -1/2) (log.f64 (/.f64 -1 x)))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (log.f64 -1/2) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (log.f64 -1/2)))
(+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (log.f64 (/.f64 -1 x))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (+.f64 (log.f64 -1/2) (*.f64 3/32 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(+.f64 (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 3/32 (/.f64 1 (pow.f64 x 4)))) (+.f64 (log.f64 -1/2) (log.f64 (/.f64 -1 x))))
(+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (log.f64 -1/2) (log.f64 (/.f64 -1 x)))))
(+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (log.f64 (/.f64 -1 x)))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 5/96 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 5/96 (/.f64 1 (pow.f64 x 6))))) (log.f64 -1/2)))
(+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (log.f64 -1/2))) (*.f64 5/96 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (log.f64 -1/2) (log.f64 (/.f64 -1 x)))) (*.f64 5/96 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 5/96 (/.f64 1 (pow.f64 x 6))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (log.f64 (/.f64 -1 x))))))
(+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 3/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (log.f64 (/.f64 -1 x)) (+.f64 (*.f64 5/96 (/.f64 1 (pow.f64 x 6))) (log.f64 -1/2)))))
(sqrt.f64 -1)
(+.f64 (sqrt.f64 -1) x)
(+.f64 (sqrt.f64 -1) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) x))
(+.f64 (sqrt.f64 -1) (+.f64 x (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1)))))
(+.f64 (+.f64 (sqrt.f64 -1) x) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (+.f64 (sqrt.f64 -1) x))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) x)))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (sqrt.f64 -1) (+.f64 x (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))) (+.f64 (+.f64 (sqrt.f64 -1) x) (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1)))))
(+.f64 x (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (sqrt.f64 -1))) (+.f64 (sqrt.f64 -1) (*.f64 -1/8 (/.f64 (pow.f64 x 4) (pow.f64 (sqrt.f64 -1) 3))))))
(*.f64 2 x)
(*.f64 x 2)
(-.f64 (*.f64 2 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 x 2) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))
(-.f64 (*.f64 2 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (*.f64 x 2) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(+.f64 (*.f64 x 2) (-.f64 (*.f64 (/.f64 1 x) -1/2) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(+.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2)) (*.f64 (/.f64 1 (pow.f64 x 3)) -1/8))
(+.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2)) (*.f64 -1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (*.f64 2 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(-.f64 (*.f64 x 2) (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5))))))
(-.f64 (-.f64 (*.f64 x 2) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5))))
(+.f64 (*.f64 x 2) (-.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))))
(+.f64 (*.f64 x 2) (-.f64 (*.f64 (/.f64 1 x) -1/2) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 (/.f64 1 (pow.f64 x 5)) -1/16))))
(/.f64 1/2 x)
(+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 -1/8 (/.f64 1 (pow.f64 x 3))))
(+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 (/.f64 1 (pow.f64 x 5)) -1/16)))
(+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 5/128 (/.f64 1 (pow.f64 x 7))))))
(+.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 5/128 (/.f64 1 (pow.f64 x 7)))))
(+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 5/128 (/.f64 1 (pow.f64 x 7))))))
(+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 5/128 (/.f64 1 (pow.f64 x 7))))))
(+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (-.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 -1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 5/128 (/.f64 1 (pow.f64 x 7)))))
(+.f64 (sqrt.f64 (+.f64 (*.f64 x x) -1)) 0)
(+.f64 (sqrt.f64 (+.f64 -1 (*.f64 x x))) 0)
(+.f64 0 (sqrt.f64 (+.f64 (*.f64 x x) -1)))
(+.f64 (sqrt.f64 (+.f64 -1 (*.f64 x x))) 0)
(*.f64 1 (sqrt.f64 (+.f64 (*.f64 x x) -1)))
(*.f64 1 (sqrt.f64 (+.f64 -1 (*.f64 x x))))
(*.f64 (sqrt.f64 (+.f64 (*.f64 x x) -1)) 1)
(*.f64 1 (sqrt.f64 (+.f64 -1 (*.f64 x x))))
(+.f64 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) 0)
(+.f64 0 (log.f64 (+.f64 x (sqrt.f64 (+.f64 -1 (*.f64 x x))))))
(+.f64 0 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))
(+.f64 0 (log.f64 (+.f64 x (sqrt.f64 (+.f64 -1 (*.f64 x x))))))
(*.f64 1 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))))
(*.f64 1 (log.f64 (+.f64 x (sqrt.f64 (+.f64 -1 (*.f64 x x))))))
(*.f64 (log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1)))) 1)
(*.f64 1 (log.f64 (+.f64 x (sqrt.f64 (+.f64 -1 (*.f64 x x))))))
(*.f64 1 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))))
(*.f64 1 (+.f64 x (sqrt.f64 (+.f64 -1 (*.f64 x x)))))
(*.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) -1))) 1)
(*.f64 1 (+.f64 x (sqrt.f64 (+.f64 -1 (*.f64 x x)))))

eval49.0ms (2.9%)

Compiler

Compiled 2556 to 2150 computations (15.9% saved)

prune18.0ms (1.1%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New1244128
Fresh000
Picked011
Done000
Total1245129
Error
0.0b
Counts
129 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.5b
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
63.0b
(log.f64 (/.f64 1/2 x))
0.3b
(log.f64 (-.f64 (*.f64 x 2) (*.f64 1/2 (/.f64 1 x))))
30.0b
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
0.6b
(log.f64 (+.f64 x x))
Compiler

Compiled 41 to 32 computations (22% saved)

localize4.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(log.f64 (+.f64 x x))
Compiler

Compiled 9 to 3 computations (66.7% saved)

series42.0ms (2.5%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
18.0ms
x
@0
(log.f64 (+.f64 x x))
14.0ms
x
@-inf
(log.f64 (+.f64 x x))
10.0ms
x
@inf
(log.f64 (+.f64 x x))

rewrite9.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
22×bool.json-1
18×rational.json-simplify-2
16×rational.json-1
16×rational.json-2
16×rational.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0611
12811
25511
36411
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(log.f64 (+.f64 x x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 x x)) (log.f64 (+.f64 x x)))))))

simplify6.0ms (0.3%)

Algorithm
egg-herbie
Rules
rational.json-simplify-1
rational.json-simplify-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
027344
132344
Stop Event
saturated
Counts
16 → 7
Calls
Call 1
Inputs
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (log.f64 (+.f64 x x)) 0)
(+.f64 0 (log.f64 (+.f64 x x)))
(*.f64 (log.f64 (+.f64 x x)) 1)
(*.f64 1 (log.f64 (+.f64 x x)))
Outputs
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(+.f64 (log.f64 (+.f64 x x)) 0)
(+.f64 0 (log.f64 (+.f64 x x)))
(+.f64 (log.f64 (+.f64 x x)) 0)
(*.f64 (log.f64 (+.f64 x x)) 1)
(*.f64 1 (log.f64 (+.f64 x x)))
(*.f64 1 (log.f64 (+.f64 x x)))

localize14.0ms (0.8%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f64 1/2 (/.f64 1 x))
0.2b
(log.f64 (-.f64 (*.f64 x 2) (*.f64 1/2 (/.f64 1 x))))
Compiler

Compiled 35 to 27 computations (22.9% saved)

series2.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

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

rewrite11.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
64×rational.json-simplify-2
58×bool.json-1
44×rational.json-1
44×rational.json-simplify-31
44×rational.json-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01242
15742
210242
314442
416542
518742
620942
723242
823342
Stop Event
saturated
Counts
2 → 9
Calls
Call 1
Inputs
(log.f64 (-.f64 (*.f64 x 2) (*.f64 1/2 (/.f64 1 x))))
(*.f64 1/2 (/.f64 1 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/2 (/.f64 1 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 1/2 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 1/2 (/.f64 1 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 (/.f64 1 x) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 (/.f64 1 x) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x or (*.f64 1/2 (/.f64 1 x)) (*.f64 1/2 (/.f64 1 x)))))))

simplify117.0ms (6.9%)

Algorithm
egg-herbie
Rules
1792×rational.json-simplify-27
1224×rational.json-simplify-29
1162×rational.json-simplify-1
1000×rational.json-simplify-41
968×rational.json-simplify-33
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
079985
1151985
2316985
3734985
41882985
54491985
64930985
75081985
85195985
95233985
105513985
116317985
126522985
136632985
146792985
156802985
166802985
Stop Event
saturated
Counts
33 → 59
Calls
Call 1
Inputs
(+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -1 (log.f64 x))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (*.f64 -1 (log.f64 x)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -64/3 (pow.f64 x 6)) (*.f64 -1 (log.f64 x))))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(+.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) 0)
(+.f64 0 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))
(*.f64 1 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))
(*.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) 1)
(+.f64 (*.f64 1/2 (/.f64 1 x)) 0)
(+.f64 0 (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 1/2 (/.f64 1 x)) 0)
(-.f64 0 (*.f64 (/.f64 1 x) -1/2))
(neg.f64 (*.f64 (/.f64 1 x) -1/2))
Outputs
(+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -1 (log.f64 x))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -4 (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (log.f64 -1/2) (*.f64 -4 (pow.f64 x 2))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (*.f64 -1 (log.f64 x)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -8 (pow.f64 x 4)))))
(+.f64 (log.f64 -1/2) (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -4 (pow.f64 x 2))) (*.f64 -8 (pow.f64 x 4))))
(+.f64 (+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x))) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -8 (pow.f64 x 4))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -64/3 (pow.f64 x 6)) (*.f64 -1 (log.f64 x))))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -64/3 (pow.f64 x 6))))))
(+.f64 (log.f64 -1/2) (+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -4 (pow.f64 x 2))) (*.f64 -8 (pow.f64 x 4))) (*.f64 -64/3 (pow.f64 x 6))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (*.f64 -64/3 (pow.f64 x 6))))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)))
(-.f64 (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)) (*.f64 (log.f64 (/.f64 1 x)) 1))
(-.f64 (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)) (*.f64 1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 2) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (*.f64 1/32 (/.f64 1 (pow.f64 x 4))))))
(-.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (-.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4))))
(+.f64 (-.f64 (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)) (*.f64 (log.f64 (/.f64 1 x)) 1)) (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32))
(+.f64 (-.f64 (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)) (*.f64 1 (log.f64 (/.f64 1 x)))) (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (log.f64 2) (-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(+.f64 (log.f64 2) (-.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (-.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (log.f64 2) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32) (*.f64 (/.f64 1 (pow.f64 x 6)) -1/192)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4)))))
(+.f64 (log.f64 -2) (-.f64 (-.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -2) (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (-.f64 (+.f64 (log.f64 -2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -2) (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (+.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32) (*.f64 (/.f64 1 (pow.f64 x 6)) -1/192)) (+.f64 (log.f64 -2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4))))
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(/.f64 1/2 x)
(+.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) 0)
(+.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 -1/2 (/.f64 1 x)))) 0)
(+.f64 0 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))
(+.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 -1/2 (/.f64 1 x)))) 0)
(*.f64 1 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))))
(*.f64 1 (log.f64 (+.f64 (*.f64 x 2) (*.f64 -1/2 (/.f64 1 x)))))
(*.f64 (log.f64 (+.f64 (*.f64 x 2) (*.f64 (/.f64 1 x) -1/2))) 1)
(*.f64 1 (log.f64 (+.f64 (*.f64 x 2) (*.f64 -1/2 (/.f64 1 x)))))
(+.f64 (*.f64 1/2 (/.f64 1 x)) 0)
(*.f64 (/.f64 1 x) 1/2)
(+.f64 0 (*.f64 1/2 (/.f64 1 x)))
(*.f64 (/.f64 1 x) 1/2)
(-.f64 (*.f64 1/2 (/.f64 1 x)) 0)
(*.f64 (/.f64 1 x) 1/2)
(-.f64 0 (*.f64 (/.f64 1 x) -1/2))
(*.f64 (/.f64 1 x) 1/2)
(neg.f64 (*.f64 (/.f64 1 x) -1/2))
(*.f64 (/.f64 1 x) 1/2)

localize21.0ms (1.2%)

Compiler

Compiled 10 to 7 computations (30% saved)

localize16.0ms (0.9%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(log.f64 (/.f64 1 x))
0.2b
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
Compiler

Compiled 29 to 24 computations (17.2% saved)

series44.0ms (2.6%)

Counts
2 → 16
Calls

6 calls:

TimeVariablePointExpression
22.0ms
x
@-inf
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
17.0ms
x
@0
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
5.0ms
x
@inf
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
0.0ms
x
@0
(log.f64 (/.f64 1 x))
0.0ms
x
@-inf
(log.f64 (/.f64 1 x))

rewrite8.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
30×bool.json-1
24×rational.json-simplify-2
24×rational.json-simplify-1
22×rational.json-1
22×rational.json-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01238
15338
28038
38538
Stop Event
saturated
Counts
2 → 6
Calls
Call 1
Inputs
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(log.f64 (/.f64 1 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (/.f64 1 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (/.f64 1 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (/.f64 1 x)) (log.f64 (/.f64 1 x)))))))

simplify6.0ms (0.4%)

Algorithm
egg-herbie
Rules
10×rational.json-simplify-2
10×rational.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
028470
135470
Stop Event
saturated
Counts
22 → 11
Calls
Call 1
Inputs
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(*.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))
(*.f64 1 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))))
(*.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) 1)
(+.f64 (log.f64 (/.f64 1 x)) 0)
(+.f64 0 (log.f64 (/.f64 1 x)))
(*.f64 1 (log.f64 (/.f64 1 x)))
(*.f64 (log.f64 (/.f64 1 x)) 1)
Outputs
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (log.f64 x))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (log.f64 2) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(*.f64 -1 (log.f64 x))
(*.f64 (log.f64 x) -1)
(*.f64 -1 (log.f64 x))
(*.f64 (log.f64 x) -1)
(*.f64 -1 (log.f64 x))
(*.f64 (log.f64 x) -1)
(*.f64 -1 (log.f64 x))
(*.f64 (log.f64 x) -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))
(+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))
(*.f64 1 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))))
(*.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) 1)
(*.f64 1 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))))
(+.f64 (log.f64 (/.f64 1 x)) 0)
(+.f64 0 (log.f64 (/.f64 1 x)))
(+.f64 (log.f64 (/.f64 1 x)) 0)
(*.f64 1 (log.f64 (/.f64 1 x)))
(*.f64 (log.f64 (/.f64 1 x)) 1)
(*.f64 1 (log.f64 (/.f64 1 x)))

eval30.0ms (1.8%)

Compiler

Compiled 1390 to 1183 computations (14.9% saved)

prune10.0ms (0.6%)

Pruning

5 alts after pruning (2 fresh and 3 done)

PrunedKeptTotal
New75277
Fresh000
Picked101
Done134
Total77582
Error
0.0b
Counts
82 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.5b
(+.f64 (log.f64 2) (log.f64 x))
63.0b
(log.f64 (/.f64 1/2 x))
0.3b
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
30.0b
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
0.6b
(log.f64 (+.f64 x x))
Compiler

Compiled 35 to 26 computations (25.7% saved)

localize11.0ms (0.6%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
Compiler

Compiled 25 to 18 computations (28% saved)

series0.0ms (0%)

Counts
1 → 12
Calls

3 calls:

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

rewrite8.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
50×rational.json-simplify-2
50×bool.json-1
38×rational.json-1
38×rational.json-2
32×rational.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01023
14923
29523
313623
415223
516223
617723
719023
819123
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))))))

simplify110.0ms (6.5%)

Algorithm
egg-herbie
Rules
1810×rational.json-simplify-27
1228×rational.json-simplify-29
1200×rational.json-simplify-1
1014×rational.json-simplify-41
988×rational.json-simplify-33
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
072812
1138812
2298812
3715812
41869812
54490812
64931812
75082812
85216812
95258812
105558812
116383812
126575812
136685812
146861812
156874812
166874812
Stop Event
saturated
Counts
16 → 48
Calls
Call 1
Inputs
(+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -1 (log.f64 x))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (*.f64 -1 (log.f64 x)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -64/3 (pow.f64 x 6)) (*.f64 -1 (log.f64 x))))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(+.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 0)
(+.f64 0 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))
(*.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 1)
(*.f64 1 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))
Outputs
(+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -1 (log.f64 x))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -4 (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (log.f64 -1/2) (*.f64 -4 (pow.f64 x 2))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (*.f64 -1 (log.f64 x)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -8 (pow.f64 x 4)))))
(+.f64 (log.f64 -1/2) (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -4 (pow.f64 x 2))) (*.f64 -8 (pow.f64 x 4))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -8 (pow.f64 x 4)))))
(+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (log.f64 -1/2) (*.f64 -4 (pow.f64 x 2)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -64/3 (pow.f64 x 6)) (*.f64 -1 (log.f64 x))))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -4 (pow.f64 x 2)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -64/3 (pow.f64 x 6))))))
(+.f64 (log.f64 -1/2) (+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 -4 (pow.f64 x 2))) (*.f64 -8 (pow.f64 x 4))) (*.f64 -64/3 (pow.f64 x 6))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 -64/3 (pow.f64 x 6)) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -8 (pow.f64 x 4))))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 -8 (pow.f64 x 4)) (+.f64 (*.f64 -4 (pow.f64 x 2)) (*.f64 -64/3 (pow.f64 x 6))))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 2) (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4)))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4)))))
(-.f64 (-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (*.f64 1/32 (/.f64 1 (pow.f64 x 4))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (-.f64 (-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4))))
(-.f64 (+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x)))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32) (*.f64 (/.f64 1 (pow.f64 x 6)) -1/192)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (-.f64 (log.f64 -2) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))))
(-.f64 (-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (*.f64 1/4 (/.f64 1 (pow.f64 x 2)))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (-.f64 (log.f64 -2) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/32 (/.f64 1 (pow.f64 x 4))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 2)) -1/4) (+.f64 (log.f64 -2) (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/192 (/.f64 1 (pow.f64 x 6))) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -2)) (+.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(-.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (-.f64 (*.f64 1/4 (/.f64 1 (pow.f64 x 2))) (log.f64 -2)) (+.f64 (*.f64 1/32 (/.f64 1 (pow.f64 x 4))) (*.f64 1/192 (/.f64 1 (pow.f64 x 6))))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (-.f64 (log.f64 -2) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))) (-.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32) (*.f64 1/192 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (-.f64 (log.f64 -2) (*.f64 1/4 (/.f64 1 (pow.f64 x 2))))) (+.f64 (*.f64 (/.f64 1 (pow.f64 x 4)) -1/32) (*.f64 (/.f64 1 (pow.f64 x 6)) -1/192)))
(+.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 0)
(+.f64 0 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))
(+.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 0)
(*.f64 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))) 1)
(*.f64 1 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))
(*.f64 1 (log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x))))

localize9.0ms (0.5%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(+.f64 (log.f64 2) (log.f64 x))
Compiler

Compiled 12 to 8 computations (33.3% saved)

series6.0ms (0.4%)

Counts
1 → 8
Calls

3 calls:

TimeVariablePointExpression
6.0ms
x
@-inf
(+.f64 (log.f64 2) (log.f64 x))
0.0ms
x
@0
(+.f64 (log.f64 2) (log.f64 x))
0.0ms
x
@inf
(+.f64 (log.f64 2) (log.f64 x))

rewrite5.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
24×bool.json-1
20×rational.json-simplify-1
18×rational.json-1
18×rational.json-2
18×rational.json-simplify-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0815
13715
26315
36715
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (log.f64 2) (log.f64 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (log.f64 2) (log.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (log.f64 2) (log.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (log.f64 2) (log.f64 x)) (+.f64 (log.f64 2) (log.f64 x)))))))

simplify6.0ms (0.4%)

Algorithm
egg-herbie
Rules
16×rational.json-simplify-1
rational.json-simplify-2
rational.json-simplify-33
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
022298
130298
234298
336298
Stop Event
saturated
Counts
10 → 5
Calls
Call 1
Inputs
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(*.f64 (+.f64 (log.f64 2) (log.f64 x)) 1)
(*.f64 1 (+.f64 (log.f64 2) (log.f64 x)))
Outputs
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 2) (log.f64 -1)))
(+.f64 (log.f64 2) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(*.f64 (+.f64 (log.f64 2) (log.f64 x)) 1)
(*.f64 1 (+.f64 (log.f64 2) (log.f64 x)))
(*.f64 1 (+.f64 (log.f64 2) (log.f64 x)))

eval21.0ms (1.3%)

Compiler

Compiled 1136 to 972 computations (14.4% saved)

prune7.0ms (0.4%)

Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New53053
Fresh000
Picked011
Done044
Total53558
Error
0.0b
Counts
58 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.5b
(+.f64 (log.f64 2) (log.f64 x))
63.0b
(log.f64 (/.f64 1/2 x))
0.3b
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
30.0b
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
0.6b
(log.f64 (+.f64 x x))
Compiler

Compiled 35 to 26 computations (25.7% saved)

regimes17.0ms (1%)

Counts
7 → 1
Calls
Call 1
Inputs
(log.f64 (+.f64 x x))
(log.f64 (/.f64 1/2 x))
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
(log.f64 (-.f64 (*.f64 x 2) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (log.f64 2) (log.f64 x))
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
(+.f64 (log.f64 2) (*.f64 -1 (log.f64 (/.f64 1 x))))
Outputs
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
Calls

3 calls:

5.0ms
x
5.0ms
(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
4.0ms
(+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1)))
Results
ErrorSegmentsBranch
0.3b1x
0.3b1(log.f64 (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))))
0.3b1(+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1)))
Compiler

Compiled 71 to 52 computations (26.8% saved)

regimes4.0ms (0.2%)

Accuracy

Total -62.5b remaining (-11255.3%)

Threshold costs -62.5b (-11255.3%)

Counts
2 → 1
Calls
Call 1
Inputs
(log.f64 (+.f64 x x))
(log.f64 (/.f64 1/2 x))
Outputs
(log.f64 (+.f64 x x))
Calls

1 calls:

3.0ms
x
Results
ErrorSegmentsBranch
0.6b1x
Compiler

Compiled 11 to 7 computations (36.4% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01234
Stop Event
done
saturated
Calls
Call 1
Inputs
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
(log.f64 (+.f64 x x))
Outputs
(log.f64 (-.f64 (*.f64 x 2) (/.f64 1/2 x)))
(log.f64 (+.f64 x x))
Compiler

Compiled 14 to 10 computations (28.6% saved)

soundness178.0ms (10.6%)

Algorithm
egg-herbie
Rules
1484×rational.json-simplify-27
1128×rational.json-simplify-1
1126×rational.json-simplify-29
924×rational.json-simplify-33
874×rational.json-simplify-34
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01291910
12501910
24841890
39981890
420941890
540661890
644811890
746341890
847721890
948101890
1049521890
1154031890
1256581890
1357641890
1459961890
1560091890
1660091890
Stop Event
saturated
Compiler

Compiled 21 to 17 computations (19% saved)

end15.0ms (0.9%)

Compiler

Compiled 13 to 9 computations (30.8% saved)

Profiling

Loading profile data...