Details

Time bar (total: 2.3s)

analyze0.0ms (0%)

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

Compiled 4 to 3 computations (25% saved)

sample582.0ms (24.9%)

Results
569.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
(asinh.f64 x)
Outputs
(asinh.f64 x)
Compiler

Compiled 14 to 10 computations (28.6% saved)

simplify4.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01237
11437
Stop Event
saturated
Counts
1 → 1
Calls
Call 1
Inputs
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
Outputs
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)

eval0.0ms (0%)

Compiler

Compiled 13 to 9 computations (30.8% saved)

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

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

Compiled 13 to 9 computations (30.8% saved)

localize18.0ms (0.8%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))
2.4b
(log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1))))
12.8b
(sqrt.f64 (+.f64 (*.f64 x x) 1))
Compiler

Compiled 50 to 24 computations (52% saved)

series3.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

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

rewrite6.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01175
14975
27875
38375
Stop Event
saturated
Counts
3 → 10
Calls
Call 1
Inputs
(sqrt.f64 (+.f64 (*.f64 x x) 1))
(log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1))))
(+.f64 (fabs.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 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)) (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)))))))

simplify78.0ms (3.3%)

Algorithm
egg-herbie
Rules
956×rational.json-simplify-27
938×rational.json-simplify-1
708×rational.json-simplify-41
628×rational.json-simplify-33
556×rational.json-simplify-40
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01392048
12742048
24812048
39012012
415962012
526272008
632462008
733952008
835212008
935952008
1036042008
Stop Event
saturated
Counts
46 → 119
Calls
Call 1
Inputs
1
(+.f64 1 (*.f64 1/2 (pow.f64 x 2)))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (*.f64 -1/8 (pow.f64 x 4))))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 1/16 (pow.f64 x 6)) (*.f64 -1/8 (pow.f64 x 4)))))
x
(+.f64 (*.f64 1/2 (/.f64 1 x)) x)
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) x) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(*.f64 -1 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x)) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))))
(log.f64 (+.f64 1 (fabs.f64 x)))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x))))
(+.f64 (*.f64 -1/24 (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (pow.f64 x 4))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))))
(+.f64 (*.f64 -1/24 (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (pow.f64 x 4))) (+.f64 (*.f64 1/720 (*.f64 (+.f64 (*.f64 45 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (+.f64 (*.f64 30 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 3))) (*.f64 45 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2))))) (pow.f64 x 6))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x))))))
(*.f64 -1 (log.f64 (/.f64 1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -3 (fabs.f64 x)) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))))
(*.f64 -1 (log.f64 (/.f64 -1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (*.f64 -1 (/.f64 (fabs.f64 x) x)) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 -3 (fabs.f64 x))) (pow.f64 x 3))))))
(+.f64 1 (fabs.f64 x))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (fabs.f64 x)))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (fabs.f64 x))))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 1/16 (pow.f64 x 6)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (fabs.f64 x)))))
x
(+.f64 (fabs.f64 x) x)
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(*.f64 -1 x)
(+.f64 (fabs.f64 x) (*.f64 -1 x))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (fabs.f64 x) (*.f64 -1 x))) (*.f64 1/2 (/.f64 1 x)))
(+.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 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))
(*.f64 1 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))
(*.f64 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) 1)
(*.f64 1 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)))
(*.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)) 1)
Outputs
1
(+.f64 1 (*.f64 1/2 (pow.f64 x 2)))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (*.f64 -1/8 (pow.f64 x 4))))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 1/16 (pow.f64 x 6)) (*.f64 -1/8 (pow.f64 x 4)))))
(+.f64 (+.f64 1 (*.f64 1/2 (pow.f64 x 2))) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (*.f64 1/16 (pow.f64 x 6))))
(+.f64 1 (+.f64 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (*.f64 -1/8 (pow.f64 x 4))) (*.f64 1/16 (pow.f64 x 6))))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (*.f64 1/16 (pow.f64 x 6)))))
(+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (+.f64 1 (*.f64 1/16 (pow.f64 x 6)))))
x
(+.f64 (*.f64 1/2 (/.f64 1 x)) x)
(+.f64 x (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) 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 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 (pow.f64 x 3)) -1/8)))
(+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 -1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 x (*.f64 1/16 (/.f64 1 (pow.f64 x 5))))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/16 (/.f64 1 (pow.f64 x 5))))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(+.f64 (+.f64 x (-.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 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 x 5))) (*.f64 (/.f64 1 (pow.f64 x 3)) -1/8))))
(+.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 -1 x)
(*.f64 x -1)
(neg.f64 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 x -1) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 (/.f64 1 x) -1/2) x)
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 x -1)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (*.f64 x -1) (*.f64 1/2 (/.f64 1 x))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(+.f64 (*.f64 (/.f64 1 x) -1/2) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) x))
(-.f64 (*.f64 (/.f64 1 x) -1/2) (+.f64 x (*.f64 -1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 -1 x)) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 x -1)) (+.f64 (*.f64 1/2 (/.f64 1 x)) (*.f64 1/16 (/.f64 1 (pow.f64 x 5)))))
(-.f64 (+.f64 (-.f64 (*.f64 x -1) (*.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 1/8 (/.f64 1 (pow.f64 x 3))) (-.f64 (*.f64 (/.f64 1 x) -1/2) (+.f64 x (*.f64 1/16 (/.f64 1 (pow.f64 x 5))))))
(+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (*.f64 (/.f64 1 (pow.f64 x 5)) -1/16)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x))))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))))
(+.f64 (*.f64 -1/24 (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (pow.f64 x 4))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))))
(+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4))))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (*.f64 (pow.f64 x 4) (*.f64 -1/24 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2))))))))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 (pow.f64 x 4) -1/24))))
(+.f64 (*.f64 -1/24 (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (pow.f64 x 4))) (+.f64 (*.f64 1/720 (*.f64 (+.f64 (*.f64 45 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (+.f64 (*.f64 30 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 3))) (*.f64 45 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2))))) (pow.f64 x 6))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x))))))
(+.f64 (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4))) (+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 (/.f64 1 (+.f64 1 (fabs.f64 x))) 45) (+.f64 (*.f64 30 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 3))) (*.f64 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)) 45))) (*.f64 1/720 (pow.f64 x 6)))))
(+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (*.f64 (pow.f64 x 4) (*.f64 -1/24 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))))))) (*.f64 (+.f64 (*.f64 (/.f64 1 (+.f64 1 (fabs.f64 x))) 45) (+.f64 (*.f64 30 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 3))) (*.f64 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)) 45))) (*.f64 (pow.f64 x 6) 1/720)))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (+.f64 (*.f64 (pow.f64 x 4) (*.f64 -1/24 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))))) (*.f64 (pow.f64 x 6) (*.f64 1/720 (+.f64 (*.f64 (/.f64 1 (+.f64 1 (fabs.f64 x))) 45) (+.f64 (*.f64 30 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 3))) (*.f64 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)) 45))))))))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (+.f64 (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 (pow.f64 x 4) -1/24)) (*.f64 (pow.f64 x 6) (*.f64 1/720 (+.f64 (*.f64 (/.f64 1 (+.f64 1 (fabs.f64 x))) 45) (+.f64 (*.f64 30 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 3))) (*.f64 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)) 45))))))))
(*.f64 -1 (log.f64 (/.f64 1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))
(+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -3 (fabs.f64 x)) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))))
(+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3)))))
(+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (/.f64 x (fabs.f64 x)) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))))
(*.f64 -1 (log.f64 (/.f64 -1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x)))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (*.f64 -1 (/.f64 (fabs.f64 x) x)) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 -3 (fabs.f64 x))) (pow.f64 x 3))))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x)))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3)))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))))))
(+.f64 1 (fabs.f64 x))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (fabs.f64 x)))
(+.f64 (+.f64 1 (fabs.f64 x)) (*.f64 1/2 (pow.f64 x 2)))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (fabs.f64 x))))
(+.f64 (+.f64 1 (*.f64 1/2 (pow.f64 x 2))) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (fabs.f64 x)))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (*.f64 1/16 (pow.f64 x 6)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (fabs.f64 x)))))
(+.f64 (+.f64 1 (*.f64 1/2 (pow.f64 x 2))) (+.f64 (*.f64 1/16 (pow.f64 x 6)) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (fabs.f64 x))))
(+.f64 1 (+.f64 (*.f64 1/2 (pow.f64 x 2)) (+.f64 (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (*.f64 1/16 (pow.f64 x 6))) (fabs.f64 x))))
(+.f64 (+.f64 1 (*.f64 1/2 (pow.f64 x 2))) (+.f64 (*.f64 -1/8 (pow.f64 x 4)) (+.f64 (*.f64 1/16 (pow.f64 x 6)) (fabs.f64 x))))
x
(+.f64 (fabs.f64 x) x)
(+.f64 x (fabs.f64 x))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 x (fabs.f64 x)))
(+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))
(+.f64 x (-.f64 (fabs.f64 x) (*.f64 (/.f64 1 x) -1/2)))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x)) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 x (fabs.f64 x))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(+.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 x (fabs.f64 x))) (*.f64 (/.f64 1 (pow.f64 x 3)) -1/8))
(+.f64 x (-.f64 (*.f64 1/2 (/.f64 1 x)) (-.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (fabs.f64 x))))
(+.f64 x (+.f64 (*.f64 -1/8 (/.f64 1 (pow.f64 x 3))) (-.f64 (fabs.f64 x) (*.f64 (/.f64 1 x) -1/2))))
(*.f64 -1 x)
(*.f64 x -1)
(neg.f64 x)
(+.f64 (fabs.f64 x) (*.f64 -1 x))
(+.f64 (*.f64 x -1) (fabs.f64 x))
(+.f64 (neg.f64 x) (fabs.f64 x))
(-.f64 (fabs.f64 x) x)
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 x -1) (fabs.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (fabs.f64 x) (*.f64 -1 x))) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (*.f64 x -1) (fabs.f64 x))) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (+.f64 (*.f64 x -1) (fabs.f64 x)) (*.f64 1/2 (/.f64 1 x))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (-.f64 (+.f64 (*.f64 x -1) (fabs.f64 x)) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 (/.f64 1 x) -1/2) (+.f64 x (*.f64 -1/8 (/.f64 1 (pow.f64 x 3))))))
(+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (fabs.f64 x)))
(+.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 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 1 (*.f64 x x))))))
(+.f64 0 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))
(+.f64 0 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 1 (*.f64 x x))))))
(*.f64 1 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))))
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 1 (*.f64 x x))))))
(*.f64 (log.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x))) 1)
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 1 (*.f64 x x))))))
(*.f64 1 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)))
(*.f64 1 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 1 (*.f64 x x)))))
(*.f64 (+.f64 (sqrt.f64 (+.f64 (*.f64 x x) 1)) (fabs.f64 x)) 1)
(*.f64 1 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 1 (*.f64 x x)))))

eval45.0ms (1.9%)

Compiler

Compiled 2846 to 2010 computations (29.4% saved)

prune27.0ms (1.1%)

Pruning

13 alts after pruning (12 fresh and 1 done)

PrunedKeptTotal
New10712119
Fresh000
Picked011
Done000
Total10713120
Error
29.0b
Counts
120 → 13
Alt Table
Click to see full alt table
StatusErrorProgram
62.0b
(copysign.f64 (+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))) x)
60.3b
(copysign.f64 (+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4)))) x)
59.8b
(copysign.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))) x)
58.2b
(copysign.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)) x)
57.5b
(copysign.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))) x)
58.5b
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) x)
57.8b
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) x)
46.5b
(copysign.f64 (log.f64 (-.f64 (fabs.f64 x) x)) x)
46.4b
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
48.4b
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
43.1b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
48.5b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) x)) x)
51.8b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
Compiler

Compiled 435 to 321 computations (26.2% saved)

localize22.0ms (0.9%)

Local error

Found 3 expressions with local error:

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

Compiled 55 to 36 computations (34.5% saved)

series2.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

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

rewrite10.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01281
15781
210681
315681
418681
520581
622881
723181
Stop Event
saturated
Counts
3 → 15
Calls
Call 1
Inputs
(+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))
(-.f64 (*.f64 (/.f64 1 x) -1/2) x)
(log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)) (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (/.f64 1 x) -1/2) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (-.f64 (*.f64 (/.f64 1 x) -1/2) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (neg.f64 x) (*.f64 (/.f64 1 x) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (*.f64 (/.f64 1 x) -1/2) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (*.f64 (/.f64 1 x) 1/2)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (+.f64 x (*.f64 (/.f64 1 x) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (+.f64 x (*.f64 (/.f64 1 x) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x or (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (-.f64 (*.f64 (/.f64 1 x) -1/2) x))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))))))

simplify50.0ms (2.1%)

Algorithm
egg-herbie
Rules
548×rational.json-simplify-1
462×rational.json-simplify-33
168×rational.json-simplify-2
108×rational.json-simplify-27
100×rational.json-simplify-31
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01081827
11981827
23131827
35121731
47661731
59611723
610341723
710761723
811121723
911151723
Stop Event
saturated
Counts
51 → 79
Calls
Call 1
Inputs
(/.f64 -1/2 x)
(-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(*.f64 -1 x)
(+.f64 (fabs.f64 x) (*.f64 -1 x))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(*.f64 -1 x)
(+.f64 (fabs.f64 x) (*.f64 -1 x))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(/.f64 -1/2 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(*.f64 -1 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(*.f64 -1 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 -2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x)))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 -2 (*.f64 (fabs.f64 x) x)) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 24 (fabs.f64 x))) (pow.f64 x 3))) (*.f64 -1 (log.f64 x))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 (fabs.f64 x) x)))))
(+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 3 (fabs.f64 x))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 (fabs.f64 x) x))))))
(*.f64 -1 (log.f64 (/.f64 -1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (*.f64 -1 (/.f64 (fabs.f64 x) x)) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 -3 (fabs.f64 x))) (pow.f64 x 3))))))
(*.f64 1 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)))
(*.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)) 1)
(+.f64 (*.f64 (/.f64 1 x) -1/2) (neg.f64 x))
(+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) 0)
(+.f64 0 (-.f64 (*.f64 (/.f64 1 x) -1/2) x))
(+.f64 (neg.f64 x) (*.f64 (/.f64 1 x) -1/2))
(*.f64 1 (-.f64 (*.f64 (/.f64 1 x) -1/2) x))
(*.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) 1)
(*.f64 (+.f64 x (*.f64 (/.f64 1 x) 1/2)) -1)
(*.f64 -1 (+.f64 x (*.f64 (/.f64 1 x) 1/2)))
(neg.f64 (+.f64 x (*.f64 (/.f64 1 x) 1/2)))
(+.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))
(*.f64 1 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))
(*.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) 1)
Outputs
(/.f64 -1/2 x)
(-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (fabs.f64 x) (*.f64 -1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (fabs.f64 x) (*.f64 -1 x))
(+.f64 (fabs.f64 x) (neg.f64 x))
(-.f64 (fabs.f64 x) x)
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(*.f64 -1 x)
(neg.f64 x)
(+.f64 (fabs.f64 x) (*.f64 -1 x))
(+.f64 (fabs.f64 x) (neg.f64 x))
(-.f64 (fabs.f64 x) x)
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(-.f64 (+.f64 (fabs.f64 x) (*.f64 -1 x)) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(/.f64 -1/2 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(*.f64 -1 x)
(neg.f64 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(*.f64 -1 x)
(neg.f64 x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(-.f64 (*.f64 -1 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(+.f64 (log.f64 -1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 (fabs.f64 x) (*.f64 -2 x))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 -2 (fabs.f64 x)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 (fabs.f64 x) -2))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 -2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x)))))
(+.f64 (+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 (fabs.f64 x) (*.f64 -2 x)))) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 -2 (fabs.f64 x)))) (+.f64 (log.f64 -1/2) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (log.f64 -1/2) (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 (fabs.f64 x) -2))) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 x (*.f64 (fabs.f64 x) -2)) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 -2 (*.f64 (fabs.f64 x) x)) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 24 (fabs.f64 x))) (pow.f64 x 3))) (*.f64 -1 (log.f64 x))))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (+.f64 (*.f64 (fabs.f64 x) (*.f64 -2 x)) (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 24)) (pow.f64 x 3)))) (*.f64 -1 (log.f64 x)))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 x (*.f64 -2 (fabs.f64 x))) (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 24)) (pow.f64 x 3)))))))
(+.f64 (log.f64 -1/2) (+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 x (*.f64 (fabs.f64 x) -2)) (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 24)) (pow.f64 x 3)))))))
(+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 24)) (pow.f64 x 3))) (+.f64 (log.f64 -1/2) (*.f64 x (*.f64 (fabs.f64 x) -2))))))
(+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (log.f64 -1/2) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 -16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 24)) (pow.f64 x 3))) (+.f64 (*.f64 x (*.f64 (fabs.f64 x) -2)) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 (fabs.f64 x) x))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1)) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 (fabs.f64 x) x)))))
(+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1)) (*.f64 -1 (/.f64 x (fabs.f64 x)))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 x (fabs.f64 x)))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (+.f64 (log.f64 -1) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))))
(+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 3 (fabs.f64 x))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (log.f64 -1) (*.f64 -1 (/.f64 (fabs.f64 x) x))))))
(+.f64 (+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1)) (*.f64 -1 (/.f64 x (fabs.f64 x)))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3))))
(+.f64 (+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3))) (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1)) (*.f64 -1 (/.f64 x (fabs.f64 x))))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (log.f64 -1)) (*.f64 -1 (/.f64 x (fabs.f64 x)))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3)))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 -1) (+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x)))))))
(*.f64 -1 (log.f64 (/.f64 -1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (*.f64 -1 (/.f64 (fabs.f64 x) x)) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 -3 (fabs.f64 x))) (pow.f64 x 3))))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -3)) (pow.f64 x 3)))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -3)) (pow.f64 x 3))))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 2 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -3)) (pow.f64 x 3))))))
(*.f64 1 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)))
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(*.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x)) 1)
(-.f64 (+.f64 (fabs.f64 x) (neg.f64 x)) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (-.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))) (neg.f64 x))
(+.f64 (fabs.f64 x) (-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))
(+.f64 (*.f64 (/.f64 1 x) -1/2) (neg.f64 x))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) 0)
(+.f64 (-.f64 (*.f64 -1/2 (/.f64 1 x)) x) 0)
(+.f64 0 (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(+.f64 0 (-.f64 (*.f64 (/.f64 1 x) -1/2) x))
(+.f64 (-.f64 (*.f64 -1/2 (/.f64 1 x)) x) 0)
(+.f64 0 (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))
(+.f64 (neg.f64 x) (*.f64 (/.f64 1 x) -1/2))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(*.f64 1 (-.f64 (*.f64 (/.f64 1 x) -1/2) x))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(*.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) 1)
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(*.f64 (+.f64 x (*.f64 (/.f64 1 x) 1/2)) -1)
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(*.f64 -1 (+.f64 x (*.f64 (/.f64 1 x) 1/2)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(neg.f64 (+.f64 x (*.f64 (/.f64 1 x) 1/2)))
(-.f64 (neg.f64 x) (*.f64 1/2 (/.f64 1 x)))
(-.f64 (*.f64 -1/2 (/.f64 1 x)) x)
(+.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))))
(+.f64 0 (log.f64 (-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))))
(+.f64 0 (log.f64 (+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))))
(+.f64 0 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))
(+.f64 0 (log.f64 (+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))))
(+.f64 0 (log.f64 (-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))))
(+.f64 0 (log.f64 (+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))))
(*.f64 1 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))))
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))))
(*.f64 1 (log.f64 (-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))))
(*.f64 1 (log.f64 (+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))))
(*.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) 1)
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) (-.f64 (*.f64 -1/2 (/.f64 1 x)) x))))
(*.f64 1 (log.f64 (-.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 x (fabs.f64 x)))))
(*.f64 1 (log.f64 (+.f64 (*.f64 -1/2 (/.f64 1 x)) (-.f64 (fabs.f64 x) x))))

localize13.0ms (0.6%)

Local error

Found 1 expressions with local error:

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

Compiled 24 to 18 computations (25% saved)

series41.0ms (1.7%)

Counts
1 → 8
Calls

3 calls:

TimeVariablePointExpression
18.0ms
x
@0
(log.f64 (/.f64 -1 x))
17.0ms
x
@-inf
(log.f64 (/.f64 -1 x))
5.0ms
x
@inf
(log.f64 (/.f64 -1 x))

rewrite5.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0711
13211
25611
36011
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(log.f64 (/.f64 -1 x))
Outputs
((#(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 (log.f64 (/.f64 -1 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (/.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (/.f64 -1 x)) (log.f64 (/.f64 -1 x)))))))

simplify5.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
020236
123236
Stop Event
saturated
Counts
12 → 7
Calls
Call 1
Inputs
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1) (*.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 (log.f64 (/.f64 -1 x)) 0)
(+.f64 0 (log.f64 (/.f64 -1 x)))
(*.f64 (log.f64 (/.f64 -1 x)) 1)
(*.f64 1 (log.f64 (/.f64 -1 x)))
Outputs
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))
(+.f64 (log.f64 -1) (log.f64 (/.f64 1 x)))
(+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))
(+.f64 (log.f64 -1) (log.f64 (/.f64 1 x)))
(+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))
(+.f64 (log.f64 -1) (log.f64 (/.f64 1 x)))
(+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))
(+.f64 (log.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 (log.f64 (/.f64 -1 x)) 1)
(*.f64 1 (log.f64 (/.f64 -1 x)))
(*.f64 1 (log.f64 (/.f64 -1 x)))

localize10.0ms (0.4%)

Local error

Found 1 expressions with local error:

NewErrorProgram
2.5b
(log.f64 (+.f64 (fabs.f64 x) 1))
Compiler

Compiled 21 to 12 computations (42.9% saved)

series45.0ms (1.9%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
22.0ms
x
@inf
(log.f64 (+.f64 (fabs.f64 x) 1))
13.0ms
x
@0
(log.f64 (+.f64 (fabs.f64 x) 1))
10.0ms
x
@-inf
(log.f64 (+.f64 (fabs.f64 x) 1))

rewrite5.0ms (0.2%)

Algorithm
batch-egg-rewrite
Rules
22×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
13615
25915
36415
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(log.f64 (+.f64 (fabs.f64 x) 1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 (fabs.f64 x) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 (fabs.f64 x) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 (fabs.f64 x) 1)) (log.f64 (+.f64 (fabs.f64 x) 1)))))))

simplify10.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
015264
115264
Stop Event
saturated
Counts
16 → 7
Calls
Call 1
Inputs
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(+.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) 0)
(+.f64 0 (log.f64 (+.f64 (fabs.f64 x) 1)))
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) 1)))
(*.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) 1)
Outputs
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(+.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) 0)
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 (fabs.f64 x) 1)))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 0)
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) 1)))
(*.f64 1 (log.f64 (+.f64 1 (fabs.f64 x))))
(*.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) 1)
(*.f64 1 (log.f64 (+.f64 1 (fabs.f64 x))))

localize8.0ms (0.3%)

Compiler

Compiled 20 to 5 computations (75% saved)

localize19.0ms (0.8%)

Local error

Found 2 expressions with local error:

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

Compiled 47 to 28 computations (40.4% saved)

series8.0ms (0.3%)

Counts
2 → 17
Calls

6 calls:

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

rewrite6.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01244
15444
28344
38844
Stop Event
saturated
Counts
2 → 6
Calls
Call 1
Inputs
(log.f64 (/.f64 1 x))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))
Outputs
((#(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)))))))
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))))))))

simplify7.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
030521
138521
Stop Event
saturated
Counts
23 → 17
Calls
Call 1
Inputs
(*.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 (fabs.f64 x) x)
(+.f64 (log.f64 x) (/.f64 (fabs.f64 x) x))
(+.f64 (log.f64 x) (/.f64 (fabs.f64 x) x))
(+.f64 (log.f64 x) (/.f64 (fabs.f64 x) x))
(*.f64 -1 (log.f64 (/.f64 1 x)))
(*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))) (/.f64 (fabs.f64 x) x))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))) (/.f64 (fabs.f64 x) x))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))) (/.f64 (fabs.f64 x) x))
(+.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)
(*.f64 1 (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))))
(*.f64 (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))) 1)
Outputs
(*.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 (fabs.f64 x) x)
(/.f64 x (fabs.f64 x))
(+.f64 (log.f64 x) (/.f64 (fabs.f64 x) x))
(+.f64 (log.f64 x) (/.f64 x (fabs.f64 x)))
(+.f64 (log.f64 x) (/.f64 (fabs.f64 x) x))
(+.f64 (log.f64 x) (/.f64 x (fabs.f64 x)))
(+.f64 (log.f64 x) (/.f64 (fabs.f64 x) x))
(+.f64 (log.f64 x) (/.f64 x (fabs.f64 x)))
(*.f64 -1 (log.f64 (/.f64 1 x)))
(*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1)))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))) (/.f64 (fabs.f64 x) x))
(+.f64 (/.f64 x (fabs.f64 x)) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))) (/.f64 (fabs.f64 x) x))
(+.f64 (/.f64 x (fabs.f64 x)) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))) (/.f64 (fabs.f64 x) x))
(+.f64 (/.f64 x (fabs.f64 x)) (*.f64 -1 (+.f64 (log.f64 (/.f64 -1 x)) (log.f64 -1))))
(+.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)))
(*.f64 1 (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))))
(*.f64 1 (+.f64 (/.f64 x (fabs.f64 x)) (*.f64 -1 (log.f64 (/.f64 1 x)))))
(*.f64 (+.f64 (*.f64 (log.f64 (/.f64 1 x)) -1) (/.f64 x (fabs.f64 x))) 1)
(*.f64 1 (+.f64 (/.f64 x (fabs.f64 x)) (*.f64 -1 (log.f64 (/.f64 1 x)))))

eval40.0ms (1.7%)

Compiler

Compiled 2169 to 1463 computations (32.5% saved)

prune25.0ms (1.1%)

Pruning

12 alts after pruning (9 fresh and 3 done)

PrunedKeptTotal
New1064110
Fresh257
Picked101
Done235
Total11112123
Error
29.0b
Counts
123 → 12
Alt Table
Click to see full alt table
StatusErrorProgram
57.7b
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
60.3b
(copysign.f64 (+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4)))) x)
59.8b
(copysign.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))) x)
57.5b
(copysign.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) x)
58.5b
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) x)
46.5b
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
46.4b
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
48.4b
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
43.1b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
48.5b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) x)) x)
51.8b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
57.8b
(copysign.f64 (log.f64 (neg.f64 x)) x)
Compiler

Compiled 297 to 217 computations (26.9% saved)

localize10.0ms (0.4%)

Local error

Found 1 expressions with local error:

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

Compiled 16 to 11 computations (31.3% saved)

series25.0ms (1.1%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
10.0ms
x
@-inf
(log.f64 (/.f64 -1/2 x))
10.0ms
x
@0
(log.f64 (/.f64 -1/2 x))
5.0ms
x
@inf
(log.f64 (/.f64 -1/2 x))

rewrite5.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0711
13211
25611
36011
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(log.f64 (/.f64 -1/2 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (/.f64 -1/2 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (/.f64 -1/2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (/.f64 -1/2 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (/.f64 -1/2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (/.f64 -1/2 x)) (log.f64 (/.f64 -1/2 x)))))))

simplify6.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

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

localize7.0ms (0.3%)

Compiler

Compiled 12 to 4 computations (66.7% saved)

localize75.0ms (3.2%)

Local error

Found 1 expressions with local error:

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

Compiled 25 to 19 computations (24% saved)

localize19.0ms (0.8%)

Local error

Found 2 expressions with local error:

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

Compiled 52 to 29 computations (44.2% saved)

series1.0ms (0.1%)

Counts
2 → 20
Calls

6 calls:

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

rewrite10.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01262
15662
29262
310662
411062
Stop Event
saturated
Counts
2 → 6
Calls
Call 1
Inputs
(log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))) (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))))))))

simplify28.0ms (1.2%)

Algorithm
egg-herbie
Rules
488×rational.json-simplify-1
454×rational.json-simplify-33
70×rational.json-simplify-2
12×rational.json-simplify-31
rational.json-simplify-15
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0881204
11561204
22421204
33951204
45611204
56521204
66571204
Stop Event
saturated
Counts
26 → 59
Calls
Call 1
Inputs
(+.f64 (log.f64 1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 1/2) (+.f64 (*.f64 2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 1/2) (+.f64 (*.f64 2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x)))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 -24 (fabs.f64 x))) (pow.f64 x 3))) (+.f64 (log.f64 1/2) (+.f64 (*.f64 2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x))))))
(*.f64 -1 (log.f64 (/.f64 1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -3 (fabs.f64 x)) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -1) (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -1) (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 -1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 3 (fabs.f64 x))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -1) (/.f64 (fabs.f64 x) x)))))
(/.f64 1/2 x)
(+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (fabs.f64 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) x))
(+.f64 (fabs.f64 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) x))
x
(+.f64 (fabs.f64 x) x)
x
(+.f64 (fabs.f64 x) x)
(+.f64 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) 0)
(+.f64 0 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))
(*.f64 1 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))
(*.f64 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) 1)
(*.f64 1 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))))
(*.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))) 1)
Outputs
(+.f64 (log.f64 1/2) (*.f64 -1 (log.f64 x)))
(+.f64 (log.f64 1/2) (+.f64 (*.f64 2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x))))
(+.f64 (log.f64 1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 2 (*.f64 x (fabs.f64 x)))))
(+.f64 (*.f64 -1 (log.f64 x)) (+.f64 (log.f64 1/2) (*.f64 x (*.f64 2 (fabs.f64 x)))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (log.f64 1/2) (+.f64 (*.f64 2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x)))))
(+.f64 (+.f64 (log.f64 1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 2 (*.f64 x (fabs.f64 x))))) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 2 (fabs.f64 x)))) (+.f64 (log.f64 1/2) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (log.f64 1/2) (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 2 (fabs.f64 x)))) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (log.f64 1/2) (+.f64 (*.f64 x (*.f64 2 (fabs.f64 x))) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 -24 (fabs.f64 x))) (pow.f64 x 3))) (+.f64 (log.f64 1/2) (+.f64 (*.f64 2 (*.f64 (fabs.f64 x) x)) (*.f64 -1 (log.f64 x))))))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (+.f64 (log.f64 1/2) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 2 (*.f64 x (fabs.f64 x))))) (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -24)) (pow.f64 x 3)))))
(+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 2 (fabs.f64 x)))) (+.f64 (log.f64 1/2) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))) (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -24)) (pow.f64 x 3))))
(+.f64 (+.f64 (log.f64 1/2) (+.f64 (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 x (*.f64 2 (fabs.f64 x)))) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))) (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -24)) (pow.f64 x 3))))
(+.f64 (log.f64 1/2) (+.f64 (+.f64 (*.f64 x (*.f64 2 (fabs.f64 x))) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))) (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -24)) (pow.f64 x 3)))))
(+.f64 (log.f64 1/2) (+.f64 (*.f64 x (*.f64 2 (fabs.f64 x))) (+.f64 (*.f64 1/6 (*.f64 (+.f64 (*.f64 16 (pow.f64 (fabs.f64 x) 3)) (*.f64 (fabs.f64 x) -24)) (pow.f64 x 3))) (+.f64 (*.f64 -1 (log.f64 x)) (*.f64 1/2 (*.f64 (+.f64 4 (*.f64 -4 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))))
(*.f64 -1 (log.f64 (/.f64 1 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))))
(+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (/.f64 x (fabs.f64 x)) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))
(+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 -3 (fabs.f64 x)) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x))))
(+.f64 (+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))))
(+.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 x (fabs.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3)))))
(+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -1) (/.f64 (fabs.f64 x) x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (/.f64 x (fabs.f64 x)) (log.f64 -1)))
(+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -1) (/.f64 (fabs.f64 x) x))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (/.f64 x (fabs.f64 x)) (log.f64 -1))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))))
(+.f64 (*.f64 -1/6 (/.f64 (+.f64 (*.f64 -2 (pow.f64 (fabs.f64 x) 3)) (*.f64 3 (fabs.f64 x))) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (log.f64 -1) (/.f64 (fabs.f64 x) x)))))
(+.f64 (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (/.f64 x (fabs.f64 x)) (log.f64 -1)))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (pow.f64 (fabs.f64 x) 3) -2) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3))))
(+.f64 (+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1)))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (pow.f64 (fabs.f64 x) 3) -2) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (log.f64 -1))) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (pow.f64 (fabs.f64 x) 3) -2) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3)))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (+.f64 (/.f64 x (fabs.f64 x)) (log.f64 -1)) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (pow.f64 (fabs.f64 x) 3) -2) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3))))))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2))) (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (log.f64 -1) (*.f64 -1/6 (/.f64 (+.f64 (*.f64 (pow.f64 (fabs.f64 x) 3) -2) (*.f64 (fabs.f64 x) 3)) (pow.f64 x 3)))))))
(/.f64 1/2 x)
(+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x)))
(+.f64 (fabs.f64 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) x))
(+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (+.f64 (*.f64 1/2 (/.f64 1 x)) x))
(+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))))
(+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x))))
x
(+.f64 (fabs.f64 x) x)
(+.f64 x (fabs.f64 x))
x
(+.f64 (fabs.f64 x) x)
(+.f64 x (fabs.f64 x))
(+.f64 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) 0)
(+.f64 (log.f64 (+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))))) 0)
(+.f64 (log.f64 (+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x))))) 0)
(+.f64 0 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))
(+.f64 (log.f64 (+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))))) 0)
(+.f64 (log.f64 (+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x))))) 0)
(*.f64 1 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))))
(*.f64 1 (log.f64 (+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))))))
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x))))))
(*.f64 (log.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x)))) 1)
(*.f64 1 (log.f64 (+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x))))))
(*.f64 1 (log.f64 (+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x))))))
(*.f64 1 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))))
(*.f64 1 (+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x)))))
(*.f64 1 (+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x)))))
(*.f64 (+.f64 x (+.f64 (*.f64 1/2 (/.f64 1 x)) (fabs.f64 x))) 1)
(*.f64 1 (+.f64 x (+.f64 (fabs.f64 x) (*.f64 1/2 (/.f64 1 x)))))
(*.f64 1 (+.f64 (fabs.f64 x) (+.f64 x (*.f64 1/2 (/.f64 1 x)))))

localize28.0ms (1.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
0.0b
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x))))
2.5b
(log.f64 (+.f64 1 (fabs.f64 x)))
12.8b
(/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))
Compiler

Compiled 71 to 47 computations (33.8% saved)

series15.0ms (0.7%)

Counts
4 → 3
Calls

12 calls:

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

rewrite9.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
34×bool.json-1
30×rational.json-simplify-1
28×rational.json-simplify-2
26×rational.json-1
26×rational.json-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014116
162116
293116
399116
Stop Event
saturated
Counts
4 → 12
Calls
Call 1
Inputs
(/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))
(log.f64 (+.f64 1 (fabs.f64 x)))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x))))
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (+.f64 1 (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (+.f64 1 (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (+.f64 1 (fabs.f64 x))) (log.f64 (+.f64 1 (fabs.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)) (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x or (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2))))))

simplify6.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
028453
130453
Stop Event
saturated
Counts
15 → 16
Calls
Call 1
Inputs
(log.f64 (+.f64 1 (fabs.f64 x)))
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(+.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 0)
(+.f64 0 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(*.f64 1 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1)
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 1 (fabs.f64 x))))
(*.f64 1 (log.f64 (+.f64 1 (fabs.f64 x))))
(*.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 1)
(*.f64 1 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)))
(*.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)) 1)
(+.f64 (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2) 0)
(+.f64 0 (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2))
Outputs
(log.f64 (+.f64 1 (fabs.f64 x)))
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(+.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 0)
(+.f64 0 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(+.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 0)
(*.f64 1 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1)
(*.f64 1 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 0)
(+.f64 0 (log.f64 (+.f64 1 (fabs.f64 x))))
(+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 0)
(*.f64 1 (log.f64 (+.f64 1 (fabs.f64 x))))
(*.f64 (log.f64 (+.f64 1 (fabs.f64 x))) 1)
(*.f64 1 (log.f64 (+.f64 1 (fabs.f64 x))))
(*.f64 1 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)))
(*.f64 1 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))))
(*.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2)) 1)
(*.f64 1 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))))
(+.f64 (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2) 0)
(+.f64 0 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))))
(+.f64 0 (*.f64 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))) 1/2))
(+.f64 0 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))))

eval34.0ms (1.4%)

Compiler

Compiled 1954 to 1356 computations (30.6% saved)

prune22.0ms (0.9%)

Pruning

13 alts after pruning (6 fresh and 7 done)

PrunedKeptTotal
New85388
Fresh134
Picked011
Done167
Total8713100
Error
29.0b
Counts
100 → 13
Alt Table
Click to see full alt table
StatusErrorProgram
57.7b
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
60.3b
(copysign.f64 (+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4)))) x)
59.8b
(copysign.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))) x)
57.5b
(copysign.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) x)
60.5b
(copysign.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) x)
48.5b
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
46.5b
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
46.4b
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
48.4b
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
43.1b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
51.8b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
57.8b
(copysign.f64 (log.f64 (neg.f64 x)) x)
58.5b
(copysign.f64 (log.f64 x) x)
Compiler

Compiled 267 to 196 computations (26.6% saved)

localize9.0ms (0.4%)

Local error

Found 1 expressions with local error:

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

Compiled 16 to 11 computations (31.3% saved)

series8.0ms (0.4%)

Counts
1 → 12
Calls

3 calls:

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

rewrite5.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0711
13211
25611
36011
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(log.f64 (/.f64 1/2 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (/.f64 1/2 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (/.f64 1/2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (/.f64 1/2 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (/.f64 1/2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x or (log.f64 (/.f64 1/2 x)) (log.f64 (/.f64 1/2 x)))))))

simplify6.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

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

localize5.0ms (0.2%)

Compiler

Compiled 8 to 3 computations (62.5% saved)

localize6.0ms (0.2%)

Compiler

Compiled 14 to 4 computations (71.4% saved)

localize16.0ms (0.7%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))
12.8b
(/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))
Compiler

Compiled 44 to 29 computations (34.1% saved)

localize73.0ms (3.1%)

Local error

Found 2 expressions with local error:

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

Compiled 56 to 33 computations (41.1% saved)

series1.0ms (0.1%)

Counts
1 → 12
Calls

3 calls:

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

rewrite6.0ms (0.2%)

Algorithm
batch-egg-rewrite
Rules
32×bool.json-1
30×rational.json-simplify-2
28×rational.json-simplify-1
26×rational.json-1
26×rational.json-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01239
15539
28939
39439
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x or (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))))))

simplify7.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
027562
136562
Stop Event
saturated
Counts
14 → 9
Calls
Call 1
Inputs
(*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(*.f64 -1 (/.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(*.f64 -1 (/.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(*.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) 1)
(*.f64 1 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))
Outputs
(*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 -1) (*.f64 -1 (log.f64 x)))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(*.f64 -1 (/.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (+.f64 (log.f64 -1) (log.f64 (/.f64 1 x)))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (+.f64 (log.f64 -1) (log.f64 (/.f64 1 x)))))
(+.f64 (*.f64 -1 (+.f64 (log.f64 (/.f64 1 x)) (log.f64 -1))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (+.f64 (log.f64 -1) (log.f64 (/.f64 1 x)))))
(*.f64 -1 (/.f64 x (fabs.f64 x)))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x))))
(+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 x (fabs.f64 x))))
(+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x))))
(*.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) 1)
(*.f64 1 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))
(*.f64 1 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))))

eval22.0ms (0.9%)

Compiler

Compiled 426 to 290 computations (31.9% saved)

prune9.0ms (0.4%)

Pruning

13 alts after pruning (1 fresh and 12 done)

PrunedKeptTotal
New31031
Fresh011
Picked011
Done01111
Total311344
Error
29.0b
Counts
44 → 13
Alt Table
Click to see full alt table
StatusErrorProgram
57.7b
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
60.3b
(copysign.f64 (+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4)))) x)
59.8b
(copysign.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))) x)
57.5b
(copysign.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) x)
60.5b
(copysign.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) x)
48.5b
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
46.5b
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
46.4b
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
48.4b
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
43.1b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
51.8b
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
57.8b
(copysign.f64 (log.f64 (neg.f64 x)) x)
58.5b
(copysign.f64 (log.f64 x) x)
Compiler

Compiled 174 to 127 computations (27% saved)

regimes48.0ms (2%)

Counts
20 → 3
Calls
Call 1
Inputs
(copysign.f64 (log.f64 x) x)
(copysign.f64 (log.f64 (neg.f64 x)) x)
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) x)) x)
(copysign.f64 (log.f64 (-.f64 (fabs.f64 x) x)) x)
(copysign.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) x)
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
(copysign.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)) x)
(copysign.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))) x)
(copysign.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
(copysign.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) (log.f64 (+.f64 1 (fabs.f64 x)))) x)
(copysign.f64 (+.f64 (+.f64 (log.f64 (+.f64 1 (fabs.f64 x))) (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x))))) (*.f64 (+.f64 (*.f64 3 (/.f64 1 (+.f64 1 (fabs.f64 x)))) (*.f64 3 (/.f64 1 (pow.f64 (+.f64 1 (fabs.f64 x)) 2)))) (*.f64 -1/24 (pow.f64 x 4)))) x)
(copysign.f64 (+.f64 (/.f64 x (fabs.f64 x)) (+.f64 (*.f64 1/6 (/.f64 (+.f64 (*.f64 (fabs.f64 x) -3) (*.f64 2 (pow.f64 (fabs.f64 x) 3))) (pow.f64 x 3))) (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (*.f64 1/2 (/.f64 (+.f64 1 (*.f64 -1 (pow.f64 (fabs.f64 x) 2))) (pow.f64 x 2)))))) x)
Outputs
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
Calls

2 calls:

28.0ms
x
14.0ms
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
Results
ErrorSegmentsBranch
29.3b3x
29.3b3(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x)
Compiler

Compiled 281 to 182 computations (35.2% saved)

bsearch11.0ms (0.5%)

Algorithm
binary-search
Steps
TimeLeftRight
4.0ms
934.3335640027162
17268228303.375347
6.0ms
-1.6528170366255184e+158
-1.208017555026636e+151
Results
9.0ms64×body256valid
Compiler

Compiled 105 to 76 computations (27.6% saved)

regimes23.0ms (1%)

Counts
16 → 2
Calls
Call 1
Inputs
(copysign.f64 (log.f64 x) x)
(copysign.f64 (log.f64 (neg.f64 x)) x)
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) x)) x)
(copysign.f64 (log.f64 (-.f64 (fabs.f64 x) x)) x)
(copysign.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) x)
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
(copysign.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) (/.f64 (fabs.f64 x) x)) x)
(copysign.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) (*.f64 -1 (/.f64 (fabs.f64 x) x))) x)
(copysign.f64 (+.f64 (*.f64 -1 (/.f64 x (fabs.f64 x))) (*.f64 -1 (log.f64 (/.f64 -1 x)))) x)
Outputs
(copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x)
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
Calls

1 calls:

20.0ms
x
Results
ErrorSegmentsBranch
30.8b2x
Compiler

Compiled 148 to 89 computations (39.9% saved)

bsearch59.0ms (2.5%)

Algorithm
binary-search
Steps
TimeLeftRight
58.0ms
-1.5782355865368033e-308
3.031560272966948e-304
Results
57.0ms80×body2048valid
Compiler

Compiled 167 to 122 computations (26.9% saved)

regimes80.0ms (3.4%)

Counts
12 → 2
Calls
Call 1
Inputs
(copysign.f64 (log.f64 x) x)
(copysign.f64 (log.f64 (neg.f64 x)) x)
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) x)) x)
(copysign.f64 (log.f64 (-.f64 (fabs.f64 x) x)) x)
(copysign.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) x)
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
Outputs
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x)
Calls

1 calls:

78.0ms
x
Results
ErrorSegmentsBranch
30.9b2x
Compiler

Compiled 92 to 55 computations (40.2% saved)

bsearch72.0ms (3.1%)

Algorithm
binary-search
Steps
TimeLeftRight
72.0ms
-1.5782355865368033e-308
3.031560272966948e-304
Results
70.0ms96×body2048valid
Compiler

Compiled 155 to 114 computations (26.5% saved)

regimes15.0ms (0.6%)

Counts
11 → 2
Calls
Call 1
Inputs
(copysign.f64 (log.f64 x) x)
(copysign.f64 (log.f64 (neg.f64 x)) x)
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
(copysign.f64 (/.f64 (fabs.f64 x) x) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 -1 x))) x)
(copysign.f64 (*.f64 -1 (log.f64 (/.f64 1 x))) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) 1)) x)
(copysign.f64 (log.f64 (+.f64 (fabs.f64 x) x)) x)
(copysign.f64 (log.f64 (-.f64 (fabs.f64 x) x)) x)
(copysign.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) (+.f64 1 (fabs.f64 x)))) x)
Outputs
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 (/.f64 1/2 x)) x)
Calls

1 calls:

13.0ms
x
Results
ErrorSegmentsBranch
31.0b2x
Compiler

Compiled 79 to 48 computations (39.2% saved)

bsearch69.0ms (2.9%)

Algorithm
binary-search
Steps
TimeLeftRight
69.0ms
-1.5782355865368033e-308
3.031560272966948e-304
Results
67.0ms96×body2048valid
Compiler

Compiled 113 to 84 computations (25.7% saved)

regimes49.0ms (2.1%)

Counts
3 → 2
Calls
Call 1
Inputs
(copysign.f64 (log.f64 x) x)
(copysign.f64 (log.f64 (neg.f64 x)) x)
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
Outputs
(copysign.f64 (log.f64 (/.f64 -1/2 x)) x)
(copysign.f64 (log.f64 x) x)
Calls

1 calls:

48.0ms
x
Results
ErrorSegmentsBranch
41.0b2x
Compiler

Compiled 18 to 11 computations (38.9% saved)

bsearch81.0ms (3.4%)

Algorithm
binary-search
Steps
TimeLeftRight
81.0ms
-1.5782355865368033e-308
3.031560272966948e-304
Results
79.0ms112×body2048valid
Compiler

Compiled 115 to 82 computations (28.7% saved)

regimes8.0ms (0.3%)

Accuracy

Total -11.6b remaining (-22.2%)

Threshold costs -11.6b (-22.2%)

Counts
2 → 2
Calls
Call 1
Inputs
(copysign.f64 (log.f64 x) x)
(copysign.f64 (log.f64 (neg.f64 x)) x)
Outputs
(copysign.f64 (log.f64 (neg.f64 x)) x)
(copysign.f64 (log.f64 x) x)
Calls

1 calls:

7.0ms
x
Results
ErrorSegmentsBranch
52.4b2x
Compiler

Compiled 12 to 7 computations (41.7% saved)

bsearch102.0ms (4.3%)

Algorithm
binary-search
Steps
TimeLeftRight
102.0ms
-1.5782355865368033e-308
3.031560272966948e-304
Results
100.0ms128×body2048valid
Compiler

Compiled 121 to 84 computations (30.6% saved)

simplify6.0ms (0.3%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
056367
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(if (<=.f64 x -40000000000000001477901827522329061639236719319370753807691114208602174637388878388866052438821633309786047014748930669257348013398293616684184769793097728) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (if (<=.f64 x 5000000) (copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x) (copysign.f64 (log.f64 (/.f64 1/2 x)) x)))
(if (<=.f64 x -1012011266536553/101201126653655309176247673359458653524778324882071059178450679013715169783997673445980191850718562247593538932158405955694904368692896738433506699970369254960758712138283180682233453871046608170619883839236372534281003741712346349309051677824579778170405028256179384776166707307615251266093163754323003131653853870546747392) (copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x) (copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x))
(if (<=.f64 x -1012011266536553/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x))
(if (<=.f64 x -1012011266536553/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (copysign.f64 (log.f64 (/.f64 1/2 x)) x))
(if (<=.f64 x -1012011266536553/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (copysign.f64 (log.f64 x) x))
(if (<=.f64 x -202402253307311/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (neg.f64 x)) x) (copysign.f64 (log.f64 x) x))
(copysign.f64 (log.f64 x) x)
Outputs
(if (<=.f64 x -40000000000000001477901827522329061639236719319370753807691114208602174637388878388866052438821633309786047014748930669257348013398293616684184769793097728) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (if (<=.f64 x 5000000) (copysign.f64 (log.f64 (+.f64 (fabs.f64 x) (sqrt.f64 (+.f64 (*.f64 x x) 1)))) x) (copysign.f64 (log.f64 (/.f64 1/2 x)) x)))
(if (<=.f64 x -1012011266536553/101201126653655309176247673359458653524778324882071059178450679013715169783997673445980191850718562247593538932158405955694904368692896738433506699970369254960758712138283180682233453871046608170619883839236372534281003741712346349309051677824579778170405028256179384776166707307615251266093163754323003131653853870546747392) (copysign.f64 (log.f64 (+.f64 (-.f64 (*.f64 (/.f64 1 x) -1/2) x) (fabs.f64 x))) x) (copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x))
(if (<=.f64 x -1012011266536553/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (copysign.f64 (log.f64 (+.f64 (*.f64 1/2 (/.f64 1 x)) (+.f64 (fabs.f64 x) x))) x))
(if (<=.f64 x -1012011266536553/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (copysign.f64 (log.f64 (/.f64 1/2 x)) x))
(if (<=.f64 x -1012011266536553/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (/.f64 -1/2 x)) x) (copysign.f64 (log.f64 x) x))
(if (<=.f64 x -202402253307311/202402253307310618352495346718917307049556649764142118356901358027430339567995346891960383701437124495187077864316811911389808737385793476867013399940738509921517424276566361364466907742093216341239767678472745068562007483424692698618103355649159556340810056512358769552333414615230502532186327508646006263307707741093494784) (copysign.f64 (log.f64 (neg.f64 x)) x) (copysign.f64 (log.f64 x) x))
(copysign.f64 (log.f64 x) x)
Compiler

Compiled 139 to 95 computations (31.7% saved)

soundness79.0ms (3.4%)

Algorithm
egg-herbie
Rules
956×rational.json-simplify-27
938×rational.json-simplify-1
708×rational.json-simplify-41
628×rational.json-simplify-33
556×rational.json-simplify-40
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01392048
12742048
24812048
39012012
415962012
526272008
632462008
733952008
835212008
935952008
1036042008
Stop Event
saturated
Compiler

Compiled 198 to 134 computations (32.3% saved)

end69.0ms (3%)

Compiler

Compiled 133 to 82 computations (38.3% saved)

Profiling

Loading profile data...