Details

Time bar (total: 5.9s)

analyze298.0ms (5.1%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
12.5%12.5%87.4%0.1%0%0%0%7
18.8%18.7%81.1%0.1%0%0%0%8
25.4%25%73.3%0.1%1.6%0%0%9
35.3%34.3%62.8%0.1%2.7%0%0%10
43.9%41.3%52.9%0.1%5.7%0%0%11
50.6%46.8%45.7%0.1%7.3%0%0%12
Compiler

Compiled 15 to 10 computations (33.3% saved)

sample1.4s (23.5%)

Results
1.1s7891×body256valid
142.0ms1423×body256infinite
111.0ms213×body512valid
38.0ms152×body1024valid
Bogosity

preprocess15.0ms (0.3%)

Algorithm
egg-herbie
Rules
66×rational.json-simplify-1
38×rational.json-simplify-2
36×rational.json-simplify-51
26×rational.json-simplify-41
swap-d2-d3
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
023124
140100
26676
39776
411776
512276
033
133
Stop Event
unsound
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
1
Call 2
Inputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (+.f64 (*.f64 d2 3) (*.f64 d2 d1)) (*.f64 d2 d3))
(+.f64 (+.f64 (*.f64 d3 3) (*.f64 d3 d2)) (*.f64 d3 d1))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d3)) (*.f64 d1 d2))
Outputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (*.f64 d1 d2) (*.f64 d1 (+.f64 d3 3)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (+.f64 (*.f64 d2 3) (*.f64 d2 d1)) (*.f64 d2 d3))
(+.f64 (+.f64 (*.f64 d1 d2) (*.f64 3 d2)) (*.f64 d2 d3))
(+.f64 (*.f64 d2 (+.f64 3 d1)) (*.f64 d2 d3))
(*.f64 d2 (+.f64 d3 (+.f64 d1 3)))
(*.f64 d2 (+.f64 3 (+.f64 d1 d3)))
(+.f64 (+.f64 (*.f64 d3 3) (*.f64 d3 d2)) (*.f64 d3 d1))
(+.f64 (*.f64 d1 d3) (+.f64 (*.f64 3 d3) (*.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d3 (+.f64 d2 3)))
(*.f64 d3 (+.f64 d1 (+.f64 3 d2)))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d3)) (*.f64 d1 d2))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (*.f64 d1 d2) (*.f64 d1 (+.f64 d3 3)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
Symmetry

(sort d2 d3)

Compiler

Compiled 17 to 12 computations (29.4% saved)

simplify9.0ms (0.2%)

Algorithm
egg-herbie
Rules
24×rational.json-simplify-1
14×rational.json-simplify-2
10×rational.json-simplify-51
rational.json-simplify-41
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01131
11625
22419
33519
44319
54519
Stop Event
saturated
Counts
1 → 4
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Outputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))

eval1.0ms (0%)

Compiler

Compiled 37 to 21 computations (43.2% saved)

prune2.0ms (0%)

Pruning

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New134
Fresh011
Picked000
Done000
Total145
Error
0.1b
Counts
5 → 3
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
0.1b
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
0.1b
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
Compiler

Compiled 36 to 24 computations (33.3% saved)

localize9.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
Compiler

Compiled 22 to 13 computations (40.9% saved)

series3.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
d3
@inf
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
0.0ms
d1
@0
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
0.0ms
d1
@-inf
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
0.0ms
d1
@inf
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
0.0ms
d2
@inf
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))

rewrite105.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
1636×rational.json-1
1636×rational.json-2
1636×rational.json-3
1604×exponential.json-3
1604×rational.json-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0919
16119
213319
328119
458819
5150319
6343119
7505419
8685019
Stop Event
node limit
Counts
1 → 13
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 1/2)) (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (+.f64 d1 d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 1)))))

simplify358.0ms (6.1%)

Algorithm
egg-herbie
Rules
3512×rational.json-simplify-41
2776×rational.json-simplify-2
2040×rational.json-simplify-35
1416×rational.json-simplify-53
836×exponential.json-simplify-26
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057871
1133871
2242871
3567871
42111871
53545871
63759871
73875871
83974871
94071871
104167871
115138871
126181871
136278871
146374871
156374871
166388871
Stop Event
node limit
Counts
49 → 23
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 d2 3) d1)
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 0)
(+.f64 0 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))))
(+.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 1/2)) (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 1/2)))
(-.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 0)
(/.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 1)
(/.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (+.f64 d1 d1)) 2)
(/.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 4)) 4)
(/.f64 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)) 8)
(/.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))))) 64)
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)))))) 128)
(pow.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 1)
Outputs
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d2 3) d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 0)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 0 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 1/2)) (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 1/2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(-.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 0)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (+.f64 d1 d1)) 2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 (+.f64 d3 (+.f64 3 d2)) (*.f64 d1 4)) 4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)) 8)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))) 16)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)))) 32)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))))) 64)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d3 (+.f64 3 d2)) 8)))))) 128)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(pow.f64 (*.f64 d1 (+.f64 d3 (+.f64 3 d2))) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
0.0b
(*.f64 d1 (+.f64 d2 3))
Compiler

Compiled 27 to 14 computations (48.1% saved)

series4.0ms (0.1%)

Counts
2 → 60
Calls

15 calls:

TimeVariablePointExpression
1.0ms
d1
@inf
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
1.0ms
d1
@-inf
(*.f64 d1 (+.f64 d2 3))
0.0ms
d1
@0
(*.f64 d1 (+.f64 d2 3))
0.0ms
d1
@0
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
0.0ms
d1
@inf
(*.f64 d1 (+.f64 d2 3))

rewrite275.0ms (4.7%)

Algorithm
batch-egg-rewrite
Rules
2334×rational.json-simplify-35
1816×rational.json-1
1388×rational.json-simplify-1
1196×rational.json-simplify-2
1180×rational.json-2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01038
16632
213532
329132
456732
5132332
6273432
7448632
8565532
9646732
10646732
11646732
12797232
Stop Event
node limit
Counts
2 → 54
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d2 3))
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 d2 3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 d1 (+.f64 d2 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)) (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 d2 3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d2 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 3) (+.f64 d1 d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))))))) 256)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d2 3)) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 (+.f64 d2 3) d3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 d1 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (/.f64 (+.f64 (+.f64 d2 3) d3) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 d2 3) d3) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 (*.f64 d1 1/2) (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (*.f64 1/2 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 8 (*.f64 (/.f64 d1 4) (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 8) (*.f64 1/4 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 (+.f64 d2 3) d3)) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (+.f64 (*.f64 d1 (+.f64 d3 d3)) (*.f64 (+.f64 d2 3) (+.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 (+.f64 d2 3) d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (+.f64 d2 3) d3) 2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 d1 (+.f64 d3 d3)) (*.f64 (+.f64 d2 3) (+.f64 d1 d1))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6))) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (/.f64 d1 4)) (*.f64 4 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2)) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6)))) (*.f64 1/2 (*.f64 d1 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)))))) 256)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)))))

simplify219.0ms (3.7%)

Algorithm
egg-herbie
Rules
2116×rational.json-simplify-2
1994×rational.json-simplify-35
1166×rational.json-simplify-1
1144×exponential.json-simplify-26
1128×rational.json-simplify-53
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01431866
13341860
27221860
321441860
448011860
555041860
657271860
758901860
860491860
962141860
1076571860
Stop Event
node limit
Counts
114 → 70
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 (+.f64 d2 3)) 0)
(+.f64 0 (*.f64 d1 (+.f64 d2 3)))
(+.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)) (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)))
(-.f64 (*.f64 d1 (+.f64 d2 3)) 0)
(/.f64 (*.f64 d1 (+.f64 d2 3)) 1)
(/.f64 (*.f64 (+.f64 d2 3) (+.f64 d1 d1)) 2)
(/.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 4)) 4)
(/.f64 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)) 8)
(/.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))))) 128)
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))))))) 256)
(pow.f64 (*.f64 d1 (+.f64 d2 3)) 1)
(-.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 0)
(*.f64 d1 (+.f64 (+.f64 d2 3) d3))
(*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)
(*.f64 1 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)))
(*.f64 2 (*.f64 d1 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2))
(*.f64 (+.f64 d1 d1) (/.f64 (+.f64 (+.f64 d2 3) d3) 2))
(*.f64 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)) 1/2)
(*.f64 (+.f64 (+.f64 d2 3) d3) d1)
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 4))
(*.f64 4 (*.f64 (*.f64 d1 1/2) (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 (*.f64 d1 4) (*.f64 1/2 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)) 1/4)
(*.f64 8 (*.f64 (/.f64 d1 4) (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 (*.f64 d1 8) (*.f64 1/4 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 (*.f64 2 (+.f64 (+.f64 d2 3) d3)) (*.f64 d1 1/2))
(*.f64 1/2 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)))
(*.f64 1/2 (+.f64 (*.f64 d1 (+.f64 d3 d3)) (*.f64 (+.f64 d2 3) (+.f64 d1 d1))))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 (+.f64 d2 3) d3)))
(*.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6))))
(*.f64 (*.f64 d1 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)) 2)
(*.f64 (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2) (+.f64 d1 d1))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)))
(*.f64 (/.f64 (+.f64 (+.f64 d2 3) d3) 2) (+.f64 d1 d1))
(*.f64 (+.f64 (*.f64 d1 (+.f64 d3 d3)) (*.f64 (+.f64 d2 3) (+.f64 d1 d1))) 1/2)
(*.f64 (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6))) (*.f64 d1 1/2))
(*.f64 (*.f64 2 (/.f64 d1 4)) (*.f64 4 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 (*.f64 2 (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2)) d1)
(*.f64 (/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 4) 4)
(*.f64 (*.f64 2 (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6)))) (*.f64 1/2 (*.f64 d1 1/2)))
(/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)
(/.f64 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)) 2)
(/.f64 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)) 4)
(/.f64 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8) 8)
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))))) 128)
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)))))) 256)
(pow.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)
Outputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 3 d1)
(*.f64 d1 3)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 (+.f64 d2 3))) d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 d1 (+.f64 d2 3)) 0)
(*.f64 d1 (+.f64 3 d2))
(+.f64 0 (*.f64 d1 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)) (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)))
(*.f64 d1 (+.f64 3 d2))
(-.f64 (*.f64 d1 (+.f64 d2 3)) 0)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (+.f64 d2 3)) 1)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d2 3) (+.f64 d1 d1)) 2)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 4)) 4)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)) 8)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))) 16)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))) 32)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))))) 64)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))))) 128)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8)))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 d2 3) 8))))))) 256)
(*.f64 d1 (+.f64 3 d2))
(pow.f64 (*.f64 d1 (+.f64 d2 3)) 1)
(*.f64 d1 (+.f64 3 d2))
(-.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 0)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 d2 3) d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 1 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 2 (*.f64 d1 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 d1 d1) (/.f64 (+.f64 (+.f64 d2 3) d3) 2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)) 1/2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 (+.f64 d2 3) d3) d1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 4))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 4 (*.f64 (*.f64 d1 1/2) (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 4) (*.f64 1/2 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)) 1/4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 8 (*.f64 (/.f64 d1 4) (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 8) (*.f64 1/4 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 2 (+.f64 (+.f64 d2 3) d3)) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 1/2 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 1/2 (+.f64 (*.f64 d1 (+.f64 d3 d3)) (*.f64 (+.f64 d2 3) (+.f64 d1 d1))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 (+.f64 d2 3) d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)) 2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (/.f64 (+.f64 (+.f64 d2 3) d3) 2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 (*.f64 d1 (+.f64 d3 d3)) (*.f64 (+.f64 d2 3) (+.f64 d1 d1))) 1/2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6))) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 2 (/.f64 d1 4)) (*.f64 4 (/.f64 (+.f64 (+.f64 d2 3) d3) 2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 2 (*.f64 (+.f64 (+.f64 d2 3) d3) 1/2)) d1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 4) 4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 2 (+.f64 (+.f64 d3 d3) (+.f64 d2 (+.f64 d2 6)))) (*.f64 1/2 (*.f64 d1 1/2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 (+.f64 d1 d1) (+.f64 (+.f64 d2 3) d3)) 2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 d1 (*.f64 (+.f64 (+.f64 d2 3) d3) 4)) 4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8) 8)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)) 16)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))) 32)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)))) 64)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))))) 128)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 8)))))) 256)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(pow.f64 (*.f64 d1 (+.f64 (+.f64 d2 3) d3)) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))

localize12.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
0.0b
(+.f64 (*.f64 d1 3) (*.f64 d1 d2))
Compiler

Compiled 34 to 15 computations (55.9% saved)

series3.0ms (0.1%)

Counts
2 → 60
Calls

15 calls:

TimeVariablePointExpression
1.0ms
d1
@-inf
(+.f64 (*.f64 d1 3) (*.f64 d1 d2))
0.0ms
d1
@0
(+.f64 (*.f64 d1 3) (*.f64 d1 d2))
0.0ms
d3
@0
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
0.0ms
d2
@0
(+.f64 (*.f64 d1 3) (*.f64 d1 d2))
0.0ms
d2
@-inf
(+.f64 (*.f64 d1 3) (*.f64 d1 d2))

rewrite118.0ms (2%)

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

Useful iterations: 2 (0.0ms)

IterNodesCost
01150
17338
215032
334332
473032
5194432
6361232
7485632
8706532
Stop Event
node limit
Counts
2 → 59
Calls
Call 1
Inputs
(+.f64 (*.f64 d1 3) (*.f64 d1 d2))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 3 d2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 3 d2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 3 d2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 d1 (/.f64 (+.f64 3 d2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 (*.f64 (+.f64 3 d2) 1/2) d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d2) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (/.f64 (+.f64 3 d2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 3 d2) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (/.f64 (*.f64 d1 (+.f64 3 d2)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 4 (+.f64 3 d2))) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 3 d2)) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (/.f64 (+.f64 3 d2) 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) 1/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 d1 (*.f64 4 (+.f64 3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 3 d2) 2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (+.f64 3 d2)) 4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (*.f64 (+.f64 3 d2) 1/2)) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (/.f64 (+.f64 3 d2) 2)) d1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 3 d2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 4 (+.f64 3 d2))) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 d2)) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 3 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 (+.f64 3 (+.f64 d2 d3)) (*.f64 d1 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2) d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 3 (+.f64 d2 d3)) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 3 (+.f64 d2 d3))) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) (*.f64 d1 1/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2)) d1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)))))

simplify401.0ms (6.8%)

Algorithm
egg-herbie
Rules
4422×rational.json-simplify-41
2488×rational.json-simplify-2
2364×rational.json-simplify-35
1012×rational.json-simplify-51
994×rational.json-simplify-53
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01331979
12961925
26381925
320181901
439781869
548671853
651371853
752791853
854221853
955511853
1060881853
1164951853
1269081853
1369081853
1470891853
1572041853
1673191853
Stop Event
node limit
Counts
119 → 84
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(-.f64 (*.f64 d1 (+.f64 3 d2)) 0)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 1 (*.f64 d1 (+.f64 3 d2)))
(*.f64 2 (*.f64 d1 (/.f64 (+.f64 3 d2) 2)))
(*.f64 2 (*.f64 (*.f64 (+.f64 3 d2) 1/2) d1))
(*.f64 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)) 1/2)
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d2) 1/2))
(*.f64 (+.f64 d1 d1) (/.f64 (+.f64 3 d2) 2))
(*.f64 (+.f64 3 d2) d1)
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 3 d2)) 4))
(*.f64 (*.f64 d1 (*.f64 4 (+.f64 3 d2))) 1/4)
(*.f64 (*.f64 2 (+.f64 3 d2)) (*.f64 d1 1/2))
(*.f64 1/2 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 d2)))
(*.f64 (*.f64 d1 (/.f64 (+.f64 3 d2) 2)) 2)
(*.f64 (*.f64 (+.f64 3 d2) 1/2) (+.f64 d1 d1))
(*.f64 1/4 (*.f64 d1 (*.f64 4 (+.f64 3 d2))))
(*.f64 (/.f64 (+.f64 3 d2) 2) (+.f64 d1 d1))
(*.f64 (/.f64 (*.f64 d1 (+.f64 3 d2)) 4) 4)
(*.f64 (*.f64 2 (*.f64 (+.f64 3 d2) 1/2)) d1)
(*.f64 (*.f64 2 (/.f64 (+.f64 3 d2) 2)) d1)
(/.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(/.f64 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)) 2)
(/.f64 (*.f64 d1 (*.f64 4 (+.f64 3 d2))) 4)
(/.f64 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))) 8)
(/.f64 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) 64)
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))))))) 128)
(pow.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(-.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 0)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)
(*.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))
(*.f64 2 (*.f64 (+.f64 3 (+.f64 d2 d3)) (*.f64 d1 1/2)))
(*.f64 2 (*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2) d1))
(*.f64 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))) 1/2)
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2))
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 4))
(*.f64 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))) 1/4)
(*.f64 (+.f64 3 (+.f64 d2 d3)) d1)
(*.f64 (*.f64 2 (+.f64 3 (+.f64 d2 d3))) (*.f64 d1 1/2))
(*.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 (+.f64 d2 d3))))
(*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) (*.f64 d1 1/2)) 2)
(*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2) (+.f64 d1 d1))
(*.f64 1/4 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))
(*.f64 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 4) 4)
(*.f64 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2)) d1)
(/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)
(/.f64 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))) 2)
(/.f64 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))) 4)
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))) 8)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) 64)
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))))))) 128)
(pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)
Outputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d2) (neg.f64 d1))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d2) (neg.f64 d1))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d2) (neg.f64 d1))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d2) (neg.f64 d1))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 3 d1)
(*.f64 d1 3)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 d1 (*.f64 (+.f64 (*.f64 d2 -1) (-.f64 (*.f64 -1 d3) 3)) -1))
(*.f64 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3) (neg.f64 d1))
(*.f64 (+.f64 (neg.f64 d2) (-.f64 -3 d3)) (neg.f64 d1))
(*.f64 d1 (-.f64 3 (neg.f64 (+.f64 d2 d3))))
(*.f64 d1 (-.f64 (+.f64 d2 d3) -3))
(*.f64 d1 (+.f64 d2 (-.f64 d3 -3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 d1 (*.f64 (+.f64 (*.f64 d2 -1) (-.f64 (*.f64 -1 d3) 3)) -1))
(*.f64 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3) (neg.f64 d1))
(*.f64 (+.f64 (neg.f64 d2) (-.f64 -3 d3)) (neg.f64 d1))
(*.f64 d1 (-.f64 3 (neg.f64 (+.f64 d2 d3))))
(*.f64 d1 (-.f64 (+.f64 d2 d3) -3))
(*.f64 d1 (+.f64 d2 (-.f64 d3 -3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 d1 (*.f64 (+.f64 (*.f64 d2 -1) (-.f64 (*.f64 -1 d3) 3)) -1))
(*.f64 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3) (neg.f64 d1))
(*.f64 (+.f64 (neg.f64 d2) (-.f64 -3 d3)) (neg.f64 d1))
(*.f64 d1 (-.f64 3 (neg.f64 (+.f64 d2 d3))))
(*.f64 d1 (-.f64 (+.f64 d2 d3) -3))
(*.f64 d1 (+.f64 d2 (-.f64 d3 -3)))
(*.f64 -1 (*.f64 d1 (-.f64 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2)) 3)))
(*.f64 d1 (*.f64 (+.f64 (*.f64 d2 -1) (-.f64 (*.f64 -1 d3) 3)) -1))
(*.f64 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3) (neg.f64 d1))
(*.f64 (+.f64 (neg.f64 d2) (-.f64 -3 d3)) (neg.f64 d1))
(*.f64 d1 (-.f64 3 (neg.f64 (+.f64 d2 d3))))
(*.f64 d1 (-.f64 (+.f64 d2 d3) -3))
(*.f64 d1 (+.f64 d2 (-.f64 d3 -3)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(-.f64 (*.f64 d1 (+.f64 3 d2)) 0)
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 1 (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 2 (*.f64 d1 (/.f64 (+.f64 3 d2) 2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 2 (*.f64 (*.f64 (+.f64 3 d2) 1/2) d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)) 1/2)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d2) 1/2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d1 d1) (/.f64 (+.f64 3 d2) 2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 3 d2) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 3 d2)) 4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (*.f64 4 (+.f64 3 d2))) 1/4)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 2 (+.f64 3 d2)) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 1/2 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (/.f64 (+.f64 3 d2) 2)) 2)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 3 d2) 1/2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 1/4 (*.f64 d1 (*.f64 4 (+.f64 3 d2))))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (/.f64 (+.f64 3 d2) 2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (/.f64 (*.f64 d1 (+.f64 3 d2)) 4) 4)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 2 (*.f64 (+.f64 3 d2) 1/2)) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 2 (/.f64 (+.f64 3 d2) 2)) d1)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)) 2)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (*.f64 4 (+.f64 3 d2))) 4)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))) 8)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))) 16)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))))) 32)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) 64)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2)))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 4 (*.f64 (+.f64 d1 d1) (+.f64 3 d2))))))) 128)
(*.f64 d1 (+.f64 3 d2))
(pow.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 d1 (+.f64 3 d2))
(-.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 0)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 2 (*.f64 (+.f64 3 (+.f64 d2 d3)) (*.f64 d1 1/2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 2 (*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2) d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))) 1/2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 4))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))) 1/4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (+.f64 3 (+.f64 d2 d3)) d1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 2 (+.f64 3 (+.f64 d2 d3))) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) (*.f64 d1 1/2)) 2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 1/4 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 4) 4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d2 d3)) 1/2)) d1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 d1 (*.f64 2 (+.f64 3 (+.f64 d2 d3)))) 2)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))) 4)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))) 8)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))) 16)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))))) 32)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) 64)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3))))))) (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 4) (+.f64 3 (+.f64 d2 d3)))))))) 128)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))

eval81.0ms (1.4%)

Compiler

Compiled 2063 to 1267 computations (38.6% saved)

prune25.0ms (0.4%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New1716177
Fresh000
Picked101
Done112
Total1737180
Error
0.1b
Counts
180 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
21.8b
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
22.6b
(*.f64 (+.f64 d2 3) d1)
41.1b
(*.f64 d2 d1)
0.1b
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
21.9b
(*.f64 d1 (+.f64 3 d3))
39.6b
(*.f64 d1 d3)
Compiler

Compiled 110 to 77 computations (30% saved)

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
0.0b
(*.f64 d1 (+.f64 3 d3))
Compiler

Compiled 27 to 14 computations (48.1% saved)

series2.0ms (0%)

Counts
2 → 39
Calls

15 calls:

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

rewrite199.0ms (3.4%)

Algorithm
batch-egg-rewrite
Rules
2672×rational.json-simplify-2
1462×rational.json-simplify-1
1350×rational.json-simplify-35
1302×rational.json-1
1302×rational.json-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01032
16832
214632
331032
459532
5148932
6304332
7457332
8595032
9673632
10673632
11781332
Stop Event
node limit
Counts
2 → 55
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 3 d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 d1 (+.f64 3 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 1/2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 3 d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 3 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 d3)) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 3 (+.f64 d3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 3 (+.f64 d3 d2)) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (*.f64 1/2 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 2) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 8 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (/.f64 d1 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 8) (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4) (*.f64 1/2 (*.f64 d1 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (+.f64 (*.f64 d1 (+.f64 d2 d2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d2 d2) (*.f64 (+.f64 3 d3) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 4) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 d1 (+.f64 d2 d2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 2))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 d2 d2) (*.f64 (+.f64 3 d3) 2)) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (/.f64 d1 4)) (*.f64 4 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 1/2 (*.f64 d1 1/2)) (*.f64 (+.f64 3 (+.f64 d3 d2)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 1/2 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (/.f64 d1 4)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) 1/4) (*.f64 d1 8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 4 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) (*.f64 2 (/.f64 d1 4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8))) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8))))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)))))

simplify300.0ms (5.1%)

Algorithm
egg-herbie
Rules
2474×rational.json-simplify-2
1888×rational.json-simplify-53
1798×rational.json-simplify-35
1000×exponential.json-simplify-26
888×rational.json-simplify-48
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01341702
13261558
27381558
319771558
438841558
548771558
651911558
753821558
855671558
957521558
1065541558
1173761558
1278461558
Stop Event
node limit
Counts
94 → 70
Calls
Call 1
Inputs
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d2 d1)
(*.f64 d2 d1)
(+.f64 (*.f64 d1 (+.f64 3 d3)) 0)
(+.f64 0 (*.f64 d1 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 1/2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 1/2)))
(-.f64 (*.f64 d1 (+.f64 3 d3)) 0)
(/.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 2)) 2)
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 4)
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)) 8)
(/.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8))) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8))))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)))))) 128)
(pow.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(-.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 0)
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)
(*.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))))
(*.f64 (+.f64 3 (+.f64 d3 d2)) d1)
(*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2))
(*.f64 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2) 1/2)
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 4))
(*.f64 4 (*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 (*.f64 d1 4) (*.f64 1/2 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 2) (*.f64 d1 1/2))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)) 1/4)
(*.f64 8 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (/.f64 d1 4)))
(*.f64 (*.f64 d1 8) (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) 1/4))
(*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4) (*.f64 1/2 (*.f64 d1 1/2)))
(*.f64 1/2 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2))
(*.f64 1/2 (+.f64 (*.f64 d1 (+.f64 d2 d2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 2))))
(*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 2))
(*.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d2 d2) (*.f64 (+.f64 3 d3) 2)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) 2)
(*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (+.f64 d1 d1))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)))
(*.f64 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 4) 4)
(*.f64 (+.f64 (*.f64 d1 (+.f64 d2 d2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 2))) 1/2)
(*.f64 (+.f64 (+.f64 d2 d2) (*.f64 (+.f64 3 d3) 2)) (*.f64 d1 1/2))
(*.f64 (*.f64 2 (/.f64 d1 4)) (*.f64 4 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 (*.f64 1/2 (*.f64 d1 1/2)) (*.f64 (+.f64 3 (+.f64 d3 d2)) 4))
(*.f64 (*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) 4)
(*.f64 (*.f64 1/2 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) (*.f64 d1 4))
(*.f64 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (/.f64 d1 4)) 8)
(*.f64 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) 1/4) (*.f64 d1 8))
(*.f64 (*.f64 4 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) (*.f64 2 (/.f64 d1 4)))
(/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)
(/.f64 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2) 2)
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)) 4)
(/.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)) 8)
(/.f64 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8))) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8))))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)))))) 128)
(pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)
Outputs
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d2) (*.f64 -1 (+.f64 3 d3)))))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d1 (+.f64 3 d3)) 0)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 0 (*.f64 d1 (+.f64 3 d3)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 1/2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 1/2)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(-.f64 (*.f64 d1 (+.f64 3 d3)) 0)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 2)) 2)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 4)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)) 8)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8))) 16)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)))) 32)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8))))) 64)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d3) 8)))))) 128)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(pow.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(-.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 0)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (+.f64 3 (+.f64 d3 d2)) d1)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2) 1/2)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 4 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 4))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 4 (*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 4) (*.f64 1/2 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 2) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)) 1/4)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 8 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (/.f64 d1 4)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 8) (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) 1/4))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4) (*.f64 1/2 (*.f64 d1 1/2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 1/2 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 1/2 (+.f64 (*.f64 d1 (+.f64 d2 d2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 2))))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 2))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d2 d2) (*.f64 (+.f64 3 d3) 2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) 2)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 4) 4)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (+.f64 (*.f64 d1 (+.f64 d2 d2)) (*.f64 d1 (*.f64 (+.f64 3 d3) 2))) 1/2)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (+.f64 (+.f64 d2 d2) (*.f64 (+.f64 3 d3) 2)) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 2 (/.f64 d1 4)) (*.f64 4 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 1/2 (*.f64 d1 1/2)) (*.f64 (+.f64 3 (+.f64 d3 d2)) 4))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (*.f64 d1 1/2) (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) 4)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 1/2 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) (*.f64 d1 4))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) (/.f64 d1 4)) 8)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2) 1/4) (*.f64 d1 8))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(*.f64 (*.f64 4 (*.f64 (+.f64 3 (+.f64 d3 d2)) 1/2)) (*.f64 2 (/.f64 d1 4)))
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 2) 2)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 (+.f64 d3 d2)) 4)) 4)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)) 8)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8))) 16)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)))) 32)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8))))) 64)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (+.f64 3 (+.f64 d3 d2)) (*.f64 d1 8)))))) 128)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d3 d2))) 1)
(*.f64 d1 (+.f64 d3 (+.f64 d2 3)))
(*.f64 d1 (+.f64 3 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))

localize3.0ms (0.1%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize3.0ms (0.1%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 d1 (+.f64 3 d3))
Compiler

Compiled 14 to 9 computations (35.7% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (+.f64 d2 3) d1)
Compiler

Compiled 14 to 9 computations (35.7% saved)

series0.0ms (0%)

Counts
1 → 20
Calls

6 calls:

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

rewrite208.0ms (3.5%)

Algorithm
batch-egg-rewrite
Rules
2428×rational.json-simplify-35
1496×rational.json-simplify-1
1480×rational.json-simplify-53
1242×exponential.json-3
1242×rational.json-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
14613
29913
320113
436913
581913
6205613
7364013
8474813
9614513
10688413
11688413
12688413
Stop Event
node limit
Counts
1 → 15
Calls
Call 1
Inputs
(*.f64 (+.f64 d2 3) d1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 d2 3) d1) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (+.f64 d2 3) d1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)) (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (+.f64 d2 3) d1) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 3) d1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 3) (+.f64 d1 d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8)))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 16 (*.f64 (+.f64 d2 3) d1)) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 d1 4) (*.f64 (+.f64 d2 3) 8)) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))))) 256)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))))) (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8)))))) 512)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 d2 3) d1) 1)))))

simplify272.0ms (4.6%)

Algorithm
egg-herbie
Rules
2218×rational.json-simplify-2
1914×rational.json-simplify-35
1480×rational.json-simplify-53
1234×exponential.json-simplify-26
1224×rational.json-simplify-1
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
054629
1137437
2284437
3713437
42627437
54840437
65673437
75982437
85987437
95989437
106791437
117876437
127880437
Stop Event
node limit
Counts
35 → 21
Calls
Call 1
Inputs
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 (+.f64 d2 3) d1) 0)
(+.f64 0 (*.f64 (+.f64 d2 3) d1))
(+.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)) (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)))
(-.f64 (*.f64 (+.f64 d2 3) d1) 0)
(/.f64 (*.f64 (+.f64 d2 3) d1) 1)
(/.f64 (*.f64 (+.f64 d2 3) (+.f64 d1 d1)) 2)
(/.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 4)) 4)
(/.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 8)) 8)
(/.f64 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8)))) 128)
(/.f64 (*.f64 16 (*.f64 (+.f64 d2 3) d1)) 16)
(/.f64 (*.f64 (*.f64 d1 4) (*.f64 (+.f64 d2 3) 8)) 32)
(/.f64 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))))) 256)
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))))) (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8)))))) 512)
(pow.f64 (*.f64 (+.f64 d2 3) d1) 1)
Outputs
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(+.f64 (*.f64 (+.f64 d2 3) d1) 0)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 0 (*.f64 (+.f64 d2 3) d1))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)) (*.f64 (+.f64 d2 3) (*.f64 d1 1/2)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(-.f64 (*.f64 (+.f64 d2 3) d1) 0)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d2 3) d1) 1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d2 3) (+.f64 d1 d1)) 2)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 4)) 4)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (+.f64 d2 3) (*.f64 d1 8)) 8)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8)))) 128)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 16 (*.f64 (+.f64 d2 3) d1)) 16)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (*.f64 d1 4) (*.f64 (+.f64 d2 3) 8)) 32)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))) 64)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))))) 256)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (+.f64 (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8))))) (*.f64 2 (*.f64 2 (*.f64 8 (*.f64 (+.f64 d2 3) (*.f64 d1 8)))))) 512)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))
(pow.f64 (*.f64 (+.f64 d2 3) d1) 1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d2))
(*.f64 d1 (+.f64 3 d2))

eval25.0ms (0.4%)

Compiler

Compiled 1147 to 756 computations (34.1% saved)

prune16.0ms (0.3%)

Pruning

8 alts after pruning (3 fresh and 5 done)

PrunedKeptTotal
New1062108
Fresh011
Picked011
Done145
Total1078115
Error
0.1b
Counts
115 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
21.8b
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
22.6b
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
22.6b
(*.f64 (+.f64 d2 3) d1)
41.1b
(*.f64 d2 d1)
0.1b
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
21.9b
(*.f64 d1 (+.f64 3 d3))
39.6b
(*.f64 d1 d3)
44.1b
(*.f64 3 d1)
Compiler

Compiled 64 to 46 computations (28.1% saved)

localize3.0ms (0.1%)

Compiler

Compiled 8 to 6 computations (25% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
Compiler

Compiled 19 to 10 computations (47.4% saved)

series0.0ms (0%)

Counts
1 → 15
Calls

6 calls:

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

rewrite192.0ms (3.3%)

Algorithm
batch-egg-rewrite
Rules
2644×rational.json-simplify-2
1568×rational.json-simplify-1
1198×exponential.json-3
1198×rational.json-1
1198×rational.json-2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0819
15313
211413
324513
445713
5104913
6261713
7489913
8592413
9680913
10680913
11680913
Stop Event
node limit
Counts
1 → 50
Calls
Call 1
Inputs
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 3 d2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 3 d2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 3 d2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d2) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d2))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d2) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (+.f64 (*.f64 d2 1/2) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (*.f64 2 (+.f64 3 d2)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 3 d2) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 d1 (/.f64 (+.f64 3 d2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 (*.f64 2 (+.f64 3 d2)) (/.f64 d1 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (/.f64 (+.f64 3 d2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (*.f64 (+.f64 3 d2) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (*.f64 (*.f64 2 (+.f64 3 d2)) 1/8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 8 (*.f64 (+.f64 3 d2) (/.f64 d1 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 3 d2)) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8) 1/8)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 8) (*.f64 (+.f64 3 d2) 1/8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 1/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d2 d2) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (*.f64 d1 8)) (*.f64 (+.f64 3 d2) 1/16))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) 4) (*.f64 d1 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) 1/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (/.f64 (+.f64 3 d2) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/4) (*.f64 (+.f64 3 d2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/8 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 3 d2) 4) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 d2 d2) 6) (*.f64 d1 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 d2 1/2) 3/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) 1/4) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) (/.f64 d1 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) 1/8) (*.f64 d1 8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d2) 1/16) (*.f64 2 (*.f64 d1 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) 1/4) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) (/.f64 d1 8)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) 1/8) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 3 d2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d2))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8)) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8)))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 d2)) 1)))))

simplify243.0ms (4.1%)

Algorithm
egg-herbie
Rules
2874×rational.json-simplify-2
1850×rational.json-simplify-35
1430×rational.json-simplify-53
1196×rational.json-simplify-1
1186×rational.json-simplify-51
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
0111899
1248883
2565883
31412867
43490851
55093851
65939851
76074851
86182851
96286851
106386851
117301851
127986851
Stop Event
node limit
Counts
65 → 61
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 3 d1)
(*.f64 d2 d1)
(*.f64 d2 d1)
(-.f64 (*.f64 d1 (+.f64 3 d2)) 0)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 1 (*.f64 d1 (+.f64 3 d2)))
(*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d2) 1/2)))
(*.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d2))) 1/2)
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d2) 1/2))
(*.f64 (+.f64 d1 d1) (+.f64 (*.f64 d2 1/2) 3/2))
(*.f64 (+.f64 d1 d1) (*.f64 (*.f64 2 (+.f64 3 d2)) 1/4))
(*.f64 (+.f64 3 d2) d1)
(*.f64 4 (*.f64 d1 (/.f64 (+.f64 3 d2) 4)))
(*.f64 4 (*.f64 (*.f64 2 (+.f64 3 d2)) (/.f64 d1 8)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)) 1/4)
(*.f64 (*.f64 d1 4) (/.f64 (+.f64 3 d2) 4))
(*.f64 (*.f64 d1 4) (*.f64 (+.f64 3 d2) 1/4))
(*.f64 (*.f64 d1 4) (*.f64 (*.f64 2 (+.f64 3 d2)) 1/8))
(*.f64 8 (*.f64 (+.f64 3 d2) (/.f64 d1 8)))
(*.f64 (*.f64 2 (+.f64 3 d2)) (*.f64 d1 1/2))
(*.f64 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8) 1/8)
(*.f64 (*.f64 d1 8) (*.f64 (+.f64 3 d2) 1/8))
(*.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 d2))))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 1/2)) 2)
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 d2)))
(*.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d2 d2) 6))
(*.f64 (*.f64 2 (*.f64 d1 8)) (*.f64 (+.f64 3 d2) 1/16))
(*.f64 (*.f64 (+.f64 3 d2) 4) (*.f64 d1 1/4))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)))
(*.f64 (*.f64 (+.f64 3 d2) 1/2) (+.f64 d1 d1))
(*.f64 (*.f64 d1 (/.f64 (+.f64 3 d2) 4)) 4)
(*.f64 (*.f64 d1 1/4) (*.f64 (+.f64 3 d2) 4))
(*.f64 1/8 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))
(*.f64 (/.f64 (+.f64 3 d2) 4) (*.f64 d1 4))
(*.f64 (+.f64 (+.f64 d2 d2) 6) (*.f64 d1 1/2))
(*.f64 (+.f64 (*.f64 d2 1/2) 3/2) (+.f64 d1 d1))
(*.f64 (*.f64 (+.f64 3 d2) 1/4) (*.f64 d1 4))
(*.f64 (*.f64 (+.f64 3 d2) (/.f64 d1 8)) 8)
(*.f64 (*.f64 (+.f64 3 d2) 1/8) (*.f64 d1 8))
(*.f64 (*.f64 (+.f64 3 d2) 1/16) (*.f64 2 (*.f64 d1 8)))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) 1/4) (+.f64 d1 d1))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) (/.f64 d1 8)) 4)
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) 1/8) (*.f64 d1 4))
(/.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(/.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d2))) 2)
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)) 4)
(/.f64 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8) 8)
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8)) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8)))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))))) 128)
(pow.f64 (*.f64 d1 (+.f64 3 d2)) 1)
Outputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d2) 3)))
(*.f64 d1 (neg.f64 (-.f64 -3 d2)))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d2) 3)))
(*.f64 d1 (neg.f64 (-.f64 -3 d2)))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d2) 3)))
(*.f64 d1 (neg.f64 (-.f64 -3 d2)))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 d2) 3) d1))
(*.f64 (-.f64 (*.f64 d2 -1) 3) (*.f64 d1 -1))
(*.f64 (-.f64 (neg.f64 d2) 3) (neg.f64 d1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d2) 3)))
(*.f64 d1 (neg.f64 (-.f64 -3 d2)))
(*.f64 d1 (-.f64 d2 -3))
(*.f64 3 d1)
(*.f64 d1 3)
(*.f64 d2 d1)
(*.f64 d1 d2)
(*.f64 d2 d1)
(*.f64 d1 d2)
(-.f64 (*.f64 d1 (+.f64 3 d2)) 0)
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 1 (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 2 (*.f64 d1 (*.f64 (+.f64 3 d2) 1/2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d2))) 1/2)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d2) 1/2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d1 d1) (+.f64 (*.f64 d2 1/2) 3/2))
(*.f64 (+.f64 d1 d1) (*.f64 (*.f64 2 (+.f64 3 d2)) 1/4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 3 d2) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 4 (*.f64 d1 (/.f64 (+.f64 3 d2) 4)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 4 (*.f64 (*.f64 2 (+.f64 3 d2)) (/.f64 d1 8)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)) 1/4)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 4) (/.f64 (+.f64 3 d2) 4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 4) (*.f64 (+.f64 3 d2) 1/4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 4) (*.f64 (*.f64 2 (+.f64 3 d2)) 1/8))
(*.f64 d1 (+.f64 3 d2))
(*.f64 8 (*.f64 (+.f64 3 d2) (/.f64 d1 8)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 2 (+.f64 3 d2)) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8) 1/8)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 8) (*.f64 (+.f64 3 d2) 1/8))
(*.f64 d1 (+.f64 3 d2))
(*.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 d2))))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 1/2)) 2)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 1/2) (*.f64 2 (+.f64 3 d2)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 1/2) (+.f64 (+.f64 d2 d2) 6))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 2 (*.f64 d1 8)) (*.f64 (+.f64 3 d2) 1/16))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 3 d2) 4) (*.f64 d1 1/4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 3 d2) 1/2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 (/.f64 (+.f64 3 d2) 4)) 4)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 d1 1/4) (*.f64 (+.f64 3 d2) 4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 1/8 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (/.f64 (+.f64 3 d2) 4) (*.f64 d1 4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 (+.f64 d2 d2) 6) (*.f64 d1 1/2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 (*.f64 d2 1/2) 3/2) (+.f64 d1 d1))
(*.f64 (+.f64 d1 d1) (+.f64 (*.f64 d2 1/2) 3/2))
(*.f64 (*.f64 (+.f64 3 d2) 1/4) (*.f64 d1 4))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 3 d2) (/.f64 d1 8)) 8)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 3 d2) 1/8) (*.f64 d1 8))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (+.f64 3 d2) 1/16) (*.f64 2 (*.f64 d1 8)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) 1/4) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) (/.f64 d1 8)) 4)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d2)) 1/8) (*.f64 d1 4))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d2))) 2)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d2) 4)) 4)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8) 8)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8)) 16)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))) 32)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8)))) 64)
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d2)) 8))))) 128)
(*.f64 d1 (+.f64 3 d2))
(pow.f64 (*.f64 d1 (+.f64 3 d2)) 1)
(*.f64 d1 (+.f64 3 d2))

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
Compiler

Compiled 19 to 10 computations (47.4% saved)

series1.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite188.0ms (3.2%)

Algorithm
batch-egg-rewrite
Rules
2646×rational.json-simplify-2
1558×rational.json-simplify-1
1198×exponential.json-3
1198×rational.json-1
1198×rational.json-2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0819
15313
211413
324513
445713
5105113
6262513
7491013
8593513
9682013
10682013
11682013
Stop Event
node limit
Counts
1 → 50
Calls
Call 1
Inputs
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 3 d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 3 d3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 3 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 3 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 (+.f64 3 d3) (/.f64 d1 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d3) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (+.f64 (*.f64 d3 1/2) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d1 d1) (*.f64 (*.f64 2 (+.f64 3 d3)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d3))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 3 d3) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 d1 (/.f64 (+.f64 3 d3) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 4 (*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (/.f64 (+.f64 3 d3) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (*.f64 (+.f64 3 d3) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 4) (*.f64 (*.f64 2 (+.f64 3 d3)) 1/8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 8 (*.f64 (+.f64 3 d3) (/.f64 d1 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 8) (*.f64 (+.f64 3 d3) 1/8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8) 1/8)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 2) (*.f64 2 (+.f64 3 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 2) (+.f64 (+.f64 d3 d3) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) (/.f64 d1 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 2 (*.f64 d1 8)) (*.f64 (+.f64 3 d3) 1/16))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) 4) (*.f64 d1 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) 1/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (/.f64 (+.f64 3 d3) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 1/4) (*.f64 (+.f64 3 d3) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/8 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 3 d3) 4) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 d3 d3) 6) (/.f64 d1 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 d3 1/2) 3/2) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) 1/4) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) (/.f64 d1 8)) 8)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) 1/8) (*.f64 d1 8))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 3 d3) 1/16) (*.f64 2 (*.f64 d1 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) 1/4) (+.f64 d1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 8)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) 1/8) (*.f64 d1 4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 3 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 4)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8) 8)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8)) 16)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))) 32)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8)))) 64)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))))) 128)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 d3)) 1)))))

simplify423.0ms (7.2%)

Algorithm
egg-herbie
Rules
2428×rational.json-simplify-35
2192×rational.json-simplify-2
1508×rational.json-simplify-53
1202×exponential.json-simplify-26
1150×rational.json-simplify-1
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01101016
12421000
25451000
32059984
43428968
54715968
65611968
75810968
85937968
96713968
106987968
117107968
127356968
137681968
147681968
157681968
167800968
177919968
Stop Event
node limit
Counts
74 → 60
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(-.f64 (*.f64 d1 (+.f64 3 d3)) 0)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(*.f64 1 (*.f64 d1 (+.f64 3 d3)))
(*.f64 2 (*.f64 (+.f64 3 d3) (/.f64 d1 2)))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d3) 1/2))
(*.f64 (+.f64 d1 d1) (+.f64 (*.f64 d3 1/2) 3/2))
(*.f64 (+.f64 d1 d1) (*.f64 (*.f64 2 (+.f64 3 d3)) 1/4))
(*.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d3))) 1/2)
(*.f64 (+.f64 3 d3) d1)
(*.f64 4 (*.f64 d1 (/.f64 (+.f64 3 d3) 4)))
(*.f64 4 (*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 8)))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 1/4)
(*.f64 (*.f64 d1 4) (/.f64 (+.f64 3 d3) 4))
(*.f64 (*.f64 d1 4) (*.f64 (+.f64 3 d3) 1/4))
(*.f64 (*.f64 d1 4) (*.f64 (*.f64 2 (+.f64 3 d3)) 1/8))
(*.f64 8 (*.f64 (+.f64 3 d3) (/.f64 d1 8)))
(*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 2))
(*.f64 (*.f64 d1 8) (*.f64 (+.f64 3 d3) 1/8))
(*.f64 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8) 1/8)
(*.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 d3))))
(*.f64 (/.f64 d1 2) (*.f64 2 (+.f64 3 d3)))
(*.f64 (/.f64 d1 2) (+.f64 (+.f64 d3 d3) 6))
(*.f64 (*.f64 (+.f64 3 d3) (/.f64 d1 2)) 2)
(*.f64 (*.f64 2 (*.f64 d1 8)) (*.f64 (+.f64 3 d3) 1/16))
(*.f64 (*.f64 (+.f64 3 d3) 4) (*.f64 d1 1/4))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)))
(*.f64 (*.f64 (+.f64 3 d3) 1/2) (+.f64 d1 d1))
(*.f64 (*.f64 d1 (/.f64 (+.f64 3 d3) 4)) 4)
(*.f64 (*.f64 d1 1/4) (*.f64 (+.f64 3 d3) 4))
(*.f64 1/8 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))
(*.f64 (/.f64 (+.f64 3 d3) 4) (*.f64 d1 4))
(*.f64 (+.f64 (+.f64 d3 d3) 6) (/.f64 d1 2))
(*.f64 (+.f64 (*.f64 d3 1/2) 3/2) (+.f64 d1 d1))
(*.f64 (*.f64 (+.f64 3 d3) 1/4) (*.f64 d1 4))
(*.f64 (*.f64 (+.f64 3 d3) (/.f64 d1 8)) 8)
(*.f64 (*.f64 (+.f64 3 d3) 1/8) (*.f64 d1 8))
(*.f64 (*.f64 (+.f64 3 d3) 1/16) (*.f64 2 (*.f64 d1 8)))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) 1/4) (+.f64 d1 d1))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 8)) 4)
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) 1/8) (*.f64 d1 4))
(/.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(/.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d3))) 2)
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 4)
(/.f64 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8) 8)
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8)) 16)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))) 32)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8)))) 64)
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))))) 128)
(pow.f64 (*.f64 d1 (+.f64 3 d3)) 1)
Outputs
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 d1 (*.f64 (-.f64 (*.f64 d3 -1) 3) -1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d3) 3)))
(*.f64 (-.f64 (neg.f64 d3) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d3) (neg.f64 d1))
(*.f64 d1 (-.f64 d3 -3))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 d1 (*.f64 (-.f64 (*.f64 d3 -1) 3) -1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d3) 3)))
(*.f64 (-.f64 (neg.f64 d3) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d3) (neg.f64 d1))
(*.f64 d1 (-.f64 d3 -3))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 d1 (*.f64 (-.f64 (*.f64 d3 -1) 3) -1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d3) 3)))
(*.f64 (-.f64 (neg.f64 d3) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d3) (neg.f64 d1))
(*.f64 d1 (-.f64 d3 -3))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 d3) 3)))
(*.f64 d1 (*.f64 (-.f64 (*.f64 d3 -1) 3) -1))
(*.f64 d1 (neg.f64 (-.f64 (neg.f64 d3) 3)))
(*.f64 (-.f64 (neg.f64 d3) 3) (neg.f64 d1))
(*.f64 (-.f64 -3 d3) (neg.f64 d1))
(*.f64 d1 (-.f64 d3 -3))
(*.f64 3 d1)
(*.f64 d1 3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 3 d3))
(-.f64 (*.f64 d1 (+.f64 3 d3)) 0)
(*.f64 d1 (+.f64 3 d3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(*.f64 d1 (+.f64 3 d3))
(*.f64 1 (*.f64 d1 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 2 (*.f64 (+.f64 3 d3) (/.f64 d1 2)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 d1 d1) (*.f64 (+.f64 3 d3) 1/2))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 d1 d1) (+.f64 (*.f64 d3 1/2) 3/2))
(*.f64 (+.f64 d1 d1) (*.f64 (*.f64 2 (+.f64 3 d3)) 1/4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d3))) 1/2)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 3 d3) d1)
(*.f64 d1 (+.f64 3 d3))
(*.f64 4 (*.f64 d1 (/.f64 (+.f64 3 d3) 4)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 4 (*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 8)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 1/4)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 4) (/.f64 (+.f64 3 d3) 4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 4) (*.f64 (+.f64 3 d3) 1/4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 4) (*.f64 (*.f64 2 (+.f64 3 d3)) 1/8))
(*.f64 d1 (+.f64 3 d3))
(*.f64 8 (*.f64 (+.f64 3 d3) (/.f64 d1 8)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 2))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 8) (*.f64 (+.f64 3 d3) 1/8))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8) 1/8)
(*.f64 d1 (+.f64 3 d3))
(*.f64 1/2 (*.f64 d1 (*.f64 2 (+.f64 3 d3))))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (/.f64 d1 2) (*.f64 2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (/.f64 d1 2) (+.f64 (+.f64 d3 d3) 6))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (+.f64 3 d3) (/.f64 d1 2)) 2)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 2 (*.f64 d1 8)) (*.f64 (+.f64 3 d3) 1/16))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (+.f64 3 d3) 4) (*.f64 d1 1/4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 1/4 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (+.f64 3 d3) 1/2) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 (/.f64 (+.f64 3 d3) 4)) 4)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 d1 1/4) (*.f64 (+.f64 3 d3) 4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 1/8 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (/.f64 (+.f64 3 d3) 4) (*.f64 d1 4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 (+.f64 d3 d3) 6) (/.f64 d1 2))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 (*.f64 d3 1/2) 3/2) (+.f64 d1 d1))
(*.f64 (+.f64 d1 d1) (+.f64 (*.f64 d3 1/2) 3/2))
(*.f64 (*.f64 (+.f64 3 d3) 1/4) (*.f64 d1 4))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (+.f64 3 d3) (/.f64 d1 8)) 8)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (+.f64 3 d3) 1/8) (*.f64 d1 8))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (+.f64 3 d3) 1/16) (*.f64 2 (*.f64 d1 8)))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) 1/4) (+.f64 d1 d1))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) (/.f64 d1 8)) 4)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (*.f64 (*.f64 2 (+.f64 3 d3)) 1/8) (*.f64 d1 4))
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (*.f64 2 (+.f64 3 d3))) 2)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 d1 (*.f64 (+.f64 3 d3) 4)) 4)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8) 8)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8)) 16)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))) 32)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8)))) 64)
(*.f64 d1 (+.f64 3 d3))
(/.f64 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 2 (*.f64 (*.f64 d1 (+.f64 3 d3)) 8))))) 128)
(*.f64 d1 (+.f64 3 d3))
(pow.f64 (*.f64 d1 (+.f64 3 d3)) 1)
(*.f64 d1 (+.f64 3 d3))

eval29.0ms (0.5%)

Compiler

Compiled 1058 to 785 computations (25.8% saved)

prune21.0ms (0.4%)

Pruning

8 alts after pruning (0 fresh and 8 done)

PrunedKeptTotal
New1210121
Fresh000
Picked011
Done077
Total1218129
Error
0.1b
Counts
129 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
21.8b
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
22.6b
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
22.6b
(*.f64 (+.f64 d2 3) d1)
41.1b
(*.f64 d2 d1)
0.1b
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
21.9b
(*.f64 d1 (+.f64 3 d3))
39.6b
(*.f64 d1 d3)
44.1b
(*.f64 3 d1)
Compiler

Compiled 64 to 46 computations (28.1% saved)

regimes31.0ms (0.5%)

Counts
11 → 1
Calls
Call 1
Inputs
(*.f64 3 d1)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Outputs
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
Calls

4 calls:

8.0ms
d3
7.0ms
d1
7.0ms
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
7.0ms
d2
Results
ErrorSegmentsBranch
0.1b1d1
0.1b1d2
0.1b1d3
0.1b1(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Compiler

Compiled 98 to 54 computations (44.9% saved)

regimes26.0ms (0.4%)

Counts
9 → 1
Calls
Call 1
Inputs
(*.f64 3 d1)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 d1 3) (*.f64 d1 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
Outputs
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
Calls

3 calls:

12.0ms
d3
6.0ms
d1
6.0ms
d2
Results
ErrorSegmentsBranch
0.1b1d1
0.1b1d2
0.1b1d3
Compiler

Compiled 64 to 36 computations (43.8% saved)

regimes35.0ms (0.6%)

Counts
5 → 2
Calls
Call 1
Inputs
(*.f64 3 d1)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 3 d3))
(*.f64 (+.f64 d2 3) d1)
Outputs
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d3))
Calls

3 calls:

17.0ms
d1
9.0ms
d2
8.0ms
d3
Results
ErrorSegmentsBranch
16.6b4d1
3.1b2d2
3.3b2d3
Compiler

Compiled 34 to 22 computations (35.3% saved)

bsearch0.0ms (0%)

Algorithm
binary-search
Steps
TimeLeftRight
0.0ms
-1407483625.1876903
-1369535676.660079
Compiler

Compiled 20 to 14 computations (30% saved)

regimes60.0ms (1%)

Counts
4 → 2
Calls
Call 1
Inputs
(*.f64 3 d1)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 3 d3))
Outputs
(*.f64 d2 d1)
(*.f64 d1 (+.f64 3 d3))
Calls

3 calls:

26.0ms
d3
23.0ms
d1
10.0ms
d2
Results
ErrorSegmentsBranch
18.0b7d1
3.2b2d2
14.6b6d3
Compiler

Compiled 29 to 19 computations (34.5% saved)

bsearch0.0ms (0%)

Algorithm
binary-search
Steps
TimeLeftRight
0.0ms
-1407483625.1876903
-1369535676.660079
Compiler

Compiled 20 to 14 computations (30% saved)

regimes62.0ms (1%)

Counts
3 → 5
Calls
Call 1
Inputs
(*.f64 3 d1)
(*.f64 d1 d3)
(*.f64 d2 d1)
Outputs
(*.f64 d2 d1)
(*.f64 3 d1)
(*.f64 d1 d3)
(*.f64 3 d1)
(*.f64 d1 d3)
Calls

3 calls:

26.0ms
d3
20.0ms
d2
15.0ms
d1
Results
ErrorSegmentsBranch
32.6b4d1
14.0b5d2
14.1b8d3
Compiler

Compiled 24 to 16 computations (33.3% saved)

bsearch46.0ms (0.8%)

Algorithm
binary-search
Steps
TimeLeftRight
21.0ms
1.2755314948205988e-275
6.649743671087207e-250
12.0ms
-1.0318594272947134e-229
-1.4009243911040642e-231
13.0ms
-7.727419866626197e-194
-1.609994367741899e-194
0.0ms
-1407483625.1876903
-1369535676.660079
Results
35.0ms352×body256valid
5.0ms22×body1024valid
2.0ms10×body512valid
Compiler

Compiled 356 to 278 computations (21.9% saved)

regimes42.0ms (0.7%)

Accuracy

Total -38.4b remaining (-168.2%)

Threshold costs -38.4b (-168.2%)

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

3 calls:

21.0ms
d2
14.0ms
d1
6.0ms
d3
Results
ErrorSegmentsBranch
34.5b5d1
31.5b5d2
22.8b2d3
Compiler

Compiled 21 to 15 computations (28.6% saved)

bsearch10.0ms (0.2%)

Algorithm
binary-search
Steps
TimeLeftRight
10.0ms
5.3894320619317435
48.54581933112946
Results
9.0ms96×body256valid
Compiler

Compiled 104 to 80 computations (23.1% saved)

simplify6.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
038209
Stop Event
done
saturated
Calls
Call 1
Inputs
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(if (<=.f64 d2 -1400000000) (*.f64 (+.f64 d2 3) d1) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d2 -1400000000) (*.f64 d2 d1) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d2 -1400000000) (*.f64 d2 d1) (if (<=.f64 d2 -3369774561929427/164379246923386672101280933840004020798448118838224183109321278220897879821783775691052079258674639100843217776755569303531857257818243870722744211582871276561100739722763893693489492433885084914727914116743168) (*.f64 3 d1) (if (<=.f64 d2 -6773422405034819/109248748468303532426524291739177087748419720352823839299932287987941986104404083859807145179079545499532163655162810211465442126301091677476673225561388319475223061782757614525859074636379160981159362824370366086868021215846014341794428966928384) (*.f64 d1 d3) (if (<=.f64 d2 4057301999121909/8452712498170643941637436558664265704301557216577944354047371344426782440907597751590676094202515006314790319892114058862117560952042968596008623655407033230534186943984081346699704282822823056848387726531379014466368452684024987821414350380272583623832617294363807973376) (*.f64 3 d1) (*.f64 d1 d3)))))
(if (<=.f64 d3 11/2) (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 3 d1)
Outputs
(+.f64 (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d3 (+.f64 3 d2)))
(if (<=.f64 d2 -1400000000) (*.f64 (+.f64 d2 3) d1) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d2 -1400000000) (*.f64 d2 d1) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d2 -1400000000) (*.f64 d2 d1) (if (<=.f64 d2 -3369774561929427/164379246923386672101280933840004020798448118838224183109321278220897879821783775691052079258674639100843217776755569303531857257818243870722744211582871276561100739722763893693489492433885084914727914116743168) (*.f64 3 d1) (if (<=.f64 d2 -6773422405034819/109248748468303532426524291739177087748419720352823839299932287987941986104404083859807145179079545499532163655162810211465442126301091677476673225561388319475223061782757614525859074636379160981159362824370366086868021215846014341794428966928384) (*.f64 d1 d3) (if (<=.f64 d2 4057301999121909/8452712498170643941637436558664265704301557216577944354047371344426782440907597751590676094202515006314790319892114058862117560952042968596008623655407033230534186943984081346699704282822823056848387726531379014466368452684024987821414350380272583623832617294363807973376) (*.f64 3 d1) (*.f64 d1 d3)))))
(if (<=.f64 d3 11/2) (*.f64 3 d1) (*.f64 d1 d3))
(*.f64 3 d1)
Compiler

Compiled 107 to 72 computations (32.7% saved)

soundness10.0ms (0.2%)

Algorithm
egg-herbie
Rules
24×rational.json-simplify-1
14×rational.json-simplify-2
10×rational.json-simplify-51
rational.json-simplify-41
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01131
11625
22419
33519
44319
54519
Stop Event
saturated
Compiler

Compiled 34 to 18 computations (47.1% saved)

end59.0ms (1%)

Compiler

Compiled 113 to 67 computations (40.7% saved)

Profiling

Loading profile data...