Details

Time bar (total: 3.5s)

analyze2.0ms (0.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%0%100%0
0%0%100%1
Compiler

Compiled 17 to 11 computations (35.3% saved)

sample927.0ms (26.7%)

Results
752.0ms8256×body128valid
Compiler

Compiled 44 to 28 computations (36.4% saved)

simplify74.0ms (2.1%)

Algorithm
egg-herbie
Rules
649×fma-neg_binary64
504×div-sub_binary64
481×fma-def_binary64
326×times-frac_binary64
174×associate-/l/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11310
22110
33710
46410
511310
621610
741510
875410
9118310
10153710
11161210
12165710
13168410
14169410
15170210
16170210
17160010
Stop Event
saturated
Counts
1 → 1

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
62.0b
Counts
2 → 1
Alt Table
StatusErrorProgram
62.0b
(/.f64 (-.f64 x lo) (-.f64 hi lo))
Compiler

Compiled 30 to 18 computations (40% saved)

localize4.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
62.0b
(/.f64 (-.f64 x lo) (-.f64 hi lo))

series16.0ms (0.5%)

Counts
1 → 36
Calls

1 calls:

16.0ms
(/.f64 (-.f64 x lo) (-.f64 hi lo))

rewrite91.0ms (2.6%)

Algorithm
batch-egg-rewrite
Rules
952×prod-diff_binary64
728×fma-udef_binary64
226×fma-neg_binary64
166×expm1-udef_binary64
166×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
116710
2253010
3473010
4451710
5510810
Stop Event
node limit
Counts
1 → 68
Calls

1 calls:

90.0ms
(/.f64 (-.f64 x lo) (-.f64 hi lo))

simplify62.0ms (1.8%)

Algorithm
egg-herbie
Rules
721×sub-neg_binary64
402×associate--l+_binary64
332×associate--r+_binary64
330×fma-def_binary64
301×associate-+l+_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
0781093
12341075
2842919
34059913
44904898
55053898
Stop Event
node limit
Counts
104 → 99

prune47.0ms (1.4%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New94599
Fresh000
Picked101
Done000
Total955100
Error
51.5b
Counts
100 → 5
Alt Table
StatusErrorProgram
58.0b
(-.f64 (*.f64 (/.f64 lo hi) (/.f64 (-.f64 x lo) hi)) (/.f64 (-.f64 lo x) hi))
52.0b
(/.f64 (-.f64 x lo) hi)
51.9b
(+.f64 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)) (-.f64 (-.f64 1 (/.f64 x lo)) (*.f64 (/.f64 x lo) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)))))
57.5b
(+.f64 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)) (+.f64 (pow.f64 (/.f64 hi lo) 3) (-.f64 (-.f64 1 (/.f64 x lo)) (*.f64 (/.f64 x lo) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))))))
51.9b
(-.f64 (+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
Compiler

Compiled 2482 to 874 computations (64.8% saved)

localize9.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)))
0.2b
(*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo))
0.4b
(*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))
1.7b
(+.f64 1 (/.f64 hi lo))

series46.0ms (1.3%)

Counts
4 → 90
Calls

4 calls:

18.0ms
(*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo))
13.0ms
(*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))
11.0ms
(+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)))
4.0ms
(+.f64 1 (/.f64 hi lo))

rewrite64.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
732×prod-diff_binary64
219×log1p-udef_binary64
151×egg-rr
121×add-sqr-sqrt_binary64
115×log1p-expm1-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01149
124247
2337547
3529347
Stop Event
node limit
Counts
4 → 151
Calls

4 calls:

61.0ms
(+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)))
61.0ms
(*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo))
61.0ms
(*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))
61.0ms
(+.f64 1 (/.f64 hi lo))

simplify78.0ms (2.2%)

Algorithm
egg-herbie
Rules
894×fma-def_binary64
574×associate-/l*_binary64
362×associate-/r*_binary64
346×unswap-sqr_binary64
331×associate-/l/_binary64
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
0191197
1391197
2751008
3166924
4659924
53131924
64154882
74684882
85079882
Stop Event
node limit
Counts
241 → 164

prune146.0ms (4.2%)

Pruning

17 alts after pruning (17 fresh and 0 done)

PrunedKeptTotal
New18514199
Fresh134
Picked101
Done000
Total18717204
Error
51.3b
Counts
204 → 17
Alt Table
StatusErrorProgram
52.0b
(/.f64 (-.f64 x lo) hi)
51.9b
(-.f64 (cbrt.f64 (pow.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1) 3)) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
57.5b
(+.f64 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo)) (+.f64 (pow.f64 (/.f64 hi lo) 3) (-.f64 (-.f64 1 (/.f64 x lo)) (*.f64 (/.f64 x lo) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))))))
51.9b
(-.f64 (+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))) (/.f64 x lo))
51.9b
(-.f64 (pow.f64 (sqrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)) 2) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (fma.f64 (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (cbrt.f64 (/.f64 hi lo)) 1) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (pow.f64 (cbrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)) 3) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (fma.f64 hi (/.f64 1 lo) 1) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))) (*.f64 (/.f64 hi lo) (/.f64 x lo)))
51.9b
(-.f64 (/.f64 (+.f64 1 (pow.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))) 3)) (+.f64 (pow.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))) 2) (-.f64 1 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)))))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (*.f64 (cbrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)) (pow.f64 (cbrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)) 2)) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
58.0b
(-.f64 (*.f64 (/.f64 lo hi) (/.f64 (-.f64 x lo) hi)) (/.f64 (-.f64 lo x) hi))
51.9b
(-.f64 (log.f64 (+.f64 1 (expm1.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (log.f64 (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 hi lo))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (/.f64 1 (/.f64 (-.f64 1 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)))) (-.f64 1 (pow.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))) 2)))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (/.f64 1 (/.f64 (+.f64 1 (-.f64 (pow.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))) 2) (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))))) (+.f64 1 (pow.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))) 3)))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
Compiler

Compiled 6417 to 3197 computations (50.2% saved)

localize11.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo)))
0.4b
(*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo))
0.5b
(pow.f64 (+.f64 1 (/.f64 hi lo)) 2)
1.7b
(+.f64 1 (/.f64 hi lo))

series29.0ms (0.8%)

Counts
3 → 72
Calls

3 calls:

13.0ms
(*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo))
10.0ms
(+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo)))
6.0ms
(pow.f64 (+.f64 1 (/.f64 hi lo)) 2)

rewrite66.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
714×prod-diff_binary64
474×fma-def_binary64
185×expm1-udef_binary64
185×log1p-udef_binary64
183×fma-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01139
122237
2277137
3513337
Stop Event
node limit
Counts
3 → 181
Calls

3 calls:

62.0ms
(+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo)))
62.0ms
(*.f64 (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)) (/.f64 hi lo))
62.0ms
(pow.f64 (+.f64 1 (/.f64 hi lo)) 2)

simplify90.0ms (2.6%)

Algorithm
egg-herbie
Rules
661×times-frac_binary64
650×unswap-sqr_binary64
357×distribute-rgt-out_binary64
329×associate-/l*_binary64
282×distribute-lft-in_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0161014
1371008
263849
3132801
4434801
52504801
64487801
74807801
84978801
94959801
Stop Event
node limit
Counts
253 → 195

prune180.0ms (5.2%)

Pruning

27 alts after pruning (27 fresh and 0 done)

PrunedKeptTotal
New24322265
Fresh11516
Picked101
Done000
Total25527282
Error
50.6b
Counts
282 → 27
Alt Table
StatusErrorProgram
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (fma.f64 hi (/.f64 1 lo) 1) 2)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (/.f64 (+.f64 1 (/.f64 hi lo)) (pow.f64 (cbrt.f64 lo) 2)) (/.f64 hi (cbrt.f64 lo)) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (*.f64 (cbrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)) (pow.f64 (cbrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)) 1)) 2)) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (cbrt.f64 (/.f64 hi lo)) 1) 2)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
52.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (sqrt.f64 (cbrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 4))) (sqrt.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2)) (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
58.0b
(-.f64 (*.f64 (/.f64 lo hi) (/.f64 (-.f64 x lo) hi)) (/.f64 (-.f64 lo x) hi))
51.9b
(-.f64 (+.f64 1 (fma.f64 (/.f64 (pow.f64 (cbrt.f64 hi) 2) (pow.f64 (cbrt.f64 lo) 2)) (cbrt.f64 (/.f64 hi lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (-.f64 (exp.f64 (log1p.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2))) 1)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
52.0b
(/.f64 (-.f64 x lo) hi)
51.9b
(-.f64 (+.f64 1 (fma.f64 (/.f64 (pow.f64 (cbrt.f64 hi) 2) 1) (/.f64 (cbrt.f64 hi) lo) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (cbrt.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)))) (pow.f64 (cbrt.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)))) 2) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (/.f64 1 (pow.f64 (cbrt.f64 lo) 2)) (/.f64 hi (cbrt.f64 lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2) (*.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) (/.f64 hi lo)) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))) (/.f64 x lo))
51.9b
(-.f64 (+.f64 1 (fma.f64 (*.f64 (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2)) (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2) (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 2 (/.f64 hi lo)) 1)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))) (*.f64 (/.f64 hi lo) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (cbrt.f64 (/.f64 hi lo)) (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (log.f64 (+.f64 1 (expm1.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) 1) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (/.f64 (sqrt.f64 hi) (pow.f64 (cbrt.f64 lo) 2)) (/.f64 (sqrt.f64 hi) (cbrt.f64 lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (sqrt.f64 hi) (*.f64 (sqrt.f64 hi) (/.f64 1 lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (pow.f64 (cbrt.f64 hi) 2) (*.f64 (cbrt.f64 hi) (/.f64 1 lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 hi (*.f64 (/.f64 1 lo) (/.f64 hi lo)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
57.2b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (pow.f64 (/.f64 hi lo) 2)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
Compiler

Compiled 9695 to 4941 computations (49% saved)

localize14.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo)))
0.4b
(*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))
1.7b
(+.f64 1 (/.f64 hi lo))
6.0b
(fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))

series63.0ms (1.8%)

Counts
3 → 72
Calls

3 calls:

31.0ms
(fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))
20.0ms
(*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))
12.0ms
(+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo)))

rewrite87.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
650×fma-def_binary64
274×fma-neg_binary64
211×expm1-udef_binary64
211×log1p-udef_binary64
165×egg-rr
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01279
126737
2331537
3498437
4493437
Stop Event
node limit
Counts
3 → 165
Calls

3 calls:

84.0ms
(+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo)))
84.0ms
(*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))
84.0ms
(fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))

simplify72.0ms (2.1%)

Algorithm
egg-herbie
Rules
753×associate-/l*_binary64
730×fma-neg_binary64
484×associate-/r*_binary64
449×associate-*l/_binary64
387×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0201026
1521020
2107853
3256805
41011805
54461805
64828805
75092805
Stop Event
node limit
Counts
237 → 185

prune215.0ms (6.2%)

Pruning

29 alts after pruning (29 fresh and 0 done)

PrunedKeptTotal
New27317290
Fresh141226
Picked101
Done000
Total28829317
Error
50.6b
Counts
317 → 29
Alt Table
StatusErrorProgram
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 1 (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (*.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2) (cbrt.f64 (+.f64 1 (/.f64 hi lo)))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (/.f64 (sqrt.f64 hi) (pow.f64 (cbrt.f64 lo) 2)) (/.f64 (sqrt.f64 hi) (cbrt.f64 lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
52.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (sqrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 2)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
52.0b
(/.f64 (-.f64 x lo) hi)
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (cbrt.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)))) (pow.f64 (cbrt.f64 (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo)))) 2) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2) (*.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) (/.f64 hi lo)) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (log.f64 (+.f64 1 (expm1.f64 (+.f64 1 (/.f64 hi lo)))))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (*.f64 (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2)) (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2) (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (/.f64 hi lo) (+.f64 2 (/.f64 hi lo)) 1)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (*.f64 (cbrt.f64 (fma.f64 hi (/.f64 (+.f64 1 (/.f64 hi lo)) lo) 1)) (pow.f64 (cbrt.f64 (fma.f64 hi (/.f64 (+.f64 1 (/.f64 hi lo)) lo) 1)) 2)) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 hi lo))) (*.f64 (/.f64 hi lo) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (fma.f64 hi (/.f64 1 lo) 1)) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (-.f64 (exp.f64 (log1p.f64 (+.f64 1 (/.f64 hi lo)))) 1)) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (fma.f64 hi (/.f64 1 lo) 1))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (+.f64 (fma.f64 hi (/.f64 (+.f64 1 (/.f64 hi lo)) lo) (/.f64 hi lo)) 1)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 (pow.f64 (cbrt.f64 hi) 2) (*.f64 (cbrt.f64 hi) (/.f64 1 lo)) (pow.f64 (/.f64 hi lo) 2))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (-.f64 (exp.f64 (log1p.f64 (+.f64 1 (/.f64 hi lo)))) 1))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.9b
(-.f64 (+.f64 1 (fma.f64 hi (*.f64 (/.f64 1 lo) (/.f64 hi lo)) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (-.f64 (/.f64 1 (-.f64 1 (/.f64 hi lo))) (/.f64 (pow.f64 (/.f64 hi lo) 2) (-.f64 1 (/.f64 hi lo))))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (fma.f64 (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (cbrt.f64 (/.f64 hi lo)) 1)) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (fma.f64 (pow.f64 (cbrt.f64 (/.f64 hi lo)) 2) (cbrt.f64 (/.f64 hi lo)) 1))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
57.2b
(-.f64 (+.f64 1 (neg.f64 (*.f64 (/.f64 hi lo) (/.f64 hi lo)))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
52.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 (sqrt.f64 (cbrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 4))) (sqrt.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2)) (*.f64 (/.f64 hi lo) (+.f64 1 (/.f64 hi lo))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
58.0b
(-.f64 (*.f64 (/.f64 lo hi) (/.f64 (-.f64 x lo) hi)) (/.f64 (-.f64 lo x) hi))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (cbrt.f64 (pow.f64 (+.f64 1 (/.f64 hi lo)) 3)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (+.f64 1 (/.f64 hi lo))) (-.f64 (/.f64 1 (-.f64 1 (/.f64 hi lo))) (/.f64 (pow.f64 (/.f64 hi lo) 2) (-.f64 1 (/.f64 hi lo)))))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
51.7b
(-.f64 (+.f64 1 (*.f64 (sqrt.f64 (fma.f64 hi (*.f64 (/.f64 1 lo) (*.f64 (pow.f64 (cbrt.f64 (+.f64 1 (/.f64 hi lo))) 2) (cbrt.f64 (+.f64 1 (/.f64 hi lo))))) (+.f64 1 (/.f64 hi lo)))) (/.f64 hi lo))) (*.f64 (+.f64 1 (/.f64 hi lo)) (/.f64 x lo)))
Compiler

Compiled 10424 to 5256 computations (49.6% saved)

regimes552.0ms (15.9%)

Accuracy

Total 0.8b remaining (1.6%)

Threshold costs 0.8b (1.6%)

Counts
130 → 1
Compiler

Compiled 16834 to 10108 computations (40% saved)

simplify4.0ms (0.1%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
*-commutative_binary64
sub-neg_binary64
neg-sub0_binary64
neg-mul-1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02060
13260
24560
35860
46860
57460
67660
77460
Stop Event
saturated

end516.0ms (14.9%)

Compiler

Compiled 1154 to 679 computations (41.2% saved)

Profiling

Loading profile data...