Details

Time bar (total: 11.9s)

analyze2.3s (19.3%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.6%0.4%0
0%99.6%0.4%1
0%99.6%0.4%2
0%99.6%0.4%3
0%99.6%0.4%4
0%99.6%0.4%5
0%99.6%0.4%6
0%99.6%0.4%7
0%99.6%0.4%8
0%99.6%0.4%9
0%99.6%0.4%10
0%99.6%0.4%11
0%99.6%0.4%12
0%99.6%0.4%13
0%99.6%0.4%14
Compiler

Compiled 28 to 19 computations (32.1% saved)

sample2.7s (22.7%)

Results
1.4s8256×body128valid
1.3s7314×body128invalid
Compiler

Compiled 56 to 38 computations (32.1% saved)

preprocess46.0ms (0.4%)

Algorithm
egg-herbie
Rules
647×fma-def_binary64
618×distribute-lft-in_binary64
618×distribute-rgt-in_binary64
548×cancel-sign-sub-inv_binary64
330×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0188754
1558696
21885696
088
188
Stop Event
unsound
node limit
Symmetry

(sort x y)

(sort z t)

Compiler

Compiled 27 to 18 computations (33.3% saved)

simplify26.0ms (0.2%)

Algorithm
egg-herbie
Rules
583×fma-def_binary64
441×fma-neg_binary64
435×distribute-rgt-in_binary64
372×distribute-lft-in_binary64
298×associate-*l*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01926
13724
210424
337124
4136824
5359524
Stop Event
node limit
Counts
1 → 2

prune5.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.6b
Counts
3 → 2
Alt Table
StatusErrorProgram
4.8b
(*.f64 2 (-.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 (*.f64 (+.f64 a (*.f64 b c)) c) i)))
1.5b
(*.f64 2 (fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))))
Compiler

Compiled 148 to 93 computations (37.2% saved)

localize13.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y)))
1.8b
(fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))

series87.0ms (0.7%)

Counts
2 → 168
Calls

42 calls:

3.0ms
(fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))
x
0
3.0ms
(fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y)))
t
0
3.0ms
(fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y)))
x
inf
3.0ms
(fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))
b
-inf
2.0ms
(fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y)))
c
-inf

rewrite58.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
334×prod-diff_binary64
263×expm1-udef_binary64
263×log1p-udef_binary64
156×add-sqr-sqrt_binary64
142×log1p-expm1-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01538
130034
2373134
Stop Event
node limit
Counts
2 → 47

simplify109.0ms (0.9%)

Algorithm
egg-herbie
Rules
924×fma-neg_binary64
631×cancel-sign-sub-inv_binary64
426×fma-def_binary64
246×distribute-rgt-neg-in_binary64
241×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0493618
11583216
23553082
38582814
424952814
549292814
Stop Event
node limit
Counts
215 → 80

prune73.0ms (0.6%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New75580
Fresh101
Picked011
Done000
Total76682
Error
0.0b
Counts
82 → 6
Alt Table
StatusErrorProgram
29.2b
(*.f64 2 (fma.f64 z t (*.f64 -1 (*.f64 (+.f64 (*.f64 (pow.f64 c 2) b) (*.f64 c a)) i))))
1.5b
(*.f64 2 (fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))))
28.3b
(*.f64 2 (fma.f64 z t (*.f64 c (*.f64 (neg.f64 i) (fma.f64 c b a)))))
4.8b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a))))))
16.7b
(*.f64 2 (-.f64 (fma.f64 y x (*.f64 t z)) (*.f64 c (*.f64 c (*.f64 i b)))))
49.4b
(*.f64 2 (neg.f64 (+.f64 (*.f64 c (*.f64 a i)) (*.f64 (pow.f64 c 2) (*.f64 i b)))))
Compiler

Compiled 1878 to 656 computations (65.1% saved)

localize13.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a)))))
0.0b
(-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a))))
0.1b
(*.f64 c (fma.f64 c b a))
7.5b
(*.f64 i (*.f64 c (fma.f64 c b a)))

series122.0ms (1%)

Counts
4 → 252
Calls

63 calls:

6.0ms
(-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a))))
i
inf
5.0ms
(fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a)))))
y
0
4.0ms
(fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a)))))
z
-inf
4.0ms
(*.f64 i (*.f64 c (fma.f64 c b a)))
b
-inf
2.0ms
(fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a)))))
b
-inf

rewrite76.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
298×expm1-udef_binary64
298×log1p-udef_binary64
165×add-sqr-sqrt_binary64
153×log1p-expm1-u_binary64
153×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01557
131957
2420857
Stop Event
node limit
Counts
4 → 109

simplify114.0ms (1%)

Algorithm
egg-herbie
Rules
928×fma-neg_binary64
705×cancel-sign-sub-inv_binary64
487×fma-def_binary64
265×associate-*l*_binary64
258×distribute-rgt-neg-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0534590
11633669
23823588
39473588
427103588
Stop Event
node limit
Counts
361 → 159

prune168.0ms (1.4%)

Pruning

8 alts after pruning (6 fresh and 2 done)

PrunedKeptTotal
New1554159
Fresh224
Picked011
Done011
Total1578165
Error
0.0b
Counts
165 → 8
Alt Table
StatusErrorProgram
5.8b
(*.f64 2 (fma.f64 y x (+.f64 (-.f64 (*.f64 t z) (*.f64 (fma.f64 c b a) (*.f64 i c))) (+.f64 (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c))) (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))))))
11.9b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 c (*.f64 i a)))))
20.9b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (cbrt.f64 (pow.f64 (*.f64 c (fma.f64 c b a)) 3))))))
4.8b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a))))))
16.7b
(*.f64 2 (-.f64 (fma.f64 y x (*.f64 t z)) (*.f64 c (*.f64 c (*.f64 i b)))))
49.4b
(*.f64 2 (neg.f64 (+.f64 (*.f64 c (*.f64 a i)) (*.f64 (pow.f64 c 2) (*.f64 i b)))))
24.4b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (pow.f64 (sqrt.f64 (*.f64 (fma.f64 c b a) (*.f64 i c))) 2))))
1.5b
(*.f64 2 (fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))))
Compiler

Compiled 4285 to 1285 computations (70% saved)

localize20.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 t z) (*.f64 (fma.f64 c b a) (*.f64 i c)))
0.1b
(*.f64 (fma.f64 c b a) (neg.f64 c))
4.5b
(*.f64 (fma.f64 c b a) (*.f64 i c))
47.6b
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))

series123.0ms (1%)

Counts
4 → 204
Calls

51 calls:

7.0ms
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))
a
inf
6.0ms
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))
b
0
6.0ms
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))
a
-inf
5.0ms
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))
b
inf
5.0ms
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))
i
-inf

rewrite67.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
272×log1p-udef_binary64
168×add-sqr-sqrt_binary64
164×associate-*r*_binary64
156×log1p-expm1-u_binary64
156×expm1-log1p-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01562
132656
2455556
Stop Event
node limit
Counts
4 → 108

simplify92.0ms (0.8%)

Algorithm
egg-herbie
Rules
929×fma-neg_binary64
313×fma-def_binary64
292×associate-*l*_binary64
253×unsub-neg_binary64
242×distribute-rgt-neg-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0532628
11732052
24091971
39151971
426161971
547501971
Stop Event
node limit
Counts
312 → 147

prune332.0ms (2.8%)

Pruning

9 alts after pruning (6 fresh and 3 done)

PrunedKeptTotal
New2571258
Fresh055
Picked011
Done022
Total2579266
Error
0b
Counts
266 → 9
Alt Table
StatusErrorProgram
5.8b
(*.f64 2 (fma.f64 y x (+.f64 (-.f64 (*.f64 t z) (*.f64 (fma.f64 c b a) (*.f64 i c))) (+.f64 (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c))) (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))))))
11.9b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 c (*.f64 i a)))))
9.3b
(*.f64 2 (fma.f64 y x (+.f64 (-.f64 (*.f64 t z) (*.f64 (fma.f64 c b a) (*.f64 i c))) (+.f64 (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c))) (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (pow.f64 (cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i))) 3))))))
20.9b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (cbrt.f64 (pow.f64 (*.f64 c (fma.f64 c b a)) 3))))))
4.8b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a))))))
16.7b
(*.f64 2 (-.f64 (fma.f64 y x (*.f64 t z)) (*.f64 c (*.f64 c (*.f64 i b)))))
49.4b
(*.f64 2 (neg.f64 (+.f64 (*.f64 c (*.f64 a i)) (*.f64 (pow.f64 c 2) (*.f64 i b)))))
24.4b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (pow.f64 (sqrt.f64 (*.f64 (fma.f64 c b a) (*.f64 i c))) 2))))
1.5b
(*.f64 2 (fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))))
Compiler

Compiled 15387 to 2321 computations (84.9% saved)

localize27.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
4.5b
(*.f64 (fma.f64 c b a) (*.f64 i c))
13.3b
(cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i)))
47.0b
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (pow.f64 (cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i))) 3))
47.6b
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))

series3.7s (30.7%)

Counts
2 → 96
Calls

24 calls:

2.3s
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (pow.f64 (cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i))) 3))
a
0
664.0ms
(fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (pow.f64 (cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i))) 3))
b
0
145.0ms
(cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i)))
i
0
91.0ms
(cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i)))
i
-inf
85.0ms
(cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i)))
i
inf

rewrite60.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
625×log-prod_binary64
217×expm1-udef_binary64
217×log1p-udef_binary64
199×log-pow_binary64
149×fma-def_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01437
128834
2347432
Stop Event
node limit
Counts
2 → 61

simplify96.0ms (0.8%)

Algorithm
egg-herbie
Rules
280×times-frac_binary64
276×fma-neg_binary64
263×associate-*r*_binary64
238×associate-/l*_binary64
201×associate-/r*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
03465166
112404396
247274265
Stop Event
node limit
Counts
157 → 180

prune376.0ms (3.2%)

Pruning

9 alts after pruning (5 fresh and 4 done)

PrunedKeptTotal
New2650265
Fresh055
Picked011
Done033
Total2659274
Error
0b
Counts
274 → 9
Alt Table
StatusErrorProgram
5.8b
(*.f64 2 (fma.f64 y x (+.f64 (-.f64 (*.f64 t z) (*.f64 (fma.f64 c b a) (*.f64 i c))) (+.f64 (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c))) (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c)))))))
11.9b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 c (*.f64 i a)))))
9.3b
(*.f64 2 (fma.f64 y x (+.f64 (-.f64 (*.f64 t z) (*.f64 (fma.f64 c b a) (*.f64 i c))) (+.f64 (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (*.f64 (fma.f64 c b a) (*.f64 i c))) (fma.f64 (*.f64 (fma.f64 c b a) (neg.f64 c)) i (pow.f64 (cbrt.f64 (*.f64 c (*.f64 (fma.f64 c b a) i))) 3))))))
20.9b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (cbrt.f64 (pow.f64 (*.f64 c (fma.f64 c b a)) 3))))))
4.8b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (*.f64 i (*.f64 c (fma.f64 c b a))))))
16.7b
(*.f64 2 (-.f64 (fma.f64 y x (*.f64 t z)) (*.f64 c (*.f64 c (*.f64 i b)))))
49.4b
(*.f64 2 (neg.f64 (+.f64 (*.f64 c (*.f64 a i)) (*.f64 (pow.f64 c 2) (*.f64 i b)))))
24.4b
(*.f64 2 (fma.f64 y x (-.f64 (*.f64 t z) (pow.f64 (sqrt.f64 (*.f64 (fma.f64 c b a) (*.f64 i c))) 2))))
1.5b
(*.f64 2 (fma.f64 z t (fma.f64 (fma.f64 b c a) (*.f64 i (neg.f64 c)) (*.f64 x y))))
Compiler

Compiled 18704 to 5043 computations (73% saved)

regimes987.0ms (8.3%)

Accuracy

Total 2.0b remaining (99.2%)

Threshold costs 0b (0%)

Counts
57 → 1
Compiler

Compiled 27693 to 16259 computations (41.3% saved)

simplify3.0ms (0%)

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
01724
12624
23424
34024
44324
54424
Stop Event
saturated

end160.0ms (1.3%)

Stop Event
fuel
Remove

(sort z t)

(sort x y)

Compiler

Compiled 451 to 263 computations (41.7% saved)

Profiling

Loading profile data...