Details

Time bar (total: 5.6s)

analyze3.0ms (0.1%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%100%0%0%0%0%0
0%0%100%0%0%0%0%1
0%0%100%0%0%0%0%2
50%50%50%0%0%0%0%3
66.7%50%25%0%25%0%0%4
83.3%62.5%12.5%0%25%0%0%5
90.9%62.5%6.2%0%31.2%0%0%6
95.5%65.6%3.1%0%31.2%0%0%7
97.7%65.6%1.6%0%32.8%0%0%8
98.8%66.4%0.8%0%32.8%0%0%9
99.4%66.4%0.4%0%33.2%0%0%10
99.7%66.6%0.2%0%33.2%0%0%11
99.9%66.6%0.1%0%33.3%0%0%12
Compiler

Compiled 11 to 8 computations (27.3% saved)

sample933.0ms (16.6%)

Results
917.0ms8256×body256valid
1.0msbody256infinite
Bogosity

preprocess7.0ms (0.1%)

Algorithm
egg-herbie
Rules
14×rational.json-simplify-2
rational.json-simplify-54
rational.json-simplify-43
rational.json-simplify-55
rational.json-simplify-73
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0925
11325
21725
32325
42925
52925
011
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Outputs
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify23.0ms (0.4%)

Algorithm
egg-herbie
Rules
14×rational.json-simplify-2
rational.json-simplify-54
rational.json-simplify-43
rational.json-simplify-55
rational.json-simplify-73
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0925
11325
21725
32325
42925
52925
Stop Event
saturated
Counts
1 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Outputs
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))

eval1.0ms (0%)

Compiler

Compiled 10 to 7 computations (30% saved)

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

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

Compiled 10 to 7 computations (30% saved)

localize16.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Compiler

Compiled 24 to 15 computations (37.5% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
x
@inf
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
1.0ms
x
@0
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
1.0ms
x
@-inf
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))

rewrite119.0ms (2.1%)

Algorithm
batch-egg-rewrite
Rules
1812×rational.json-5
1810×exponential.json-3
1810×rational.json-1
1810×rational.json-2
1810×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0925
17625
224025
386825
4351725
Stop Event
node limit
Counts
1 → 6
Calls
Call 1
Inputs
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 1)))))

simplify197.0ms (3.5%)

Algorithm
egg-herbie
Rules
1640×rational.json-simplify-47
1408×rational.json-simplify-79
834×rational.json-simplify-104
820×rational.json-simplify-76
790×rational.json-simplify-111
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
024468
141468
295468
3280468
41210468
52761468
65240468
76834468
Stop Event
node limit
Counts
18 → 12
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 0)
(+.f64 0 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))))
(-.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 0)
(/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 1)
(/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x)))))
(pow.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 1)
Outputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 0)
(*.f64 (*.f64 x x) (-.f64 (-.f64 3 x) x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(+.f64 0 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))))
(*.f64 (*.f64 x x) (-.f64 (-.f64 3 x) x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 0)
(*.f64 (*.f64 x x) (-.f64 (-.f64 3 x) x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 1)
(*.f64 (*.f64 x x) (-.f64 (-.f64 3 x) x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x)))))
(*.f64 (*.f64 x x) (-.f64 (-.f64 3 x) x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(pow.f64 (*.f64 (*.f64 x x) (-.f64 3 (+.f64 x x))) 1)
(*.f64 (*.f64 x x) (-.f64 (-.f64 3 x) x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))

eval2.0ms (0%)

Compiler

Compiled 133 to 69 computations (48.1% saved)

prune5.0ms (0.1%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New8412
Fresh000
Picked011
Done000
Total8513
Error
0.0b
Counts
13 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.2b
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
0.1b
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
21.9b
(*.f64 -2 (pow.f64 x 3))
Compiler

Compiled 48 to 34 computations (29.2% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 -2 (pow.f64 x 3))
Compiler

Compiled 12 to 9 computations (25% saved)

series1.0ms (0%)

Counts
1 → 0
Calls

3 calls:

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

rewrite78.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
1190×rational.json-simplify-111
1128×rational.json-5
1126×exponential.json-3
1126×rational.json-1
1126×rational.json-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
15713
217513
361113
4232313
Stop Event
node limit
Counts
1 → 9
Calls
Call 1
Inputs
(*.f64 -2 (pow.f64 x 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 -2 (pow.f64 x 3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 -2 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 -2 (pow.f64 x 3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 -2 (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 -2 (pow.f64 x 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -2 (pow.f64 x 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -2 (pow.f64 x 3)) (/.f64 (pow.f64 x 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 -2 (pow.f64 x 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 -2 (pow.f64 x 3))))))))

simplify223.0ms (4%)

Algorithm
egg-herbie
Rules
1368×rational.json-simplify-2
874×exponential.json-simplify-27
844×rational.json-simplify-79
838×rational.json-simplify-43
780×rational.json-simplify-80
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
024117
147117
292117
3209117
4485117
51292117
62932117
74698117
86174117
97907117
Stop Event
node limit
Counts
9 → 10
Calls
Call 1
Inputs
(+.f64 (*.f64 -2 (pow.f64 x 3)) 0)
(+.f64 0 (*.f64 -2 (pow.f64 x 3)))
(-.f64 (*.f64 -2 (pow.f64 x 3)) 0)
(-.f64 0 (neg.f64 (*.f64 -2 (pow.f64 x 3))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 -2 (pow.f64 x 3)))) 1)
(/.f64 (*.f64 -2 (pow.f64 x 3)) 1)
(/.f64 (*.f64 -2 (pow.f64 x 3)) (/.f64 (pow.f64 x 3) (pow.f64 x 3)))
(pow.f64 (*.f64 -2 (pow.f64 x 3)) 1)
(neg.f64 (neg.f64 (*.f64 -2 (pow.f64 x 3))))
Outputs
(+.f64 (*.f64 -2 (pow.f64 x 3)) 0)
(*.f64 -2 (pow.f64 x 3))
(+.f64 0 (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(-.f64 (*.f64 -2 (pow.f64 x 3)) 0)
(*.f64 -2 (pow.f64 x 3))
(-.f64 0 (neg.f64 (*.f64 -2 (pow.f64 x 3))))
(*.f64 -2 (pow.f64 x 3))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 -2 (pow.f64 x 3)))) 1)
(*.f64 -2 (pow.f64 x 3))
(/.f64 (*.f64 -2 (pow.f64 x 3)) 1)
(*.f64 -2 (pow.f64 x 3))
(/.f64 (*.f64 -2 (pow.f64 x 3)) (/.f64 (pow.f64 x 3) (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(pow.f64 (*.f64 -2 (pow.f64 x 3)) 1)
(*.f64 -2 (pow.f64 x 3))
(neg.f64 (neg.f64 (*.f64 -2 (pow.f64 x 3))))
(*.f64 -2 (pow.f64 x 3))

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f64 x (-.f64 3 (+.f64 x x)))
0.1b
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
Compiler

Compiled 27 to 12 computations (55.6% saved)

series1.0ms (0%)

Counts
2 → 24
Calls

6 calls:

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

rewrite90.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
1676×rational.json-5
1674×exponential.json-3
1674×rational.json-1
1674×rational.json-2
1674×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0844
16944
223044
381644
4320344
Stop Event
node limit
Counts
2 → 12
Calls
Call 1
Inputs
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)))))

simplify184.0ms (3.3%)

Algorithm
egg-herbie
Rules
1474×rational.json-simplify-79
1128×rational.json-simplify-2
1018×rational.json-simplify-76
938×rational.json-simplify-104
836×rational.json-simplify-55
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
034840
161840
2153840
3464840
42117840
55038840
67139840
Stop Event
node limit
Counts
36 → 23
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(+.f64 0 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))))
(-.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))))
(pow.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(+.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(+.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))
(pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
Outputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(+.f64 0 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(-.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(pow.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(+.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(+.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(-.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))

localize14.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (-.f64 3 x) x)
0.0b
(*.f64 x (-.f64 (-.f64 3 x) x))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
Compiler

Compiled 27 to 16 computations (40.7% saved)

series1.0ms (0%)

Counts
3 → 36
Calls

9 calls:

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

rewrite139.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
1686×rational.json-5
1684×exponential.json-3
1684×rational.json-1
1684×rational.json-2
1684×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0857
16957
222957
381957
4322057
Stop Event
node limit
Counts
3 → 35
Calls
Call 1
Inputs
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(-.f64 (-.f64 3 x) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 3 (+.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (-.f64 3 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (-.f64 -1 (+.f64 x (-.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 x) (-.f64 1 (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 (-.f64 x 3)) (-.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 x) (-.f64 -1 (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 (+.f64 x (-.f64 x 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 3 (+.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 3 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))) (-.f64 3 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (-.f64 x 3)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))) (/.f64 1 (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (+.f64 x (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 3 (+.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 x (-.f64 x 3)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 3 (+.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (+.f64 x (-.f64 x 3)))))))

simplify164.0ms (2.9%)

Algorithm
egg-herbie
Rules
1212×rational.json-simplify-47
1046×rational.json-simplify-2
996×rational.json-simplify-49
662×rational.json-simplify-1
652×rational.json-simplify-54
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0741271
11231271
23621271
315551271
455851271
Stop Event
node limit
Counts
71 → 52
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(+.f64 0 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))))
(-.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))))
(pow.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(+.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(+.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))
(pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(+.f64 (-.f64 3 (+.f64 x x)) 0)
(+.f64 0 (-.f64 3 (+.f64 x x)))
(+.f64 1 (-.f64 -1 (+.f64 x (-.f64 x 3))))
(+.f64 (-.f64 -1 x) (-.f64 1 (-.f64 x 3)))
(+.f64 (-.f64 -1 (-.f64 x 3)) (-.f64 1 x))
(+.f64 (-.f64 1 x) (-.f64 -1 (-.f64 x 3)))
(+.f64 (-.f64 -1 (+.f64 x (-.f64 x 3))) 1)
(+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))
(*.f64 (-.f64 3 (+.f64 x x)) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(*.f64 1 (-.f64 3 (+.f64 x x)))
(*.f64 (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))) (-.f64 3 (+.f64 x x)))
(*.f64 (+.f64 x (-.f64 x 3)) -1)
(*.f64 (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))) (/.f64 1 (-.f64 3 (+.f64 x x))))
(*.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(*.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))
(*.f64 -1 (+.f64 x (-.f64 x 3)))
(*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))
(/.f64 (-.f64 3 (+.f64 x x)) 1)
(/.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (+.f64 x (-.f64 x 3)) -1)
(pow.f64 (-.f64 3 (+.f64 x x)) 1)
(neg.f64 (+.f64 x (-.f64 x 3)))
Outputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(*.f64 -2 x)
(*.f64 x -2)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(*.f64 -2 x)
(*.f64 x -2)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(+.f64 0 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(-.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 0)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (/.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(pow.f64 (*.f64 x (*.f64 x (-.f64 3 (+.f64 x x)))) 1)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(+.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(+.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(-.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(+.f64 (-.f64 3 (+.f64 x x)) 0)
(-.f64 3 (+.f64 x x))
(+.f64 0 (-.f64 3 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(+.f64 1 (-.f64 -1 (+.f64 x (-.f64 x 3))))
(-.f64 3 (+.f64 x x))
(+.f64 (-.f64 -1 x) (-.f64 1 (-.f64 x 3)))
(-.f64 3 (+.f64 x x))
(+.f64 (-.f64 -1 (-.f64 x 3)) (-.f64 1 x))
(-.f64 3 (+.f64 x x))
(+.f64 (-.f64 1 x) (-.f64 -1 (-.f64 x 3)))
(-.f64 3 (+.f64 x x))
(+.f64 (-.f64 -1 (+.f64 x (-.f64 x 3))) 1)
(-.f64 3 (+.f64 x x))
(+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))
(-.f64 3 (+.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) 1)
(-.f64 3 (+.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(-.f64 3 (+.f64 x x))
(*.f64 1 (-.f64 3 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))) (-.f64 3 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (+.f64 x (-.f64 x 3)) -1)
(-.f64 3 (+.f64 x x))
(*.f64 (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))) (/.f64 1 (-.f64 3 (+.f64 x x))))
(-.f64 3 (+.f64 x x))
(*.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(-.f64 3 (+.f64 x x))
(*.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))
(-.f64 3 (+.f64 x x))
(*.f64 -1 (+.f64 x (-.f64 x 3)))
(-.f64 3 (+.f64 x x))
(*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))
(-.f64 3 (+.f64 x x))
(/.f64 (-.f64 3 (+.f64 x x)) 1)
(-.f64 3 (+.f64 x x))
(/.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(-.f64 3 (+.f64 x x))
(/.f64 (+.f64 x (-.f64 x 3)) -1)
(-.f64 3 (+.f64 x x))
(pow.f64 (-.f64 3 (+.f64 x x)) 1)
(-.f64 3 (+.f64 x x))
(neg.f64 (+.f64 x (-.f64 x 3)))
(-.f64 3 (+.f64 x x))

localize68.0ms (1.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(*.f64 -2 (pow.f64 x 3))
0.0b
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.2b
(*.f64 3 (pow.f64 x 2))
Compiler

Compiled 32 to 25 computations (21.9% saved)

series1.0ms (0%)

Counts
2 → 3
Calls

6 calls:

TimeVariablePointExpression
0.0ms
x
@0
(*.f64 3 (pow.f64 x 2))
0.0ms
x
@inf
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.0ms
x
@inf
(*.f64 3 (pow.f64 x 2))
0.0ms
x
@-inf
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.0ms
x
@0
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))

rewrite91.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
1834×rational.json-5
1832×exponential.json-3
1832×rational.json-1
1832×rational.json-2
1832×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01144
19044
226444
394344
4370644
Stop Event
node limit
Counts
2 → 17
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (pow.f64 x 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 3 (pow.f64 x 2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 3 (pow.f64 x 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (pow.f64 x 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (pow.f64 x 2)) (/.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 3 (pow.f64 x 2))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (pow.f64 x 2)) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))) (/.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)))))

simplify219.0ms (3.9%)

Algorithm
egg-herbie
Rules
1258×rational.json-simplify-58
972×rational.json-simplify-47
660×rational.json-simplify-49
654×rational.json-simplify-2
638×rational.json-simplify-111
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
038458
167458
2232458
31061458
43827458
56379458
Stop Event
node limit
Counts
20 → 20
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) 0)
(+.f64 0 (*.f64 3 (pow.f64 x 2)))
(-.f64 (*.f64 3 (pow.f64 x 2)) 0)
(/.f64 (*.f64 3 (pow.f64 x 2)) 1)
(/.f64 (*.f64 3 (pow.f64 x 2)) (/.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 3 (pow.f64 x 2))))
(pow.f64 (*.f64 3 (pow.f64 x 2)) 1)
(-.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 0)
(*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)
(*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(*.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))))
(*.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(*.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) 1))
(*.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(*.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))) (/.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))))))
(/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)
(/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(pow.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)
Outputs
(*.f64 3 (pow.f64 x 2))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) 0)
(*.f64 3 (pow.f64 x 2))
(+.f64 0 (*.f64 3 (pow.f64 x 2)))
(*.f64 3 (pow.f64 x 2))
(-.f64 (*.f64 3 (pow.f64 x 2)) 0)
(*.f64 3 (pow.f64 x 2))
(/.f64 (*.f64 3 (pow.f64 x 2)) 1)
(*.f64 3 (pow.f64 x 2))
(/.f64 (*.f64 3 (pow.f64 x 2)) (/.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 3 (pow.f64 x 2))))
(*.f64 3 (pow.f64 x 2))
(pow.f64 (*.f64 3 (pow.f64 x 2)) 1)
(*.f64 3 (pow.f64 x 2))
(-.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 0)
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) 1))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))) (/.f64 (/.f64 1 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))) (*.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))))))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (/.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(pow.f64 (+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3))) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))

eval33.0ms (0.6%)

Compiler

Compiled 1603 to 1089 computations (32.1% saved)

prune19.0ms (0.3%)

Pruning

8 alts after pruning (3 fresh and 5 done)

PrunedKeptTotal
New1123115
Fresh000
Picked011
Done044
Total1128120
Error
0.0b
Counts
120 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.2b
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
0.1b
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
0.1b
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
22.0b
(*.f64 x (*.f64 x (*.f64 x -2)))
18.6b
(*.f64 x (*.f64 x 3))
21.9b
(*.f64 -2 (pow.f64 x 3))
Compiler

Compiled 76 to 53 computations (30.3% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 x (*.f64 x 3))
Compiler

Compiled 11 to 7 computations (36.4% saved)

series0.0ms (0%)

Counts
1 → 12
Calls

3 calls:

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

rewrite100.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
1276×rational.json-5
1274×exponential.json-3
1274×rational.json-1
1274×rational.json-2
1274×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0613
15113
216813
362013
4246713
Stop Event
node limit
Counts
1 → 29
Calls
Call 1
Inputs
(*.f64 x (*.f64 x 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 x 3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (*.f64 x 3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 x (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 x (*.f64 x 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x 3)) (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 x (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (neg.f64 (*.f64 x (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x (*.f64 3 (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 x 3) (fabs.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 x 3) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (neg.f64 x) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (neg.f64 (*.f64 x 3)) (fabs.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (fabs.f64 x) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 3 (fabs.f64 x)) (/.f64 x (fabs.f64 (/.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 x 3) (/.f64 x (fabs.f64 (/.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x (neg.f64 (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (neg.f64 x) (neg.f64 (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (neg.f64 (*.f64 x 3)) (/.f64 x (fabs.f64 (/.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (neg.f64 x) (*.f64 3 (fabs.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (/.f64 x (fabs.f64 (/.f64 x x))) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (/.f64 (neg.f64 (*.f64 x (*.f64 x 3))) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (neg.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (-.f64 0 (/.f64 (*.f64 x (*.f64 x 3)) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3)))))))))))

simplify158.0ms (2.8%)

Algorithm
egg-herbie
Rules
1488×rational.json-simplify-104
1142×rational.json-simplify-111
964×rational.json-simplify-47
728×rational.json-simplify-49
726×rational.json-simplify-79
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
076533
1199533
2418533
31090533
42330533
55923533
Stop Event
node limit
Counts
41 → 32
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 x (*.f64 x 3)) 0)
(+.f64 0 (*.f64 x (*.f64 x 3)))
(-.f64 (*.f64 x (*.f64 x 3)) 0)
(-.f64 0 (neg.f64 (*.f64 x (*.f64 x 3))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (*.f64 x 3)))) 1)
(/.f64 (*.f64 x (*.f64 x 3)) 1)
(/.f64 (*.f64 x (*.f64 x 3)) (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))
(pow.f64 (*.f64 x (*.f64 x 3)) 1)
(neg.f64 (neg.f64 (*.f64 x (*.f64 x 3))))
(fabs.f64 (*.f64 x (*.f64 x 3)))
(fabs.f64 (neg.f64 (*.f64 x (*.f64 x 3))))
(fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))
(fabs.f64 (*.f64 x (*.f64 3 (fabs.f64 x))))
(fabs.f64 (*.f64 (*.f64 x 3) (fabs.f64 x)))
(fabs.f64 (*.f64 x (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(fabs.f64 (*.f64 (*.f64 x 3) (neg.f64 x)))
(fabs.f64 (*.f64 (neg.f64 x) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(fabs.f64 (*.f64 (neg.f64 (*.f64 x 3)) (fabs.f64 x)))
(fabs.f64 (*.f64 (fabs.f64 x) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(fabs.f64 (*.f64 (*.f64 3 (fabs.f64 x)) (/.f64 x (fabs.f64 (/.f64 x x)))))
(fabs.f64 (*.f64 (*.f64 x 3) (/.f64 x (fabs.f64 (/.f64 x x)))))
(fabs.f64 (*.f64 x (neg.f64 (*.f64 x 3))))
(fabs.f64 (*.f64 (neg.f64 x) (neg.f64 (*.f64 x 3))))
(fabs.f64 (*.f64 (neg.f64 (*.f64 x 3)) (/.f64 x (fabs.f64 (/.f64 x x)))))
(fabs.f64 (*.f64 (neg.f64 x) (*.f64 3 (fabs.f64 x))))
(fabs.f64 (*.f64 (/.f64 x (fabs.f64 (/.f64 x x))) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(fabs.f64 (/.f64 (neg.f64 (*.f64 x (*.f64 x 3))) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))
(fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (neg.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))
(fabs.f64 (-.f64 0 (/.f64 (*.f64 x (*.f64 x 3)) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3)))))))
Outputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 x (*.f64 x 3)) 0)
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(+.f64 0 (*.f64 x (*.f64 x 3)))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(-.f64 (*.f64 x (*.f64 x 3)) 0)
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(-.f64 0 (neg.f64 (*.f64 x (*.f64 x 3))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (*.f64 x 3)))) 1)
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x 3)) 1)
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x 3)) (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(pow.f64 (*.f64 x (*.f64 x 3)) 1)
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(neg.f64 (neg.f64 (*.f64 x (*.f64 x 3))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 x (*.f64 x 3)))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (neg.f64 (*.f64 x (*.f64 x 3))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 x (*.f64 3 (fabs.f64 x))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (*.f64 x 3) (fabs.f64 x)))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 x (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (*.f64 x 3) (neg.f64 x)))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (neg.f64 x) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (neg.f64 (*.f64 x 3)) (fabs.f64 x)))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (fabs.f64 x) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (*.f64 3 (fabs.f64 x)) (/.f64 x (fabs.f64 (/.f64 x x)))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (*.f64 x 3) (/.f64 x (fabs.f64 (/.f64 x x)))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 x (neg.f64 (*.f64 x 3))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (neg.f64 x) (neg.f64 (*.f64 x 3))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (neg.f64 (*.f64 x 3)) (/.f64 x (fabs.f64 (/.f64 x x)))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (neg.f64 x) (*.f64 3 (fabs.f64 x))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (*.f64 (/.f64 x (fabs.f64 (/.f64 x x))) (/.f64 (*.f64 x 3) (fabs.f64 (/.f64 (*.f64 x 3) (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (/.f64 (neg.f64 (*.f64 x (*.f64 x 3))) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (neg.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))
(fabs.f64 (-.f64 0 (/.f64 (*.f64 x (*.f64 x 3)) (fabs.f64 (/.f64 (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x 3)))))))
(*.f64 x (*.f64 3 x))
(*.f64 3 (*.f64 x x))

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 x (*.f64 x (*.f64 x -2)))
Compiler

Compiled 18 to 11 computations (38.9% saved)

series0.0ms (0%)

Counts
1 → 12
Calls

3 calls:

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

rewrite238.0ms (4.2%)

Algorithm
batch-egg-rewrite
Rules
1544×rational.json-5
1542×exponential.json-3
1542×rational.json-1
1542×rational.json-2
1542×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0719
16019
219519
373319
4309519
Stop Event
node limit
Counts
1 → 9
Calls
Call 1
Inputs
(*.f64 x (*.f64 x (*.f64 x -2)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 x (*.f64 x -2))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 x (*.f64 x (*.f64 x -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 x (*.f64 x (*.f64 x -2))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 x (*.f64 x -2))) (/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) (*.f64 x (*.f64 x (*.f64 x -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 x (*.f64 x (*.f64 x -2)))))))))

simplify174.0ms (3.1%)

Algorithm
egg-herbie
Rules
956×rational.json-simplify-2
818×rational.json-simplify-49
774×rational.json-simplify-111
682×rational.json-simplify-104
570×rational.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
027327
153327
2126327
3397327
41608327
54274327
66350327
Stop Event
node limit
Counts
21 → 14
Calls
Call 1
Inputs
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 0)
(+.f64 0 (*.f64 x (*.f64 x (*.f64 x -2))))
(-.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 0)
(-.f64 0 (neg.f64 (*.f64 x (*.f64 x (*.f64 x -2)))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (*.f64 x (*.f64 x -2))))) 1)
(/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 1)
(/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) (/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) (*.f64 x (*.f64 x (*.f64 x -2)))))
(pow.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 1)
(neg.f64 (neg.f64 (*.f64 x (*.f64 x (*.f64 x -2)))))
Outputs
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 0)
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(+.f64 0 (*.f64 x (*.f64 x (*.f64 x -2))))
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(-.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 0)
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(-.f64 0 (neg.f64 (*.f64 x (*.f64 x (*.f64 x -2)))))
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (*.f64 x (*.f64 x -2))))) 1)
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 1)
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) (/.f64 (*.f64 x (*.f64 x (*.f64 x -2))) (*.f64 x (*.f64 x (*.f64 x -2)))))
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(pow.f64 (*.f64 x (*.f64 x (*.f64 x -2))) 1)
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))
(neg.f64 (neg.f64 (*.f64 x (*.f64 x (*.f64 x -2)))))
(*.f64 x (*.f64 x (*.f64 -2 x)))
(*.f64 x (*.f64 -2 (*.f64 x x)))
(*.f64 -2 (*.f64 (*.f64 x x) x))
(*.f64 (*.f64 -2 x) (*.f64 x x))

localize18.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))
0.0b
(*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x)))
0.1b
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
Compiler

Compiled 49 to 36 computations (26.5% saved)

series1.0ms (0%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
0.0ms
x
@0
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
0.0ms
x
@-inf
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
0.0ms
x
@inf
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
0.0ms
x
@-inf
(+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))
0.0ms
x
@-inf
(*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x)))

rewrite127.0ms (2.2%)

Algorithm
batch-egg-rewrite
Rules
1134×rational.json-simplify-2
948×rational.json-simplify-79
594×rational.json-simplify-47
586×rational.json-simplify-54
506×rational.json-simplify-58
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01293
110193
230087
3107575
4421757
Stop Event
node limit
Counts
3 → 57
Calls
Call 1
Inputs
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
(*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x)))
(+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 x (-.f64 (-.f64 3 x) x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 1 (-.f64 x (-.f64 2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 1 (+.f64 (-.f64 x 3) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 3 (-.f64 x (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 3 (+.f64 (+.f64 x -1) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 4 x) (+.f64 x 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 -1 (-.f64 x (-.f64 4 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 -1 (+.f64 x (-.f64 x 4)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 -1 x) (-.f64 x 4))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 (-.f64 3 x) x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (+.f64 x (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (+.f64 (+.f64 x 1) (-.f64 x 4)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (+.f64 (-.f64 x 4) (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 3 x) x)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 3 x) (+.f64 -1 (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (neg.f64 x) (-.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 4 (+.f64 x (+.f64 x 1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 4 (-.f64 x (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 (-.f64 2 x) x) -1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (-.f64 -1 x) 4) x)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 3 (-.f64 -1 x)) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 2 x) (+.f64 x -1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 (-.f64 4 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 x 5)) (-.f64 x -2))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 x (-.f64 4 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 (-.f64 -1 x) (-.f64 x 5)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (-.f64 3 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (-.f64 3 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (-.f64 (-.f64 3 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (-.f64 3 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (-.f64 3 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (+.f64 x (-.f64 x 3)))))))

simplify229.0ms (4.1%)

Algorithm
egg-herbie
Rules
1018×rational.json-simplify-1
696×rational.json-simplify-2
644×exponential.json-simplify-26
636×rational.json-simplify-51
616×rational.json-simplify-58
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01301845
12961611
26251611
321821611
449701611
575461611
Stop Event
node limit
Counts
93 → 75
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(+.f64 0 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))
(-.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(-.f64 0 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))) 1)
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(pow.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(neg.f64 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(+.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(+.f64 0 (*.f64 x (-.f64 (-.f64 3 x) x)))
(-.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(-.f64 0 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (-.f64 (-.f64 3 x) x)))) 1)
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))
(pow.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(neg.f64 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(-.f64 1 (-.f64 x (-.f64 2 x)))
(-.f64 1 (+.f64 (-.f64 x 3) (+.f64 x 1)))
(-.f64 3 (-.f64 x (neg.f64 x)))
(-.f64 3 (+.f64 (+.f64 x -1) (+.f64 x 1)))
(-.f64 (-.f64 4 x) (+.f64 x 1))
(-.f64 -1 (-.f64 x (-.f64 4 x)))
(-.f64 -1 (+.f64 x (-.f64 x 4)))
(-.f64 (-.f64 -1 x) (-.f64 x 4))
(-.f64 (-.f64 (-.f64 3 x) x) 0)
(-.f64 0 (+.f64 x (-.f64 x 3)))
(-.f64 0 (+.f64 (+.f64 x 1) (-.f64 x 4)))
(-.f64 0 (+.f64 (-.f64 x 4) (+.f64 x 1)))
(-.f64 (-.f64 3 x) x)
(-.f64 (-.f64 3 x) (+.f64 -1 (+.f64 x 1)))
(-.f64 (neg.f64 x) (-.f64 x 3))
(-.f64 4 (+.f64 x (+.f64 x 1)))
(-.f64 4 (-.f64 x (-.f64 -1 x)))
(-.f64 (-.f64 (-.f64 2 x) x) -1)
(-.f64 (+.f64 (-.f64 -1 x) 4) x)
(-.f64 (+.f64 3 (-.f64 -1 x)) (+.f64 x -1))
(-.f64 (-.f64 2 x) (+.f64 x -1))
(-.f64 (-.f64 (-.f64 4 x) x) 1)
(-.f64 (-.f64 0 (-.f64 x 5)) (-.f64 x -2))
(-.f64 (-.f64 0 (-.f64 x (-.f64 4 x))) 1)
(-.f64 (-.f64 (-.f64 -1 x) (-.f64 x 5)) 1)
(*.f64 1 (-.f64 (-.f64 3 x) x))
(*.f64 (-.f64 (-.f64 3 x) x) 1)
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (-.f64 (-.f64 3 x) x))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (-.f64 (-.f64 3 x) x)))
(*.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))
(*.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))
(*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))
(/.f64 (-.f64 (-.f64 3 x) x) 1)
(/.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(pow.f64 (-.f64 (-.f64 3 x) x) 1)
(neg.f64 (+.f64 x (-.f64 x 3)))
Outputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(*.f64 -2 x)
(*.f64 x -2)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(*.f64 -2 x)
(*.f64 x -2)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(+.f64 0 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 0 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(pow.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(neg.f64 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(+.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(+.f64 0 (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (-.f64 3 (+.f64 x x)))
(-.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(-.f64 0 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (-.f64 (-.f64 3 x) x)))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(pow.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(neg.f64 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(-.f64 1 (-.f64 x (-.f64 2 x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 1 (+.f64 (-.f64 x 3) (+.f64 x 1)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 3 (-.f64 x (neg.f64 x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 3 (+.f64 (+.f64 x -1) (+.f64 x 1)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 4 x) (+.f64 x 1))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 -1 (-.f64 x (-.f64 4 x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 -1 (+.f64 x (-.f64 x 4)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 -1 x) (-.f64 x 4))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 (-.f64 3 x) x) 0)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 0 (+.f64 x (-.f64 x 3)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 0 (+.f64 (+.f64 x 1) (-.f64 x 4)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 0 (+.f64 (-.f64 x 4) (+.f64 x 1)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) (+.f64 -1 (+.f64 x 1)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (neg.f64 x) (-.f64 x 3))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 4 (+.f64 x (+.f64 x 1)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 4 (-.f64 x (-.f64 -1 x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 (-.f64 2 x) x) -1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (+.f64 (-.f64 -1 x) 4) x)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (+.f64 3 (-.f64 -1 x)) (+.f64 x -1))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 2 x) (+.f64 x -1))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 (-.f64 4 x) x) 1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 0 (-.f64 x 5)) (-.f64 x -2))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 0 (-.f64 x (-.f64 4 x))) 1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 (-.f64 -1 x) (-.f64 x 5)) 1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 1 (-.f64 (-.f64 3 x) x))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (-.f64 (-.f64 3 x) x) 1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (-.f64 (-.f64 3 x) x))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (-.f64 (-.f64 3 x) x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(/.f64 (-.f64 (-.f64 3 x) x) 1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(/.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(pow.f64 (-.f64 (-.f64 3 x) x) 1)
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(neg.f64 (+.f64 x (-.f64 x 3)))
(+.f64 1 (-.f64 2 (+.f64 x x)))
(-.f64 3 (+.f64 x x))

eval177.0ms (3.2%)

Compiler

Compiled 1533 to 978 computations (36.2% saved)

prune31.0ms (0.5%)

Pruning

10 alts after pruning (3 fresh and 7 done)

PrunedKeptTotal
New1183121
Fresh000
Picked101
Done077
Total11910129
Error
0.0b
Counts
129 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.2b
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
0.1b
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
11.6b
(*.f64 x (*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))
22.0b
(*.f64 x (*.f64 x (*.f64 x -2)))
18.6b
(*.f64 x (*.f64 x 3))
18.7b
(*.f64 3 (*.f64 x x))
21.9b
(*.f64 -2 (pow.f64 x 3))
Compiler

Compiled 176 to 119 computations (32.4% saved)

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 3 (*.f64 x x))
Compiler

Compiled 11 to 5 computations (54.5% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

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

rewrite111.0ms (2%)

Algorithm
batch-egg-rewrite
Rules
1450×rational.json-5
1448×exponential.json-3
1448×rational.json-1
1448×rational.json-2
1448×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0613
15413
219113
368113
4287413
Stop Event
node limit
Counts
1 → 19
Calls
Call 1
Inputs
(*.f64 3 (*.f64 x x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x x) (*.f64 (*.f64 x x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 3 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x x) 2) (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 3 (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 3 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 3 (*.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (*.f64 x x)) (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 3 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 3 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (neg.f64 (*.f64 3 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 3 x) (fabs.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 3 x) (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (*.f64 3 x) (/.f64 x (fabs.f64 (/.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (/.f64 (neg.f64 (*.f64 3 (*.f64 x x))) (fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (neg.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))))))

simplify198.0ms (3.5%)

Algorithm
egg-herbie
Rules
1644×rational.json-simplify-49
1278×rational.json-simplify-43
1058×rational.json-simplify-47
1014×rational.json-simplify-54
764×rational.json-simplify-1
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
051631
1120631
2259517
3739517
42714403
57336403
Stop Event
node limit
Counts
31 → 23
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 x x) (*.f64 (*.f64 x x) 2))
(+.f64 (*.f64 3 (*.f64 x x)) 0)
(+.f64 0 (*.f64 3 (*.f64 x x)))
(+.f64 (*.f64 (*.f64 x x) 2) (*.f64 x x))
(-.f64 (*.f64 3 (*.f64 x x)) 0)
(-.f64 0 (neg.f64 (*.f64 3 (*.f64 x x))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 3 (*.f64 x x)))) 1)
(/.f64 (*.f64 3 (*.f64 x x)) 1)
(/.f64 (*.f64 3 (*.f64 x x)) (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))
(pow.f64 (*.f64 3 (*.f64 x x)) 1)
(neg.f64 (neg.f64 (*.f64 3 (*.f64 x x))))
(fabs.f64 (*.f64 3 (*.f64 x x)))
(fabs.f64 (neg.f64 (*.f64 3 (*.f64 x x))))
(fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))
(fabs.f64 (*.f64 (*.f64 3 x) (fabs.f64 x)))
(fabs.f64 (*.f64 (*.f64 3 x) (neg.f64 x)))
(fabs.f64 (*.f64 (*.f64 3 x) (/.f64 x (fabs.f64 (/.f64 x x)))))
(fabs.f64 (/.f64 (neg.f64 (*.f64 3 (*.f64 x x))) (fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))
(fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (neg.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))
Outputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 x x) (*.f64 (*.f64 x x) 2))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(+.f64 (*.f64 3 (*.f64 x x)) 0)
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(+.f64 0 (*.f64 3 (*.f64 x x)))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(+.f64 (*.f64 (*.f64 x x) 2) (*.f64 x x))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(-.f64 (*.f64 3 (*.f64 x x)) 0)
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(-.f64 0 (neg.f64 (*.f64 3 (*.f64 x x))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 3 (*.f64 x x)))) 1)
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(/.f64 (*.f64 3 (*.f64 x x)) 1)
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(/.f64 (*.f64 3 (*.f64 x x)) (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(pow.f64 (*.f64 3 (*.f64 x x)) 1)
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(neg.f64 (neg.f64 (*.f64 3 (*.f64 x x))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (*.f64 3 (*.f64 x x)))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (neg.f64 (*.f64 3 (*.f64 x x))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (*.f64 (*.f64 3 x) (fabs.f64 x)))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (*.f64 (*.f64 3 x) (neg.f64 x)))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (*.f64 (*.f64 3 x) (/.f64 x (fabs.f64 (/.f64 x x)))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (/.f64 (neg.f64 (*.f64 3 (*.f64 x x))) (fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))
(fabs.f64 (/.f64 (*.f64 3 (*.f64 x x)) (neg.f64 (/.f64 (*.f64 3 (*.f64 x x)) (*.f64 3 (*.f64 x x))))))
(+.f64 (*.f64 x x) (*.f64 2 (*.f64 x x)))
(*.f64 x (+.f64 x (*.f64 x 2)))
(*.f64 x (*.f64 3 x))

localize249.0ms (4.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
0.1b
(*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))))
0.1b
(*.f64 x (*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))
11.2b
(*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))
Compiler

Compiled 466 to 310 computations (33.5% saved)

series3.0ms (0.1%)

Counts
4 → 48
Calls

12 calls:

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

rewrite138.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
1040×rational.json-5
1038×exponential.json-3
1038×rational.json-1
1038×rational.json-2
1038×rational.json-4
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
019886
1172886
2573562
32270112
Stop Event
node limit
Counts
4 → 39
Calls
Call 1
Inputs
(*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))
(*.f64 x (*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))
(*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 3 (+.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (-.f64 3 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 (-.f64 x 3)) (-.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 x) (-.f64 1 (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 (+.f64 x (-.f64 x 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 3 (+.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 3 (-.f64 x (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 3 x) x)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 3 x) (-.f64 0 (neg.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 3 (+.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (+.f64 x (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (neg.f64 x) (-.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 3 (+.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 x (-.f64 x 3)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 3 (+.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (+.f64 x (-.f64 x 3)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) (/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (+.f64 x (-.f64 x 3)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (+.f64 x (-.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))) (/.f64 (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 1)))))

simplify197.0ms (3.5%)

Algorithm
egg-herbie
Rules
1300×rational.json-simplify-54
800×rational.json-simplify-50
778×rational.json-simplify-111
612×rational.json-simplify-41
582×rational.json-simplify-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01282289
12452289
24892289
313722289
437622289
578502289
Stop Event
node limit
Counts
87 → 84
Calls
Call 1
Inputs
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
1/27
(+.f64 (*.f64 2/27 x) 1/27)
(+.f64 (*.f64 2/27 x) (+.f64 1/27 (*.f64 8/81 (pow.f64 x 2))))
(+.f64 (*.f64 2/27 x) (+.f64 1/27 (+.f64 (*.f64 80/729 (pow.f64 x 3)) (*.f64 8/81 (pow.f64 x 2)))))
(/.f64 -1/8 (pow.f64 x 3))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(neg.f64 (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))))
(/.f64 -1/8 (pow.f64 x 3))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(neg.f64 (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))))
(+.f64 (-.f64 3 (+.f64 x x)) 0)
(+.f64 0 (-.f64 3 (+.f64 x x)))
(+.f64 (-.f64 -1 (-.f64 x 3)) (-.f64 1 x))
(+.f64 (-.f64 -1 x) (-.f64 1 (-.f64 x 3)))
(+.f64 (-.f64 -1 (+.f64 x (-.f64 x 3))) 1)
(-.f64 3 (+.f64 x x))
(-.f64 3 (-.f64 x (neg.f64 x)))
(-.f64 (-.f64 3 x) x)
(-.f64 (-.f64 3 x) (-.f64 0 (neg.f64 x)))
(-.f64 (-.f64 3 (+.f64 x x)) 0)
(-.f64 0 (+.f64 x (-.f64 x 3)))
(-.f64 (neg.f64 x) (-.f64 x 3))
(/.f64 (-.f64 3 (+.f64 x x)) 1)
(/.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (+.f64 x (-.f64 x 3)) -1)
(pow.f64 (-.f64 3 (+.f64 x x)) 1)
(neg.f64 (+.f64 x (-.f64 x 3)))
(+.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 0)
(+.f64 0 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)))
(-.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 0)
(/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 1)
(/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) (/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))))
(pow.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 1)
(+.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(+.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))
(-.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))
(pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(+.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 0)
(+.f64 0 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))
(-.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 0)
(*.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))
(*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 1)
(*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (+.f64 x (-.f64 x 3)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (+.f64 x (-.f64 x 3))))))
(*.f64 (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))
(*.f64 (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))
(*.f64 (*.f64 (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))) (/.f64 (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))))
(pow.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 1)
Outputs
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
1/27
(+.f64 (*.f64 2/27 x) 1/27)
(+.f64 1/27 (*.f64 x 2/27))
(+.f64 (*.f64 2/27 x) (+.f64 1/27 (*.f64 8/81 (pow.f64 x 2))))
(+.f64 1/27 (+.f64 (*.f64 (pow.f64 x 2) 8/81) (*.f64 x 2/27)))
(+.f64 (*.f64 (pow.f64 x 2) 8/81) (+.f64 1/27 (*.f64 x 2/27)))
(+.f64 (+.f64 1/27 (*.f64 x 2/27)) (*.f64 (pow.f64 x 2) 8/81))
(+.f64 1/27 (+.f64 (*.f64 x 2/27) (*.f64 (pow.f64 x 2) 8/81)))
(+.f64 (*.f64 2/27 x) (+.f64 1/27 (+.f64 (*.f64 80/729 (pow.f64 x 3)) (*.f64 8/81 (pow.f64 x 2)))))
(+.f64 1/27 (+.f64 (+.f64 (*.f64 (pow.f64 x 2) 8/81) (*.f64 (pow.f64 x 3) 80/729)) (*.f64 x 2/27)))
(+.f64 (*.f64 x 2/27) (+.f64 (*.f64 (pow.f64 x 2) 8/81) (+.f64 1/27 (*.f64 (pow.f64 x 3) 80/729))))
(+.f64 (+.f64 1/27 (*.f64 x 2/27)) (+.f64 (*.f64 (pow.f64 x 2) 8/81) (*.f64 (pow.f64 x 3) 80/729)))
(+.f64 (*.f64 x 2/27) (+.f64 1/27 (+.f64 (*.f64 (pow.f64 x 2) 8/81) (*.f64 (pow.f64 x 3) 80/729))))
(/.f64 -1/8 (pow.f64 x 3))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (neg.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4))))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))))
(neg.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4))))))
(-.f64 (-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))
(-.f64 (-.f64 (neg.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))
(neg.f64 (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))))
(neg.f64 (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (+.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))))
(neg.f64 (+.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))))
(-.f64 (-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 135/32 (/.f64 1 (pow.f64 x 6)))))
(-.f64 (-.f64 (-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 135/32 (/.f64 1 (pow.f64 x 6)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))
(-.f64 (-.f64 (neg.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 135/32 (/.f64 1 (pow.f64 x 6)))))
(/.f64 -1/8 (pow.f64 x 3))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))
(-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))
(-.f64 (neg.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4))))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3))))))
(neg.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))))
(neg.f64 (+.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4))))))
(-.f64 (-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))
(-.f64 (-.f64 (neg.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))
(neg.f64 (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))))))
(neg.f64 (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (+.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))))
(neg.f64 (+.f64 (+.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (+.f64 (*.f64 135/32 (/.f64 1 (pow.f64 x 6))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))))
(-.f64 (-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 135/32 (/.f64 1 (pow.f64 x 6)))))
(-.f64 (-.f64 (-.f64 (neg.f64 (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 135/32 (/.f64 1 (pow.f64 x 6)))) (*.f64 27/16 (/.f64 1 (pow.f64 x 5))))
(-.f64 (-.f64 (neg.f64 (*.f64 1/8 (/.f64 1 (pow.f64 x 3)))) (*.f64 9/16 (/.f64 1 (pow.f64 x 4)))) (+.f64 (*.f64 27/16 (/.f64 1 (pow.f64 x 5))) (*.f64 135/32 (/.f64 1 (pow.f64 x 6)))))
(+.f64 (-.f64 3 (+.f64 x x)) 0)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(+.f64 0 (-.f64 3 (+.f64 x x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -1 (-.f64 x 3)) (-.f64 1 x))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -1 x) (-.f64 1 (-.f64 x 3)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -1 (+.f64 x (-.f64 x 3))) 1)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(-.f64 3 (-.f64 x (neg.f64 x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(-.f64 (-.f64 3 x) x)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) (-.f64 0 (neg.f64 x)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(-.f64 (-.f64 3 (+.f64 x x)) 0)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(-.f64 0 (+.f64 x (-.f64 x 3)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(-.f64 (neg.f64 x) (-.f64 x 3))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(/.f64 (-.f64 3 (+.f64 x x)) 1)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(/.f64 (-.f64 3 (+.f64 x x)) (/.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(/.f64 (+.f64 x (-.f64 x 3)) -1)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(pow.f64 (-.f64 3 (+.f64 x x)) 1)
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(neg.f64 (+.f64 x (-.f64 x 3)))
(-.f64 3 (+.f64 x x))
(-.f64 (-.f64 3 x) x)
(+.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 0)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(+.f64 0 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(-.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 0)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 1)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) (/.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(pow.f64 (*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x)) 1)
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(+.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(+.f64 0 (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(-.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (*.f64 x (-.f64 3 (+.f64 x x)))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(pow.f64 (*.f64 x (-.f64 3 (+.f64 x x))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(+.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 0)
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(+.f64 0 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(-.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 0)
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 1)
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (+.f64 x (-.f64 x 3)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (+.f64 x (-.f64 x 3))))))
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))))
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))) (/.f64 (/.f64 1 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))) (*.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))))))
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(pow.f64 (/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x)))) 1)
(/.f64 (/.f64 1 (-.f64 3 (+.f64 x x))) (*.f64 (-.f64 3 (+.f64 x x)) (-.f64 3 (+.f64 x x))))
(/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))

localize15.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (-.f64 4 x) (+.f64 x 1))
0.0b
(*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1)))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
Compiler

Compiled 37 to 25 computations (32.4% saved)

series1.0ms (0%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
0.0ms
x
@0
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
0.0ms
x
@inf
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
0.0ms
x
@0
(*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1)))
0.0ms
x
@-inf
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
0.0ms
x
@inf
(*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1)))

rewrite121.0ms (2.2%)

Algorithm
batch-egg-rewrite
Rules
1104×rational.json-simplify-2
612×rational.json-simplify-41
592×rational.json-simplify-47
572×rational.json-simplify-54
510×rational.json-simplify-49
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01075
19057
230257
3110557
4418557
Stop Event
node limit
Counts
3 → 57
Calls
Call 1
Inputs
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
(*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1)))
(-.f64 (-.f64 4 x) (+.f64 x 1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (-.f64 0 (-.f64 -1 (*.f64 x (-.f64 (-.f64 3 x) x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 4 x) (-.f64 -1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (+.f64 (-.f64 3 x) (-.f64 -1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (-.f64 3 x) x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (-.f64 (-.f64 3 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 3 x) (neg.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 3 x) (+.f64 (-.f64 1 x) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 4 (+.f64 x x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (-.f64 4 (+.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 x) (-.f64 4 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -1 x) (+.f64 (-.f64 0 (-.f64 x 5)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (neg.f64 x) (-.f64 3 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (-.f64 3 x) (-.f64 -1 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 4 (+.f64 x 2)) (-.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 4 (+.f64 x 2)) (+.f64 (-.f64 1 x) 0))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 x) (-.f64 4 (+.f64 x 2)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -2 x) (-.f64 0 (-.f64 x 5)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -2 x) (+.f64 (-.f64 0 (-.f64 x 5)) 0))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 -2 x) (+.f64 1 (-.f64 4 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 0 (-.f64 x 5)) (-.f64 -2 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (-.f64 3 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (-.f64 3 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (+.f64 x (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (-.f64 x 3)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 -1 (+.f64 x (-.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (+.f64 x (-.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (-.f64 -1 (+.f64 (-.f64 3 x) (-.f64 -1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (-.f64 3 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 x (-.f64 x 3)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (-.f64 3 x) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (+.f64 x (-.f64 x 3)))))))

simplify191.0ms (3.4%)

Algorithm
egg-herbie
Rules
1084×rational.json-simplify-49
962×rational.json-simplify-47
734×rational.json-simplify-1
710×rational.json-simplify-54
542×rational.json-simplify-2
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01232319
12512319
24992319
313112157
437362157
575802127
Stop Event
node limit
Counts
93 → 84
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(*.f64 -2 (pow.f64 x 2))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(*.f64 -2 x)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 -2 x))
(+.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(+.f64 0 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))
(-.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(-.f64 0 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))) 1)
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(pow.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(neg.f64 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(+.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(+.f64 0 (*.f64 x (-.f64 (-.f64 3 x) x)))
(-.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(-.f64 0 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (-.f64 (-.f64 3 x) x)))) 1)
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))
(pow.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(neg.f64 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(+.f64 1 (+.f64 (-.f64 3 x) (-.f64 -1 x)))
(+.f64 (-.f64 (-.f64 3 x) x) 0)
(+.f64 0 (-.f64 (-.f64 3 x) x))
(+.f64 (-.f64 3 x) (neg.f64 x))
(+.f64 (-.f64 3 x) (+.f64 (-.f64 1 x) -1))
(+.f64 (-.f64 4 (+.f64 x x)) -1)
(+.f64 -1 (-.f64 4 (+.f64 x x)))
(+.f64 (-.f64 -1 x) (-.f64 4 x))
(+.f64 (-.f64 -1 x) (+.f64 (-.f64 0 (-.f64 x 5)) -1))
(+.f64 (neg.f64 x) (-.f64 3 x))
(+.f64 (+.f64 (-.f64 3 x) (-.f64 -1 x)) 1)
(+.f64 (-.f64 4 (+.f64 x 2)) (-.f64 1 x))
(+.f64 (-.f64 4 (+.f64 x 2)) (+.f64 (-.f64 1 x) 0))
(+.f64 (-.f64 1 x) (-.f64 4 (+.f64 x 2)))
(+.f64 (-.f64 -2 x) (-.f64 0 (-.f64 x 5)))
(+.f64 (-.f64 -2 x) (+.f64 (-.f64 0 (-.f64 x 5)) 0))
(+.f64 (-.f64 -2 x) (+.f64 1 (-.f64 4 x)))
(+.f64 (-.f64 0 (-.f64 x 5)) (-.f64 -2 x))
(*.f64 1 (-.f64 (-.f64 3 x) x))
(*.f64 (-.f64 (-.f64 3 x) x) 1)
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x))
(*.f64 -1 (+.f64 x (-.f64 x 3)))
(*.f64 (+.f64 x (-.f64 x 3)) -1)
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 -1 (+.f64 x (-.f64 x 3))))
(*.f64 (neg.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (+.f64 x (-.f64 x 3)))
(*.f64 (neg.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (-.f64 -1 (+.f64 (-.f64 3 x) (-.f64 -1 x))))
(*.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))
(*.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))
(*.f64 (*.f64 (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))
(/.f64 (-.f64 (-.f64 3 x) x) 1)
(/.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(/.f64 (+.f64 x (-.f64 x 3)) -1)
(pow.f64 (-.f64 (-.f64 3 x) x) 1)
(neg.f64 (+.f64 x (-.f64 x 3)))
Outputs
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 3 x)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(*.f64 -2 (pow.f64 x 2))
(*.f64 (pow.f64 x 2) -2)
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
(+.f64 (*.f64 3 x) (*.f64 -2 (pow.f64 x 2)))
(+.f64 (*.f64 3 x) (*.f64 (pow.f64 x 2) -2))
(+.f64 (*.f64 (pow.f64 x 2) -2) (*.f64 3 x))
3
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(*.f64 -2 x)
(*.f64 x -2)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(*.f64 -2 x)
(*.f64 x -2)
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 3 (*.f64 -2 x))
(+.f64 3 (*.f64 x -2))
(+.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(+.f64 0 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(-.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 0)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(-.f64 0 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)))) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (/.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(pow.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x)) 1)
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(neg.f64 (neg.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 x x))))
(*.f64 (-.f64 3 (+.f64 x x)) (*.f64 x x))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(+.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(+.f64 0 (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(-.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 0)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(-.f64 0 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(-.f64 (-.f64 0 (-.f64 -1 (*.f64 x (-.f64 (-.f64 3 x) x)))) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))
(/.f64 (*.f64 x (-.f64 3 (+.f64 x x))) (/.f64 (*.f64 x (+.f64 x (-.f64 x 3))) (*.f64 x (+.f64 x (-.f64 x 3)))))
(/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (/.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) (*.f64 x (-.f64 (-.f64 3 x) x))))
(pow.f64 (*.f64 x (-.f64 (-.f64 3 x) x)) 1)
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(neg.f64 (neg.f64 (*.f64 x (-.f64 (-.f64 3 x) x))))
(*.f64 x (-.f64 3 (+.f64 x x)))
(*.f64 x (-.f64 (-.f64 3 x) x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 1 (+.f64 (-.f64 3 x) (-.f64 -1 x)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 (-.f64 3 x) x) 0)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 0 (-.f64 (-.f64 3 x) x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 3 x) (neg.f64 x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 3 x) (+.f64 (-.f64 1 x) -1))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 4 (+.f64 x x)) -1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 -1 (-.f64 4 (+.f64 x x)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -1 x) (-.f64 4 x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -1 x) (+.f64 (-.f64 0 (-.f64 x 5)) -1))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (neg.f64 x) (-.f64 3 x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (+.f64 (-.f64 3 x) (-.f64 -1 x)) 1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 4 (+.f64 x 2)) (-.f64 1 x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 4 (+.f64 x 2)) (+.f64 (-.f64 1 x) 0))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 1 x) (-.f64 4 (+.f64 x 2)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -2 x) (-.f64 0 (-.f64 x 5)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -2 x) (+.f64 (-.f64 0 (-.f64 x 5)) 0))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 -2 x) (+.f64 1 (-.f64 4 x)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(+.f64 (-.f64 0 (-.f64 x 5)) (-.f64 -2 x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(*.f64 1 (-.f64 (-.f64 3 x) x))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(*.f64 (-.f64 (-.f64 3 x) x) 1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 -1 (+.f64 x (-.f64 x 3)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(*.f64 (+.f64 x (-.f64 x 3)) -1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (+.f64 x (-.f64 x 3)) (*.f64 (+.f64 x (-.f64 x 3)) (/.f64 1 (-.f64 3 (+.f64 x x)))))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 3 (+.f64 x x))))
(*.f64 (+.f64 x (-.f64 x 3)) (*.f64 (+.f64 x (-.f64 x 3)) (/.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (-.f64 (-.f64 3 x) x))))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 -1 (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (neg.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (+.f64 x (-.f64 x 3)))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (neg.f64 (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (-.f64 -1 (+.f64 (-.f64 3 x) (-.f64 -1 x))))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (+.f64 x (-.f64 x 3)) (*.f64 (+.f64 x (-.f64 x 3)) (/.f64 1 (-.f64 3 (+.f64 x x)))))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))
(*.f64 (+.f64 x (-.f64 x 3)) (*.f64 (+.f64 x (-.f64 x 3)) (/.f64 1 (-.f64 3 (+.f64 x x)))))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))
(*.f64 (+.f64 x (-.f64 x 3)) (*.f64 (+.f64 x (-.f64 x 3)) (/.f64 1 (-.f64 3 (+.f64 x x)))))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))))
(*.f64 (+.f64 x (-.f64 x 3)) (*.f64 (+.f64 x (-.f64 x 3)) (/.f64 1 (-.f64 3 (+.f64 x x)))))
(*.f64 (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)) (/.f64 1 (-.f64 (-.f64 3 x) x)))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (-.f64 (-.f64 3 x) x) (-.f64 (-.f64 3 x) x)))
(/.f64 (-.f64 (-.f64 3 x) x) 1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(/.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 3 (+.f64 x x)) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(*.f64 (-.f64 (-.f64 3 x) x) (/.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))
(/.f64 (+.f64 x (-.f64 x 3)) -1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(pow.f64 (-.f64 (-.f64 3 x) x) 1)
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)
(neg.f64 (+.f64 x (-.f64 x 3)))
(+.f64 (-.f64 4 x) (-.f64 -1 x))
(-.f64 (-.f64 3 x) x)

eval150.0ms (2.7%)

Compiler

Compiled 6064 to 3941 computations (35% saved)

prune37.0ms (0.7%)

Pruning

10 alts after pruning (0 fresh and 10 done)

PrunedKeptTotal
New1910191
Fresh000
Picked011
Done099
Total19110201
Error
0.0b
Counts
201 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
0.2b
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
0.1b
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
0.1b
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
11.6b
(*.f64 x (*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))
22.0b
(*.f64 x (*.f64 x (*.f64 x -2)))
18.6b
(*.f64 x (*.f64 x 3))
18.7b
(*.f64 3 (*.f64 x x))
21.9b
(*.f64 -2 (pow.f64 x 3))
Compiler

Compiled 176 to 119 computations (32.4% saved)

regimes18.0ms (0.3%)

Counts
11 → 1
Calls
Call 1
Inputs
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 x (*.f64 x -2)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
(*.f64 x (*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))
(*.f64 -2 (pow.f64 x 3))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
Outputs
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
Calls

2 calls:

9.0ms
x
5.0ms
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Results
ErrorSegmentsBranch
0.1b1x
0.1b1(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Compiler

Compiled 192 to 126 computations (34.4% saved)

regimes166.0ms (2.9%)

Counts
10 → 1
Calls
Call 1
Inputs
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 x (*.f64 x -2)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(*.f64 x (*.f64 x (-.f64 (-.f64 3 x) x)))
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
(*.f64 x (*.f64 x (-.f64 (-.f64 4 x) (+.f64 x 1))))
(*.f64 x (*.f64 x (+.f64 (-.f64 1 (-.f64 x 3)) (-.f64 -1 x))))
(*.f64 x (*.f64 x (*.f64 (*.f64 (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3))))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))) (/.f64 (/.f64 (/.f64 1 (-.f64 (-.f64 3 x) x)) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (-.f64 (-.f64 3 x) x) (*.f64 (+.f64 x (-.f64 x 3)) (+.f64 x (-.f64 x 3)))))))))
(*.f64 -2 (pow.f64 x 3))
Outputs
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
Calls

2 calls:

156.0ms
x
5.0ms
(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Results
ErrorSegmentsBranch
0.1b1x
0.1b1(*.f64 (*.f64 x x) (-.f64 3 (*.f64 x 2)))
Compiler

Compiled 181 to 117 computations (35.4% saved)

regimes13.0ms (0.2%)

Counts
3 → 3
Calls
Call 1
Inputs
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 x (*.f64 x -2)))
Outputs
(*.f64 x (*.f64 x (*.f64 x -2)))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 x (*.f64 x -2)))
Calls

1 calls:

12.0ms
x
Results
ErrorSegmentsBranch
2.3b3x
Compiler

Compiled 20 to 12 computations (40% saved)

bsearch42.0ms (0.7%)

Algorithm
binary-search
Steps
TimeLeftRight
20.0ms
0.0015597399396620258
25.652046306408312
22.0ms
-32646.0550757152
-0.4604163768690626
Results
37.0ms272×body256valid
Compiler

Compiled 286 to 197 computations (31.1% saved)

regimes5.0ms (0.1%)

Accuracy

Total -0.1b remaining (-0.4%)

Threshold costs -0.1b (-0.4%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
Outputs
(*.f64 x (*.f64 x 3))
Calls

1 calls:

4.0ms
x
Results
ErrorSegmentsBranch
18.6b1x
Compiler

Compiled 13 to 8 computations (38.5% saved)

simplify4.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
031151
Stop Event
done
saturated
Calls
Call 1
Inputs
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(if (<=.f64 x -3/2) (*.f64 x (*.f64 x (*.f64 x -2))) (if (<=.f64 x 3/2) (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x (*.f64 x -2)))))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
Outputs
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -2 (pow.f64 x 3)))
(*.f64 x (*.f64 x (-.f64 3 (+.f64 x x))))
(if (<=.f64 x -3/2) (*.f64 x (*.f64 x (*.f64 x -2))) (if (<=.f64 x 3/2) (*.f64 x (*.f64 x 3)) (*.f64 x (*.f64 x (*.f64 x -2)))))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
Compiler

Compiled 62 to 42 computations (32.3% saved)

soundness0.0ms (0%)

end45.0ms (0.8%)

Compiler

Compiled 58 to 38 computations (34.5% saved)

Profiling

Loading profile data...