Details

Time bar (total: 4.4s)

analyze240.0ms (5.5%)

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
29.7%29.6%70.2%0.1%0%0%0%9
42.2%42.1%57.7%0.1%0%0%0%10
47.7%47.6%52.1%0.1%0.2%0%0%11
54.7%53.8%44.6%0.1%1.5%0%0%12
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample1.2s (26.6%)

Results
879.0ms8256×body256valid
265.0ms2167×body256infinite
Bogosity

preprocess208.0ms (4.8%)

Algorithm
egg-herbie
Rules
1612×fma-neg_binary64
563×fma-def_binary64
490×div-sub_binary64
453×associate-/l*_binary64
453×times-frac_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01640
13740
27340
314040
430740
563240
6157540
7364140
8429540
9457640
10473840
11479440
12572640
13577840
14599440
15685840
16768440
033
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 y (/.f64 (-.f64 x y) z))
(+.f64 z (/.f64 (-.f64 y z) x))
(+.f64 x (/.f64 (-.f64 z x) y))
Outputs
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 y (/.f64 (-.f64 x y) z))
(-.f64 y (/.f64 (-.f64 y x) z))
(+.f64 z (/.f64 (-.f64 y z) x))
(-.f64 z (/.f64 (-.f64 z y) x))
(+.f64 x (/.f64 (-.f64 z x) y))
(-.f64 x (/.f64 (-.f64 x z) y))
Compiler

Compiled 13 to 9 computations (30.8% saved)

simplify40.0ms (0.9%)

Algorithm
egg-herbie
Rules
377×fma-neg_binary64
307×fma-def_binary64
119×cancel-sign-sub-inv_binary64
77×distribute-rgt-in_binary64
56×unsub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11310
22410
34210
48810
516610
638510
772410
8121510
9150010
10159310
11167110
12167510
Stop Event
saturated
Counts
1 → 1
Calls
Call 1
Inputs
(+.f64 x (/.f64 (-.f64 y x) z))
Outputs
(+.f64 x (/.f64 (-.f64 y x) z))

eval0.0ms (0%)

Compiler

Compiled 10 to 6 computations (40% saved)

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.0b
Counts
2 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 x (/.f64 (-.f64 y x) z))
Compiler

Compiled 10 to 6 computations (40% saved)

localize7.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (/.f64 (-.f64 y x) z))
0.0b
(/.f64 (-.f64 y x) z)
Compiler

Compiled 21 to 6 computations (71.4% saved)

series9.0ms (0.2%)

Counts
2 → 60
Calls

18 calls:

TimeVariablePointExpression
1.0ms
x
@inf
(+.f64 x (/.f64 (-.f64 y x) z))
1.0ms
y
@-inf
(/.f64 (-.f64 y x) z)
1.0ms
x
@-inf
(/.f64 (-.f64 y x) z)
1.0ms
y
@inf
(/.f64 (-.f64 y x) z)
1.0ms
y
@0
(/.f64 (-.f64 y x) z)

rewrite68.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
462×log-prod_binary64
362×fma-def_binary64
354×exp-prod_binary64
315×pow-prod-down_binary64
248×pow2_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0717
116717
2273117
Stop Event
node limit
Counts
2 → 144
Calls
Call 1
Inputs
(/.f64 (-.f64 y x) z)
(+.f64 x (/.f64 (-.f64 y x) z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 y z) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) z))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) z)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 y z) (/.f64 x z))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (-.f64 y x) z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 y x) (/.f64 1 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (-.f64 y x) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) (pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) 2) (cbrt.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) (*.f64 (cbrt.f64 (-.f64 y x)) (/.f64 1 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (-.f64 y x) z)) (sqrt.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 y x)) (*.f64 (sqrt.f64 (-.f64 y x)) (/.f64 1 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (-.f64 y x)) (/.f64 1 (neg.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 z) (-.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) 1) (/.f64 (cbrt.f64 (-.f64 y x)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (-.f64 y x)) 1) (/.f64 (sqrt.f64 (-.f64 y x)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 z) -2) (/.f64 (-.f64 y x) (cbrt.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) (pow.f64 (cbrt.f64 z) 2)) (cbrt.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (-.f64 y x)) (pow.f64 (cbrt.f64 z) 2)) (/.f64 (sqrt.f64 (-.f64 y x)) (cbrt.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 z -1/2) (/.f64 (-.f64 y x) (sqrt.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) (sqrt.f64 z)) (/.f64 (cbrt.f64 (-.f64 y x)) (sqrt.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 y x) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (-.f64 y x) z) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (-.f64 y x) z)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (-.f64 y x) z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 z (-.f64 y x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 z (-.f64 y x)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (/.f64 (-.f64 y x) z))) 2)) (cbrt.f64 (log.f64 (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (/.f64 (-.f64 y x) z)))) (sqrt.f64 (log.f64 (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (-.f64 y x) (neg.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (-.f64 y x) z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (-.f64 y x) z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) z)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 (-.f64 y x) z))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 (-.f64 y x) z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (/.f64 (-.f64 y x) z))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 z (-.f64 y x))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) z)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 (-.f64 y x) z)) 3) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 (-.f64 y x)) 1) (log.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (-.f64 y x)) (*.f64 (log.f64 z) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 (-.f64 y x)) 1) (*.f64 (log.f64 z) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (/.f64 1 z) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 y z) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 y z)) 2) (cbrt.f64 (/.f64 y z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 y z)) (sqrt.f64 (/.f64 y z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 z) -2) (/.f64 y (cbrt.f64 z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 z -1/2) (/.f64 y (sqrt.f64 z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 1) (/.f64 (cbrt.f64 y) z) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 y) 1) (/.f64 (sqrt.f64 y) z) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (pow.f64 (cbrt.f64 z) 2)) (/.f64 (cbrt.f64 y) (cbrt.f64 z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 y) (pow.f64 (cbrt.f64 z) 2)) (/.f64 (sqrt.f64 y) (cbrt.f64 z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (sqrt.f64 z)) (/.f64 (cbrt.f64 y) (sqrt.f64 z)) (neg.f64 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 y) (sqrt.f64 z)) (/.f64 (sqrt.f64 y) (sqrt.f64 z)) (neg.f64 (/.f64 x z)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 y z) (-.f64 (/.f64 x z) x))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (+.f64 x (/.f64 (-.f64 y x) z)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 x x) (-.f64 x (/.f64 (-.f64 y x) z))) (/.f64 (pow.f64 (/.f64 (-.f64 y x) z) 2) (-.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (/.f64 (-.f64 y x) z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 x (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))) (pow.f64 (cbrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))) 2) (cbrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))) (sqrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (-.f64 y x) z) 3)) (/.f64 1 (fma.f64 (/.f64 (-.f64 y x) z) (-.f64 (/.f64 (-.f64 y x) z) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 (-.f64 y x) z) 2)) (/.f64 1 (-.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (/.f64 (-.f64 y x) z) (-.f64 (/.f64 (-.f64 y x) z) x) (*.f64 x x)) (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (-.f64 y x) z) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 x (/.f64 (-.f64 y x) z)) (-.f64 (*.f64 x x) (pow.f64 (/.f64 (-.f64 y x) z) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (-.f64 y x) z) 3)) (fma.f64 (/.f64 (-.f64 y x) z) (-.f64 (/.f64 (-.f64 y x) z) x) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (-.f64 y x) z) 3)) (+.f64 (pow.f64 (/.f64 (-.f64 y x) z) 2) (-.f64 (*.f64 x x) (*.f64 x (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 (-.f64 y x) z) 2)) (-.f64 x (/.f64 (-.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (-.f64 y x) z) 3))) (neg.f64 (fma.f64 (/.f64 (-.f64 y x) z) (-.f64 (/.f64 (-.f64 y x) z) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 (-.f64 y x) z) 2))) (neg.f64 (-.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (/.f64 (-.f64 y x) z) 2) (*.f64 x x)) (-.f64 (/.f64 (-.f64 y x) z) x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 x (/.f64 (-.f64 y x) z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 x (/.f64 (-.f64 y x) z)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 x (/.f64 (-.f64 y x) z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 x (/.f64 (-.f64 y x) z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (/.f64 (-.f64 y x) z) (-.f64 (/.f64 (-.f64 y x) z) x) (*.f64 x x)) (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (-.f64 y x) z) 3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 x (/.f64 (-.f64 y x) z)) (-.f64 (*.f64 x x) (pow.f64 (/.f64 (-.f64 y x) z) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z)))) 2)) (cbrt.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z))))) (sqrt.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 x (/.f64 (-.f64 y x) z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (+.f64 x (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 x)) (exp.f64 (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 x) (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 x)) (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) z))) (exp.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (/.f64 (-.f64 y x) z)) (+.f64 1 (expm1.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (/.f64 (-.f64 y x) z))) (+.f64 1 (expm1.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 x (/.f64 (-.f64 y x) z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (+.f64 x (/.f64 (-.f64 y x) z)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (+.f64 x (/.f64 (-.f64 y x) z)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (+.f64 x (/.f64 (-.f64 y x) z))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (/.f64 1 z) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 1 (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 y x) (/.f64 1 z) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (-.f64 y x) z) 1 x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 x (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 (-.f64 y x) z) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 y z) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) (pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) 2) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 y x) z)) 2) (cbrt.f64 (/.f64 (-.f64 y x) z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 x) (pow.f64 (cbrt.f64 x) 2) (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 x) (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) (*.f64 (cbrt.f64 (-.f64 y x)) (/.f64 1 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 (-.f64 y x) z)) (sqrt.f64 (/.f64 (-.f64 y x) z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (sqrt.f64 x) (/.f64 (-.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 y x)) (*.f64 (sqrt.f64 (-.f64 y x)) (/.f64 1 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (-.f64 y x)) (/.f64 1 (neg.f64 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 z) (-.f64 y x) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (/.f64 y z)) 2) (cbrt.f64 (/.f64 y z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 y z)) (sqrt.f64 (/.f64 y z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) 1) (/.f64 (cbrt.f64 (-.f64 y x)) z) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 (-.f64 y x)) 1) (/.f64 (sqrt.f64 (-.f64 y x)) z) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 z) -2) (/.f64 (-.f64 y x) (cbrt.f64 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 z) -2) (/.f64 y (cbrt.f64 z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) (pow.f64 (cbrt.f64 z) 2)) (cbrt.f64 (/.f64 (-.f64 y x) z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 (-.f64 y x)) (pow.f64 (cbrt.f64 z) 2)) (/.f64 (sqrt.f64 (-.f64 y x)) (cbrt.f64 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 z -1/2) (/.f64 (-.f64 y x) (sqrt.f64 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 z -1/2) (/.f64 y (sqrt.f64 z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 y x)) 2) (sqrt.f64 z)) (/.f64 (cbrt.f64 (-.f64 y x)) (sqrt.f64 z)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 1) (/.f64 (cbrt.f64 y) z) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 y) 1) (/.f64 (sqrt.f64 y) z) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (pow.f64 (cbrt.f64 z) 2)) (/.f64 (cbrt.f64 y) (cbrt.f64 z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 y) (pow.f64 (cbrt.f64 z) 2)) (/.f64 (sqrt.f64 y) (cbrt.f64 z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (sqrt.f64 z)) (/.f64 (cbrt.f64 y) (sqrt.f64 z)) (neg.f64 (-.f64 (/.f64 x z) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (sqrt.f64 y) (sqrt.f64 z)) (/.f64 (sqrt.f64 y) (sqrt.f64 z)) (neg.f64 (-.f64 (/.f64 x z) x)))))))

simplify58.0ms (1.3%)

Algorithm
egg-herbie
Rules
325×fma-def_binary64
311×fma-neg_binary64
73×distribute-rgt-in_binary64
71×cancel-sign-sub-inv_binary64
45×sub-neg_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
027661
161585
2107468
3199468
4368468
5661468
61026468
71232468
81331468
91412468
101502468
Stop Event
saturated
Counts
204 → 161
Calls
Call 1
Inputs
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 y z)
(+.f64 (*.f64 (-.f64 1 (/.f64 1 z)) x) (/.f64 y z))
(+.f64 (*.f64 (-.f64 1 (/.f64 1 z)) x) (/.f64 y z))
(+.f64 (*.f64 (-.f64 1 (/.f64 1 z)) x) (/.f64 y z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(+.f64 (/.f64 y z) (*.f64 (-.f64 1 (/.f64 1 z)) x))
(+.f64 (/.f64 y z) (*.f64 (-.f64 1 (/.f64 1 z)) x))
(+.f64 (/.f64 y z) (*.f64 (-.f64 1 (/.f64 1 z)) x))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(+.f64 (*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x)) (/.f64 y z))
(+.f64 (*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x)) (/.f64 y z))
(+.f64 (*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x)) (/.f64 y z))
(-.f64 x (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(/.f64 y z)
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (+.f64 x (/.f64 y z)))
(+.f64 (*.f64 -1 (/.f64 x z)) (+.f64 x (/.f64 y z)))
(+.f64 (*.f64 -1 (/.f64 x z)) (+.f64 x (/.f64 y z)))
(/.f64 (-.f64 y x) z)
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
x
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
x
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
Outputs
(*.f64 -1 (/.f64 x z))
(neg.f64 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 x z))
(neg.f64 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 x z))
(neg.f64 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(/.f64 (-.f64 y x) z)
(/.f64 y z)
(+.f64 (*.f64 (-.f64 1 (/.f64 1 z)) x) (/.f64 y z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (*.f64 (-.f64 1 (/.f64 1 z)) x) (/.f64 y z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (*.f64 (-.f64 1 (/.f64 1 z)) x) (/.f64 y z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (/.f64 y z) (*.f64 (-.f64 1 (/.f64 1 z)) x))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (/.f64 y z) (*.f64 (-.f64 1 (/.f64 1 z)) x))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (/.f64 y z) (*.f64 (-.f64 1 (/.f64 1 z)) x))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x)) (/.f64 y z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x)) (/.f64 y z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x)) (/.f64 y z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 x (/.f64 x z))
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(/.f64 y z)
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (+.f64 x (/.f64 y z)))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (*.f64 -1 (/.f64 x z)) (+.f64 x (/.f64 y z)))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(+.f64 (*.f64 -1 (/.f64 x z)) (+.f64 x (/.f64 y z)))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(/.f64 (-.f64 y x) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 x (/.f64 y z)) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
x
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
x
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(-.f64 (+.f64 (/.f64 y z) x) (/.f64 x z))
(fma.f64 (-.f64 1 (/.f64 1 z)) x (/.f64 y z))
(fma.f64 x (-.f64 1 (/.f64 1 z)) (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))

eval30.0ms (0.7%)

Compiler

Compiled 2175 to 675 computations (69% saved)

prune24.0ms (0.6%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New1574161
Fresh000
Picked011
Done000
Total1575162
Error
0b
Counts
162 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
24.3b
(-.f64 x (/.f64 x z))
13.8b
(+.f64 x (/.f64 y z))
37.4b
x
25.8b
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
0.0b
(+.f64 x (/.f64 (-.f64 y x) z))
Compiler

Compiled 41 to 26 computations (36.6% saved)

localize5.0ms (0.1%)

Compiler

Compiled 14 to 5 computations (64.3% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(-.f64 x (/.f64 x z))
Compiler

Compiled 13 to 5 computations (61.5% saved)

series2.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@inf
(-.f64 x (/.f64 x z))
0.0ms
x
@0
(-.f64 x (/.f64 x z))
0.0ms
z
@-inf
(-.f64 x (/.f64 x z))
0.0ms
z
@inf
(-.f64 x (/.f64 x z))
0.0ms
x
@-inf
(-.f64 x (/.f64 x z))

rewrite51.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
726×pow1_binary64
678×add-log-exp_binary64
678×log1p-expm1-u_binary64
678×expm1-log1p-u_binary64
663×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
11167
217897
Stop Event
node limit
Counts
1 → 36
Calls
Call 1
Inputs
(-.f64 x (/.f64 x z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 x (/.f64 (neg.f64 x) z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 x (*.f64 (/.f64 (neg.f64 x) z) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 x (/.f64 x z)) (fma.f64 (neg.f64 (/.f64 1 z)) x (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 x (/.f64 x z)) (fma.f64 (/.f64 (neg.f64 x) z) 1 (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 x (/.f64 x z)) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 x z))) (pow.f64 (cbrt.f64 (/.f64 x z)) 2) (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 x (/.f64 x z)) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 x z))) (sqrt.f64 (/.f64 x z)) (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (neg.f64 x) z) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 x (/.f64 x z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 x (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 x (/.f64 x z))) (pow.f64 (cbrt.f64 (-.f64 x (/.f64 x z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 x (/.f64 x z))) 2) (cbrt.f64 (-.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 x (/.f64 x z))) (sqrt.f64 (-.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x 3) (pow.f64 (/.f64 x z) 3)) (/.f64 1 (fma.f64 x x (*.f64 (/.f64 x z) (+.f64 x (/.f64 x z))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 x z) 2)) (/.f64 1 (+.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 x) (sqrt.f64 (/.f64 x z))) (-.f64 (sqrt.f64 x) (sqrt.f64 (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 x x (*.f64 (/.f64 x z) (+.f64 x (/.f64 x z)))) (-.f64 (pow.f64 x 3) (pow.f64 (/.f64 x z) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 x (/.f64 x z)) (-.f64 (*.f64 x x) (pow.f64 (/.f64 x z) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x 3) (pow.f64 (/.f64 x z) 3)) (fma.f64 x x (*.f64 (/.f64 x z) (+.f64 x (/.f64 x z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 x z) 2)) (+.f64 x (/.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x 3) (pow.f64 (/.f64 x z) 3))) (neg.f64 (fma.f64 x x (*.f64 (/.f64 x z) (+.f64 x (/.f64 x z))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (/.f64 x z) 2))) (neg.f64 (+.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x 3) (pow.f64 (/.f64 (neg.f64 x) z) 3)) (+.f64 (*.f64 x x) (-.f64 (*.f64 (/.f64 (neg.f64 x) z) (/.f64 (neg.f64 x) z)) (*.f64 x (/.f64 (neg.f64 x) z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 x x) (*.f64 (/.f64 (neg.f64 x) z) (/.f64 (neg.f64 x) z))) (-.f64 x (/.f64 (neg.f64 x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 x (/.f64 x z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 x (/.f64 x z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 x (/.f64 x z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 x (/.f64 x z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 x (/.f64 x z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 x (/.f64 x z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 x (/.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 x (/.f64 (neg.f64 x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 x) (/.f64 (neg.f64 x) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (sqrt.f64 x) (/.f64 (neg.f64 x) z))))))

simplify23.0ms (0.5%)

Algorithm
egg-herbie
Rules
148×fma-def_binary64
74×fma-neg_binary64
28×distribute-rgt-in_binary64
25×distribute-lft-in_binary64
23×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
014218
132218
267155
3132155
4223155
5385155
6621155
7649155
Stop Event
saturated
Counts
60 → 43
Calls
Call 1
Inputs
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
x
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
x
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
Outputs
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 -1 (*.f64 (-.f64 (/.f64 1 z) 1) x))
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(*.f64 -1 (/.f64 x z))
(neg.f64 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
x
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
x
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) x)
(*.f64 (-.f64 1 (/.f64 1 z)) x)
(*.f64 x (-.f64 1 (/.f64 1 z)))
(-.f64 x (/.f64 x z))

localize8.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
Compiler

Compiled 21 to 8 computations (61.9% saved)

series6.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
2.0ms
z
@-inf
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
1.0ms
z
@inf
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
1.0ms
z
@0
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
1.0ms
x
@-inf
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
0.0ms
x
@0
(fma.f64 -1 (/.f64 x z) (/.f64 y z))

rewrite51.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
870×pow1_binary64
801×add-log-exp_binary64
801×log1p-expm1-u_binary64
801×expm1-log1p-u_binary64
784×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0811
116311
2210811
Stop Event
node limit
Counts
1 → 21
Calls
Call 1
Inputs
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 y z) (/.f64 (neg.f64 x) z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (neg.f64 x) z) (/.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (/.f64 (neg.f64 x) z) 1) (/.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 -1 (/.f64 x z) (/.f64 y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) (pow.f64 (cbrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) 2) (cbrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) (sqrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (/.f64 (neg.f64 x) z) 3) (pow.f64 (/.f64 y z) 3)) (+.f64 (*.f64 (/.f64 (neg.f64 x) z) (/.f64 (neg.f64 x) z)) (-.f64 (pow.f64 (/.f64 y z) 2) (*.f64 (/.f64 (neg.f64 x) z) (/.f64 y z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (/.f64 (neg.f64 x) z) (/.f64 (neg.f64 x) z)) (pow.f64 (/.f64 y z) 2)) (-.f64 (/.f64 (neg.f64 x) z) (/.f64 y z)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 -1 (/.f64 x z) (/.f64 y z))))))))

simplify63.0ms (1.4%)

Algorithm
egg-herbie
Rules
279×fma-def_binary64
135×fma-neg_binary64
54×unsub-neg_binary64
46×cancel-sign-sub-inv_binary64
41×div-sub_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
016360
132330
259240
395240
4179240
5365240
6672240
71022240
81066240
91097240
101102240
Stop Event
saturated
Counts
57 → 28
Calls
Call 1
Inputs
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(*.f64 -1 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
Outputs
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(neg.f64 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(neg.f64 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 (+.f64 y (*.f64 -1 x)) z)
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 (+.f64 (*.f64 -1 y) x) z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(*.f64 -1 (/.f64 x z))
(/.f64 (neg.f64 x) z)
(neg.f64 (/.f64 x z))
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(/.f64 y z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)
(+.f64 (*.f64 -1 (/.f64 x z)) (/.f64 y z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
(-.f64 (/.f64 y z) (/.f64 x z))
(/.f64 (-.f64 y x) z)

eval149.0ms (3.4%)

Compiler

Compiled 845 to 289 computations (65.8% saved)

prune12.0ms (0.3%)

Pruning

6 alts after pruning (4 fresh and 2 done)

PrunedKeptTotal
New67471
Fresh101
Picked101
Done123
Total70676
Error
0b
Counts
76 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
37.4b
x
13.8b
(+.f64 x (/.f64 y z))
25.7b
(/.f64 (-.f64 y x) z)
39.5b
(/.f64 y z)
24.3b
(-.f64 x (/.f64 x z))
49.0b
(/.f64 (neg.f64 x) z)
Compiler

Compiled 41 to 27 computations (34.1% saved)

localize3.0ms (0.1%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize5.0ms (0.1%)

Compiler

Compiled 11 to 5 computations (54.5% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (-.f64 y x) z)
Compiler

Compiled 14 to 5 computations (64.3% saved)

eval12.0ms (0.3%)

Compiler

Compiled 735 to 250 computations (66% saved)

prune12.0ms (0.3%)

Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New68068
Fresh011
Picked011
Done044
Total68674
Error
0b
Counts
74 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
37.4b
x
13.8b
(+.f64 x (/.f64 y z))
25.7b
(/.f64 (-.f64 y x) z)
39.5b
(/.f64 y z)
24.3b
(-.f64 x (/.f64 x z))
49.0b
(/.f64 (neg.f64 x) z)
Compiler

Compiled 41 to 27 computations (34.1% saved)

eval0.0ms (0%)

Compiler

Compiled 3 to 3 computations (0% saved)

prune3.0ms (0.1%)

Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done055
Total066
Error
0b
Counts
6 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
37.4b
x
13.8b
(+.f64 x (/.f64 y z))
25.7b
(/.f64 (-.f64 y x) z)
39.5b
(/.f64 y z)
24.3b
(-.f64 x (/.f64 x z))
49.0b
(/.f64 (neg.f64 x) z)
Compiler

Compiled 41 to 27 computations (34.1% saved)

regimes27.0ms (0.6%)

Counts
9 → 1
Calls
Call 1
Inputs
x
x
(/.f64 y z)
(/.f64 (neg.f64 x) z)
(/.f64 (-.f64 y x) z)
(-.f64 x (/.f64 x z))
(+.f64 x (/.f64 y z))
(+.f64 x (/.f64 (-.f64 y x) z))
(fma.f64 -1 (/.f64 x z) (/.f64 y z))
Outputs
(+.f64 x (/.f64 (-.f64 y x) z))
Calls

4 calls:

7.0ms
x
6.0ms
y
6.0ms
(+.f64 x (/.f64 (-.f64 y x) z))
6.0ms
z
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1z
0.0b1(+.f64 x (/.f64 (-.f64 y x) z))
Compiler

Compiled 64 to 29 computations (54.7% saved)

regimes63.0ms (1.5%)

Counts
7 → 3
Calls
Call 1
Inputs
x
x
(/.f64 y z)
(/.f64 (neg.f64 x) z)
(/.f64 (-.f64 y x) z)
(-.f64 x (/.f64 x z))
(+.f64 x (/.f64 y z))
Outputs
(+.f64 x (/.f64 y z))
(/.f64 (-.f64 y x) z)
(+.f64 x (/.f64 y z))
Calls

3 calls:

28.0ms
x
19.0ms
y
14.0ms
z
Results
ErrorSegmentsBranch
11.5b2x
6.0b3y
0.3b3z
Compiler

Compiled 39 to 20 computations (48.7% saved)

bsearch17.0ms (0.4%)

Algorithm
binary-search
Steps
TimeLeftRight
16.0ms
6.472231787234202e-7
855526.8602279826
0.0ms
-9.193223774454409e+24
-8.907729106168405e+24
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes207.0ms (4.7%)

Counts
6 → 5
Calls
Call 1
Inputs
x
x
(/.f64 y z)
(/.f64 (neg.f64 x) z)
(/.f64 (-.f64 y x) z)
(-.f64 x (/.f64 x z))
Outputs
x
(/.f64 (-.f64 y x) z)
(-.f64 x (/.f64 x z))
(/.f64 y z)
(-.f64 x (/.f64 x z))
Calls

3 calls:

156.0ms
z
30.0ms
y
19.0ms
x
Results
ErrorSegmentsBranch
12.9b3x
14.7b5y
9.1b5z
Compiler

Compiled 34 to 19 computations (44.1% saved)

bsearch67.0ms (1.5%)

Algorithm
binary-search
Steps
TimeLeftRight
17.0ms
1.7243604846030907e+148
2.109292762670114e+149
16.0ms
2.8439207904081147e+128
1.3199762650369755e+130
17.0ms
855526.8602279826
2501547657.856695
17.0ms
-1.294707571850147e+80
-9.837373853363432e+75
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes229.0ms (5.3%)

Counts
5 → 5
Calls
Call 1
Inputs
x
x
(/.f64 y z)
(/.f64 (neg.f64 x) z)
(/.f64 (-.f64 y x) z)
Outputs
x
(/.f64 (-.f64 y x) z)
x
(/.f64 y z)
x
Calls

3 calls:

150.0ms
x
42.0ms
z
36.0ms
y
Results
ErrorSegmentsBranch
15.7b5x
19.7b9y
9.2b5z
Compiler

Compiled 29 to 17 computations (41.4% saved)

bsearch68.0ms (1.6%)

Algorithm
binary-search
Steps
TimeLeftRight
16.0ms
1.7243604846030907e+148
2.109292762670114e+149
19.0ms
2.8439207904081147e+128
1.3199762650369755e+130
16.0ms
310141886876.70105
76311442860632.16
17.0ms
-1.294707571850147e+80
-9.837373853363432e+75
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes269.0ms (6.2%)

Counts
4 → 9
Calls
Call 1
Inputs
x
x
(/.f64 y z)
(/.f64 (neg.f64 x) z)
Outputs
x
(/.f64 y z)
(/.f64 (neg.f64 x) z)
(/.f64 y z)
(/.f64 (neg.f64 x) z)
(/.f64 y z)
x
(/.f64 y z)
x
Calls

3 calls:

197.0ms
y
52.0ms
z
18.0ms
x
Results
ErrorSegmentsBranch
25.1b5x
25.5b8y
18.7b9z
Compiler

Compiled 24 to 15 computations (37.5% saved)

bsearch630.0ms (14.4%)

Algorithm
binary-search
Steps
TimeLeftRight
49.0ms
1.7243604846030907e+148
2.109292762670114e+149
17.0ms
2.8439207904081147e+128
1.3199762650369755e+130
182.0ms
310141886876.70105
76311442860632.16
17.0ms
1.293935249322462e-16
2.4788496516505026e-15
184.0ms
1.2478834023735621e-166
2.8174320613872145e-165
19.0ms
-1.964074810213814e-228
-9.009876131342992e-256
19.0ms
-3.0531896805934778e-9
-1.6179776088093436e-12
142.0ms
-1.294707571850147e+80
-9.837373853363432e+75
Compiler

Compiled 286 to 209 computations (26.9% saved)

regimes95.0ms (2.2%)

Counts
3 → 5
Calls
Call 1
Inputs
x
x
(/.f64 y z)
Outputs
x
(/.f64 y z)
x
(/.f64 y z)
x
Calls

3 calls:

54.0ms
x
22.0ms
y
18.0ms
z
Results
ErrorSegmentsBranch
25.1b5x
28.3b5y
22.9b5z
Compiler

Compiled 20 to 13 computations (35% saved)

bsearch223.0ms (5.1%)

Algorithm
binary-search
Steps
TimeLeftRight
17.0ms
1.7243604846030907e+148
2.109292762670114e+149
141.0ms
2.8439207904081147e+128
1.3199762650369755e+130
19.0ms
310141886876.70105
76311442860632.16
46.0ms
-1.294707571850147e+80
-9.837373853363432e+75
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes120.0ms (2.7%)

Accuracy

Total 0.0b remaining (0%)

Threshold costs 0.0b (0%)

Counts
2 → 1
Calls
Call 1
Inputs
x
x
Outputs
x
Calls

3 calls:

112.0ms
y
3.0ms
x
3.0ms
z
Results
ErrorSegmentsBranch
37.4b1x
37.4b1y
37.4b1z
Compiler

Compiled 17 to 12 computations (29.4% saved)

simplify14.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
053246
163246
269246
372246
473246
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(+.f64 x (/.f64 (-.f64 y x) z))
(if (<=.f64 z -9000000000000000385875968) (+.f64 x (/.f64 y z)) (if (<=.f64 z 6112850092279659/9444732965739290427392) (/.f64 (-.f64 y x) z) (+.f64 x (/.f64 y z))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z 7348919771057497/8589934592) (/.f64 (-.f64 y x) z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) (-.f64 x (/.f64 x z)) (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) (-.f64 x (/.f64 x z))))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z 2540682337293935/8192) (/.f64 (-.f64 y x) z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) x (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) x))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z -1845539918525199/604462909807314587353088) (/.f64 y z) (if (<=.f64 z -121507742161203/132073632783916311588084946229129151629711831509030380531990177256668475639181214868604313971914296973668598748314282169720586889875671384312634744615734894227096670999751271042182879419106610263256058227052797101037007073187890434709599224691759119122384645224434499584) (/.f64 (neg.f64 x) z) (if (<=.f64 z 4149515568880993/33196124551047943668099262909529289208099569857939495199965258637525222491303265171197656391576830354305583092890406313459161208603294202463094998672911709496489454427212076189483008) (/.f64 y z) (if (<=.f64 z 656103118184033/5070602400912917605986812821504) (/.f64 (neg.f64 x) z) (if (<=.f64 z 2540682337293935/8192) (/.f64 y z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) x (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) x))))))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z 2540682337293935/8192) (/.f64 y z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) x (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) x))))
x
Outputs
(+.f64 x (/.f64 (-.f64 y x) z))
(if (<=.f64 z -9000000000000000385875968) (+.f64 x (/.f64 y z)) (if (<=.f64 z 6112850092279659/9444732965739290427392) (/.f64 (-.f64 y x) z) (+.f64 x (/.f64 y z))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z 7348919771057497/8589934592) (/.f64 (-.f64 y x) z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) (-.f64 x (/.f64 x z)) (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) (-.f64 x (/.f64 x z))))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z 2540682337293935/8192) (/.f64 (-.f64 y x) z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) x (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) x))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z -1845539918525199/604462909807314587353088) (/.f64 y z) (if (<=.f64 z -121507742161203/132073632783916311588084946229129151629711831509030380531990177256668475639181214868604313971914296973668598748314282169720586889875671384312634744615734894227096670999751271042182879419106610263256058227052797101037007073187890434709599224691759119122384645224434499584) (/.f64 (neg.f64 x) z) (if (<=.f64 z 4149515568880993/33196124551047943668099262909529289208099569857939495199965258637525222491303265171197656391576830354305583092890406313459161208603294202463094998672911709496489454427212076189483008) (/.f64 y z) (if (<=.f64 z 656103118184033/5070602400912917605986812821504) (/.f64 (neg.f64 x) z) (if (<=.f64 z 2540682337293935/8192) (/.f64 y z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) x (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) x))))))))
(if (<=.f64 z -129470757185014694543302797839948365494292397106623677336393218260487799830478848) x (if (<=.f64 z 2540682337293935/8192) (/.f64 y z) (if (<=.f64 z 284392079040811468240409822133974407153945084439114967662891390913935369716704244935204725142028100615307651759662715151000272896) x (if (<=.f64 z 17243604846030907149798874389893204284546495886711024894201779540505596561596538656547768489194852415790212765154367771388943092250889212273969070080) (/.f64 y z) x))))
x
Compiler

Compiled 194 to 106 computations (45.4% saved)

soundness0.0ms (0%)

end71.0ms (1.6%)

Compiler

Compiled 176 to 78 computations (55.7% saved)

Profiling

Loading profile data...